/* ============ FIPE BR — Design System (PHP build) ============ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Manrope:wght@400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#ffffff;
  --fg:#1a2a4a;            /* deep navy text */
  --muted:#6b7691;
  --muted-2:#9aa3b8;
  --border:#e6eaf2;
  --surface:#f7f9fc;
  --card:#ffffff;
  --primary:#1e3a5f;       /* deep navy */
  --primary-fg:#ffffff;
  --accent:#2563eb;        /* clean blue CTA */
  --accent-fg:#ffffff;
  --accent-soft:rgba(37,99,235,.10);
  --success:#16a34a;
  --danger:#dc2626;
  --radius:14px;
  --radius-lg:18px;
  --radius-xl:22px;
  --shadow-card:0 8px 24px -10px rgba(26,42,74,.12);
  --shadow-primary:0 14px 36px -12px rgba(37,99,235,.45);
  --gradient-primary:linear-gradient(135deg,#2563eb,#3b6fa0 60%,#1e3a5f);
  --gradient-dark:linear-gradient(180deg,#152a4a,#0c1a31);
  --gradient-glow:radial-gradient(ellipse at top right,rgba(37,99,235,.10),transparent 60%);
}
html,body{background:var(--bg);color:var(--fg);font-family:'Manrope',system-ui,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.55}
h1,h2,h3,h4{font-family:'Sora',system-ui,sans-serif;letter-spacing:-.025em;line-height:1.1;color:var(--fg)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%;display:block}
input,textarea{font-family:inherit}

.container{max-width:1120px;margin:0 auto;padding:0 20px}
.container.narrow{max-width:960px}
.muted{color:var(--muted)} .small{font-size:13px} .center{text-align:center}
.hidden{display:none!important}
.kicker{font-size:10px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.kicker.light{color:rgba(255,255,255,.75)}
.accent-text{color:var(--accent)}
.plate-font{font-family:'Sora',monospace;font-weight:800;letter-spacing:.18em}

/* ========== Header ========== */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.header-inner{max-width:1120px;margin:0 auto;padding:0 20px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:14px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:44px;width:auto;transition:transform .2s}
.brand:hover img{transform:scale(1.05)}
.site-nav{display:flex;align-items:center;gap:4px}
.site-nav a{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:10px;font-size:14px;font-weight:600;color:var(--muted);transition:background .15s,color .15s}
.site-nav a:hover,.site-nav a.active{background:var(--surface);color:var(--fg)}
.nav-cta{margin-left:8px;background:var(--gradient-primary);color:#fff!important;padding:10px 18px!important;border-radius:10px;box-shadow:var(--shadow-primary);font-weight:700}
.nav-cta:hover{filter:brightness(1.08);background:var(--gradient-primary)!important;color:#fff!important}
.mobile-toggle{display:none;padding:8px;border-radius:8px;background:transparent;color:var(--fg)}
@media(max-width:880px){
  .site-nav{display:none}
  .mobile-toggle{display:inline-flex}
  .site-nav.open{display:flex;flex-direction:column;align-items:stretch;gap:4px;position:absolute;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:14px 20px}
  .nav-cta{margin-left:0;margin-top:4px;text-align:center;justify-content:center}
}

/* ========== Hero ========== */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--border);background:var(--gradient-glow)}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(26,42,74,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(26,42,74,.04) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}
.hero-inner{position:relative;max-width:1120px;margin:0 auto;padding:56px 20px 64px;text-align:center}
.badge{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:700;padding:6px 14px;border-radius:999px;margin-bottom:22px}
.badge .dot{width:8px;height:8px;border-radius:99px;background:var(--accent);box-shadow:0 0 0 4px rgba(37,99,235,.18)}
.hero h1{font-size:clamp(34px,5.4vw,60px);font-weight:800;margin-bottom:18px;max-width:780px;margin-inline:auto;text-wrap:balance}
.hero h1 .accent{position:relative;color:var(--accent);display:inline-block}
.hero h1 .accent::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:10px;background:rgba(37,99,235,.15);transform:skewX(-8deg);z-index:-1}
.hero .lead{font-size:18px;color:var(--muted);margin:0 auto 32px;max-width:600px}
.hero .lead strong{color:var(--fg)}
.hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:22px;justify-content:center;margin-top:30px;font-size:14px;color:var(--muted)}
.hero-trust li{display:flex;align-items:center;gap:6px}
.hero-trust svg{width:16px;height:16px;color:var(--accent)}
.hero-image{position:relative;max-width:880px;margin:40px auto 0}
.hero-image::before{content:"";position:absolute;inset:-20px;background:rgba(37,99,235,.10);border-radius:50%;filter:blur(60px);z-index:0}
.hero-image img{position:relative;width:100%;height:auto;filter:drop-shadow(0 30px 50px rgba(26,42,74,.25));z-index:1}

