
/* ============================================================
   Design tokens — Brasil GEO canon (Pacto skin)
   ============================================================ */
:root{
  --ink-950:#06091a;--ink-900:#080d1f;--ink-800:#0e1320;--ink-700:#11172a;--ink-600:#1a2138;--ink-500:#252d49;
  --paper:#f7f8f9;--paper-soft:#eef1f5;
  --brand-50:#eef2ff;--brand-100:#dbe3ff;--brand-200:#b9c6ff;--brand-300:#92aaf5;--brand-400:#6a85e8;
  --brand-500:#3b5cd9;--brand-600:#2b46c7;--brand-700:#1f36a8;--brand-800:#15268b;--brand-900:#0d1a6e;
  --ok:#34d399;--warn:#fbbf24;--danger:#f87171;--info:#60a5fa;
  --rule:rgba(255,255,255,0.08);--rule-strong:rgba(255,255,255,0.14);
  --glass:rgba(255,255,255,0.04);--glass-strong:rgba(255,255,255,0.08);
  --muted:rgba(255,255,255,0.55);--muted-strong:rgba(255,255,255,0.75);
  --shadow-soft:0 1px 2px rgba(0,0,0,0.18),0 1px 1px rgba(0,0,0,0.10);
  --shadow-chip:0 4px 12px rgba(59,92,217,0.18);
  --shadow-lift:0 24px 48px rgba(0,0,0,0.40),0 4px 16px rgba(0,0,0,0.20);
  --shadow-menu:0 36px 80px rgba(0,0,0,0.50),0 8px 24px rgba(0,0,0,0.30);
  --font-display:'Unbounded','Exo',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  --font-display-alt:'Exo','Unbounded',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  --font-sans:'Mona Sans','Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  --font-body:'Inter','Mona Sans',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  --font-mono:'Cascadia Mono','Consolas',ui-monospace,'SF Mono',Menlo,monospace;
  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-7:32px;--s-8:40px;--s-9:48px;--s-10:64px;--s-11:80px;--s-12:96px;
  --r-sm:6px;--r-md:10px;--r-lg:16px;--r-xl:24px;--r-full:999px;
  --t-fast:180ms cubic-bezier(.2,.8,.2,1);--t-base:250ms cubic-bezier(.2,.8,.2,1);--t-slow:350ms cubic-bezier(.16,1,.3,1);
}

