/* ==========================================================================
   Trasmontano | Queiroz Beneficios - Design System
   Cabecalho BRANCO (regra absoluta). Vermelho Trasmontano so em CTA/detalhes.
   System fonts, sem libs externas. AA >= 4.5:1 em texto sobre cor.
   ========================================================================== */
:root{
  --primary:#C8102E;        /* vermelho CTA (texto branco passa AA) */
  --primary-dark:#9E0C24;   /* hover / titulos destaque */
  --primary-bright:#E83030; /* vermelho do logo - detalhes */
  --primary-soft:#FCE9EC;   /* fundos suaves */
  --green:#387068;          /* verde Queiroz (corretora) */
  --green-dark:#2B564F;
  --header-bg:#FFFFFF;
  --text:#232323;
  --muted:#5F6368;
  --bg:#FFFFFF;
  --bg-soft:#F5F6F8;
  --border:#E5E7EB;
  --success:#1FAD53;
  --whats:#25D366;
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 1px 3px rgba(16,24,40,.06),0 1px 2px rgba(16,24,40,.04);
  --shadow-md:0 6px 20px rgba(16,24,40,.10);
  --maxw:1140px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font);font-size:17px;line-height:1.65;color:var(--text);background:var(--bg);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary-dark);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.2;color:#1a1a1a;margin:0 0 .5em}
