/*-----------------------------------------------------------------------
Template Name      : Prachite - Temple Church And Mosque Website HTML Template
Author             : pus_infotech
Author Portfolio   : https://themeforest.net/user/pus_infotech 
Version            : 1.0.0 
-----------------------------------------------------------------------
CSS TABLE OF CONTENTS
-----------------------------------------------------------------------
- base 
    - variables
    - mixin
    - reset
    - typography
    - forms

- components 
    - accordion
    - breadcrumb
    - buttons
    - offcanvus
    - widget

- theme
    - animations
    - common
    - preloader 
    - spacing
    - theme-class
 
- layout
    -header
        - header
        - meanmenu
    - footer 
        - footer
    - section 
        - about 
        - authentication
        - blog
        - breadcrumb
        - campaigns
        - cart
        - checkout
        - comingsoon
        - contact
        - counter
        - courses
        - cta
        - donate
        - event
        - faq
        - gallery
        - hero
        - how-it-work
        - instagram
        - marquee
        - micon
        - mission
        - page
        - partners
        - prayer
        - pricing
        - product
        - progress
        - services
        - shop
        - team
        - testimonials
        - upcomming-event
        - video
        - why
        - wishlist
        
Main Style file-> assets/css/main.css
-----------------------------------------------------------------------*/

/* Brand primary — deep maroon (replaces theme orange) */
:root {
    --primary-color: #470804;
    --primary-rgb-05: rgba(71, 8, 4, 0.50);
    --primary-rgb-06: rgba(71, 8, 4, 0.06);
    --extra-color: #F5EBEA;
}

/* Global mobile stability — no horizontal shift / side gap */
html {
    overflow-x: clip;
    width: 100%;
}

body {
    overflow-x: clip;
    width: 100%;
    max-width: 100%;
    margin: 0;
}

.page-wrapper {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: clip;
}

img,
video,
iframe,
svg {
    max-width: 100%;
    height: auto;
}

/* Global typography — bolder text + larger headings (KashiBhakti) */
body {
    font-weight: 500;
}

p,
li,
label,
.about-content p,
.section-title-content p,
.section-title p {
    font-weight: 500;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 700;
}

h1 {
    font-size: 72px;
}

h2 {
    font-size: 56px;
}

h3 {
    font-size: 24px;
    font-weight: 700;
}

h4 {
    font-size: 1.85rem;
    font-weight: 700;
}

h5 {
    font-size: 1.55rem;
    font-weight: 600;
}

h6 {
    font-size: 1.3rem;
    font-weight: 600;
}

.section-title h2,
.section-title-white h2 {
    font-size: 44px;
    font-weight: 700;
}

.section-title .sub-title,
.sub-title {
    font-weight: 600;
}

.breadcrumb-section .breadcrumb-wapper .breadcrumb-content .breadcrumb-title h1 {
    font-weight: 700;
}

.breadcrumb-section .breadcrumb-wapper .breadcrumb-content:has(.breadcrumb-shlok) .breadcrumb-title h1 {
    margin-bottom: 14px;
}

.breadcrumb-shlok {
    text-align: center;
    margin: 0 auto 20px;
    padding: 0 16px;
    max-width: 820px;
}

.breadcrumb-shlok__heading {
    margin: 0 0 8px;
    color: #ffffff;
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.15rem, 2vw, 1.5rem);
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.02em;
}

.breadcrumb-shlok__text {
    margin: 0;
    color: rgba(255, 255, 255, 0.92);
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(0.95rem, 1.5vw, 1.1rem);
    font-weight: 500;
    line-height: 1.65;
    letter-spacing: 0.01em;
}

.widget .widget-title h3 {
    font-weight: 700;
}

@media (max-width: 1399px) {
    h1 {
        font-size: 56px;
    }

    .section-title h2,
    .section-title-white h2 {
        font-size: 42px;
    }
}

@media (max-width: 991px) {
    body {
        font-weight: 500;
    }

    h1 {
        font-size: 50px;
    }

    h2 {
        font-size: 44px;
    }

    .section-title h2,
    .section-title-white h2 {
        font-size: 40px;
    }
}

@media (max-width: 767px) {
    h1 {
        font-size: 38px;
    }

    h2 {
        font-size: 38px;
    }

    h3 {
        font-size: 22px;
    }

    .section-title h2,
    .section-title-white h2 {
        font-size: 36px;
    }
}

/* Main navigation — refined under premium header */
.kb-header .main-menu ul .nav-item .nav-link,
.kb-header #mobile-menu ul .nav-item .nav-link {
    font-size: 15px !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em;
}

.mean-container .mean-nav > ul li a:not(.mean-expand) {
    font-size: 16px !important;
    font-weight: 600 !important;
}

/* Testimonials / devotee experiences — premium spiritual travel (KashiBhakti) */
.kb-testimonials-section {
    position: relative;
    overflow: hidden;
    padding: 80px 0 72px;
    background:
        radial-gradient(ellipse 80% 60% at 15% 20%, rgba(255, 193, 7, 0.12) 0%, transparent 55%),
        radial-gradient(ellipse 70% 55% at 85% 75%, rgba(255, 193, 7, 0.08) 0%, transparent 50%),
        linear-gradient(145deg, #3d0703 0%, #470804 32%, #5c120d 58%, #3d0703 100%);
}

.kb-testimonials-section::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.22;
    background-image: radial-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px);
    background-size: 24px 24px;
    z-index: 0;
}

.kb-testimonials-section::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse at center, transparent 42%, rgba(20, 0, 0, 0.35) 100%);
    z-index: 0;
}

.kb-testimonials-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-testimonials-section__orb--one {
    width: 340px;
    height: 340px;
    top: -100px;
    right: -80px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.16) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-testimonials-section__orb--two {
    width: 280px;
    height: 280px;
    bottom: -70px;
    left: -60px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.14) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-testimonials-section__motif {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 193, 7, 0.14);
    opacity: 0.35;
}

.kb-testimonials-section__motif--one {
    width: 140px;
    height: 140px;
    top: 18%;
    left: 4%;
}

.kb-testimonials-section__motif--two {
    width: 90px;
    height: 90px;
    bottom: 16%;
    right: 6%;
}

.kb-testimonials-section .container {
    position: relative;
    z-index: 1;
}

.kb-testimonials-section__header.section-title-area {
    align-items: flex-end;
    gap: 28px 48px;
    margin-bottom: 48px;
}

.kb-testimonials-section__title.section-title {
    max-width: 560px;
}

.kb-testimonials-section__title.section-title .sub-title {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 193, 7, 0.28);
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.92);
}

.kb-testimonials-section__title.section-title h2 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.875rem, 3.2vw, 2.75rem);
    line-height: 1.2;
    color: var(--white-color, #ffffff);
    margin-top: 6px;
}

.kb-testimonials-section__intro-wrap.section-title-content {
    max-width: 460px;
    align-items: flex-end;
    justify-content: flex-end;
}

.kb-testimonials-section__intro {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 16px;
    line-height: 1.78;
    font-weight: 500;
    text-align: right;
    max-width: 42ch;
}

.kb-testimonials-section__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 40px 56px;
    align-items: stretch;
}

.kb-testimonials-section__slider-col,
.kb-testimonials-section__visual-col {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
}

.kb-testimonials-section__slider-wrap.testimonials-wapper {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    width: 100%;
    background: linear-gradient(160deg, rgba(255, 252, 247, 0.98) 0%, rgba(248, 242, 230, 0.96) 100%);
    padding: 36px 36px 28px;
    border-radius: 30px;
    border: 1px solid rgba(255, 255, 255, 0.65);
    box-shadow:
        0 4px 12px rgba(0, 0, 0, 0.08),
        0 24px 56px rgba(0, 0, 0, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
    transition: box-shadow 0.45s ease, transform 0.45s ease;
}

.kb-testimonials-section__slider-wrap.testimonials-wapper:hover {
    box-shadow:
        0 8px 20px rgba(0, 0, 0, 0.1),
        0 32px 64px rgba(0, 0, 0, 0.22),
        0 0 40px rgba(255, 193, 7, 0.08);
}

.kb-testimonials-section .testimonials-slider-one {
    overflow: hidden;
    width: 100%;
    min-width: 0;
}

.kb-testimonials-section .testimonials-slider-one .swiper-wrapper {
    align-items: stretch;
    box-sizing: border-box;
}

.kb-testimonials-section .testimonials-slider-one .swiper-slide {
    width: 100% !important;
    height: auto !important;
    flex-shrink: 0;
    box-sizing: border-box;
    padding: 0;
}

.kb-testimonials-section__card.testimonials-item,
.kb-testimonials-section .testimonials-wapper .testimonials-item {
    margin-bottom: 0 !important;
    width: 100%;
    padding: 0;
}

.kb-testimonials-section .testimonials-slider-one .swiper-slide-active {
    z-index: 1;
}

.kb-testimonials-section .testimonials-slider-one .swiper-slide:not(.swiper-slide-active) .kb-testimonials-section__card {
    visibility: hidden;
}

.kb-testimonials-section .testimonials-slider-one .swiper-slide-active .kb-testimonials-section__card {
    visibility: visible;
}

.kb-testimonials-section__meta.testimonials-meta {
    margin-bottom: 22px;
}

.kb-testimonials-section__quote.testimonials-quote {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    background: linear-gradient(145deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: var(--accent-color-two, #FFC107);
    font-size: 18px;
    box-shadow: 0 8px 20px rgba(71, 8, 4, 0.22);
}

.kb-testimonials-section__rating.testimonials-rating {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.kb-testimonials-section.testimonials-section-1 .testimonials-wapper .testimonials-item .testimonials-meta .testimonials-rating.kb-testimonials-section__rating i,
.kb-testimonials-section__rating.testimonials-rating i {
    font-size: 16px;
    line-height: 1;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #d4a017;
    filter: none;
    -webkit-text-stroke: 0;
}

.kb-testimonials-section.testimonials-section-1 .testimonials-wapper .testimonials-item .testimonials-meta .testimonials-rating.kb-testimonials-section__rating i.active,
.kb-testimonials-section__rating.testimonials-rating i.active {
    color: #ffc107 !important;
    filter: drop-shadow(0 1px 2px rgba(212, 160, 23, 0.55));
}

.kb-testimonials-section__content.testimonials-content {
    padding-bottom: 26px;
    padding-left: 2px;
    border-bottom: 1px solid rgba(18, 47, 42, 0.08);
    overflow: visible;
}

.kb-testimonials-section__content.testimonials-content::before {
    display: none;
}

.kb-testimonials-section__content.testimonials-content p {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.05rem, 1.4vw, 1.2rem);
    line-height: 1.75;
    color: var(--secondary-color, #122F2A);
    font-weight: 400;
    font-style: italic;
    margin: 0;
    padding: 0;
    text-indent: 0;
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
    word-wrap: break-word;
}

.kb-testimonials-section__author.testimonials-author {
    padding-top: 22px;
}

.kb-testimonials-section__avatar.testimonials-author-image {
    width: 64px;
    height: 64px;
    margin-right: 14px;
    border: 3px solid rgba(255, 193, 7, 0.35);
    box-shadow: 0 6px 18px rgba(18, 47, 42, 0.12);
}

.kb-testimonials-section__author-info.testimonials-author-content h3 {
    font-size: 17px;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin-bottom: 2px;
}

.kb-testimonials-section__author-info.testimonials-author-content p {
    font-size: 14px;
    font-weight: 500;
    color: #6b7a75;
    margin: 0;
}

.kb-testimonials-section__pagination.swiper-actions {
    margin-top: 22px;
    margin-left: 0 !important;
    justify-content: flex-start !important;
    gap: 0;
}

.kb-testimonials-section__dots.dot {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    min-height: 12px;
    width: auto;
}

.kb-testimonials-section__dots .swiper-pagination-bullet,
.kb-testimonials-section .testimonials-slider-one .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    margin: 0 !important;
    opacity: 1;
    background: rgba(18, 47, 42, 0.22);
    border-radius: 50%;
    transition:
        background 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.kb-testimonials-section__dots .swiper-pagination-bullet-active,
.kb-testimonials-section .testimonials-slider-one .swiper-pagination-bullet-active {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--primary-color, #470804);
    transform: scale(1.15);
    box-shadow: 0 0 0 3px rgba(255, 193, 7, 0.35);
}

.kb-testimonials-section__dots .swiper-pagination-bullet-active::before {
    display: none !important;
    content: none !important;
}

.kb-testimonials-section__visual.testimonials-image {
    position: relative;
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 420px;
    width: 100%;
}

.kb-testimonials-section.testimonials-section-1 .testimonials-image figure,
.kb-testimonials-section__figure {
    position: relative;
    margin: 0;
    padding-left: 0 !important;
    flex: 1;
    width: 100%;
    min-height: 420px;
    border-radius: 30px;
    overflow: hidden;
    box-shadow:
        0 20px 50px rgba(0, 0, 0, 0.28),
        0 0 0 1px rgba(255, 193, 7, 0.12);
}

.kb-testimonials-section__figure img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: cover;
    border-radius: 30px;
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-testimonials-section__figure-overlay {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    background: linear-gradient(
        160deg,
        rgba(71, 8, 4, 0.08) 0%,
        transparent 40%,
        rgba(18, 47, 42, 0.22) 100%
    );
}

.kb-testimonials-section__visual:hover .kb-testimonials-section__figure img {
    transform: scale(1.03);
}

.kb-testimonials-section__badge.success-rate {
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 193, 7, 0.35);
    border-radius: 22px;
    padding: 20px 22px;
    max-width: 220px;
    bottom: 40px;
    left: 0;
    box-shadow:
        0 12px 32px rgba(0, 0, 0, 0.18),
        0 0 28px rgba(255, 193, 7, 0.12);
}

.kb-testimonials-section__badge-value.success-rate-review {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.25rem, 2vw, 1.625rem);
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin-bottom: 8px;
    line-height: 1.2;
}

.kb-testimonials-section__badge-stars.success-rate-star {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    width: 100%;
}

.kb-testimonials-section.testimonials-section-1 .testimonials-image .success-rate .success-rate-star.kb-testimonials-section__badge-stars i,
.kb-testimonials-section__badge-stars.success-rate-star i,
.kb-testimonials-section__badge-stars.success-rate-star i.active {
    font-size: 16px;
    line-height: 1;
    padding: 0 !important;
    background: transparent !important;
    color: #ffc107 !important;
    filter: drop-shadow(0 1px 2px rgba(212, 160, 23, 0.55));
}

@media (max-width: 991px) {
    .kb-testimonials-section {
        padding: 64px 0 56px;
    }

    .kb-testimonials-section__header.section-title-area {
        align-items: flex-start;
        margin-bottom: 36px;
    }

    .kb-testimonials-section__intro-wrap.section-title-content {
        align-items: flex-start;
        justify-content: flex-start;
    }

    .kb-testimonials-section__intro {
        text-align: left;
        max-width: none;
    }

    .kb-testimonials-section__layout {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .kb-testimonials-section__visual.testimonials-image {
        margin-top: 0;
        min-height: 360px;
    }

    .kb-testimonials-section__figure {
        min-height: 360px;
    }
}

@media (max-width: 767px) {
    .kb-testimonials-section {
        padding: 52px 0 48px;
    }

    .kb-testimonials-section__slider-wrap.testimonials-wapper {
        padding: 28px 24px 22px;
        border-radius: 24px;
    }

    .kb-testimonials-section__figure {
        border-radius: 22px;
        min-height: 300px;
    }

    .kb-testimonials-section__figure img {
        border-radius: 22px;
    }

    .kb-testimonials-section__badge.success-rate {
        max-width: 160px;
        padding: 14px 16px;
        bottom: 16px;
    }
}

/* Team section — premium spiritual travel (KashiBhakti) */
.kb-team-section {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 48%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-team-section::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.35;
    background-image: radial-gradient(rgba(71, 8, 4, 0.06) 1px, transparent 1px);
    background-size: 28px 28px;
    z-index: 0;
}

.kb-team-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-team-section__orb--one {
    width: 300px;
    height: 300px;
    top: 8%;
    right: -70px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.12) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-team-section__orb--two {
    width: 260px;
    height: 260px;
    bottom: -60px;
    left: -50px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.08) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-team-section .container {
    position: relative;
    z-index: 1;
}

.kb-team-section__layout {
    display: grid;
    grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
    gap: 48px 64px;
    align-items: start;
    min-width: 0;
}

.kb-team-section__aside {
    align-self: start;
    min-width: 0;
    max-width: 100%;
}


@media (min-width: 992px) {
    .kb-team-section__aside {
        position: sticky;
        top: 120px;
        z-index: 2;
    }
}

.kb-team-section__intro.section-title {
    width: 100%;
    max-width: 100%;
    margin-bottom: 28px;
    min-width: 0;
}

.kb-team-section__intro.section-title h2 {
    font-size: clamp(2rem, 3.2vw, 2.75rem);
    line-height: 1.2;
    margin-bottom: 0;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
    max-width: 100%;
    overflow-wrap: break-word;
    word-wrap: break-word;
}

.kb-team-section__intro.section-title .sub-title {
    margin-bottom: 14px;
    max-width: 100%;
    white-space: normal;
}

.kb-team-section__description {
    margin-top: 14px;
    margin-bottom: 0;
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.75;
    font-weight: 500;
    max-width: 100%;
    overflow-wrap: break-word;
}

.kb-team-section__cta-wrap {
    margin-top: 28px;
}

.kb-team-section__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 26px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: var(--white-color, #ffffff);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-decoration: none;
    box-shadow:
        0 12px 28px rgba(71, 8, 4, 0.22),
        inset 0 1px 0 rgba(255, 193, 7, 0.18);
    transition:
        background 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.kb-team-section__cta i {
    font-size: 12px;
    transition: transform 0.35s ease;
}

.kb-team-section__cta:hover {
    background: linear-gradient(135deg, var(--secondary-color, #122F2A) 0%, #0f2420 100%);
    color: var(--white-color, #ffffff);
    transform: translateY(-2px);
    box-shadow:
        0 16px 32px rgba(18, 47, 42, 0.22),
        0 0 0 1px rgba(255, 193, 7, 0.28);
}

.kb-team-section__cta:hover i {
    transform: translateX(4px);
}

.kb-team-section__cards {
    display: grid;
    gap: 28px;
    min-width: 0;
    max-width: 100%;
}

.kb-team-section__card {
    position: relative;
    display: grid;
    grid-template-columns: 228px minmax(0, 1fr);
    align-items: stretch;
    gap: 0;
    min-width: 0;
    max-width: 100%;
    padding: 14px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow:
        0 4px 10px rgba(71, 8, 4, 0.04),
        0 20px 48px rgba(18, 47, 42, 0.1);
    transition:
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.45s ease,
        border-color 0.45s ease;
}

.kb-team-section__card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(
        135deg,
        rgba(255, 193, 7, 0.35) 0%,
        rgba(71, 8, 4, 0.08) 50%,
        rgba(18, 47, 42, 0.08) 100%
    );
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.45s ease;
}

.kb-team-section__card:hover {
    transform: translateY(-6px);
    border-color: rgba(255, 193, 7, 0.32);
    box-shadow:
        0 10px 20px rgba(71, 8, 4, 0.06),
        0 28px 56px rgba(18, 47, 42, 0.14),
        0 0 0 1px rgba(255, 193, 7, 0.16);
}

.kb-team-section__card:hover::before {
    opacity: 1;
}

.kb-team-section__media {
    position: relative;
    min-height: 248px;
    border-radius: 20px;
    overflow: hidden;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.25),
        0 10px 28px rgba(18, 47, 42, 0.14);
}

.kb-team-section__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-team-section__media-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(18, 47, 42, 0.05) 0%,
        rgba(18, 47, 42, 0.28) 55%,
        rgba(71, 8, 4, 0.45) 100%
    );
    pointer-events: none;
    transition: opacity 0.45s ease;
}

.kb-team-section__card:hover .kb-team-section__media img {
    transform: scale(1.08);
}

.kb-team-section__card:hover .kb-team-section__media-overlay {
    opacity: 0.85;
}

.kb-team-section__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 14px 18px 14px 10px;
}

.kb-team-section__badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    align-self: flex-start;
    margin-bottom: 14px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--extra-color, #F5EBEA);
    color: var(--primary-color, #470804);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.kb-team-section__badge i {
    color: var(--accent-one, #FFC107);
    font-size: 12px;
}

.kb-team-section__name {
    margin: 0 0 12px;
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.25rem, 1.8vw, 1.55rem);
    font-weight: 700;
    line-height: 1.3;
    color: var(--primary-color, #470804);
    transition: color 0.35s ease;
}

.kb-team-section__card:hover .kb-team-section__name {
    color: var(--secondary-color, #122F2A);
}

.kb-team-section__bio {
    margin: 0;
    color: var(--text-color, #555555);
    font-size: 15px;
    line-height: 1.75;
    font-weight: 500;
}

.kb-team-section__social {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.kb-team-section__social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--extra-color, #F5EBEA);
    color: var(--primary-color, #470804);
    font-size: 14px;
    text-decoration: none;
    transition:
        background 0.35s ease,
        color 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.kb-team-section__social a:hover {
    background: var(--primary-color, #470804);
    color: var(--white-color, #ffffff);
    transform: translateY(-2px);
    box-shadow: 0 8px 18px rgba(71, 8, 4, 0.2);
}

@media (max-width: 1199px) {
    .kb-team-section__layout {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .kb-team-section__aside {
        position: relative;
        top: 0;
    }

    .kb-team-section__card {
        grid-template-columns: 1fr;
        padding: 12px;
    }

    .kb-team-section__media {
        min-height: 260px;
        aspect-ratio: 16 / 10;
        border-radius: 18px;
    }

    .kb-team-section__content {
        padding: 18px 12px 12px;
    }

    .kb-team-section__orb--one {
        width: 200px;
        height: 200px;
        right: -80px;
    }

    .kb-team-section__orb--two {
        width: 160px;
        height: 160px;
        left: -70px;
    }
}

@media (max-width: 991px) {
    .kb-team-section__intro.section-title {
        margin-bottom: 24px;
    }

    .kb-team-section__intro.section-title h2 {
        font-size: clamp(1.65rem, 6vw, 2.15rem);
    }

    .kb-team-section__description {
        font-size: 15px;
    }

    .kb-team-section__cta-wrap {
        margin-top: 22px;
    }

    .kb-team-section__cta {
        max-width: 100%;
        justify-content: center;
    }
}

@media (max-width: 767px) {
    .kb-team-section .container {
        padding-left: 16px;
        padding-right: 16px;
    }

    .kb-team-section__layout {
        gap: 28px;
    }

    .kb-team-section__intro.section-title {
        margin-bottom: 20px;
        gap: 12px;
    }

    .kb-team-section__intro.section-title h2 {
        font-size: clamp(1.45rem, 7.5vw, 1.85rem);
        line-height: 1.25;
    }

    .kb-team-section__intro.section-title .sub-title {
        font-size: 12px;
        padding: 8px 12px 8px 38px;
    }

    .kb-team-section__card {
        border-radius: 22px;
        padding: 10px;
    }

    .kb-team-section__media {
        min-height: 168px;
        border-radius: 16px;
    }

    .kb-team-section__content {
        padding: 14px 10px 10px;
    }

    .kb-team-section__name {
        font-size: 1.2rem;
        overflow-wrap: break-word;
    }

    .kb-team-section__bio {
        font-size: 14px;
    }

    .kb-team-section__orb {
        opacity: 0.5;
    }
}

@media (max-width: 575px) {
    .kb-team-section__cta {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        justify-content: center;
        padding: 12px 20px;
    }

    .kb-team-section__cta-wrap {
        width: 100%;
        max-width: 100%;
    }
}

/* Blog cards — premium spiritual travel (KashiBhakti) */
.blog-section {
    --kb-blog-primary: var(--primary-color, #470804);
    --kb-blog-primary-dark: #3d0703;
    --kb-blog-soft: var(--extra-color, #F5EBEA);
    --kb-blog-white: #ffffff;
}

.blog-section__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 30px;
    align-items: start;
}

.blog-section__empty {
    grid-column: 1 / -1;
    text-align: center;
    margin: 0;
    color: #5a6b66;
    font-size: 16px;
    font-weight: 500;
}

.blog-section .kb-blog-card {
    display: flex;
    flex-direction: column;
    background: var(--kb-blog-white);
    border: 1px solid rgba(71, 8, 4, 0.08);
    border-radius: 24px;
    overflow: hidden;
    box-shadow:
        0 4px 6px rgba(71, 8, 4, 0.04),
        0 18px 40px rgba(71, 8, 4, 0.08);
    transition:
        transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        border-color 0.4s ease;
}

.blog-section .kb-blog-card:hover {
    transform: translateY(-10px);
    border-color: rgba(71, 8, 4, 0.42);
    box-shadow:
        0 0 0 1px rgba(71, 8, 4, 0.28),
        0 8px 20px rgba(71, 8, 4, 0.12),
        0 28px 56px rgba(71, 8, 4, 0.14);
}

.blog-section .kb-blog-card__media {
    display: block;
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    flex-shrink: 0;
}

.blog-section .kb-blog-card__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(71, 8, 4, 0) 55%, rgba(71, 8, 4, 0.18) 100%);
    pointer-events: none;
    transition: opacity 0.4s ease;
}

.blog-section .kb-blog-card:hover .kb-blog-card__media::after {
    opacity: 0.75;
}

.blog-section .kb-blog-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.blog-section .kb-blog-card:hover .kb-blog-card__media img {
    transform: scale(1.08);
}

.blog-section .kb-blog-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 18px 20px 20px;
}

.blog-section .kb-blog-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
    margin-bottom: 10px;
}

.blog-section .kb-blog-card__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(71, 8, 4, 0.72);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.blog-section .kb-blog-card__meta-item i {
    color: var(--kb-blog-primary);
    font-size: 13px;
}

.blog-section .kb-blog-card__title {
    margin: 0 0 10px;
    font-size: clamp(1.15rem, 1.6vw, 1.4rem);
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: -0.01em;
}

.blog-section .kb-blog-card__title a {
    color: var(--kb-blog-primary);
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color 0.3s ease;
}

.blog-section .kb-blog-card__title a:hover {
    color: var(--kb-blog-primary-dark);
}

.blog-section .kb-blog-card__excerpt {
    margin: 0 0 14px;
    color: rgba(71, 8, 4, 0.72);
    font-size: 14px;
    line-height: 1.6;
    font-weight: 500;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-section .kb-blog-card__cta {
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 999px;
    background: var(--kb-blog-primary);
    color: #ffffff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(71, 8, 4, 0.18);
    transition:
        background 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.blog-section .kb-blog-card__cta i {
    font-size: 12px;
    transition: transform 0.35s ease;
}

.blog-section .kb-blog-card__cta:hover {
    background: var(--kb-blog-primary-dark);
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(61, 7, 3, 0.24);
}

.blog-section .kb-blog-card__cta:hover i {
    transform: translateX(4px);
}

@media (max-width: 991px) {
    .blog-section__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 24px;
    }

    .blog-section .kb-blog-card__body {
        padding: 16px 18px 18px;
    }
}

@media (max-width: 767px) {
    .blog-section__grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .blog-section .kb-blog-card__body {
        padding: 16px 16px 18px;
    }

    .blog-section .kb-blog-card__title {
        font-size: 1.25rem;
    }
}

/* Blog detail page — premium spiritual travel */
.kb-blog-detail-section {
    --kb-detail-primary: var(--primary-color, #470804);
    --kb-detail-primary-dark: #3d0703;
    --kb-detail-soft: var(--extra-color, #F5EBEA);
}

.kb-blog-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 36px;
    align-items: start;
}

.kb-blog-detail__hero {
    margin-bottom: 28px;
}

.kb-blog-detail__media {
    margin: 0;
    border-radius: 24px;
    overflow: hidden;
    box-shadow:
        0 8px 24px rgba(71, 8, 4, 0.1),
        0 24px 48px rgba(71, 8, 4, 0.12);
    position: relative;
}

.kb-blog-detail__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(71, 8, 4, 0.02) 0%, rgba(71, 8, 4, 0.22) 100%);
    pointer-events: none;
    transition: opacity 0.45s ease;
}

.kb-blog-detail__media img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-blog-detail__hero:hover .kb-blog-detail__media img {
    transform: scale(1.04);
}

.kb-blog-detail__card,
.kb-blog-detail__tags,
.kb-blog-detail__nav,
.kb-blog-detail__comments,
.kb-blog-detail__form-card {
    background: #ffffff;
    border: 1px solid rgba(71, 8, 4, 0.08);
    border-radius: 24px;
    box-shadow:
        0 4px 8px rgba(71, 8, 4, 0.04),
        0 16px 40px rgba(71, 8, 4, 0.08);
}

.kb-blog-detail__card {
    padding: 34px 36px 38px;
    margin-bottom: 28px;
}

.kb-blog-detail__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 12px;
    margin-bottom: 22px;
}

.kb-blog-detail__pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(71, 8, 4, 0.1);
    color: var(--kb-detail-primary);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

.kb-blog-detail__pill i {
    color: var(--kb-detail-primary);
    font-size: 12px;
}

.kb-blog-detail__pill--link:hover {
    background: var(--kb-detail-primary);
    color: #ffffff;
    transform: translateY(-1px);
}

.kb-blog-detail__pill--link:hover i {
    color: #ffffff;
}

.kb-blog-detail__title {
    margin: 0 0 24px;
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: -0.02em;
    color: var(--kb-detail-primary);
}

.kb-blog-detail__tips {
    display: flex;
    gap: 18px;
    align-items: flex-start;
    padding: 22px 24px;
    margin-bottom: 30px;
    border-radius: 20px;
    background: linear-gradient(135deg, var(--kb-detail-soft) 0%, #ffffff 100%);
    border: 1px solid rgba(71, 8, 4, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.kb-blog-detail__tips-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--kb-detail-primary);
    color: #ffffff;
    flex-shrink: 0;
    font-size: 20px;
    box-shadow: 0 10px 24px rgba(71, 8, 4, 0.28);
}

.kb-blog-detail__tips-title {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 700;
    color: var(--kb-detail-primary-dark);
}

.kb-blog-detail__tips-body p {
    margin: 0;
    color: rgba(71, 8, 4, 0.78);
    font-size: 15px;
    line-height: 1.75;
    font-weight: 500;
}

.kb-blog-detail__content {
    color: rgba(71, 8, 4, 0.88);
    font-size: 17px;
    line-height: 1.85;
    font-weight: 500;
}

.kb-blog-detail__content p {
    margin-bottom: 1.25em;
}

.kb-blog-detail__content h2,
.kb-blog-detail__content h3,
.kb-blog-detail__content h4 {
    color: var(--kb-detail-primary);
    font-weight: 700;
    line-height: 1.35;
    margin: 1.6em 0 0.75em;
}

.kb-blog-detail__content h2 { font-size: 1.65rem; }
.kb-blog-detail__content h3 { font-size: 1.35rem; }

.kb-blog-detail__content ul,
.kb-blog-detail__content ol {
    margin-bottom: 1.25em;
    padding-left: 1.4em;
}

.kb-blog-detail__content li {
    margin-bottom: 0.5em;
}

.kb-blog-detail__content img {
    max-width: 100%;
    border-radius: 16px;
    margin: 1.5em 0;
}

.kb-blog-detail__content blockquote {
    margin: 1.5em 0;
    padding: 20px 24px;
    border-left: 4px solid var(--kb-detail-primary);
    border-radius: 0 16px 16px 0;
    background: rgba(71, 8, 4, 0.08);
    font-style: italic;
}

.kb-blog-detail__tags {
    padding: 24px 28px;
    margin-bottom: 28px;
}

.kb-blog-detail__tags-label {
    display: block;
    margin-bottom: 14px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--kb-detail-primary-dark);
}

.kb-blog-detail__tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.kb-blog-detail__tag-list a {
    display: inline-block;
    padding: 8px 16px;
    border-radius: 999px;
    background: rgba(71, 8, 4, 0.06);
    color: var(--kb-detail-primary);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

.kb-blog-detail__tag-list a:hover {
    background: var(--kb-detail-primary);
    color: #ffffff;
    transform: translateY(-2px);
}

.kb-blog-detail__nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    padding: 18px;
    margin-bottom: 28px;
}

.kb-blog-detail__nav-item {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 20px 22px;
    border-radius: 18px;
    background: var(--kb-detail-soft);
    border: 1px solid rgba(71, 8, 4, 0.08);
    text-decoration: none;
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.kb-blog-detail__nav-item:hover {
    transform: translateY(-4px);
    border-color: rgba(71, 8, 4, 0.35);
    box-shadow: 0 12px 28px rgba(71, 8, 4, 0.1);
}

.kb-blog-detail__nav-item--next {
    text-align: right;
}

.kb-blog-detail__nav-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--kb-detail-primary);
}

.kb-blog-detail__nav-title {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.45;
    color: var(--kb-detail-primary);
}

.kb-blog-detail__comments,
.kb-blog-detail__form-card {
    padding: 32px 34px;
    margin-bottom: 28px;
}

.kb-blog-detail__section-title {
    margin: 0 0 22px;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--kb-detail-primary);
}

.kb-blog-detail__alert {
    padding: 14px 18px;
    margin-bottom: 20px;
    border-radius: 14px;
    background: rgba(71, 8, 4, 0.08);
    border: 1px solid rgba(71, 8, 4, 0.12);
    color: var(--kb-detail-primary);
    font-size: 14px;
    font-weight: 600;
}

.kb-blog-detail__comment-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 16px;
}

.kb-blog-detail__comment {
    display: flex;
    gap: 16px;
    padding: 20px;
    border-radius: 18px;
    background: var(--kb-detail-soft);
    border: 1px solid rgba(71, 8, 4, 0.06);
}

.kb-blog-detail__comment-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--kb-detail-primary), #5a1812);
    color: #ffffff;
    font-weight: 700;
    font-size: 18px;
    flex-shrink: 0;
    box-shadow: 0 8px 20px rgba(71, 8, 4, 0.2);
}

.kb-blog-detail__comment-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
    margin-bottom: 8px;
}

