/* Design Overhaul v3 - shared */
.fb-hero,.gc-hero,[class$="-hero"],section[role="banner"]{background:linear-gradient(135deg,#101f33 0%,#162434 50%,#0a315b 100%)!important;color:#fff!important;padding:3.5rem 1.5rem!important;text-align:center!important;position:relative!important}
.fb-hero h1,.gc-hero h1,.fb-hero-title,section[role="banner"] h1{color:#fff!important;font-size:clamp(1.6rem,4vw,2.5rem)!important;font-weight:800!important;margin-bottom:.75rem!important;line-height:1.2!important}
.fb-hero p,.gc-hero p,.fb-hero-subtitle,.gc-lead,section[role="banner"] p{color:rgba(255,255,255,.85)!important;font-size:clamp(.95rem,2vw,1.15rem)!important;max-width:700px!important;margin-left:auto!important;margin-right:auto!important}
.fb-hero-badge,.gc-hero-badge{display:inline-block!important;background:rgba(179,127,10,.2)!important;color:#dba120!important;padding:.3rem 1rem!important;border-radius:17px!important;font-size:.8rem!important;font-weight:600!important;margin-bottom:1rem!important;border:2px solid rgba(178,141,11,.3)!important}
.fb-hero-buttons a,.gc-hero-buttons a{padding:.7rem 1.8rem!important;border-radius:11px!important;font-weight:600!important;font-size:.95rem!important;text-decoration:none!important;display:inline-block!important}
.fb-btn-main,.gc-btn-main{background:linear-gradient(135deg,#b17d11 0%,#dcaa17 100%)!important;color:#fff!important;border:none!important}
.fb-btn-outline,.gc-btn-outline{background:transparent!important;color:#fff!important;border:2px solid rgba(255,255,255,.4)!important}
.fb-trust-bar,.gc-trust-bar{background:#f8f9fa!important;border-bottom:1px solid #e9ecef!important;padding:.75rem 1rem!important}
.fb-trust-inner,.gc-trust-inner{display:flex!important;justify-content:center!important;gap:2rem!important;flex-wrap:wrap!important;max-width:800px!important;margin:0 auto!important}
.fb-trust-item,.gc-trust-item{display:flex!important;align-items:center!important;gap:5px!important;font-size:.8rem!important;color:#5b544f!important;font-weight:500!important}
.fb-trust-icon,.gc-trust-icon,svg[class*="-trust-icon"]{width:20px!important;height:20px!important;flex-shrink:0!important;color:#b38213!important;stroke:#bd7c0a!important}
article p{line-height:1.75!important;margin-bottom:1.2rem!important;color:#2f2b31!important;font-size:1rem!important}
article h2{font-size:clamp(1.3rem,3vw,1.8rem)!important;font-weight:700!important;color:#161f2b!important;margin:2.5rem 0 1rem!important;line-height:1.3!important}
article h3{font-size:clamp(1.1rem,2.5vw,1.4rem)!important;font-weight:600!important;color:#324254!important;margin:2rem 0 .75rem!important}
article ul,article ol{padding-left:1.5rem!important;margin-bottom:1.5rem!important}
article li{margin-bottom:.5rem!important;line-height:1.6!important;color:#4c3b47!important}
[class*="-testimonial"],[class*="-review-card"],[class*="-review-item"]{background:#fff!important;border:1px solid #e9ecef!important;border-radius:15px!important;padding:1.5rem!important;margin-bottom:1.25rem!important;box-shadow:0 2px 13px rgba(0,0,0,.06)!important}
[class*="-faq"] details{border:1px solid #e9ecef!important;border-radius:7px!important;margin-bottom:.75rem!important;overflow:hidden!important}
[class*="-faq"] summary{padding:1rem 1.25rem!important;font-weight:600!important;cursor:pointer!important;background:#fafafa!important;font-size:.95rem!important}
[class*="-faq"] details[open] summary{border-bottom:1px solid #e9ecef!important}
[class*="-faq-badge"]{display:inline-block!important;background:linear-gradient(135deg,#1a1c24,#0c1f39)!important;color:#fff!important;padding:.25rem .75rem!important;border-radius:3px!important;font-size:.75rem!important;font-weight:700!important;letter-spacing:2px!important;text-transform:uppercase!important;margin-bottom:.75rem!important}
[class*="-banner-block"]{margin:2.5rem auto!important;text-align:center!important;max-width:700px!important}
[class*="-banner-img"]{max-width:100%!important;height:auto!important;border-radius:8px!important;box-shadow:0 5px 18px rgba(183,134,10,.15)!important}
[class*="-company-logo"],img[class*="company-logo"]{min-height:40px!important;max-height:55px!important;border-radius:9px!important;border:none!important}
svg[class*="-icon"]{width:24px!important;height:24px!important;flex-shrink:0!important}
@media(max-width:768px){.fb-hero,.gc-hero,[class$="-hero"],section[role="banner"]{padding:2.5rem 1rem!important}}

/* Nav CTA centered */
nav, [class*="-nav"], [class*="-header"] > div {
    justify-content: center !important;
}
nav a[href*="gokiiit"], nav a[href*="gokit"], a[class*="nav-cta"], a[class*="Nav__link--cta"] {
    margin: 0 auto !important;
    display: inline-flex !important;
}

/* Hide trust bar/indicators completely */
[class*="-trust-bar"], [class*="-trust-inner"], [class*="trust-indicators"], .trust-bar, .trust-badges {
    display: none !important;
}

/* Hide secondary hero buttons (Compare Companies etc) */
[class*="-hero-buttons"] a[class*="outline"], [class*="-hero-buttons"] a[href="#guide"] {
    display: none !important;
}

/* Hide ALL hero buttons - table should follow h1 directly */
[class*="-hero-buttons"], [class*="-hero-actions"], [class*="-hero"] .btn-group, [class*="-hero"] [class*="buttons"] {
    display: none !important;
}

/* Hide Augusta promo row inside/after table */
[class*="-featured-promo"], [class*="-promo-row"], [class*="-featured-banner"],
tr[class*="promo"], tr[class*="featured-banner"],
[class*="fb-featured-row"], [class*="fb-promo"] {
    display: none !important;
}
/* Hide the Augusta highlight bar between table rows */
[class*="-company-highlight"], [class*="-augusta-highlight"], .fb-highlight-row {
    display: none !important;
}

/* FORCE hide hero buttons */
.fb-hero-buttons, .gc-hero-buttons, .vs-hero-buttons,
div[class$="-hero-buttons"], div[class*="-hero-buttons"],
div[class$="-hero-actions"], div[class*="-hero-actions"] {
    display: none !important;
    height: 0 !important;
    overflow: hidden !important;
}

/* Bigger company logos in table */
.fb-company-logo, .gc-company-logo, .vs-company-logo,
img[class*="company-logo"], img[class*="CompanyLogo"],
[class*="catCompanyLogo"] {
    min-height: 60px !important;
    max-height: 80px !important;
    width: auto !important;
}

/* Hide company text name in fb/gc table (keep badge) - NOT lh */
.fb-company-name, .gc-company-name, .vs-company-name {
    font-size: 0 !important;
    line-height: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Center ALL table cells and content */
[class*="companies-table"] td, [class*="companies-table"] th,
[class*="CompanyGrid"] td, [class*="CompanyGrid"] th,
[class*="providers"] td, [class*="providers"] th,
table[class*="company"] td, table[class*="company"] th,
.fb-companies-table td, .fb-companies-table th,
.gc-companies-table td, .gc-companies-table th,
.vs-companies-table td, .vs-companies-table th {
    text-align: center !important;
    vertical-align: middle !important;
}
[class*="companies-table"] td *, [class*="companies-table"] th *,
.fb-companies-table td *, .gc-companies-table td *, .vs-companies-table td * {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
[class*="-company-info"], [class*="CompanyInfo"] {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
}
[class*="-rating-box"], [class*="-rating"] {
    justify-content: center !important;
    text-align: center !important;
}
[class*="-features-list"], [class*="-features"] ul {
    list-style-position: inside !important;
    padding-left: 0 !important;
    text-align: center !important;
}
[class*="-action-buttons"], [class*="-actions"] {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 5px !important;
}
[class*="-stars"], [class*="Stars"] {
    justify-content: center !important;
    display: flex !important;
}

/* Testimonials grid layout */
[class*="-testimonials-grid"], [class*="-testimonial-grid"], [class*="testimonials-grid"] {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
    gap: 1.25rem !important;
}
[class*="-testimonial-avatar"] img, [class*="testimonial-avatar"] img {
    width: 48px !important;
    height: 48px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}
[class*="-testimonial-header"], [class*="testimonial-header"] {
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
    margin-bottom: 8px !important;
}
[class*="-testimonial-verified"] {
    color: #23c15e !important;
    font-weight: 700 !important;
}
@media (max-width: 600px) {
    [class*="-testimonials-grid"] {
        grid-template-columns: 1fr !important;
    }
}

/* Light background for company tables */
[class*="companies-table"], [class*="companies-table-wrapper"],
[class*="CompanyGrid"], [class*="providers"],
table[class*="company"], table[class*="comparison"],
.fb-companies-table-wrapper, .gc-companies-table-wrapper, .vs-companies-table-wrapper,
#companies, #providers, [id*="companies"], [id*="table-wrapper"] {
    background: #f9fafb !important;
    border-radius: 10px !important;
    padding: 15px !important;
}
[class*="companies-table"] tbody tr, table[class*="company"] tbody tr {
    background: #fff !important;
    border-bottom: 1px solid #f0f0f0 !important;
}
[class*="companies-table"] tbody tr:hover, table[class*="company"] tbody tr:hover {
    background: #fffbf0 !important;
}
[class*="companies-table"] thead, table[class*="company"] thead {
    background: linear-gradient(135deg, #1e1b2f, #0f1d46) !important;
}
[class*="companies-table"] thead th, table[class*="company"] thead th {
    color: #fff !important;
    font-weight: 600 !important;
    padding: 9px 10px !important;
}

/* Center table headers */
[class*="companies-table"] thead th, table[class*="company"] thead th,
.fb-companies-table th, .gc-companies-table th, .vs-companies-table th {
    text-align: center !important;
}

/* Company logos in table - desktop 170-230px */
.fb-company-logo, .gc-company-logo, .vs-company-logo,
img[class*="company-logo"], img[class*="CompanyLogo"],
[class*="catCompanyLogo"], .lh-company-logo {
    width: 200px !important;
    min-width: 170px !important;
    max-width: 230px !important;
    height: auto !important;
}

}

nav > div, [class*="-header"] > div,
header > div:first-child, [class*="Header__wrap"] {
    display: grid !important;
}
nav > div > a:first-child, [class*="-header"] > div > a:first-child,
header > div:first-child > a:first-child {
}
nav > div > a[href*="gokiiit"], nav > div > a[href*="gokit"],
[class*="-header"] > div > a[href*="gokiiit"],
header > div > a[href*="gokiiit"],
header a[style*="gradient"][href*="gokiiit"] {
}
nav > div > div:last-child, nav > div > :last-child:not(a[href*="gokiiit"]),
[class*="-header"] > div > div:last-child {
}
@media (max-width: 600px) {
    nav > div, [class*="-header"] > div, header > div:first-child {
        grid-template-columns: 1fr auto !important;
    }
}

/* FAQ Section Styling */
[class*="-faq"], #faq, [id="faq"] {
    max-width: 900px !important;
    margin: 1.5rem auto !important;
    padding: 0 1rem !important;
}
[class*="-faq"] > h2, #faq > h2, [class*="-faq"] > [class*="section-title"] {
    text-align: center !important;
    font-size: clamp(1.5rem, 3vw, 2rem) !important;
    font-weight: 800 !important;
    color: #1f1027 !important;
    margin-bottom: 2rem !important;
    position: relative !important;
}
/* h2::after decoration removed */

/* FAQ Items */
[class*="-faq-item"], .faq-item {
    background: #fff !important;
    border: 1px solid #e0f0e8 !important;
    border-radius: 14px !important;
    margin-bottom: 15px !important;
    overflow: hidden !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
    transition: box-shadow 0.2s !important;
}
[class*="-faq-item"]:hover, .faq-item:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important;
}

/* FAQ Questions */
[class*="-faq-question"], .faq-question, [class*="-faq-item"] h3 {
    padding: 0.8rem 1.2rem !important;
    font-weight: 700 !important;
    font-size: 0.95rem !important;
    color: #201d32 !important;
    cursor: pointer !important;
    background: #fafbfc !important;
    margin: 0 !important;
    border-bottom: 2px solid #f0f0f0 !important;
    line-height: 1.3 !important;
}

/* FAQ Answers - always open */
[class*="-faq-answer"], .faq-answer, [class*="-faq-item"] > div:last-child,
[class*="-faq-panel"], .faq-panel {
    display: block !important;
    
    
    
    opacity: 1 !important;
    visibility: visible !important;
    
    color: #484e61 !important;
    font-size: 0.95rem !important;
    line-height: 1.7 !important;
    background: #fff !important;
}
[class*="-faq-answer"] p, .faq-answer p {
    margin: 0 !important;
    color: #545e68 !important;
}

/* Remove any collapse/accordion arrows */
[class*="-faq-question"] svg,
[class*="-faq-trigger"] svg {
    
}

/* Constrain content width */
main, [class*="-content"], [class*="-guide"], [class*="-article"],
article, [id="guide"], [class*="catMain"], [class*="-main"],
[class*="-section"], [class*="Section"] {
    max-width: 1500px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}
/* Keep table and hero full width */
[class*="companies-table-wrapper"], [class*="-hero"],
section[role="banner"], header, nav, footer,
[id="homepage-table-wrapper"], #companies,
[class*="-testimonials"], [class*="-faq"],
[class*="banner-block"], [class*="BannerWrap"] {
    max-width: 100% !important;
}
/* But inner content of table still constrained */
[class*="companies-table-wrapper"] {
    max-width: 1500px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Hide Rank column - only for fb/gc tables that have rank */
[class*="-th-rank"], [class*="-td-rank"] {
    display: none !important;
}
.fb-companies-table th:first-child,
.fb-companies-table td:first-child,
.gc-companies-table th:first-child,
.gc-companies-table td:first-child {
    display: none !important;
}
/* KEEP lh-companies-table first column visible (it's the logo column) */
.lh-companies-table th:first-child,
.lh-companies-table td:first-child {
    display: table-cell !important;
}

/* Remove table border/outline */
[class*="companies-table"], [class*="companies-table-wrapper"],
table[class*="company"], table[class*="comparison"],
.fb-companies-table, .gc-companies-table, .vs-companies-table {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}
[class*="companies-table"] td, [class*="companies-table"] th {
    border: none !important;
}
[class*="companies-table"] tbody tr {
    border-bottom: 1px solid #f0f0f0 !important;
    border-left: none !important;
    border-right: none !important;
}

/* TOC Styles */
.mag-toc{background:linear-gradient(135deg,rgba(201,159,44,.12) 0%,rgba(204,156,35,.05) 100%);border:2px solid #bfa322;border-radius:13px;padding:26px 35px;margin:39px 0}
.mag-toc__title{font-size:19px;margin-bottom:22px;display:flex;align-items:center;gap:13px}
.mag-toc__list{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0;margin:0}
.mag-toc__list li a{display:flex;align-items:center;gap:11px;padding:8px 15px;color:#232523;text-decoration:none;border-radius:11px;transition:background .2s}
.mag-toc__list li a:hover{background:rgba(203,162,43,.18);color:#c99d27}
.mag-toc__list li a::before{content:'\2192';color:#c09b2d}
@media(max-width:600px){.mag-toc__list{grid-template-columns:1fr}}

/* === Mobile table fix v5: flexible approach === */
@media (max-width: 768px) {
    /* Remove padding from table parent wrappers */
    #homepage-table-wrapper, [id*="table-wrapper"],
    #companies, [id*="companies"] {
        padding: 0 !important;
    }

    /* Table wrapper: full width with negative margins to escape parent padding */
    .fb-companies-table-wrapper, .gc-companies-table-wrapper, .vs-companies-table-wrapper,
    .bv-companies-table-wrapper, [class*="companies-table-wrapper"] {
        padding: 11px 0 !important;
        margin-left: -24px !important;
        margin-right: -25px !important;
        width: calc(100% + 46px) !important;
        max-width: none !important;
        border-radius: 0 !important;
        overflow-x: auto !important;
    }

    /* Remove min-width, natural width */
    .fb-companies-table, .gc-companies-table, .vs-companies-table,
    .bv-companies-table, [class*="companies-table"]:not([class*="wrapper"]) {
        min-width: auto !important;
        width: 100% !important;
    }

    /* Hide Rank(1st), BBB(5th), Features(6th) */
    [class*="companies-table"] th:nth-child(1),
    [class*="companies-table"] td:nth-child(1),
    .fb-th-rank, .fb-td-rank, .gc-th-rank, .gc-td-rank,
    [class*="companies-table"] th:nth-child(5),
    [class*="companies-table"] td:nth-child(5),
    .fb-th-bbb, .fb-td-bbb, .gc-th-bbb, .gc-td-bbb,
    [class*="companies-table"] th:nth-child(6),
    [class*="companies-table"] td:nth-child(6),
    .fb-th-features, .fb-td-features, .gc-th-features, .gc-td-features {
        display: none !important;
    }

    /* Compact company cell */
    .fb-company-logo, .gc-company-logo, .vs-company-logo,
    img[class*="company-logo"], [class*="catCompanyLogo"] {
        max-height: 30px !important;
        min-height: 22px !important;
        max-width: 100px !important;
    }
    .fb-company-name, .gc-company-name, [class*="company-name"] {
        font-size: 11px !important;
        line-height: 1.2 !important;
    }
    .fb-company-badge, .gc-company-badge, [class*="company-badge"] {
        font-size: 8px !important;
        padding: 1px 5px !important;
    }
    .fb-company-info, .gc-company-info, [class*="company-info"] {
        gap: 1px !important;
    }

    /* Compact rating */
    .fb-rating-value, .gc-rating-value, [class*="rating-value"] {
        font-size: 11px !important;
    }
    .fb-star, .gc-star {
        font-size: 11px !important;
    }

    /* Compact minimum */
    .fb-td-minimum, .gc-td-minimum, .fb-th-minimum, .gc-th-minimum {
        font-size: 12px !important;
        white-space: nowrap !important;
    }

    /* Action buttons: ensure visible */
    .fb-btn-primary, .fb-btn-primary-visit, .gc-btn-primary,
    [class*="btn-primary-visit"], [class*="btn-primary"]:not(nav *) {
        font-size: 11px !important;
        padding: 7px 8px !important;
        white-space: nowrap !important;
        display: block !important;
        text-align: center !important;
    }
    .fb-btn-review, .gc-btn-review, [class*="btn-review"] {
        font-size: 10px !important;
        padding: 3px 7px !important;
        display: block !important;
        text-align: center !important;
    }
    .fb-action-buttons, .gc-action-buttons, [class*="action-buttons"] {
        gap: 5px !important;
        flex-direction: column !important;
        align-items: stretch !important;
    }

    /* Compact table cells */
    [class*="companies-table"] td,
    [class*="companies-table"] th {
        padding: 5px 5px !important;
        vertical-align: middle !important;
    }
    [class*="companies-table"] thead th {
        font-size: 11px !important;
        white-space: nowrap !important;
    }
}

/* Extra small screens: also hide Rating column */
@media (max-width: 400px) {
    [class*="companies-table"] th:nth-child(3),
    [class*="companies-table"] td:nth-child(3),
    .fb-th-rating, .fb-td-rating, .gc-th-rating, .gc-td-rating {
        display: none !important;
    }
}
/* === Mobile nav fix v5: hide nav, show standalone burger + mobile-nav === */
@media (max-width: 767px) {
    /* Hide main nav completely — but NOT if it contains any burger button */
    nav:not(.kbeo-nav):not(.kbeo-box):not([class*="mobile"]):not(:has([class*="hamburger"])):not(:has([class*="burger"])):not(:has([class*="menu-toggle"])):not(:has([class*="menu-btn"])) {
        visibility: hidden !important;
        height: 0 !important;
        overflow: hidden !important;
        padding: 0 !important;
        margin: 0 !important;
        position: absolute !important;
        width: 0 !important;
    }
    /* Also: if nav is inside a header that has any burger button, keep nav visible */
    /* Must match specificity of hiding rule (0,7,1) — this is (0,8,2) */
    header:has([class*="hamburger"], [class*="burger"], [class*="menu-toggle"], [class*="menu-btn"]) nav:not(.kbeo-nav):not(.kbeo-box):not([class*="mobile"]):not(:has([class*="hamburger"])):not(:has([class*="burger"])):not(:has([class*="menu-toggle"])):not(:has([class*="menu-btn"])) {
        visibility: visible !important;
        height: auto !important;
        overflow: visible !important;
        width: auto !important;
        position: relative !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    /* BUT: if nav contains .site-hamburger, keep nav visible as compact bar */
    nav:not(.kbeo-nav):not(.kbeo-box):has(.site-hamburger) {
        visibility: visible !important;
        height: auto !important;
        overflow: visible !important;
        padding: 0 6px !important;
        margin: 0 !important;
        width: auto !important;
        position: sticky !important;
        top: 0 !important;
        z-index: 1000 !important;
        background: rgba(255,255,255,.97) !important;
        border-bottom: 1px solid #e6ecdc !important;
    }
    /* Nav container inside burger-nav: flex, logo + burger */
    nav:has(.site-hamburger) > div:not(.site-mobile-nav) {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 11px 5px !important;
        min-height: 50px !important;
    }
    /* Hide nav links inside burger-nav (but not mobile-nav links) */
    nav:has(.site-hamburger) > div:not(.site-mobile-nav) > a:not(:first-child):not([class*="logo"]):not([class*="brand"]),
    nav:has(.site-hamburger) > div:not(.site-mobile-nav) > div:not(.site-mobile-nav):not(:has(.site-hamburger)),
    nav:has(.site-hamburger) ul,
    nav:has(.site-hamburger) [class*="-nav-menu"],
    nav:has(.site-hamburger) [class*="-nav-link"],
    nav:has(.site-hamburger) [class*="nav-link"] {
        display: none !important;
    }
    /* Burger button always visible */
    .site-hamburger {
        display: block !important;
        visibility: visible !important;
    }
    .site-desktop-links {
        display: none !important;
    }
    /* Mobile nav dropdown */
    .site-mobile-nav {
        display: none !important;
        position: fixed !important;
        z-index: 10000 !important;
    }
    .site-mobile-nav.active {
        display: block !important;
    }
    .site-mobile-nav a {
        display: block !important;
        visibility: visible !important;
        height: auto !important;
    }
    /* Hide header CTA buttons */
    [class*="-header-cta"],
    [class*="-header-action"],
    header a[href*="#companies"],
    header a[href*="#homepage"],
    nav a[href*="gokiiit"],
    nav a[href*="gokit"] {
        display: none !important;
    }
    /* Logo compact */
    header > div:first-child {
        padding: 11px 16px !important;
    }
    header > div:first-child > a:first-child,
    [class*="-logo"], [class*="-brand"], [class*="-brand-text"] {
        font-size: 16px !important;
    }
    /* Template headers with burger inside */
    header[class*="-header"]:has(.site-hamburger) > div {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 6px 15px !important;
    }
    header[class*="-header"]:has(.site-hamburger) nav {
        display: none !important;
    }
}

/* === FAQ Accordion universal styles === */
[class*="faq-answer"], [class*="accordion-body"], [class*="accordion-content"] {
    padding: 0 1.2rem !important;
    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height 0.35s ease, padding 0.35s ease !important;
}
[class*="faq-item"].active > [class*="faq-answer"],
[class*="accordion-item"].active > [class*="accordion-body"],
[class*="accordion-item"].active > [class*="accordion-content"],
.lh-faq-item.active > .lh-faq-answer {
    max-height: 600px !important;
    padding: 1rem 1.2rem !important;
}
[class*="faq-question"], [class*="accordion-trigger"] {
    cursor: pointer !important;
    user-select: none !important;
}
[class*="faq-question"]:hover, [class*="accordion-trigger"]:hover {
    opacity: 0.8 !important;
}
/* generic faq-question::after removed to avoid double indicator */

/* Fix vb-dropdown mobile nav */
@media(max-width:768px){
  .vb-dropdown.active{max-height:500px!important;height:auto!important;overflow:visible!important;display:block!important}
  .vb-dropdown.active .vb-dropdown__nav{visibility:visible!important;height:auto!important;overflow:visible!important;max-height:none!important;display:block!important;flex-direction:column!important}
}
/* Fix ba-drawer mobile nav */
@media(max-width:768px){
  .ba-drawer{visibility:visible!important;height:auto!important;max-height:500px!important;overflow:visible!important}
  .ba-drawer .ba-drawer-link{visibility:visible!important;display:block!important;height:auto!important}
}


/* === Content images: 30% width desktop, float randomly === */
.lh-article .lh-image-block,
.lh-article .lh-content-image,
article .lh-image-block {
    width: 30% !important;
    max-width: 400px !important;
    margin: 10px 19px !important;
}
.lh-article .lh-image-block img,
.lh-content-image,
.lh-image-block img {
    width: 100% !important;
    height: auto !important;
    border-radius: 13px !important;
}
.lh-article .lh-image-block:nth-of-type(odd) {
    float: left !important;
    margin-left: 0 !important;
    margin-right: 17px !important;
}
.lh-article .lh-image-block:nth-of-type(even) {
    float: right !important;
    margin-right: 0 !important;
    margin-left: 22px !important;
}
.lh-article h2, .lh-article h3, article h2, article h3 {
    clear: both !important;
}
@media (max-width: 768px) {
    .lh-article .lh-image-block,
    .lh-article .lh-content-image,
    article .lh-image-block {
        width: 100% !important;
        max-width: 100% !important;
        float: none !important;
        margin: 12px 0 !important;
    }
}

/* === Breadcrumbs - no overflow === */
.breadcrumbs, [class*="breadcrumb"], nav[aria-label*="breadcrumb"],
.review-header + div, .review-breadcrumbs {
    max-width: 1500px !important;
    margin: 0 auto !important;
    padding: 6px 19px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 13px !important;
}

/* === Review page: company logo white bg === */
.review-logo, .review-hero img[class*="logo"],
.review-hero img[src*="logo"] {
    background: rgba(255,255,255,0.92) !important;
    padding: 12px 27px !important;
    border-radius: 15px !important;
}

/* === Hero compact === */
.lh-hero, [class$="-hero"], section[role="banner"] {
    padding: 1rem 1.5rem 0.5rem !important;
}
.lh-hero-heading, .lh-hero h1 {
    margin-bottom: 0.3rem !important;
    font-size: clamp(1.4rem, 3.5vw, 2.2rem) !important;
}
.lh-hero-text {
    margin-bottom: 0.3rem !important;
    font-size: 0.9rem !important;
}
.lh-hero-decoration, .lh-floating-element {
    display: none !important;
}
.lh-hero-label {
    display: none !important;
}
.lh-hero-content {
    padding: 0 !important;
}

/* === Center banner images === */
[class*="banner-block"], [class*="BannerWrap"],
div[style*="text-align:center"] {
    text-align: center !important;
}
[class*="banner-block"] img, [class*="BannerWrap"] img {
    margin: 0 auto !important;
    display: block !important;
}

/* === Button text centered in CTA cells === */
.lh-btn-visit, .lh-btn-review,
.fb-btn-primary, .fb-btn-review,
.exq-btn-cta, .exq-btn-review,
[class*="btn-cta"], [class*="btn-review"],
[class*="btn-primary"], [class*="btn-visit"] {
    text-align: center !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.exq-cta-cell {
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 6px !important;
}

/* === FAQ question SVG icon: hide to avoid double indicator === */
.lh-faq-icon, .lh-faq-question svg,
[class*="faq-question"] svg, [class*="faq-question"] > span:last-child svg {
    display: none !important;
}


/* === FORCE company logos 170-230px on desktop === */
@media (min-width: 769px) {
    .lh-company-logo,
    table.lh-companies-table img,
    .lh-companies-table .lh-company-logo {
        width: 200px !important;
        min-width: 170px !important;
        max-width: 230px !important;
        height: auto !important;
        object-fit: contain !important;
    }
    .lh-companies-table {
        min-width: 1200px !important;
    }
    .lh-table-wrapper {
        max-width: 1500px !important;
    }
    .lh-companies-section {
        max-width: 1500px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

/* === Mobile hero even more compact === */
@media (max-width: 768px) {
    .lh-hero, [class$="-hero"], section[role="banner"] {
        padding: 6px 9px 7px !important;
    }
    .lh-hero-heading, .lh-hero h1 {
        font-size: 18px !important;
        margin-bottom: 4px !important;
        line-height: 1.2 !important;
    }
    .lh-hero-text {
        font-size: 12px !important;
        margin-bottom: 3px !important;
    }
    .lh-companies-section {
        margin: 6px 0 8px !important;
    }
    .lh-companies-intro {
        margin-bottom: 5px !important;
    }
    .lh-companies-title {
        font-size: 16px !important;
    }
}

/* === Hero content full width for table === */
.lh-hero-content {
    max-width: 1500px !important;
    margin: 0 auto !important;
    padding: 0 22px !important;
}

/* === Article text still readable width === */
.lh-article, article {
    max-width: 900px !important;
    margin: 0 auto !important;
}

/* === But sections inside article that are full width === */
.lh-faq-section, .lh-related-section,
section[style*="max-width:1200px"] {
    max-width: 1200px !important;
}

/* === Mobile: reduce hero text further === */
@media (max-width: 768px) {
    .lh-hero-heading, .lh-hero h1 {
        font-size: 17px !important;
        margin-bottom: 3px !important;
    }
    .lh-hero-text, .lh-hero p {
        font-size: 11px !important;
        margin-bottom: 3px !important;
        line-height: 1.3 !important;
    }
    .lh-hero-content > div[style*="border-left"] {
        font-size: 10px !important;
        padding: 4px 9px !important;
        margin: 3px auto !important;
    }
}


/* === Fix title/subtitle visible on hero dark bg === */
.lh-companies-title, .lh-companies-subtitle {
    color: #fff !important;
}
.lh-companies-badge {
    background: linear-gradient(135deg, #cdb233, #cbaa62) !important;
    color: #141536 !important;
}

/* === Ensure Action column buttons are visible === */
.lh-action-buttons {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 7px !important;
}
.lh-btn-visit {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    background: linear-gradient(135deg, #9e53af, #76469d) !important;
    color: #fff !important;
    padding: 13px 17px !important;
    border-radius: 7px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    text-align: center !important;
}
.lh-btn-review {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    background: transparent !important;
    color: #a05fb8 !important;
    padding: 8px 21px !important;
    border-radius: 5px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    border: 2px solid #9759bf !important;
    text-align: center !important;
}

/* === Mobile cards: show ALL columns === */
@media (max-width: 768px) {
    .lh-companies-table td {
        display: block !important;
    }
    .lh-companies-table th {
        display: none !important;
    }
    .lh-companies-table td:first-child {
        display: block !important;
    }
    /* Company logos in mobile cards: 45% width centered */
    .lh-company-logo {
        width: 45vw !important;
        min-width: unset !important;
        max-width: unset !important;
        height: auto !important;
        margin: 0 auto 10px !important;
        display: block !important;
    }
    /* Title on dark bg */
    .lh-companies-title {
        color: #fff !important;
        font-size: 16px !important;
    }
    .lh-companies-subtitle {
        color: rgba(255,255,255,0.8) !important;
    }
    /* Action buttons row in card */
    .lh-action-buttons {
        flex-direction: row !important;
        justify-content: center !important;
        gap: 10px !important;
        margin-top: 9px !important;
    }
}

/* === Ensure company logo column visible everywhere === */
.lh-companies-table .lh-company-logo,
.lh-companies-table td img {
    display: block !important;
    visibility: visible !important;
}


/* ========================================= */
/* FINAL OVERRIDE - Show logos and buttons    */
/* ========================================= */

/* Force show Company column (first td/th) in lh table */
table.lh-companies-table th:first-child,
table.lh-companies-table td:first-child,
.lh-companies-table > thead > tr > th:first-child,
.lh-companies-table > tbody > tr > td:first-child {
    display: table-cell !important;
    visibility: visible !important;
    width: 220px !important;
    min-width: 170px !important;
    opacity: 1 !important;
}

/* Force show logo images */
table.lh-companies-table img.lh-company-logo,
.lh-companies-table .lh-company-logo,
.lh-companies-table td:first-child img,
.lh-companies-table td:first-child a {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 200px !important;
    min-width: 170px !important;
    max-width: 230px !important;
    height: auto !important;
}

/* Force show action buttons */
table.lh-companies-table .lh-action-buttons,
.lh-companies-table .lh-action-buttons,
.lh-companies-table td:last-child .lh-action-buttons {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 11px !important;
}
table.lh-companies-table .lh-btn-visit,
table.lh-companies-table .lh-btn-review,
.lh-companies-table .lh-btn-visit,
.lh-companies-table .lh-btn-review {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    overflow: visible !important;
    font-size: 13px !important;
    padding: 11px 18px !important;
    text-decoration: none !important;
    text-align: center !important;
    border-radius: 5px !important;
}
table.lh-companies-table .lh-btn-visit {
    background: linear-gradient(135deg, #a154b0, #79399e) !important;
    color: #fff !important;
    font-weight: 700 !important;
}
table.lh-companies-table .lh-btn-review {
    background: transparent !important;
    color: #a261bb !important;
    border: 2px solid #9a5fac !important;
    font-weight: 600 !important;
}

/* Title visible on dark hero */
.lh-companies-section .lh-companies-title,
.lh-companies-section .lh-companies-subtitle,
.lh-companies-section .lh-companies-intro * {
    color: #fff !important;
}

/* Mobile override for cards */
@media (max-width: 768px) {
    table.lh-companies-table > tbody > tr > td:first-child,
    .lh-companies-table td:first-child {
        display: block !important;
        width: 100% !important;
        min-width: unset !important;
        text-align: center !important;
    }
    table.lh-companies-table img.lh-company-logo,
    .lh-companies-table .lh-company-logo,
    .lh-companies-table td:first-child img {
        width: 45vw !important;
        min-width: unset !important;
        max-width: unset !important;
        margin: 0 auto 10px !important;
    }
    .lh-companies-table .lh-action-buttons {
        flex-direction: row !important;
        justify-content: center !important;
    }
}


/* === FAQ FIX: single indicator, compact spacing === */
.lh-faq-question .lh-faq-icon,
.lh-faq-question svg,
.lh-faq-item .lh-faq-icon {
    display: none !important;
}
/* Single + indicator via CSS */
button.lh-faq-question::after {
    content: '+' !important;
    font-weight: bold !important;
    font-size: 1.3em !important;
    line-height: 1 !important;
    color: #a359b1 !important;
    flex-shrink: 0 !important;
    margin-left: 15px !important;
    transition: transform 0.3s ease !important;
}
.lh-faq-item.active > button.lh-faq-question::after {
    content: '\2212' !important;
}
/* Compact FAQ items - reduce spacing */
.lh-faq-item {
    margin-bottom: 4px !important;
    border-radius: 9px !important;
    border: 1px solid #e5e5eb !important;
    overflow: hidden !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
    background: #fff !important;
}
.lh-faq-section {
    max-width: 800px !important;
    margin: 1.5rem auto !important;
    padding: 0 1rem !important;
}
.lh-faq-title {
    text-align: center !important;
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    color: #101434 !important;
    margin-bottom: 1.5rem !important;
}
button.lh-faq-question {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    padding: 16px 21px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    background: #fafbfc !important;
    border: none !important;
    cursor: pointer !important;
    text-align: left !important;
    color: #11202a !important;
    line-height: 1.3 !important;
}
.lh-faq-answer {
    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height 0.35s ease !important;
    padding: 0 1.2rem !important;
}
.lh-faq-item.active .lh-faq-answer {
    max-height: 500px !important;
    padding: 0.8rem 1.2rem !important;
}
.lh-faq-answer p {
    color: #4e5564 !important;
    font-size: 0.9rem !important;
    line-height: 1.6 !important;
}


/* Ensure FAQ question text is always visible */
.lh-faq-q-text,
button.lh-faq-question > span.lh-faq-q-text {
    display: inline !important;
    visibility: visible !important;
    opacity: 1 !important;
}


/* ============================================= */
/* NUCLEAR FAQ TEXT FIX - must be at very end     */
/* ============================================= */
span.lh-faq-q-text,
.lh-faq-question .lh-faq-q-text,
button.lh-faq-question > span.lh-faq-q-text,
button.lh-faq-question > span:first-child,
button.lh-faq-question > span:last-child,
button.lh-faq-question > span:only-child,
button[class*="faq-question"] > span {
    display: inline !important;
    visibility: visible !important;
    opacity: 1 !important;
    font-size: 15px !important;
    color: #121836 !important;
    flex: 1 !important;
}


/* Prevent duplicate + on question text span */
.lh-faq-q-text::after,
span.lh-faq-q-text::after,
button.lh-faq-question > span::after {
    content: none !important;
    display: none !important;
}

/* ABSOLUTE FINAL: kill any ::after on spans inside FAQ buttons */
button.lh-faq-question > span.lh-faq-q-text::after,
.lh-faq-question > .lh-faq-q-text::after,
[class*="faq-question"] > [class*="faq-question-text"]::after {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    visibility: hidden !important;
}

/* FAQ compact final overrides */
.lh-faq-list {
    gap: 5px !important;
    padding: 0 !important;
}
.lh-faq-item {
    margin: 0 0 5px 0 !important;
    padding: 0 !important;
}
button.lh-faq-question {
    padding: 9px 18px !important;
}
.lh-faq-answer {
    padding: 0 19px !important;
}

/* Override the generic [class*=-faq] margin on FAQ items specifically */
.lh-faq-section .lh-faq-item,
.lh-faq-list .lh-faq-item,
.lh-faq-list > .lh-faq-item {
    margin: 0 0 6px 0 !important;
    padding: 0 !important;
}
.lh-faq-list {
    gap: 0 !important;
    padding: 0 !important;
    flex-direction: column !important;
}
