/* homepage.css - V28 - DEFINITIVE TOOLTIP Z-INDEX FIX */

:root { --blue-darkest: #002a45; --blue-primary: #00529b; --gray-900: #1a202c; --gray-700: #4a5568; --gray-500: #a0aec0; --gray-300: #e2e8f0; --gray-100: #f7fafc; --white: #ffffff; --accent-gold: #ffc107; --accent-red: #D32F2F; --radius: 3px; --font-sans: 'Lato', -apple-system, sans-serif; --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05); --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1); --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1); }
html { scroll-behavior: smooth; }
body.bq-headless-page { font-family: var(--font-sans); color: var(--gray-700); background-color: var(--white); margin: 0; font-size: 16px; font-weight: 400; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body.mobile-nav-open { overflow: hidden; }
.bq-container { max-width: 1600px; margin: 0 auto; padding: 0 24px; }

/* --- SCOPED BUTTON STYLES --- */
.bq-button { display: inline-block; padding: 10px 22px; border-radius: 1px !important; font-weight: 600; text-decoration: none; transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.2s ease-in-out; cursor: pointer; border: 1px solid transparent; font-size: 15px; text-align: center; }
.bq-header__actions .bq-button--primary { background-color: var(--white); color: var(--blue-darkest); font-weight: 400; }
.bq-header__actions .bq-button--primary:hover { background-color: var(--gray-300); }
.bq-header__actions .bq-button--secondary { background-color: transparent; border-color: rgba(255, 255, 255, 0.3); color: var(--white); font-weight:400; }
.bq-header__actions .bq-button--secondary:hover { background-color: rgba(255, 255, 255, 0.1); }
.bq-pricing-card .bq-button--primary { background-color: var(--blue-primary); color: var(--white); }
.bq-pricing-card .bq-button--primary:hover { background-color: #00417a; }
.bq-pricing-card .bq-button--secondary { background-color: var(--white); color: var(--gray-900); border-color: var(--gray-300); }
.bq-pricing-card .bq-button--secondary:hover { background-color: var(--gray-100); }
.bq-pricing-card__cta .bq-button { display: block; width: 100%; text-align: left; box-sizing: border-box; }
.bq-mobile-nav__actions .bq-button { width: 100%; box-sizing: border-box; }
.bq-mobile-nav__actions .bq-button--primary { background-color: var(--blue-primary); color: var(--white); }
.bq-mobile-nav__actions .bq-button--primary:hover { background-color: #00417a; }
.bq-mobile-nav__actions .bq-button--secondary { background-color: var(--white); color: var(--gray-900); border-color: var(--gray-300); }
.bq-mobile-nav__actions .bq-button--secondary:hover { background-color: var(--gray-100); }

h1, h2, h3 { font-weight: 600; }
h1 { font-size: 40px; } h2 { font-size: 28px; }

/* --- HEADER & FONT WEIGHT FIX --- */
#bq-main-header { 
    height: 54px; 
    display: flex; 
    align-items: center; 
    position: sticky; 
    top: 0; 
    z-index: 1000;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1); 
    background-color: var(--blue-darkest); 
}
#bq-main-header .bq-header__container { display: flex; justify-content: space-between; align-items: center; width: 100%; }
#bq-main-header .bq-header__logo img { height: 28px; display: block; }
#bq-main-header .bq-header__nav { display: none; align-items: center; gap: 32px; height: 100%; }
#bq-main-header .bq-header__nav a { color: var(--gray-300); text-decoration: none; font-weight: 400; transition: color 0.2s ease; font-size: 15px; }
#bq-main-header .bq-header__nav a:hover { color: var(--white); }
#bq-main-header .bq-nav__dropdown { position: relative; height: 100%; display: flex; align-items: center; }
#bq-main-header .bq-nav__dropdown { padding-bottom: 15px; margin-bottom: -15px; }
#bq-main-header .bq-nav__dropdown > a { display: flex; align-items: center; gap: 6px; }
#bq-main-header .bq-nav__dropdown > a svg { height: 1em; width: 1em; transition: transform 0.2s ease; }
#bq-main-header .bq-nav__dropdown:hover > a svg { transform: rotate(180deg); }
#bq-main-header .bq-dropdown__content { display: none; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); background-color: var(--white); box-shadow: var(--shadow-lg); border-radius: var(--radius); padding: 8px; min-width: 240px; z-index: 10; border: 1px solid var(--gray-300); }
#bq-main-header .bq-nav__dropdown:hover .bq-dropdown__content { display: block; }
#bq-main-header .bq-dropdown__content a { display: block; padding: 10px 15px; color: var(--gray-900); border-radius: var(--radius); font-size: 14px; font-weight: 400; }
#bq-main-header .bq-dropdown__content a:hover { background-color: var(--gray-100); color: var(--gray-900); }
#bq-main-header .bq-header__actions { display: none; gap: 12px; }
#bq-main-header .bq-header__mobile-toggle { display: block; background: none; border: none; color: var(--white); cursor: pointer; padding: 0; }
#bq-main-header .bq-header__mobile-toggle svg { height: 20px; display: block; }

/* --- MOBILE NAVIGATION --- */
.bq-mobile-nav__overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 1001; opacity: 0; visibility: hidden; transition: opacity 0.3s ease, visibility 0s 0.3s; }
.bq-mobile-nav { position: fixed; top: 0; right: 0; bottom: 0; width: 300px; background-color: var(--white); z-index: 1002; transform: translateX(100%); transition: transform 0.3s ease; display: flex; flex-direction: column; box-shadow: var(--shadow-lg); }
.bq-mobile-nav.is-open { transform: translateX(0); }
.bq-mobile-nav__overlay.is-open { opacity: 1; visibility: visible; transition: opacity 0.3s ease, visibility 0s; }
.bq-mobile-nav__header { display: flex; justify-content: flex-end; align-items: center; padding: 0 20px; height: 54px; border-bottom: 1px solid var(--gray-300); }
.bq-mobile-nav__header-title { font-size: 12px; font-weight: 600; color: var(--gray-500); text-transform: uppercase; margin-right: auto; padding-left: 10px; }
.bq-mobile-nav__close { font-size: 30px; background: none; border: none; cursor: pointer; color: var(--gray-700); padding: 0; line-height: 1; }
.bq-mobile-nav__links { display: flex; flex-direction: column; padding: 20px 0; overflow-y: auto; flex-grow: 1; }
.bq-mobile-nav__links a { color: var(--gray-900); text-decoration: none; font-size: 16px; padding: 12px 30px; }
.bq-mobile-nav__links a:hover { background-color: var(--gray-100); }
.bq-mobile-nav__links .bq-mobile-nav__title { font-size: 12px; text-transform: uppercase; color: var(--gray-500); padding: 12px 30px 5px; margin: 35px 0 0; font-weight: 600; }
.bq-mobile-nav__links .bq-mobile-nav__title:first-child { margin-top: 0; }
.bq-mobile-nav__actions { padding: 20px; margin-top: auto; display: flex; flex-direction: column; gap: 10px; border-top: 1px solid var(--gray-300); }

/* --- HERO & OTHER SECTIONS --- */
.bq-hero { background-color: var(--blue-darkest); padding: 120px 0; text-align: center; }
.bq-hero__title { margin: 0 0 20px; line-height: 1.2; color: var(--white); }
.bq-hero__subtitle { font-size: 18px; max-width: 750px; margin: 0 auto 40px; color: var(--gray-300); line-height: 1.6; }
.bq-ticker-search-wrapper { max-width: 650px; margin: 0 auto; }
.bq-ticker-search { position: relative; width: 100%; }
.bq-search-icon { position: absolute; top: 50%; transform: translateY(-50%); left: 20px; color: var(--gray-500); height: 18px; }
.bq-ticker-search__input { width: 100%; padding: 18px 20px 18px 55px; font-size: 16px; border: 1px solid var(--gray-300); border-radius: var(--radius); box-shadow: var(--shadow-sm); transition: border-color 0.3s, box-shadow 0.3s; font-family: var(--font-sans); box-sizing: border-box; }
.bq-ticker-search__input:focus { outline: none; border-color: var(--blue-primary); box-shadow: 0 0 0 3px rgba(0, 82, 155, 0.2); }
.bq-popular-tickers { margin-top: 24px; display: flex; justify-content: center; align-items: center; gap: 8px; font-size: 14px; flex-wrap: wrap; }
.bq-popular-tickers span { color: var(--gray-300); font-weight: 500; }
.bq-popular-tickers a { color: var(--white); text-decoration: none; padding: 5px 12px; background-color: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 30px; transition: all 0.2s ease; }
.bq-popular-tickers a:hover { background-color: rgba(255, 255, 255, 0.2); border-color: rgba(255, 255, 255, 0.4); }
.bq-seen-in { padding: 20px 0; background-color: var(--white); border-bottom: 1px solid var(--gray-300); text-align: center; color: var(--gray-500); font-size: 14px; }
.bq-logo-carousel { overflow: hidden; position: relative; width: 100%; -webkit-mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent); mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent); margin-top: 30px; }
.bq-logo-track { display: flex; width: fit-content; }
.bq-logo-slide { flex-shrink: 0; width: 250px; display: flex; justify-content: center; align-items: center; }
.bq-logo-slide img { height: 28px; width: auto; max-width: 150px; object-fit: contain; filter: grayscale(100%); opacity: 0.7; }
.bq-section { padding: 100px 0; }
.bq-section-header { text-align: center; max-width: 700px; margin: 0 auto 60px; }
.bq-section-header h2 { margin: 0 0 15px; color: var(--gray-900); }
.bq-section-header p { line-height: 1.6; margin: 0; }
.bq-features__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.bq-feature-card { border: 1px solid transparent; background-clip: padding-box; border-radius: var(--radius); padding: 30px; transition: all 0.2s ease-in-out; text-decoration: none; }
.bq-feature-card:hover { border-color: var(--blue-primary); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.bq-feature-card__icon { height: 24px; margin-bottom: 20px; }
.bq-feature-card__icon svg { height: 100%; color: var(--gray-900); }
.bq-feature-card:nth-child(6n+1) { background-color: #f8fbff; } .bq-feature-card:nth-child(6n+2) { background-color: #f8fff8; } .bq-feature-card:nth-child(6n+3) { background-color: #fffaf4; } .bq-feature-card:nth-child(6n+4) { background-color: #fdf8ff; } .bq-feature-card:nth-child(6n+5) { background-color: #f5fffe; } .bq-feature-card:nth-child(6n+6) { background-color: #fff5f8; }
.bq-feature-card h3 { font-size: 18px; color: var(--gray-900); margin: 0 0 10px; }
.bq-feature-card p { font-size: 15px; line-height: 1.6; color: var(--gray-700); margin: 0; }

/* --- PRICING & COUNTDOWN --- */
.bq-pricing { background-color: #f7f7f7; }
.bq-pricing__inner-container { max-width: 1200px; margin: 0 auto; }
.bq-pricing-controls { display: flex; flex-direction: column; align-items: center; gap: 50px; margin-bottom: 50px; }
.bq-countdown { text-align: center; }
.bq-countdown p { margin: 0 0 12px; font-size: 18px; font-weight: 600; color: var(--accent-red); }
.bq-countdown__blocks { display: flex; justify-content: center; gap: 10px; }
.bq-countdown .time-block { display: flex; flex-direction: column; align-items: center; background: var(--white); border: 1px solid var(--gray-300); padding: 8px 12px; border-radius: var(--radius); min-width: 60px; }
.bq-countdown .time-block span { font-size: 24px; font-weight: 600; color: var(--gray-900); line-height: 1; }
.bq-countdown .time-block small { font-size: 10px; text-transform: uppercase; color: var(--gray-500); margin-top: 4px; }
.bq-pricing-toggle { display: flex; align-items: center; gap: 12px; }
.bq-pricing-toggle .toggle-label { font-size: 16px; font-weight: 500; color: var(--gray-500); transition: color .3s ease; cursor: pointer; }
.bq-pricing-toggle .toggle-label.active { color: var(--gray-900); font-weight: 600; }
.bq-pricing-toggle__switch { position: relative; display: inline-block; width: 52px; height: 28px; }
.bq-pricing-toggle__switch input { opacity: 0; width: 0; height: 0; }
.bq-pricing-toggle__slider { position: absolute; cursor: pointer; inset: 0; background-color: var(--gray-300); border-radius: 34px; transition: .4s; }
.bq-pricing-toggle__slider:before { position: absolute; content: ""; height: 22px; width: 22px; left: 3px; bottom: 3px; background-color: white; border-radius: 50%; transition: .4s; }
input:checked + .bq-pricing-toggle__slider { background-color: var(--blue-primary); }
input:checked + .bq-pricing-toggle__slider:before { transform: translateX(24px); }
.bq-pricing-toggle__badge { background: var(--accent-gold); color: var(--gray-900); font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 10px; margin-left: 6px; }
.bq-pricing-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; align-items: stretch; }
.bq-pricing-card { display: flex; flex-direction: column; background-color: var(--white); border: 1px solid var(--gray-300); border-radius: var(--radius); overflow: visible; }
.bq-pricing-card--featured { border: 2px solid var(--blue-primary); position: relative; }
.bq-pricing-card__badge { position: absolute; top: 0; left: 50%; transform: translateX(-50%) translateY(-50%); background: var(--blue-primary); color: var(--white); font-size: 13px; font-weight: 600; padding: 6px 18px; border-radius: 4px; white-space: nowrap; }
.bq-pricing-card__header { padding: 30px; text-align: center; }
.bq-pricing-card h3 { font-size: 20px; font-weight: 600; margin: 0 0 8px; color: var(--gray-900); }
.bq-pricing-card__header > p { font-size: 15px; color: var(--gray-700); margin: 0; }
.bq-pricing-card__price { font-size: 26px; font-weight: 600; color: var(--gray-900); margin: 30px 0 5px; line-height: 1; }
.bq-pricing-card__price sup { font-size: 18px; font-weight: 500; top: -0.6em; }
.bq-pricing-card__price small { font-size: 16px; font-weight: 400; color: var(--gray-500); }
.billing-note { font-size: 13px; color: var(--gray-500); height: 18px; margin: 0; }
.bq-pricing-card__content-wrapper { display: flex; flex-direction: column; flex-grow: 1; }
.bq-pricing-card__body { padding: 30px; border-top: 1px solid var(--gray-300); display: flex; flex-direction: column; flex-grow: 1; }
.bq-pricing-card__features { list-style: none; padding: 0; margin: 0 0 30px; text-align: left; flex-grow: 1; }
.bq-pricing-card__features li { 
    margin-bottom: 15px; 
    display: flex; 
    align-items: center;
    gap: 12px; 
    font-size: 15px; 
    line-height: 1.5;
    contain: layout;
}
.bq-pricing-card__cta { margin-top: auto; }
.bq-tick-icon, .bq-cross-icon { height: 1em; width: 1em; margin-top: 0; flex-shrink: 0; }
.bq-tick-icon { color: var(--blue-primary); } 
.bq-cross-icon { color: var(--gray-500); }

/* --- TOOLTIP STYLES --- */
.bq-tooltip { position: relative; display: inline-flex; cursor: help; align-items: center; }
.bq-tooltip-icon { height: 1em; width: 1em; color: var(--gray-500); }

/* The original tooltip text is now ONLY a data source for JS and should be hidden */
.bq-tooltip__text { display: none !important; }

/* ADDED: Styles for the new global tooltip element created by JS */
#bq-global-tooltip {
    display: none; /* Hidden by default */
    position: absolute;
    background-color: var(--white);
    color: var(--gray-900);
    border: 1px solid var(--gray-300);
    text-align: left;
    border-radius: var(--radius);
    padding: 12px;
    z-index: 500; /* High enough to be on top of table content, but below main header */
    font-size: 13px;
    line-height: 1.5;
    box-shadow: var(--shadow-md);
    transition: opacity 0.2s;
    pointer-events: none; /* Prevent the tooltip from interfering with mouse events */
}
#bq-global-tooltip::after {
    content: "";
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 5px;
    border-style: solid;
    border-color: transparent transparent var(--white) transparent;
}