.kb-blog-detail__comment-head strong {
    color: var(--kb-detail-primary);
    font-size: 15px;
}

.kb-blog-detail__comment-head span {
    color: rgba(71, 8, 4, 0.6);
    font-size: 13px;
    font-weight: 500;
}

.kb-blog-detail__comment-body p {
    margin: 0;
    color: rgba(71, 8, 4, 0.82);
    font-size: 15px;
    line-height: 1.7;
}

.kb-blog-detail__comment-empty {
    padding: 24px;
    text-align: center;
    color: rgba(71, 8, 4, 0.65);
    font-weight: 500;
    list-style: none;
}

.kb-blog-detail__form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.kb-blog-detail__field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.kb-blog-detail__field--full {
    grid-column: 1 / -1;
}

.kb-blog-detail__field label {
    font-size: 13px;
    font-weight: 700;
    color: var(--kb-detail-primary);
    letter-spacing: 0.02em;
}

.kb-blog-detail__field input,
.kb-blog-detail__field textarea {
    width: 100%;
    border: 1px solid rgba(71, 8, 4, 0.12);
    border-radius: 16px;
    padding: 14px 18px;
    font-size: 15px;
    font-weight: 500;
    color: var(--kb-detail-primary);
    background: #ffffff;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.kb-blog-detail__field textarea {
    min-height: 140px;
    resize: vertical;
}

.kb-blog-detail__field input:focus,
.kb-blog-detail__field textarea:focus {
    outline: none;
    border-color: rgba(71, 8, 4, 0.55);
    box-shadow: 0 0 0 4px rgba(71, 8, 4, 0.15);
}

.kb-blog-detail__error {
    color: #b42318;
    font-size: 12px;
    font-weight: 600;
}

.kb-blog-detail__submit {
    margin-top: 22px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    border: 0;
    border-radius: 999px;
    background: var(--kb-detail-primary);
    color: #ffffff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.03em;
    cursor: pointer;
    box-shadow: 0 12px 28px rgba(71, 8, 4, 0.22);
    transition: background 0.35s ease, transform 0.35s ease, box-shadow 0.35s ease;
}

.kb-blog-detail__submit:hover {
    background: var(--kb-detail-primary-dark);
    transform: translateY(-2px);
    box-shadow: 0 16px 32px rgba(61, 7, 3, 0.24);
}

.kb-blog-detail__submit i {
    font-size: 12px;
    transition: transform 0.35s ease;
}

.kb-blog-detail__submit:hover i {
    transform: translateX(4px);
}

/* Blog detail sidebar */
.kb-blog-sidebar {
    position: sticky;
    top: 120px;
}

.kb-blog-sidebar__widgets {
    display: grid;
    gap: 24px;
}

.kb-blog-sidebar__widget {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(71, 8, 4, 0.14);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.6) inset,
        0 10px 30px rgba(71, 8, 4, 0.08);
    backdrop-filter: blur(6px);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.kb-blog-sidebar__widget:hover {
    transform: translateY(-3px);
    box-shadow:
        0 0 0 1px rgba(71, 8, 4, 0.2),
        0 16px 36px rgba(71, 8, 4, 0.12);
}

.kb-blog-sidebar__title {
    margin: 0 0 18px;
    font-size: 18px;
    font-weight: 700;
    color: var(--kb-detail-primary);
}

.kb-blog-sidebar__search {
    display: flex;
    border: 1px solid rgba(71, 8, 4, 0.1);
    border-radius: 999px;
    overflow: hidden;
    background: #ffffff;
}

.kb-blog-sidebar__search input {
    flex: 1;
    border: 0;
    outline: 0;
    padding: 12px 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--kb-detail-primary);
    background: transparent;
}

.kb-blog-sidebar__search button {
    width: 48px;
    border: 0;
    background: var(--kb-detail-primary);
    color: #ffffff;
    cursor: pointer;
}

.kb-blog-sidebar__categories {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.kb-blog-sidebar__categories a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    border-radius: 12px;
    text-decoration: none;
    color: rgba(71, 8, 4, 0.82);
    font-size: 14px;
    font-weight: 600;
    transition: background 0.3s ease, color 0.3s ease;
}

.kb-blog-sidebar__categories a:hover,
.kb-blog-sidebar__categories a.is-active {
    background: rgba(71, 8, 4, 0.12);
    color: var(--kb-detail-primary-dark);
}

.kb-blog-sidebar__count {
    min-width: 28px;
    padding: 2px 8px;
    border-radius: 999px;
    background: rgba(71, 8, 4, 0.08);
    font-size: 12px;
    text-align: center;
}

.kb-blog-sidebar__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.kb-blog-sidebar__tags a {
    display: inline-block;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(71, 8, 4, 0.06);
    color: var(--kb-detail-primary);
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.3s ease, color 0.3s ease;
}

.kb-blog-sidebar__tags a:hover,
.kb-blog-sidebar__tags a.is-active {
    background: var(--kb-detail-primary);
    color: #ffffff;
}

.kb-blog-sidebar__recent {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 14px;
}

.kb-blog-sidebar__recent-item {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 12px;
    align-items: center;
    text-decoration: none;
    padding: 10px;
    border-radius: 16px;
    transition: background 0.3s ease, transform 0.3s ease;
}

.kb-blog-sidebar__recent-item:hover {
    background: rgba(71, 8, 4, 0.1);
    transform: translateX(4px);
}

.kb-blog-sidebar__recent-thumb {
    width: 72px;
    height: 56px;
    border-radius: 12px;
    overflow: hidden;
    display: block;
    box-shadow: 0 6px 16px rgba(71, 8, 4, 0.12);
}

.kb-blog-sidebar__recent-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.kb-blog-sidebar__recent-item:hover .kb-blog-sidebar__recent-thumb img {
    transform: scale(1.08);
}

