/* cepddd — design system (esmeralda; Plus Jakarta Sans + JetBrains Mono).
   Extraido dos prototipos docs/ux/. Header com busca + corpo 2 colunas (sidebar
   a esquerda) + footer cnpjcpf. Mobile-first. */
:root{
  --em-900:#063d2b; --em-700:#0a7a52; --em-600:#0e8b5d; --em-500:#15a861; --em-300:#3ddc97;
  --lime:#c7f25a; --coral:#fb7185; --mint-50:#eafaf1; --mint-100:#d8f3e4;
  --ink:#0c1f18; --muted:#5b7268; --bg:#f6faf8; --card:#fff; --line:#e3ede8;
  --grad:linear-gradient(135deg,#0a7a52 0%,#15a861 55%,#1fbf74 100%);
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.58;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--em-500)}

/* ===== HEADER + busca ===== */
header{position:sticky;top:0;z-index:40;background:rgba(246,250,248,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;gap:24px;height:64px}
.brand{font-weight:800;font-size:20px;letter-spacing:-.02em}
.brand b{color:var(--em-500)}
nav.top{display:flex;gap:20px;font-size:14.5px;font-weight:600}
nav.top a{color:var(--muted);transition:color .15s}
nav.top a:hover{color:var(--em-700)}
.hsearch{margin-left:auto;position:relative}
.hsearch form{display:flex;align-items:center;background:#fff;border:1.5px solid var(--line);border-radius:11px;padding:3px 3px 3px 12px;transition:border-color .15s}
.hsearch form:focus-within{border-color:var(--em-500)}
.hsearch input{border:0;outline:0;font:600 14px var(--sans);color:var(--ink);width:200px;background:transparent}
.hsearch button{background:var(--em-700);color:#fff;border:0;border-radius:8px;width:34px;height:32px;cursor:pointer;font-size:15px}
.hsearch button:hover{background:var(--em-900)}
.hresult{position:absolute;top:46px;right:0;width:330px;background:#fff;border:1px solid var(--line);border-radius:13px;box-shadow:0 20px 44px -20px rgba(6,61,43,.5);padding:16px;font-size:14.5px;z-index:50}
.hresult[hidden]{display:none}
.hresult .mono{font-family:var(--mono);background:var(--mint-50);color:var(--em-700);padding:1px 7px;border-radius:6px}
.hresult a.more{display:inline-block;margin-top:10px;font-weight:700;color:var(--em-700);font-size:13.5px}

/* ===== HERO (home) ===== */
.hero{background:var(--grad);color:#fff;padding:66px 0 92px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-130px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(199,242,90,.30),transparent 70%)}
.hero .eyebrow{color:#bff0d4}
.hero h1{font-size:clamp(34px,5.2vw,52px);line-height:1.05;letter-spacing:-.03em;font-weight:800;margin:14px 0 16px;max-width:15ch}
.hero h1 i{font-style:italic;color:var(--lime);font-weight:700}
.hero p.sub{font-size:clamp(16px,2vw,19px);max-width:52ch;color:#e4f6ec;margin:0 0 26px}
.lookup{display:flex;gap:10px;max-width:560px;background:#fff;border-radius:16px;padding:8px;box-shadow:0 18px 40px -18px rgba(3,40,28,.6)}
.lookup input{flex:1;border:0;outline:0;font:600 16px var(--sans);color:var(--ink);padding:12px 14px;background:transparent}
.lookup .b{background:var(--em-700);color:#fff;border:0;border-radius:11px;padding:0 20px;font:700 15px var(--sans);cursor:pointer}
.lookup .b:hover{background:var(--em-900)}
.ans{margin-top:14px;min-height:22px;font-size:15px;color:#eafaf1}
.ans b{color:#fff}
.ans .mono{font-family:var(--mono);background:rgba(255,255,255,.16);padding:2px 8px;border-radius:7px}
.trust{margin-top:10px;font-size:13px;color:#bfe6cf}

/* ===== 4 BOXES (home) ===== */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:-46px;position:relative;z-index:5}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:6px;transition:transform .16s,box-shadow .16s,border-color .16s}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 32px -20px rgba(6,61,43,.4);border-color:var(--em-300)}
.tag{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--em-500);letter-spacing:.04em}
.card h3{margin:2px 0 0;font-size:16.5px;font-weight:700}
.card p{margin:0;color:var(--muted);font-size:13.5px;flex:1}
.card .go{font-weight:700;color:var(--em-700);font-size:14px}

/* ===== PAGE HEAD (conteudo) ===== */
.phead{background:linear-gradient(180deg,#eef8f2,#f6faf8);border-bottom:1px solid var(--line);padding:20px 0 34px}
.crumb{font-size:13px;color:var(--muted);display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}
.crumb a{color:var(--em-600);font-weight:600}
.crumb span.sep{color:#aebdb6}
.phead h1{font-size:clamp(27px,4vw,40px);letter-spacing:-.025em;line-height:1.08;margin:6px 0 14px;font-weight:800}
.phead h1 .mono{font-family:var(--mono);color:var(--em-600)}
.answer{background:#fff;border:1px solid var(--line);border-left:4px solid var(--em-500);border-radius:14px;padding:18px 20px;max-width:760px}
.answer .big{font-size:17px;font-weight:600}
.answer .code{font-family:var(--mono);font-weight:700;color:#fff;background:var(--em-600);padding:3px 11px;border-radius:8px;font-size:17px}
.factrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.fact{background:#fff;border:1px solid var(--line);border-radius:11px;padding:10px 16px}
.fact .n{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--em-700)}
.fact .l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}

/* ===== AdSense (BLUEPRINT §8): contêiner height:0 + guarda do seletor irmão ===== */
.ad-slot{height:0;overflow:hidden;margin:0}
.ad-slot + .card{margin-top:0}
.ad{margin:22px 0}
.ad .slot{border:1px dashed var(--line);border-radius:11px;min-height:90px;display:grid;place-items:center;color:#aebdb6;font-size:11px;letter-spacing:.14em;text-transform:uppercase}

/* ===== BODY 2 COLUNAS (sidebar à ESQUERDA) ===== */
.layout{display:grid;grid-template-columns:320px 1fr;gap:36px;padding:40px 0}
.side{order:-1;align-self:start;position:sticky;top:84px;display:flex;flex-direction:column;gap:18px}
.main h2{font-size:23px;letter-spacing:-.02em;margin:0 0 4px;font-weight:800}
.main h2+.note{color:var(--muted);font-size:14.5px;margin:0 0 16px}
.main .note a,.prose a,.groups a,table.data a{color:var(--em-700);font-weight:600}
.main .note a:hover,.prose a:hover{text-decoration:underline}
.block{margin-bottom:44px}

/* tabela */
table.data{width:100%;border-collapse:collapse;font-size:14.5px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
table.data th{text-align:left;background:var(--mint-50);color:var(--em-700);font-size:12px;letter-spacing:.05em;text-transform:uppercase;padding:11px 14px}
table.data td{padding:11px 14px;border-top:1px solid var(--line)}
table.data tr:hover td{background:#f8fcfa}
table.data .code{font-family:var(--mono);font-weight:700;color:var(--em-700)}

/* grade 67 */
.grid67{display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:7px}
.g67{aspect-ratio:1;border:1px solid var(--line);border-radius:9px;display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:15px;color:var(--em-700);background:#fff;transition:.13s}
.g67:hover{background:var(--em-600);color:#fff;border-color:var(--em-600)}

/* lista de cidades */
.citylist{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.citylist a{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 13px;font-size:14px;color:var(--ink);display:flex;justify-content:space-between;align-items:center}
.citylist a:hover{border-color:var(--em-300);background:#f0fbf5}
.citylist a .pop{font-size:11.5px;color:var(--muted);font-family:var(--mono)}

/* atalhos (home como-ligar) */
.atalhos{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.atalho{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;transition:border-color .14s}
.atalho:hover{border-color:var(--em-300)}
.atalho .em{font-size:22px;line-height:1}
.atalho b{display:block;color:var(--ink);font-size:14.5px}
.atalho span.d{color:var(--muted);font-size:13px}

/* steps (como ligar) */
.steps{counter-reset:s;display:flex;flex-direction:column;gap:10px}
.step{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.step::before{counter-increment:s;content:counter(s);flex:0 0 28px;height:28px;border-radius:8px;background:var(--mint-50);color:var(--em-700);font-family:var(--mono);font-weight:700;display:grid;place-items:center;font-size:14px}
.step b{font-size:14.5px}
.step .mono{font-family:var(--mono);color:var(--em-700)}
.step span.d{display:block;color:var(--muted);font-size:13px}
.dialbox{font-family:var(--mono);font-size:15px;background:var(--em-900);color:#dff6ea;border-radius:12px;padding:16px 18px;margin-top:6px}
.dialbox .hl{color:var(--lime);font-weight:700}
.note-amber{background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:14px 16px;font-size:14px;color:#7c3a12}
.note-amber b{color:#9a3412}
.note-amber a{color:#b45309;font-weight:700}

/* prose */
.prose p{font-size:15.5px;color:#28392f;margin:0 0 14px}
.prose strong{color:var(--ink)}

/* entenda */
.groups{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.groups h4{font-size:13px;letter-spacing:.04em;color:var(--ink);margin:0 0 10px;padding-bottom:8px;border-bottom:2px solid var(--mint-100)}
.groups ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:14px}

/* faq */
.faq details{border-bottom:1px solid var(--line);padding:4px 0}
.faq summary{cursor:pointer;font-weight:700;padding:13px 0;list-style:none;font-size:15px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--em-500);font-weight:800}
.faq details[open] summary::after{content:"–"}
.faq p{margin:0 0 14px;color:var(--muted);font-size:14.5px}

/* sidebar widgets */
.swid{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px}
.swid h3{margin:0 0 12px;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.minirow{display:flex;gap:8px}
.minirow input{flex:1;border:1.5px solid var(--line);border-radius:10px;padding:10px 12px;font:600 14px var(--sans);outline:0}
.minirow input:focus{border-color:var(--em-500)}
.minirow button{background:var(--em-700);color:#fff;border:0;border-radius:10px;padding:0 15px;font:700 13.5px var(--sans);cursor:pointer}
.minirow button:hover{background:var(--em-900)}
.minians{margin-top:10px;font-size:13.5px;color:var(--ink)}
.minians .mono{font-family:var(--mono);background:var(--mint-50);color:var(--em-700);padding:1px 6px;border-radius:6px}
.related{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;font-size:14px}
.related a{color:var(--em-700);font-weight:600;display:flex;justify-content:space-between}
.related a:hover{text-decoration:underline}
.related .mono{font-family:var(--mono);color:var(--muted);font-weight:500}
.bigstats .row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}
.bigstats .n{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--ink)}
.bigstats .t{font-size:13px;color:var(--muted);text-align:right}
.stat{display:flex;justify-content:space-between;align-items:baseline;padding:9px 0;border-bottom:1px dashed var(--line)}
.stat:last-child{border-bottom:0}
.stat .v{font-family:var(--mono);font-weight:700;color:var(--em-700)}
.stat .l{font-size:13.5px;color:var(--muted)}
.cepwid{background:linear-gradient(150deg,#063d2b,#0a7a52);color:#fff}
.cepwid h3{color:#bff0d4}
.cepwid p{margin:0 0 12px;font-size:13.5px;color:#cdeede}
.cepwid a.b{display:inline-block;background:var(--lime);color:var(--em-900);font-weight:700;font-size:13.5px;padding:8px 14px;border-radius:10px}
.cepwid a.b:hover{background:#d6f97a}

/* ===== Formulário "fale conosco" (/contato/) — POST ao mailer da rede ===== */
.fc-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:28px;align-items:start}
@media (max-width:760px){.fc-grid{grid-template-columns:1fr}}
.fc-form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px}
.fc-form h2{margin:0 0 4px}
.fc-field{margin-bottom:14px;display:flex;flex-direction:column;gap:6px}
.fc-field label{font-size:13px;font-weight:600;color:var(--muted)}
.fc-field input,.fc-form textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:10px 12px;font:500 15px var(--sans);color:var(--ink);background:var(--bg);outline:0}
.fc-field input:focus,.fc-form textarea:focus{border-color:var(--em-500)}
.fc-form textarea{resize:vertical;min-height:120px;line-height:1.5}
.fc-btn{background:var(--em-700);color:#fff;border:0;border-radius:11px;padding:11px 20px;font:700 15px var(--sans);cursor:pointer;transition:background .15s}
.fc-btn:hover{background:var(--em-900)}
.fc-btn:disabled{opacity:.6;cursor:default}
.fc-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.fc-status{margin:12px 0 0;font-size:14px;min-height:20px}
.fc-status.ok{color:var(--em-700);font-weight:600}
.fc-status.err{color:var(--coral);font-weight:600}

/* ===== FOOTER ===== */
footer{background:#06281d;color:#bcd9cc;padding:48px 0 30px;margin-top:14px}
footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
footer .brand{color:#fff;font-size:20px}
footer .brand b{color:var(--em-300)}
footer p.tag{font-size:13.5px;color:#9dc6b4;max-width:34ch;margin:10px 0 0}
footer h5{color:#fff;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 12px}
footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;font-size:14px}
footer ul a{color:#bcd9cc}
footer ul a:hover{color:var(--em-300)}
.foot-base{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;color:#8fbaa6}
.foot-base a{color:var(--em-300)}

:focus-visible{outline:3px solid var(--lime);outline-offset:2px;border-radius:6px}
@media (max-width:980px){
  .layout{grid-template-columns:1fr}
  .side{order:0;position:static;flex-direction:row;flex-wrap:wrap}
  .side .swid{flex:1;min-width:240px}
  .groups{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(2,1fr)}
  .citylist{grid-template-columns:repeat(2,1fr)}
  nav.top{display:none}
  .hsearch input{width:150px}
}
@media (max-width:560px){
  .cards{grid-template-columns:1fr}
  .atalhos{grid-template-columns:1fr}
  .side .swid{min-width:100%}
  .citylist{grid-template-columns:1fr}
  .hsearch{display:none}
  footer .cols{grid-template-columns:1fr 1fr}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