h1{font-size:2.1rem;letter-spacing:-.02em}
h2{font-size:1.65rem;letter-spacing:-.01em}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
section{padding:56px 0}
.bg-soft{background:var(--bg-soft)}
.center{text-align:center}
.muted{color:var(--muted)}
.eyebrow{display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:.6rem}
.lead{font-size:1.18rem;color:#3a3a3a}
.skip{position:absolute;left:-999px;top:auto}
.skip:focus{left:12px;top:12px;background:#fff;padding:10px 16px;border:2px solid var(--primary);border-radius:8px;z-index:9999}
:focus-visible{outline:3px solid #1a73e8;outline-offset:2px;border-radius:4px}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;justify-content:center;font:inherit;font-weight:700;font-size:1rem;
  padding:14px 24px;border-radius:999px;border:2px solid transparent;cursor:pointer;min-height:48px;transition:background .15s,transform .15s,box-shadow .15s;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);color:#fff}
.btn-whats{background:var(--whats);color:#08331c}
.btn-whats:hover{background:#1ebe5a;color:#08331c}
.btn-ghost{background:#fff;color:var(--primary-dark);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--primary);background:var(--primary-soft)}
.btn-lg{padding:16px 30px;font-size:1.05rem}
.btn svg{width:20px;height:20px;flex:0 0 auto}

/* ---- Header (BRANCO) ---- */
.site-header{position:sticky;top:0;z-index:100;background:var(--header-bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow)}
.hd-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;max-width:var(--maxw);margin:0 auto;padding:10px 20px}
.hd-logos{display:flex;align-items:center;gap:14px;flex:0 0 auto}
.hd-logos a{display:flex;align-items:center}
.hd-logos .sep{width:1px;height:30px;background:var(--border)}
.logo-tras{height:38px;width:auto}
.logo-queiroz{height:30px;width:auto}
.hd-nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.hd-nav a{color:#2b2b2b;font-weight:600;font-size:.96rem;padding:9px 11px;border-radius:8px;white-space:nowrap}
.hd-nav a:hover{background:var(--bg-soft);text-decoration:none;color:var(--primary-dark)}
.hd-cta{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.hd-cta .btn{padding:10px 18px;min-height:42px;font-size:.95rem}
.nav-toggle{display:none;background:none;border:1px solid var(--border);border-radius:8px;width:46px;height:44px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle svg{width:24px;height:24px}
@media(max-width:1000px){
  .hd-nav{display:none}
  .nav-toggle{display:inline-flex}
  .hd-cta .btn-wa-text{display:none}
}
/* mobile drawer */
.mob-nav{display:none;border-top:1px solid var(--border);background:#fff}
.mob-nav.open{display:block}
.mob-nav a{display:block;padding:14px 20px;border-bottom:1px solid var(--border);color:#2b2b2b;font-weight:600}
.mob-nav a:hover{background:var(--bg-soft);text-decoration:none}

/* ---- Hero ---- */
.hero{background:linear-gradient(160deg,#fff 0%,#fff 40%,var(--primary-soft) 100%);padding:64px 0 56px;border-bottom:1px solid var(--border)}
.hero h1{font-size:2.5rem;margin-bottom:.5rem}
.hero .lead{max-width:620px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.hero-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:26px}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:24px;font-size:.92rem;color:var(--muted)}
.hero-trust b{color:var(--text)}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;gap:28px}.hero h1{font-size:2rem}.hero{padding:40px 0}}

/* ---- Cards / grid ---- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.card h3{margin-top:.2rem}
.card .ico{width:46px;height:46px;border-radius:11px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.card .ico svg{width:24px;height:24px}
.card-link{display:block;transition:box-shadow .15s,transform .15s,border-color .15s}
.card-link:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none;border-color:#d8c2c6}
.tag{display:inline-block;background:var(--primary-soft);color:var(--primary-dark);font-size:.78rem;font-weight:700;padding:3px 10px;border-radius:999px;margin:2px 4px 2px 0}
.tag-green{background:#e7f1ee;color:var(--green-dark)}

/* ---- Answer block (featured snippet / IA) ---- */
.answer{background:#fff;border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:var(--radius-sm);padding:20px 22px;box-shadow:var(--shadow);font-size:1.08rem}
.answer strong{color:var(--primary-dark)}

/* ---- Tables ---- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
table.price{border-collapse:collapse;width:100%;min-width:520px;font-size:.95rem;background:#fff}
table.price caption{text-align:left;padding:14px 16px;font-weight:700;background:var(--bg-soft);border-bottom:1px solid var(--border)}
table.price th,table.price td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--border)}
table.price thead th{background:#fafbfc;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
table.price tbody tr:hover{background:var(--bg-soft)}
table.price td.val{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}

/* ---- Disclaimer / aviso ---- */
.disclaimer{font-size:.86rem;color:var(--muted);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;margin-top:14px}
.aviso-corretora{font-size:.84rem;color:var(--muted);line-height:1.55}

/* ---- Simulator ---- */
.sim{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:26px}
.sim .field{margin-bottom:16px}
.sim label{display:block;font-weight:700;font-size:.92rem;margin-bottom:6px}
.sim select,.sim input,form.lead-form input,form.lead-form select,form.lead-form textarea{
  width:100%;padding:13px 14px;font:inherit;font-size:1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;min-height:48px}
.sim select:focus,.sim input:focus{border-color:var(--primary);outline:none}
.sim-result{margin-top:18px;padding:20px;border-radius:var(--radius-sm);background:var(--primary-soft);border:1px solid #f0cdd3;display:none}
.sim-result.show{display:block}
.sim-result .big{font-size:2rem;font-weight:800;color:var(--primary-dark);font-variant-numeric:tabular-nums}
.radio-row{display:flex;flex-wrap:wrap;gap:8px}
.radio-row label{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--border);border-radius:999px;padding:9px 16px;cursor:pointer;font-weight:600;font-size:.92rem;min-height:44px;background:#fff}
.radio-row input{width:auto;min-height:auto;margin:0}
.radio-row label:has(input:checked){border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark)}

/* ---- Forms ---- */
form.lead-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){form.lead-form .row{grid-template-columns:1fr}}
form.lead-form .field{margin-bottom:14px}
form.lead-form label{font-weight:700;font-size:.9rem;display:block;margin-bottom:6px}
form.lead-form textarea{min-height:96px;resize:vertical}
.form-note{font-size:.82rem;color:var(--muted);margin-top:10px}
.form-ok{display:none;background:#e7f7ee;border:1px solid #b6e6c8;color:#0c5c30;border-radius:var(--radius-sm);padding:16px}
.form-ok.show{display:block}

/* ---- FAQ accordion ---- */
.faq{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.faq details{border-bottom:1px solid var(--border)}
.faq details:last-child{border-bottom:none}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:700;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--primary);font-weight:400;flex:0 0 auto}
.faq details[open] summary::after{content:"\2212"}
.faq summary:hover{background:var(--bg-soft)}
.faq .faq-a{padding:0 22px 20px;color:#3a3a3a}

/* ---- Specialist block ---- */
.especialista{display:flex;gap:20px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.especialista img{width:84px;height:84px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:3px solid var(--primary-soft)}
@media(max-width:560px){.especialista{flex-direction:column;text-align:center}}

/* ---- Breadcrumb ---- */
.crumb{font-size:.85rem;color:var(--muted);padding:14px 0}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--primary-dark)}

/* ---- City chips ---- */
.cidades-list{display:flex;flex-wrap:wrap;gap:10px}
.cidades-list a{background:#fff;border:1px solid var(--border);border-radius:999px;padding:9px 16px;font-weight:600;font-size:.92rem;color:#2b2b2b}
.cidades-list a:hover{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark);text-decoration:none}

/* ---- Footer ---- */
.site-footer{background:#16201e;color:#cfd6d3;padding:48px 0 26px;font-size:.93rem}
.site-footer h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px}
@media(max-width:820px){.ft-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ft-grid{grid-template-columns:1fr}}
.site-footer a{color:#cfd6d3}
.site-footer a:hover{color:#fff}
.ft-logo{height:34px;width:auto;margin-bottom:14px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:8px}
.ft-bottom{border-top:1px solid #2c3a37;margin-top:34px;padding-top:18px;color:#9aa6a2;font-size:.84rem;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ---- WhatsApp float ---- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:200;background:var(--whats);color:#08331c;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.25);transition:transform .15s}
.wa-float:hover{transform:scale(1.06)}
.wa-float svg{width:32px;height:32px}

/* ---- Utilities ---- */
.mt0{margin-top:0}.mb0{margin-bottom:0}
.stack>*+*{margin-top:14px}
.pill-list{list-style:none;padding:0;margin:14px 0}
.pill-list li{position:relative;padding-left:30px;margin-bottom:10px}
.pill-list li::before{content:"";position:absolute;left:0;top:4px;width:18px;height:18px;border-radius:50%;background:var(--primary-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C8102E' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat}
.divider{height:1px;background:var(--border);border:0;margin:30px 0}
.note-strong{background:#fff7e6;border:1px solid #ffe2a8;border-radius:var(--radius-sm);padding:14px 16px;font-size:.92rem}
