/* ================================================================
   BODHIRA SKILLS ACADEMY — Franchise Page CSS
   Matches index page: cobalt/navy · gold · glassmorphism · Plus Jakarta Sans
   ================================================================ */

/* ── RESET & BASE ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

/* ── BREADCRUMB ──────────────────────────────────────────── */
.breadcrumb-wrapper {
    background: linear-gradient(160deg, #1239a6 0%, #1a56db 100%) !important;
    padding: 64px 0 !important;
    position: relative; overflow: hidden;
}
.breadcrumb-wrapper::before {
    content: ''; position: absolute;
    bottom: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A);
    z-index: 2;
}
.breadcrumb-wrapper::after {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 48px 48px; pointer-events: none;
}
.breadcrumb-wrapper .page-heading { position: relative; z-index: 1; padding: 0 !important; }
.breadcrumb-wrapper .page-heading h1 {
    color: #fff !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 42px !important; font-weight: 800 !important;
    margin-bottom: 12px; letter-spacing: -.5px;
}
.breadcrumb-wrapper .page-heading .breadcrumb-items li {
    color: rgba(255,255,255,.65) !important; font-size: 13px; font-weight: 500;
}
.breadcrumb-wrapper .page-heading .breadcrumb-items li a { color: rgba(255,255,255,.65) !important; }
.breadcrumb-wrapper .page-heading .breadcrumb-items li a:hover { color: #F0BE55 !important; }
.breadcrumb-wrapper .page-heading .breadcrumb-items li.style-2 { color: #F0BE55 !important; font-weight: 700; }

/* ── SHARED SECTION HEADING ──────────────────────────────── */
.bsi-section-head { margin-bottom: 48px; }
.bsi-section-head .bsi-label {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 11px; font-weight: 800; letter-spacing: 2.5px;
    text-transform: uppercase; color: #C4972A;
    margin-bottom: 14px;
    font-family: 'Plus Jakarta Sans', sans-serif;
}
.bsi-section-head .bsi-label::before {
    content: ''; display: block; width: 28px; height: 2px;
    background: linear-gradient(120deg, #C4972A, #F0BE55); border-radius: 1px;
}
.bsi-section-head h2 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 36px !important; font-weight: 800 !important;
    color: #0F1B4C !important; letter-spacing: -.5px; margin: 0;
}
.bsi-section-head h2 span { color: #1a56db; }
.bsi-section-head p { font-size: 14px; color: #4B5680; margin: 10px 0 0; line-height: 1.7; }

/* Light variant */
.bsi-section-head.light h2 { color: #fff !important; }
.bsi-section-head.light .bsi-label { color: #F0BE55; }
.bsi-section-head.light .bsi-label::before { background: linear-gradient(120deg, #F0BE55, #C4972A); }
.bsi-section-head.light p { color: rgba(255,255,255,.65); }

/* Gold underline on centered headings */
.bsi-section-head.text-center h2::after {
    content: ''; display: block; width: 60px; height: 3px;
    background: linear-gradient(120deg, #C4972A, #F0BE55);
    border-radius: 2px; margin: 12px auto 0;
}
.bsi-section-head.text-center .bsi-label { justify-content: center; }

/* ── METRICS STRIP ───────────────────────────────────────── */
.bsi-metrics {
    background: linear-gradient(160deg, #1239a6 0%, #1a56db 100%);
    padding: 0; position: relative; overflow: hidden;
}
.bsi-metrics::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A); z-index: 2;
}
.bsi-metrics::after {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 48px 48px; pointer-events: none;
}
.bsi-metrics-inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr) auto;
    position: relative; z-index: 1;
}
.bsi-metric-item {
    padding: 36px 28px;
    display: flex; align-items: center; gap: 16px;
    border-right: 1px solid rgba(255,255,255,.08);
    transition: background .3s;
    position: relative;
}
.bsi-metric-item::after {
    content: ''; position: absolute;
    bottom: 0; left: 20%; right: 20%; height: 2px;
    background: linear-gradient(120deg, #C4972A, #F0BE55);
    opacity: 0; transition: opacity .3s;
}
.bsi-metric-item:hover { background: rgba(196,151,42,.07); }
.bsi-metric-item:hover::after { opacity: 1; }
.bsi-metric-item:last-child { border-right: none; }

.bsi-metric-icon {
    width: 52px; height: 52px; border-radius: 50%; flex-shrink: 0;
    background: rgba(196,151,42,.12);
    border: 1px solid rgba(196,151,42,.3);
    display: flex; align-items: center; justify-content: center;
    transition: all .3s;
}
.bsi-metric-item:hover .bsi-metric-icon {
    background: rgba(196,151,42,.2);
    border-color: rgba(196,151,42,.5);
    box-shadow: 0 0 20px rgba(196,151,42,.25);
}
.bsi-metric-icon img {
    width: 26px; height: 26px; object-fit: contain;
    filter: brightness(0) sepia(1) hue-rotate(10deg) saturate(4);
}
.bsi-metric-text h3 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 28px !important; font-weight: 800 !important;
    color: #F0BE55 !important; margin: 0 !important;
    line-height: 1; letter-spacing: -.5px;
}
.bsi-metric-text p {
    font-size: 11px; font-weight: 700; color: rgba(255,255,255,.6);
    letter-spacing: 1.2px; text-transform: uppercase;
    margin: 6px 0 0; font-family: 'Plus Jakarta Sans', sans-serif;
}

/* CTA in metrics */
.bsi-metric-cta {
    padding: 24px 32px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(196,151,42,.07);
    border-left: 1px solid rgba(196,151,42,.2);
}
.bsi-partner-btn {
    display: inline-flex; align-items: center; gap: 10px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A);
    color: #0F1B4C !important;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 800; font-size: 13px; letter-spacing: .8px;
    text-transform: uppercase; padding: 14px 28px; border-radius: 5px;
    border: none; cursor: pointer; white-space: nowrap;
    box-shadow: 0 4px 20px rgba(196,151,42,.4);
    transition: transform .2s, box-shadow .2s;
    text-decoration: none;
}
.bsi-partner-btn:hover {
    transform: translateY(-2px); color: #0F1B4C !important;
    box-shadow: 0 8px 28px rgba(196,151,42,.6);
}

/* ── ABOUT / OVERVIEW — single clean bg ──────────────────── */
.bsi-franchise-about {
    background: #EEF1FA;
    padding: 90px 0;
    position: relative;
    border-top: 3px solid #C4972A;
    border-bottom: 1px solid rgba(26,86,219,.1);
}
.bsi-franchise-about .container { position: relative; z-index: 1; }

.bsi-about-img {
    border-radius: 14px; overflow: hidden; position: relative;
}
.bsi-about-img img {
    width: 100%; border-radius: 14px; display: block;
    box-shadow: 0 24px 64px rgba(26,86,219,.15);
    transition: transform .5s ease;
}
.bsi-about-img:hover img { transform: scale(1.02); }
.bsi-about-img::before {
    content: ''; position: absolute;
    left: -8px; top: 32px; bottom: 32px; width: 4px;
    background: linear-gradient(to bottom, #C4972A, #F0BE55, #1a56db);
    border-radius: 2px; z-index: 2;
}

.bsi-divider {
    width: 48px; height: 3px; border-radius: 2px;
    background: linear-gradient(120deg, #C4972A, #F0BE55);
    margin: 16px 0 20px;
}

.bsi-apply-btn {
    display: inline-flex; align-items: center; gap: 10px;
    background: linear-gradient(135deg, #1239a6, #1a56db);
    color: #fff !important;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 800; font-size: 13px; letter-spacing: .6px;
    text-transform: uppercase; padding: 13px 30px; border-radius: 5px;
    border: none; cursor: pointer;
    box-shadow: 0 6px 24px rgba(26,86,219,.3);
    transition: transform .25s, box-shadow .25s; text-decoration: none;
}
.bsi-apply-btn:hover {
    transform: translateY(-2px); color: #fff !important;
    box-shadow: 0 12px 32px rgba(26,86,219,.45);
}

/* Feature list inside about */
.bsi-about-features { display: flex; flex-direction: column; gap: 14px; margin-bottom: 28px; }
.bsi-about-feature {
    display: flex; align-items: flex-start; gap: 14px;
    background: #fff;
    border: 1px solid rgba(26,86,219,.1);
    border-left: 3px solid #C4972A;
    border-radius: 8px; padding: 14px 16px;
    transition: box-shadow .25s, transform .25s;
}
.bsi-about-feature:hover { box-shadow: 0 6px 20px rgba(26,86,219,.1); transform: translateX(4px); }
.bsi-about-feature-icon {
    width: 38px; height: 38px; border-radius: 8px; flex-shrink: 0;
    background: linear-gradient(135deg, #eef2ff, #dbe4ff);
    border: 1px solid rgba(26,86,219,.15);
    display: flex; align-items: center; justify-content: center;
    font-size: 15px; color: #1a56db;
}
.bsi-about-feature strong {
    display: block; font-size: 13px; font-weight: 800;
    color: #0F1B4C; line-height: 1.3; margin-bottom: 3px;
    font-family: 'Plus Jakarta Sans', sans-serif;
}
.bsi-about-feature span { font-size: 12px; color: #4B5680; font-weight: 500; }

/* ================================================================
   FRANCHISE MODEL CARDS — MODERNIZED (glass + glow + gold ring)
   ================================================================ */
.bsi-model-section {
    background: linear-gradient(160deg, #0c2575 0%, #1239a6 50%, #1a56db 100%);
    padding: 90px 0; position: relative; overflow: hidden;
}
.bsi-model-section::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A);
}
.bsi-model-section::after {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 48px 48px; pointer-events: none;
}
/* Decorative blurred gold orb */
.bsi-model-section .container { position: relative; z-index: 1; }
.bsi-model-section .container::before {
    content: ''; position: absolute;
    top: -100px; right: -50px;
    width: 280px; height: 280px; border-radius: 50%;
    background: radial-gradient(circle, rgba(196,151,42,.25) 0%, transparent 70%);
    filter: blur(40px); pointer-events: none; z-index: 0;
}

.bsi-model-card {
    background: linear-gradient(160deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,.04) 100%);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 20px;
    padding: 44px 28px 32px;
    text-align: center;
    height: 100%;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow:
        0 16px 40px rgba(0,0,0,.25),
        0 4px 12px rgba(0,0,0,.15),
        inset 0 1px 0 rgba(255,255,255,.15),
        inset 0 -1px 0 rgba(0,0,0,.1);
    transition: all .45s cubic-bezier(.4,0,.2,1);
}
/* Gold corner ribbon */
.bsi-model-card::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 4px;
    background: linear-gradient(120deg, #C4972A 0%, #F0BE55 50%, #C4972A 100%);
    transform: scaleX(0); transform-origin: left;
    transition: transform .5s ease;
    z-index: 3;
}
/* Subtle shimmer on hover */
.bsi-model-card::after {
    content: ''; position: absolute;
    top: 0; left: -150%; width: 50%; height: 100%;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.08) 50%, transparent 100%);
    transform: skewX(-20deg);
    transition: left .8s ease;
    pointer-events: none;
}
.bsi-model-card:hover {
    transform: translateY(-12px);
    border-color: rgba(196,151,42,.6);
    background: linear-gradient(160deg, rgba(255,255,255,.14) 0%, rgba(255,255,255,.06) 100%);
    box-shadow:
        0 32px 64px rgba(0,0,0,.4),
        0 12px 24px rgba(0,0,0,.25),
        0 0 32px rgba(196,151,42,.25),
        inset 0 1px 0 rgba(255,255,255,.25);
}
.bsi-model-card:hover::before { transform: scaleX(1); }
.bsi-model-card:hover::after { left: 200%; }

/* Number badge — premium gold */
.bsi-model-card-num {
    position: absolute;
    top: 16px; right: 16px;
    width: 38px; height: 38px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(196,151,42,.2), rgba(240,190,85,.1));
    border: 1.5px solid rgba(196,151,42,.5);
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 900;
    color: #F0BE55;
    font-family: 'Plus Jakarta Sans', sans-serif;
    z-index: 4;
    letter-spacing: .5px;
    box-shadow: 0 4px 12px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.15);
    transition: all .35s ease;
}
.bsi-model-card:hover .bsi-model-card-num {
    background: linear-gradient(135deg, #C4972A, #F0BE55);
    color: #0F1B4C;
    border-color: #F0BE55;
    transform: scale(1.1) rotate(360deg);
    box-shadow: 0 6px 18px rgba(196,151,42,.5);
}

/* Icon — circular gold ring */
.bsi-model-icon {
    width: 84px; height: 84px; border-radius: 50%;
    background: linear-gradient(135deg, rgba(196,151,42,.15), rgba(240,190,85,.05));
    border: 2px solid rgba(196,151,42,.4);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 18px;
    transition: all .45s cubic-bezier(.4,0,.2,1);
    position: relative; z-index: 2;
    box-shadow:
        0 8px 24px rgba(0,0,0,.2),
        inset 0 1px 0 rgba(255,255,255,.15);
}
.bsi-model-icon::before {
    content: ''; position: absolute;
    inset: -6px;
    border-radius: 50%;
    border: 1px dashed rgba(196,151,42,.3);
    opacity: 0;
    transition: all .45s ease;
}
.bsi-model-card:hover .bsi-model-icon {
    background: linear-gradient(135deg, #C4972A, #F0BE55);
    border-color: #F0BE55;
    transform: scale(1.08) rotate(-5deg);
    box-shadow: 0 12px 32px rgba(196,151,42,.5);
}
.bsi-model-card:hover .bsi-model-icon::before {
    opacity: 1;
    inset: -10px;
    animation: spinSlow 8s linear infinite;
}
@keyframes spinSlow {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
.bsi-model-icon img {
    width: 40px; height: 40px; object-fit: contain;
    filter: brightness(0) saturate(100%) invert(70%) sepia(70%) saturate(450%) hue-rotate(360deg) brightness(95%);
    transition: filter .35s;
}
.bsi-model-card:hover .bsi-model-icon img { filter: brightness(0) invert(8%) sepia(40%) saturate(2500%) hue-rotate(218deg); }

/* Gold divider */
.bsi-model-card-divider {
    width: 40px; height: 3px; border-radius: 2px;
    background: linear-gradient(120deg, #C4972A, #F0BE55);
    margin: 0 auto 14px;
    transition: width .4s ease;
    position: relative; z-index: 2;
    box-shadow: 0 0 8px rgba(240,190,85,.3);
}
.bsi-model-card:hover .bsi-model-card-divider { width: 72px; }

.bsi-model-card h4 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 17px !important; font-weight: 800 !important;
    color: #ffffff !important; margin-bottom: 12px;
    position: relative; z-index: 2;
    transition: color .25s; line-height: 1.3;
    text-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.bsi-model-card:hover h4 { color: #F0BE55 !important; }
.bsi-model-card .model-description,
.bsi-model-card p {
    font-size: 13px; color: rgba(255,255,255,.78);
    line-height: 1.7; margin: 0;
    position: relative; z-index: 2;
    font-weight: 500;
}

/* ================================================================
   WHY CHOOSE US — MODERNIZED (gradient stroke + floating icon)
   ================================================================ */
.bsi-why-section {
    background: linear-gradient(180deg, #EEF1FA 0%, #DEE5F8 100%);
    padding: 90px 0;
    position: relative; overflow: hidden;
}
.bg-3d-wrapper {
    position: absolute; inset: 0;
    pointer-events: none; perspective: 1000px; z-index: 1;
}
.bg-item {
    position: absolute; width: 120px; height: 120px;
    opacity: .5; transform-style: preserve-3d;
    transition: transform .1s linear;
    background-size: contain; background-repeat: no-repeat;
    background-position: center;
}
.item1 { top: 10%; left: 5%; }
.item2 { top: 10%; right: 5%; }
.item3 { bottom: 15%; left: 2%; }
.item4 { bottom: 15%; right: 2%; }
.item5 { top: 50%; left: 50%; translate: -50% -50%; display: none; }

.bsi-why-card {
    background: #fff;
    border: 1px solid rgba(26,86,219,.08);
    border-radius: 18px;
    padding: 36px 24px 28px;
    text-align: center;
    height: 100%;
    box-shadow:
        0 8px 24px rgba(26,86,219,.08),
        0 2px 4px rgba(26,86,219,.04);
    transition: all .4s cubic-bezier(.4,0,.2,1);
    position: relative; overflow: hidden;
}
/* Gradient border on hover via pseudo */
.bsi-why-card::before {
    content: ''; position: absolute;
    inset: 0; padding: 2px; border-radius: 18px;
    background: linear-gradient(135deg, #C4972A, #F0BE55, #1a56db);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    opacity: 0;
    transition: opacity .4s ease;
    pointer-events: none;
    z-index: 3;
}
/* Top gold arc */
.bsi-why-card::after {
    content: ''; position: absolute;
    top: -60px; left: 50%; transform: translateX(-50%) scale(.8);
    width: 220px; height: 120px; border-radius: 50%;
    background: radial-gradient(circle at center bottom, rgba(196,151,42,.18) 0%, transparent 70%);
    opacity: 0; transition: opacity .4s ease, transform .4s ease;
    pointer-events: none;
}
.bsi-why-card:hover {
    transform: translateY(-10px);
    box-shadow:
        0 24px 56px rgba(26,86,219,.18),
        0 8px 16px rgba(26,86,219,.1);
}
.bsi-why-card:hover::before { opacity: 1; }
.bsi-why-card:hover::after { opacity: 1; transform: translateX(-50%) scale(1); }

/* Icon container — floating hex-ish */
.bsi-why-icon-wrap {
    position: relative;
    width: 86px; height: 86px;
    margin: 0 auto 22px;
}
.bsi-why-icon-wrap::before {
    content: ''; position: absolute;
    inset: -8px;
    border-radius: 50%;
    border: 1.5px dashed rgba(196,151,42,.35);
    opacity: 0;
    transition: opacity .4s ease;
}
.bsi-why-card:hover .bsi-why-icon-wrap::before {
    opacity: 1;
    animation: spinSlow 10s linear infinite;
}

.bsi-why-icon {
    width: 86px; height: 86px;
    border-radius: 22px;
    background: linear-gradient(135deg, #EEF3FF 0%, #DCE5FF 100%);
    border: 1.5px solid rgba(26,86,219,.15);
    display: flex; align-items: center; justify-content: center;
    transition: all .45s cubic-bezier(.4,0,.2,1);
    position: relative; z-index: 2;
    box-shadow:
        0 8px 20px rgba(26,86,219,.15),
        inset 0 1px 0 rgba(255,255,255,.6);
}
.bsi-why-icon::after {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 50%;
    border-radius: 22px 22px 0 0;
    background: linear-gradient(to bottom, rgba(255,255,255,.4), transparent);
    pointer-events: none;
}
.bsi-why-card:hover .bsi-why-icon {
    background: linear-gradient(135deg, #1239a6, #1a56db);
    border-color: transparent;
    transform: rotate(-8deg) scale(1.08);
    box-shadow:
        0 12px 32px rgba(26,86,219,.45),
        0 4px 8px rgba(26,86,219,.25);
}
.bsi-why-icon img {
    width: 38px; height: 38px; object-fit: contain;
    filter: invert(22%) sepia(80%) saturate(900%) hue-rotate(210deg);
    transition: filter .35s;
    position: relative; z-index: 1;
}
.bsi-why-card:hover .bsi-why-icon img { filter: brightness(0) invert(1); }

.bsi-why-card h4 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 15px !important; font-weight: 800 !important;
    color: #0F1B4C !important; margin-bottom: 10px;
    transition: color .3s;
    position: relative; z-index: 2;
}
.bsi-why-card:hover h4 { color: #1a56db !important; }
.bsi-why-card p {
    font-size: 13px; color: #4B5680;
    line-height: 1.7; margin: 0 0 16px;
    position: relative; z-index: 2;
}

/* Bottom arrow indicator */
.bsi-why-card-arrow {
    width: 36px; height: 36px; border-radius: 50%;
    background: linear-gradient(135deg, #EEF3FF, #DCE5FF);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 12px;
    color: #1a56db;
    transition: all .4s ease;
    margin-top: 4px;
    position: relative; z-index: 2;
    box-shadow: 0 4px 12px rgba(26,86,219,.1);
}
.bsi-why-card:hover .bsi-why-card-arrow {
    background: linear-gradient(120deg, #C4972A, #F0BE55);
    color: #0F1B4C;
    transform: translateX(4px) rotate(-45deg);
    box-shadow: 0 6px 16px rgba(196,151,42,.4);
}

/* ================================================================
   COMPARISON TABLE
   ================================================================ */
.bsi-compare-section {
    background: #fff;
    padding: 90px 0;
    position: relative;
}
.bsi-compare-section::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(196,151,42,.4), transparent);
}

.bsi-compare-wrap {
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow:
        0 20px 56px rgba(26,86,219,.12),
        0 8px 16px rgba(26,86,219,.06);
    border: 1px solid rgba(26,86,219,.08);
    position: relative;
}
.bsi-compare-table-scroll { overflow-x: auto; }

.bsi-compare-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 720px;
    font-family: 'Plus Jakarta Sans', sans-serif;
}

.bsi-compare-table thead tr {
    background: linear-gradient(160deg, #EEF1FA 0%, #DEE5F8 100%);
}
.bsi-compare-table thead th {
    padding: 22px 24px;
    font-size: 13px;
    font-weight: 800;
    color: #0F1B4C;
    text-align: center;
    border-bottom: 2px solid rgba(26,86,219,.1);
    position: relative;
}
.bsi-compare-table thead th.bsi-compare-th-label {
    text-align: left;
    color: #0F1B4C;
}

/* "Bodhira" column highlighted */
.bsi-compare-table thead th.bsi-compare-th-us {
    background: linear-gradient(135deg, #1239a6 0%, #1a56db 100%);
    color: #fff;
    font-weight: 900;
    position: relative;
    border-bottom: 2px solid #F0BE55;
}
.bsi-compare-table thead th.bsi-compare-th-us::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A);
}
.bsi-compare-table thead th.bsi-compare-th-us i {
    margin-right: 6px;
    color: #F0BE55;
    font-size: 14px;
}
.bsi-compare-table thead th.bsi-compare-th-other {
    color: #4B5680;
    font-weight: 700;
}

.bsi-compare-table tbody tr {
    transition: background .25s;
    border-bottom: 1px solid rgba(26,86,219,.06);
}
.bsi-compare-table tbody tr:last-child { border-bottom: none; }
.bsi-compare-table tbody tr:hover { background: rgba(26,86,219,.025); }

.bsi-compare-table tbody td {
    padding: 18px 24px;
    font-size: 14px;
    color: #2d3550;
    font-weight: 600;
    text-align: center;
    vertical-align: middle;
}
.bsi-compare-table tbody td:first-child {
    text-align: left;
    color: #0F1B4C;
    font-weight: 700;
}

/* Highlighted Bodhira column body */
.bsi-cell-us {
    background: linear-gradient(180deg, rgba(26,86,219,.04), rgba(26,86,219,.08));
    border-left: 1px solid rgba(240,190,85,.3);
    border-right: 1px solid rgba(240,190,85,.3);
    position: relative;
}

.bsi-tick {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, #16a34a, #22c55e);
    color: #fff;
    font-size: 14px;
    font-weight: 900;
    box-shadow:
        0 4px 12px rgba(34,197,94,.35),
        inset 0 1px 0 rgba(255,255,255,.2);
}

.bsi-cross {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, #fee2e2, #fecaca);
    color: #dc2626;
    font-size: 14px;
    font-weight: 900;
    border: 1px solid rgba(220,38,38,.2);
}

.bsi-dash {
    display: inline-block;
    color: #94a3b8;
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
}

/* Footer accent — last row in Bodhira column has extra bottom border */
.bsi-compare-table tbody tr:last-child .bsi-cell-us {
    border-bottom: 2px solid #F0BE55;
}

/* ================================================================
   FAQ SECTION (Dynamic)
   ================================================================ */
.bsi-faq-section {
    background: linear-gradient(160deg, #1239a6 0%, #1a56db 100%);
    padding: 90px 0;
    position: relative;
    overflow: hidden;
}
.bsi-faq-section::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A);
    z-index: 2;
}
.bsi-faq-section::after {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 48px 48px; pointer-events: none;
}
.bsi-faq-section .container { position: relative; z-index: 1; }

/* Light heading override for FAQ section */
.bsi-faq-section .bsi-section-head h2 {
    color: #ffffff !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.3);
}
.bsi-faq-section .bsi-section-head h2 span {
    color: #F0BE55 !important;
}
.bsi-faq-section .bsi-section-head p {
    color: rgba(255,255,255,.85);
}
.bsi-faq-section .bsi-section-head .bsi-label {
    color: #F0BE55;
}
.bsi-faq-section .bsi-section-head .bsi-label::before {
    background: linear-gradient(120deg, #F0BE55, #C4972A);
}

/* Grid layout: accordion + sidebar CTA */
.bsi-faq-wrap {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 32px;
    align-items: flex-start;
}

.bsi-faq-item {
    background: #fff;
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 14px;
    margin-bottom: 14px;
    overflow: hidden;
    transition: all .35s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 8px 24px rgba(0,0,0,.18), 0 2px 6px rgba(0,0,0,.1);
}
.bsi-faq-item:has(.bsi-faq-btn:not(.collapsed)) {
    box-shadow:
        0 20px 48px rgba(0,0,0,.3),
        0 6px 12px rgba(0,0,0,.18),
        0 0 0 1px rgba(240,190,85,.5);
    border-color: rgba(240,190,85,.6);
    transform: translateY(-2px);
}

.bsi-faq-btn {
    width: 100%;
    background: #fff;
    border: none;
    padding: 22px 24px;
    text-align: left;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 18px;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 15px;
    font-weight: 700;
    color: #0F1B4C;
    transition: all .3s ease;
    position: relative;
}
.bsi-faq-btn:hover { background: #FAFBFF; }
.bsi-faq-btn:focus { outline: none; box-shadow: none; }

/* When open, add gold left strip */
.bsi-faq-btn:not(.collapsed) {
    background: linear-gradient(135deg, #1239a6 0%, #1a56db 100%);
    color: #fff;
}
.bsi-faq-btn:not(.collapsed):hover {
    background: linear-gradient(135deg, #1239a6 0%, #1a56db 100%);
}

.bsi-faq-q-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px; height: 42px;
    border-radius: 12px;
    background: linear-gradient(135deg, #EEF3FF, #DCE5FF);
    border: 1px solid rgba(26,86,219,.15);
    color: #1a56db;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .5px;
    flex-shrink: 0;
    transition: all .3s ease;
}
.bsi-faq-btn:not(.collapsed) .bsi-faq-q-num {
    background: linear-gradient(120deg, #C4972A, #F0BE55);
    color: #0F1B4C;
    border-color: transparent;
    box-shadow: 0 4px 12px rgba(196,151,42,.4);
}

.bsi-faq-q-text {
    flex: 1;
    line-height: 1.4;
    font-size: 15px;
    font-weight: 700;
}

.bsi-faq-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(26,86,219,.08);
    color: #1a56db;
    font-size: 13px;
    flex-shrink: 0;
    transition: all .35s ease;
}
.bsi-faq-btn:not(.collapsed) .bsi-faq-icon {
    background: rgba(255,255,255,.15);
    color: #fff;
    transform: rotate(45deg);
}
.bsi-faq-btn:not(.collapsed) .bsi-faq-icon i::before {
    content: '\f067'; /* fa-plus, stays plus but rotated to look like × */
}

.bsi-faq-answer {
    padding: 22px 24px 26px 84px;
    background: #fff;
    color: #4B5680;
    font-size: 14px;
    line-height: 1.8;
    font-weight: 500;
    border-top: 1px solid rgba(26,86,219,.06);
}
.bsi-faq-answer p { margin: 0 0 10px; }
.bsi-faq-answer p:last-child { margin: 0; }
.bsi-faq-answer ul, .bsi-faq-answer ol { margin: 8px 0 12px; padding-left: 20px; }
.bsi-faq-answer li { margin-bottom: 6px; }
.bsi-faq-answer a { color: #1a56db; font-weight: 700; }
.bsi-faq-answer a:hover { color: #C4972A; }

/* FAQ Empty State */
.bsi-faq-empty {
    background: linear-gradient(160deg, rgba(255,255,255,.14) 0%, rgba(255,255,255,.06) 100%);
    border: 1.5px dashed rgba(240,190,85,.5);
    border-radius: 14px;
    padding: 48px 28px;
    text-align: center;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 12px 32px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.15);
}
.bsi-faq-empty i {
    font-size: 36px;
    color: #F0BE55;
    margin-bottom: 14px;
    display: block;
}
.bsi-faq-empty h5 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    margin: 0 0 8px;
}
.bsi-faq-empty p {
    font-size: 13px;
    color: rgba(255,255,255,.85);
    margin: 0;
    line-height: 1.7;
}

/* FAQ Side CTA — glass style to stand out on blue bg */
.bsi-faq-cta {
    background: linear-gradient(160deg, rgba(255,255,255,.16) 0%, rgba(255,255,255,.06) 100%);
    border-radius: 18px;
    padding: 32px 28px;
    text-align: center;
    position: sticky;
    top: 100px;
    color: #fff;
    box-shadow:
        0 16px 40px rgba(0,0,0,.3),
        0 4px 12px rgba(0,0,0,.18),
        inset 0 1px 0 rgba(255,255,255,.2);
    border: 1px solid rgba(196,151,42,.45);
    overflow: hidden;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.bsi-faq-cta::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A);
}
.bsi-faq-cta::after {
    content: ''; position: absolute;
    bottom: -50px; right: -50px;
    width: 180px; height: 180px; border-radius: 50%;
    background: radial-gradient(circle, rgba(240,190,85,.2) 0%, transparent 70%);
    pointer-events: none;
}
.bsi-faq-cta-icon {
    width: 60px; height: 60px; border-radius: 50%;
    background: linear-gradient(120deg, #C4972A, #F0BE55);
    color: #0F1B4C;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 22px;
    margin-bottom: 16px;
    box-shadow: 0 6px 16px rgba(196,151,42,.4);
    position: relative; z-index: 1;
}
.bsi-faq-cta h4 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 18px !important; font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 8px;
    position: relative; z-index: 1;
}
.bsi-faq-cta p {
    font-size: 13px;
    color: rgba(255,255,255,.85);
    margin: 0 0 20px;
    line-height: 1.6;
    position: relative; z-index: 1;
}
.bsi-faq-cta .bsi-partner-btn {
    width: 100%;
    justify-content: center;
    position: relative; z-index: 1;
}

/* ── BENEFITS SECTION ────────────────────────────────────── */
.bsi-benefits-section {
    background: linear-gradient(160deg, #1239a6 0%, #1a56db 100%);
    padding: 80px 0; position: relative; overflow: hidden;
}
.bsi-benefits-section::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(120deg, #C4972A, #F0BE55, #C4972A);
}
.bsi-benefits-section::after {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 48px 48px; pointer-events: none;
}
.bsi-benefits-section .container { position: relative; z-index: 1; }

.bsi-benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }

.bsi-benefit-card {
    background: linear-gradient(160deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.10) 100%);
    border: 1px solid rgba(196,151,42,.45);
    border-top: 2px solid rgba(240,190,85,.6);
    border-left: 1px solid rgba(255,255,255,.2);
    border-radius: 12px; padding: 24px 20px;
    display: flex; gap: 16px; align-items: flex-start;
    box-shadow: 0 8px 24px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.2);
    position: relative; overflow: hidden;
    transition: all .35s ease;
}
.bsi-benefit-card::before {
    content: ''; position: absolute;
    left: 0; top: 0; bottom: 0; width: 3px;
    background: linear-gradient(to bottom, #F0BE55, #C4972A, transparent);
    border-radius: 12px 0 0 12px; opacity: .7; transition: opacity .35s;
}
.bsi-benefit-card::after {
    content: ''; position: absolute;
    top: 0; left: -100%; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(240,190,85,.8), transparent);
    transition: left .5s ease;
}
.bsi-benefit-card:hover::after { left: 100%; }
.bsi-benefit-card:hover {
    background: linear-gradient(160deg, rgba(196,151,42,.2) 0%, rgba(196,151,42,.08) 100%);
    border-color: rgba(240,190,85,.65);
    box-shadow: 0 16px 48px rgba(0,0,0,.35), 0 0 24px rgba(196,151,42,.15);
    transform: translateY(-4px);
}
.bsi-benefit-card:hover::before { opacity: 1; }

.bsi-benefit-tick {
    width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
    background: linear-gradient(135deg, #C4972A, #F0BE55);
    display: flex; align-items: center; justify-content: center;
    color: #0F1B4C; font-size: 14px; font-weight: 900;
    box-shadow: 0 4px 14px rgba(196,151,42,.4);
    transition: all .35s ease;
}
.bsi-benefit-card:hover .bsi-benefit-tick {
    box-shadow: 0 6px 20px rgba(196,151,42,.6);
    transform: scale(1.1) rotate(5deg);
}
.bsi-benefit-text h5 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 13px !important; font-weight: 800 !important;
    color: #F0BE55 !important; margin-bottom: 5px;
}
.bsi-benefit-text p { font-size: 12px; color: rgba(255,255,255,.65); line-height: 1.65; margin: 0; }

/* ── BOTTOM CTA ──────────────────────────────────────────── */
.bsi-franchise-cta {
    background: #fff;
    border-top: 3px solid #C4972A;
    border-bottom: 1px solid rgba(26,86,219,.1);
    padding: 40px 0;
}
.bsi-franchise-cta-inner {
    display: flex; align-items: center;
    justify-content: space-between; gap: 24px; flex-wrap: wrap;
}
.bsi-franchise-cta-text h3 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 24px !important; font-weight: 800 !important;
    color: #0F1B4C !important; margin: 0 0 6px;
}
.bsi-franchise-cta-text p { font-size: 14px; color: #4B5680; margin: 0; }

/* ── PARTNER MODAL ───────────────────────────────────────── */
.modal-content { border-radius: 10px !important; overflow: hidden !important; box-shadow: 0 24px 80px rgba(15,27,76,.2) !important; }
.modal-header { background: linear-gradient(160deg, #1239a6, #1a56db) !important; border-bottom: 2px solid #C4972A !important; padding: 16px 24px !important; }
.modal-title { color: #F0BE55 !important; font-weight: 800 !important; font-size: 13px !important; letter-spacing: .8px; text-transform: uppercase; }
.modal-header .btn-close { filter: invert(1) brightness(100%) !important; opacity: .6 !important; }
.partner-form .form-control:focus,
.partner-form .form-select:focus { border-color: #1a56db !important; box-shadow: 0 0 0 3px rgba(26,86,219,.1) !important; }
.partner-form .btn-primary { background: linear-gradient(135deg, #1239a6, #1a56db) !important; border: none !important; border-radius: 4px !important; font-weight: 800 !important; }
.partner-form .btn-primary:hover { background: linear-gradient(120deg, #C4972A, #F0BE55) !important; color: #0F1B4C !important; }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width: 1199px) {
    .bsi-metrics-inner { grid-template-columns: repeat(4, 1fr); }
    .bsi-metric-cta { grid-column: 5; }
    .bsi-faq-wrap { grid-template-columns: 1fr 280px; gap: 24px; }
}
@media(max-width: 991px) {
    .bsi-metrics-inner { grid-template-columns: repeat(2, 1fr); }
    .bsi-metric-cta { grid-column: 1 / -1; border-left: none; border-top: 1px solid rgba(196,151,42,.15); }
    .bsi-benefits-grid { grid-template-columns: repeat(2, 1fr); }
    .bsi-section-head h2 { font-size: 28px !important; }
    .bsi-faq-wrap { grid-template-columns: 1fr; gap: 24px; }
    .bsi-faq-cta { position: static; }
}
@media(max-width: 767px) {
    .bsi-metrics-inner { grid-template-columns: 1fr 1fr; }
    .bsi-metric-item { padding: 20px 14px; gap: 10px; }
    .bsi-metric-text h3 { font-size: 20px !important; }
    .bsi-metric-icon { width: 42px; height: 42px; }
    .bsi-metric-icon img { width: 20px; height: 20px; }
    .breadcrumb-wrapper .page-heading h1 { font-size: 28px !important; }
    .bsi-franchise-cta-inner { flex-direction: column; align-items: flex-start; }
    .bsi-section-head h2 { font-size: 24px !important; }
    .bsi-benefits-grid { grid-template-columns: 1fr; }
    .bsi-franchise-about { padding: 56px 0; }
    .bsi-about-img::before { display: none; }
    .bsi-model-section, .bsi-why-section, .bsi-benefits-section,
    .bsi-compare-section, .bsi-faq-section { padding: 56px 0; }
    .bsi-model-card { padding: 32px 22px 26px; }
    .bsi-model-icon { width: 72px; height: 72px; }
    .bsi-model-icon img { width: 32px; height: 32px; }

    /* FAQ mobile */
    .bsi-faq-btn { padding: 16px 16px; gap: 12px; font-size: 13px; }
    .bsi-faq-q-num { min-width: 36px; height: 36px; font-size: 11px; }
    .bsi-faq-q-text { font-size: 13px; }
    .bsi-faq-icon { width: 30px; height: 30px; font-size: 11px; }
    .bsi-faq-answer { padding: 16px 16px 20px 16px; font-size: 13px; }
    .bsi-faq-cta { padding: 26px 22px; }

    /* Comparison table mobile */
    .bsi-compare-table { min-width: 600px; }
    .bsi-compare-table thead th { padding: 16px 14px; font-size: 11px; }
    .bsi-compare-table tbody td { padding: 14px 14px; font-size: 12px; }
    .bsi-tick, .bsi-cross { width: 28px; height: 28px; font-size: 12px; }
}
@media(max-width: 575px) {
    .bsi-metrics-inner { grid-template-columns: 1fr 1fr; }
    .bsi-metric-item { padding: 16px 10px; }
    .bsi-metric-text h3 { font-size: 18px !important; }
    .bsi-partner-btn { width: 100%; justify-content: center; }
    .bsi-section-head.text-center h2::after { margin: 10px auto 0; }
}