.kb-blog-sidebar__recent-content {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.kb-blog-detail-section .kb-blog-sidebar__recent-title {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.4;
    color: var(--kb-detail-primary);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kb-blog-sidebar__recent-date {
    font-size: 12px;
    font-weight: 500;
    color: rgba(71, 8, 4, 0.6);
}

.kb-blog-sidebar__recent-date i {
    color: var(--kb-detail-primary);
    margin-right: 4px;
}

@media (max-width: 1199px) {
    .kb-blog-detail-layout {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .kb-blog-sidebar {
        position: static;
    }
}

@media (max-width: 767px) {
    .kb-blog-detail__card {
        padding: 24px 22px 28px;
    }

    .kb-blog-detail__tips {
        flex-direction: column;
    }

    .kb-blog-detail__nav {
        grid-template-columns: 1fr;
    }

    .kb-blog-detail__nav-item--next {
        text-align: left;
    }

    .kb-blog-detail__form-grid {
        grid-template-columns: 1fr;
    }

    .kb-blog-detail__comments,
    .kb-blog-detail__form-card {
        padding: 24px 22px;
    }
}

/* Site search results */
.kb-search-section__form {
    margin-bottom: 0;
}

.kb-search-section__field {
    display: flex;
    align-items: stretch;
    border: 1px solid rgba(71, 8, 4, 0.12);
    border-radius: 999px;
    overflow: hidden;
    background: #ffffff;
    box-shadow: 0 10px 28px rgba(18, 47, 42, 0.07);
}

.kb-search-section__field input {
    flex: 1;
    border: 0;
    outline: 0;
    padding: 16px 22px;
    font-size: 16px;
    font-weight: 500;
    color: #122f2a;
    background: transparent;
}

.kb-search-section__field button {
    border: 0;
    width: 58px;
    background: var(--primary-color, #470804);
    color: #ffffff;
    flex-shrink: 0;
}

.kb-search-section__summary {
    color: #5a6b66;
    font-size: 16px;
    font-weight: 500;
}

.kb-search-section__group {
    margin-bottom: 36px;
}

.kb-search-section__heading {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 18px;
    color: #122f2a;
}

.kb-search-section__list {
    display: grid;
    gap: 16px;
}

.kb-search-section__item {
    display: grid;
    grid-template-columns: 96px 1fr auto;
    gap: 18px;
    align-items: center;
    padding: 16px;
    border: 1px solid rgba(71, 8, 4, 0.08);
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 10px 28px rgba(18, 47, 42, 0.07);
    color: inherit;
    text-decoration: none;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.kb-search-section__item:hover {
    transform: translateY(-3px);
    border-color: rgba(71, 8, 4, 0.14);
    box-shadow: 0 16px 36px rgba(71, 8, 4, 0.12);
    color: inherit;
}

.kb-search-section__thumb {
    width: 96px;
    height: 72px;
    border-radius: 12px;
    overflow: hidden;
}

.kb-search-section__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kb-search-section__badge {
    display: inline-block;
    margin-bottom: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    background: var(--extra-color, #F5EBEA);
    color: var(--primary-color, #470804);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.kb-search-section__content h3 {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 6px;
    color: #122f2a;
}

.kb-search-section__content p {
    margin-bottom: 0;
    color: #5a6b66;
    font-size: 14px;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kb-search-section__arrow {
    color: var(--primary-color, #470804);
    font-size: 16px;
}

@media (max-width: 767px) {
    .kb-search-section__item {
        grid-template-columns: 72px 1fr;
        gap: 14px;
    }

    .kb-search-section__arrow {
        display: none;
    }

    .kb-search-section__thumb {
        width: 72px;
        height: 72px;
    }

    .kb-search-section__content h3 {
        font-size: 18px;
    }
}

/* Services carousel — premium spiritual travel (KashiBhakti) */
.kb-services-section {
    position: relative;
    overflow: hidden;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 38%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-services-section::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.32;
    background-image: radial-gradient(rgba(71, 8, 4, 0.05) 1px, transparent 1px);
    background-size: 26px 26px;
    z-index: 0;
}

.kb-services-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-services-section__orb--one {
    width: 300px;
    height: 300px;
    top: -70px;
    right: -60px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.14) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-services-section__orb--two {
    width: 260px;
    height: 260px;
    bottom: 12%;
    left: -70px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.09) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-services-section__motif {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 193, 7, 0.2);
    width: 100px;
    height: 100px;
    top: 42%;
    right: 10%;
    opacity: 0.3;
}

.kb-services-section .container {
    position: relative;
    z-index: 1;
}

.kb-services-section__header {
    justify-content: space-between;
    align-items: flex-end;
    gap: 32px 48px;
    margin-bottom: 56px;
}

.kb-services-section__title.section-title {
    width: min(100%, 560px);
    max-width: 560px;
    margin-left: 0;
    margin-right: 0;
    align-items: flex-start;
    text-align: left;
}

.kb-services-section__title.section-title .sub-title {
    font-size: 13px;
    padding: 8px 16px 8px 42px;
    margin-left: 0;
    margin-right: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(18, 47, 42, 0.08);
}

.kb-services-section__title.section-title .sub-title strong {
    font-weight: 700;
    color: var(--primary-color, #470804);
}

.kb-services-section__title.section-title h2 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.875rem, 3.2vw, 2.75rem);
    line-height: 1.2 !important;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin-top: 4px;
}

.kb-services-section__intro-wrap.section-title-content {
    width: min(100%, 480px);
    align-items: flex-end;
    justify-content: flex-end;
}

.kb-services-section__intro {
    margin-bottom: 0;
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.78;
    font-weight: 500;
    max-width: 42ch;
    text-align: right;
}

.kb-services-section__slider-wrap {
    margin-top: 4px;
}

.kb-services-section__slider.home-services-slider,
.home-services-section.kb-services-section .home-services-slider {
    padding-bottom: 0;
}

.kb-services-section__slider .swiper-slide {
    height: auto;
}

/* Cards — shared circular service card (see .kb-service-card__* below) */
.kb-services-section .services-slider .service-items.kb-services-section__card,
.kb-services-section .services-slider .home-services-empty {
    min-height: unset;
}

.kb-services-section .home-services-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
    text-align: center;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.7), rgba(245, 235, 234, 0.9));
    color: var(--secondary-color, #122F2A);
    font-weight: 600;
}

.kb-services-section__actions.home-services-slider__actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-top: 36px;
}

.kb-services-section__nav.swiper-button-prev,
.kb-services-section__nav.swiper-button-next,
.kb-services-section .home-services-slider__actions .swiper-button-prev,
.kb-services-section .home-services-slider__actions .swiper-button-next {
    position: static;
    width: 52px;
    height: 52px;
    margin: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.88);
    color: var(--secondary-color, #122F2A);
    border: 1px solid rgba(18, 47, 42, 0.12);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow:
        0 10px 28px rgba(18, 47, 42, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.8);
    transition:
        background 0.35s ease,
        color 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.kb-services-section__nav.swiper-button-prev::after,
.kb-services-section__nav.swiper-button-next::after,
.kb-services-section .home-services-slider__actions .swiper-button-prev::after,
.kb-services-section .home-services-slider__actions .swiper-button-next::after {
    display: none;
}

.kb-services-section__nav.swiper-button-prev i,
.kb-services-section__nav.swiper-button-next i {
    font-size: 14px;
}

.kb-services-section__nav.swiper-button-prev:hover,
.kb-services-section__nav.swiper-button-next:hover,
.kb-services-section .home-services-slider__actions .swiper-button-prev:hover,
.kb-services-section .home-services-slider__actions .swiper-button-next:hover {
    background: linear-gradient(145deg, var(--secondary-color, #122F2A) 0%, #1a3f38 100%);
    color: var(--accent-color-two, #FFC107);
    border-color: rgba(255, 193, 7, 0.35);
    transform: translateY(-2px);
    box-shadow:
        0 14px 32px rgba(18, 47, 42, 0.2),
        0 0 24px rgba(255, 193, 7, 0.15);
}

.kb-services-section__dots.dot,
.kb-services-section .home-services-slider__actions .dot {
    width: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 12px;
}

.kb-services-section__dots .swiper-pagination-bullet,
.kb-services-section .home-services-slider__actions .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 !important;
    opacity: 1;
    background: rgba(18, 47, 42, 0.18);
    border-radius: 50%;
    transition:
        background 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.kb-services-section__dots .swiper-pagination-bullet-active,
.kb-services-section .home-services-slider__actions .swiper-pagination-bullet-active {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--secondary-color, #122F2A) 0%, var(--primary-color, #470804) 100%);
    transform: scale(1.2);
    box-shadow: 0 0 0 3px rgba(255, 193, 7, 0.35);
}

.kb-services-section__dots .swiper-pagination-bullet-active::before,
.kb-services-section .home-services-slider__actions .swiper-pagination-bullet-active::before {
    display: none !important;
    content: none !important;
}

@media (max-width: 991px) {
    .kb-services-section__header {
        align-items: flex-start;
        margin-bottom: 40px;
    }

    .kb-services-section__title.section-title {
        width: 100%;
    }

    .kb-services-section__intro-wrap.section-title-content {
        width: 100%;
        align-items: flex-start;
        justify-content: flex-start;
    }

    .kb-services-section__intro {
        text-align: left;
        max-width: none;
        font-size: 15px;
    }

    .kb-services-section .services-slider .home-services-empty {
        min-height: 280px;
        border-radius: 24px;
    }
}

@media (max-width: 767px) {
    .kb-services-section .services-slider .home-services-empty {
        min-height: 260px;
        border-radius: 22px;
    }
}

/* Gallery / Moments From Kashi — premium spiritual photography (KashiBhakti) */
.kb-gallery-section {
    position: relative;
    overflow: hidden;
}

.kb-gallery-section::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.2;
    background-image: radial-gradient(rgba(71, 8, 4, 0.04) 1px, transparent 1px);
    background-size: 26px 26px;
    z-index: 0;
}

.kb-gallery-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-gallery-section__orb--one {
    width: 300px;
    height: 300px;
    top: -80px;
    right: -60px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-gallery-section__orb--two {
    width: 260px;
    height: 260px;
    bottom: 10%;
    left: -70px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.08) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-gallery-section__motif {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 193, 7, 0.16);
    opacity: 0.32;
}

.kb-gallery-section__motif--one {
    width: 100px;
    height: 100px;
    top: 22%;
    left: 6%;
}

.kb-gallery-section .container {
    position: relative;
    z-index: 1;
}

.kb-gallery-section__header.section-title-area,
.kb-gallery-section__header.home-gallery-section__header {
    justify-content: space-between;
    align-items: flex-end;
    gap: 32px 48px;
    margin-bottom: 52px;
}

.kb-gallery-section__title.section-title,
.kb-gallery-section__title.home-gallery-section__title {
    width: min(100%, 560px);
    max-width: 560px;
    margin-left: 0;
    margin-right: 0;
    align-items: flex-start;
    text-align: left;
}

.kb-gallery-section__title.section-title .sub-title {
    font-size: 13px;
    padding: 8px 16px 8px 42px;
    margin-left: 0;
    margin-right: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 193, 7, 0.28);
}

.kb-gallery-section__title.section-title .sub-title strong {
    font-weight: 700;
    color: var(--primary-color, #470804);
}

.kb-gallery-section__heading,
.kb-gallery-section__title.section-title h2 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.875rem, 3.2vw, 2.75rem);
    line-height: 1.2 !important;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin-top: 6px;
}

.kb-gallery-section__intro-wrap.section-title-content {
    width: min(100%, 480px);
    align-items: flex-end;
    justify-content: flex-end;
}

.kb-gallery-section__intro {
    margin: 0;
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.78;
    font-weight: 500;
    max-width: 42ch;
    text-align: right;
}

.kb-gallery-section__grid.row {
    margin-left: -14px;
    margin-right: -14px;
}

.kb-gallery-section__grid > [class*="col-"] {
    padding-left: 14px;
    padding-right: 14px;
    margin-bottom: 28px;
}

.kb-gallery-section__item.photo-gallery {
    margin-bottom: 0;
    border-radius: 28px;
    box-shadow:
        0 4px 12px rgba(18, 47, 42, 0.06),
        0 16px 40px rgba(18, 47, 42, 0.08);
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.45s ease;
}

.kb-gallery-section__item.photo-gallery::before {
    background: linear-gradient(
        165deg,
        rgba(71, 8, 4, 0.82) 0%,
        rgba(18, 47, 42, 0.62) 48%,
        rgba(71, 8, 4, 0.5) 100%
    );
    border-radius: 28px;
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
    -ms-transition: all 0.4s;
    -o-transition: all 0.4s;
    transition: all 0.4s;
}

.kb-gallery-section__image.photo-gallery-image {
    position: relative;
    border-radius: 28px;
    overflow: hidden;
}

.kb-gallery-section__image.photo-gallery-image figure {
    border-radius: 28px;
    aspect-ratio: 4 / 3.2;
    margin: 0;
}

.kb-gallery-section__image.photo-gallery-image figure img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 28px;
    -webkit-transition: transform 0.4s ease;
    -moz-transition: transform 0.4s ease;
    -ms-transition: transform 0.4s ease;
    -o-transition: transform 0.4s ease;
    transition: transform 0.4s ease;
}

.kb-gallery-section__image-shine {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    z-index: 1;
    background: linear-gradient(
        180deg,
        rgba(255, 193, 7, 0.04) 0%,
        transparent 38%,
        rgba(18, 47, 42, 0.22) 100%
    );
    opacity: 0.65;
    transition: opacity 0.4s ease;
}

.kb-gallery-section__item.photo-gallery:hover {
    transform: translateY(-5px);
    box-shadow:
        0 10px 24px rgba(18, 47, 42, 0.1),
        0 24px 52px rgba(18, 47, 42, 0.12),
        0 0 36px rgba(255, 193, 7, 0.1);
}

.kb-gallery-section__item.photo-gallery:hover::before {
    opacity: 0.88;
}

.kb-gallery-section__item.photo-gallery:hover .photo-gallery-image figure img {
    -webkit-transform: scale(1.05);
    -moz-transform: scale(1.05);
    -ms-transform: scale(1.05);
    -o-transform: scale(1.05);
    transform: scale(1.05);
}

.kb-gallery-section__item.photo-gallery:hover .kb-gallery-section__image-shine {
    opacity: 0.9;
}

.kb-gallery-section__icon.photo-gallery-icon a {
    -webkit-transition: all 500ms ease;
    -moz-transition: all 500ms ease;
    -ms-transition: all 500ms ease;
    -o-transition: all 500ms ease;
    transition: all 500ms ease;
}

.kb-gallery-section__icon.photo-gallery-icon a i {
    width: 56px;
    height: 56px;
    font-size: 17px;
    color: var(--primary-color, #470804);
    background: rgba(255, 255, 255, 0.96);
    border: 2px solid rgba(255, 193, 7, 0.42);
    border-radius: 50%;
    box-shadow:
        0 8px 22px rgba(71, 8, 4, 0.18),
        0 0 20px rgba(255, 193, 7, 0.12);
    -webkit-transition: all 500ms ease;
    -moz-transition: all 500ms ease;
    -ms-transition: all 500ms ease;
    -o-transition: all 500ms ease;
    transition: all 500ms ease;
}

.kb-gallery-section__item.photo-gallery:hover .photo-gallery-icon a i {
    border-color: rgba(255, 193, 7, 0.65);
    box-shadow:
        0 10px 28px rgba(71, 8, 4, 0.22),
        0 0 28px rgba(255, 193, 7, 0.22);
}

.kb-gallery-section__footer {
    margin-top: 12px !important;
}

.kb-gallery-section__cta.theme-button.style-1 {
    border-radius: 999px;
    box-shadow:
        0 4px 14px rgba(71, 8, 4, 0.12),
        0 0 24px rgba(255, 193, 7, 0.08);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.kb-gallery-section__cta.theme-button.style-1:hover {
    transform: translateY(-2px);
    box-shadow:
        0 8px 22px rgba(71, 8, 4, 0.16),
        0 0 32px rgba(255, 193, 7, 0.14);
}

.kb-gallery-section--page .kb-gallery-section__grid > [class*="col-"] {
    margin-bottom: 28px;
}

@media (max-width: 1199px) {
    .kb-gallery-section__image.photo-gallery-image figure,
    .kb-gallery-section__image.photo-gallery-image figure img,
    .kb-gallery-section__item.photo-gallery::before {
        border-radius: 22px;
    }
}

@media (max-width: 991px) {
    .kb-gallery-section__header.section-title-area,
    .kb-gallery-section__header.home-gallery-section__header {
        align-items: center;
        text-align: center;
        margin-bottom: 40px;
    }

    .kb-gallery-section__title.section-title,
    .kb-gallery-section__title.home-gallery-section__title {
        width: 100%;
        max-width: 100%;
        align-items: center;
        text-align: center;
        margin-left: auto;
        margin-right: auto;
    }

    .kb-gallery-section__title.section-title .sub-title {
        margin-left: auto;
        margin-right: auto;
    }

    .kb-gallery-section__heading,
    .kb-gallery-section__title.section-title h2 {
        text-align: center;
    }

    .kb-gallery-section__intro-wrap.section-title-content {
        width: 100%;
        align-items: center;
        justify-content: center;
    }

    .kb-gallery-section__intro {
        text-align: center;
        max-width: none;
        font-size: 15px;
    }
}

@media (max-width: 767px) {
    .kb-gallery-section__grid > [class*="col-"] {
        padding-left: 10px;
        padding-right: 10px;
        margin-bottom: 20px;
    }

    .kb-gallery-section__image.photo-gallery-image figure {
        aspect-ratio: 4 / 3.4;
    }

    .kb-gallery-section__icon.photo-gallery-icon a i {
        width: 50px;
        height: 50px;
        font-size: 15px;
    }
}

/* About Kashi / Sacred Traditions — premium spiritual travel (KashiBhakti) */
.kb-about-section {
    position: relative;
    overflow: hidden;
    padding: 80px 0;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 42%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-about-section::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.32;
    background-image: radial-gradient(rgba(71, 8, 4, 0.05) 1px, transparent 1px);
    background-size: 26px 26px;
    z-index: 0;
}

.kb-about-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-about-section__orb--one {
    width: 320px;
    height: 320px;
    top: -80px;
    left: -90px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.14) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-about-section__orb--two {
    width: 280px;
    height: 280px;
    bottom: -70px;
    right: 8%;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.1) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-about-section__motif {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 193, 7, 0.22);
}

.kb-about-section__motif--one {
    width: 120px;
    height: 120px;
    top: 18%;
    right: 42%;
    opacity: 0.35;
}

.kb-about-section__motif--two {
    width: 72px;
    height: 72px;
    bottom: 22%;
    left: 6%;
    opacity: 0.28;
    border-color: rgba(18, 47, 42, 0.12);
}

.kb-about-section .container {
    position: relative;
    z-index: 1;
}

.kb-about-section__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 520px);
    gap: 56px 72px;
    align-items: stretch;
}

.kb-about-section__content {
    display: flex;
    flex-direction: column;
    align-self: stretch;
    max-width: 560px;
    min-height: 0;
}

.kb-about-section__collage {
    position: relative;
    display: flex;
    flex-direction: column;
    align-self: stretch;
    width: 100%;
    padding: 0;
    min-height: 0;
}

.kb-about-section__heading {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2.125rem, 3.4vw, 2.875rem);
    line-height: 1.18;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin-bottom: 22px;
    letter-spacing: -0.01em;
}

.kb-about-section__intro {
    color: var(--text-color, #555555);
    font-size: 17px;
    font-weight: 500;
    line-height: 1.82;
    margin-bottom: 32px;
    max-width: 52ch;
}

.kb-about-section__features {
    list-style: none;
    margin: 0 0 28px;
    padding: 0 0 28px;
    border-bottom: 1px solid rgba(18, 47, 42, 0.1);
    display: flex;
    flex-direction: column;
    flex: 1;
    justify-content: space-evenly;
    gap: 12px;
    min-height: 0;
}

.kb-about-section__feature {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(18, 47, 42, 0.08);
    box-shadow: 0 8px 24px rgba(18, 47, 42, 0.04);
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease,
        background 0.35s ease;
}

.kb-about-section__feature:hover {
    transform: translateX(6px);
    background: rgba(255, 255, 255, 0.88);
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow:
        0 14px 32px rgba(18, 47, 42, 0.08),
        0 0 0 1px rgba(255, 193, 7, 0.12);
}

.kb-about-section__feature-icon {
    flex-shrink: 0;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, rgba(18, 47, 42, 0.1) 0%, rgba(255, 193, 7, 0.16) 100%);
    color: var(--secondary-color, #122F2A);
    font-size: 15px;
    transition: transform 0.35s ease, background 0.35s ease, color 0.35s ease;
}

.kb-about-section__feature:hover .kb-about-section__feature-icon {
    transform: scale(1.06);
    background: linear-gradient(145deg, var(--secondary-color, #122F2A) 0%, #1a3f38 100%);
    color: var(--accent-color-two, #FFC107);
}

.kb-about-section__feature-text {
    color: var(--secondary-color, #122F2A);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.55;
    padding-top: 2px;
}

.kb-about-section__actions.about-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 24px 28px;
    margin-top: auto;
    flex-shrink: 0;
}

.kb-about-section__cta.theme-button.style-1 {
    border-radius: 999px;
    box-shadow:
        0 12px 28px rgba(71, 8, 4, 0.22),
        inset 0 1px 0 rgba(255, 193, 7, 0.18);
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.kb-about-section__cta.theme-button.style-1:hover {
    transform: translateY(-2px);
    box-shadow:
        0 16px 36px rgba(71, 8, 4, 0.28),
        inset 0 1px 0 rgba(255, 193, 7, 0.22);
}

.kb-about-section__contact.about-contact-box {
    padding: 12px 18px 12px 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(18, 47, 42, 0.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 10px 28px rgba(18, 47, 42, 0.06);
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.kb-about-section__contact.about-contact-box:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow: 0 16px 36px rgba(18, 47, 42, 0.1);
}

.kb-about-section__contact .about-contact-box-content p {
    font-size: 13px;
    font-weight: 600;
    color: #6b7a75;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.kb-about-section__contact .about-contact-box-content a {
    font-size: 1.125rem;
    color: var(--black-color, #1a1a1a);
}

.kb-about-section__collage-glow {
    position: absolute;
    inset: 6%;
    border-radius: 30px;
    background: radial-gradient(circle at 30% 30%, rgba(255, 193, 7, 0.16) 0%, rgba(255, 193, 7, 0) 58%);
    pointer-events: none;
    z-index: 0;
}

.kb-about-section__collage-frame {
    position: absolute;
    inset: 0;
    border-radius: 30px;
    border: 1px solid rgba(255, 193, 7, 0.2);
    pointer-events: none;
    z-index: 1;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.kb-about-section__year.about-year {
    left: -24px;
    top: 64px;
    width: 168px;
    height: 168px;
    background: linear-gradient(145deg, var(--secondary-color, #122F2A) 0%, #1a3f38 100%);
    box-shadow:
        0 18px 40px rgba(18, 47, 42, 0.28),
        0 0 0 6px rgba(255, 255, 255, 0.65);
    z-index: 4;
}

.kb-about-section__year.about-year p {
    font-size: 17px;
    margin-top: 12px;
}

.kb-about-section__year.about-year p span {
    font-size: 36px;
    line-height: 1;
    margin-top: 10px;
    color: var(--accent-color-two, #FFC107);
}

.kb-about-section__badge {
    position: absolute;
    top: 28px;
    right: 0;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(18, 47, 42, 0.1);
    box-shadow: 0 12px 28px rgba(18, 47, 42, 0.1);
    color: var(--secondary-color, #122F2A);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.kb-about-section__badge i {
    color: var(--primary-color, #470804);
    font-size: 14px;
}

.kb-about-section__collage.about-images-box {
    padding-left: 0;
}

.kb-about-section__collage.about-images-box figure {
    padding-left: 0;
}

.kb-about-section__photo {
    position: relative;
    overflow: hidden;
    border-radius: 30px;
    box-shadow:
        0 22px 50px rgba(18, 47, 42, 0.16),
        0 0 0 1px rgba(255, 255, 255, 0.4);
    transition:
        transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.55s ease;
}

.kb-about-section__photo figure,
.kb-about-section__photo img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kb-about-section__photo--main {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: unset;
}

.kb-about-section__photo--main figure {
    width: 100%;
    height: 100%;
    margin: 0;
    overflow: hidden;
    border-radius: 30px;
}

.kb-about-section__photo--main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-about-section__photo--accent {
    position: absolute;
    z-index: 3;
    width: 38%;
    aspect-ratio: 4 / 5;
    border: 3px solid rgba(255, 255, 255, 0.92);
}

.kb-about-section__photo--accent-one {
    right: 0;
    top: 18%;
}

.kb-about-section__photo--accent-one img {
    object-position: 72% 22%;
}

.kb-about-section__photo--accent-two {
    right: 12%;
    bottom: 0;
    width: 34%;
    aspect-ratio: 1 / 1;
}

.kb-about-section__photo--accent-two img {
    object-position: 28% 68%;
}

.kb-about-section__photo--accent img {
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-about-section__photo-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(
        180deg,
        rgba(18, 47, 42, 0) 45%,
        rgba(18, 47, 42, 0.28) 100%
    );
    opacity: 0.75;
    transition: opacity 0.45s ease;
}

.kb-about-section__photo--main .kb-about-section__photo-overlay {
    background: linear-gradient(
        145deg,
        rgba(71, 8, 4, 0.08) 0%,
        rgba(18, 47, 42, 0) 42%,
        rgba(18, 47, 42, 0.22) 100%
    );
}

.kb-about-section__collage:hover .kb-about-section__photo--main {
    transform: translateY(-4px);
    box-shadow:
        0 28px 60px rgba(18, 47, 42, 0.2),
        0 0 0 1px rgba(255, 193, 7, 0.18);
}

.kb-about-section__collage:hover .kb-about-section__photo--main img {
    transform: scale(1.04);
}

.kb-about-section__collage:hover .kb-about-section__photo--accent-one {
    transform: translateY(-6px) translateX(-4px);
    box-shadow: 0 20px 44px rgba(18, 47, 42, 0.18);
}

.kb-about-section__collage:hover .kb-about-section__photo--accent-two {
    transform: translateY(-8px) translateX(4px);
    box-shadow: 0 20px 44px rgba(18, 47, 42, 0.18);
}

.kb-about-section__collage:hover .kb-about-section__photo--accent img {
    transform: scale(1.06);
}

.kb-about-section__collage:hover .kb-about-section__photo-overlay {
    opacity: 0.55;
}

@media (min-width: 992px) {
    .kb-about-section__layout {
        align-items: stretch;
    }

    .kb-about-section__collage-glow,
    .kb-about-section__collage-frame {
        inset: 0;
    }

    .kb-about-section__feature {
        flex: 1;
        align-items: center;
    }
}

@media (max-width: 1199px) {
    .kb-about-section__layout {
        gap: 40px 48px;
    }
}

@media (max-width: 991px) {
    .kb-about-section {
        padding: 64px 0;
    }

    .kb-about-section__layout {
        grid-template-columns: 1fr;
        gap: 48px;
        align-items: start;
    }

    .kb-about-section__content {
        height: auto;
        max-width: none;
    }

    .kb-about-section__features {
        flex: none;
        display: grid;
        gap: 14px;
        justify-content: initial;
        margin-bottom: 28px;
        padding-bottom: 28px;
    }

    .kb-about-section__actions.about-footer {
        margin-top: 0;
    }

    .kb-about-section__heading {
        font-size: clamp(1.875rem, 5vw, 2.375rem);
    }

    .kb-about-section__intro {
        font-size: 16px;
        max-width: none;
    }

    .kb-about-section__collage {
        max-width: 520px;
        margin-inline: auto;
        min-height: 360px;
        height: auto;
    }

    .kb-about-section__photo--main {
        position: relative;
        inset: auto;
        height: auto;
        aspect-ratio: 4 / 4.6;
    }

    .kb-about-section__photo--main figure,
    .kb-about-section__photo--main img {
        height: 100%;
    }
}

@media (max-width: 767px) {
    .kb-about-section {
        padding: 52px 0;
    }

    .kb-about-section__feature {
        padding: 12px 14px;
    }

    .kb-about-section__feature-icon {
        width: 38px;
        height: 38px;
        border-radius: 12px;
        font-size: 14px;
    }

    .kb-about-section__actions.about-footer {
        flex-direction: column;
        align-items: stretch;
        gap: 18px;
    }

    .kb-about-section__contact.about-contact-box {
        justify-content: flex-start;
    }

    .kb-about-section__photo,
    .kb-about-section__photo--main figure,
    .kb-about-section__collage-frame {
        border-radius: 22px;
    }

    .kb-about-section__photo--main {
        aspect-ratio: 4 / 4.2;
    }
}

/* Statistics / achievements — premium spiritual travel (KashiBhakti) */
.kb-stats-section {
    position: relative;
    overflow: visible;
    padding-top: 64px;
    padding-bottom: 36px;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 55%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-stats-section::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.3;
    background-image: radial-gradient(rgba(71, 8, 4, 0.05) 1px, transparent 1px);
    background-size: 26px 26px;
    z-index: 0;
}

.kb-stats-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-stats-section__orb--one {
    width: 280px;
    height: 280px;
    top: -60px;
    left: -40px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-stats-section__orb--two {
    width: 240px;
    height: 240px;
    bottom: -50px;
    right: -30px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.07) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-stats-section .container {
    position: relative;
    z-index: 1;
}

.kb-stats-section__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 24px;
    align-items: stretch;
}

/* Reset theme counter-item defaults that cause top border + extra padding */
.kb-stats-section .counter-item::after {
    display: none;
    content: none;
    width: 0;
    height: 0;
}

.kb-stats-section__card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    height: 100%;
    min-height: 100%;
    padding: 28px 22px 26px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(71, 8, 4, 0.06);
    box-shadow:
        0 2px 8px rgba(71, 8, 4, 0.03),
        0 12px 32px rgba(18, 47, 42, 0.07);
    transition:
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.45s ease,
        border-color 0.45s ease;
    overflow: hidden;
    will-change: transform;
}

.kb-stats-section__card:hover {
    transform: translateY(-6px);
    border-color: rgba(255, 193, 7, 0.28);
    box-shadow:
        0 8px 20px rgba(71, 8, 4, 0.04),
        0 20px 44px rgba(18, 47, 42, 0.1),
        0 0 32px rgba(255, 193, 7, 0.1);
}

.kb-stats-section__icon {
    margin-bottom: 20px;
}

.kb-stats-section__icon figure {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 96px;
    height: 96px;
    margin: 0 auto;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--extra-color, #F5EBEA) 0%, var(--accent-color-one, #F8F2E6) 100%);
    border: 1px solid rgba(255, 193, 7, 0.18);
    box-shadow:
        0 6px 18px rgba(71, 8, 4, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.85);
    transition:
        background 0.4s ease,
        border-color 0.4s ease,
        box-shadow 0.4s ease,
        transform 0.4s ease;
}

.kb-stats-section__icon figure img {
    width: 44px;
    height: 44px;
    object-fit: contain;
    transition: filter 0.4s ease, transform 0.4s ease;
}

.kb-stats-section__card:hover .kb-stats-section__icon figure {
    background: linear-gradient(135deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    border-color: rgba(255, 193, 7, 0.3);
    box-shadow:
        0 10px 24px rgba(71, 8, 4, 0.16),
        0 0 20px rgba(255, 193, 7, 0.14);
    transform: translateY(-2px) scale(1.04);
}

.kb-stats-section__card:hover .kb-stats-section__icon figure img {
    filter: brightness(0) invert(1);
    transform: scale(1.05);
}

.kb-stats-section__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
}

.kb-stats-section__label {
    margin: 0 0 10px;
    color: var(--secondary-color, #122F2A);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.4;
}

.kb-stats-section__value {
    margin: 0 0 12px;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2.25rem, 3.5vw, 3rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
}

.kb-stats-section__value .counter-value {
    color: inherit;
    font: inherit;
}

.kb-stats-section__suffix {
    color: var(--accent-one, #FFC107);
    font-size: 0.72em;
    margin-left: 2px;
}

.kb-stats-section__desc {
    margin: 0;
    max-width: 220px;
    flex: 1;
    color: var(--text-color, #555555);
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
}

@media (max-width: 991px) {
    .kb-stats-section {
        padding-top: 52px;
        padding-bottom: 28px;
    }
}

@media (max-width: 1199px) {
    .kb-stats-section__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 20px;
    }
}

@media (max-width: 767px) {
    .kb-stats-section {
        padding-top: 44px;
        padding-bottom: 24px;
    }

    .kb-stats-section__grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .kb-stats-section__card {
        padding: 24px 20px 22px;
        border-radius: 22px;
    }

    .kb-stats-section__icon figure {
        width: 84px;
        height: 84px;
    }

    .kb-stats-section__desc {
        max-width: none;
    }
}

/* Pull ticker closer to stats cards */
.kb-stats-section + .kb-marquee-ticker {
    margin-top: -8px;
}

/* Luxury pilgrimage ticker */
.kb-marquee-ticker {
    position: relative;
    padding: 10px 0 !important;
    overflow: hidden;
    background: linear-gradient(
        90deg,
        rgba(248, 242, 230, 0.95) 0%,
        rgba(245, 235, 234, 0.98) 50%,
        rgba(248, 242, 230, 0.95) 100%
    ) !important;
    border-top: 1px solid rgba(255, 193, 7, 0.22);
    border-bottom: 1px solid rgba(71, 8, 4, 0.08);
    backdrop-filter: blur(10px);
}

.kb-marquee-ticker::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(
        90deg,
        var(--accent-color-one, #F8F2E6) 0%,
        transparent 12%,
        transparent 88%,
        var(--accent-color-one, #F8F2E6) 100%
    );
    z-index: 1;
}

.kb-marquee-ticker__track {
    gap: 24px !important;
}

.kb-marquee-ticker__content {
    gap: 24px !important;
    animation-duration: 40s !important;
}

.kb-marquee-ticker__item {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.kb-marquee-ticker .kb-marquee-ticker__icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    min-height: 30px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.85) !important;
    border: 1px solid rgba(255, 193, 7, 0.35) !important;
    box-shadow: 0 4px 12px rgba(71, 8, 4, 0.06) !important;
    flex-shrink: 0;
}

.kb-marquee-ticker .kb-marquee-ticker__icon .home-marquee-section__om,
.kb-marquee-ticker .kb-marquee-ticker__icon .fa-om {
    display: block !important;
    font-size: 14px !important;
    line-height: 1 !important;
    color: var(--primary-color, #470804) !important;
}

.kb-marquee-ticker .marquee-content p {
    margin: 0;
    color: var(--secondary-color, #122F2A) !important;
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.kb-marquee-ticker__dot {
    display: inline-block;
    width: 5px;
    height: 5px;
    margin: 0 2px;
    border-radius: 50%;
    background: var(--accent-one, #FFC107);
    opacity: 0.7;
    flex-shrink: 0;
    box-shadow: 0 0 6px rgba(255, 193, 7, 0.35);
}

@media (max-width: 767px) {
    .kb-marquee-ticker {
        padding: 8px 0 !important;
    }

    .kb-marquee-ticker__content {
        gap: 18px !important;
    }

    .kb-marquee-ticker .marquee-content p {
        font-size: 14px !important;
    }

    .kb-marquee-ticker .kb-marquee-ticker__icon {
        width: 26px !important;
        height: 26px !important;
        min-width: 26px !important;
        min-height: 26px !important;
    }
}

/* Home contact section — premium spiritual travel (KashiBhakti) */
.kb-contact-section {
    position: relative;
    overflow: hidden;
    background: linear-gradient(
        180deg,
        var(--accent-color-one, #F8F2E6) 0%,
        var(--extra-color, #F5EBEA) 52%,
        var(--white-color, #ffffff) 100%
    );
}

.kb-contact-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-contact-section__orb--one {
    width: 340px;
    height: 340px;
    top: -90px;
    left: -80px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.12) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-contact-section__orb--two {
    width: 280px;
    height: 280px;
    bottom: -40px;
    right: -50px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.08) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-contact-section .container {
    position: relative;
    z-index: 1;
}

.kb-contact-section__layout {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 48px 56px;
    align-items: center;
}

.kb-contact-section__visual {
    position: relative;
    border-radius: 30px;
    overflow: hidden;
    min-height: 100%;
    box-shadow:
        0 8px 20px rgba(71, 8, 4, 0.08),
        0 28px 60px rgba(18, 47, 42, 0.16);
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.5s ease;
}

.kb-contact-section__visual:hover {
    transform: translateY(-6px);
    box-shadow:
        0 12px 28px rgba(71, 8, 4, 0.1),
        0 36px 72px rgba(18, 47, 42, 0.2),
        0 0 0 1px rgba(255, 193, 7, 0.18);
}

.kb-contact-section__figure {
    position: absolute;
    inset: 0;
    margin: 0;
}

.kb-contact-section__figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-contact-section__visual:hover .kb-contact-section__figure img {
    transform: scale(1.06);
}

.kb-contact-section__visual-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(18, 47, 42, 0.15) 0%,
        rgba(18, 47, 42, 0.45) 52%,
        rgba(71, 8, 4, 0.72) 100%
    );
    pointer-events: none;
}

.kb-contact-section__visual-glow {
    position: absolute;
    inset: auto -20% -25% auto;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.35) 0%, rgba(255, 193, 7, 0) 70%);
    pointer-events: none;
    filter: blur(2px);
}

.kb-contact-section__badge {
    position: absolute;
    left: 24px;
    bottom: 24px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 18px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    color: var(--primary-color, #470804);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.03em;
    box-shadow: 0 12px 28px rgba(18, 47, 42, 0.18);
}

.kb-contact-section__badge i {
    color: var(--accent-one, #FFC107);
    font-size: 16px;
}

.kb-contact-section__header.section-title h2 {
    font-size: clamp(2rem, 3.2vw, 2.75rem);
    line-height: 1.2;
    margin-bottom: 0;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
}

.kb-contact-section__header.section-title .sub-title {
    margin-bottom: 14px;
}

.kb-contact-section__intro {
    margin-top: 14px;
    margin-bottom: 0;
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.75;
    font-weight: 500;
    max-width: 52ch;
}

.kb-contact-section__card {
    margin-top: 28px;
    padding: 34px 34px 32px;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow:
        0 4px 10px rgba(71, 8, 4, 0.04),
        0 24px 56px rgba(18, 47, 42, 0.12);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}

.kb-contact-section__card:hover {
    transform: translateY(-4px);
    box-shadow:
        0 8px 16px rgba(71, 8, 4, 0.06),
        0 32px 64px rgba(18, 47, 42, 0.14),
        0 0 0 1px rgba(255, 193, 7, 0.14);
}

.kb-contact-form__alert {
    margin-bottom: 18px;
    padding: 14px 18px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 600;
}

.kb-contact-form__alert--success {
    background: rgba(18, 47, 42, 0.08);
    border: 1px solid rgba(18, 47, 42, 0.14);
    color: var(--secondary-color, #122F2A);
}

.kb-contact-form__alert--error {
    background: rgba(71, 8, 4, 0.08);
    border: 1px solid rgba(71, 8, 4, 0.14);
    color: var(--primary-color, #470804);
}

.kb-contact-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 20px;
}

.kb-contact-form__field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.kb-contact-form__field--full {
    grid-column: 1 / -1;
}

.kb-contact-form__field label {
    font-size: 13px;
    font-weight: 700;
    color: var(--primary-color, #470804);
    letter-spacing: 0.02em;
}

.kb-contact-form__field input,
.kb-contact-form__field textarea {
    width: 100%;
    border: 1px solid rgba(71, 8, 4, 0.1);
    border-radius: 16px;
    padding: 15px 18px;
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 500;
    color: var(--primary-color, #470804);
    background: rgba(245, 235, 234, 0.45);
    box-shadow: inset 0 1px 2px rgba(18, 47, 42, 0.04);
    transition:
        border-color 0.35s ease,
        box-shadow 0.35s ease,
        background 0.35s ease,
        transform 0.35s ease;
}

.kb-contact-form__field textarea {
    min-height: 150px;
    resize: vertical;
}

.kb-contact-form__field input::placeholder,
.kb-contact-form__field textarea::placeholder {
    color: rgba(71, 8, 4, 0.45);
}

.kb-contact-form__field input:focus,
.kb-contact-form__field textarea:focus {
    outline: none;
    border-color: rgba(255, 193, 7, 0.65);
    background: var(--white-color, #ffffff);
    box-shadow:
        0 0 0 4px rgba(255, 193, 7, 0.18),
        0 10px 24px rgba(71, 8, 4, 0.08);
    transform: translateY(-1px);
}

.kb-contact-form__actions {
    margin-top: 24px;
}

.kb-contact-form__submit {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: var(--white-color, #ffffff);
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.03em;
    cursor: pointer;
    box-shadow:
        0 12px 28px rgba(71, 8, 4, 0.22),
        inset 0 1px 0 rgba(255, 193, 7, 0.18);
    transition:
        background 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.kb-contact-form__submit i {
    font-size: 12px;
    transition: transform 0.35s ease;
}

.kb-contact-form__submit:hover {
    background: linear-gradient(135deg, var(--secondary-color, #122F2A) 0%, #0f2420 100%);
    transform: translateY(-2px);
    box-shadow:
        0 16px 32px rgba(18, 47, 42, 0.22),
        0 0 0 1px rgba(255, 193, 7, 0.28);
}

.kb-contact-form__submit:hover i {
    transform: translateX(4px);
}

@media (max-width: 1199px) {
    .kb-contact-section__layout {
        gap: 40px;
    }

    .kb-contact-section__visual {
        min-height: 480px;
    }
}

@media (max-width: 991px) {
    .kb-contact-section__layout {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .kb-contact-section__visual {
        min-height: 380px;
    }

    .kb-contact-section__card {
        margin-top: 0;
    }
}

.contact-form-box.kb-contact-section__card {
    margin-top: 0;
}

@media (max-width: 767px) {
    .kb-contact-section__visual {
        min-height: 300px;
        border-radius: 22px;
    }

    .kb-contact-section__card {
        padding: 24px 20px 22px;
        border-radius: 22px;
    }

    .kb-contact-form__grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

/* Service detail page — premium spiritual booking (KashiBhakti) */
.kb-service-detail {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
}

.kb-service-detail::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.18;
    background-image: radial-gradient(rgba(71, 8, 4, 0.04) 1px, transparent 1px);
    background-size: 26px 26px;
    z-index: 0;
}

.kb-service-detail__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-service-detail__orb--one {
    width: 280px;
    height: 280px;
    top: 8%;
    right: -70px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-service-detail__orb--two {
    width: 220px;
    height: 220px;
    bottom: 12%;
    left: -50px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.08) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-service-detail .container {
    position: relative;
    z-index: 1;
}

.kb-service-detail__layout {
    align-items: flex-start;
    gap: 0;
}

.kb-service-detail__main-col {
    margin-bottom: 0;
}

.kb-service-detail__main.service-single-post {
    margin-bottom: 0;
}

/* Hero image */
.kb-service-detail__hero.service-single-media {
    position: relative;
    width: 100%;
    margin-bottom: 36px;
    border-radius: 28px;
    overflow: hidden;
    box-shadow:
        0 16px 44px rgba(18, 47, 42, 0.12),
        0 0 0 1px rgba(255, 193, 7, 0.12);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}

.kb-service-detail__hero.service-single-media:hover {
    transform: translateY(-4px);
    box-shadow:
        0 22px 52px rgba(18, 47, 42, 0.14),
        0 0 0 1px rgba(255, 193, 7, 0.2),
        0 0 32px rgba(255, 193, 7, 0.08);
}

.kb-service-detail__hero.service-single-media figure {
    width: 100%;
    margin: 0;
    aspect-ratio: 16 / 9;
    max-height: min(52vh, 520px);
    overflow: hidden;
    border-radius: 28px;
}

.kb-service-detail__hero.service-single-media figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: 28px;
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-service-detail__hero.service-single-media:hover figure img {
    transform: scale(1.03);
}

.kb-service-detail__hero-frame {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    border: 1px solid rgba(255, 193, 7, 0.2);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
    z-index: 2;
}

/* Main content typography */
.kb-service-detail__title {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2rem, 3.4vw, 2.75rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--primary-color, #470804);
    margin: 0 0 16px;
    text-transform: none;
}

.kb-service-detail__lead {
    font-size: 18px;
    line-height: 1.75;
    font-weight: 500;
    color: var(--secondary-color, #122F2A);
    margin: 0 0 28px;
    max-width: 72ch;
}

.kb-service-detail__prose {
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.82;
    font-weight: 500;
}

.kb-service-detail__prose p {
    margin-bottom: 1.1em;
}

.kb-service-detail__prose h2,
.kb-service-detail__prose h3,
.kb-service-detail__prose h4 {
    font-family: var(--title-fonts, "Merriweather", serif);
    color: var(--primary-color, #470804);
    font-weight: 700;
    line-height: 1.35;
    margin: 1.6em 0 0.65em;
    text-transform: none;
}

.kb-service-detail__prose h2 {
    font-size: clamp(1.5rem, 2.2vw, 1.875rem);
}

.kb-service-detail__prose h3 {
    font-size: clamp(1.25rem, 1.8vw, 1.5rem);
}

.kb-service-detail__prose ul,
.kb-service-detail__prose ol {
    margin: 0 0 1.25em;
    padding-left: 1.25em;
}

.kb-service-detail__prose li {
    margin-bottom: 0.5em;
}

.kb-service-detail__block {
    margin-top: 40px;
    padding-top: 36px;
    border-top: 1px solid rgba(18, 47, 42, 0.08);
}

.kb-service-detail__subtitle {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.35rem, 2vw, 1.625rem);
    font-weight: 700;
    line-height: 1.35;
    color: var(--primary-color, #470804);
    margin: 0 0 20px;
    text-transform: none;
}

.kb-service-detail__benefits {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 12px;
}

.kb-service-detail__benefits li {
    position: relative;
    margin: 0;
    padding: 16px 18px 16px 48px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(71, 8, 4, 0.06);
    box-shadow: 0 4px 14px rgba(18, 47, 42, 0.05);
    color: var(--text-color, #555555);
    font-size: 15px;
    line-height: 1.65;
    font-weight: 500;
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.kb-service-detail__benefits li::before {
    content: "\f004";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    color: var(--primary-color, #470804);
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.35) 0%, rgba(255, 193, 7, 0.12) 100%);
    border-radius: 50%;
}

.kb-service-detail__benefits li:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 193, 7, 0.22);
    box-shadow: 0 8px 22px rgba(18, 47, 42, 0.08);
}

/* Service page FAQ — reuse premium accordion */
.kb-service-detail .kb-service-detail__faq.kb-faq-accordion {
    display: grid;
    gap: 14px;
}

.kb-service-detail .kb-service-detail__faq .accordion-item.kb-faq-accordion__item {
    margin-bottom: 0;
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(71, 8, 4, 0.08);
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 4px 14px rgba(18, 47, 42, 0.06);
    transition: transform 0.4s ease, box-shadow 0.4s ease, border-color 0.4s ease;
}

.kb-service-detail .kb-service-detail__faq .accordion-item.kb-faq-accordion__item:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 193, 7, 0.28);
    box-shadow: 0 12px 32px rgba(18, 47, 42, 0.1);
}

.kb-service-detail .kb-service-detail__faq .accordion-button.kb-faq-accordion__trigger {
    padding: 20px 22px;
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--primary-color, #470804);
    background: transparent;
    box-shadow: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.kb-service-detail .kb-service-detail__faq .accordion-button.kb-faq-accordion__trigger::after {
    display: none;
}

.kb-service-detail .kb-service-detail__faq .kb-faq-accordion__question {
    flex: 1;
    text-align: left;
}

.kb-service-detail .kb-service-detail__faq .kb-faq-accordion__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--extra-color, #F5EBEA);
    color: var(--primary-color, #470804);
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    border: 1px solid rgba(255, 193, 7, 0.25);
    transition: transform 0.45s ease, background 0.4s ease, box-shadow 0.4s ease;
}

.kb-service-detail .kb-service-detail__faq .kb-faq-accordion__icon::before {
    content: "+";
}

.kb-service-detail .kb-service-detail__faq .accordion-button.kb-faq-accordion__trigger:not(.collapsed) {
    background: var(--secondary-color, #122F2A);
    color: #ffffff;
}

.kb-service-detail .kb-service-detail__faq .accordion-button:not(.collapsed) .kb-faq-accordion__icon {
    background: rgba(255, 193, 7, 0.18);
    color: #ffc107;
    box-shadow: 0 0 0 1px rgba(255, 193, 7, 0.35);
    transform: rotate(45deg);
}

.kb-service-detail .kb-service-detail__faq .accordion-button:not(.collapsed) .kb-faq-accordion__icon::before {
    content: "+";
}

.kb-service-detail .kb-service-detail__faq .accordion-body.kb-faq-accordion__body {
    padding: 0 22px 20px;
    color: var(--text-color, #555555);
    font-size: 15px;
    line-height: 1.75;
}

.kb-service-detail .kb-service-detail__faq .accordion-body.kb-faq-accordion__body p {
    margin: 0;
}

/* Sidebar — sticky on left (desktop); main content scrolls on right */
@media (min-width: 992px) {
    .kb-service-detail__sidebar-col {
        position: sticky;
        top: 120px;
        align-self: flex-start;
        z-index: 2;
    }
}

.kb-service-detail__sidebar.widget-sidebar {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.kb-service-detail__nav-card.widget,
.kb-service-detail__help-card.widget {
    margin-bottom: 0 !important;
    padding: 28px 24px 26px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(71, 8, 4, 0.06);
    box-shadow:
        0 4px 12px rgba(71, 8, 4, 0.03),
        0 16px 40px rgba(18, 47, 42, 0.08);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}

.kb-service-detail__nav-card.widget:hover,
.kb-service-detail__help-card.widget:hover {
    transform: translateY(-4px);
    box-shadow:
        0 8px 20px rgba(71, 8, 4, 0.05),
        0 22px 48px rgba(18, 47, 42, 0.1);
}

.kb-service-detail__widget-title h3 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin: 0 0 20px;
    text-transform: none;
}

.kb-service-detail__nav-list.category-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.kb-service-detail__nav-list.category-list li {
    margin: 0 0 10px;
}

.kb-service-detail__nav-list.category-list li:last-child {
    margin-bottom: 0;
}

.kb-service-detail__nav-link,
.kb-service-detail .widget-categories-list .category-list li a.kb-service-detail__nav-link {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 14px 18px;
    border-radius: 999px;
    background: rgba(248, 242, 230, 0.65);
    border: 1px solid rgba(18, 47, 42, 0.06);
    color: var(--secondary-color, #122F2A);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
    text-decoration: none;
    text-transform: none;
    transition:
        background 0.35s ease,
        color 0.35s ease,
        border-color 0.35s ease,
        box-shadow 0.35s ease,
        transform 0.35s ease;
}

.kb-service-detail__nav-link:hover,
.kb-service-detail .widget-categories-list .category-list li a.kb-service-detail__nav-link:hover {
    background: rgba(255, 255, 255, 0.95);
    color: var(--primary-color, #470804);
    border-color: rgba(255, 193, 7, 0.28);
    box-shadow: 0 6px 18px rgba(18, 47, 42, 0.08);
    transform: translateX(4px);
}

.kb-service-detail__nav-link.active,
.kb-service-detail .widget-categories-list .category-list li a.kb-service-detail__nav-link.active {
    background: linear-gradient(135deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: #ffffff !important;
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow:
        0 8px 22px rgba(71, 8, 4, 0.2),
        0 0 24px rgba(255, 193, 7, 0.12);
}

.kb-service-detail__help-text {
    margin: 0 0 20px;
    font-size: 15px;
    line-height: 1.7;
    color: var(--text-color, #555555);
    font-weight: 500;
}

.kb-service-detail .widget.widget-cta .service-cta-item .service-cta-list.kb-service-detail__help-row {
    margin-bottom: 16px;
}

.kb-service-detail .widget.widget-cta .service-cta-item .service-cta-list.kb-service-detail__help-row:last-of-type {
    margin-bottom: 22px;
}

.kb-service-detail .widget.widget-cta .service-cta-item .service-cta-list .kb-service-detail__help-icon.service-cta-icon {
    width: 48px;
    height: 48px;
    min-width: 48px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--extra-color, #F5EBEA) 0%, var(--accent-color-one, #F8F2E6) 100%);
    border: 1px solid rgba(255, 193, 7, 0.22);
    color: var(--primary-color, #470804);
    box-shadow: 0 4px 14px rgba(71, 8, 4, 0.06);
    transition: background 0.35s ease, color 0.35s ease, transform 0.35s ease;
}

.kb-service-detail .widget.widget-cta .service-cta-item .service-cta-list .kb-service-detail__help-icon.service-cta-icon::before {
    display: none !important;
}

.kb-service-detail .widget.widget-cta .service-cta-item .service-cta-list .kb-service-detail__help-icon.service-cta-icon i {
    position: relative;
    z-index: 2;
    display: block;
    font-size: 16px;
    line-height: 1;
    color: var(--primary-color, #470804);
}

.kb-service-detail .widget.widget-cta .service-cta-item .service-cta-list:hover .kb-service-detail__help-icon.service-cta-icon {
    background: linear-gradient(145deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: #ffffff;
    transform: scale(1.04);
}

.kb-service-detail .widget.widget-cta .service-cta-item .service-cta-list:hover .kb-service-detail__help-icon.service-cta-icon i {
    color: #ffffff;
}

.kb-service-detail__help-row .service-cta-content p {
    margin: 0 0 2px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--secondary-color, #122F2A);
}

.kb-service-detail__help-row .service-cta-content a {
    font-size: 15px;
    font-weight: 700;
    color: var(--primary-color, #470804);
    text-decoration: none;
    transition: color 0.3s ease;
}

.kb-service-detail__help-row:hover .service-cta-content a {
    color: var(--primary-color, #470804);
}

.kb-service-detail__help-cta.theme-button.style-1 {
    width: 100%;
    justify-content: center;
    border-radius: 999px;
    margin-top: 4px;
    box-shadow: 0 4px 16px rgba(71, 8, 4, 0.12);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.kb-service-detail__help-cta.theme-button.style-1:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(71, 8, 4, 0.18), 0 0 28px rgba(255, 193, 7, 0.12);
}

@media (max-width: 1199px) {
    .kb-service-detail__hero.service-single-media figure,
    .kb-service-detail__hero.service-single-media figure img,
    .kb-service-detail__hero.service-single-media {
        border-radius: 22px;
    }
}

@media (max-width: 991px) {
    .kb-service-detail__main-col {
        margin-bottom: 40px;
    }

    .kb-service-detail__sidebar.widget-sidebar {
        gap: 20px;
    }
}

@media (max-width: 767px) {
    .kb-service-detail__hero.service-single-media figure {
        aspect-ratio: 4 / 3;
    }

    .kb-service-detail__nav-card.widget,
    .kb-service-detail__help-card.widget {
        padding: 22px 20px 20px;
        border-radius: 22px;
    }

    .kb-service-detail__lead {
        font-size: 16px;
    }
}

/* Blog detail — same wide banner image as service detail */
.blog-single-section .blog-single-post .blog-single-media {
    width: 100%;
    margin-bottom: 30px;
}

.blog-single-section .blog-single-post .blog-single-media figure {
    width: 100%;
    margin: 0;
    aspect-ratio: 856 / 513;
    max-height: min(52vh, 513px);
    overflow: hidden;
}

.blog-single-section .blog-single-post .blog-single-media figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* Events listing — no underline on card titles */
.event-section-2 .event-item .event-content h2 a,
.event-section-2 .event-item .event-content h2 a:hover,
.event-section-2 .event-item:hover .event-content h2 a,
.event-section-2 .kb-events-list__card .kb-events-list__title a,
.event-section-2 .kb-events-list__card .kb-events-list__title a:hover,
.event-section-2 .kb-events-list__card.event-item:hover .kb-events-list__title a {
    text-decoration: none !important;
}

/* Home featured spiritual event — premium visual layer (animations unchanged) */
.event-section-1.kb-featured-events-section {
    position: relative;
    overflow: visible;
    background: linear-gradient(
        180deg,
        var(--accent-color-one, #F8F2E6) 0%,
        var(--extra-color, #F5EBEA) 45%,
        var(--white-color, #ffffff) 100%
    ) !important;
}

.event-section-1.kb-featured-events-section::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.28;
    background-image: radial-gradient(rgba(71, 8, 4, 0.05) 1px, transparent 1px);
    background-size: 28px 28px;
    z-index: 0;
}

.event-section-1.kb-featured-events-section .event-wapper {
    position: relative;
    z-index: 1;
}

.event-section-1.kb-featured-events-section .section-title h2 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2rem, 3.2vw, 2.75rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--primary-color, #470804);
}

.event-section-1.kb-featured-events-section .section-title p {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.75;
    font-weight: 500;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event {
    border-radius: 32px;
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow:
        0 6px 14px rgba(71, 8, 4, 0.04),
        0 24px 56px rgba(18, 47, 42, 0.1);
    margin-bottom: 40px;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content {
    position: relative;
    padding: 40px 32px 40px 40px;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content .event-number {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(3rem, 5vw, 4.25rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.03em;
    color: rgba(71, 8, 4, 0.14);
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content h2 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 14px;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content h2 a {
    color: var(--primary-color, #470804);
    text-decoration: none;
    transition: color 0.35s ease;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content p.desc {
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.75;
    font-weight: 500;
    max-width: 520px;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content .event-info {
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 193, 7, 0.2);
    border-left: 3px solid var(--accent-one, #FFC107);
    border-radius: 22px;
    padding: 26px 28px;
    box-shadow:
        0 10px 28px rgba(18, 47, 42, 0.1),
        0 0 0 1px rgba(255, 255, 255, 0.6) inset;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content .event-info ul {
    gap: 18px;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content .event-info ul li p.event-info-content {
    color: var(--secondary-color, #122F2A);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.5;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content .event-info ul li p.event-info-icon {
    width: 42px;
    height: 42px;
    min-width: 42px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--extra-color, #F5EBEA) 0%, var(--accent-color-one, #F8F2E6) 100%);
    color: var(--primary-color, #470804);
    border: 1px solid rgba(255, 193, 7, 0.28);
    box-shadow: 0 6px 16px rgba(71, 8, 4, 0.08);
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-image {
    padding: 20px 20px 20px 8px;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-image a figure {
    border-radius: 24px;
    overflow: hidden;
    box-shadow:
        0 12px 32px rgba(18, 47, 42, 0.16),
        inset 0 0 0 1px rgba(255, 255, 255, 0.25);
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-image::after {
    content: "";
    position: absolute;
    inset: 20px 20px 20px 8px;
    border-radius: 24px;
    pointer-events: none;
    z-index: 2;
    background: linear-gradient(
        180deg,
        rgba(18, 47, 42, 0.08) 0%,
        rgba(18, 47, 42, 0.22) 55%,
        rgba(71, 8, 4, 0.38) 100%
    );
    opacity: 0.55;
    transition: opacity 0.5s ease;
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event:hover .event-image::after {
    opacity: 0.72;
}

/* Preserve existing hover color behavior (theme main.css) */
.event-section-1.kb-featured-events-section .event-item.kb-featured-event:hover .event-content .event-number {
    color: var(--white-color, #ffffff);
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event:hover .event-content h2,
.event-section-1.kb-featured-events-section .event-item.kb-featured-event:hover .event-content h2 a {
    color: var(--white-color, #ffffff);
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event:hover .event-content p.desc {
    color: var(--white-color, #ffffff);
}

.event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-button-wapper .theme-button.style-1 {
    border-radius: 999px;
    box-shadow:
        0 12px 28px rgba(71, 8, 4, 0.2),
        inset 0 1px 0 rgba(255, 193, 7, 0.16);
}

.event-section-1.kb-featured-events-section .more-event-content p {
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.7;
    font-weight: 500;
}

@media (max-width: 991px) {
    .event-section-1.kb-featured-events-section .event-item.kb-featured-event {
        border-radius: 24px;
    }

    .event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content {
        padding: 28px 24px;
    }

    .event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-image {
        padding: 16px;
    }

    .event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-image::after {
        inset: 16px;
        border-radius: 20px;
    }

    .event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-image a figure {
        border-radius: 20px;
    }
}

@media (max-width: 767px) {
    .event-section-1.kb-featured-events-section .event-item.kb-featured-event .event-content .event-info {
        padding: 22px 20px;
    }
}

/* Home hero — full-width background image */
.hero-section-1--fullwidth .hero-items {
    min-height: min(88vh, 920px);
}

.hero-section-1--fullwidth .hero-items .hero-image {
    width: 100%;
    left: 0;
    right: 0;
    inset: 0;
}

.hero-section-1--fullwidth .hero-items .hero-image::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        90deg,
        rgba(13, 59, 46, 0.94) 0%,
        rgba(13, 59, 46, 0.78) 38%,
        rgba(13, 59, 46, 0.35) 62%,
        rgba(13, 59, 46, 0.08) 100%
    );
}

.hero-section-1--fullwidth .hero-items .hero-image figure {
    position: absolute;
    inset: 0;
}

.hero-section-1--fullwidth .hero-items .hero-content.hero-content--overlay {
    position: relative;
    z-index: 3;
    width: min(680px, 58%);
    max-width: 680px;
    background: transparent;
    padding-left: clamp(24px, 4vw, 50px);
    padding-right: clamp(24px, 4vw, 50px);
}

.hero-section-1 .hero-items .hero-content .section-title {
    gap: 14px;
}

.hero-section-1 .hero-items .hero-content .section-title h1 {
    line-height: 1.12;
    margin-bottom: 0;
}

.hero-section-1 .hero-items .hero-content .section-title p {
    line-height: 1.45;
    margin-bottom: 0;
}

.hero-image-info-btn {
    position: absolute;
    top: 24px;
    right: 24px;
    z-index: 5;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border: none;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: var(--secondary-color, #0d3b2e);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    transition: background 0.2s ease, transform 0.2s ease;
}

.hero-image-info-btn:hover {
    background: #fff;
    transform: translateY(-1px);
}

.hero-ai-prompt-modal .hero-ai-prompt-intro {
    margin-bottom: 16px;
    color: #555;
}

.hero-ai-prompt-modal .hero-ai-prompt-text {
    margin: 0;
    padding: 16px;
    border-radius: 12px;
    background: #f4f6f5;
    border: 1px solid #dde5e1;
    white-space: pre-wrap;
    word-break: break-word;
    font-size: 13px;
    line-height: 1.55;
    max-height: 50vh;
    overflow: auto;
}

.hero-ai-prompt-modal .modal-footer {
    gap: 12px;
    flex-wrap: wrap;
}

@media (max-width: 991px) {
    .hero-section-1--fullwidth .hero-items {
        min-height: auto;
    }

    .hero-section-1--fullwidth .hero-items .hero-image {
        position: relative;
        min-height: 420px;
    }

    .hero-section-1--fullwidth .hero-items .hero-image::after {
        background: linear-gradient(
            180deg,
            rgba(13, 59, 46, 0.15) 0%,
            rgba(13, 59, 46, 0.55) 100%
        );
    }

    .hero-section-1--fullwidth .hero-items .hero-content.hero-content--overlay {
        width: 100%;
        background: var(--secondary-color);
    }

    .hero-section-1 .hero-items .hero-content .section-title h1 {
        line-height: 1.15;
    }

    .hero-image-info-btn {
        top: 16px;
        right: 16px;
    }
}

/* FAQ section — premium spiritual travel (KashiBhakti) */
.kb-faq-section {
    position: relative;
    overflow: hidden;
    background: var(--extra-color, #F5EBEA);
}

.kb-faq-section--warm {
    background: linear-gradient(
        180deg,
        var(--accent-color-one, #F8F2E6) 0%,
        var(--extra-color, #F5EBEA) 55%,
        var(--white-color, #ffffff) 100%
    );
}

.kb-faq-section__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-faq-section__orb--one {
    width: 320px;
    height: 320px;
    top: -80px;
    right: -60px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.14) 0%, rgba(255, 193, 7, 0) 70%);
}

.kb-faq-section__orb--two {
    width: 260px;
    height: 260px;
    bottom: 12%;
    left: -70px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.08) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-faq-section .container {
    position: relative;
    z-index: 1;
}

.kb-faq-section__layout {
    display: grid;
    grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
    gap: 48px 64px;
    align-items: start;
}

@media (min-width: 992px) {
    .kb-faq-section__aside {
        position: sticky;
        top: 120px;
    }
}

.kb-faq-section__intro.section-title h2 {
    font-size: clamp(2rem, 3.2vw, 2.75rem);
    line-height: 1.2;
    margin-bottom: 0;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
}

.kb-faq-section__intro.section-title .sub-title {
    margin-bottom: 14px;
}

.kb-faq-section__help-card {
    position: relative;
    margin-top: 32px;
    padding: 34px 32px 32px;
    border-radius: 28px;
    background: var(--white-color, #ffffff);
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow:
        0 4px 8px rgba(71, 8, 4, 0.04),
        0 22px 48px rgba(18, 47, 42, 0.1);
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.45s ease;
}

.kb-faq-section__help-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(
        135deg,
        rgba(255, 193, 7, 0.45) 0%,
        rgba(71, 8, 4, 0.12) 48%,
        rgba(18, 47, 42, 0.1) 100%
    );
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
}

.kb-faq-section__help-card:hover {
    transform: translateY(-6px);
    box-shadow:
        0 8px 16px rgba(71, 8, 4, 0.06),
        0 28px 56px rgba(18, 47, 42, 0.14),
        0 0 0 1px rgba(255, 193, 7, 0.18);
}

.kb-faq-section__help-accent {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    margin-bottom: 18px;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--extra-color, #F5EBEA) 0%, var(--accent-color-one, #F8F2E6) 100%);
    color: var(--primary-color, #470804);
    font-size: 22px;
    box-shadow: 0 10px 24px rgba(71, 8, 4, 0.1);
}

.kb-faq-section__help-title {
    margin: 0 0 12px;
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.35rem, 2vw, 1.75rem);
    font-weight: 700;
    line-height: 1.35;
    color: var(--primary-color, #470804);
}

.kb-faq-section__help-text {
    margin: 0 0 24px;
    color: var(--text-color, #555555);
    font-size: 15px;
    line-height: 1.75;
    font-weight: 500;
}

.kb-faq-section__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 26px;
    border-radius: 999px;
    background: var(--primary-color, #470804);
    color: var(--white-color, #ffffff);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-decoration: none;
    box-shadow: 0 12px 28px rgba(71, 8, 4, 0.22);
    transition:
        background 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
}

.kb-faq-section__cta i {
    font-size: 12px;
    transition: transform 0.35s ease;
}

.kb-faq-section__cta:hover {
    background: var(--secondary-color, #122F2A);
    color: var(--white-color, #ffffff);
    transform: translateY(-2px);
    box-shadow:
        0 16px 32px rgba(18, 47, 42, 0.22),
        0 0 0 1px rgba(255, 193, 7, 0.25);
}

.kb-faq-section__cta:hover i {
    transform: translateX(4px);
}

.kb-faq-accordion {
    display: grid;
    gap: 18px;
}

.kb-faq-section .kb-faq-accordion .accordion-item.kb-faq-accordion__item {
    margin-bottom: 0;
    background: var(--white-color, #ffffff);
    border: 1px solid rgba(71, 8, 4, 0.08);
    border-radius: 22px;
    overflow: hidden;
    box-shadow:
        0 4px 8px rgba(71, 8, 4, 0.04),
        0 16px 36px rgba(18, 47, 42, 0.08);
    transition:
        transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.4s ease,
        border-color 0.4s ease;
}

.kb-faq-section .kb-faq-accordion .accordion-item.kb-faq-accordion__item:hover {
    transform: translateY(-4px);
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow:
        0 8px 16px rgba(71, 8, 4, 0.06),
        0 24px 48px rgba(18, 47, 42, 0.12),
        0 0 0 1px rgba(255, 193, 7, 0.12);
}

.kb-faq-section .kb-faq-accordion .accordion-item.kb-faq-accordion__item:has(.accordion-button:not(.collapsed)) {
    border-color: rgba(255, 193, 7, 0.28);
    box-shadow:
        0 10px 24px rgba(18, 47, 42, 0.18),
        0 0 0 1px rgba(255, 193, 7, 0.2),
        0 0 32px rgba(255, 193, 7, 0.12);
    transform: translateY(-2px);
}

.kb-faq-section .kb-faq-accordion .accordion-header.kb-faq-accordion__header {
    margin-bottom: 0 !important;
}

.kb-faq-section .kb-faq-accordion .accordion-button.kb-faq-accordion__trigger {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    width: 100%;
    padding: 22px 24px;
    background: transparent;
    border: 0;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1rem, 1.4vw, 1.125rem);
    font-weight: 700;
    line-height: 1.45;
    text-align: left;
    text-transform: none;
    box-shadow: none;
    transition:
        background 0.4s ease,
        color 0.4s ease,
        padding 0.35s ease;
}

.kb-faq-section .kb-faq-accordion .accordion-button.kb-faq-accordion__trigger::after {
    display: none;
}

.kb-faq-section .kb-faq-accordion .kb-faq-accordion__question {
    flex: 1;
    padding-right: 8px;
}

.kb-faq-section .kb-faq-accordion .kb-faq-accordion__icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--extra-color, #F5EBEA);
    color: var(--primary-color, #470804);
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    transition:
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        background 0.4s ease,
        color 0.4s ease,
        box-shadow 0.4s ease;
}

.kb-faq-section .kb-faq-accordion .kb-faq-accordion__icon::before {
    content: "+";
}

.kb-faq-section .kb-faq-accordion .accordion-button.kb-faq-accordion__trigger:not(.collapsed) {
    background: var(--secondary-color, #122F2A);
    color: var(--white-color, #ffffff);
    padding-bottom: 14px;
}

.kb-faq-section .kb-faq-accordion .accordion-button.kb-faq-accordion__trigger:not(.collapsed) .kb-faq-accordion__icon {
    background: rgba(255, 193, 7, 0.18);
    color: var(--accent-one, #FFC107);
    box-shadow: 0 0 0 1px rgba(255, 193, 7, 0.35);
    transform: rotate(45deg);
}

.kb-faq-section .kb-faq-accordion .accordion-button.kb-faq-accordion__trigger:not(.collapsed) .kb-faq-accordion__icon::before {
    content: "+";
}

.kb-faq-section .kb-faq-accordion .accordion-collapse.kb-faq-accordion__panel {
    border-top: 0;
}

.kb-faq-section .kb-faq-accordion .accordion-body.kb-faq-accordion__body {
    padding: 0 24px 24px;
    background: var(--secondary-color, #122F2A);
}

.kb-faq-section .kb-faq-accordion .accordion-body.kb-faq-accordion__body p {
    margin: 0;
    padding-top: 4px;
    color: rgba(255, 255, 255, 0.92);
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 500;
    line-height: 1.8;
}

@media (max-width: 1199px) {
    .kb-faq-section__layout {
        grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
        gap: 40px 48px;
    }
}

@media (max-width: 991px) {
    .kb-faq-section__layout {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .kb-faq-section__help-card {
        margin-top: 24px;
    }
}

@media (max-width: 767px) {
    .kb-faq-section__help-card {
        padding: 26px 22px 24px;
        border-radius: 22px;
    }

    .kb-faq-section .kb-faq-accordion .accordion-button.kb-faq-accordion__trigger {
        padding: 18px 18px;
        gap: 14px;
    }

    .kb-faq-section .kb-faq-accordion .kb-faq-accordion__icon {
        width: 40px;
        height: 40px;
        font-size: 16px;
    }

    .kb-faq-section .kb-faq-accordion .accordion-body.kb-faq-accordion__body {
        padding: 0 18px 20px;
    }
}

/* About Page — KashiBhakti storytelling (keeps light background) */
.kb-about-page-section {
    position: relative;
    overflow: hidden;
}

.kb-about-page-section__motif {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 193, 7, 0.16);
    opacity: 0.35;
}

.kb-about-page-section__motif--one {
    width: 120px;
    height: 120px;
    top: 48%;
    right: 6%;
}

.kb-about-page-section__motif--two {
    width: 80px;
    height: 80px;
    bottom: 10%;
    left: 3%;
    border-color: rgba(18, 47, 42, 0.1);
}

.kb-about-page-section .container {
    position: relative;
    z-index: 1;
}

.kb-about-page-section__header.section-title-area {
    margin-bottom: 48px;
    max-width: none;
    width: 100%;
}

.kb-about-page-section__header.section-title-area .kb-about-page-section__title.section-title {
    width: 100%;
    max-width: 100%;
}

.kb-about-page-section__title.section-title .sub-title {
    background: rgba(71, 8, 4, 0.06);
    border: 1px solid rgba(255, 193, 7, 0.28);
    border-radius: 999px;
    color: var(--primary-color, #470804);
    font-weight: 600;
}

.kb-about-page-section__heading {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2rem, 3.6vw, 3rem);
    line-height: 1.18;
    color: var(--primary-color, #470804);
    margin: 8px 0 0;
    max-width: none;
    width: 100%;
}

.kb-about-page-section__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 48px 72px;
    align-items: start;
}

.kb-about-page-section .about-left {
    margin-right: 0 !important;
    margin-bottom: 0 !important;
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.kb-about-page-section .about-right {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.kb-about-page-section__photo {
    position: relative;
    overflow: hidden;
    border-radius: 30px;
    box-shadow:
        0 16px 44px rgba(18, 47, 42, 0.1),
        0 0 0 1px rgba(255, 193, 7, 0.12);
    transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.45s ease;
}

.kb-about-page-section__photo figure,
.kb-about-page-section__photo figure img {
    display: block;
    width: 100%;
    height: 100%;
    margin: 0;
}

.kb-about-page-section__photo figure img {
    object-fit: cover;
    border-radius: 30px;
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-about-page-section__photo--primary {
    aspect-ratio: 4 / 4.2;
}

.kb-about-page-section__photo--secondary {
    aspect-ratio: 16 / 10;
    max-width: 100%;
}

.kb-about-page-section__photo-frame {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    border: 1px solid rgba(255, 193, 7, 0.18);
    pointer-events: none;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.kb-about-page-section__photo:hover {
    transform: translateY(-4px);
    box-shadow:
        0 22px 52px rgba(18, 47, 42, 0.14),
        0 0 0 1px rgba(255, 193, 7, 0.2),
        0 0 32px rgba(255, 193, 7, 0.08);
}

.kb-about-page-section__photo:hover figure img {
    transform: scale(1.04);
}

.kb-about-page-section__established.established-box {
    display: grid;
    grid-template-columns: minmax(140px, 180px) minmax(0, 1fr);
    gap: 20px;
    align-items: stretch;
}

.kb-about-page-section__video.established-video {
    width: auto;
    height: auto;
    min-height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border-radius: 28px;
    background: linear-gradient(145deg, rgba(71, 8, 4, 0.92) 0%, rgba(61, 7, 3, 0.96) 100%);
    border: 1px solid rgba(255, 193, 7, 0.22);
    box-shadow:
        0 12px 32px rgba(71, 8, 4, 0.2),
        0 0 28px rgba(255, 193, 7, 0.1);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}

.kb-about-page-section__video.established-video:hover {
    transform: translateY(-4px);
    box-shadow:
        0 18px 40px rgba(71, 8, 4, 0.24),
        0 0 36px rgba(255, 193, 7, 0.14);
}

.kb-about-page-section__play.video-play {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: #ffffff;
    box-shadow: 0 0 0 6px rgba(255, 193, 7, 0.18);
    transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.kb-about-page-section__play.video-play .icon {
    display: flex;
    align-items: center;
    justify-content: center;
}

.kb-about-page-section__play.video-play .icon i {
    font-size: 18px;
    margin-left: 3px;
}

.kb-about-page-section__video:hover .kb-about-page-section__play.video-play {
    transform: scale(1.06);
    background: rgba(255, 193, 7, 0.22);
    box-shadow: 0 0 0 8px rgba(255, 193, 7, 0.24);
}

.kb-about-page-section__since.established-content {
    width: auto !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 28px 22px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(71, 8, 4, 0.06);
    box-shadow:
        0 2px 8px rgba(71, 8, 4, 0.03),
        0 12px 32px rgba(18, 47, 42, 0.07);
    transition:
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.45s ease,
        border-color 0.45s ease;
}

.kb-about-page-section__since.established-content:hover {
    transform: translateY(-6px);
    border-color: rgba(255, 193, 7, 0.28);
    box-shadow:
        0 8px 20px rgba(71, 8, 4, 0.04),
        0 20px 44px rgba(18, 47, 42, 0.1),
        0 0 32px rgba(255, 193, 7, 0.1);
}

.kb-about-page-section__since-label.established-text {
    margin: 0 0 8px;
    color: var(--secondary-color, #122F2A);
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.4;
}

.kb-about-page-section__since-year.established-year {
    margin: 0;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2rem, 3.2vw, 2.75rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
}

.kb-about-page-section__blocks.about-content-box {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.kb-about-page-section__block.about-content-item {
    margin-bottom: 0 !important;
    padding: 28px 28px 26px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(71, 8, 4, 0.06);
    box-shadow:
        0 2px 8px rgba(71, 8, 4, 0.03),
        0 12px 32px rgba(18, 47, 42, 0.06);
    transition: transform 0.45s ease, box-shadow 0.45s ease, border-color 0.45s ease;
}

.kb-about-page-section__block.about-content-item:hover {
    transform: translateY(-4px);
    border-color: rgba(255, 193, 7, 0.22);
    box-shadow:
        0 8px 20px rgba(71, 8, 4, 0.04),
        0 20px 44px rgba(18, 47, 42, 0.09),
        0 0 28px rgba(255, 193, 7, 0.08);
}

.kb-about-page-section__block-title.about-text {
    position: relative;
    margin: 0 0 12px;
    padding-left: 18px;
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.25rem, 1.8vw, 1.5rem);
    line-height: 1.35;
    color: var(--primary-color, #470804);
    font-weight: 700;
}

.kb-about-page-section__block-title.about-text::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.35em;
    width: 4px;
    height: 1.1em;
    border-radius: 999px;
    background: linear-gradient(180deg, #ffc107 0%, rgba(255, 193, 7, 0.45) 100%);
}

.kb-about-page-section__block-text.desc {
    margin: 0;
    color: var(--text-color, #555555);
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 16px;
    line-height: 1.78;
    font-weight: 500;
}

.kb-about-page-section__contact-wrap.about-footer {
    margin-bottom: 0 !important;
    gap: 0;
}

.kb-about-page-section__contact.about-contact-box {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow:
        0 4px 14px rgba(18, 47, 42, 0.06),
        0 0 0 1px rgba(255, 255, 255, 0.6);
    text-decoration: none;
    transition: transform 0.4s ease, box-shadow 0.4s ease, border-color 0.4s ease;
}

.kb-about-page-section__contact.about-contact-box:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 193, 7, 0.28);
    box-shadow:
        0 10px 28px rgba(18, 47, 42, 0.1),
        0 0 24px rgba(255, 193, 7, 0.1);
}

.kb-about-page-section__contact-icon.icon-box {
    position: relative;
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    margin-right: 0 !important;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--extra-color, #F5EBEA) 0%, var(--accent-color-one, #F8F2E6) 100%);
    border: 1px solid rgba(255, 193, 7, 0.18);
    color: var(--primary-color, #470804);
    box-shadow:
        0 6px 18px rgba(71, 8, 4, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.85);
    transition: background 0.4s ease, color 0.4s ease, box-shadow 0.4s ease, transform 0.4s ease;
}

.kb-about-page-section__contact-icon.icon-box::before {
    display: none !important;
}

.kb-about-page-section__contact.about-contact-box:hover .kb-about-page-section__contact-icon.icon-box {
    background: linear-gradient(145deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: #ffffff;
    transform: scale(1.04);
    box-shadow:
        0 10px 24px rgba(71, 8, 4, 0.16),
        0 0 20px rgba(255, 193, 7, 0.14);
}

.kb-about-page-section__contact-label {
    margin: 0 0 2px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--secondary-color, #122F2A);
}

.kb-about-page-section__contact-value {
    display: block;
    font-size: 1.125rem;
    line-height: 1.4;
    font-weight: 700;
    color: var(--primary-color, #470804);
    transition: color 0.35s ease;
}

.kb-about-page-section .about-image-1 {
    margin-bottom: 0 !important;
}

.kb-about-page-section + .kb-stats-section {
    padding-top: 56px;
    margin-top: -12px;
}

@media (max-width: 1199px) {
    .kb-about-page-section__layout {
        gap: 40px 48px;
    }

    .kb-about-page-section__heading {
        max-width: none;
    }
}

@media (max-width: 991px) {
    .kb-about-page-section__header.section-title-area {
        margin-bottom: 36px;
    }

    .kb-about-page-section__layout {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .kb-about-page-section__established.established-box {
        grid-template-columns: 140px minmax(0, 1fr);
    }

    .kb-about-page-section + .kb-stats-section {
        padding-top: 48px;
        margin-top: 0;
    }
}

@media (max-width: 767px) {
    .kb-about-page-section__established.established-box {
        grid-template-columns: 1fr;
    }

    .kb-about-page-section__video.established-video {
        min-height: 160px;
    }

    .kb-about-page-section__play.video-play {
        width: 58px;
        height: 58px;
    }

    .kb-about-page-section__block.about-content-item {
        padding: 22px 20px 20px;
        border-radius: 22px;
    }

    .kb-about-page-section__photo,
    .kb-about-page-section__photo figure img {
        border-radius: 22px;
    }

    .kb-about-page-section__contact.about-contact-box {
        width: 100%;
        border-radius: 22px;
    }
}

/* Services list page — premium spiritual marketplace (KashiBhakti) */
.kb-services-list {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 42%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-services-list::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.16;
    background-image: radial-gradient(rgba(71, 8, 4, 0.04) 1px, transparent 1px);
    background-size: 26px 26px;
    z-index: 0;
}

.kb-services-list__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-services-list__orb--one {
    width: 300px;
    height: 300px;
    top: -70px;
    right: -60px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-services-list__orb--two {
    width: 240px;
    height: 240px;
    bottom: 8%;
    left: -50px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.07) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-services-list .container {
    position: relative;
    z-index: 1;
}

.kb-services-list__header.section-title {
    margin-bottom: 48px;
}

.kb-services-list__header .sub-title {
    background: rgba(71, 8, 4, 0.06);
    border: 1px solid rgba(255, 193, 7, 0.28);
    border-radius: 999px;
    color: var(--primary-color, #470804);
    font-weight: 600;
}

.kb-services-list__heading {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2rem, 3.4vw, 2.75rem);
    line-height: 1.2;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin-top: 6px;
}

.kb-services-list__intro {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.75;
    font-weight: 500;
}

.kb-services-list__tabs,
.kb-services-list__filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: 0 0 28px;
    padding: 0;
}

.kb-services-list__tab,
.kb-services-list__filter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
    text-decoration: none;
    color: var(--secondary-color, #122F2A);
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow: 0 4px 12px rgba(18, 47, 42, 0.05);
    transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
    cursor: pointer;
    font-family: inherit;
}

.kb-services-list__tab:hover,
.kb-services-list__filter:hover {
    color: var(--primary-color, #470804);
    border-color: rgba(255, 193, 7, 0.28);
    transform: translateY(-1px);
}

.kb-services-list__tab.is-active,
.kb-services-list__filter.is-active {
    background: linear-gradient(135deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: #ffffff;
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow: 0 8px 20px rgba(71, 8, 4, 0.16);
}

.kb-services-list__col.is-hidden {
    display: none !important;
}

#kb-services-empty-filter.is-hidden {
    display: none !important;
}

.kb-services-list__empty {
    color: var(--text-color, #555555);
    font-size: 16px;
    font-weight: 500;
}

.kb-services-list__grid.row {
    margin-left: -14px;
    margin-right: -14px;
    align-items: stretch;
}

.kb-services-list__col {
    display: flex;
    margin-bottom: 28px;
    padding-left: 14px;
    padding-right: 14px;
}

/* Shared service card — circular image, centered title, theme button */
.kb-service-card__body {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    height: 100%;
    text-align: center;
}

.kb-service-card__thumb {
    flex-shrink: 0;
    width: clamp(200px, 92%, 300px);
    aspect-ratio: 1;
    margin: 0 auto 26px;
    padding: 6px;
    border-radius: 50%;
    background: linear-gradient(145deg, rgba(255, 193, 7, 0.45) 0%, rgba(255, 255, 255, 0.95) 100%);
    box-shadow:
        0 10px 28px rgba(18, 47, 42, 0.1),
        inset 0 0 0 1px rgba(255, 193, 7, 0.25);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.kb-service-card__thumb figure {
    width: 100%;
    height: 100%;
    margin: 0;
    border-radius: 50%;
    overflow: hidden;
    border: 3px solid var(--white-color, #ffffff);
}

.kb-service-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-service-card__title {
    margin: 0 0 22px;
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(0.92rem, 1.15vw, 1.08rem);
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--secondary-color, #122F2A);
}

.kb-service-card__title a {
    color: inherit;
    text-decoration: none;
    transition: color 0.3s ease;
}

.kb-service-card__title a:hover {
    color: var(--primary-color, #470804);
}

.kb-service-card__cta {
    margin-top: auto;
    padding-top: 4px;
}

.kb-service-card__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 148px;
    padding: 12px 28px;
    border-radius: 999px;
    border: none;
    background: linear-gradient(135deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: #ffffff !important;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.02em;
    text-decoration: none !important;
    box-shadow:
        0 10px 24px rgba(71, 8, 4, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.kb-service-card__btn:hover {
    transform: translateY(-2px);
    color: #ffffff !important;
    background: linear-gradient(135deg, #5a0a06 0%, var(--primary-color, #470804) 100%);
    box-shadow:
        0 14px 30px rgba(71, 8, 4, 0.28),
        0 0 24px rgba(255, 193, 7, 0.12);
}

.kb-services-list.services-section-3 .kb-services-list__card.service-items,
.kb-services-section.services-section-3 .service-items.kb-services-section__card {
    min-height: unset !important;
    margin-bottom: 0 !important;
}

.kb-services-list__card.service-items,
.kb-services-section .services-slider .service-items.kb-services-section__card {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: unset;
    margin-bottom: 0 !important;
    padding: 28px 18px 26px;
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--accent-color-one, #F8F2E6) 100%
    );
    border: 1px solid rgba(18, 47, 42, 0.08);
    box-shadow:
        0 12px 32px rgba(18, 47, 42, 0.08),
        0 0 0 1px rgba(255, 255, 255, 0.6);
    transition:
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.45s ease,
        border-color 0.45s ease;
}

.kb-services-list.services-section-3 .kb-services-list__card.service-items::before,
.kb-services-list__card.service-items::after,
.kb-services-section .services-slider .service-items.kb-services-section__card::before,
.kb-services-section .services-slider .service-items.kb-services-section__card::after {
    display: none !important;
}

.kb-services-list__card.service-items:hover,
.kb-services-section .services-slider .service-items.kb-services-section__card:hover {
    transform: translateY(-6px);
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow:
        0 22px 48px rgba(18, 47, 42, 0.12),
        0 0 0 1px rgba(255, 193, 7, 0.2),
        0 0 32px rgba(255, 193, 7, 0.08);
}

.kb-services-list__card.service-items:hover .kb-service-card__thumb,
.kb-services-section .services-slider .service-items.kb-services-section__card:hover .kb-service-card__thumb {
    transform: scale(1.03);
    box-shadow:
        0 14px 34px rgba(18, 47, 42, 0.14),
        inset 0 0 0 1px rgba(255, 193, 7, 0.35);
}

.kb-services-list__card.service-items:hover .kb-service-card__thumb img,
.kb-services-section .services-slider .service-items.kb-services-section__card:hover .kb-service-card__thumb img {
    transform: scale(1.06);
}

@media (max-width: 1199px) {
    .kb-services-list__card.service-items,
    .kb-services-section .services-slider .service-items.kb-services-section__card {
        border-radius: 22px;
        padding: 30px 20px 26px;
    }
}

@media (max-width: 991px) {
    .kb-services-list__header.section-title {
        margin-bottom: 36px;
    }
}

@media (max-width: 767px) {
    .kb-services-list__grid.row {
        margin-left: -10px;
        margin-right: -10px;
    }

    .kb-services-list__col {
        padding-left: 10px;
        padding-right: 10px;
        margin-bottom: 20px;
    }

    .kb-services-list__card.service-items,
    .kb-services-section .services-slider .service-items.kb-services-section__card {
        padding: 28px 18px 24px;
    }

    .kb-service-card__thumb {
        margin-bottom: 18px;
    }

    .kb-service-card__title {
        margin-bottom: 18px;
    }

    .breadcrumb-shlok {
        margin-bottom: 16px;
        padding: 0 12px;
    }

    .breadcrumb-shlok__heading {
        font-size: 1.05rem;
    }

    .breadcrumb-shlok__text {
        font-size: 0.92rem;
    }
}

/* Events list page — compact premium spiritual listing (KashiBhakti) */
.kb-events-list {
    position: relative;
    overflow-x: clip;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 38%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-events-list__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-events-list__orb--one {
    width: 260px;
    height: 260px;
    top: -60px;
    right: -50px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-events-list__orb--two {
    width: 220px;
    height: 220px;
    bottom: 6%;
    left: -45px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.07) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-events-list .container {
    position: relative;
    z-index: 1;
}

.kb-events-list__empty {
    color: var(--text-color, #555555);
    font-size: 16px;
    font-weight: 500;
}

.kb-events-list .event-item-box.grid-2.kb-events-list__grid {
    grid-gap: 20px;
}

/* Compact event card — list + related events */
.event-section-2 .kb-events-list__card.event-item.grid {
    border-radius: 22px;
    border: 1px solid rgba(18, 47, 42, 0.1);
    background-color: var(--white-color, #ffffff);
    box-shadow:
        0 8px 24px rgba(18, 47, 42, 0.07),
        0 0 0 1px rgba(255, 255, 255, 0.6);
    transition:
        transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.4s ease,
        border-color 0.4s ease,
        background-color 0.4s ease;
}

.event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__media.event-image a figure {
    height: 168px;
    min-height: 168px;
    max-height: 168px;
    overflow: hidden;
    border-radius: 22px 22px 0 0;
}

.event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__media.event-image a figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(1.04) sepia(0.04);
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), filter 0.5s ease;
}

.event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__body.event-content {
    padding: 12px 14px 14px;
}

.event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__date.event-date {
    top: 14px;
    left: 14px;
    padding: 8px 12px;
    font-size: 1.35rem;
    line-height: 1.15;
    font-weight: 700;
    border-radius: 14px;
    box-shadow: 0 6px 18px rgba(71, 8, 4, 0.2);
}

.event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__date.event-date span {
    display: block;
    margin-left: 0;
    margin-top: 2px;
    width: auto;
    font-size: 11px;
    line-height: 1.3;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    opacity: 0.92;
}

.event-section-2 .kb-events-list__card .kb-events-list__title {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.05rem, 1.35vw, 1.2rem);
    font-weight: 700;
    line-height: 1.35;
    margin: 0 0 8px;
    text-transform: none;
}

.event-section-2 .kb-events-list__card .kb-events-list__title a {
    color: var(--primary-color, #470804);
}

.event-section-2 .kb-events-list__card .kb-events-list__desc.desc {
    margin: 0 0 10px;
    font-size: 13px;
    line-height: 1.5;
    font-weight: 500;
    color: var(--text-color, #555555);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.event-section-2 .kb-events-list__card .kb-events-list__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 12px;
    margin-bottom: 10px;
    padding: 8px 10px;
    border-radius: 12px;
    background: rgba(245, 235, 234, 0.65);
    border: 1px solid rgba(18, 47, 42, 0.08);
}

.event-section-2 .kb-events-list__card .kb-events-list__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.event-section-2 .kb-events-list__card .kb-events-list__meta-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--white-color, #ffffff);
    color: var(--primary-color, #470804);
    font-size: 12px;
    box-shadow: 0 2px 8px rgba(18, 47, 42, 0.08);
}

.event-section-2 .kb-events-list__card .kb-events-list__meta-text {
    font-size: 13px;
    line-height: 1.4;
    font-weight: 600;
    color: var(--primary-color, #470804);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 220px;
}

.event-section-2 .kb-events-list__card .kb-events-list__cta.event-button-wapper {
    margin-top: 0;
    text-align: left;
}

.event-section-2 .kb-events-list__card .kb-events-list__btn.theme-button.style-1 {
    min-height: 38px;
    padding: 8px 16px 8px 18px;
    border-radius: 999px;
    font-size: 12px;
    box-shadow: 0 6px 18px rgba(71, 8, 4, 0.12);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.event-section-2 .kb-events-list__card .kb-events-list__btn.theme-button.style-1 i {
    transition: transform 0.35s ease;
}

.event-section-2 .kb-events-list__card .kb-events-list__btn.theme-button.style-1:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(71, 8, 4, 0.16), 0 0 18px rgba(255, 193, 7, 0.14);
}

.event-section-2 .kb-events-list__card .kb-events-list__btn.theme-button.style-1:hover i {
    transform: translateX(3px);
}

/* Hover — soft lift, no full green card fill */
.event-section-2 .kb-events-list__card.event-item.grid:hover {
    background-color: var(--white-color, #ffffff);
    border-color: rgba(255, 193, 7, 0.32);
    transform: translateY(-5px);
    box-shadow:
        0 16px 40px rgba(18, 47, 42, 0.12),
        0 0 0 1px rgba(255, 193, 7, 0.16),
        0 0 28px rgba(255, 193, 7, 0.08);
}

.event-section-2 .kb-events-list__card.event-item.grid:hover .kb-events-list__media.event-image a figure img {
    transform: scale(1.04);
    filter: saturate(1.08) sepia(0.06);
}

.event-section-2 .kb-events-list__card.event-item.grid:hover .kb-events-list__date.event-date {
    color: var(--white-color, #ffffff);
}

.event-section-2 .kb-events-list__card.event-item.grid:hover .kb-events-list__date.event-date span {
    color: rgba(255, 255, 255, 0.92);
}

.event-section-2 .kb-events-list__card.event-item.grid:hover .kb-events-list__title,
.event-section-2 .kb-events-list__card.event-item.grid:hover .kb-events-list__title a {
    color: var(--primary-color, #470804) !important;
}

.event-section-2 .kb-events-list__card.event-item.grid:hover .kb-events-list__desc.desc {
    color: var(--text-color, #555555) !important;
}

.event-section-2 .kb-events-list__card.event-item.grid:hover .kb-events-list__meta {
    background: rgba(255, 193, 7, 0.1);
    border-color: rgba(255, 193, 7, 0.22);
}

@media (max-width: 991px) {
    .kb-events-list .event-item-box.grid-2.kb-events-list__grid {
        grid-gap: 18px;
    }

    .event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__media.event-image a figure {
        height: 160px;
        min-height: 160px;
        max-height: 160px;
    }

    .event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__body.event-content {
        padding: 12px 14px 14px;
    }
}

@media (max-width: 575px) {
    .event-section-2 .kb-events-list__card.event-item.grid .kb-events-list__media.event-image a figure {
        height: 150px;
        min-height: 150px;
        max-height: 150px;
    }

    .event-section-2 .kb-events-list__card .kb-events-list__meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .event-section-2 .kb-events-list__card .kb-events-list__meta-text {
        max-width: 100%;
        white-space: normal;
    }
}

/* Event detail page — luxury spiritual booking (KashiBhakti) */
.kb-event-detail {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 32%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-event-detail::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.16;
    background-image: radial-gradient(rgba(71, 8, 4, 0.04) 1px, transparent 1px);
    background-size: 26px 26px;
    z-index: 0;
}

.kb-event-detail__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-event-detail__orb--one {
    width: 280px;
    height: 280px;
    top: 6%;
    right: -70px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.11) 0%, rgba(255, 193, 7, 0) 72%);
}

.kb-event-detail__orb--two {
    width: 220px;
    height: 220px;
    bottom: 10%;
    left: -50px;
    background: radial-gradient(circle, rgba(18, 47, 42, 0.08) 0%, rgba(18, 47, 42, 0) 72%);
}

.kb-event-detail .container {
    position: relative;
    z-index: 1;
}

.kb-event-detail__layout {
    align-items: flex-start;
}

.kb-event-detail__main.event-single-post {
    margin-bottom: 0;
}

/* Hero */
.kb-event-detail__hero.event-single-media {
    position: relative;
    margin-bottom: 28px;
    border-radius: 28px;
    overflow: hidden;
    box-shadow:
        0 16px 44px rgba(18, 47, 42, 0.12),
        0 0 0 1px rgba(255, 193, 7, 0.12);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}

.kb-event-detail__hero.event-single-media:hover {
    transform: translateY(-4px);
    box-shadow:
        0 22px 52px rgba(18, 47, 42, 0.14),
        0 0 0 1px rgba(255, 193, 7, 0.2),
        0 0 32px rgba(255, 193, 7, 0.08);
}

.kb-event-detail__hero.event-single-media figure {
    width: 100%;
    margin: 0;
    aspect-ratio: 16 / 8.5;
    max-height: min(44vh, 420px);
    overflow: hidden;
    border-radius: 28px;
}

.kb-event-detail__hero.event-single-media figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
    filter: saturate(1.04) sepia(0.04);
}

.kb-event-detail__hero.event-single-media:hover figure img {
    transform: scale(1.03);
}

.kb-event-detail__hero-frame {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    border: 1px solid rgba(255, 193, 7, 0.2);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
    z-index: 2;
}

.kb-event-detail__hero-badge {
    position: absolute;
    bottom: 16px;
    left: 16px;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(255, 193, 7, 0.28);
    color: var(--primary-color, #470804);
    font-size: 13px;
    font-weight: 700;
    box-shadow: 0 8px 22px rgba(18, 47, 42, 0.12);
}

.kb-event-detail__hero-badge i {
    color: var(--primary-color, #470804);
    font-size: 12px;
}

/* Header */
.kb-event-detail__eyebrow.sub-title {
    display: inline-block;
    margin-bottom: 10px;
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(71, 8, 4, 0.06);
    border: 1px solid rgba(255, 193, 7, 0.28);
    color: var(--primary-color, #470804);
    font-weight: 600;
    font-size: 12px;
}

.kb-event-detail__title {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.75rem, 3.2vw, 2.5rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--primary-color, #470804);
    margin: 0 0 12px;
    text-transform: none;
}

.kb-event-detail__lead {
    margin: 0 0 22px;
    font-size: 17px;
    line-height: 1.7;
    font-weight: 500;
    color: var(--secondary-color, #122F2A);
    max-width: 68ch;
}

/* Info card — compact grid */
.kb-event-detail__info-card.event-offer-single-item {
    margin-bottom: 24px !important;
    padding: 16px 18px !important;
    border-radius: 22px !important;
    background: rgba(255, 255, 255, 0.88) !important;
    border: 1px solid rgba(71, 8, 4, 0.08) !important;
    box-shadow:
        0 4px 14px rgba(18, 47, 42, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(6px);
}

.kb-event-detail__info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 16px;
}

.kb-event-detail__info-item.event-offer-single-list {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

.kb-event-detail__info-icon.event-offer-single-icon {
    flex-shrink: 0;
    width: 40px !important;
    height: 40px !important;
    font-size: 15px !important;
    border-radius: 50%;
    background: linear-gradient(145deg, var(--primary-color, #470804) 0%, #3d0703 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(71, 8, 4, 0.18);
}

.kb-event-detail__info-icon.event-offer-single-icon::before {
    display: none !important;
}

.kb-event-detail__info-text.event-offer-single-content span {
    display: block;
    margin-bottom: 2px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--secondary-color, #122F2A);
}

.kb-event-detail__info-text.event-offer-single-content p {
    margin: 0;
    font-size: 14px;
    line-height: 1.45;
    font-weight: 600;
    color: var(--primary-color, #470804);
}

.kb-event-detail__info-sub {
    display: block;
    margin-top: 2px;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-color, #555555);
}

.kb-event-detail__info-item:hover .kb-event-detail__info-icon {
    transform: scale(1.04);
    box-shadow: 0 6px 16px rgba(71, 8, 4, 0.22);
}

/* Prose */
.kb-event-detail__prose {
    color: var(--text-color, #555555);
    font-size: 16px;
    line-height: 1.82;
    font-weight: 500;
}

.kb-event-detail__prose p {
    margin-bottom: 1.05em;
}

.kb-event-detail__prose h2,
.kb-event-detail__prose h3,
.kb-event-detail__prose h4 {
    font-family: var(--title-fonts, "Merriweather", serif);
    color: var(--primary-color, #470804);
    font-weight: 700;
    line-height: 1.35;
    margin: 1.5em 0 0.6em;
    text-transform: none;
}

.kb-event-detail__prose h2 {
    font-size: clamp(1.4rem, 2vw, 1.75rem);
}

.kb-event-detail__prose h3 {
    font-size: clamp(1.2rem, 1.6vw, 1.45rem);
}

.kb-event-detail__prose ul,
.kb-event-detail__prose ol {
    margin: 0 0 1.15em;
    padding-left: 1.2em;
}

.kb-event-detail__prose li {
    margin-bottom: 0.45em;
}

/* Highlights */
.kb-event-detail__block {
    margin-top: 32px;
    padding-top: 28px;
    border-top: 1px solid rgba(18, 47, 42, 0.08);
}

.kb-event-detail__subtitle {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(1.3rem, 2vw, 1.55rem);
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin: 0 0 18px;
    text-transform: none;
}

.kb-event-detail__highlights {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.kb-event-detail__highlight-card.benifits-item {
    margin: 0;
    padding: 16px 16px 16px 14px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(71, 8, 4, 0.07);
    box-shadow: 0 4px 16px rgba(18, 47, 42, 0.06);
    display: flex;
    gap: 12px;
    align-items: flex-start;
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.kb-event-detail__highlight-card:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 193, 7, 0.28);
    box-shadow: 0 10px 28px rgba(18, 47, 42, 0.1);
}

.kb-event-detail__highlight-icon {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.35) 0%, rgba(255, 193, 7, 0.12) 100%);
    color: var(--primary-color, #470804);
    font-size: 14px;
}

.kb-event-detail__highlight-body h3 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
    color: var(--primary-color, #470804);
    margin: 0 0 6px;
    text-transform: none;
}

.kb-event-detail__highlight-body p {
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
    color: var(--text-color, #555555);
    font-weight: 500;
}

.kb-event-detail__highlight-body i {
    display: none;
}

/* Sidebar sticky */
@media (min-width: 992px) {
    .kb-event-detail__sidebar-col {
        position: sticky;
        top: 120px;
        align-self: flex-start;
        z-index: 2;
    }
}

.kb-event-detail__sidebar.widget-sidebar {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.kb-event-detail__widget-title h3 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin: 0 0 10px;
    text-transform: none;
}

.kb-event-detail__booking-card.widget,
.kb-event-detail__help-card.widget {
    margin-bottom: 0 !important;
    padding: 22px 20px 20px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow:
        0 4px 12px rgba(71, 8, 4, 0.04),
        0 14px 36px rgba(18, 47, 42, 0.08);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.kb-event-detail__booking-card.widget:hover,
.kb-event-detail__help-card.widget:hover {
    transform: translateY(-3px);
    box-shadow:
        0 8px 20px rgba(71, 8, 4, 0.06),
        0 20px 44px rgba(18, 47, 42, 0.1);
}

.kb-event-detail__booking-note {
    margin: 0 0 16px;
    font-size: 13px;
    line-height: 1.6;
    font-weight: 500;
    color: var(--text-color, #555555);
}

/* Booking form */
.kb-event-detail__alert {
    margin-bottom: 14px;
    padding: 12px 14px;
    border-radius: 14px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.5;
}

.kb-event-detail__alert--success {
    background: rgba(18, 47, 42, 0.08);
    border: 1px solid rgba(18, 47, 42, 0.15);
    color: var(--secondary-color, #122F2A);
}

.kb-event-detail__alert--error {
    background: rgba(71, 8, 4, 0.06);
    border: 1px solid rgba(71, 8, 4, 0.12);
    color: var(--primary-color, #470804);
}

.kb-event-detail__form-grid {
    display: grid;
    gap: 12px;
}

.kb-event-detail__field label {
    display: block;
    margin-bottom: 6px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.03em;
    color: var(--primary-color, #470804);
}

.kb-event-detail__optional {
    font-weight: 500;
    color: var(--text-color, #555555);
    letter-spacing: 0;
    text-transform: none;
}

.kb-event-detail__field .form-control,
.kb-event-detail__field .form-select {
    width: 100%;
    min-height: 44px;
    padding: 10px 14px;
    border: 1px solid rgba(71, 8, 4, 0.12);
    border-radius: 14px;
    font-family: var(--body-fonts, "DM Sans", sans-serif);
    font-size: 14px;
    font-weight: 500;
    color: var(--primary-color, #470804);
    background: rgba(245, 235, 234, 0.5) !important;
    box-shadow: inset 0 1px 2px rgba(18, 47, 42, 0.04);
    transition:
        border-color 0.3s ease,
        box-shadow 0.3s ease,
        background 0.3s ease;
}

.kb-event-detail__field textarea.form-control {
    min-height: 72px;
    resize: vertical;
}

.kb-event-detail__field .form-control::placeholder {
    color: rgba(71, 8, 4, 0.42);
}

.kb-event-detail__field .form-control:focus,
.kb-event-detail__field .form-select:focus {
    outline: none;
    border-color: rgba(255, 193, 7, 0.6);
    background: var(--white-color, #ffffff) !important;
    box-shadow: 0 0 0 3px rgba(255, 193, 7, 0.16);
}

.kb-event-detail__checkbox {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.kb-event-detail__checkbox label {
    margin: 0;
    font-size: 12px;
    line-height: 1.5;
    font-weight: 600;
    color: var(--text-color, #555555);
}

.kb-event-detail__form-actions {
    margin-top: 16px !important;
}

.kb-event-detail__submit.theme-button.style-1 {
    min-height: 46px;
    border-radius: 999px;
    box-shadow: 0 6px 20px rgba(71, 8, 4, 0.14);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.kb-event-detail__submit.theme-button.style-1:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(71, 8, 4, 0.18), 0 0 22px rgba(255, 193, 7, 0.14);
}

.kb-event-detail__submit.theme-button.style-1 i {
    transition: transform 0.35s ease;
}

.kb-event-detail__submit.theme-button.style-1:hover i {
    transform: translateX(3px);
}

/* Help card */
.kb-event-detail__help-text {
    margin: 0 0 16px;
    font-size: 14px;
    line-height: 1.65;
    font-weight: 500;
    color: var(--text-color, #555555);
}

.kb-event-detail .widget.widget-cta .service-cta-item .service-cta-list.kb-event-detail__help-row {
    margin-bottom: 14px;
}

.kb-event-detail .widget.widget-cta .service-cta-item .service-cta-list.kb-event-detail__help-row:last-of-type {
    margin-bottom: 18px;
}

.kb-event-detail .widget.widget-cta .service-cta-item .service-cta-list .kb-event-detail__help-icon.service-cta-icon {
    width: 44px;
    height: 44px;
    min-width: 44px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--extra-color, #F5EBEA) 0%, var(--accent-color-one, #F8F2E6) 100%);
    border: 1px solid rgba(255, 193, 7, 0.22);
    color: var(--primary-color, #470804);
    box-shadow: 0 4px 12px rgba(71, 8, 4, 0.06);
}

.kb-event-detail .widget.widget-cta .service-cta-item .service-cta-list .kb-event-detail__help-icon.service-cta-icon::before {
    display: none !important;
}

.kb-event-detail .widget.widget-cta .service-cta-item .service-cta-list .kb-event-detail__help-icon.service-cta-icon i {
    position: relative;
    z-index: 2;
    display: block;
    font-size: 15px;
    line-height: 1;
    color: var(--primary-color, #470804);
}

.kb-event-detail .widget.widget-cta .service-cta-item .service-cta-list:hover .kb-event-detail__help-icon.service-cta-icon {
    background: linear-gradient(145deg, var(--primary-color, #470804) 0%, #3d0703 100%);
    color: #ffffff;
}

.kb-event-detail .widget.widget-cta .service-cta-item .service-cta-list:hover .kb-event-detail__help-icon.service-cta-icon i {
    color: #ffffff;
}

.kb-event-detail__help-row .service-cta-content p {
    margin: 0 0 2px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--secondary-color, #122F2A);
}

.kb-event-detail__help-row .service-cta-content a {
    font-size: 14px;
    font-weight: 700;
    color: var(--primary-color, #470804);
    text-decoration: none;
}

.kb-event-detail__help-cta.theme-button.style-1 {
    width: 100%;
    justify-content: center;
    border-radius: 999px;
    min-height: 44px;
    box-shadow: 0 4px 16px rgba(71, 8, 4, 0.12);
}

.kb-event-detail__help-cta.theme-button.style-1:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(71, 8, 4, 0.16), 0 0 24px rgba(255, 193, 7, 0.1);
}

/* Related events slider — compact cards */
.kb-event-detail__related.kb-events-list {
    background: var(--accent-color-one, #F8F2E6);
}

.kb-event-detail__related-header {
    margin-bottom: 32px;
}

.kb-event-detail__related-slider .swiper-slide {
    height: auto;
}

.kb-event-detail__related .kb-events-list__card.event-item.grid {
    height: 100%;
}

@media (max-width: 991px) {
    .kb-event-detail__main-col {
        margin-bottom: 36px;
    }

    .kb-event-detail__hero.event-single-media figure {
        aspect-ratio: 16 / 10;
        max-height: 360px;
    }

    .kb-event-detail__info-grid {
        grid-template-columns: 1fr;
    }

    .kb-event-detail__highlights {
        grid-template-columns: 1fr;
    }

    .kb-event-detail__sidebar.widget-sidebar {
        gap: 18px;
    }
}

@media (max-width: 767px) {
    .kb-event-detail__hero.event-single-media,
    .kb-event-detail__hero.event-single-media figure,
    .kb-event-detail__hero.event-single-media figure img {
        border-radius: 22px;
    }

    .kb-event-detail__title {
        font-size: 1.65rem;
    }

    .kb-event-detail__lead {
        font-size: 15px;
        margin-bottom: 18px;
    }

    .kb-event-detail__booking-card.widget,
    .kb-event-detail__help-card.widget {
        padding: 18px 16px 16px;
        border-radius: 20px;
    }
}

/* Header / Navbar — two-row premium layout (KashiBhakti) */
.kb-header {
    position: relative;
    z-index: 100;
    width: 100%;
}

/* —— Row 1: Full-width topbar —— */
.kb-header__topbar {
    width: 100%;
}

.kb-header__topbar-track {
    width: 100%;
 
}

.kb-header__topbar-grid.header-top-content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    gap: 20px 28px;
    min-height: 38px;
    padding: 7px 0;
}

.kb-header.header-1 .header-top .header-top-content .header-top-left,
.kb-header.header-1 .header-top .header-top-content .header-top-center,
.kb-header.header-1 .header-top .header-top-content .header-top-right {
    margin-left: 0;
}

.kb-header__topbar-col--times {
    justify-self: start;
}

.kb-header__topbar-col--contact {
    justify-self: center;
}

.kb-header__topbar-col--social {
    justify-self: end;
}

.kb-header__topbar--compact .kb-header__topbar-track {
    min-height: 34px;
}

.kb-header__topbar-compact {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 4px 0;
}

.kb-header__topbar-compact .kb-header__topbar-phone {
    justify-self: start;
    grid-column: 1;
}

.kb-header__topbar-compact .kb-header__social {
    justify-self: end;
    grid-column: 2;
}

.kb-header__topbar-compact .kb-header__social ul {
    justify-content: flex-end;
}

.kb-header__topbar-compact:not(:has(.kb-header__topbar-phone)) .kb-header__social {
    grid-column: 1 / -1;
    justify-self: end;
}

.kb-header__topbar-phone {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--primary-color, #470804);
    text-decoration: none;
}

.kb-header__topbar-phone i {
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 11px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(255, 193, 7, 0.22);
}

.kb-header__sun ul {
    display: flex;
    align-items: center;
    gap: 18px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.kb-header__sun ul li {
    margin: 0;
}

.kb-header__sun p {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--secondary-color, #122F2A);
}

.kb-header__sun p img {
    width: 16px;
    height: 16px;
    object-fit: contain;
    filter: none;
    opacity: 0.85;
}

.kb-header__contact ul {
    display: flex;
    align-items: center;
    gap: 20px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.kb-header__contact ul li {
    margin: 0 !important;
    position: relative;
    padding-right: 20px;
}

.kb-header__contact ul li::before {
    display: none !important;
}

.kb-header__contact ul li:not(:last-child)::after {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 14px;
    background: rgba(71, 8, 4, 0.12);
}

.kb-header__contact ul li:last-child {
    padding-right: 0;
}

.kb-header__contact ul li p {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--primary-color, #470804);
}

.kb-header__contact ul li p i {
    width: 26px;
    height: 26px;
    margin: 0;
    border-radius: 50%;
    font-size: 11px;
    color: var(--primary-color, #470804);
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(255, 193, 7, 0.22);
    box-shadow: 0 2px 8px rgba(18, 47, 42, 0.06);
}

.kb-header__contact ul li p a {
    color: inherit;
    text-decoration: none;
    transition: color 0.3s ease;
}

.kb-header__contact ul li p a:hover {
    color: var(--secondary-color, #122F2A);
}

.kb-header__social ul {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.kb-header__social ul li a {
    position: relative;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 30px !important;
    height: 30px !important;
    padding: 0 !important;
    font-size: 13px !important;
    line-height: 1 !important;
    border-radius: 50%;
    color: var(--primary-color, #470804) !important;
    background: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid rgba(71, 8, 4, 0.1);
    box-shadow: 0 2px 8px rgba(18, 47, 42, 0.06);
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.kb-header__social ul li a i {
    position: relative;
    z-index: 2;
    display: block;
    line-height: 1;
}

.kb-header__topbar--compact .kb-header__social ul li a {
    width: 34px !important;
    height: 34px !important;
    font-size: 15px !important;
}

.kb-header__social ul li a::before {
    background: linear-gradient(145deg, var(--primary-color, #470804) 0%, #3d0703 100%) !important;
}

.kb-header__social ul li a:hover {
    color: #ffffff !important;
    transform: translateY(-2px);
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow: 0 4px 14px rgba(71, 8, 4, 0.14);
}

/* —— Row 2: Main navbar —— */
.kb-header__navbar.header-lower {
    width: 100%;
    padding: 0;
    background: rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid rgba(71, 8, 4, 0.06);
    transition: background 0.4s ease, box-shadow 0.4s ease;
}

.kb-header__navbar-grid.header-content {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 16px 28px;
    min-height: 74px;
    position: relative;
    z-index: 2;
}

.kb-header.header-1 .header-lower .header-content .header-navigation,
.kb-header.header-1 .header-lower .header-content .logo-box {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Logo — inline in navbar (no overlap / absolute offset) */
.kb-header.header-1 .kb-header__logo-box.logo-box,
.kb-header.header-1 .kb-header__logo.logo,
.kb-header.header-1 .logo-box .logo {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    padding: 0 !important;
    background: transparent !important;
}

.kb-header.header-1 .logo-box .logo .logo-shape {
    display: none !important;
}

.kb-header.header-1 .logo-box .logo a {
    display: block;
    width: auto;
    height: auto;
}

.kb-header.header-1 .logo-box .logo a figure {
    display: block;
    width: auto;
    height: auto;
    margin: 0;
}

.kb-header.header-1 .logo-box .logo a figure img {
    display: block;
    width: auto;
    height: 58px;
    max-height: 58px;
    object-fit: contain;
}

.kb-header__brand.header-left {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.kb-header__nav.header-navigation {
    display: flex;
    justify-content: center;
    min-width: 0;
}

.kb-header__nav .main-menu {
    width: 100%;
    display: flex;
    justify-content: center;
}

.kb-header__actions.header-right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-shrink: 0;
    gap: 10px;
}

@media (min-width: 1200px) {
    .kb-header #mobile-menu > ul {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap;
        gap: 6px 28px;
        margin: 0;
        padding: 0;
        list-style: none;
    }
}

.kb-header #mobile-menu > ul > li.nav-item {
    margin: 0;
}

.kb-header .main-menu ul .nav-item .nav-link {
    position: relative;
    padding: 8px 2px;
    color: var(--secondary-color, #122F2A) !important;
    text-decoration: none !important;
    transition: color 0.35s ease;
}

.kb-header .main-menu ul .nav-item .nav-link::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    height: 2px;
    border-radius: 2px;
    background: linear-gradient(90deg, var(--primary-color, #470804) 0%, rgba(255, 193, 7, 0.9) 100%);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.kb-header .main-menu ul .nav-item .nav-link:hover,
.kb-header .main-menu ul .nav-item .nav-link.active {
    color: var(--primary-color, #470804) !important;
}

.kb-header .main-menu ul .nav-item .nav-link:hover::after,
.kb-header .main-menu ul .nav-item .nav-link.active::after {
    transform: scaleX(1);
}

/* Actions */
.kb-header__actions.header-right {
    gap: 12px !important;
}

.kb-header__translate {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.kb-header__translate-select {
    min-height: 42px;
    min-width: 118px;
    padding: 8px 34px 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(71, 8, 4, 0.12);
    background: rgba(255, 255, 255, 0.95);
    color: var(--secondary-color, #122F2A);
    font-size: 13px;
    font-weight: 600;
    outline: none;
    box-shadow: 0 4px 14px rgba(18, 47, 42, 0.08);
    appearance: none;
    -webkit-appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, var(--primary-color, #470804) 50%),
        linear-gradient(135deg, var(--primary-color, #470804) 50%, transparent 50%);
    background-position:
        calc(100% - 16px) 17px,
        calc(100% - 10px) 17px;
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
}

.kb-header__translate-select:focus {
    border-color: rgba(255, 193, 7, 0.55);
    box-shadow: 0 0 0 3px rgba(255, 193, 7, 0.2);
}

.kb-google-translate__element {
    position: absolute;
    inset: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

.offcanvas-language-switcher {
    margin: 14px 0 20px;
}

.offcanvas-language-switcher .kb-header__translate-select {
    width: 100%;
    min-width: 0;
}

.kb-video-modal {
    width: min(920px, 92vw);
    margin: 0 auto;
    background: #000;
    border-radius: 12px;
    overflow: hidden;
}

.kb-video-modal__player {
    display: block;
    width: 100%;
    height: auto;
    max-height: 80vh;
    background: #000;
}

.goog-te-banner-frame.skiptranslate {
    display: none !important;
}

body {
    top: 0 !important;
}

.kb-header__call.header-call {
    padding: 6px 12px 6px 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow: 0 4px 14px rgba(18, 47, 42, 0.06);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.kb-header__call.header-call:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(18, 47, 42, 0.1);
}

.kb-header__call-icon.header-call-icon {
    width: 38px !important;
    height: 38px !important;
    font-size: 14px !important;
    animation: none !important;
    background: linear-gradient(145deg, var(--primary-color, #470804) 0%, #3d0703 100%) !important;
    box-shadow: 0 4px 12px rgba(71, 8, 4, 0.2);
}

.kb-header__call-text.header-call-content {
    margin-left: 10px !important;
    font-size: 14px;
    line-height: 1.25;
}

.kb-header__call-text span {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--secondary-color, #122F2A);
}

.kb-header__call-text a {
    font-size: 14px;
    font-weight: 700;
    color: var(--primary-color, #470804);
    text-decoration: none;
}

.kb-header__icon-group.button-wapper {
    gap: 8px;
    padding: 0;
    background: transparent;
    border-radius: 0;
}

.kb-header__icon-btn .search-btn,
.kb-header__icon-btn .sidebar-toggler,
.kb-header .button-wapper .header-search a,
.kb-header .button-wapper .header-sidebar a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 42px !important;
    height: 42px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.95) !important;
    color: var(--primary-color, #470804) !important;
    border: 1px solid rgba(71, 8, 4, 0.1) !important;
    box-shadow: 0 4px 14px rgba(18, 47, 42, 0.08);
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease, background 0.35s ease;
}

.kb-header__icon-btn .sidebar-toggler span,
.kb-header .header-sidebar .sidebar-toggler span {
    background-color: var(--primary-color, #470804) !important;
    width: 18px;
    height: 2px;
}

.kb-header .button-wapper .header-search a:hover,
.kb-header .button-wapper .header-sidebar a:hover,
.kb-header__icon-btn .search-btn:hover {
    background: var(--primary-color, #470804) !important;
    color: #ffffff !important;
    border-color: rgba(255, 193, 7, 0.35) !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(71, 8, 4, 0.16), 0 0 16px rgba(255, 193, 7, 0.12);
}

.kb-header .header-sidebar .sidebar-toggler:hover span {
    background-color: #ffffff !important;
}

.kb-header__cta .kb-header__cta-btn.theme-button.style-1 {
    min-height: 42px;
    padding: 10px 18px 10px 20px;
    border-radius: 999px;
    font-size: 13px;
    box-shadow: 0 6px 20px rgba(71, 8, 4, 0.14);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.kb-header__cta .kb-header__cta-btn.theme-button.style-1 i {
    transition: transform 0.35s ease;
}

.kb-header__cta .kb-header__cta-btn.theme-button.style-1:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(71, 8, 4, 0.18), 0 0 22px rgba(255, 193, 7, 0.14);
}

.kb-header__cta .kb-header__cta-btn.theme-button.style-1:hover i {
    transform: translateX(3px);
}

/* Sticky navbar */
.kb-header .header-lower.sticky,
.kb-header .kb-header__navbar.sticky {
    background: rgba(255, 255, 255, 0.9) !important;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(71, 8, 4, 0.08);
    box-shadow:
        0 8px 32px rgba(18, 47, 42, 0.1),
        0 0 0 1px rgba(255, 193, 7, 0.06);
    animation: none;
}

.kb-header .header-lower.sticky .kb-header__navbar-grid {
    min-height: 66px;
}

.kb-header .header-lower.sticky .logo-box .logo a figure img {
    height: 50px;
    max-height: 50px;
}

/* Search overlay */
.kb-header__search-panel#search-box .search-wapper .search-form .input-group input {
    border-radius: 999px;
    border: 1px solid rgba(255, 193, 7, 0.35);
    background: rgba(255, 255, 255, 0.95);
    color: var(--primary-color, #470804);
}

.kb-header__search-panel#search-box .search-wapper .search-form .search-submit-btn {
    color: var(--primary-color, #470804);
}

/* Mobile / tablet */
@media (max-width: 1199px) {
    .kb-header__navbar-grid.header-content {
        grid-template-columns: 1fr auto;
        grid-template-areas: "brand actions";
        gap: 10px 12px;
        min-height: auto;
        padding: 10px 0;
        align-items: center;
    }

    .kb-header__brand.header-left {
        grid-area: brand;
        min-width: 0;
        align-items: center;
    }

    .kb-header__actions.header-right {
        grid-area: actions;
        flex-shrink: 0;
        align-items: center;
    }

    .kb-header__translate {
        display: none;
    }

    .kb-header.header-1 .header-lower .header-content .logo-box .logo,
    .kb-header.header-1 .kb-header__logo-box.logo-box .kb-header__logo.logo {
        position: relative !important;
        top: 0 !important;
        height: auto !important;
        padding: 0 !important;
    }

    .kb-header.header-1 .header-lower.sticky .header-content .logo-box .logo {
        top: 0 !important;
        height: auto !important;
    }

    .kb-header.header-1 .header-lower .header-content .logo-box .logo a {
        width: auto !important;
        height: auto !important;
    }

    .kb-header.header-1 .header-lower .header-content .logo-box .logo a figure {
        height: auto !important;
        width: auto !important;
        display: block !important;
    }

    .kb-header .button-wapper .header-search a,
    .kb-header .button-wapper .header-sidebar a {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* Desktop nav hidden — menu opens via offcanvas hamburger */
    .kb-header__nav.header-navigation,
    .kb-header__nav .main-menu,
    .kb-header #mobile-menu {
        display: none !important;
    }

    .kb-header.header-1 .logo-box .logo a figure img {
        height: 48px;
        max-height: 48px;
    }
}

@media (max-width: 1199px) {
    .container,
    .container-fluid {
        width: 100%;
        max-width: 100%;
        padding-left: 15px;
        padding-right: 15px;
        margin-left: auto;
        margin-right: auto;
        box-sizing: border-box;
    }

    [class*="kb-"] section {
        max-width: 100%;
        overflow-x: clip;
    }

    .mouse-cursor {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .container,
    .container-fluid {
        padding-left: 12px;
        padding-right: 12px;
    }
}

@media (max-width: 1599px) {
    .kb-header__call.header-call {
        display: none !important;
    }
}

@media (max-width: 1399px) {
    .kb-header #mobile-menu > ul {
        gap: 6px 20px;
    }
}

@media (min-width: 1200px) and (max-width: 1499px) {
    .kb-header .main-menu ul .nav-item .nav-link,
    .kb-header #mobile-menu ul .nav-item .nav-link {
        font-size: 14px !important;
    }

    .kb-header #mobile-menu > ul {
        gap: 6px 18px;
    }
}

/* Mobile offcanvas menu — compact premium (KashiBhakti) */
#offcanvas-sidebar.offcanvas {
    width: min(300px, 90vw);
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 100%
    );
}

#offcanvas-sidebar .offcanvas-header {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 12px 44px 10px 14px !important;
    border-bottom: 1px solid rgba(71, 8, 4, 0.08);
    min-height: 0;
}

#offcanvas-sidebar .offcanvas-header .offcanvas-logo {
    position: relative;
    padding: 0 !important;
    margin: 0;
    max-width: 130px;
    width: auto;
}

#offcanvas-sidebar .offcanvas-header .offcanvas-logo figure {
    margin: 0;
    line-height: 0;
}

#offcanvas-sidebar .offcanvas-header .offcanvas-logo figure img {
    display: block;
    width: auto;
    height: 48px;
    max-height: 48px;
    max-width: 100%;
    margin: 0;
    object-fit: contain;
}

#offcanvas-sidebar .offcanvas-header .offcanvas-logo .logo-shape {
    display: none !important;
}

#offcanvas-sidebar .offcanvas-close {
    position: absolute !important;
    right: 10px !important;
    top: 50% !important;
    width: 34px !important;
    height: 34px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    font-size: 18px !important;
    color: var(--primary-color, #470804) !important;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(71, 8, 4, 0.1);
    transform: translateY(-50%) !important;
    transition: background 0.3s ease, color 0.3s ease;
}

#offcanvas-sidebar.show .offcanvas-close {
    transform: translateY(-50%) !important;
}

#offcanvas-sidebar .offcanvas-close:hover {
    background: var(--primary-color, #470804);
    color: #ffffff !important;
}

#offcanvas-sidebar .offcanvas-body {
    padding: 10px 14px 18px !important;
}

#offcanvas-sidebar .mobile-menu {
    margin-bottom: 12px;
}

#offcanvas-sidebar .mean-container {
    width: 100%;
}

#offcanvas-sidebar .mean-container .mean-nav {
    margin: 0 !important;
    float: none !important;
    width: 100%;
    background: transparent;
}

#offcanvas-sidebar .mean-container .mean-nav > ul {
    margin: 0;
    padding: 0;
}

#offcanvas-sidebar .mean-container .mean-nav > ul > li {
    margin: 0 0 4px;
}

#offcanvas-sidebar .mean-container .mean-nav > ul > li:last-child {
    margin-bottom: 0;
}

#offcanvas-sidebar .mean-container .mean-nav > ul li a:not(.mean-expand) {
    display: block;
    padding: 10px 12px !important;
    border-top: none !important;
    border-radius: 10px;
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.35;
    color: var(--primary-color, #470804) !important;
    text-transform: capitalize;
    background: rgba(255, 255, 255, 0.55);
    transition: background 0.3s ease, color 0.3s ease;
}

#offcanvas-sidebar .mean-container .mean-nav > ul li a:not(.mean-expand):hover,
#offcanvas-sidebar .mean-container .mean-nav > ul li.current_page_item > a:not(.mean-expand) {
    background: rgba(255, 193, 7, 0.14) !important;
    color: var(--primary-color, #470804) !important;
}

#offcanvas-sidebar .mean-container .mean-nav > ul li a.mean-expand {
    border-top: none !important;
}

#offcanvas-sidebar .offcanvas-contact {
    display: block !important;
    width: 100%;
    margin-top: 14px !important;
    margin-bottom: 14px !important;
    padding-top: 14px;
    border-top: 1px solid rgba(71, 8, 4, 0.08);
}

#offcanvas-sidebar .offcanvas-contact .widget-title {
    margin-bottom: 10px;
}

#offcanvas-sidebar .offcanvas-contact .widget-title h3 {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary-color, #470804);
    margin: 0;
    text-transform: none;
}

#offcanvas-sidebar .offcanvas-contact .offcanvas-cta-item .offcanvas-cta-list {
    margin-bottom: 10px !important;
    gap: 10px !important;
}

#offcanvas-sidebar .offcanvas-contact .offcanvas-cta-item .offcanvas-cta-list:last-of-type {
    margin-bottom: 0 !important;
}

#offcanvas-sidebar .offcanvas-contact .offcanvas-cta-content a,
#offcanvas-sidebar .offcanvas-contact .offcanvas-cta-content p {
    font-size: 14px;
    font-weight: 500;
    line-height: 1.45;
    color: var(--text-color, #555555);
}

#offcanvas-sidebar .offcanvas-button-wapper {
    display: block !important;
    width: 100%;
    margin-bottom: 14px !important;
}

#offcanvas-sidebar .offcanvas-button-wapper .theme-button.style-1 {
    width: 100%;
    justify-content: center;
    min-height: 42px;
    border-radius: 999px;
}

#offcanvas-sidebar .offcanvas-social {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 12px;
    border-top: 1px solid rgba(71, 8, 4, 0.08);
}

#offcanvas-sidebar .offcanvas-social .social-icon {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

#offcanvas-sidebar .offcanvas-social .social-icon li a {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    color: var(--primary-color, #470804);
    border: 1px solid rgba(71, 8, 4, 0.1);
    font-size: 13px;
    transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

#offcanvas-sidebar .offcanvas-social .social-icon li a:hover {
    background: var(--primary-color, #470804);
    color: #ffffff;
    transform: translateY(-2px);
}

/* Footer logo */
.footer .footer-widget-about .kb-footer__logo.footer-logo {
    display: inline-block;
    max-width: 100%;
    margin-bottom: 22px;
}

.footer .footer-widget-about .kb-footer__logo a {
    display: inline-block;
    line-height: 0;
}

.footer .footer-widget-about .kb-footer__logo figure {
    margin: 0;
    line-height: 0;
}

.footer .footer-widget-about .kb-footer__logo img {
    display: block;
    width: auto;
    height: auto;
    max-width: 200px;
    max-height: 56px;
    object-fit: contain;
}

@media (max-width: 767px) {
    .footer .footer-widget-about .kb-footer__logo img {
        max-width: 168px;
        max-height: 48px;
    }
}

/* Floating WhatsApp contact — left side */
.kb-whatsapp-float {
    position: fixed;
    left: 20px;
    bottom: 24px;
    z-index: 999;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px 14px 16px;
    border-radius: 999px;
    background: #25d366;
    color: #ffffff;
    text-decoration: none;
    box-shadow:
        0 8px 28px rgba(37, 211, 102, 0.35),
        0 0 0 1px rgba(255, 255, 255, 0.18);
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.kb-whatsapp-float i {
    font-size: 1.65rem;
    line-height: 1;
}

.kb-whatsapp-float__label {
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.kb-whatsapp-float:hover {
    color: #ffffff;
    background: #1ebe57;
    transform: translateY(-3px);
    box-shadow:
        0 12px 32px rgba(37, 211, 102, 0.42),
        0 0 0 1px rgba(255, 255, 255, 0.22);
}

@media (max-width: 767px) {
    .kb-whatsapp-float {
        left: 16px;
        bottom: 16px;
        padding: 14px;
    }

    .kb-whatsapp-float__label {
        display: none;
    }
}

/* Visit Kashi — temples listing */
.kb-temples-list {
    position: relative;
    overflow-x: clip;
    background: linear-gradient(
        180deg,
        var(--white-color, #ffffff) 0%,
        var(--extra-color, #F5EBEA) 38%,
        var(--accent-color-one, #F8F2E6) 100%
    );
}

.kb-temples-list__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-temples-list__orb--one {
    width: 320px;
    height: 320px;
    top: 8%;
    left: -80px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.12) 0%, transparent 70%);
}

.kb-temples-list__orb--two {
    width: 280px;
    height: 280px;
    bottom: 12%;
    right: -60px;
    background: radial-gradient(circle, rgba(71, 8, 4, 0.08) 0%, transparent 70%);
}

.kb-temples-list .container {
    position: relative;
    z-index: 1;
}

.kb-temples-list__header {
    margin-bottom: 48px;
}

.kb-temples-list__heading {
    margin-bottom: 16px;
}

.kb-temples-list__intro {
    max-width: 760px;
    margin: 0 auto;
    color: rgba(18, 47, 42, 0.78);
    line-height: 1.75;
}

.kb-temples-list__grid {
    row-gap: 0;
}

.kb-temples-list__col {
    margin-bottom: 32px;
}

.kb-temples-list__card {
    height: 100%;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border-radius: 24px;
    overflow: hidden;
    box-shadow:
        0 12px 36px rgba(18, 47, 42, 0.08),
        0 0 0 1px rgba(255, 193, 7, 0.1);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.kb-temples-list__card:hover {
    transform: translateY(-6px);
    box-shadow:
        0 20px 48px rgba(18, 47, 42, 0.12),
        0 0 0 1px rgba(255, 193, 7, 0.18);
}

.kb-temples-list__media {
    position: relative;
    overflow: hidden;
}

.kb-temples-list__media figure {
    margin: 0;
    aspect-ratio: 3 / 2;
    min-height: 280px;
    overflow: hidden;
}

.kb-temples-list__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.kb-temples-list__card:hover .kb-temples-list__media img {
    transform: scale(1.05);
}

.kb-temples-list__badge {
    position: absolute;
    top: 16px;
    left: 16px;
    padding: 6px 14px;
    border-radius: 999px;
    background: var(--primary-color, #470804);
    color: #ffffff;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.kb-temples-list__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 20px 20px 24px;
}

.kb-temples-list__title {
    margin: 0 0 6px;
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1.35rem;
    font-weight: 700;
    line-height: 1.3;
}

.kb-temples-list__title a {
    color: var(--title-color, #122f2a);
    text-decoration: none;
}

.kb-temples-list__title a:hover {
    color: var(--primary-color, #470804);
}

.kb-temples-list__title-hi {
    margin: 0 0 12px;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.5;
}

.kb-temples-list__desc {
    margin: 0 0 16px;
    color: rgba(18, 47, 42, 0.72);
    font-size: 0.95rem;
    line-height: 1.65;
    flex: 1;
}

.kb-temples-list__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
    color: rgba(18, 47, 42, 0.65);
    font-size: 0.9rem;
}

.kb-temples-list__meta-icon {
    color: var(--primary-color, #470804);
}

.kb-temples-list__actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.kb-temples-list__btn {
    padding: 12px 22px;
    font-size: 0.9rem;
}

.kb-temples-list__link {
    color: var(--primary-color, #470804);
    font-weight: 600;
    text-decoration: none;
}

.kb-temples-list__link:hover {
    text-decoration: underline;
}

.kb-temples-list__cta {
    margin-top: 48px;
    padding: 40px 32px;
    border-radius: 24px;
    background: var(--primary-color, #470804);
    color: #ffffff;
}

.kb-temples-list__cta-text {
    max-width: 680px;
    margin: 0 auto 24px;
    color: rgba(255, 255, 255, 0.92);
    line-height: 1.75;
}

.kb-temples-list__empty {
    color: rgba(18, 47, 42, 0.65);
}

#temple-booking {
    scroll-margin-top: 120px;
}

/* Visit Kashi — temple detail */
.kb-temple-detail {
    position: relative;
    overflow-x: clip;
    background: linear-gradient(180deg, #ffffff 0%, var(--extra-color, #F5EBEA) 100%);
}

.kb-temple-detail__orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.kb-temple-detail__orb--one {
    width: 300px;
    height: 300px;
    top: 5%;
    right: -70px;
    background: radial-gradient(circle, rgba(255, 193, 7, 0.1) 0%, transparent 70%);
}

.kb-temple-detail__orb--two {
    width: 260px;
    height: 260px;
    bottom: 20%;
    left: -60px;
    background: radial-gradient(circle, rgba(71, 8, 4, 0.06) 0%, transparent 70%);
}

.kb-temple-detail .container {
    position: relative;
    z-index: 1;
}

.kb-temple-detail__hero {
    position: relative;
    margin-bottom: 36px;
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 16px 44px rgba(18, 47, 42, 0.12);
}

.kb-temple-detail__hero--full {
    width: 100%;
}

.kb-temple-detail__hero figure {
    margin: 0;
    line-height: 0;
}

.kb-temple-detail__hero img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
}

.kb-temple-detail__hero-frame {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    border: 1px solid rgba(255, 193, 7, 0.2);
}

.kb-temple-detail__hero-badge {
    position: absolute;
    top: 20px;
    left: 20px;
    padding: 8px 16px;
    border-radius: 999px;
    background: var(--primary-color, #470804);
    color: #ffffff;
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
}

.kb-temple-detail__eyebrow {
    display: inline-block;
    margin-bottom: 12px;
}

.kb-temple-detail__title {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: clamp(2rem, 3.4vw, 2.75rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 8px;
}

.kb-temple-detail__title-hi {
    margin: 0 0 16px;
    color: var(--primary-color, #470804);
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1.25rem;
    font-weight: 600;
}

.kb-temple-detail__lead {
    margin-bottom: 28px;
    color: rgba(18, 47, 42, 0.78);
    font-size: 1.05rem;
    line-height: 1.75;
}

.kb-temple-detail__info-card {
    margin-bottom: 32px;
    padding: 28px;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 8px 28px rgba(18, 47, 42, 0.06);
}

.kb-temple-detail__info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.kb-temple-detail__info-item {
    display: flex;
    gap: 14px;
    align-items: flex-start;
}

.kb-temple-detail__info-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    border-radius: 12px;
    background: rgba(71, 8, 4, 0.08);
    color: var(--primary-color, #470804);
}

.kb-temple-detail__info-text span {
    display: block;
    margin-bottom: 4px;
    color: rgba(18, 47, 42, 0.55);
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.kb-temple-detail__info-text p {
    margin: 0;
    color: var(--title-color, #122f2a);
    font-weight: 500;
    line-height: 1.6;
}

.kb-temple-detail__info-sub {
    display: block;
    margin-top: 4px;
    color: rgba(18, 47, 42, 0.65);
    font-size: 0.92rem;
    font-weight: 400;
}

.kb-temple-detail__prose {
    color: rgba(18, 47, 42, 0.82);
    line-height: 1.8;
}

.kb-temple-detail__prose p {
    margin-bottom: 1rem;
}

.kb-temple-detail__block {
    margin-top: 36px;
    padding-top: 28px;
    border-top: 1px solid rgba(71, 8, 4, 0.1);
}

.kb-temple-detail__subtitle {
    font-family: var(--title-fonts, "Merriweather", serif);
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 16px;
}

.kb-temple-detail__visit-time {
    margin: 0;
    padding: 20px 24px;
    border-radius: 16px;
    background: rgba(255, 193, 7, 0.12);
    color: var(--title-color, #122f2a);
    line-height: 1.7;
}

.kb-temple-detail__sidebar .widget {
    margin-bottom: 24px;
}

.kb-temple-detail__book-card,
.kb-temple-detail__nav-card,
.kb-temple-detail__help-card {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 8px 28px rgba(18, 47, 42, 0.06);
}

.kb-temple-detail__book-text,
.kb-temple-detail__help-text {
    margin-bottom: 20px;
    line-height: 1.7;
}

.kb-temple-detail__book-cta {
    width: 100%;
    justify-content: center;
}

.kb-temple-detail__nav-list .kb-temple-detail__nav-link.active {
    color: var(--primary-color, #470804);
    font-weight: 600;
}

.kb-temple-detail__related {
    background: var(--extra-color, #F5EBEA);
}

.kb-temple-detail__related-header {
    margin-bottom: 40px;
}

@media (max-width: 991px) {
    .kb-temple-detail__info-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    .kb-temples-list__body {
        padding: 20px 18px 24px;
    }

    .kb-temples-list__cta {
        padding: 28px 20px;
    }

    .kb-temple-detail__info-card {
        padding: 20px;
    }
}

/* Pages without uploaded images — layout fallbacks */
.breadcrumb-wapper--no-bg {
    background: linear-gradient(135deg, #122f2a 0%, #0d3b2e 55%, #1a4a3d 100%);
}

.kb-service-card__body--no-image {
    padding-top: 8px;
}

.kb-service-card__body--no-image .kb-service-card__title {
    margin-top: 0;
}

.kb-temples-list__card--no-media .kb-temples-list__body {
    padding-top: 24px;
}

.kb-temples-list__badge--inline {
    position: static;
    display: inline-block;
    margin-bottom: 12px;
}

.event-section-2 .kb-events-list__card.kb-events-list__card--no-media .kb-events-list__date.event-date {
    position: static;
    display: inline-block;
    margin-bottom: 10px;
}

.kb-blog-card--no-media .kb-blog-card__body {
    padding-top: 4px;
}

.kb-service-detail__main--no-hero .kb-service-detail__body,
.kb-event-detail__main--no-hero .kb-event-detail__body,
.kb-temple-detail__main--no-hero .kb-temple-detail__body {
    padding-top: 0;
}

.kb-blog-detail--no-hero .kb-blog-detail__card {
    margin-top: 0;
}

.hero-section-1--fullwidth .hero-items .hero-image.hero-image--no-photo {
    background: linear-gradient(135deg, #0d3b2e 0%, #122f2a 48%, #1a4a3d 100%);
}

.hero-section-1--fullwidth .hero-items .hero-image.hero-image--no-photo::after {
    background: linear-gradient(
        90deg,
        rgba(13, 59, 46, 0.88) 0%,
        rgba(13, 59, 46, 0.62) 45%,
        rgba(13, 59, 46, 0.28) 100%
    );
}

