/* ============================================================
   melhores-casas — Design System v2 (Nexin-led, GLOBAL)
   Marcellus (display) + DM Sans (UI) + lima #BFF747 + near-black.
   Re-skin das classes existentes (81 páginas) sem mexer no HTML.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Marcellus&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

:root{
  --ink:#121212; --ink-soft:#5B606A; --soft:#5B606A; --ink-faint:#9AA0A8; --gray:#797E88;
  --paper:#F6F7F2; --surface:#FFFFFF; --surface-2:#EEF0E8;
  --line:#E2E6DC; --line-strong:#D3D8CC;
  --brand:#0E7C5A; --brand-ink:#0A5B42; --brand-wash:#E7F2EC;
  --lime:#BFF747; --lime-deep:#A9E62E; --lime-ink:#1C2208; --lime-wash:#EEF9D2;
  --score:#C8841A; --score-ink:#9A6310; --score-wash:#FAF0DC;
  --alert:#C0473B; --alert-wash:#F7E7E5; --info:#2A5DB0;
  --serif:'Marcellus', Georgia, 'Times New Roman', serif;
  --sans:'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono:ui-monospace,'SFMono-Regular','Menlo','Consolas',monospace;
  --t-xs:.75rem; --t-sm:.875rem; --t-base:1rem;
  --t-lg:clamp(1.1rem,1.04rem + .3vw,1.28rem);
  --t-xl:clamp(1.35rem,1.15rem + .8vw,1.7rem);
  --t-2xl:clamp(1.8rem,1.4rem + 1.6vw,2.6rem);
  --t-3xl:clamp(2.2rem,1.6rem + 2.6vw,3.4rem);
  --t-4xl:clamp(2.7rem,1.8rem + 4vw,4.6rem);
  --sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.5rem;--sp-6:2rem;--sp-7:3rem;--sp-8:4rem;--sp-9:6rem;
  --r-sm:8px;--r:12px;--r-lg:18px;--r-pill:999px;
  --wrap:1200px;--wrap-narrow:760px;
  --shadow:0 1px 2px rgba(18,18,18,.04),0 12px 30px -16px rgba(18,18,18,.16);
  --shadow-lg:0 2px 6px rgba(18,18,18,.06),0 30px 60px -24px rgba(18,18,18,.2);
}

/* base */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink-soft);font-family:var(--sans);font-size:var(--t-base);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.08;letter-spacing:-.01em;color:var(--ink);margin:0 0 .4em}
h1{font-size:var(--t-3xl)} h2{font-size:var(--t-2xl)} h3{font-size:var(--t-xl)} h4{font-size:var(--t-lg)}
p{margin:0 0 1rem}
a{color:var(--brand-ink);text-decoration:none} a:hover{color:var(--ink)}
.prose a{text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--brand) 35%,transparent);text-underline-offset:3px}
img{max-width:100%;height:auto;display:block}
hr{border:0;border-top:1px solid var(--line);margin:var(--sp-6) 0}
:focus-visible{outline:2.5px solid var(--lime-deep);outline-offset:2px;border-radius:3px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* layout */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:24px}
.wrap--narrow{max-width:var(--wrap-narrow)}
.section{padding-block:var(--sp-8)} .section--tight{padding-block:var(--sp-6)}
.grid{display:grid;gap:var(--sp-5)}
.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}
.stack>*+*{margin-top:var(--sp-4)}
.cluster-row{display:flex;flex-wrap:wrap;gap:var(--sp-3);align-items:center}
@media(max-width:900px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* marca / labels */
.eyebrow{font-family:var(--mono);font-size:var(--t-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;margin:0 0 var(--sp-3)}
.eyebrow--brand{color:var(--brand)}
.lead{font-size:var(--t-lg);color:var(--ink-soft);line-height:1.55}
.kicker-rule{display:inline-block;width:30px;height:8px;background:var(--lime);vertical-align:middle;margin-right:.6em;border-radius:3px}
.muted{color:var(--ink-soft)} .center{text-align:center} .mt-0{margin-top:0}
.tag{font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--brand);font-weight:500}

/* botões */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:600;font-size:var(--t-sm);padding:.78em 1.4em;border-radius:var(--r-pill);border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:.16s ease;white-space:nowrap}
.btn--primary{background:var(--lime);color:var(--lime-ink)} .btn--primary:hover{background:var(--lime-deep);color:var(--lime-ink);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)} .btn--ghost:hover{border-color:var(--ink);background:var(--surface)}
.btn--dark{background:var(--ink);color:#fff} .btn--dark:hover{background:#000;color:#fff}
.btn--sm{padding:.5em .95em;font-size:var(--t-xs)}

/* pílulas */
.pill{display:inline-flex;align-items:center;gap:.4em;font-family:var(--mono);font-size:var(--t-xs);letter-spacing:.04em;padding:.36em .75em;border-radius:var(--r-pill);border:1px solid var(--line-strong);color:var(--ink-soft);background:var(--surface)}
.pill--verified{color:var(--lime-ink);background:var(--lime-wash);border-color:var(--lime-deep)}
.pill--verified .dot{width:7px;height:7px;border-radius:50%;background:var(--brand)}
.pill--alert{color:var(--alert);background:var(--alert-wash);border-color:color-mix(in srgb,var(--alert) 25%,transparent)}

/* score */
.score-chip{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;min-width:62px;padding:.5em .6em;border-radius:var(--r);background:var(--score-wash);border:1px solid color-mix(in srgb,var(--score) 30%,transparent)}
.score-chip .n{font-family:var(--serif);font-size:var(--t-xl);color:var(--score-ink);line-height:1}
.score-chip .max{font-family:var(--mono);font-size:10px;letter-spacing:.05em;color:var(--score-ink);opacity:.7;margin-top:2px}
.score-chip--lg{min-width:92px;padding:.7em} .score-chip--lg .n{font-size:var(--t-3xl)}
.subscores{display:grid;gap:.55rem}
.subscore{display:grid;grid-template-columns:7.5rem 1fr 2.2rem;align-items:center;gap:.6rem;font-size:var(--t-sm)}
.subscore .label{color:var(--ink-soft)}
.subscore .bar{height:7px;border-radius:var(--r-pill);background:var(--surface-2);overflow:hidden}
.subscore .bar>i{display:block;height:100%;border-radius:inherit;background:var(--brand)}
.subscore .val{font-family:var(--mono);font-size:var(--t-xs);color:var(--ink);text-align:right}

/* cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-5);box-shadow:var(--shadow);transition:.18s ease}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.card--flat{box-shadow:none}.card--flat:hover{transform:none;box-shadow:var(--shadow)}
.card h3{margin-bottom:.3em}
.card .meta{font-family:var(--mono);font-size:var(--t-xs);color:var(--ink-faint);letter-spacing:.04em}

/* cápsula */
.capsule{position:relative;background:var(--surface);border:1px solid var(--line-strong);border-left:4px solid var(--lime);border-radius:var(--r);padding:var(--sp-5) var(--sp-5) var(--sp-4);margin:var(--sp-5) 0}
.capsule .eyebrow{margin-bottom:var(--sp-2)}
.capsule p{font-size:var(--t-lg);line-height:1.55;margin:0;color:var(--ink)}
.capsule p strong{font-weight:600}

/* tabela ranking */
.rank-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;font-size:var(--t-sm)}
.rank-table caption{caption-side:top;text-align:left;font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);padding-bottom:var(--sp-3)}
.rank-table th,.rank-table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.rank-table thead th{font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);font-weight:500;background:var(--surface-2)}
.rank-table tbody tr:last-child td{border-bottom:0}
.rank-table tbody tr:hover{background:var(--lime-wash)}
.rank-table .rank-n{font-family:var(--serif);font-size:var(--t-lg);color:var(--ink-faint);width:2ch}
.rank-table .casa{display:flex;align-items:center;gap:.7rem;font-weight:600;color:var(--ink)}
.rank-table .logo{width:34px;height:34px;border-radius:9px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--serif);color:var(--ink-soft);flex:none}
.rank-table .yes{color:var(--brand)} .rank-table .no{color:var(--ink-faint)}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* FAQ */
.faq details{border-bottom:1px solid var(--line);padding:.2rem 0}
.faq summary{font-family:var(--serif);font-size:var(--t-lg);cursor:pointer;list-style:none;padding:var(--sp-4) 2rem var(--sp-4) 0;position:relative;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';position:absolute;right:.2rem;top:50%;transform:translateY(-50%);font-family:var(--sans);font-size:1.3rem;color:var(--brand);transition:.2s}
.faq details[open] summary::after{content:'–'}
.faq details[open] summary{padding-bottom:var(--sp-2)}
.faq .answer{color:var(--ink-soft);padding-bottom:var(--sp-4);max-width:62ch}

/* prosa */
.prose{font-size:1.075rem;line-height:1.78;color:#23262C}
.prose>p,.prose>ul,.prose>ol{max-width:68ch}
.prose h2{margin-top:var(--sp-7)} .prose h3{margin-top:var(--sp-6)}
.prose ul,.prose ol{padding-left:1.3em} .prose li{margin:.4em 0}
.pullquote{font-family:var(--serif);font-size:var(--t-xl);line-height:1.4;color:var(--ink);border-top:2px solid var(--lime);border-bottom:2px solid var(--lime);padding:var(--sp-5) 0;margin:var(--sp-6) 0;max-width:none}
.takeaways{background:var(--surface-2);border-radius:var(--r-lg);padding:var(--sp-5);margin:var(--sp-6) 0}
.takeaways ul{list-style:none;padding:0;margin:0}
.takeaways li{padding-left:1.7em;position:relative;margin:.5em 0;color:var(--ink)}
.takeaways li::before{content:'✓';position:absolute;left:0;color:var(--brand);font-weight:700}

/* byline / meta */
.byline{display:flex;align-items:center;gap:.8rem;font-size:var(--t-sm);color:var(--ink-soft);margin:var(--sp-4) 0}
.byline .avatar{width:42px;height:42px;border-radius:50%;background:var(--surface-2);border:1px solid var(--line);flex:none;display:grid;place-items:center;font-family:var(--serif);color:var(--ink-soft)}
.byline b{color:var(--ink);font-weight:600}
.dot-sep::before{content:'·';margin:0 .5em;color:var(--ink-faint)}

/* TOC */
.toc{position:sticky;top:var(--sp-5);align-self:start;font-size:var(--t-sm)}
.toc .eyebrow{margin-bottom:var(--sp-3)}
.toc ul{list-style:none;padding:0;margin:0;border-left:1px solid var(--line)}
.toc a{display:block;padding:.35rem 0 .35rem 1rem;margin-left:-1px;border-left:2px solid transparent;color:var(--ink-soft)}
.toc a:hover{color:var(--ink)} .toc a.is-active{border-left-color:var(--lime);color:var(--brand-ink);font-weight:600}

/* breadcrumb */
.crumbs{font-family:var(--mono);font-size:var(--t-xs);letter-spacing:.04em;color:var(--ink-faint);margin:var(--sp-5) 0 var(--sp-4)}
.crumbs a{color:var(--ink-soft)} .crumbs a:hover{color:var(--brand)} .crumbs span{margin:0 .5em}

/* quickfacts */
.quickfacts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin:var(--sp-5) 0}
.quickfacts div{background:var(--surface);padding:var(--sp-4)}
.quickfacts dt{font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin-bottom:.25rem}
.quickfacts dd{margin:0;font-weight:600;color:var(--ink)}
@media(max-width:620px){.quickfacts{grid-template-columns:1fr 1fr}}

/* review header */
.review-head{display:grid;grid-template-columns:1fr auto;gap:var(--sp-5);align-items:center;padding:var(--sp-6);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.review-head .logo-lg{width:60px;height:60px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--serif);font-size:1.6rem;color:var(--ink-soft)}
@media(max-width:620px){.review-head{grid-template-columns:1fr}}

/* pros/cons */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5)}
.proscons ul{list-style:none;padding:0;margin:0}
.proscons li{padding-left:1.6em;position:relative;margin:.5em 0;font-size:var(--t-sm)}
.pros li::before{content:'+';position:absolute;left:0;color:var(--brand);font-weight:700}
.cons li::before{content:'–';position:absolute;left:0;color:var(--alert);font-weight:700}
@media(max-width:620px){.proscons{grid-template-columns:1fr}}

