/* ==========================================================================
   VICMAR — Sistema "Oficina Clara" v2  (vanilla, mobile-first, temável)
   Camadas de token: 1 primitivos · 2 semânticos · 3 componente
   Re-tematizar (projeto-irmão) = editar SÓ a Camada 1.
   ========================================================================== */

/* ===== FONTES (self-hosted, 0 request externo) ========================== */
@font-face{font-family:"Inter";src:url("../fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-900.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}

/* ===== CAMADA 1 — PRIMITIVOS  (★ ÚNICO BLOCO A TROCAR PARA RE-TEMAR) ==== */
:root{
  --c-navy-950:#051320; --c-navy-900:#061B30; --c-navy-800:#0A2A47;
  --c-navy-700:#0F4C81; --c-navy-600:#1565A8; --c-navy-300:#9DC3E0;
  --c-navy-100:#E3EDF6; --c-navy-050:#F1F6FB;
  --c-amber-600:#B45309; --c-amber-500:#E0801A; --c-amber-400:#F0A93B; --c-amber-100:#FBEAD2;
  --c-green-700:#0B7C3E; --c-green-600:#0E9F4F; --c-green-glyph:#25D366;
  --c-ink-950:#0B1620; --c-ink-900:#16242F; --c-ink-700:#3C4A57; --c-ink-500:#5E6C78; --c-ink-400:#8A96A1;
  --c-paper:#FCFCFA; --c-paper-alt:#F4F2EC; --c-surface:#FFFFFF; --c-surface-blue:#F1F6FB;
  --c-hairline:#E6E3DB; --c-hairline-strong:#D4D0C5; --c-hairline-dark:rgba(157,195,224,.18);
  --c-success-700:#0B7C3E; --c-error-700:#B23B3B;
  --c-on-dark-900:#F4F8FC; --c-on-dark-600:#B8C6D4;
}
/* ===== CAMADA 2 — SEMÂNTICOS =========================================== */
:root{
  --color-bg:var(--c-paper); --color-bg-alt:var(--c-paper-alt);
  --color-surface:var(--c-surface); --color-surface-sunk:var(--c-surface-blue);
  --color-bg-dark:var(--c-navy-950); --color-bg-brand:var(--c-navy-900);
  --color-text:var(--c-ink-900); --color-text-strong:var(--c-ink-950);
  --color-text-muted:var(--c-ink-700); --color-text-subtle:var(--c-ink-500);
  --color-text-on-dark:var(--c-on-dark-900); --color-text-on-dark-muted:var(--c-on-dark-600);
  --color-brand:var(--c-navy-900); --color-action:var(--c-navy-700); --color-action-hover:var(--c-navy-600);
  --color-accent:var(--c-amber-600); --color-accent-line:var(--c-amber-500);
  --color-cta:var(--c-green-700); --color-cta-hover:var(--c-green-600);
  --color-cta-text:#fff; --color-cta-glyph:var(--c-green-glyph);
  --color-border:var(--c-hairline); --color-border-strong:var(--c-hairline-strong);
  --color-focus:var(--c-navy-700);
  --color-success:var(--c-success-700); --color-error:var(--c-error-700);

  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --fs-display:clamp(2.5rem,1.7rem + 3.6vw,4.25rem);
  --fs-h1:clamp(2rem,1.5rem + 2.2vw,3rem);
  --fs-h2:clamp(1.625rem,1.25rem + 1.7vw,2.5rem);
  --fs-h3:clamp(1.25rem,1.1rem + .65vw,1.5rem);
  --fs-lead:clamp(1.125rem,1.03rem + .4vw,1.375rem);
  --fs-body:clamp(1rem,.97rem + .15vw,1.125rem);
  --fs-small:.9375rem; --fs-label:.75rem;
  --fs-button:clamp(1rem,.97rem + .15vw,1.0625rem);
  --fs-numeral:clamp(3.5rem,2.2rem + 5vw,6rem);
  --lh-tight:1.04; --lh-snug:1.15; --lh-normal:1.5; --lh-relaxed:1.65; --measure:62ch;

  --space-2xs:4px; --space-xs:8px; --space-sm:12px; --space-md:16px;
  --space-lg:24px; --space-xl:32px; --space-2xl:48px; --space-3xl:64px; --space-4xl:96px;
  --section-gap:clamp(3.5rem,2.3rem + 4.5vw,6.5rem);
  --container-max:1200px; --container-narrow:720px;
  --gutter:clamp(1.25rem,.6rem + 2.2vw,2rem); --grid-gap:clamp(1rem,.6rem + 1.5vw,1.75rem);
  --radius-sm:8px; --radius-md:14px; --radius-lg:20px; --radius-pill:999px;
  --v-angle:24deg;
  --shadow-sm:0 1px 3px rgba(11,22,32,.07);
  --shadow-md:0 8px 24px rgba(11,22,32,.10);
  --shadow-lg:0 18px 44px rgba(11,22,32,.16);
  --shadow-cta:0 8px 20px rgba(11,124,62,.30);
  --dur-fast:140ms; --dur-base:240ms; --dur-slow:520ms;
  --ease-out:cubic-bezier(.2,.8,.2,1); --ease-emph:cubic-bezier(.16,1,.3,1);
  --tap-min:44px; --header-h:64px;
}

/* ===== RESET =========================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);-webkit-text-size-adjust:100%;scroll-behavior:smooth;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
body{font-size:var(--fs-body);line-height:var(--lh-relaxed);overflow-x:hidden}
body.no-scroll{overflow:hidden}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none;padding:0}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
:focus-visible{outline:3px solid var(--color-focus);outline-offset:2px;border-radius:var(--radius-sm)}
.is-dark :focus-visible{outline-color:var(--c-navy-300)}

/* ===== TIPOGRAFIA ====================================================== */
h1,h2,h3{line-height:var(--lh-snug);color:var(--color-text-strong);font-weight:700;letter-spacing:-.01em;text-wrap:balance}
.t-display{font-family:var(--font-display);font-weight:900;font-size:var(--fs-display);line-height:var(--lh-tight);letter-spacing:-.02em}
.t-h1{font-family:var(--font-display);font-weight:900;font-size:var(--fs-h1);line-height:1.08;letter-spacing:-.015em}
.t-h2{font-family:var(--font-display);font-weight:900;font-size:var(--fs-h2);line-height:1.1;letter-spacing:-.015em}
.t-h3{font-size:var(--fs-h3);font-weight:600}
.lead{font-size:var(--fs-lead);line-height:var(--lh-normal);color:var(--color-text-muted);font-weight:500;max-width:48ch;text-wrap:pretty}
.accent-word{color:var(--color-accent);font-style:italic}
.is-dark .accent-word{color:var(--c-amber-400)}
p{max-width:var(--measure);text-wrap:pretty}

/* ===== UTILITÁRIOS ===================================================== */
.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-gap)}
.section--alt{background:var(--color-bg-alt)}
.section--sunk{background:var(--color-surface-sunk)}
.section--brand{background:var(--color-bg-brand);color:var(--color-text-on-dark)}
.section--dark{background:var(--color-bg-dark);color:var(--color-text-on-dark)}
.section--brand :is(h1,h2,h3),.section--dark :is(h1,h2,h3){color:var(--color-text-on-dark)}
.eyebrow{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--fs-label);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-action)}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--color-accent-line);transform:skewX(calc(-1 * var(--v-angle)));transform-origin:left}
.section--brand .eyebrow,.section--dark .eyebrow,.hero .eyebrow{color:var(--c-amber-400)}
.section-head{max-width:var(--measure);margin-bottom:var(--space-2xl)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .lead{margin-top:var(--space-sm)}
.section--brand .lead,.section--dark .lead{color:var(--color-text-on-dark-muted)}
.muted{color:var(--color-text-muted)}
.note{font-size:var(--fs-small);color:var(--color-text-subtle)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--color-brand);color:#fff;padding:12px 16px;border-radius:0 0 var(--radius-sm) 0;z-index:200;font-weight:600}
.skip-link:focus{left:0}

/* ===== BOTÕES ========================================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);min-height:48px;padding:14px 26px;border-radius:var(--radius-pill);font-size:var(--fs-button);font-weight:700;letter-spacing:.01em;transition:transform var(--dur-fast) var(--ease-out),background var(--dur-fast),box-shadow var(--dur-fast)}
.btn svg{width:1.25em;height:1.25em;flex:none}
.btn--wa{background:var(--color-cta);color:var(--color-cta-text);box-shadow:var(--shadow-cta)}
.btn--wa svg{color:var(--color-cta-glyph)}
.btn--wa:hover{background:var(--color-cta-hover);transform:translateY(-2px)}
.btn--wa:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
.btn--ghost{color:var(--color-action);border:1.5px solid var(--color-action);background:transparent}
.btn--ghost:hover{background:var(--c-navy-050)}
.is-dark .btn--ghost,.hero .btn--ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.is-dark .btn--ghost:hover,.hero .btn--ghost:hover{background:rgba(255,255,255,.1)}
.btn--lg{min-height:56px;padding:17px 34px;font-size:1.0625rem}
.btn--block{width:100%}

/* ===== PLACEHOLDER DE MÍDIA (prancha azul rica, NÃO buraco branco) ===== */
.media-ph{aspect-ratio:var(--ph-ratio,4/5);background:linear-gradient(140deg,var(--c-navy-800),var(--c-navy-950));
  border-radius:var(--radius-md);display:grid;place-content:center;gap:var(--space-xs);text-align:center;
  padding:var(--space-lg);color:rgba(244,248,252,.72);position:relative;overflow:hidden}
.media-ph::after{content:"";position:absolute;inset:0;background:
  radial-gradient(120% 80% at 80% 10%,rgba(240,169,59,.16),transparent 55%),
  radial-gradient(80% 60% at 10% 100%,rgba(27,101,168,.35),transparent 60%);pointer-events:none}
.media-ph::before{content:"";position:absolute;top:14px;left:14px;width:46px;height:3px;z-index:2;
  background:var(--c-amber-400);transform:skewX(calc(-1 * var(--v-angle)));transform-origin:left}
.media-ph svg{width:40px;height:40px;margin-inline:auto;opacity:.85;position:relative;z-index:1}
.media-ph .ph-label{font-size:var(--fs-label);font-weight:700;letter-spacing:.12em;text-transform:uppercase;position:relative;z-index:1}
.media-ph .ph-desc{font-size:var(--fs-small);max-width:30ch;position:relative;z-index:1;color:rgba(244,248,252,.6)}

/* ===== TOP-BAR ========================================================= */
.topbar{display:none;background:var(--color-bg-dark);color:var(--color-text-on-dark-muted);font-size:var(--fs-label)}
.topbar .container{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:var(--space-md)}
.topbar span{display:inline-flex;align-items:center;gap:6px}
.topbar a{color:var(--c-amber-400);font-weight:600}

/* ===== HEADER / NAV ==================================================== */
.header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--color-bg) 94%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:box-shadow var(--dur-base),border-color var(--dur-base)}
@supports not (backdrop-filter:blur(10px)){.header{background:var(--color-bg)}}
.header.is-scrolled{border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}
.header .container{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);min-height:var(--header-h)}
.brand img{height:32px;width:auto}
.nav{display:none}
.nav ul{display:flex;align-items:center;gap:var(--space-lg)}
.nav a{font-weight:600;font-size:var(--fs-button);color:var(--color-text);padding:6px 2px;position:relative}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--color-accent-line);transition:width var(--dur-fast) var(--ease-out)}
.nav a:hover,.nav a[aria-current="page"]{color:var(--color-action)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.header-actions{display:flex;align-items:center;gap:var(--space-xs)}
.header .btn--wa{padding:10px 16px;min-height:44px}
.header .btn--wa .btn-label-full{display:none}
.nav-toggle{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;color:var(--color-brand)}
.nav-toggle svg{width:26px;height:26px}

.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(88vw,360px);background:var(--color-surface);box-shadow:var(--shadow-lg);z-index:120;transform:translateX(100%);transition:transform var(--dur-base) var(--ease-emph);display:flex;flex-direction:column;visibility:hidden}
.mobile-menu.is-open{transform:translateX(0);visibility:visible}
.mobile-menu__head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--gutter);min-height:56px;border-bottom:1px solid var(--color-border)}
.mobile-menu__head img{height:28px}
.mobile-menu nav{flex:1;overflow-y:auto}
.mobile-menu a.m-item{display:flex;align-items:center;justify-content:space-between;padding:18px var(--gutter);min-height:56px;font-size:var(--fs-h3);font-weight:600;border-bottom:1px solid var(--color-border)}
.mobile-menu a.m-item:active{background:var(--c-navy-050)}
.mobile-menu a.m-item svg{width:18px;height:18px;color:var(--color-text-subtle)}
.mobile-menu__foot{padding:var(--space-md) var(--gutter);border-top:1px solid var(--color-border)}
.mobile-menu__foot .note{margin-top:var(--space-sm);text-align:center}
.menu-overlay{position:fixed;inset:0;background:rgba(11,22,32,.5);z-index:110;opacity:0;visibility:hidden;transition:opacity var(--dur-base)}
.menu-overlay.is-open{opacity:1;visibility:visible}