/* ========== Plate search ========== */
.plate-search{max-width:460px;margin:0 auto;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:20px;text-align:left}
.plate-search label.lbl{display:block;font-size:10px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.plate-search .plate-input-wrap{position:relative}
.plate-search input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:text;z-index:2}
.plate-display{font-family:'Sora',monospace;font-weight:800;letter-spacing:.04em;background:#fff;border:2px solid rgba(26,42,74,.2);border-radius:14px;padding:18px 8px;display:flex;justify-content:center;gap:6px;font-size:32px;user-select:none}
.plate-display span{display:inline-block;min-width:30px;text-align:center;color:var(--fg)}
.plate-display span.empty{color:rgba(26,42,74,.18)}
.plate-search button[type=submit]{margin-top:16px;width:100%;background:var(--gradient-primary);color:#fff;font-weight:700;border-radius:14px;padding:16px;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-primary);transition:filter .15s}
.plate-search button[type=submit]:hover{filter:brightness(1.08)}
.plate-search .hint{font-size:11px;color:var(--muted);text-align:center;margin-top:12px}

/* ========== Stats bar ========== */
.stats-bar{border-bottom:1px solid var(--border);background:var(--surface)}
.stats-bar .container{padding-top:30px;padding-bottom:30px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
@media(max-width:680px){.stats-bar .container{grid-template-columns:repeat(2,1fr)}}
.stat-v{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(22px,3vw,32px);color:var(--fg)}
.stat-l{font-size:13px;color:var(--muted);margin-top:4px}

/* ========== Sections ========== */
section.block{padding:72px 0}
.section-head{text-align:center;max-width:640px;margin:0 auto 44px}
.section-head .eyebrow{display:inline-block;color:var(--accent);font-size:12px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;margin-bottom:10px}
.section-head h2{font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:10px;text-wrap:balance}
.section-head p{color:var(--muted)}
.section-alt{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:980px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps-grid{grid-template-columns:1fr}}
.step-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-card);overflow:hidden;transition:border-color .2s}
.step-card:hover{border-color:rgba(37,99,235,.5)}
.step-card .num{position:absolute;top:-6px;right:-4px;font-family:'Sora',sans-serif;font-weight:800;font-size:74px;color:rgba(37,99,235,.10);line-height:1}
.step-card .ic{position:relative;width:46px;height:46px;border-radius:12px;background:var(--gradient-primary);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-primary);margin-bottom:14px}
.step-card h3{font-size:17px;font-weight:700;margin-bottom:4px}
.step-card p{font-size:14px;color:var(--muted)}