/* figure */
.figure{margin:var(--sp-5) 0}
.figure .ph{aspect-ratio:16/9;background:linear-gradient(135deg,var(--surface-2),#E4E8DC);border:1px solid var(--line);border-radius:var(--r-lg);display:grid;place-items:center;color:var(--ink-faint);font-family:var(--mono);font-size:var(--t-xs);letter-spacing:.1em}
.figure figcaption{font-size:var(--t-xs);color:var(--ink-faint);margin-top:.6rem}

/* utilbar */
.utilbar{background:var(--ink);color:#D7DAD2;font-family:var(--mono);font-size:var(--t-xs);letter-spacing:.03em}
.utilbar .wrap{display:flex;justify-content:space-between;align-items:center;padding-block:9px;gap:1rem}
.utilbar .pill--verified{background:transparent;color:var(--lime);border-color:rgba(191,247,71,.4)}
.utilbar .pill--verified .dot{background:var(--lime)}
.utilbar a{color:#D7DAD2} .utilbar a:hover{color:#fff}

/* masthead */
.masthead{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 86%,transparent);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.masthead .wrap{display:flex;align-items:center;gap:var(--sp-5);padding-block:var(--sp-4)}
.brand{display:flex;align-items:baseline;gap:.4rem;font-family:var(--serif);font-size:1.45rem;letter-spacing:-.01em;color:var(--ink);text-decoration:none}
.brand .b-mark{color:var(--lime-deep)}
.brand .b-tld{font-family:var(--mono);font-size:.66rem;letter-spacing:.05em;color:var(--ink-faint)}
.mainnav{display:flex;gap:var(--sp-5);margin-left:var(--sp-3)}
.mainnav a{font-size:var(--t-sm);font-weight:500;color:var(--ink-soft);text-decoration:none;padding:.3rem 0;position:relative}
.mainnav a:hover{color:var(--ink)}
.mainnav a[aria-current]{color:var(--ink)} .mainnav a[aria-current]::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--lime)}
.mast-search{margin-left:auto;display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1.5px solid var(--line-strong);border-radius:var(--r-pill);padding:.4rem .9rem;min-width:200px}
.mast-search input{border:0;background:transparent;outline:none;font:inherit;font-size:var(--t-sm);width:100%;color:var(--ink)}
.mast-search svg{color:var(--ink-faint);flex:none}
@media(max-width:860px){.mainnav,.mast-search{display:none}}

/* ===== menu mobile (hamburguer CSS-only) v3 ===== */
.masthead .wrap{position:relative}
.nav-toggle{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.burger{display:none;margin-left:auto;width:44px;height:44px;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:1px solid var(--line-strong);border-radius:11px;background:var(--surface);cursor:pointer;padding:0}
.burger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .2s}
@media(max-width:860px){
  .burger{display:flex}
  #nav-principal.mainnav{display:none;position:absolute;top:calc(100% + 1px);left:0;right:0;flex-direction:column;gap:0;margin:0;padding:6px 0;background:var(--paper);border-bottom:1px solid var(--line);box-shadow:0 22px 36px -24px rgba(18,18,18,.55);z-index:60}
  .nav-toggle:checked ~ #nav-principal.mainnav{display:flex}
  #nav-principal.mainnav a{padding:14px 22px;font-size:1rem;border-top:1px solid var(--line)}
  #nav-principal.mainnav a:first-child{border-top:0}
  #nav-principal.mainnav a[aria-current]::after{display:none}
  .nav-toggle:checked ~ .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked ~ .burger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* hero */
.hero{padding-block:var(--sp-8) var(--sp-7)}
.hero h1{font-size:var(--t-4xl);max-width:18ch}
.hero .lead{max-width:54ch;margin-top:var(--sp-4)}
.hero-actions{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-top:var(--sp-5)}
.hero-trust{display:flex;flex-wrap:wrap;gap:var(--sp-4) var(--sp-5);margin-top:var(--sp-6);padding-top:var(--sp-5);border-top:1px solid var(--line)}
.hero-trust .stat,.stats .s{display:flex;flex-direction:column}
.hero-trust .stat b,.stats .s b{font-family:var(--serif);font-size:var(--t-2xl);font-weight:400;line-height:1;color:var(--ink)}
.hero-trust .stat span,.stats .s span{font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-top:.3rem}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5);border-top:1px solid var(--line);margin-top:var(--sp-7);padding-top:var(--sp-6)}
@media(max-width:680px){.stats{grid-template-columns:1fr 1fr}}

/* sec-head */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--sp-4);margin-bottom:var(--sp-5)}
.sec-head h2{margin:0} .sec-head .more{font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.08em;text-decoration:none;color:var(--brand);white-space:nowrap}