/* ===== HERO FULL-BLEED ================================================= */
.hero{position:relative;color:#fff;background:linear-gradient(135deg,var(--c-navy-800) 0%,var(--c-navy-950) 70%);overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;background:
  radial-gradient(80% 60% at 85% 8%,rgba(240,169,59,.18),transparent 55%),
  linear-gradient(180deg,rgba(5,19,32,.2),rgba(5,19,32,.72))}
.hero__v{position:absolute;right:-6%;bottom:-12%;width:46%;max-width:520px;opacity:.07;z-index:-1;color:#fff;pointer-events:none}
.hero .container{position:relative;display:flex;flex-direction:column;gap:var(--space-md);padding-block:clamp(3rem,2rem+6vw,7rem);min-height:clamp(440px,70vh,640px);justify-content:center}
.hero h1{color:#fff;max-width:16ch}
.hero .lead{color:rgba(244,248,252,.88);max-width:50ch}
.hero__chips{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-2xs)}
.hero .chip{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.18)}
.hero__cta{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm)}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-small);font-weight:600;padding:7px 14px;border-radius:var(--radius-pill);font-variant-numeric:tabular-nums}

/* ===== FAIXA DE CONFIANÇA (selos) ==================================== */
.trust{background:var(--color-surface-sunk);border-block:1px solid var(--color-border)}
.trust .container{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md) var(--space-sm);padding-block:var(--space-2xl)}
.seal{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}
.seal__img{width:56px;height:56px}
.seal__label{font-size:var(--fs-label);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-subtle)}
.seal__value{font-size:1.0625rem;font-weight:700;color:var(--color-text-strong);font-variant-numeric:tabular-nums}