/* Reset + base */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;color-scheme:dark}
body{min-height:100vh;background:var(--ink-950);color:#fff;font-family:var(--font-body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:0;background:transparent;color:inherit;cursor:pointer}

/* A11y */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:-100px;left:var(--s-4);z-index:200;background:var(--brand-500);color:#fff;padding:var(--s-3) var(--s-5);border-radius:var(--r-md);font-weight:600;transition:top var(--t-fast)}
.skip-link:focus{top:var(--s-4);outline:none}
:focus-visible{outline:2px solid var(--brand-400);outline-offset:3px;border-radius:4px}

/* BG layer */
.bg{position:fixed;inset:0;z-index:0;pointer-events:none}
.bg::before{content:"";position:absolute;inset:0;background:radial-gradient(1200px 800px at 78% 8%, rgba(59,92,217,0.32), transparent 62%),radial-gradient(900px 700px at 12% 92%, rgba(106,133,232,0.14), transparent 65%),linear-gradient(180deg,var(--ink-950) 0%, var(--ink-900) 50%, #050818 100%)}
.bg::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg, rgba(255,255,255,0.014) 0 1px, transparent 1px 72px);opacity:.7}

/* Shell + container */
.shell{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}
.container{width:100%;max-width:1280px;margin:0 auto;padding-left:var(--s-6);padding-right:var(--s-6)}
@media (max-width:720px){.container{padding-left:var(--s-5);padding-right:var(--s-5)}}

/* ============================================================
   Header sticky + Mega Menu cascata
   ============================================================ */
header.site{position:sticky;top:0;z-index:80;background:rgba(6,9,26,0.78);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--rule)}
header.site .row{display:flex;align-items:center;justify-content:space-between;gap:var(--s-6);padding:var(--s-4) 0}
.brand{display:inline-flex;align-items:center;gap:var(--s-3);color:#fff;font-family:var(--font-display);font-weight:800;font-size:17px;letter-spacing:.04em;line-height:1}
.brand-glyph{width:30px;height:30px;display:inline-grid;place-items:center;border-radius:8px;background:linear-gradient(135deg,rgba(59,92,217,0.22),rgba(106,133,232,0.04));border:1px solid rgba(106,133,232,0.30);box-shadow:var(--shadow-chip)}
.brand-glyph svg{width:18px;height:18px}
.brand-text{display:flex;flex-direction:column;gap:2px}
.brand-text small{font-family:var(--font-sans);font-size:10px;font-weight:500;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;line-height:1}

/* Mega menu nav (desktop) */
nav.mega{display:inline-flex;align-items:center;gap:var(--s-2)}
nav.mega .nav-trigger{display:inline-flex;align-items:center;gap:6px;padding:10px var(--s-4);border-radius:var(--r-md);font-family:var(--font-sans);color:var(--muted-strong);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:color var(--t-fast),background var(--t-fast);cursor:pointer;position:relative}
nav.mega .nav-trigger:hover,nav.mega .nav-trigger[aria-expanded="true"]{color:#fff;background:var(--glass-strong)}
nav.mega .nav-trigger .chev{width:10px;height:10px;display:inline-block;transition:transform var(--t-fast)}
nav.mega .nav-trigger[aria-expanded="true"] .chev{transform:rotate(180deg)}
nav.mega .nav-cta{color:#fff;background:var(--brand-500);padding:10px var(--s-5);border-radius:var(--r-full);border:1px solid var(--brand-400);box-shadow:var(--shadow-chip);transition:transform var(--t-fast),background var(--t-fast);font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-left:var(--s-3)}
nav.mega .nav-cta:hover{background:var(--brand-600);transform:translateY(-1px)}

/* Mega panel v2: grid responsivo todas-as-categorias + aside sticky */
.mega-panel{position:absolute;left:0;right:0;top:100%;background:linear-gradient(180deg,rgba(8,13,31,0.985),rgba(6,9,26,0.97));border-bottom:1px solid var(--rule-strong);box-shadow:var(--shadow-menu);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity var(--t-base),visibility var(--t-base),transform var(--t-base);max-height:calc(100vh - 70px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(106,133,232,0.40) transparent}
.mega-panel::-webkit-scrollbar{width:8px}
.mega-panel::-webkit-scrollbar-track{background:transparent}
.mega-panel::-webkit-scrollbar-thumb{background:rgba(106,133,232,0.30);border-radius:4px}
.mega-panel[data-open="true"]{opacity:1;visibility:visible;transform:translateY(0)}
.mega-panel-inner{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:var(--s-9);padding:var(--s-9) var(--s-7) var(--s-10);max-width:1320px;margin:0 auto;container-type:inline-size}
@media (max-width:1180px){.mega-panel-inner{grid-template-columns:minmax(0,1fr) 300px;gap:var(--s-7);padding:var(--s-8) var(--s-6) var(--s-9)}}
@media (max-width:1024px){.mega-panel-inner{grid-template-columns:1fr;gap:var(--s-7)}}
.mp-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-6) var(--s-7);align-items:start}
@container (max-width:920px){.mp-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@container (max-width:560px){.mp-grid{grid-template-columns:1fr}}
.mp-cat{min-width:0;border-left:2px solid transparent;padding-left:var(--s-3);transition:border-color var(--t-fast)}
.mp-cat:hover{border-left-color:rgba(106,133,232,0.45)}
.mp-cat-label{font-family:var(--font-display-alt);font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 var(--s-3);padding-bottom:var(--s-2);border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;gap:var(--s-2)}
.mp-cat-anchor{color:var(--brand-300);transition:color var(--t-fast)}
.mp-cat-anchor:hover{color:#fff}
.mp-cat-count{font-family:var(--font-mono);font-size:10.5px;color:var(--ok);background:rgba(52,211,153,0.10);border:1px solid rgba(52,211,153,0.25);padding:2px 8px;border-radius:var(--r-full);letter-spacing:.02em;text-transform:none;font-weight:600}
.mp-cat-count-soft{color:var(--muted);background:transparent;border-color:var(--rule)}
.mp-cat ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}
.mp-cat ul li a{display:flex;align-items:flex-start;gap:8px;padding:7px 10px 7px 8px;margin-left:-8px;border-radius:var(--r-sm);font-family:var(--font-body);font-size:13.5px;line-height:1.35;color:var(--muted-strong);transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast)}
.mp-cat ul li a:hover{color:#fff;background:rgba(59,92,217,0.14);transform:translateX(2px)}
.mp-cat ul li.mp-sub-pub a{color:#fff}
.mp-cat ul li.mp-sub-pub .mp-sub-dot{color:var(--ok);font-size:9px;line-height:1.55;text-shadow:0 0 6px rgba(52,211,153,0.45)}
.mp-cat ul li.mp-sub-soon a{color:var(--muted)}
.mp-cat ul li.mp-sub-soon .mp-sub-dot{color:var(--muted);font-size:9px;line-height:1.55;opacity:.5}
.mp-sub-text{flex:1 1 auto;min-width:0}
.mp-cat-more{display:inline-block;margin-top:var(--s-3);font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--brand-300);border-bottom:1px solid rgba(106,133,232,0.30);padding-bottom:1px}
.mp-cat-more:hover{color:#fff;border-bottom-color:var(--brand-400)}
.mp-aside{border-left:1px solid var(--rule);padding-left:var(--s-7);position:sticky;top:0;align-self:start}
@media (max-width:1180px){.mp-aside{padding-left:var(--s-6)}}
@media (max-width:1024px){.mp-aside{border-left:0;padding-left:0;padding-top:var(--s-7);border-top:1px solid var(--rule)}}
.mp-aside-eyebrow{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 var(--s-3)}
.mp-aside-title{font-family:var(--font-display-alt);font-weight:700;font-size:18px;line-height:1.25;color:#fff;margin:0 0 var(--s-3);letter-spacing:-.01em}
.mp-aside-dek{font-family:var(--font-body);font-size:13.5px;line-height:1.6;color:var(--muted-strong);margin:0 0 var(--s-5)}
.mp-aside-dek strong{color:#fff;font-weight:600}
.mp-aside-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-3)}
.mp-aside-list li a{display:block;padding:var(--s-3) var(--s-4);border-radius:var(--r-md);background:var(--glass);border:1px solid var(--rule);transition:border-color var(--t-base),background var(--t-base),transform var(--t-base)}
.mp-aside-list li a:hover{border-color:rgba(106,133,232,0.40);background:var(--glass-strong);transform:translateY(-1px)}
.mp-aside-list li .mp-aside-tag{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-300);display:block;margin-bottom:4px}
.mp-aside-list li .mp-aside-link{font-family:var(--font-body);font-size:13.5px;line-height:1.4;color:#fff}
.mp-aside-sitemap{display:inline-flex;align-items:center;gap:6px;margin-top:var(--s-6);padding-top:var(--s-4);border-top:1px solid var(--rule);font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-300)}
.mp-aside-sitemap:hover{color:#fff}

/* Hide mega menu on small screens */
@media (max-width:960px){nav.mega .nav-trigger:not(.nav-cta){display:none}.mega-panel{display:none!important}}

/* Hamburger */
.hamb{display:none;width:42px;height:42px;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--glass-strong);border:1px solid var(--rule-strong);cursor:pointer}
.hamb svg{width:20px;height:20px}
@media (max-width:960px){.hamb{display:inline-flex}}

/* ============================================================
   Mobile drawer v3 — tabs sticky + busca inline + filtro só-no-ar
   ============================================================ */
.drawer{position:fixed;inset:0;z-index:90;display:none;background:rgba(6,9,26,0.78);backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%)}
.drawer[data-open="true"]{display:block}
.drawer-panel{position:absolute;right:0;top:0;bottom:0;width:min(440px,94vw);background:linear-gradient(180deg,#0b1126 0%,var(--ink-900) 22%, #060a1f 100%);border-left:1px solid var(--rule-strong);overflow-y:auto;overscroll-behavior:contain;padding:0 0 calc(var(--s-9) + env(safe-area-inset-bottom));box-shadow:var(--shadow-lift);scrollbar-width:thin;scrollbar-color:rgba(106,133,232,0.30) transparent;transition:transform var(--t-base) cubic-bezier(.16,1,.3,1)}
.drawer-panel::-webkit-scrollbar{width:6px}
.drawer-panel::-webkit-scrollbar-thumb{background:rgba(106,133,232,0.30);border-radius:3px}
.drawer[data-open="false"] .drawer-panel{transform:translateX(100%)}
.drawer[data-open="true"] .drawer-panel{transform:translateX(0)}

/* Head */
.drawer-head{position:sticky;top:0;z-index:8;display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding:var(--s-5) var(--s-5) var(--s-3);background:linear-gradient(180deg,rgba(11,17,38,0.96) 0%, rgba(11,17,38,0.86) 80%, rgba(11,17,38,0) 100%);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.drawer-brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:15px;letter-spacing:.04em;color:#fff;line-height:1}
.drawer-brand small{display:block;font-family:var(--font-mono);font-size:10.5px;color:var(--brand-300);letter-spacing:.02em;text-transform:none;font-weight:500;margin-top:3px}
.drawer-close{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--glass);border:1px solid var(--rule-strong);cursor:pointer;color:#fff;transition:background var(--t-fast),border-color var(--t-fast)}
.drawer-close:hover,.drawer-close:focus-visible{background:var(--glass-strong);border-color:rgba(106,133,232,0.40)}
.drawer-close svg{width:18px;height:18px}

/* Search row */
.drawer-search-row{padding:0 var(--s-5);margin-bottom:var(--s-4)}
.drawer-search{width:100%;display:inline-flex;align-items:center;gap:10px;padding:12px var(--s-4);background:rgba(59,92,217,0.10);border:1px solid rgba(106,133,232,0.30);border-radius:var(--r-full);font-family:var(--font-body);font-size:14px;color:var(--muted-strong);cursor:pointer;text-align:left;transition:background var(--t-fast),border-color var(--t-fast)}
.drawer-search:hover,.drawer-search:focus-visible{background:rgba(59,92,217,0.18);border-color:rgba(106,133,232,0.55)}
.drawer-search svg{width:17px;height:17px;color:var(--brand-300);flex:0 0 auto}
.drawer-search span{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.drawer-search kbd{font-family:var(--font-mono);font-size:10.5px;color:var(--brand-300);background:rgba(106,133,232,0.18);border:1px solid rgba(106,133,232,0.30);padding:2px 7px;border-radius:5px;font-weight:700}

/* Quick top: sitemap CTA primário + Início/Newsletter pills */
.drawer-quick-top{padding:0 var(--s-5);margin-bottom:var(--s-5);display:flex;flex-direction:column;gap:10px}
.dqt{display:inline-flex;align-items:center;gap:12px;padding:12px var(--s-4);border-radius:var(--r-lg);border:1px solid var(--rule);background:var(--glass);transition:transform var(--t-fast),background var(--t-fast),border-color var(--t-fast);text-decoration:none;color:#fff}
.dqt:hover,.dqt:focus-visible{transform:translateY(-1px);background:var(--glass-strong);border-color:rgba(106,133,232,0.45)}
.dqt-primary{background:linear-gradient(135deg,rgba(59,92,217,0.22),rgba(106,133,232,0.08));border-color:rgba(106,133,232,0.55);box-shadow:0 6px 16px rgba(59,92,217,0.18)}
.dqt-glyph{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-md);background:rgba(106,133,232,0.18);border:1px solid rgba(106,133,232,0.35);color:var(--brand-300);flex:0 0 auto}
.dqt-glyph svg{width:18px;height:18px}
.dqt-text{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}
.dqt-text strong{font-family:var(--font-display-alt);font-weight:700;font-size:15px;line-height:1.2;color:#fff;letter-spacing:-.005em}
.dqt-text small{font-family:var(--font-body);font-size:12px;line-height:1.35;color:var(--muted)}
.dqt-arrow{flex:0 0 auto;color:var(--brand-300);transform:translateX(0);transition:transform var(--t-fast)}
.dqt-arrow svg{width:18px;height:18px}
.dqt:hover .dqt-arrow{transform:translateX(3px)}
.dqt-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dqt-row-3{grid-template-columns:repeat(3,1fr)}
.dqt-soft{padding:10px 12px}
.dqt-soft .dqt-glyph{width:30px;height:30px;background:rgba(106,133,232,0.10);border-color:rgba(106,133,232,0.22)}
.dqt-soft .dqt-glyph svg{width:15px;height:15px}
.dqt-mini{font-family:var(--font-sans);font-size:11.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-strong);line-height:1.2}

/* Hub tabs (sticky) */
.drawer-tabs{position:sticky;top:78px;z-index:7;display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:0 var(--s-5) var(--s-3);padding:6px;background:rgba(11,17,38,0.92);border:1px solid var(--rule-strong);border-radius:var(--r-lg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.drawer-tab{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;background:transparent;border:1px solid transparent;border-radius:var(--r-md);color:var(--muted-strong);cursor:pointer;text-align:left;font-family:var(--font-body);transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}
.drawer-tab:hover,.drawer-tab:focus-visible{background:rgba(255,255,255,0.04);color:#fff}
.drawer-tab[aria-selected="true"]{background:rgba(59,92,217,0.20);border-color:rgba(106,133,232,0.50);color:#fff;box-shadow:0 0 0 1px rgba(106,133,232,0.18) inset}
.drawer-tab-glyph{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--r-sm);flex:0 0 auto;color:var(--brand-300)}
.drawer-tab-glyph svg{width:17px;height:17px}
.drawer-tab[data-tab-hub="atleta"][aria-selected="true"] .drawer-tab-glyph{color:#7dd3fc;background:rgba(125,211,252,0.12)}
.drawer-tab[data-tab-hub="academia"][aria-selected="true"] .drawer-tab-glyph{color:#fbbf24;background:rgba(251,191,36,0.12)}
.drawer-tab[data-tab-hub="personal"][aria-selected="true"] .drawer-tab-glyph{color:#a78bfa;background:rgba(167,139,250,0.12)}
.drawer-tab-text{display:flex;flex-direction:column;gap:1px;line-height:1.1;min-width:0;flex:1 1 auto}
.drawer-tab-text strong{font-family:var(--font-display-alt);font-weight:700;font-size:12.5px;letter-spacing:.01em;color:inherit}
.drawer-tab-text small{font-family:var(--font-mono);font-size:10px;color:var(--muted)}
.drawer-tab[aria-selected="true"] .drawer-tab-text small{color:var(--ok)}

/* Filter "só no ar" */
.drawer-filters{padding:0 var(--s-5);margin-bottom:var(--s-4)}
.drawer-filter{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--muted-strong);cursor:pointer;padding:8px 12px;border-radius:var(--r-full);background:var(--glass);border:1px solid var(--rule);width:100%;justify-content:flex-start}
.drawer-filter input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.drawer-filter-track{position:relative;width:30px;height:18px;border-radius:var(--r-full);background:rgba(255,255,255,0.10);transition:background var(--t-fast);flex:0 0 auto}
.drawer-filter-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform var(--t-fast),background var(--t-fast);box-shadow:0 1px 3px rgba(0,0,0,0.30)}
.drawer-filter input:checked + .drawer-filter-track{background:rgba(52,211,153,0.55)}
.drawer-filter input:checked + .drawer-filter-track .drawer-filter-thumb{transform:translateX(12px);background:#fff}
.drawer-filter-label{flex:1 1 auto;font-family:var(--font-sans);font-size:12px;text-transform:none;letter-spacing:.04em;color:var(--muted-strong)}
.drawer-filter-count{font-family:var(--font-mono);font-size:11px;color:var(--ok);background:rgba(52,211,153,0.10);border:1px solid rgba(52,211,153,0.25);padding:2px 7px;border-radius:var(--r-full);font-weight:700}
.drawer-filter:has(input:checked){border-color:rgba(52,211,153,0.40);background:rgba(52,211,153,0.06)}
.drawer-filter:focus-within{outline:2px solid var(--brand-400);outline-offset:2px}

/* Hub sections (visíveis controladas por data-visible) */
.drawer-hubs{padding:0 var(--s-5)}
.drawer-hub{display:none;animation:drawer-fade var(--t-base) ease-out both}
.drawer-hub[data-visible="true"]{display:block}
@keyframes drawer-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

.drawer-hub-head{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:start;padding:var(--s-4);border-radius:var(--r-lg);background:linear-gradient(180deg,rgba(15,21,46,0.55),rgba(8,13,31,0.30));border:1px solid var(--rule);margin-bottom:var(--s-3);position:relative;overflow:hidden}
.drawer-hub-head::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--hub-accent,#92aaf5)}
.drawer-hub-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--r-md);background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.10);color:var(--hub-accent,#92aaf5);flex:0 0 auto}
.drawer-hub-icon svg{width:22px;height:22px}
.drawer-hub-meta{min-width:0;display:flex;flex-direction:column;gap:3px}
.drawer-hub-eyebrow{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0}
.drawer-hub-title{font-family:var(--font-display-alt);font-weight:700;font-size:18px;color:#fff;margin:0;letter-spacing:-.005em;line-height:1.1}
.drawer-hub-tagline{font-family:var(--font-body);font-size:13px;line-height:1.4;color:var(--muted-strong);margin:0;font-weight:400}
.drawer-hub-badge{font-family:var(--font-mono);font-size:11px;color:var(--ok);background:rgba(52,211,153,0.10);border:1px solid rgba(52,211,153,0.30);padding:4px 10px;border-radius:var(--r-full);font-weight:700;white-space:nowrap;flex:0 0 auto;align-self:start}
.drawer-hub-badge strong{font-weight:700}

.drawer-hub-cta{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px var(--s-4);margin-bottom:var(--s-3);background:var(--brand-500);color:#fff;border:1px solid var(--brand-400);border-radius:var(--r-md);font-family:var(--font-sans);font-size:12.5px;font-weight:600;letter-spacing:.04em;transition:background var(--t-fast),transform var(--t-fast);box-shadow:var(--shadow-chip)}
.drawer-hub-cta:hover,.drawer-hub-cta:focus-visible{background:var(--brand-600);transform:translateY(-1px)}
.drawer-hub-cta svg{width:16px;height:16px;flex:0 0 auto}

.drawer-cats{display:flex;flex-direction:column;gap:6px}
.drawer-cat{border:1px solid var(--rule);border-radius:var(--r-md);background:var(--glass);overflow:hidden;transition:border-color var(--t-fast),background var(--t-fast)}
.drawer-cat:hover{border-color:rgba(106,133,232,0.30)}
.drawer-cat[open]{border-color:rgba(106,133,232,0.40);background:var(--glass-strong)}
.drawer-cat > summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:10px 12px;font-family:var(--font-body);color:#fff;transition:background var(--t-fast)}
.drawer-cat > summary::-webkit-details-marker{display:none}
.drawer-cat > summary:hover{background:rgba(59,92,217,0.06)}
.drawer-cat-mark{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:24px;padding:0 7px;border-radius:var(--r-full);font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--ok);background:rgba(52,211,153,0.10);border:1px solid rgba(52,211,153,0.30);flex:0 0 auto}
.drawer-cat[data-cat-pub="0"] .drawer-cat-mark{color:var(--muted);background:transparent;border-color:var(--rule)}
.drawer-cat-info{display:flex;flex-direction:column;gap:2px;min-width:0;text-align:left}
.drawer-cat-info strong{font-family:var(--font-display-alt);font-weight:700;font-size:14px;color:#fff;line-height:1.2;letter-spacing:-.005em}
.drawer-cat-info small{font-family:var(--font-body);font-size:11.5px;color:var(--muted);line-height:1.3}
.drawer-cat-chev{display:inline-flex;align-items:center;justify-content:center;color:var(--muted);transition:transform var(--t-fast),color var(--t-fast);flex:0 0 auto}
.drawer-cat-chev svg{width:18px;height:18px}
.drawer-cat[open] > summary .drawer-cat-chev{transform:rotate(180deg);color:var(--brand-300)}
.drawer-cat[open] > summary{background:rgba(59,92,217,0.10);border-bottom:1px solid var(--rule)}
.drawer-cat-body{padding:8px 12px 12px;background:rgba(8,13,31,0.30)}
.drawer-cat-overview{display:inline-flex;align-items:center;justify-content:space-between;width:100%;gap:8px;padding:8px 12px;margin-bottom:8px;border-radius:var(--r-sm);background:transparent;border:1px dashed var(--rule);font-family:var(--font-sans);font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-300);transition:background var(--t-fast),border-color var(--t-fast)}
.drawer-cat-overview:hover,.drawer-cat-overview:focus-visible{background:rgba(59,92,217,0.10);border-color:rgba(106,133,232,0.45);color:#fff;border-style:solid}
.drawer-cat-overview svg{width:14px;height:14px;flex:0 0 auto}

.drawer-subs{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.drawer-subs li a{display:flex;align-items:center;gap:8px;padding:8px 10px;font-family:var(--font-body);font-size:13.5px;line-height:1.4;color:var(--muted);border-radius:var(--r-sm);transition:background var(--t-fast),color var(--t-fast);min-height:38px}
.drawer-subs li a:hover,.drawer-subs li a:focus-visible{color:#fff;background:rgba(59,92,217,0.10)}
.drawer-subs li.drawer-sub-pub a{color:#fff}
.drawer-subs li.drawer-sub-pub .drawer-sub-dot{color:var(--ok);font-size:8px;text-shadow:0 0 6px rgba(52,211,153,0.45);flex:0 0 auto}
.drawer-subs li.drawer-sub-soon .drawer-sub-dot{color:var(--muted);font-size:8px;opacity:.5;flex:0 0 auto}
.drawer-sub-text{flex:1 1 auto;min-width:0}
.drawer-sub-tag{font-family:var(--font-sans);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ok);background:rgba(52,211,153,0.10);border:1px solid rgba(52,211,153,0.25);padding:1px 7px;border-radius:var(--r-full);flex:0 0 auto}

/* Institutional quick links */
.drawer-quick{padding:var(--s-6) var(--s-5) 0;margin-top:var(--s-6);border-top:1px solid var(--rule)}
.drawer-quick-label{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 var(--s-3)}
.drawer-quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.drawer-quick-grid a{padding:9px var(--s-3);border-radius:var(--r-sm);background:transparent;border:1px solid var(--rule);font-family:var(--font-body);font-size:12.5px;font-weight:500;color:var(--muted-strong);transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}
.drawer-quick-grid a:hover,.drawer-quick-grid a:focus-visible{color:#fff;background:var(--glass);border-color:rgba(106,133,232,0.30)}
.drawer-foot{padding:var(--s-5) var(--s-5) 0;font-family:var(--font-body);font-size:11.5px;line-height:1.5;color:var(--muted)}

/* ============================================================
   Bottom-nav fixa mobile — sempre visível em <960px
   ============================================================ */
.bottom-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:85;padding:6px 8px calc(6px + env(safe-area-inset-bottom));background:linear-gradient(180deg,rgba(8,13,31,0.92) 0%,rgba(6,9,26,0.98) 100%);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-top:1px solid rgba(106,133,232,0.20);box-shadow:0 -8px 24px rgba(0,0,0,0.30)}
.bottom-nav{display:none;grid-template-columns:repeat(5,1fr);gap:2px;align-items:end}
@media (max-width:960px){.bottom-nav{display:grid}body{padding-bottom:calc(60px + env(safe-area-inset-bottom))}}
.bn-item{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 2px 5px;border-radius:10px;color:var(--muted);text-decoration:none;font-family:var(--font-sans);transition:color var(--t-fast),background var(--t-fast),transform var(--t-fast);min-height:50px}
.bn-item:hover,.bn-item:focus-visible{color:#fff;background:rgba(255,255,255,0.04)}
.bn-item:active{transform:scale(.96)}
.bn-glyph{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;color:inherit}
.bn-glyph svg{width:22px;height:22px;stroke-width:1.7}
.bn-label{font-size:10.5px;font-weight:600;letter-spacing:.04em;line-height:1;color:inherit}
.bn-item-active{color:var(--brand-300)}
.bn-item-active .bn-glyph{color:var(--brand-300)}
.bn-item-active::after{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:3px;border-radius:0 0 3px 3px;background:var(--brand-400);box-shadow:0 0 8px rgba(106,133,232,0.45)}
.bn-item[data-bn-hub="atleta"].bn-item-active{color:#7dd3fc}
.bn-item[data-bn-hub="atleta"].bn-item-active .bn-glyph{color:#7dd3fc}
.bn-item[data-bn-hub="atleta"].bn-item-active::after{background:#7dd3fc;box-shadow:0 0 8px rgba(125,211,252,0.55)}
.bn-item[data-bn-hub="academia"].bn-item-active{color:#fbbf24}
.bn-item[data-bn-hub="academia"].bn-item-active .bn-glyph{color:#fbbf24}
.bn-item[data-bn-hub="academia"].bn-item-active::after{background:#fbbf24;box-shadow:0 0 8px rgba(251,191,36,0.55)}
.bn-item[data-bn-hub="personal"].bn-item-active{color:#a78bfa}
.bn-item[data-bn-hub="personal"].bn-item-active .bn-glyph{color:#a78bfa}
.bn-item[data-bn-hub="personal"].bn-item-active::after{background:#a78bfa;box-shadow:0 0 8px rgba(167,139,250,0.55)}

/* Mapa centro: FAB elevado */
.bn-item-map{transform:translateY(-12px);margin:0 4px;background:linear-gradient(135deg,var(--brand-500),var(--brand-600));color:#fff;border:1px solid var(--brand-400);border-radius:14px;padding:8px 4px 6px;box-shadow:0 8px 20px rgba(59,92,217,0.40),0 2px 6px rgba(0,0,0,0.30);min-height:56px}
.bn-item-map .bn-glyph{color:#fff}
.bn-item-map .bn-label{color:#fff;font-weight:700;letter-spacing:.06em}
.bn-item-map:hover,.bn-item-map:focus-visible{transform:translateY(-14px);background:linear-gradient(135deg,#4f6de4,var(--brand-500));color:#fff;box-shadow:0 12px 28px rgba(59,92,217,0.55),0 2px 6px rgba(0,0,0,0.30)}
.bn-item-map.bn-item-active{box-shadow:0 12px 28px rgba(59,92,217,0.55),0 0 0 2px rgba(146,170,245,0.55)}
.bn-item-map.bn-item-active::after{display:none}

/* Back-to-top FAB precisa subir acima da bottom-nav em mobile */
@media (max-width:960px){.back-to-top{bottom:calc(68px + env(safe-area-inset-bottom));right:var(--s-4)}}
@media (max-width:960px){.toast{bottom:calc(80px + env(safe-area-inset-bottom))}}

/* Hide bottom-nav quando drawer está aberto (evita stacking) */
.drawer[data-open="true"] ~ .bottom-nav,
body:has(.drawer[data-open="true"]) .bottom-nav{display:none}

/* Mapa link no header desktop e mobile */
.nav-map{display:inline-flex;align-items:center;gap:6px;border:1px dashed rgba(106,133,232,0.30);background:rgba(106,133,232,0.04)}
.nav-map:hover{background:rgba(106,133,232,0.10);border-color:rgba(106,133,232,0.55);border-style:solid}
.nav-map-glyph{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--brand-300)}
.nav-map-glyph svg{width:14px;height:14px}
.nav-map-mobile{display:none;width:42px;height:42px;align-items:center;justify-content:center;border-radius:var(--r-md);background:rgba(106,133,232,0.08);border:1px solid rgba(106,133,232,0.30);color:var(--brand-300);margin-right:6px;transition:background var(--t-fast),border-color var(--t-fast)}
.nav-map-mobile:hover,.nav-map-mobile:focus-visible{background:rgba(106,133,232,0.18);border-color:rgba(106,133,232,0.55);color:#fff}
.nav-map-mobile svg{width:18px;height:18px}
@media (max-width:960px){.nav-map-mobile{display:inline-flex}}

/* Mobile-specific tweaks */
@media (max-width:560px){
  .drawer-panel{width:100vw}
  .drawer-tabs{top:74px}
  .drawer-tab{padding:7px 8px}
  .drawer-tab-text strong{font-size:12px}
}

/* ============================================================
   Hero portal (home)
   ============================================================ */
section.block{padding:var(--s-11) 0;position:relative}
.section-head{max-width:780px;margin:0 auto var(--s-9);text-align:center}
.section-eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.20em;text-transform:uppercase;color:var(--brand-300);margin:0 0 var(--s-3)}
.section-title{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(28px,4vw,44px);line-height:1.1;letter-spacing:-.02em;margin:0 0 var(--s-4);color:#fff}
.section-lead{font-family:var(--font-body);font-size:clamp(15px,1.4vw,17px);line-height:1.6;color:var(--muted-strong);margin:0}

.hero{padding:var(--s-12) 0 var(--s-10);text-align:center;position:relative}
.hero .tag{display:inline-flex;align-items:center;gap:var(--s-3);padding:8px var(--s-4) 8px var(--s-3);border:1px solid rgba(106,133,232,0.35);background:rgba(59,92,217,0.10);border-radius:var(--r-full);font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-strong);margin-bottom:var(--s-8);backdrop-filter:blur(8px)}
.hero .tag-dot{width:6px;height:6px;border-radius:50%;background:var(--brand-300);box-shadow:0 0 12px rgba(106,133,232,0.55)}
h1.hero-title{font-family:var(--font-display);font-weight:800;font-size:clamp(42px,7vw,96px);line-height:1.02;letter-spacing:-.025em;margin:0 auto;max-width:1100px;color:#fff;text-shadow:0 0 80px rgba(59,92,217,0.25)}
h1.hero-title em{font-style:italic;font-weight:700;background:linear-gradient(180deg,var(--brand-300) 0%,var(--brand-500) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;font-family:var(--font-display-alt)}
.hero-lead{font-family:var(--font-body);font-size:clamp(16px,1.7vw,20px);font-weight:400;line-height:1.6;color:var(--muted-strong);max-width:720px;margin:var(--s-7) auto 0}
.hero-ctas{display:flex;flex-wrap:wrap;gap:var(--s-3);justify-content:center;margin-top:var(--s-9)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px var(--s-6);border-radius:var(--r-full);font-family:var(--font-sans);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:transform var(--t-fast),background var(--t-fast),border-color var(--t-fast)}
.btn.primary{background:var(--brand-500);color:#fff;border:1px solid var(--brand-400);box-shadow:var(--shadow-chip)}
.btn.primary:hover{background:var(--brand-600);transform:translateY(-1px)}
.btn.ghost{background:var(--glass);color:#fff;border:1px solid var(--rule-strong)}
.btn.ghost:hover{background:var(--glass-strong);border-color:rgba(106,133,232,0.40)}
.trust-strip{margin:var(--s-10) auto 0;max-width:1080px;display:flex;flex-wrap:wrap;justify-content:center;gap:var(--s-4) var(--s-6);font-family:var(--font-sans);font-size:12px;font-weight:500;letter-spacing:.04em;color:var(--muted);text-align:center}
.trust-strip span{position:relative;padding:0 var(--s-2)}
.trust-strip span + span::before{content:"·";position:absolute;left:-12px;color:var(--brand-400);font-weight:700}

/* ============================================================
   Hub cards (home)
   ============================================================ */
.hubs{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);margin-top:var(--s-5)}
@media (max-width:960px){.hubs{grid-template-columns:1fr}}
.hub-card{position:relative;padding:var(--s-8) var(--s-7);border-radius:var(--r-xl);background:linear-gradient(160deg,rgba(15,21,46,0.85),rgba(8,13,31,0.70));border:1px solid var(--rule);overflow:hidden;transition:transform var(--t-base),border-color var(--t-base),box-shadow var(--t-base);min-height:560px;display:flex;flex-direction:column}
.hub-card::before{content:"";position:absolute;inset:0;background:radial-gradient(520px 240px at 50% -10%,rgba(59,92,217,0.20),transparent 65%);opacity:0;transition:opacity var(--t-base);pointer-events:none}
.hub-card:hover{transform:translateY(-3px);border-color:rgba(106,133,232,0.40);box-shadow:var(--shadow-lift)}
.hub-card:hover::before{opacity:1}
.hub-card .hub-eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-300);margin:0 0 var(--s-4)}
.hub-card h3{font-family:var(--font-display-alt);font-weight:700;font-size:24px;line-height:1.18;color:#fff;margin:0 0 var(--s-4);letter-spacing:-.01em}
.hub-card .hub-lead{font-family:var(--font-body);font-size:14.5px;line-height:1.65;color:var(--muted-strong);margin:0 0 var(--s-6);flex:1}
.hub-card .hub-internal{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-3);border-top:1px solid var(--rule);padding-top:var(--s-5)}
.hub-card .hub-internal li{display:flex;flex-direction:column;gap:2px}
.hub-card .hub-internal .hi-tag{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-300)}
.hub-card .hub-internal .hi-link{font-family:var(--font-body);font-size:14px;font-weight:500;color:#fff;line-height:1.4}
.hub-card .hub-internal .hi-link:hover{color:var(--brand-300)}
.hub-card .hub-internal .hi-desc{font-family:var(--font-body);font-size:13px;line-height:1.5;color:var(--muted)}
.hub-card .hub-go{display:inline-flex;align-items:center;gap:6px;margin-top:var(--s-6);padding-top:var(--s-4);border-top:1px solid var(--rule);font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-300)}
.hub-card .hub-go:hover{color:#fff}

/* ============================================================
   Featured cards grid
   ============================================================ */
.featured{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}
@media (max-width:1024px){.featured{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.featured{grid-template-columns:1fr}}
.fc{padding:var(--s-6);border-radius:var(--r-lg);background:var(--glass);border:1px solid var(--rule);transition:border-color var(--t-base),background var(--t-base);display:flex;flex-direction:column;gap:var(--s-3);min-height:240px}
.fc:hover{border-color:rgba(106,133,232,0.40);background:var(--glass-strong)}
.fc-eyebrow{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-300)}
.fc-headline{font-family:var(--font-display-alt);font-weight:700;font-size:18px;line-height:1.25;color:#fff;letter-spacing:-.005em;margin:0}
.fc-headline a:hover{color:var(--brand-300)}
.fc-dek{font-family:var(--font-body);font-size:13.5px;line-height:1.6;color:var(--muted-strong);margin:0;flex:1}
.fc-meta{display:flex;align-items:center;gap:var(--s-3);font-family:var(--font-sans);font-size:11px;color:var(--muted);letter-spacing:.04em;margin-top:auto;padding-top:var(--s-3);border-top:1px solid var(--rule)}
.fc-meta strong{font-family:var(--font-display);font-weight:600;color:var(--brand-300);font-size:11px;letter-spacing:.10em;text-transform:uppercase}

/* ============================================================
   Trilhas (Comece por aqui)
   ============================================================ */
.trilhas{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}
@media (max-width:960px){.trilhas{grid-template-columns:1fr}}
.trilha{padding:var(--s-7) var(--s-6);border-radius:var(--r-xl);background:linear-gradient(180deg,rgba(15,21,46,0.65),rgba(8,13,31,0.45));border:1px solid var(--rule);display:flex;flex-direction:column;gap:var(--s-4)}
.trilha-q{font-family:var(--font-display-alt);font-weight:700;font-size:17px;line-height:1.35;color:#fff;margin:0;padding-bottom:var(--s-4);border-bottom:1px solid var(--rule)}
.trilha ol{list-style:none;padding:0;margin:0;counter-reset:t;display:flex;flex-direction:column;gap:var(--s-4)}
.trilha ol li{counter-increment:t;display:grid;grid-template-columns:32px 1fr;gap:var(--s-3);align-items:start}
.trilha ol li::before{content:counter(t,decimal-leading-zero);font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--brand-300);background:rgba(59,92,217,0.14);border:1px solid rgba(106,133,232,0.30);border-radius:var(--r-full);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;letter-spacing:0}
.trilha ol li > div{display:flex;flex-direction:column;gap:4px}
.trilha ol li .t-label{font-family:var(--font-body);font-weight:600;font-size:14px;color:#fff;line-height:1.4}
.trilha ol li .t-label:hover{color:var(--brand-300)}
.trilha ol li .t-desc{font-family:var(--font-body);font-size:13px;line-height:1.5;color:var(--muted)}
.trilha-cta{margin-top:auto;padding-top:var(--s-3);font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-300)}
.trilha-cta:hover{color:#fff}

/* ============================================================
   Manifesto
   ============================================================ */
.manifesto{max-width:820px;margin:0 auto;text-align:center}
.manifesto p{font-family:var(--font-body);font-size:clamp(15px,1.4vw,17px);line-height:1.7;color:var(--muted-strong);margin:0 0 var(--s-7)}
.manifesto-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--s-3)}
.manifesto-pills span{padding:8px var(--s-4);border-radius:var(--r-full);border:1px solid rgba(106,133,232,0.30);background:rgba(59,92,217,0.10);font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--brand-300)}

/* ============================================================
   Newsletter
   ============================================================ */
.newsletter{max-width:680px;margin:0 auto;text-align:center}
.newsletter-form{display:flex;gap:var(--s-3);margin-top:var(--s-7);background:var(--glass);border:1px solid var(--rule-strong);border-radius:var(--r-full);padding:6px 6px 6px var(--s-5);max-width:560px;margin-left:auto;margin-right:auto}
.newsletter-form input{flex:1;background:transparent;border:0;color:#fff;font-family:var(--font-body);font-size:14px;outline:none;padding:10px 0}
.newsletter-form input::placeholder{color:var(--muted)}
.newsletter-form button{background:var(--brand-500);color:#fff;border:1px solid var(--brand-400);border-radius:var(--r-full);padding:10px var(--s-5);font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.newsletter-form button:hover{background:var(--brand-600)}
.community-list{margin-top:var(--s-8);display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}
@media (max-width:720px){.community-list{grid-template-columns:1fr}}
.community-list li{list-style:none;padding:var(--s-4);border-radius:var(--r-md);background:var(--glass);border:1px solid var(--rule);text-align:left}
.community-list li strong{display:block;font-family:var(--font-display-alt);font-weight:700;font-size:14px;color:#fff;margin-bottom:4px}
.community-list li span{font-family:var(--font-body);font-size:13px;color:var(--muted);line-height:1.45}
.community-list li small{display:inline-block;margin-top:6px;font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--warn)}

/* ============================================================
   Hub / Category / Subcategory pages
   ============================================================ */
.crumbs{font-family:var(--font-sans);font-size:11.5px;color:var(--muted);letter-spacing:.04em;padding:var(--s-7) 0 0;display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.crumbs a{color:var(--muted-strong);transition:color var(--t-fast)}
.crumbs a:hover{color:#fff}
.crumbs .sep{opacity:.5}
.crumbs strong{color:#fff;font-weight:600}

.page-hero{padding:var(--s-10) 0 var(--s-8);max-width:880px}
.page-hero .eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-300);margin:0 0 var(--s-3)}
.page-hero h1{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(34px,5vw,64px);line-height:1.05;letter-spacing:-.02em;margin:0;color:#fff}
.page-hero .dek{font-family:var(--font-body);font-size:clamp(15px,1.4vw,18px);line-height:1.7;color:var(--muted-strong);margin:var(--s-6) 0 0;max-width:720px}

.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}
@media (max-width:960px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cat-grid{grid-template-columns:1fr}}
.cat-card{padding:var(--s-6);border-radius:var(--r-lg);background:var(--glass);border:1px solid var(--rule);display:flex;flex-direction:column;gap:var(--s-3);transition:border-color var(--t-base),background var(--t-base);min-height:200px}
.cat-card:hover{border-color:rgba(106,133,232,0.40);background:var(--glass-strong)}
.cat-card h3{font-family:var(--font-display-alt);font-weight:700;font-size:18px;line-height:1.25;color:#fff;margin:0;letter-spacing:-.005em}
.cat-card h3 a:hover{color:var(--brand-300)}
.cat-card .cat-tagline{font-family:var(--font-body);font-size:13.5px;line-height:1.55;color:var(--muted-strong);margin:0;flex:1}
.cat-card .cat-count{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.04em}
.cat-card .cat-subs{list-style:none;padding:0;margin:var(--s-3) 0 0;display:flex;flex-direction:column;gap:4px}
.cat-card .cat-subs li a{font-family:var(--font-body);font-size:13px;color:var(--muted-strong);padding:4px 0;display:block}
.cat-card .cat-subs li a:hover{color:var(--brand-300)}
.cat-card .cat-go{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-300);margin-top:auto;padding-top:var(--s-3);border-top:1px solid var(--rule)}

/* Subcategory placeholder */
.sub-status{display:inline-flex;align-items:center;gap:8px;padding:6px var(--s-3);border-radius:var(--r-full);background:rgba(251,191,36,0.12);border:1px solid rgba(251,191,36,0.30);font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--warn);margin-bottom:var(--s-5)}
.sub-status .dot{width:6px;height:6px;border-radius:50%;background:var(--warn);box-shadow:0 0 8px rgba(251,191,36,0.55)}
.sub-meta{display:flex;flex-wrap:wrap;gap:var(--s-3);margin-top:var(--s-6);padding-top:var(--s-5);border-top:1px solid var(--rule);font-family:var(--font-sans);font-size:12px;color:var(--muted)}
.sub-meta strong{color:#fff;font-weight:600;font-family:var(--font-display-alt)}
.sub-query{margin:var(--s-7) 0;padding:var(--s-6);border-left:4px solid var(--brand-500);background:var(--glass);border-radius:0 var(--r-md) var(--r-md) 0}
.sub-query .q-label{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-300);margin:0 0 var(--s-2)}
.sub-query .q-text{font-family:var(--font-body);font-size:16px;line-height:1.55;color:#fff;margin:0;font-style:italic}
.related{margin-top:var(--s-9)}
.related h2{font-family:var(--font-display-alt);font-weight:700;font-size:22px;color:#fff;margin:0 0 var(--s-5);letter-spacing:-.01em}
.related-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s-4)}
@media (max-width:720px){.related-list{grid-template-columns:1fr}}
/* Legacy direct-anchor fallback (caso algum render antigo ainda use <a>) */
.related-list > a:not(.related-card){padding:var(--s-5);background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-md);display:flex;flex-direction:column;gap:6px}
.related-list > a:not(.related-card):hover{border-color:rgba(106,133,232,0.40);background:var(--glass-strong)}
.related-list > a:not(.related-card) strong{font-family:var(--font-body);font-weight:600;font-size:14px;color:#fff}
.related-list > a:not(.related-card) span{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   Article full (subcategoria publicada)
   ============================================================ */
.article-hero{padding:var(--s-10) 0 var(--s-7);max-width:880px}
.article-hero .eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-300);margin:0 0 var(--s-3)}
.article-title{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(30px,4.6vw,56px);line-height:1.07;letter-spacing:-.022em;margin:0;color:#fff}
.article-dek{font-family:var(--font-body);font-size:clamp(17px,1.6vw,21px);line-height:1.55;color:var(--muted-strong);margin:var(--s-6) 0 0;max-width:760px;font-weight:400}
.article-meta{display:flex;flex-wrap:wrap;gap:var(--s-4);margin-top:var(--s-7);padding-top:var(--s-5);border-top:1px solid var(--rule);font-family:var(--font-sans);font-size:12px;color:var(--muted);letter-spacing:.02em}
.article-meta strong{color:#fff;font-family:var(--font-display-alt);font-weight:600;letter-spacing:.04em}

.article-prose{max-width:760px;margin:0 auto;padding:var(--s-7) 0 var(--s-9);font-family:var(--font-body);color:var(--muted-strong)}
.article-prose h2{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(22px,2.6vw,30px);line-height:1.2;letter-spacing:-.012em;color:#fff;margin:var(--s-10) 0 var(--s-5);text-align:left}
.article-prose h2:first-child{margin-top:0}
.article-prose h3{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(18px,2vw,22px);line-height:1.25;color:#fff;margin:var(--s-8) 0 var(--s-4);text-align:left;letter-spacing:-.005em}
.article-prose p{font-family:var(--font-body);font-size:clamp(16px,1.05vw,17.5px);line-height:1.78;color:var(--muted-strong);margin:0 0 var(--s-5);text-align:justify;text-justify:inter-word;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;word-break:normal;overflow-wrap:break-word}
.article-prose p:first-of-type::first-letter{font-family:var(--font-display);font-weight:800;font-size:3.2em;line-height:0.92;float:left;margin:6px var(--s-3) 0 0;color:var(--brand-300);text-shadow:0 0 24px rgba(106,133,232,0.30)}
.article-prose strong{color:#fff;font-weight:600}
.article-prose em{color:#e6eaff;font-style:italic}
.article-prose a{color:var(--brand-300);border-bottom:1px solid rgba(106,133,232,0.30);transition:color var(--t-fast),border-color var(--t-fast)}
.article-prose a:hover{color:#fff;border-bottom-color:var(--brand-400)}

.article-prose .article-list{margin:0 0 var(--s-6);padding:0 0 0 var(--s-6);list-style:none}
.article-prose .article-list li{position:relative;font-family:var(--font-body);font-size:clamp(15.5px,1.05vw,17px);line-height:1.72;color:var(--muted-strong);margin:0 0 var(--s-3);padding-left:var(--s-4);text-align:left}
.article-prose .article-list li::before{content:"";position:absolute;left:0;top:14px;width:8px;height:8px;border-radius:50%;background:var(--brand-400);box-shadow:0 0 8px rgba(106,133,232,0.40)}
.article-prose .article-list.numbered{counter-reset:list}
.article-prose .article-list.numbered li{counter-increment:list;padding-left:var(--s-7)}
.article-prose .article-list.numbered li::before{content:counter(list,decimal-leading-zero);width:auto;height:auto;background:transparent;box-shadow:none;font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--brand-300);top:0;letter-spacing:.04em}

.article-prose .article-pull{margin:var(--s-8) 0;padding:var(--s-6) var(--s-7);border-left:4px solid var(--brand-500);background:linear-gradient(180deg,rgba(59,92,217,0.10),rgba(8,13,31,0.30));border-radius:0 var(--r-md) var(--r-md) 0;font-family:var(--font-display-alt);font-weight:600;font-size:clamp(19px,1.8vw,24px);line-height:1.4;color:#fff;letter-spacing:-.005em;text-align:left}
.article-prose .article-pull::before{content:"\201C";font-family:var(--font-display);font-size:48px;color:var(--brand-400);line-height:0;display:inline-block;margin-right:8px;vertical-align:-8px;opacity:.6}

.article-prose .article-table-wrap{margin:var(--s-7) 0;overflow-x:auto;border-radius:var(--r-md);border:1px solid var(--rule)}
.article-prose .article-table{width:100%;min-width:520px;border-collapse:collapse;font-family:var(--font-body);font-size:14.5px}
.article-prose .article-table caption{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-300);text-align:left;padding:var(--s-3) var(--s-4);background:rgba(59,92,217,0.08);border-bottom:1px solid var(--rule)}
.article-prose .article-table thead th{font-family:var(--font-display-alt);font-weight:700;font-size:12.5px;letter-spacing:.04em;color:#fff;background:var(--glass-strong);padding:var(--s-3) var(--s-4);text-align:left;border-bottom:1px solid var(--rule-strong);text-transform:uppercase}
.article-prose .article-table tbody td{padding:var(--s-3) var(--s-4);border-bottom:1px solid var(--rule);color:var(--muted-strong);vertical-align:top;line-height:1.55}
.article-prose .article-table tbody tr:last-child td{border-bottom:0}
.article-prose .article-table tbody tr:hover td{background:rgba(59,92,217,0.06)}

@media (max-width:720px){
  .article-prose p{text-align:left;hyphens:none}
  .article-prose p:first-of-type::first-letter{font-size:2.6em;margin:4px var(--s-2) 0 0}
  .article-hero{padding:var(--s-7) 0 var(--s-5)}
  .article-meta{flex-direction:column;gap:var(--s-2)}
}

/* FAQ no fim do artigo */
.article-faq{max-width:760px;margin:var(--s-9) auto 0;padding:var(--s-7) 0;border-top:1px solid var(--rule)}
.article-faq h2{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(22px,2.4vw,28px);color:#fff;margin:0 0 var(--s-6);letter-spacing:-.012em}
.faq-list{display:flex;flex-direction:column;gap:var(--s-3)}
.faq-item{padding:var(--s-4) var(--s-5);background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-md);transition:border-color var(--t-fast),background var(--t-fast)}
.faq-item[open]{border-color:rgba(106,133,232,0.40);background:var(--glass-strong)}
.faq-item summary.faq-q{list-style:none;cursor:pointer;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s-4);font-family:var(--font-display-alt);font-weight:700;font-size:16px;line-height:1.4;color:#fff}
.faq-item summary.faq-q::-webkit-details-marker{display:none}
.faq-item summary.faq-q::after{content:"+";font-family:var(--font-display);font-size:22px;color:var(--brand-300);transition:transform var(--t-fast);flex:0 0 auto;line-height:1}
.faq-item[open] summary.faq-q::after{transform:rotate(45deg)}
.faq-a{font-family:var(--font-body);font-size:15.5px;line-height:1.7;color:var(--muted-strong);margin-top:var(--s-3);padding-top:var(--s-3);border-top:1px solid var(--rule);text-align:justify;hyphens:auto}
@media (max-width:720px){.faq-a{text-align:left;hyphens:none}}

/* Fontes consultadas */
.article-sources{max-width:760px;margin:var(--s-8) auto 0;padding:var(--s-6) 0}
.article-sources h2{font-family:var(--font-display-alt);font-weight:700;font-size:18px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 var(--s-4)}
.sources-list{margin:0;padding:0 0 0 var(--s-5);list-style:decimal-leading-zero}
.sources-list li{font-family:var(--font-body);font-size:13.5px;line-height:1.6;color:var(--muted);margin-bottom:var(--s-2)}
.sources-list li::marker{color:var(--brand-300);font-family:var(--font-mono);font-size:11px}
.sources-list li a{color:var(--muted-strong);border-bottom:1px dotted rgba(255,255,255,0.20);transition:color var(--t-fast)}
.sources-list li a:hover{color:#fff;border-bottom-color:var(--brand-400)}
.sources-list li small{color:var(--muted);font-family:var(--font-mono);font-size:11px}

/* ============================================================
   Footer
   ============================================================ */
footer.site{margin-top:auto;padding:var(--s-10) 0 var(--s-8);border-top:1px solid var(--rule);background:linear-gradient(180deg,transparent,rgba(5,8,24,0.6))}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:var(--s-8);margin-bottom:var(--s-9)}
@media (max-width:960px){.foot-grid{grid-template-columns:1fr 1fr;gap:var(--s-7)}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr}}
.foot-col h4{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 var(--s-4)}
.foot-col p,.foot-col li{font-family:var(--font-body);font-size:13.5px;line-height:1.65;color:var(--muted-strong);margin:0 0 var(--s-2)}
.foot-col ul{list-style:none;padding:0;margin:0}
.foot-col a{color:var(--muted-strong);border-bottom:1px solid transparent;transition:color var(--t-fast),border-color var(--t-fast);padding-bottom:1px}
.foot-col a:hover{color:#fff;border-bottom-color:var(--brand-400)}
.foot-col em{font-style:normal;color:var(--brand-300)}
.foot-sponsor{margin-top:var(--s-5);padding:var(--s-4);border-radius:var(--r-md);background:var(--glass);border:1px solid var(--rule)}
.foot-sponsor strong{font-family:var(--font-display-alt);color:#fff;font-weight:700}
.foot-sponsor small{display:block;margin-top:6px;font-family:var(--font-sans);font-size:10.5px;color:var(--muted);line-height:1.5}
.foot-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--s-4);padding-top:var(--s-6);border-top:1px solid var(--rule);font-family:var(--font-sans);font-size:11px;color:var(--muted);letter-spacing:.04em}
.foot-bar .build{font-family:var(--font-mono);font-size:10px;opacity:.7}

/* ============================================================
   Sitemap visual (/mapa-do-site) — overview ilustrado + filtros
   ============================================================ */
.sitemap-overview{margin:var(--s-7) 0 var(--s-9);padding:var(--s-7) var(--s-6);background:linear-gradient(180deg,rgba(15,21,46,0.55),rgba(8,13,31,0.30));border:1px solid var(--rule);border-radius:var(--r-xl);position:relative;overflow:hidden}
.sitemap-overview::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(106,133,232,0.45),transparent);opacity:.7}
.sm-overview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4);margin-bottom:var(--s-6)}
@media (max-width:760px){.sm-overview-grid{grid-template-columns:1fr;gap:var(--s-3)}}
.sm-overview-card{padding:var(--s-5);background:rgba(8,13,31,0.55);border:1px solid var(--rule);border-radius:var(--r-lg);display:flex;flex-direction:column;gap:8px;text-decoration:none;color:#fff;transition:transform var(--t-base),border-color var(--t-base),background var(--t-base);position:relative;overflow:hidden}
.sm-overview-card:hover{transform:translateY(-2px);border-color:rgba(106,133,232,0.55);background:rgba(15,21,46,0.65)}
.sm-overview-card[data-hub-overview="atleta"]:hover{border-color:rgba(125,211,252,0.55);box-shadow:0 8px 24px rgba(125,211,252,0.10)}
.sm-overview-card[data-hub-overview="academia"]:hover{border-color:rgba(251,191,36,0.55);box-shadow:0 8px 24px rgba(251,191,36,0.10)}
.sm-overview-card[data-hub-overview="personal"]:hover{border-color:rgba(167,139,250,0.55);box-shadow:0 8px 24px rgba(167,139,250,0.10)}
.sm-overview-shape{position:absolute;top:var(--s-3);right:var(--s-3);width:28px;height:28px;border-radius:50%;border:2px solid rgba(106,133,232,0.30);overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.sm-overview-shape-fill{display:block;width:100%;height:var(--fill);background:linear-gradient(180deg,var(--ok),rgba(52,211,153,0.30))}
.sm-overview-eyebrow{font-family:var(--font-sans);font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-300)}
.sm-overview-card[data-hub-overview="atleta"] .sm-overview-eyebrow{color:#7dd3fc}
.sm-overview-card[data-hub-overview="academia"] .sm-overview-eyebrow{color:#fbbf24}
.sm-overview-card[data-hub-overview="personal"] .sm-overview-eyebrow{color:#a78bfa}
.sm-overview-title{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(20px,2.4vw,26px);line-height:1.1;color:#fff;letter-spacing:-.01em}
.sm-overview-stats{font-family:var(--font-mono);font-size:12px;color:var(--muted)}
.sm-overview-stats strong{color:#fff;font-weight:700}
.sm-overview-divider{margin:0 6px;color:var(--rule-strong)}
.sm-overview-bar{display:block;width:100%;height:5px;border-radius:var(--r-full);background:rgba(255,255,255,0.06);overflow:hidden;margin:6px 0 4px}
.sm-overview-bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--ok),rgba(52,211,153,0.55));transition:width var(--t-slow)}
.sm-overview-tagline{font-family:var(--font-body);font-size:13.5px;line-height:1.5;color:var(--muted-strong)}
.sm-overview-cta{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-300);margin-top:auto;padding-top:8px;border-top:1px solid var(--rule)}
.sm-overview-card:hover .sm-overview-cta{color:#fff}

.sm-tree{margin:0 auto;max-width:760px;text-align:center;padding-top:var(--s-3);border-top:1px dashed var(--rule)}
.sm-tree svg{width:100%;height:auto;max-height:230px}
.sm-tree-caption{margin:var(--s-3) 0 0;font-family:var(--font-sans);font-size:11.5px;color:var(--muted);letter-spacing:.04em}

.sitemap{margin:var(--s-7) 0;container-type:inline-size}
.sm-controls{position:sticky;top:64px;z-index:20;display:flex;flex-direction:column;gap:var(--s-4);margin-bottom:var(--s-8);padding:var(--s-5) var(--s-5);background:linear-gradient(180deg,rgba(8,13,31,0.96),rgba(6,9,26,0.94));backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border:1px solid var(--rule-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-soft)}
.sm-search{position:relative;display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);background:var(--glass-strong);border:1px solid var(--rule);border-radius:var(--r-full);transition:border-color var(--t-fast)}
.sm-search:focus-within{border-color:rgba(106,133,232,0.55);background:rgba(59,92,217,0.06)}
.sm-search svg{width:18px;height:18px;color:var(--muted);flex:0 0 auto}
.sm-search input{flex:1 1 auto;background:transparent;border:0;outline:none;color:#fff;font-family:var(--font-body);font-size:15px;padding:6px 0}
.sm-search input::placeholder{color:var(--muted)}
.sm-filters{display:flex;flex-wrap:wrap;gap:var(--s-3) var(--s-5)}
.sm-filter-group{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.sm-chip{padding:7px 14px;border-radius:var(--r-full);background:var(--glass);border:1px solid var(--rule);font-family:var(--font-sans);font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-strong);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}
.sm-chip:hover{color:#fff;background:var(--glass-strong);border-color:rgba(106,133,232,0.30)}
.sm-chip.sm-chip-on{color:#fff;background:rgba(59,92,217,0.22);border-color:rgba(106,133,232,0.55);box-shadow:0 0 0 1px rgba(106,133,232,0.25) inset}

.sm-hubs{display:flex;flex-direction:column;gap:var(--s-9)}
.sm-hub{padding:var(--s-7) var(--s-6) var(--s-8);background:linear-gradient(180deg,rgba(15,21,46,0.55),rgba(8,13,31,0.30));border:1px solid var(--rule);border-radius:var(--r-xl);position:relative;overflow:hidden}
.sm-hub::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,transparent,rgba(106,133,232,0.45),transparent);opacity:.7}
.sm-hub-head{display:grid;grid-template-columns:1fr auto;gap:var(--s-5) var(--s-7);align-items:end;margin-bottom:var(--s-7);padding-bottom:var(--s-5);border-bottom:1px solid var(--rule)}
@media (max-width:640px){.sm-hub-head{grid-template-columns:1fr}}
.sm-hub-eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-300);margin:0 0 var(--s-2)}
.sm-hub-title{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(24px,3.2vw,34px);line-height:1.1;color:#fff;margin:0;letter-spacing:-.018em}
.sm-hub-title a{color:#fff;transition:color var(--t-fast)}
.sm-hub-title a:hover{color:var(--brand-300)}
.sm-hub-tagline{font-family:var(--font-body);font-size:14.5px;color:var(--muted-strong);margin:var(--s-2) 0 0;max-width:560px;line-height:1.55}
.sm-hub-stats{display:flex;flex-wrap:wrap;gap:var(--s-3);align-items:center;justify-self:end}
@media (max-width:640px){.sm-hub-stats{justify-self:start}}
.sm-hub-stat,.sm-hub-stat-soft{font-family:var(--font-sans);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:var(--r-full);border:1px solid var(--rule)}
.sm-hub-stat{color:var(--ok);background:rgba(52,211,153,0.10);border-color:rgba(52,211,153,0.30)}
.sm-hub-stat strong{font-family:var(--font-display);font-weight:700;color:var(--ok);margin-right:4px}
.sm-hub-stat-soft{color:var(--muted)}
.sm-hub-stat-soft strong{font-family:var(--font-display);font-weight:700;color:#fff;margin-right:4px}

.sm-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--s-6)}
@container (max-width:600px){.sm-cats{grid-template-columns:1fr}}
.sm-cat{padding:var(--s-5);background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-lg);transition:border-color var(--t-base),background var(--t-base)}
.sm-cat:hover{border-color:rgba(106,133,232,0.30);background:var(--glass-strong)}
.sm-cat-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--s-3);margin-bottom:var(--s-3);padding-bottom:var(--s-3);border-bottom:1px solid var(--rule)}
.sm-cat-title{font-family:var(--font-display-alt);font-weight:700;font-size:17px;line-height:1.2;margin:0;color:#fff;letter-spacing:-.005em}
.sm-cat-title a{color:#fff;transition:color var(--t-fast)}
.sm-cat-title a:hover{color:var(--brand-300)}
.sm-cat-stat{font-family:var(--font-mono);font-size:10.5px;color:var(--muted);letter-spacing:.04em;white-space:nowrap}
.sm-cat-tagline{font-family:var(--font-body);font-size:13px;line-height:1.5;color:var(--muted);margin:0 0 var(--s-3)}
.sm-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}
.sm-item a{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;margin-left:-10px;border-radius:var(--r-sm);transition:background var(--t-fast),transform var(--t-fast)}
.sm-item a:hover{background:rgba(59,92,217,0.10);transform:translateX(2px)}
.sm-dot{font-size:10px;line-height:1.5;flex:0 0 auto;margin-top:2px}
.sm-item-pub .sm-dot{color:var(--ok);text-shadow:0 0 6px rgba(52,211,153,0.45)}
.sm-item-soon .sm-dot{color:var(--muted);opacity:.5}
.sm-item-text{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}
.sm-item-text strong{font-family:var(--font-body);font-weight:500;font-size:14px;line-height:1.35;color:#fff}
.sm-item-soon .sm-item-text strong{color:var(--muted-strong);font-weight:400}
.sm-item-text small{font-family:var(--font-body);font-size:12px;line-height:1.4;color:var(--muted);font-weight:400}
.sm-status{font-family:var(--font-sans);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-full);border:1px solid;flex:0 0 auto;margin-top:1px}
.sm-item-pub .sm-status{color:var(--ok);background:rgba(52,211,153,0.10);border-color:rgba(52,211,153,0.30)}
.sm-item-soon .sm-status{color:var(--muted);background:transparent;border-color:var(--rule)}

.sm-helpers{padding:var(--s-9) 0;margin-top:var(--s-10);border-top:1px solid var(--rule)}
.sm-helpers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s-4)}
.sm-helper{padding:var(--s-6);background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-lg);display:flex;flex-direction:column;gap:var(--s-2);transition:border-color var(--t-base),background var(--t-base),transform var(--t-base)}
.sm-helper:hover{border-color:rgba(106,133,232,0.40);background:var(--glass-strong);transform:translateY(-2px)}
.sm-helper-eyebrow{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-300);margin:0}
.sm-helper-title{font-family:var(--font-display-alt);font-weight:700;font-size:19px;color:#fff;letter-spacing:-.005em}
.sm-helper-desc{font-family:var(--font-body);font-size:13.5px;line-height:1.6;color:var(--muted-strong)}
.sm-helper-tech .sm-helper-title{font-family:var(--font-mono);font-size:16px;letter-spacing:.02em}

/* ============================================================
   Related-auto v2 — crosslinks ricos com persona/intent badges
   ============================================================ */
.related-head{display:flex;flex-direction:column;gap:4px;margin:0 0 var(--s-5)}
.related-eyebrow{font-family:var(--font-sans);font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-300)}
.related-head h2{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(20px,2.4vw,26px);color:#fff;margin:0;letter-spacing:-.012em;line-height:1.2}
.related-auto{margin-top:var(--s-8)}
.related-auto h2{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(20px,2.4vw,26px);color:#fff;margin:0;letter-spacing:-.012em}

.related-list .related-card{padding:var(--s-5);background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-md);display:flex;flex-direction:column;gap:8px;text-decoration:none;color:#fff;position:relative;overflow:hidden;transition:transform var(--t-base),border-color var(--t-base),background var(--t-base)}
.related-list .related-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand-500);opacity:0;transition:opacity var(--t-fast)}
.related-list .related-card:hover,.related-list .related-card:focus-visible{transform:translateY(-2px);border-color:rgba(106,133,232,0.45);background:var(--glass-strong)}
.related-list .related-card:hover::before,.related-list .related-card:focus-visible::before{opacity:1}
.related-list .related-card[data-hub="atleta"]::before{background:#7dd3fc}
.related-list .related-card[data-hub="academia"]::before{background:#fbbf24}
.related-list .related-card[data-hub="personal"]::before{background:#a78bfa}
.related-list .related-card[data-hub="atleta"]:hover{border-color:rgba(125,211,252,0.45)}
.related-list .related-card[data-hub="academia"]:hover{border-color:rgba(251,191,36,0.45)}
.related-list .related-card[data-hub="personal"]:hover{border-color:rgba(167,139,250,0.45)}

.related-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-family:var(--font-sans);font-size:10.5px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--muted)}
.related-meta-hub{color:var(--brand-300)}
.related-list .related-card[data-hub="atleta"] .related-meta-hub{color:#7dd3fc}
.related-list .related-card[data-hub="academia"] .related-meta-hub{color:#fbbf24}
.related-list .related-card[data-hub="personal"] .related-meta-hub{color:#a78bfa}
.related-meta-sep{color:var(--rule-strong);font-weight:400}
.related-meta-cat{color:var(--muted-strong);font-weight:500}
.related-meta-pub{margin-left:auto;color:var(--ok);background:rgba(52,211,153,0.10);border:1px solid rgba(52,211,153,0.25);padding:2px 7px;border-radius:var(--r-full);letter-spacing:.10em;font-size:9.5px}
.related-meta-soon{margin-left:auto;color:var(--muted);background:transparent;border:1px solid var(--rule);padding:2px 7px;border-radius:var(--r-full);letter-spacing:.10em;font-size:9.5px}
.related-meta-ext{margin-left:auto;color:var(--muted);font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:none}
.related-headline{font-family:var(--font-display-alt);font-weight:700;font-size:15.5px;line-height:1.3;color:#fff;letter-spacing:-.005em;margin:2px 0 0}
.related-query{font-family:var(--font-body);font-size:12.5px;line-height:1.45;color:var(--muted);margin:0;font-style:italic}
.related-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.related-tag{font-family:var(--font-sans);font-size:9.5px;font-weight:600;letter-spacing:.10em;text-transform:none;padding:2px 7px;border-radius:var(--r-full);border:1px solid var(--rule);color:var(--muted-strong);background:transparent}
.related-tag-persona{color:var(--brand-300);border-color:rgba(106,133,232,0.30);background:rgba(59,92,217,0.08)}
.related-tag-intent{color:var(--warn);border-color:rgba(251,191,36,0.30);background:rgba(251,191,36,0.06)}

.related-auto-persona{background:linear-gradient(180deg,rgba(59,92,217,0.04),transparent);border-radius:var(--r-lg);padding:var(--s-5);border:1px dashed rgba(106,133,232,0.18);margin-top:var(--s-7)}
.related-auto-persona .related-eyebrow{color:var(--brand-300)}
.related-editorial,.related-entities{margin-top:var(--s-8)}
.related-card-ext .related-headline::after{content:" ↗";font-size:.8em;opacity:.55}

/* ============================================================
   Article: TOC sticky, h2 anchor, paginator, reading progress
   ============================================================ */
/* Scroll margin para anchor jumping (header sticky de ~64px) */
html{scroll-padding-top:88px}
.article-prose h2[id],.article-prose h3[id],[id]{scroll-margin-top:88px}
.article-prose h2{scroll-margin-top:88px}

/* Layout grid main+toc no desktop */
.article-layout{display:grid;grid-template-columns:minmax(0,760px) 260px;gap:var(--s-9);align-items:start;max-width:1080px;margin:0 auto;padding:var(--s-7) 0 var(--s-9)}
@media (max-width:1100px){.article-layout{grid-template-columns:minmax(0,1fr);max-width:760px;gap:var(--s-5)}}
.article-prose{margin:0;padding:0}

.article-toc-aside{position:relative}
.article-toc-mobile{display:none;margin-bottom:var(--s-5);background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-md);padding:var(--s-4) var(--s-5)}
@media (max-width:1100px){.article-toc-mobile{display:block}.article-toc-sticky{display:none}}
.article-toc-mobile > summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);font-family:var(--font-display-alt);font-weight:700;font-size:14px;color:#fff}
.article-toc-mobile > summary::-webkit-details-marker{display:none}
.article-toc-mobile > summary::after{content:"+";font-family:var(--font-display);font-size:20px;color:var(--brand-300);transition:transform var(--t-fast)}
.article-toc-mobile[open] > summary::after{transform:rotate(45deg)}
.article-toc-mobile > summary small{font-family:var(--font-mono);font-size:11px;color:var(--muted);font-weight:500}
.article-toc-mobile .article-toc-list{margin-top:var(--s-4);padding:0;list-style:none}
.article-toc-mobile .article-toc-list li{padding:6px 0;border-top:1px solid var(--rule)}
.article-toc-mobile .article-toc-list li:first-child{border-top:0}
.article-toc-mobile .article-toc-list a{font-family:var(--font-body);font-size:13.5px;line-height:1.45;color:var(--muted-strong);transition:color var(--t-fast)}
.article-toc-mobile .article-toc-list a:hover{color:#fff}
.article-toc-mobile .article-toc-list a.toc-active{color:var(--brand-300);font-weight:600}

.article-toc-sticky{position:sticky;top:80px;max-height:calc(100vh - 96px);overflow-y:auto;padding-left:var(--s-5);border-left:1px solid var(--rule);scrollbar-width:thin;scrollbar-color:rgba(106,133,232,0.35) transparent}
.article-toc-sticky::-webkit-scrollbar{width:6px}
.article-toc-sticky::-webkit-scrollbar-thumb{background:rgba(106,133,232,0.25);border-radius:3px}
.article-toc-eyebrow{font-family:var(--font-sans);font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 var(--s-4)}
.article-toc-foot{font-family:var(--font-mono);font-size:11px;color:var(--muted);margin:var(--s-4) 0 0;padding-top:var(--s-3);border-top:1px solid var(--rule)}
.article-toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px;counter-reset:toc}
.article-toc-list li{counter-increment:toc}
.article-toc-list a{display:block;padding:6px 0 6px var(--s-5);font-family:var(--font-body);font-size:13px;line-height:1.5;color:var(--muted);position:relative;transition:color var(--t-fast),padding-left var(--t-fast),border-color var(--t-fast);border-left:2px solid transparent;margin-left:-2px}
.article-toc-list a::before{content:counter(toc,decimal-leading-zero);position:absolute;left:0;font-family:var(--font-mono);font-size:10px;color:var(--muted);font-weight:600;opacity:.6}
.article-toc-list a:hover{color:#fff}
.article-toc-list a.toc-active{color:var(--brand-300);font-weight:600;border-left-color:var(--brand-400)}
.article-toc-list a.toc-active::before{color:var(--brand-300);opacity:1}

/* H2 com anchor link no hover */
.article-prose h2.article-h2{position:relative}
.article-h2-anchor{position:absolute;left:-1.4em;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-weight:700;font-size:.7em;color:var(--brand-400);opacity:0;text-decoration:none;transition:opacity var(--t-fast),color var(--t-fast);padding:0 .4em}
.article-h2:hover .article-h2-anchor,.article-h2:focus-within .article-h2-anchor{opacity:.85}
.article-h2-anchor:hover{opacity:1!important;color:var(--brand-300)}
@media (max-width:720px){.article-h2-anchor{left:auto;right:0;transform:none;top:0;position:static;display:inline-block;margin-right:.4em;opacity:.55}}

/* Paginator prev/next */
.article-paginator{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);margin:var(--s-10) auto 0;max-width:1080px;padding:0 var(--s-5)}
@media (max-width:720px){.article-paginator{grid-template-columns:1fr;gap:var(--s-3)}}
.article-paginator > a,.article-paginator > span{display:flex;flex-direction:column;gap:6px;padding:var(--s-5) var(--s-6);background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-lg);transition:border-color var(--t-base),background var(--t-base),transform var(--t-base)}
.article-paginator > a:hover{border-color:rgba(106,133,232,0.40);background:var(--glass-strong);transform:translateY(-2px)}
.article-pag-next{text-align:right}
.article-pag-dir{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-300)}
.article-pag-label{font-family:var(--font-display-alt);font-weight:700;font-size:clamp(15px,1.6vw,18px);line-height:1.3;color:#fff;letter-spacing:-.005em}
.article-paginator > a:hover .article-pag-label{color:var(--brand-300)}
.article-pag-empty{visibility:hidden;background:transparent;border:0}

/* Reading progress bar (fixed top) */
.reading-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:100;background:rgba(106,133,232,0.08);opacity:0;transition:opacity var(--t-fast);pointer-events:none}
.reading-progress-fill{width:0;height:100%;background:linear-gradient(90deg,var(--brand-400),var(--brand-500),var(--brand-300));box-shadow:0 0 8px rgba(106,133,232,0.55);transition:width 50ms linear}

/* Share bar (header + bottom) */
.article-share{display:flex;flex-wrap:wrap;gap:var(--s-2);align-items:center;margin-top:var(--s-6);padding-top:var(--s-5);border-top:1px solid var(--rule)}
.article-share-bottom{margin:var(--s-9) auto 0;max-width:1080px;padding:var(--s-5) var(--s-5);background:linear-gradient(180deg,rgba(15,21,46,0.55),rgba(8,13,31,0.30));border:1px solid var(--rule);border-radius:var(--r-lg);border-top:1px solid var(--rule);justify-content:center}
.share-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--glass);border:1px solid var(--rule);border-radius:var(--r-full);font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--muted-strong);transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast),transform var(--t-fast);cursor:pointer}
.share-btn:hover{color:#fff;background:var(--glass-strong);border-color:rgba(106,133,232,0.40);transform:translateY(-1px)}
.share-btn svg{width:15px;height:15px;flex:0 0 auto}
.share-btn span{line-height:1}
@media (max-width:560px){.share-btn span{display:none}.share-btn{padding:9px}}

/* Back to top FAB */
.back-to-top{position:fixed;right:var(--s-5);bottom:var(--s-5);width:46px;height:46px;border-radius:50%;background:rgba(59,92,217,0.92);border:1px solid var(--brand-400);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-lift);opacity:0;transform:translateY(12px) scale(0.92);transition:opacity var(--t-base),transform var(--t-base),background var(--t-fast);z-index:90;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.back-to-top.btt-show{opacity:1;transform:translateY(0) scale(1)}
.back-to-top:hover{background:var(--brand-600)}
.back-to-top svg{width:20px;height:20px}
@media (max-width:560px){.back-to-top{right:var(--s-3);bottom:var(--s-3);width:42px;height:42px}}

/* Toast */
.toast{position:fixed;bottom:calc(var(--s-5) + 60px);left:50%;transform:translateX(-50%) translateY(20px);background:rgba(15,21,46,0.96);color:#fff;font-family:var(--font-body);font-size:14px;padding:10px 16px;border-radius:var(--r-full);border:1px solid rgba(106,133,232,0.35);box-shadow:var(--shadow-lift);opacity:0;transition:opacity var(--t-base),transform var(--t-base);z-index:120;pointer-events:none;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.toast.toast-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Nav search button (header desktop) */
.nav-search{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--r-md);background:var(--glass);border:1px solid var(--rule);color:var(--muted-strong);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast);margin-left:var(--s-2)}
.nav-search:hover{color:#fff;background:var(--glass-strong);border-color:rgba(106,133,232,0.40)}
.nav-search svg{width:15px;height:15px}
.nav-search kbd{font-family:var(--font-mono);font-size:10.5px;background:rgba(106,133,232,0.12);border:1px solid rgba(106,133,232,0.30);color:var(--brand-300);padding:1px 6px;border-radius:4px;line-height:1.2}
@media (max-width:960px){.nav-search{display:none}}
.nav-search-mobile{display:none;width:42px;height:42px;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--glass-strong);border:1px solid var(--rule-strong);cursor:pointer;color:#fff;margin-right:6px}
.nav-search-mobile svg{width:18px;height:18px}
@media (max-width:960px){.nav-search-mobile{display:inline-flex}}

/* Search overlay */
.search-overlay{position:fixed;inset:0;z-index:130;display:none}
.search-overlay[data-open="true"]{display:block}
.search-backdrop{position:absolute;inset:0;background:rgba(6,9,26,0.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:fade-in 160ms ease both}
.search-modal{position:relative;max-width:720px;margin:80px auto 0;background:linear-gradient(180deg,rgba(15,21,46,0.96),rgba(8,13,31,0.94));border:1px solid var(--rule-strong);border-radius:var(--r-xl);box-shadow:var(--shadow-lift);overflow:hidden;animation:slide-in 220ms cubic-bezier(.16,1,.3,1) both}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
@keyframes slide-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.search-header{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-5) var(--s-6);border-bottom:1px solid var(--rule)}
.search-header svg{width:20px;height:20px;color:var(--brand-300);flex:0 0 auto}
.search-header input{flex:1 1 auto;background:transparent;border:0;outline:none;color:#fff;font-family:var(--font-body);font-size:17px;padding:4px 0}
.search-header input::placeholder{color:var(--muted)}
.search-esc{font-family:var(--font-mono);font-size:10.5px;font-weight:700;color:var(--muted);background:var(--glass);border:1px solid var(--rule);padding:3px 7px;border-radius:4px;cursor:pointer;flex:0 0 auto}
.search-esc:hover{color:#fff;background:var(--glass-strong)}
.search-results{max-height:60vh;overflow-y:auto;padding:var(--s-3) var(--s-3);scrollbar-width:thin;scrollbar-color:rgba(106,133,232,0.40) transparent}
.search-results::-webkit-scrollbar{width:6px}
.search-results::-webkit-scrollbar-thumb{background:rgba(106,133,232,0.30);border-radius:3px}
.sr-empty{font-family:var(--font-sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:var(--s-3) var(--s-4) var(--s-4);margin:0}
.sr-item{display:flex;align-items:center;gap:var(--s-3);padding:10px var(--s-4);border-radius:var(--r-md);text-decoration:none;color:#fff;transition:background var(--t-fast)}
.sr-item:hover,.sr-item.sr-active{background:rgba(59,92,217,0.18)}
.sr-text{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}
.sr-text strong{font-family:var(--font-body);font-size:14px;font-weight:600;color:#fff;line-height:1.35}
.sr-text small{font-family:var(--font-sans);font-size:11.5px;color:var(--muted);line-height:1.4}
.sr-text small em{font-style:normal;color:var(--muted-strong)}
.sr-text mark{background:rgba(106,133,232,0.30);color:#fff;border-radius:3px;padding:0 2px}
.sr-status{font-family:var(--font-sans);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-full);border:1px solid;flex:0 0 auto;white-space:nowrap}
.sr-status-pub{color:var(--ok);background:rgba(52,211,153,0.10);border-color:rgba(52,211,153,0.30)}
.sr-status-soon{color:var(--muted);border-color:var(--rule)}
.search-footer{display:flex;flex-wrap:wrap;gap:var(--s-4);align-items:center;padding:var(--s-3) var(--s-6);border-top:1px solid var(--rule);font-family:var(--font-sans);font-size:11px;color:var(--muted);letter-spacing:.04em}
.search-footer kbd{font-family:var(--font-mono);font-size:10px;font-weight:700;color:#fff;background:var(--glass-strong);border:1px solid var(--rule);padding:1px 5px;border-radius:3px;margin-right:2px}
.search-foot-tip{margin-left:auto;font-style:italic;color:var(--muted)}
@media (max-width:640px){.search-modal{margin:40px var(--s-3) 0;border-radius:var(--r-lg)}.search-header{padding:var(--s-4)}.search-header input{font-size:15px}.search-foot-tip{display:none}}

/* Hub page: seção publicados em destaque */
.hub-published{margin:var(--s-9) auto;padding:var(--s-7) 0}
.hub-pub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--s-4)}
.hub-pub-card{padding:var(--s-6);background:linear-gradient(180deg,rgba(15,21,46,0.55),rgba(8,13,31,0.30));border:1px solid var(--rule);border-radius:var(--r-lg);display:flex;flex-direction:column;gap:var(--s-3);transition:border-color var(--t-base),background var(--t-base),transform var(--t-base)}
.hub-pub-card:hover{border-color:rgba(106,133,232,0.40);background:var(--glass-strong);transform:translateY(-2px)}
.hub-pub-eyebrow{font-family:var(--font-sans);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-300);display:flex;align-items:center;gap:8px;margin:0}
.hub-pub-eyebrow::before{content:"●";color:var(--ok);font-size:9px;text-shadow:0 0 6px rgba(52,211,153,0.45)}
.hub-pub-title{font-family:var(--font-display-alt);font-weight:700;font-size:18px;line-height:1.25;color:#fff;margin:0;letter-spacing:-.005em}
.hub-pub-title a{color:#fff;transition:color var(--t-fast)}
.hub-pub-title a:hover{color:var(--brand-300)}
.hub-pub-dek{font-family:var(--font-body);font-size:13.5px;line-height:1.55;color:var(--muted-strong);margin:0;flex:1}
.hub-pub-meta{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11px;color:var(--muted);padding-top:var(--s-3);border-top:1px solid var(--rule);margin-top:auto}

/* Categoria: ordenação de publicados */
.cat-card.cat-pub{border-color:rgba(52,211,153,0.30);background:linear-gradient(180deg,rgba(52,211,153,0.04),var(--glass))}
.cat-card.cat-pub::after{content:"";position:absolute;top:var(--s-3);right:var(--s-3);width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px rgba(52,211,153,0.55)}
.cat-card{position:relative}
.cat-card .cat-status-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-sans);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-full);border:1px solid;width:fit-content;margin-bottom:6px}
.cat-card.cat-pub .cat-status-tag{color:var(--ok);background:rgba(52,211,153,0.10);border-color:rgba(52,211,153,0.30)}
.cat-card.cat-soon .cat-status-tag{color:var(--muted);border-color:var(--rule)}

/* ============================================================
   View Transitions API (Chrome 111+, Safari 18+)
   ============================================================ */
@view-transition{navigation:auto}
::view-transition-old(root){animation:vt-out 240ms cubic-bezier(.4,0,.2,1) both}
::view-transition-new(root){animation:vt-in 280ms cubic-bezier(.16,1,.3,1) both}
@keyframes vt-out{to{opacity:0;transform:translateY(-4px)}}
@keyframes vt-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   Reveal animation + reduced motion
   ============================================================ */
.reveal{opacity:0;transform:translateY(16px);transition:opacity var(--t-slow),transform var(--t-slow)}
.reveal.is-in{opacity:1;transform:translateY(0)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.92)}}
@media (prefers-reduced-motion:no-preference){.tag-dot{animation:pulse 2.4s ease-in-out infinite}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}

/* Print */
@media print{.bg,header.site,nav.mega,.hamb,.drawer{display:none!important}body{background:#fff;color:#000}*{color:#000!important;background:transparent!important;box-shadow:none!important;border-color:#ccc!important}}


/* sitemap-v3 specific */
.smv3-exec { margin: var(--s-6, 28px) 0 var(--s-8, 40px); }
.smv3-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.smv3-kpi {
  display: flex; flex-direction: column; gap: 4px;
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.03);
  border-radius: 12px;
}
.smv3-kpi strong { font-family: Exo, Inter, sans-serif; font-weight: 800; font-size: 28px; line-height: 1; color: #fff; }
.smv3-kpi span { font-size: 12px; color: rgba(255,255,255,0.65); text-transform: lowercase; letter-spacing: 0.02em; }

.smv3-hub-progress-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.smv3-hub-progress {
  display: flex; flex-direction: column; gap: 8px;
  padding: 18px 20px;
  border: 1px solid color-mix(in srgb, var(--smv3-accent, #fff) 35%, transparent);
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border-radius: 14px;
}
.smv3-hub-progress-eyebrow { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--smv3-accent, #fff); margin: 0; }
.smv3-hub-progress-title { font-family: Unbounded, Exo, sans-serif; font-weight: 700; font-size: 22px; line-height: 1.1; margin: 2px 0 4px; color: #fff; }
.smv3-hub-progress-tagline { font-size: 13px; color: rgba(255,255,255,0.72); margin: 0 0 6px; }
.smv3-hub-progress-bar { position: relative; height: 6px; border-radius: 999px; background: rgba(255,255,255,0.08); overflow: hidden; }
.smv3-hub-progress-bar > span { display: block; height: 100%; background: var(--smv3-accent, #fff); border-radius: 999px; }
.smv3-hub-progress-stats { font-family: Cascadia Mono, ui-monospace, monospace; font-size: 12px; color: rgba(255,255,255,0.78); margin: 4px 0 0; }
.smv3-hub-progress-stats strong { color: #fff; font-weight: 700; }
.smv3-hub-progress-cta { font-size: 13px; color: var(--smv3-accent, #fff); text-decoration: none; margin-top: 6px; align-self: flex-start; }
.smv3-hub-progress-cta:hover { text-decoration: underline; }

.smv3-section { margin-top: var(--s-8, 40px); }
.smv3-section-head { margin-bottom: 20px; max-width: 760px; }
.smv3-section-title { font-family: Unbounded, Exo, sans-serif; font-weight: 700; font-size: clamp(24px, 3vw, 32px); line-height: 1.15; margin: 4px 0 8px; color: #fff; }
.smv3-section-dek { font-size: 15px; color: rgba(255,255,255,0.72); margin: 0; max-width: 70ch; }

.smv3-hub-group { margin-bottom: 36px; }
.smv3-hub-group-head { margin-bottom: 14px; padding-left: 14px; border-left: 3px solid var(--smv3-accent, #fff); }
.smv3-hub-group-title {
  display: flex; align-items: center; gap: 10px;
  font-family: Unbounded, Exo, sans-serif; font-weight: 700;
  font-size: clamp(20px, 2.4vw, 26px);
  color: var(--smv3-accent, #fff);
  margin: 0;
}
.smv3-hub-group-dot { width: 10px; height: 10px; border-radius: 999px; background: var(--smv3-accent, #fff); display: inline-block; }
.smv3-hub-group-count { font-family: Cascadia Mono, ui-monospace, monospace; font-size: 12px; color: rgba(255,255,255,0.72); font-weight: 500; margin-left: 8px; }
.smv3-hub-group-tagline { font-size: 13px; color: rgba(255,255,255,0.65); margin: 4px 0 0; }

.smv3-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 14px;
}

.smv3-card {
  position: relative;
  display: flex; flex-direction: column; gap: 10px;
  padding: 18px 18px 16px;
  border: 1px solid rgba(255,255,255,0.10);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border-radius: 14px;
  transition: border-color .2s ease, transform .2s ease;
}
.smv3-card:hover { border-color: color-mix(in srgb, var(--smv3-accent, #fff) 55%, transparent); transform: translateY(-1px); }
.smv3-card-pub::before {
  content: ""; position: absolute; left: 0; top: 14px; bottom: 14px; width: 3px;
  background: var(--smv3-accent, #fff); border-radius: 0 3px 3px 0;
}
.smv3-card-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; font-size: 11px; color: rgba(255,255,255,0.62); }
.smv3-card-eyebrow { text-transform: uppercase; letter-spacing: 0.06em; color: var(--smv3-accent, #fff); font-weight: 600; }
.smv3-card-date { font-family: Cascadia Mono, ui-monospace, monospace; color: rgba(255,255,255,0.55); white-space: nowrap; }
.smv3-card-title { font-family: Unbounded, Exo, sans-serif; font-weight: 700; font-size: 17px; line-height: 1.25; margin: 0; }
.smv3-card-title a { color: #fff; text-decoration: none; }
.smv3-card-title a:hover { text-decoration: underline; text-decoration-color: var(--smv3-accent, #fff); text-underline-offset: 3px; }
.smv3-card-dek { font-size: 13.5px; line-height: 1.5; color: rgba(255,255,255,0.78); margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.smv3-card-meta { display: flex; gap: 14px; flex-wrap: wrap; font-size: 12px; color: rgba(255,255,255,0.62); margin-top: auto; padding-top: 4px; }
.smv3-card-meta strong { color: rgba(255,255,255,0.85); font-weight: 600; }

.smv3-flat-group .smv3-grid { margin-top: 4px; }

@media (max-width: 720px) {
  .smv3-grid { grid-template-columns: 1fr; }
  .smv3-hub-progress-grid { grid-template-columns: 1fr; }
  .smv3-section-title { font-size: 22px; }
  .smv3-card { padding: 16px; }
  .smv3-card-head { flex-direction: column; align-items: flex-start; gap: 2px; }
  .smv3-card-date { font-size: 10.5px; }
}