/* feed (news) */
.feed-item{display:grid;grid-template-columns:8.5rem 1fr;gap:var(--sp-5);padding:var(--sp-5) 0;border-bottom:1px solid var(--line);align-items:start}
.feed-item time{font-family:var(--mono);font-size:var(--t-xs);color:var(--ink-faint);letter-spacing:.04em;padding-top:.3rem}
.feed-item h3{margin:0 0 .3em;font-size:var(--t-lg)} .feed-item h3 a{text-decoration:none;color:var(--ink)} .feed-item h3 a:hover{color:var(--brand-ink)}
.feed-item p{margin:0;color:var(--ink-soft);font-size:var(--t-sm)}
@media(max-width:620px){.feed-item{grid-template-columns:1fr;gap:var(--sp-2)}}

/* band */
.band{background:var(--ink);color:#E6E8E0;border-radius:var(--r-lg);padding:var(--sp-8);text-align:center;position:relative;overflow:hidden}
.band::before{content:'';position:absolute;inset:0;background:radial-gradient(80% 120% at 50% 0,rgba(191,247,71,.16),transparent 55%)}
.band h2{color:#fff;position:relative} .band .lead{color:#AEB2A8;max-width:52ch;margin-inline:auto;position:relative}
.band .hero-actions{justify-content:center;position:relative} .band .btn--primary{background:var(--lime)} .band .btn--ghost{color:#fff;border-color:rgba(255,255,255,.25)}

/* responsible + footer */
.responsible{background:var(--alert-wash);border-top:1px solid color-mix(in srgb,var(--alert) 20%,transparent)}
.responsible .wrap{display:flex;gap:var(--sp-4);align-items:center;padding-block:var(--sp-4);font-size:var(--t-sm);color:#7A3A33}
.responsible .age{font-family:var(--serif);font-size:1.35rem;color:var(--alert);border:2px solid var(--alert);border-radius:9px;padding:.05em .35em;flex:none}
.sitefooter{background:var(--ink);color:#A7ABA2;padding-block:var(--sp-7) var(--sp-6);font-size:var(--t-sm)}
.sitefooter .wrap{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--sp-6)}
.sitefooter h4{font-family:var(--mono);font-weight:500;font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.1em;color:#7D8278;margin-bottom:var(--sp-4)}
.sitefooter ul{list-style:none;padding:0;margin:0} .sitefooter li{margin:.5em 0}
.sitefooter a{color:#C6CABF;text-decoration:none} .sitefooter a:hover{color:var(--lime)}
.sitefooter .brand{color:#fff;margin-bottom:var(--sp-3)} .sitefooter .brand .b-tld{color:#7D8278}
.foot-legal{border-top:1px solid rgba(255,255,255,.1);margin-top:var(--sp-6);padding-top:var(--sp-5);font-size:var(--t-xs);color:#7D8278;line-height:1.7}
@media(max-width:760px){.sitefooter .wrap{grid-template-columns:1fr 1fr}.sitefooter .wrap>*{min-width:0}.responsible .wrap{align-items:flex-start;flex-direction:column;gap:var(--sp-2)}}
@media(max-width:560px){.sitefooter .wrap{grid-template-columns:1fr;gap:var(--sp-4)}}

/* utilidades */
.divider-label{display:flex;align-items:center;gap:var(--sp-4);font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint);margin:var(--sp-6) 0}
.divider-label::before,.divider-label::after{content:'';flex:1;height:1px;background:var(--line)}

/* ===== DIRETÓRIO (/casas-de-apostas/) ===== */
.logo-lg{width:54px;height:54px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--serif);font-size:1.4rem;color:var(--ink);flex:none}
.dir-hero{padding:var(--sp-7) 0 var(--sp-5)}
.dir-search{display:flex;gap:10px;background:var(--surface);border:1.5px solid var(--line-strong);border-radius:var(--r-pill);padding:8px 8px 8px 22px;max-width:560px;margin-top:var(--sp-5)}
.dir-search input{flex:1;border:0;outline:0;background:transparent;font:inherit;font-size:1.05rem;color:var(--ink)}
.filterbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:var(--sp-6) 0 var(--sp-5)}
.filterbar .fl{font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-right:6px}
.chipf{font-size:var(--t-sm);padding:.5em 1.1em;border-radius:var(--r-pill);border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-soft);cursor:pointer;transition:.15s}
.chipf:hover{border-color:var(--ink)} .chipf.on{background:var(--lime);color:var(--lime-ink);border-color:var(--lime)}
.dir-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:920px){.dir-grid{grid-template-columns:1fr 1fr}}@media(max-width:600px){.dir-grid{grid-template-columns:1fr}}
.casa-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;transition:.18s ease}
.casa-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--line-strong)}
.casa-card .ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.casa-card .ci{display:flex;align-items:center;gap:12px;min-width:0}
.casa-card .logo{width:46px;height:46px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--serif);font-size:1.2rem;color:var(--ink);flex:none}
.casa-card .nm{font-family:var(--serif);font-size:1.25rem;color:var(--ink);margin:0;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.casa-card .sc{display:grid;place-items:center;min-width:48px;height:48px;border-radius:12px;background:var(--score-wash);border:1px solid color-mix(in srgb,var(--score) 30%,transparent);flex:none}
.casa-card .sc b{font-family:var(--serif);font-size:1.3rem;color:var(--score-ink);line-height:1} .casa-card .sc small{font-family:var(--mono);font-size:8px;color:var(--score-ink)}
.casa-card .sc.na{background:var(--surface-2);border-color:var(--line)} .casa-card .sc.na b{font-size:.7rem;color:var(--ink-faint);font-family:var(--mono);text-align:center;line-height:1.1}
.casa-card .meta{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 14px}
.casa-card .chip{font-family:var(--mono);font-size:10px;letter-spacing:.03em;padding:.3em .6em;border-radius:var(--r-pill);background:var(--surface-2);color:var(--ink-soft)}
.casa-card .row{display:flex;justify-content:space-between;font-size:var(--t-sm);padding:7px 0;border-top:1px dashed var(--line)}
.casa-card .row span:first-child{color:var(--ink-faint)} .casa-card .row b{color:var(--ink)}
.casa-card .cta{margin-top:14px;display:flex;gap:8px}
.dir-count{font-family:var(--mono);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-bottom:var(--sp-4)}

/* ===== Visao TV brand (play badge) ===== */
.brand .vt-play{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:9px;background:var(--lime);margin-right:.45rem;position:relative;vertical-align:-.32em}
.brand .vt-play::after{content:"";width:0;height:0;border-style:solid;border-width:7px 0 7px 11px;border-color:transparent transparent transparent var(--lime-ink);margin-left:2px}
.brand .vt-tld{font-weight:400;color:var(--soft)}