/* ===== CARDS DE SERVIÇO (corpo próprio: ícone grande, sem depender de foto) */
.cards{display:grid;grid-template-columns:1fr;gap:var(--grid-gap)}
.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-sm);position:relative;overflow:hidden;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-base),border-color var(--dur-fast)}
.card::before{content:"";position:absolute;top:0;left:0;width:56px;height:4px;background:var(--color-accent-line);transform:skewX(calc(-1 * var(--v-angle)));transform-origin:left}
.card__icon{width:60px;height:60px;border-radius:var(--radius-md);background:var(--c-navy-050);border:1px solid var(--c-navy-100);display:grid;place-content:center;margin-bottom:var(--space-2xs);color:var(--color-action);transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast),color var(--dur-fast)}
.card__icon svg{width:30px;height:30px}
.card__title{font-size:var(--fs-h3);font-weight:700}
.card p{font-size:var(--fs-small);color:var(--color-text-muted);flex:1}
/* CTA pílula — só no card de navegação (.card--nav) */
.card__cta{display:inline-flex;align-items:center;gap:var(--space-xs);align-self:flex-start;margin-top:var(--space-xs);min-height:44px;padding:8px 16px;border-radius:var(--radius-pill);background:var(--c-navy-050);color:var(--color-action);font-weight:700;font-size:var(--fs-small);transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast),gap var(--dur-fast) var(--ease-out)}
.card__cta svg{width:1.15em;height:1.15em;flex:none;transition:transform var(--dur-fast) var(--ease-out)}
.card--nav{cursor:pointer}
.card--nav .card__cta::after{content:"";position:absolute;inset:0;z-index:1;border-radius:inherit}
.card--nav .card__cta:focus-visible{outline:none}
@media (hover:hover){
  .card--nav:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-action)}
  .card--nav:hover .card__icon{background:var(--c-navy-700);border-color:var(--c-navy-700);color:#fff}
  .card--nav:hover .card__cta{background:var(--color-action);color:#fff}
  .card--nav:hover .card__cta svg{transform:translateX(4px)}
}
.card--nav:active{transform:translateY(0) scale(.99);box-shadow:var(--shadow-sm)}
.card--nav:focus-within{border-color:var(--color-action);outline:3px solid var(--color-focus);outline-offset:2px}
.cards-more{display:flex;justify-content:center;margin-top:var(--space-2xl)}
/* Card catálogo: foto no topo (substitui o ícone) */
.card--photo{padding:0;gap:0}
.card--photo::before{display:none}
.card--photo .card__img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:var(--c-navy-900);transition:transform var(--dur-base) var(--ease-out)}
.card--photo .card__body{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-xl);flex:1}
@media (hover:hover){.card--nav.card--photo:hover .card__img{transform:scale(1.045)}}