/* --- REVIEWS CAROUSEL --- */
.bq-reviews__outer-wrapper { position: relative; max-width: 1200px; margin: 0 auto; }
.bq-reviews__carousel-wrapper { overflow-x: auto; -webkit-mask-image: none; mask-image: none; scrollbar-width: none; }
.bq-reviews__carousel-wrapper::-webkit-scrollbar { display: none; }
.bq-reviews__carousel { display: flex; width: -moz-fit-content; width: fit-content; }
.bq-review-card { flex-shrink: 0; width: 380px; margin: 20px 10px; background: #fbfbfb; border: 1px solid #e7e7e7; border-radius: var(--radius); padding: 30px; position: relative; display: flex; flex-direction: column; box-sizing: border-box; }
.bq-review-card__text { font-size: 15px; font-style: italic; color: var(--gray-700); line-height: 1.6; margin: 0 0 20px; flex-grow: 1; }
.bq-review-card__author { font-size: 14px; font-weight: 600; color: var(--gray-900); text-align: right; }

/* --- CAROUSEL NAVIGATION STYLES --- */
.bq-carousel__nav { display: flex; position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; background-color: var(--white); border: 1px solid var(--gray-300); border-radius: 50%; width: 44px; height: 44px; cursor: pointer; box-shadow: var(--shadow-md); transition: all 0.2s ease; align-items: center; justify-content: center; color: var(--gray-700); }
.bq-carousel__nav svg { height: 16px; }
.bq-carousel__nav:hover { background-color: var(--gray-100); color: var(--gray-900); }
.bq-carousel__nav--prev { left: -22px; }
.bq-carousel__nav--next { right: -22px; }

/* --- FOOTER --- */
.bq-footer { background-color: var(--blue-darkest); color: var(--gray-500); padding: 80px 0 30px; font-size: 15px; }
.bq-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; padding-bottom: 50px; }
.bq-footer__col img { height: 35px; margin-bottom: 20px; }
.bq-footer__col p { line-height: 1.6; max-width: 300px; margin: 0 0 20px; }
.bq-footer__col h4 { color: var(--white); font-size: 16px; font-weight: 600; margin: 0 0 20px; }
.bq-footer__col a { display: block; color: var(--gray-500); text-decoration: none; margin-bottom: 12px; transition: color 0.2s ease; }
.bq-footer__col a:hover { color: var(--white); }
.bq-footer__socials { display: flex; gap: 20px; }
.bq-footer__socials svg { height: 20px; }
.bq-footer__bottom { padding-top: 30px; text-align: center; font-size: 14px; border-top: 1px solid #1a3c53; }

/* --- RESPONSIVE STYLES --- */
@media (min-width: 1025px) { 
    #bq-main-header .bq-header__nav, #bq-main-header .bq-header__actions { display: flex; } 
    #bq-main-header .bq-header__mobile-toggle { display: none; } 
}

@media (max-width: 1024px) { 
    .bq-features__grid { grid-template-columns: repeat(2, 1fr); } 
    .bq-pricing-cards { grid-template-columns: 1fr; } 
    .bq-pricing__inner-container { max-width: 450px; } 
    h1.bq-hero__title { font-size: 40px; } 
    h2 { font-size: 28px; } 
}

@media (max-width: 767px) { 
    .bq-section { padding: 60px 0; } 
    h1.bq-hero__title { font-size: 32px; } 
    h2 { font-size: 24px; } 

    .bq-ticker-search-wrapper { max-width: 350px; }
    .bq-logo-slide { width: 150px; }

    .bq-features__grid { 
        grid-template-columns: 1fr; 
        text-align: center; 
    } 
    .bq-feature-card, .bq-feature-card__icon { 
        margin-left: auto; 
        margin-right: auto; 
        justify-content: center; 
    } 

    .bq-pricing-controls { flex-direction: column; } 
    
    .bq-reviews__carousel-wrapper {
        scroll-snap-type: x mandatory;
        padding-left: calc(50vw - 45vw - 10px);
        padding-right: calc(50vw - 45vw - 10px);
    }
    .bq-review-card { 
        width: 90vw;
        max-width: 400px;
        scroll-snap-align: center;
    }
    
    .bq-carousel__nav--prev { left: 0px; }
    .bq-carousel__nav--next { right: 0px; }

    .bq-footer__grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 30px 20px;
        text-align: left;
    }

    .bq-footer__grid .bq-footer__col:first-child { grid-column: 1 / -1; }
    
    .bq-footer__col img,
    .bq-footer__col p {
        margin-left: 0;
        margin-right: 0;
    }
    
    .bq-footer__socials { justify-content: flex-start; }
}

.promo-btn {
    display: inline-block;
    width: 100%;
    padding: 15px 30px;
    background-color: #0d6efd;
    color: #ffffff;
    border-radius: 8px;
    text-decoration: none;
    font-weight: bold;
    font-size: 16px;
    border: none;
    transition: all 0.2s ease;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    cursor: pointer;
    max-width: 300px;
}

/* --- Icon Styling for Dropdown Menu --- */
#bq-main-header .bq-dropdown__content a,
.bq-mobile-nav__links a {
    display: flex;
    align-items: center;
    gap: 12px;
}

#bq-main-header .bq-dropdown__content a svg,
.bq-mobile-nav__links a svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: var(--gray-700);
    transition: color 0.2s ease;
}

#bq-main-header .bq-dropdown__content a:hover svg,
.bq-mobile-nav__links a:hover svg {
    color: #217ab4;
}

#bq-main-header .bq-dropdown__content a:hover {
    color: #217ab4;
}

/* --- Vertically Align Tooltip Icon --- */
.bq-pricing-card__features li,
.bq-detailed-table td.feature-col {
    align-items: center; 
    display: flex;
}
.bq-tick-icon, .bq-cross-icon {
    margin-top: 0; 
}