/* ============================================================================
 * BSM Vehica — topbar / busca / overlay mobile
 *
 * Migracao de bsm-topbar.php (HANDOFF §4 — topbar e server-render) para o
 * child theme. A ESTRUTURA HTML virou template PHP; este CSS estiliza os
 * containers nativos. JS delegado em assets/js/bsm.js popula conteudo.
 * ============================================================================ */

/* Esconde o link '/search/' do menu WP (substituido pela busca-protagonista
   da topbar). CSS-only para evitar FOUC — antes era feito por JS (tidyNav)
   o que causava flash de ~100ms com o botao aparecendo e sumindo.
   A regra pega todos os clones (Vue duplica o menu pro sticky) porque o
   seletor e' por classe+href, nao por id. */
.vehica-menu__link[href*="/search"],
.vehica-menu__link[href*="/search"] ~ .sub-menu,
li:has(> a.vehica-menu__link[href*="/search"]) {
    display: none !important;
}

:root { --bsm-acc: #FF2E34; }

/* ---- barra FIXA premium ao rolar (desktop) ---- */
.vehica-menu__wrapper.bsm-fixed {
    position: fixed !important; top: 0 !important; left: 0 !important; right: 0 !important;
    width: 100% !important;
    background: rgba(13, 15, 19, .90) !important;
    -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
    box-shadow: 0 6px 26px rgba(0, 0, 0, .30);
    border-bottom: 1px solid rgba(255, 255, 255, .07);
    z-index: 9995;
    animation: bsmTopDown .34s cubic-bezier(.22, 1, .36, 1);
}
@keyframes bsmTopDown { from { transform: translateY(-100%); } to { transform: none; } }
.vehica-menu__wrapper.bsm-fixed,
.vehica-menu__wrapper.bsm-fixed .vehica-menu__container,
.vehica-menu__wrapper.bsm-fixed .vehica-menu { height: 60px !important; min-height: 60px !important; }
.vehica-menu__wrapper.bsm-fixed img { max-height: 32px !important; width: auto !important; transition: max-height .2s; }
.vehica-menu__link { transition: color .16s ease, opacity .16s ease !important; letter-spacing: .2px; }
.vehica-menu__link:hover { color: #fff !important; }

/* ---- busca-protagonista ---- */
.bsm-topsearch {
    position: relative; display: flex !important; align-items: center !important; gap: 9px;
    height: 42px; padding: 0 15px; margin-left: 28px;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .11);
    border-radius: 12px;
    width: clamp(220px, 26vw, 360px); box-sizing: border-box;
    transition: background .16s, border-color .16s; cursor: text;
}
.bsm-topsearch:focus-within { background: rgba(255, 255, 255, .13); border-color: rgba(255, 46, 52, .55); }
.bsm-topsearch svg { display: block !important; width: 18px; height: 18px; color: rgba(255, 255, 255, .62); flex: none !important; align-self: center !important; margin: 0 !important; }
.bsm-topsearch input { flex: 1; min-width: 0; line-height: 1.2; padding: 0 !important; margin: 0 !important; background: none; border: 0; outline: 0; color: #fff; font-size: 14px; font-family: inherit; align-self: center; }
.bsm-topsearch input::placeholder { color: rgba(255, 255, 255, .52); }
@media (max-width: 1024px) { .bsm-topsearch { display: none !important; } }

/* ---- painel de exploracao ---- */
.bsm-search-panel {
    position: absolute; top: calc(100% + 12px); left: 0; width: 440px; max-width: 92vw;
    background: rgba(20, 22, 28, .80);
    -webkit-backdrop-filter: blur(34px) saturate(1.45); backdrop-filter: blur(34px) saturate(1.45);
    border: 1px solid rgba(255, 255, 255, .13);
    border-radius: 18px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .62), 0 4px 14px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 255, 255, .08);
    padding: 18px 20px;
    opacity: 0; visibility: hidden; transform: translateY(-8px) scale(.975); transform-origin: top center;
    transition: opacity .22s cubic-bezier(.22, 1, .36, 1), transform .26s cubic-bezier(.22, 1, .36, 1), visibility .22s;
    z-index: 10000;
}
.bsm-search-panel.bsm-open { opacity: 1; visibility: visible; transform: none; }
.bsm-search-panel[hidden] { display: none; }
.bsm-sp__sec { margin-bottom: 15px; }
.bsm-sp__sec:last-child { margin-bottom: 0; }
.bsm-sp__lbl { font: 700 10px/1 sans-serif; letter-spacing: .9px; text-transform: uppercase; color: #7c8493; margin: 0 0 10px; }
.bsm-sp__chips { display: flex; flex-wrap: wrap; gap: 7px; }
.bsm-sp__chip { display: inline-flex; align-items: center; padding: 7px 13px; border-radius: 9px; background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .09); color: #dfe3ea; font-size: 13px; font-weight: 600; text-decoration: none; transition: background .14s, border-color .14s, color .14s; white-space: nowrap; }
.bsm-sp__chip:hover { background: rgba(255, 46, 52, .16); border-color: rgba(255, 46, 52, .42); color: #fff; }
.bsm-sp__brands { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.bsm-sp__brand { width: 42px; height: 42px; border-radius: 11px; background: #fff; display: flex; align-items: center; justify-content: center; overflow: hidden; transition: transform .15s, box-shadow .15s; box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .12); }
.bsm-sp__brand:hover { transform: translateY(-2px) scale(1.05); box-shadow: 0 8px 20px rgba(0, 0, 0, .45); }
.bsm-sp__brand img { width: 72%; height: 72%; object-fit: contain; }
.bsm-sp__more { color: var(--bsm-acc); font-size: 12.5px; font-weight: 700; text-decoration: none; align-self: center; margin-left: 3px; white-space: nowrap; }


/* ---- MOBILE: icone de busca + overlay tela cheia ---- */
.bsm-msearch-icon { display: flex; align-items: center; justify-content: center; width: 44px; height: 44px; cursor: pointer; color: #fff; flex: none; }
.bsm-msearch-icon svg { width: 22px; height: 22px; }
@media (min-width: 1025px) { .bsm-msearch-icon { display: none !important; } }
.bsm-msearch-overlay { position: fixed; inset: 0; z-index: 99999; background: rgba(13, 15, 19, .97); -webkit-backdrop-filter: blur(24px); backdrop-filter: blur(24px); opacity: 0; visibility: hidden; transform: translateY(-14px); transition: opacity .2s, transform .24s cubic-bezier(.22, 1, .36, 1), visibility .2s; overflow-y: auto; padding: 14px 16px 34px; box-sizing: border-box; }
.bsm-msearch-overlay.bsm-open { opacity: 1; visibility: visible; transform: none; }
.bsm-msearch-overlay[hidden] { display: none; }
.bsm-mso__bar { display: flex; align-items: center; gap: 11px; margin: 0 0 20px; }
.bsm-mso__form { flex: 1; display: flex; align-items: center; gap: 10px; height: 48px; padding: 0 16px; background: rgba(255, 255, 255, .09); border: 1px solid rgba(255, 255, 255, .14); border-radius: 13px; }
.bsm-mso__form svg { width: 19px; height: 19px; color: rgba(255, 255, 255, .6); flex: none; }
.bsm-mso__form input { flex: 1; min-width: 0; background: none; border: 0; outline: 0; color: #fff; font-size: 16px; font-family: inherit; }
.bsm-mso__form input::placeholder { color: rgba(255, 255, 255, .5); }
.bsm-mso__close { width: 46px; height: 46px; flex: none; background: rgba(255, 255, 255, .08); border: 0; border-radius: 50%; color: #fff; font-size: 22px; line-height: 1; cursor: pointer; padding: 0; }
.bsm-mso__close:active { background: rgba(255, 255, 255, .16); }
.bsm-msearch-overlay .bsm-sp__sec { margin-bottom: 22px; }
.bsm-msearch-overlay .bsm-sp__chip { font-size: 14px; padding: 9px 15px; }
.bsm-msearch-overlay .bsm-sp__brand { width: 48px; height: 48px; }
.bsm-msearch-overlay .bsm-sp__brands { gap: 11px; }

/* ============================================================================
 * SEARCH TOOLBAR (migrado de bsm-search-toolbar.php)
 *
 * O HTML do .vehica-inventory-v1__bar e' Vue-render (HANDOFF §2.3),
 * portanto a estrutura NAO migra pra template. So' o CSS:
 *   - barra (abas + Comparar + keyword) vira toolbar no topo dos resultados
 *   - tabs de simulador viram segmented control premium
 *
 * O JS de mover a barra vive em /assets/js/bsm.js (moveBar com guard Vue).
 * ============================================================================ */

@media (min-width: 1025px) {
    /* barra movida = toolbar no topo dos resultados */
    .vehica-inventory-v1 > .vehica-inventory-v1__bar {
        display: flex !important; align-items: center; justify-content: space-between;
        gap: 16px; flex-wrap: nowrap; margin: 0 0 18px !important; padding: 0 !important;
        background: none !important; border: 0 !important;
    }
    .vehica-inventory-v1 > .vehica-inventory-v1__bar .vehica-inventory-v1__bar__left,
    .vehica-inventory-v1 > .vehica-inventory-v1__bar .vehica-inventory-v1__bar__right {
        display: flex !important; align-items: center; gap: 14px; margin: 0 !important;
        flex: 0 0 auto !important;
    }
    /* segmented control dos simuladores */
    .vehica-search-v1__tabs {
        display: inline-flex !important; width: auto !important; max-width: none !important;
        height: auto !important; background: #eef1f6; border-radius: 12px; padding: 4px; gap: 3px;
    }
    .vehica-search-v1__tab {
        display: flex !important; align-items: center; flex: 0 0 auto !important;
        padding: 0 !important; margin: 0 !important; border: 0 !important;
        border-radius: 9px !important; background: none !important;
        height: auto !important; min-height: 0 !important; box-shadow: none;
        transition: background .15s, box-shadow .15s;
    }
    .vehica-search-v1__tab-button {
        display: inline-flex !important; align-items: center; gap: 5px;
        padding: 8px 15px !important; margin: 0 !important;
        width: auto !important; height: auto !important; min-height: 0 !important;
        background: none !important; border: 0 !important; border-radius: 9px !important;
        font-weight: 700 !important; font-size: 13px !important; line-height: 1.2 !important;
        color: #5b6472 !important; white-space: nowrap; cursor: pointer; box-shadow: none !important;
    }
    .vehica-search-v1__tab:hover .vehica-search-v1__tab-button { color: #11131a !important; }
    .vehica-search-v1__tab--active { background: #fff !important; box-shadow: 0 1px 4px rgba(20, 22, 30, .12) !important; }
    .vehica-search-v1__tab--active .vehica-search-v1__tab-button { color: #FF2E34 !important; }
    .vehica-search-v1__tab-count { opacity: .55; font-weight: 600; }
}

/* ============================================================================
 * SEARCH RANGE SLIDERS (migrado de bsm-hp-slider.php)
 *
 * HTML dos sliders e' injetado por JS (HANDOFF §2.3 - campos number sao
 * decorados pelo Vue, template PHP nao basta). Apenas o CSS vive aqui.
 * ============================================================================ */
.bsm-hps { padding: 1px 6px 4px; }
.bsm-hps__label { display: flex; align-items: center; justify-content: space-between; gap: 6px; margin: 0 0 9px; font-size: 12px; }
.bsm-hps__title { display: inline-flex; align-items: center; gap: 5px; font-weight: 800; color: #2b313d; text-transform: uppercase; letter-spacing: .3px; white-space: nowrap; }
.bsm-hps__title svg { width: 13px; height: 13px; color: #FF2E34; flex: none; }
.bsm-hps__val { font-weight: 800; color: #FF2E34; font-size: 12px; white-space: nowrap; }
.bsm-hps__track { position: relative; height: 22px; }
.bsm-hps__rail, .bsm-hps__fill { position: absolute; top: 9px; height: 4px; border-radius: 3px; }
.bsm-hps__rail { left: 0; right: 0; background: #e2e6ee; }
.bsm-hps__fill { background: linear-gradient(90deg, #ff5a5f, #FF2E34); }
.bsm-hps__track input[type=range] { position: absolute; top: 0; left: 0; width: 100%; height: 22px; margin: 0; background: none; pointer-events: none; -webkit-appearance: none; appearance: none; }
.bsm-hps__track input[type=range]:focus { outline: none; }
.bsm-hps__track input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; pointer-events: all; width: 17px; height: 17px; border-radius: 50%; background: #fff; border: 2px solid #FF2E34; box-shadow: 0 2px 6px rgba(20, 22, 30, .22); cursor: grab; }
.bsm-hps__track input[type=range]::-webkit-slider-thumb:active { cursor: grabbing; transform: scale(1.08); }
.bsm-hps__track input[type=range]::-moz-range-thumb { pointer-events: all; width: 17px; height: 17px; border-radius: 50%; background: #fff; border: 2px solid #FF2E34; box-shadow: 0 2px 6px rgba(20, 22, 30, .22); cursor: grab; }
.bsm-hps__track input[type=range]::-webkit-slider-runnable-track { background: none; border: none; }
.bsm-hps__track input[type=range]::-moz-range-track { background: none; border: none; }

/* ============================================================================
 * BRAND LOGOS NO DROPDOWN (migrado de bsm-brand-select.php)
 * ============================================================================ */
.vehica-option .bsm-osel-logo {
    width: 22px; height: 22px; object-fit: contain; border-radius: 5px;
    margin-right: 10px; vertical-align: middle; flex: none; background: #fff;
    box-shadow: inset 0 0 0 1px rgba(20, 22, 30, .08);
}



/* ============================================================================
 * TRUST PANEL NA FICHA DO CARRO (migrado de bsm-trust.php)
 *
 * O box e' injetado por JS (HANDOFF §2.3 - precisamos achar o anchor no
 * DOM do Elementor); os dados (autor + mailto) vem do PHP via localize.
 * ============================================================================ */
.bsm-trust {
    width: 100%; flex-basis: 100%; grid-column: 1 / -1; box-sizing: border-box;
    margin: 14px 0 4px; border: 1px solid #e7eaf0; border-radius: 16px;
    background: linear-gradient(180deg, #fff, #fbfcfe);
    padding: 16px 18px; box-shadow: 0 1px 2px rgba(20, 22, 30, .04);
}
.bsm-trust__head {
    display: flex; align-items: center; gap: 9px; font-weight: 800;
    font-size: 15px; color: #10131a; margin-bottom: 12px; letter-spacing: .1px;
}
.bsm-trust__head svg { width: 19px; height: 19px; color: #1aa35a; flex: none; }
.bsm-trust__row {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
    padding: 7px 0; border-top: 1px solid #f0f2f6;
}
.bsm-trust__row:first-of-type { border-top: 0; }
.bsm-trust__k {
    font-size: 12px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .5px; color: #8a93a3; min-width: 104px;
}
.bsm-trust__chip {
    display: inline-flex; align-items: center; gap: 6px;
    background: #eef1f6; color: #2b313d; font-size: 13px; font-weight: 700;
    padding: 4px 11px; border-radius: 999px;
}
.bsm-trust__chip svg { width: 13px; height: 13px; flex: none; opacity: .7; }
.bsm-trust__v {
    font-size: 13.5px; font-weight: 700; color: #FF2E34; text-decoration: none;
}
.bsm-trust__v:hover { text-decoration: underline; }
.bsm-trust__tip {
    display: flex; align-items: flex-start; gap: 8px; margin-top: 11px;
    padding-top: 11px; border-top: 1px solid #f0f2f6;
    font-size: 12.5px; line-height: 1.5; color: #6b7280;
}
.bsm-trust__tip svg { width: 15px; height: 15px; flex: none; margin-top: 1px; color: #e0a106; }
.bsm-trust__report {
    display: inline-flex; align-items: center; gap: 6px; margin-top: 12px;
    font-size: 12.5px; font-weight: 700; color: #8a93a3;
    text-decoration: none; transition: color .15s;
}
.bsm-trust__report:hover { color: #FF2E34; }
.bsm-trust__report svg { width: 14px; height: 14px; flex: none; }

/* ============================================================================
 * DOWNLOAD PREVIEW (migrado de bsm-download-preview.php)
 *
 * Shortcode [bsm_download_preview] usado em pagina admin-only.
 * ============================================================================ */
.bsmprev {
    --red: #ff2e35; --red2: #d31119; --card: #161b22; --mut: #9aa3b2;
    max-width: 960px; margin: 0 auto; display: grid; gap: 20px;
    color: #eef1f6; font-family: inherit;
}
.bsmprev * { box-sizing: border-box; }
.bsmprev a { text-decoration: none; }
.bsmprev-hero {
    background: radial-gradient(700px 320px at 50% -20%, rgba(255, 46, 53, .18), transparent 60%), var(--card);
    border: 1px solid rgba(255, 255, 255, .07); border-radius: 18px;
    padding: clamp(26px, 4vw, 40px); text-align: center; position: relative; overflow: hidden;
}
.bsmprev-count {
    width: 96px; height: 96px; margin: 0 auto 16px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 36px; font-weight: 900;
    background: conic-gradient(var(--red) 0deg, rgba(255, 255, 255, .08) 0deg);
    transition: background .9s linear;
}
.bsmprev-count span {
    width: 78px; height: 78px; border-radius: 50%; background: var(--card);
    display: flex; align-items: center; justify-content: center;
}
.bsmprev-hero h2 { font-size: clamp(20px, 3.4vw, 28px); font-weight: 800; margin: 4px 0 6px; color: #fff; }
.bsmprev-hero h2 b { color: var(--red); }
.bsmprev-sub { color: var(--mut); font-size: 15px; margin-bottom: 20px; }
.bsmprev-dl {
    display: none; align-items: center; justify-content: center; gap: 9px;
    margin: 0 auto; padding: 15px 32px; border-radius: 14px;
    background: linear-gradient(180deg, var(--red), var(--red2)); color: #fff;
    font-weight: 800; font-size: 16px; box-shadow: 0 10px 28px rgba(255, 46, 53, .45);
    cursor: pointer; transition: transform .15s ease;
}
.bsmprev-dl:hover { transform: translateY(-2px); }
.bsmprev-dl.on { display: inline-flex; }
.bsmprev-skip {
    position: absolute; top: 16px; right: 18px; color: var(--mut);
    font-size: 13px; font-weight: 600; border: 1px solid rgba(255, 255, 255, .14);
    padding: 7px 14px; border-radius: 9px;
}
.bsmprev-skip:hover { color: #fff; border-color: var(--red); }
.bsmprev-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 760px) { .bsmprev-grid { grid-template-columns: 1fr; } }
.bsmprev-box {
    background: var(--card); border: 1px solid rgba(255, 255, 255, .07);
    border-radius: 16px; padding: 22px;
}
.bsmprev-box h3 { font-size: 16px; font-weight: 800; margin-bottom: 14px; color: #fff; }
.bsmprev-tabs { display: flex; gap: 8px; margin-bottom: 14px; }
.bsmprev-tab {
    font-size: 13px; font-weight: 700; padding: 6px 14px; border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .14); color: var(--mut); cursor: pointer;
}
.bsmprev-tab.on { background: var(--red); color: #fff; border-color: transparent; }
.bsmprev-steps { list-style: none; display: grid; gap: 10px; counter-reset: s; padding: 0; margin: 0; }
.bsmprev-steps li { display: flex; gap: 10px; color: #c7cdd6; font-size: 14px; line-height: 1.4; }
.bsmprev-steps li::before {
    content: counter(s); counter-increment: s; background: var(--red); color: #fff;
    font-weight: 800; font-size: 12px; width: 22px; height: 22px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center; flex: 0 0 22px;
}
.bsmprev-support { text-align: center; background: linear-gradient(160deg, #1d141a, var(--card)); border-color: rgba(255, 46, 53, .25); }
.bsmprev-support p { color: #d9dee6; font-size: 14px; margin-bottom: 14px; }
.bsmprev-supbtn {
    display: inline-block; background: rgba(255, 46, 53, .14); color: #ff7b80;
    border: 1px solid rgba(255, 46, 53, .4); padding: 10px 20px;
    border-radius: 10px; font-weight: 700;
}
.bsmprev-ad {
    border: 2px dashed rgba(255, 255, 255, .18); border-radius: 14px;
    min-height: 120px; display: flex; align-items: center; justify-content: center;
    color: #6b7280; font-size: 13px; text-align: center; padding: 16px;
    background: rgba(255, 255, 255, .02);
}
.bsmprev-rel { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 760px) { .bsmprev-rel { grid-template-columns: 1fr 1fr; } }
.bsmprev-card {
    display: block; background: var(--card); border: 1px solid rgba(255, 255, 255, .07);
    border-radius: 12px; overflow: hidden;
    transition: transform .15s ease, border-color .15s ease;
}
.bsmprev-card:hover { transform: translateY(-3px); border-color: var(--red); }
.bsmprev-card__img {
    display: block; height: 92px; background-size: cover; background-position: center;
    background-color: #222;
}
.bsmprev-card__t {
    display: block; padding: 10px; color: #dfe4ea; font-size: 13px;
    font-weight: 600; line-height: 1.3;
}

/* ============================================================================
 * CLS FIXES (Cumulative Layout Shift)
 *
 * As maiores causas de CLS sao anuncios que carregam tarde sem espaco
 * reservado. No mobile (412px), os anuncios medem 412x412 (largura cheia).
 *
 * Estrategia:
 * 1. Containers Elementor com ads manuais: min-height reserva espaco.
 * 2. Google Auto Ads sao injetados apos load em divs .google-auto-placed
 *    - CSS min-height no container ajuda, mas o shift intra-container
 *    - Usar contain:layout isola o shift dentro do container.
 * 3. Logo com aspect-ratio preserva espaco ate imagem carregar.
 * ============================================================================ */

/* 1. Containers de anuncios manuais (Elementor widgets) - mobile 412x412px */
.elementor-element-524d,
.elementor-element-c97b {
    min-height: 280px !important;
}

/* 2. Google Auto Ads containers - isola layout shift */
body.home .google-auto-placed {
    contain: layout;
    min-height: 280px;
}
.home .google-auto-placed ins.adsbygoogle {
    min-height: 280px !important;
}

/* 3. Anuncios na ficha */
.single-vehica_car ins.adsbygoogle {
    min-height: 120px !important;
}

/* 4. Logo no header: reserva espaco ate imagem carregar */
.vehica-logo img {
    aspect-ratio: auto 1600 / 514;
    width: auto;
    height: auto;
    max-height: 32px;
    object-fit: contain;
}