/* ===== FEATURE / CARTAZ (imagem + texto, alterna lado) ================ */
.feature{display:grid;gap:var(--space-xl);align-items:center}
.feature__media{--ph-ratio:4/3}
.feature__body{display:flex;flex-direction:column;gap:var(--space-sm)}
.feature__body .btn{margin-top:var(--space-xs);align-self:flex-start}
.feature__list{display:grid;gap:var(--space-sm);margin-top:var(--space-xs)}
.feature__list li{display:flex;gap:var(--space-sm);align-items:flex-start;font-size:var(--fs-body)}
.feature__list svg{width:22px;height:22px;color:var(--color-success);flex:none;margin-top:3px}
.section--brand .feature__list svg{color:var(--c-amber-400)}

/* ===== POR QUE VICMAR ================================================= */
.why{display:grid;gap:var(--space-2xl)}
.why__list{display:grid;gap:var(--space-lg)}
.why__item{display:flex;gap:var(--space-md);align-items:flex-start}
.why__item .why__ico{width:48px;height:48px;border-radius:var(--radius-md);background:var(--c-navy-100);display:grid;place-content:center;flex:none}
.why__item .why__ico svg{width:24px;height:24px;color:var(--color-action)}
.why__item h3{font-size:1.0625rem;font-weight:700;color:var(--color-text-strong)}
.why__item p{font-size:var(--fs-small);color:var(--color-text-muted);margin-top:3px}