/* Reports / features */
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:980px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cards-grid{grid-template-columns:1fr}}
.icon-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;transition:transform .2s,border-color .2s}
.icon-card:hover{transform:translateY(-3px);border-color:rgba(37,99,235,.5)}
.icon-card .ic{width:42px;height:42px;border-radius:12px;background:var(--card);border:1px solid var(--border);display:grid;place-items:center;color:var(--accent);margin-bottom:14px;transition:background .2s,color .2s,border-color .2s}
.icon-card:hover .ic{background:var(--gradient-primary);color:#fff;border-color:transparent}
.icon-card h3{font-size:15px;font-weight:700;margin-bottom:4px}
.icon-card p{font-size:13.5px;color:var(--muted);line-height:1.55}

/* Plans */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:980px;margin:0 auto}
@media(max-width:880px){.plans-grid{grid-template-columns:1fr;max-width:420px}}
.plan-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow-card);display:flex;flex-direction:column}
.plan-card.popular{background:var(--gradient-primary);color:#fff;border-color:var(--accent);box-shadow:var(--shadow-primary);transform:scale(1.03)}
.plan-card.popular h3,.plan-card.popular .plan-price{color:#fff}
.plan-card.popular .feat svg{color:#fff}
.popular-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:#fff;color:var(--accent);font-size:10px;font-weight:800;letter-spacing:.18em;padding:5px 12px;border-radius:999px;border:1px solid var(--accent)}
.plan-card h3{font-size:20px;font-weight:800;margin-bottom:4px}
.plan-price{font-family:'Sora',sans-serif;font-weight:800;font-size:38px;margin:8px 0 18px}
.plan-price .sm{font-size:14px;opacity:.7;font-weight:600;margin-right:2px}
.plan-card ul{list-style:none;flex:1;margin-bottom:22px}
.plan-card .feat{display:flex;align-items:flex-start;gap:8px;font-size:14px;padding:5px 0}
.plan-card .feat svg{width:16px;height:16px;color:var(--accent);flex-shrink:0;margin-top:3px}
.plan-cta{text-align:center;padding:13px;border-radius:12px;font-weight:700;background:var(--gradient-primary);color:#fff;display:block;transition:filter .15s}
.plan-cta:hover{filter:brightness(1.08)}
.plan-card.popular .plan-cta{background:#fff;color:var(--fg)}

/* Why us split */
.why-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:50px;align-items:center}
@media(max-width:980px){.why-grid{grid-template-columns:1fr}}
.why-grid h2{font-size:clamp(28px,4vw,42px);font-weight:800;margin:10px 0 14px;text-wrap:balance}
.why-grid > div > p{color:var(--muted);margin-bottom:26px}
.why-feats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:520px){.why-feats{grid-template-columns:1fr}}
.why-feat{display:flex;gap:12px}
.why-feat .ic{width:40px;height:40px;border-radius:12px;background:var(--gradient-primary);display:grid;place-items:center;color:#fff;flex-shrink:0;box-shadow:var(--shadow-primary)}
.why-feat .t{font-family:'Sora',sans-serif;font-weight:700;font-size:15px}
.why-feat .d{font-size:13.5px;color:var(--muted)}

/* Testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:880px){.testi-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
.testi{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-card)}
.stars{display:flex;gap:2px;margin-bottom:10px}
.stars svg{width:16px;height:16px;color:var(--accent);fill:var(--accent)}
.testi p{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:16px}
.testi .name{font-family:'Sora',sans-serif;font-weight:700;font-size:14px}
.testi .city{font-size:12px;color:var(--muted)}

/* Final CTA */
.cta-final{position:relative;overflow:hidden;border-top:1px solid var(--border);background:var(--gradient-glow);text-align:center;padding:64px 20px}
.cta-final h2{font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:14px;text-wrap:balance}
.cta-final p{color:var(--muted);margin-bottom:30px}

/* ========== Footer ========== */
.site-footer{background:var(--gradient-dark);color:rgba(255,255,255,.75);margin-top:80px;border-top:1px solid var(--border)}
.footer-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:56px 20px;max-width:1120px;margin:0 auto}
@media(max-width:880px){.footer-cols{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-cols{grid-template-columns:1fr}}
.footer-cols img.logo-w{height:54px;width:auto;margin-bottom:14px;filter:brightness(0) invert(1)}
.footer-cols h4{color:#fff;font-size:14px;font-family:'Sora',sans-serif;font-weight:700;margin-bottom:14px}
.footer-cols ul{list-style:none}
.footer-cols li{padding:5px 0;font-size:14px;color:rgba(255,255,255,.65)}
.footer-cols a:hover{color:var(--accent)}
.socials{display:flex;gap:8px;margin-top:18px}
.socials a{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:grid;place-items:center;color:#fff;transition:background .2s,border-color .2s}
.socials a:hover{background:var(--accent);border-color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom .inner{max-width:1120px;margin:0 auto;padding:18px 20px;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.5)}

/* ========== Consulta page ========== */
.page-bg{background:var(--surface);min-height:80vh;padding:30px 0 60px}
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--muted);margin-bottom:20px}
.back-link:hover{color:var(--fg)}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:24px;margin-bottom:18px}
@media(max-width:520px){.card{padding:18px}}
.card h2{font-size:19px;font-weight:800;margin-bottom:4px}

/* Vehicle card */
.vehicle-card{padding:0;overflow:hidden}
.vehicle-top{padding:32px 24px 28px;display:flex;flex-direction:column;align-items:center;gap:20px;border-bottom:1px solid var(--border)}
.vehicle-name{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(22px,3vw,30px);text-transform:uppercase;text-align:center;margin-top:4px;line-height:1.15}
.masked-note{font-size:11.5px;color:var(--muted);font-style:italic;text-align:center}
.vehicle-data{padding:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:560px){.vehicle-data{grid-template-columns:repeat(2,1fr)}}
.dl-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.dl-label.underline{text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:3px}
.dl-value{font-weight:700;font-size:15px}

/* Mercosul plate */
.mercosul-plate{width:100%;max-width:320px;background:#fff;border:2px solid var(--fg);border-radius:10px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.08)}
.plate-strip{background:#1d4ed8;color:#fff;padding:6px 10px;display:flex;align-items:center;justify-content:space-between;font-size:10px;font-weight:700;letter-spacing:.06em}
.plate-strip .br-flag{width:18px;height:14px;border-radius:2px;background:linear-gradient(135deg,#10b981,#facc15);display:inline-grid;place-items:center;font-size:7px;color:#1e3a5f;font-weight:800}
.plate-number{padding:10px 12px;text-align:center;font-family:'Sora',monospace;font-weight:800;letter-spacing:.18em;font-size:clamp(28px,5vw,38px);color:var(--fg)}
.plate-foot{padding:0 12px 6px;font-size:10px;font-weight:700;color:var(--fg)}

/* Locked items */
.locked-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
@media(max-width:780px){.locked-grid{grid-template-columns:repeat(2,1fr)}}
.locked-item{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;font-size:13px;font-weight:600}
.locked-item svg{flex-shrink:0}
.locked-item .lock{color:var(--muted);margin-left:auto}
.locked-item .ic{color:var(--accent)}

/* Plans on result page */
.plans-result{margin-top:6px}

/* ========== Modal ========== */
.modal-overlay{position:fixed;inset:0;z-index:60;background:rgba(26,42,74,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:grid;place-items:center;padding:16px}
.modal{background:var(--card);border-radius:24px;box-shadow:0 30px 80px -20px rgba(0,0,0,.4);width:100%;max-width:440px;overflow:hidden;max-height:92vh;display:flex;flex-direction:column}
.modal-header{background:var(--gradient-primary);color:#fff;padding:20px;display:flex;align-items:center;justify-content:space-between}
.modal-title{font-family:'Sora',sans-serif;font-weight:800;font-size:18px;margin-top:2px}
.modal-close{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;transition:background .15s}
.modal-close:hover{background:rgba(255,255,255,.22)}
.modal-body{padding:22px;overflow-y:auto}
.total{text-align:center;margin-bottom:20px}
.total-value{font-family:'Sora',sans-serif;font-weight:800;font-size:38px}
.modal-body label{display:block;margin-bottom:12px;font-size:13px;font-weight:700}
.modal-body label input{width:100%;margin-top:6px;border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:11px 14px;font-size:14px;font-weight:500;outline:none;transition:border-color .15s}
.modal-body label input:focus{border-color:var(--accent)}
.btn-primary{width:100%;background:var(--gradient-primary);color:#fff;border-radius:12px;padding:14px;font-weight:700;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-primary);transition:filter .15s}
.btn-primary:hover:not(:disabled){filter:brightness(1.08)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.btn-dark{width:100%;background:var(--fg);color:#fff;border-radius:12px;padding:14px;font-weight:700;font-size:15px}
.btn-dark:hover{background:#0f1d35}
.qr-box{background:var(--surface);border-radius:16px;padding:18px;display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:14px}
.qr-box img{width:200px;height:200px;background:#fff;border-radius:8px}
.pix-code{display:flex;align-items:center;gap:8px;background:var(--surface);border-radius:10px;padding:10px}
.pix-code code{flex:1;font-size:11px;font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pix-code button{padding:6px 10px;border-radius:6px;background:#fff;border:1px solid var(--border);font-size:12px;font-weight:600}
.paid-box{text-align:center;padding:10px 0}
.paid-box .check{width:64px;height:64px;border-radius:50%;background:rgba(22,163,74,.12);color:var(--success);display:grid;place-items:center;margin:0 auto 14px}
.paid-box h3{font-family:'Sora',sans-serif;font-weight:800;font-size:20px;margin-bottom:6px}
.paid-box p{color:var(--muted);font-size:14px;margin-bottom:18px}

/* FAQ / sobre / contato shared */
.page-hero{background:var(--gradient-primary);color:#fff;padding:64px 20px;text-align:center}
.page-hero h1{color:#fff;font-size:clamp(32px,5vw,48px);font-weight:800;margin-bottom:10px}
.page-hero p{color:rgba(255,255,255,.85)}
.faq-list{max-width:740px;margin:0 auto;padding:50px 20px;display:flex;flex-direction:column;gap:12px}
details.faq-item{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-card);overflow:hidden}
details.faq-item summary{cursor:pointer;padding:18px 22px;font-weight:700;display:flex;justify-content:space-between;align-items:center;list-style:none}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item summary::after{content:"⌄";font-size:18px;color:var(--muted);transition:transform .2s}
details.faq-item[open] summary::after{transform:rotate(180deg)}
details.faq-item .a{padding:0 22px 20px;color:var(--muted);line-height:1.6}