/* ===== PROCESSO ======================================================= */
.steps{display:grid;gap:var(--space-xl);counter-reset:step}
.step{display:grid;grid-template-columns:auto 1fr;gap:var(--space-md);align-items:start}
.step__num{font-family:var(--font-display);font-weight:900;font-size:var(--fs-numeral);line-height:.85;-webkit-text-stroke:2px var(--color-accent-line);color:transparent}
.section--brand .step__num{-webkit-text-stroke-color:var(--c-amber-400)}
.step__txt h3{font-size:var(--fs-h3);font-weight:700}
.step__txt p{font-size:var(--fs-body);color:var(--color-text-muted);margin-top:6px}
.section--brand .step__txt h3{color:#fff}
.section--brand .step__txt p{color:var(--color-text-on-dark-muted)}

/* ===== GALERIA ======================================================== */
.gallery{display:grid;grid-template-columns:1fr;gap:var(--grid-gap)}
.gallery .media-ph,.gallery .media-img{--ph-ratio:4/3}

/* ===== PÚBLICOS / CHIPS =============================================== */
.publics__chips{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-block:var(--space-md)}
.publics__chips .chip{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}

/* ===== VEÍCULOS ====================================================== */
.vehicles{display:grid;grid-template-columns:1fr;gap:var(--space-sm);margin-top:var(--space-lg)}
.vehicle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:row;align-items:center;text-align:left}
.vehicle__img{width:42%;max-width:170px;aspect-ratio:4/3;object-fit:cover;display:block;background:#fff;flex:none}
.vehicle span{font-weight:600;font-size:var(--fs-small);padding:var(--space-sm) var(--space-md)}
@media (min-width:600px){
  .vehicles{grid-template-columns:repeat(3,1fr);gap:var(--space-md)}
  .vehicle{flex-direction:column;text-align:center}
  .vehicle__img{width:100%;max-width:none}
  .vehicle span{padding:var(--space-md) var(--space-xs)}
}

/* ===== FAQ =========================================================== */
.faq{display:grid;gap:var(--space-sm);max-width:var(--container-narrow)}
.faq details{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}
.faq summary{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);min-height:var(--tap-min);cursor:pointer;font-size:var(--fs-h3);font-weight:600;color:var(--color-text-strong);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{background:var(--c-navy-050)}
.faq summary .chev{width:20px;height:20px;flex:none;transition:transform var(--dur-base) var(--ease-out);color:var(--color-action)}
.faq details[open] summary .chev{transform:rotate(180deg)}
.faq .faq-body{padding:0 var(--space-lg) var(--space-lg);color:var(--color-text-muted);font-size:var(--fs-body)}

/* ===== CTA FINAL ===================================================== */
.final-cta{position:relative;overflow:hidden;text-align:center}
.final-cta .container{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);position:relative;z-index:1}
.final-cta h2{color:#fff}
.final-cta__v{position:absolute;right:-4%;top:50%;transform:translateY(-50%);width:42%;max-width:420px;opacity:.06;z-index:0;pointer-events:none;color:#fff}

/* ===== FOOTER ======================================================== */
.footer{background:var(--color-bg-dark);color:var(--color-text-on-dark-muted);padding-block:var(--space-3xl) var(--space-xl)}
.footer__grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl)}
.footer img.flogo{height:36px;margin-bottom:var(--space-sm)}
.footer h3{font-size:var(--fs-label);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-on-dark);margin-bottom:var(--space-sm)}
.footer a{color:var(--color-text-on-dark-muted)}
.footer a:hover{color:#fff;text-decoration:underline}
.footer ul{display:grid;gap:var(--space-xs);font-size:var(--fs-small)}
.footer address{font-style:normal;font-size:var(--fs-small);line-height:1.7;display:grid;gap:6px}
.footer .btn--wa{margin-top:var(--space-sm)}
.footer__bottom{border-top:1px solid var(--c-hairline-dark);margin-top:var(--space-2xl);padding-top:var(--space-md);font-size:var(--fs-small)}

/* ===== FAB =========================================================== */
.fab{position:fixed;right:16px;bottom:16px;z-index:90;width:58px;height:58px;border-radius:50%;background:var(--color-cta);box-shadow:var(--shadow-cta);display:grid;place-content:center;opacity:0;visibility:hidden;transform:scale(.8);transition:opacity var(--dur-base),transform var(--dur-base) var(--ease-emph)}
.fab.is-visible{opacity:1;visibility:visible;transform:scale(1)}
.fab svg{width:30px;height:30px;color:var(--color-cta-glyph)}
.fab:hover{background:var(--color-cta-hover);transform:scale(1.06)}
.fab:active{transform:scale(.97)}

/* ===== REVEAL ======================================================== */
.js [data-reveal]{opacity:0;transform:translateY(18px);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}
.js [data-reveal].is-in{opacity:1;transform:none}

/* ======================================================================
   BREAKPOINTS
   ====================================================================== */
@media (min-width:768px){
  .topbar{display:block}
  .cards{grid-template-columns:repeat(2,1fr)}
  .trust .seal__img{width:64px;height:64px}
  .steps{grid-template-columns:repeat(3,1fr)}
  .gallery{grid-template-columns:2fr 1fr;grid-auto-rows:1fr}
  .gallery>:first-child{grid-row:span 2;--ph-ratio:1/1}
  .gallery .media-img{height:100%}
  .feature{grid-template-columns:1fr 1fr}
  .feature--reverse .feature__media{order:2}
  .footer__grid{grid-template-columns:1.5fr 1fr 1fr 1.3fr}
}
@media (min-width:1024px){
  :root{--header-h:70px}
  .nav{display:block}
  .nav-toggle{display:none}
  .header .btn--wa .btn-label-full{display:inline}
  .header .btn--wa .btn-label-short{display:none}
  .cards{grid-template-columns:repeat(3,1fr)}
  .hero__cta{flex-direction:row;align-items:center}
  .why{grid-template-columns:5fr 7fr}
  .why__list{grid-template-columns:1fr 1fr}
}

/* ===== IMAGEM REAL (substitui .media-ph mantendo proporcao + zero-CLS) === */
.media-img{width:100%;aspect-ratio:var(--ph-ratio,4/3);object-fit:cover;border-radius:var(--radius-md);display:block;background:var(--c-navy-900)}
.map-embed{width:100%;aspect-ratio:var(--ph-ratio,4/3);border:0;border-radius:var(--radius-md);display:block;background:var(--c-navy-900)}

/* ===== HERO INTERNO + BREADCRUMB ==================================== */
.hero--page .container{min-height:clamp(240px,34vh,360px);padding-block:clamp(2.5rem,2rem + 3vw,4.5rem)}
.hero--page h1{max-width:20ch}
.breadcrumb{font-size:var(--fs-small);margin-bottom:var(--space-xs)}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:6px;align-items:center;color:rgba(244,248,252,.7)}
.breadcrumb a{color:rgba(255,255,255,.88)}
.breadcrumb a:hover{color:#fff;text-decoration:underline}
.breadcrumb li:not(:last-child)::after{content:"/";margin-left:6px;opacity:.5}

/* ===== A11Y / MOTION ================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important}
}
