/* ============================================================
   BLACKBOX PLATAFORMA — FASE 1 v2 (validação visual)
   Tokens extraídos literalmente do Design System BlackBox
   Fonte: Brandsystem AGL 2023 · Identidade Visual BlackBox
   ============================================================ */
:root{
  /* Cores — hierarquia oficial (predominância do preto) */
  --bb-black:#161616;
  --bb-black-7:#343434;
  --bb-gold:#E79D3A;
  --bb-offwhite:#F3F4F6;
  --bb-white:#FFFFFF;

  /* Superfícies derivadas (dark-first) */
  --bb-canvas:#161616;
  --bb-surface:#1D1D1D;
  --bb-surface-2:#242424;
  --bb-surface-3:#2C2C2C;
  --bb-deep:#0E0E0E;
  --bb-hairline:rgba(255,255,255,.09);
  --bb-hairline-soft:rgba(255,255,255,.05);
  --bb-gold-soft:rgba(231,157,58,.14);
  --bb-gold-deep:#B5731F;
  --bb-gold-dark:#7A4E13;

  /* Texto */
  --bb-ink:#FFFFFF;
  --bb-ink-soft:#E8E8E8;
  --bb-text:#C9C9C9;
  --bb-slate:#9A9A9A;
  --bb-steel:#7B7B7B;
  --bb-muted:#5E5E5E;

  /* Semânticas */
  --bb-success-bg:rgba(76,175,108,.16);
  --bb-success-text:#7BD79A;
  --bb-error:#D45656;

  /* Tipografia */
  --font-display:'Anek Tamil',Epilogue,Helvetica,Arial,sans-serif;
  --font-body:'Epilogue','Anek Tamil',Helvetica,Arial,sans-serif;
  --font-serif:'Rokkitt',Georgia,serif;
  --font-notes:'Sedgwick Ave',cursive;

  /* Espaçamento — base 4px */
  --sp-xxs:4px;--sp-xs:8px;--sp-sm:12px;--sp-md:16px;--sp-lg:20px;
  --sp-xl:24px;--sp-xxl:32px;--sp-xxxl:40px;--sp-section-sm:48px;
  --sp-section:64px;

  /* Raio */
  --r-xs:4px;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;
  --r-xxl:20px;--r-hero:32px;--r-full:9999px;

  /* Elevação */
  --el-1:0 1px 2px rgba(0,0,0,.2);
  --el-2:0 4px 6px rgba(0,0,0,.35);
  --el-3:0 0 22px rgba(0,0,0,.45);
  --el-4:0 12px 16px -4px rgba(0,0,0,.5);
  --el-gold:0 0 28px rgba(231,157,58,.22);

  /* Transições */
  --t-fast:150ms ease;
  --t-base:200ms ease;
  --t-slow:400ms cubic-bezier(.22,.61,.36,1);
  --ease:cubic-bezier(.22,.61,.36,1);

  /* Estrutura */
  --appbar-h:64px;
  --bottomnav-h:64px;
  --sidebar-w:240px;

  /* Atmosferas translúcidas (remapeadas no light) */
  --bb-appbar:rgba(22,22,22,.86);
  --bb-bottomnav:rgba(22,22,22,.92);
  --bb-adm-canvas:#0E0E0E;
  --bb-adm-appbar:rgba(14,14,14,.9);
  --bb-adm-surface:#151515;
  --bb-adm-surface-2:#1B1B1B;
  --bb-adm-snav-hover:#1A1A1A;
  --bb-premium-bg:#101010;
  --bb-on-gold:var(--bb-black);
}

/* ============================================================
   LIGHT MODE — versão complementar derivada do Design System
   (off-white #F3F4F6 / branco / texto preto · dourado mantido
   como destaque). Só remapeia variáveis: nenhum componente muda.
   ============================================================ */
html[data-theme="light"]{
  --bb-canvas:#F3F4F6;
  --bb-surface:#FFFFFF;
  --bb-surface-2:#F7F8FA;
  --bb-surface-3:#ECEEF1;
  --bb-deep:#FFFFFF;
  --bb-hairline:rgba(22,22,22,.12);
  --bb-hairline-soft:rgba(22,22,22,.07);
  --bb-gold-soft:rgba(231,157,58,.16);

  --bb-ink:#161616;
  --bb-ink-soft:#26292E;
  --bb-text:#3C4046;
  --bb-slate:#5E646C;
  --bb-steel:#7C828A;
  --bb-muted:#A0A6AE;

  --bb-success-bg:rgba(34,143,80,.14);
  --bb-success-text:#1E8A4C;

  --el-1:0 1px 2px rgba(22,22,22,.06);
  --el-2:0 4px 10px rgba(22,22,22,.08);
  --el-3:0 0 22px rgba(22,22,22,.10);
  --el-4:0 12px 24px -6px rgba(22,22,22,.18);
  --el-gold:0 0 26px rgba(231,157,58,.30);

  --bb-appbar:rgba(255,255,255,.86);
  --bb-bottomnav:rgba(255,255,255,.92);
  --bb-adm-canvas:#ECEEF1;
  --bb-adm-appbar:rgba(247,248,250,.92);
  --bb-adm-surface:#FFFFFF;
  --bb-adm-surface-2:#F2F3F5;
  --bb-adm-snav-hover:#ECEEF1;
  --bb-premium-bg:#FFFFFF;
}
/* Cartão premium no light: fundo claro com borda/respiro dourado */
html[data-theme="light"] .card-premium{background:linear-gradient(180deg,#FFFFFF,#FFF8EE)}
html[data-theme="light"] .card-premium .sheen{background:linear-gradient(90deg,transparent,rgba(231,157,58,.12),transparent)}
/* Logo acompanha o tema (preto vira escuro no claro) */
html[data-theme="light"]{--bb-logo-ink:#161616}
/* Transição suave ao alternar tema */
html.theme-anim,html.theme-anim *{transition:background-color .35s ease,border-color .35s ease,color .35s ease,box-shadow .35s ease!important}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bb-canvas);
  color:var(--bb-text);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--bb-gold);color:var(--bb-black)}
button{font-family:inherit}
img{max-width:100%;display:block}

/* ============================================================
   ANIMAÇÕES GLOBAIS
   ============================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes growW{from{width:0}}
@keyframes ringIn{from{stroke-dashoffset:var(--c,260)}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 24px rgba(231,157,58,.16)}50%{box-shadow:0 0 44px rgba(231,157,58,.34)}}
@keyframes sheen{0%{transform:translateX(-140%) skewX(-18deg)}55%,100%{transform:translateX(340%) skewX(-18deg)}}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-16px) rotate(3deg)}}
@keyframes floaty2{0%,100%{transform:translateY(-8px) rotate(8deg)}50%{transform:translateY(10px) rotate(-2deg)}}
@keyframes pan{0%{transform:translate3d(-2%,-2%,0) scale(1.04)}50%{transform:translate3d(2%,2%,0) scale(1.08)}100%{transform:translate3d(-2%,-2%,0) scale(1.04)}}
@keyframes pop{0%{transform:scale(1)}45%{transform:scale(1.22)}100%{transform:scale(1)}}
@keyframes dotPing{0%{box-shadow:0 0 0 0 rgba(231,157,58,.5)}80%{box-shadow:0 0 0 7px rgba(231,157,58,0)}100%{box-shadow:0 0 0 0 rgba(231,157,58,0)}}
@keyframes barUp{from{transform:scaleY(0)}}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

/* ---------- Tipografia base (DS §04, escala ampliada) ---------- */
h1,h2,h3,h4,.display{font-family:var(--font-display);color:var(--bb-ink);font-weight:600}
.heading-lg{font-size:32px;line-height:1.2;letter-spacing:-.8px}
.heading-md{font-size:26px;line-height:1.25;letter-spacing:-.5px}
.heading-sm{font-size:21px;line-height:1.3}
.card-title{font-size:18px;line-height:1.35;font-weight:600;font-family:var(--font-display);color:var(--bb-ink)}
.body-sm{font-size:15px;line-height:1.55}
.caption{font-size:14px;line-height:1.6}
.micro{font-size:12.5px;line-height:1.5}
.eyebrow{
  font-family:var(--font-display);font-size:12.5px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--bb-gold);
  display:flex;align-items:center;gap:10px;margin-bottom:var(--sp-sm);
}
.eyebrow::before{content:'';width:26px;height:1px;background:var(--bb-gold);flex:none}
.notes{font-family:var(--font-notes);color:var(--bb-gold)}

/* ---------- Ícones ---------- */
.ic{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:none}
.ic-sm{width:16px;height:16px}

/* ---------- Botões — pílula, assinatura da marca (DS §08) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-size:15px;font-weight:600;line-height:1.4;
  padding:11px 26px;border-radius:var(--r-full);cursor:pointer;border:none;
  text-decoration:none;transition:all var(--t-base);min-height:46px;position:relative;overflow:hidden;
}
.btn-primary{background:var(--bb-gold);color:var(--bb-black)}
.btn-primary:hover{background:#F0B05A;box-shadow:var(--el-gold);transform:translateY(-1px)}
.btn-primary:active{background:var(--bb-gold-deep);transform:translateY(0)}
.btn-primary .ic{transition:transform var(--t-base)}
.btn-primary:hover .ic{transform:translateX(3px)}
.btn-secondary{background:transparent;color:var(--bb-white);border:1px solid var(--bb-white)}
.btn-secondary:hover{border-color:var(--bb-gold);color:var(--bb-gold)}
.btn-tertiary{background:transparent;color:var(--bb-ink-soft);border:1px solid var(--bb-hairline)}
.btn-tertiary:hover{border-color:var(--bb-slate);background:var(--bb-surface-2)}
.btn-link{background:none;color:var(--bb-gold);padding:8px 0;border-radius:0;font-weight:500;min-height:0}
.btn-link:hover{text-decoration:underline}
.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--r-full);
  background:transparent;border:1px solid var(--bb-hairline);color:var(--bb-ink-soft)}
.btn-icon:hover{border-color:var(--bb-gold);color:var(--bb-gold);transform:translateY(-1px)}
.btn-sm{padding:8px 18px;min-height:40px;font-size:14px}
.btn-block{width:100%}

/* ---------- Badges (DS §13) ---------- */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-size:12.5px;font-weight:600;
  padding:4px 11px;border-radius:var(--r-full);white-space:nowrap;
}
.badge-gold{background:var(--bb-gold);color:var(--bb-black)}
.badge-outline{background:transparent;color:var(--bb-gold);border:1px solid var(--bb-gold)}
.badge-success{background:var(--bb-success-bg);color:var(--bb-success-text)}
.badge-soft{background:var(--bb-gold-soft);color:var(--bb-gold)}
.badge-neutral{background:var(--bb-surface-3);color:var(--bb-slate)}

/* ---------- Cards (DS §10) ---------- */
.card{
  background:var(--bb-surface);border:1px solid var(--bb-hairline);
  border-radius:var(--r-xl);padding:var(--sp-lg);
  transition:transform var(--t-base),border-color var(--t-base),box-shadow var(--t-base);
}
.card:hover{transform:translateY(-2px);border-color:rgba(231,157,58,.35);box-shadow:var(--el-2)}
.card-premium{border-color:rgba(231,157,58,.4);background:var(--bb-premium-bg);position:relative;overflow:hidden;animation:glowPulse 4.5s ease-in-out infinite}
.card-premium::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(140% 110% at 50% 120%,rgba(231,157,58,.32),rgba(231,157,58,.05) 55%,transparent 78%)}
.card-premium .sheen{position:absolute;top:-10%;bottom:-10%;width:30%;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.055),transparent);
  animation:sheen 6s 1.4s ease-in-out infinite}
.card-premium>*{position:relative}
.card-static,.card-static:hover{transform:none;box-shadow:none;border-color:var(--bb-hairline)}
.card-premium.card-static:hover{border-color:rgba(231,157,58,.4)}

/* ---------- Grid utilitário ---------- */
.grid{display:grid;gap:var(--sp-md)}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:repeat(2,1fr)}
.stack{display:flex;flex-direction:column;gap:var(--sp-md)}
.row{display:flex;align-items:center;gap:var(--sp-sm)}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-sm)}

/* ---------- Inputs (DS §11 — raio 8px, exceção à pílula) ---------- */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:var(--font-display);font-size:13.5px;font-weight:600;color:var(--bb-ink-soft)}
.input,select.input,textarea.input{
  min-height:46px;background:var(--bb-surface-2);border:1px solid var(--bb-hairline);
  border-radius:var(--r-md);padding:var(--sp-sm) var(--sp-md);color:var(--bb-ink);
  font-family:var(--font-body);font-size:15px;outline:none;width:100%;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
textarea.input{resize:vertical;min-height:92px}
.input::placeholder{color:var(--bb-muted)}
.input:focus{border-color:var(--bb-gold);box-shadow:0 0 0 3px var(--bb-gold-soft)}
.input.error{border-color:var(--bb-error)}
.error-msg{font-size:13px;color:var(--bb-error)}
.input-wrap{position:relative}
.input-wrap .input{padding-right:48px}
.eye{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:38px;height:38px;border:none;background:none;color:var(--bb-steel);cursor:pointer;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;transition:color var(--t-fast)}
.eye:hover{color:var(--bb-gold)}
.search-pill{display:flex;align-items:center;gap:8px;height:42px;background:var(--bb-surface-2);border:1px solid var(--bb-hairline);border-radius:var(--r-full);padding:0 var(--sp-md);color:var(--bb-steel);font-size:14px;transition:border-color var(--t-fast),box-shadow var(--t-fast);cursor:text}
.search-pill:hover{border-color:var(--bb-slate)}
.search-pill:focus-within{border-color:var(--bb-gold);box-shadow:0 0 0 3px var(--bb-gold-soft)}
.search-pill input{background:none;border:none;outline:none;color:var(--bb-ink);font-family:var(--font-body);font-size:14px;width:100%}
.search-pill input::placeholder{color:var(--bb-muted)}

/* Checkbox custom */
.check{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:11px 0}
.check input{position:absolute;opacity:0;pointer-events:none}
.check .box{width:22px;height:22px;border-radius:var(--r-sm);border:1.5px solid var(--bb-hairline);background:var(--bb-surface-2);flex:none;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast);margin-top:2px}
.check .box svg{width:13px;height:13px;stroke:var(--bb-black);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:0;transform:scale(.5);transition:all var(--t-fast)}
.check input:checked + .box{background:var(--bb-gold);border-color:var(--bb-gold)}
.check input:checked + .box svg{opacity:1;transform:scale(1)}
.check input:checked ~ .check-label{color:var(--bb-steel);text-decoration:line-through}
.check input:focus-visible + .box{box-shadow:0 0 0 3px var(--bb-gold-soft)}
.check-label{font-size:15px;color:var(--bb-text);transition:color var(--t-fast)}
.check.simple input:checked ~ .check-label{text-decoration:none;color:var(--bb-text)}

/* Switch — pílula, assinatura da marca */
.switch{position:relative;display:inline-flex;width:48px;height:28px;flex:none;cursor:pointer}
.switch input{position:absolute;opacity:0;pointer-events:none}
.switch .tr{position:absolute;inset:0;border-radius:var(--r-full);background:var(--bb-surface-3);border:1px solid var(--bb-hairline);transition:all var(--t-base)}
.switch .tr::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--bb-steel);transition:all var(--t-base)}
.switch input:checked + .tr{background:var(--bb-gold);border-color:var(--bb-gold)}
.switch input:checked + .tr::after{left:23px;background:var(--bb-black)}

/* ---------- Tabs (DS §12) ---------- */
.seg-tabs{display:flex;gap:var(--sp-xs);border-bottom:1px solid var(--bb-hairline);overflow-x:auto;scrollbar-width:none}
.seg-tabs::-webkit-scrollbar{display:none}
.seg-tab{padding:var(--sp-sm) var(--sp-md);font-family:var(--font-display);font-size:15px;font-weight:500;color:var(--bb-steel);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--t-fast),border-color var(--t-fast);white-space:nowrap;min-height:46px}
.seg-tab:hover{color:var(--bb-ink-soft)}
.seg-tab.active{color:var(--bb-gold);border-bottom-color:var(--bb-gold)}
.pill-tabs{display:inline-flex;gap:var(--sp-xs);background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-full);padding:4px;max-width:100%;overflow-x:auto;scrollbar-width:none}
.pill-tabs::-webkit-scrollbar{display:none}
.pill-tab{padding:9px var(--sp-md);font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--bb-steel);background:transparent;border:none;border-radius:var(--r-full);cursor:pointer;transition:all var(--t-fast);white-space:nowrap}
.pill-tab:hover{color:var(--bb-ink)}
.pill-tab.active{background:var(--bb-gold);color:var(--bb-black)}

/* ---------- Tabela (DS §14) ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--r-md)}
.data-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--bb-hairline);border-radius:var(--r-md);overflow:hidden;font-size:15px;min-width:620px}
.data-table th{background:var(--bb-surface-2);color:var(--bb-slate);font-family:var(--font-display);font-size:13.5px;font-weight:600;text-align:left;padding:var(--sp-sm) var(--sp-md);letter-spacing:.04em}
.data-table td{padding:var(--sp-sm) var(--sp-md);border-top:1px solid var(--bb-hairline-soft);color:var(--bb-text);vertical-align:middle}
.data-table tr{transition:background var(--t-fast)}
.data-table tbody tr:hover{background:var(--bb-surface)}
.data-table td b{color:var(--bb-ink);font-weight:600;font-family:var(--font-display)}

/* ---------- Progresso ---------- */
.pbar{height:6px;background:var(--bb-surface-3);border-radius:var(--r-full);overflow:hidden}
.pbar i{display:block;height:100%;background:var(--bb-gold);border-radius:var(--r-full)}
.pbar.done i{background:var(--bb-success-text)}
.ring{position:relative;flex:none}
.ring svg{transform:rotate(-90deg);display:block}
.ring circle{fill:none;stroke-width:7}
.ring .track{stroke:var(--bb-surface-3)}
.ring .fill{stroke:var(--bb-gold);stroke-linecap:round}
.ring .val{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .val b{font-family:var(--font-display);font-size:23px;color:var(--bb-ink);line-height:1}
.ring .val span{font-size:10.5px;color:var(--bb-steel);letter-spacing:.12em;text-transform:uppercase;margin-top:3px;font-family:var(--font-display)}

/* Entradas animadas por página */
.page.active > *{animation:fadeUp .55s var(--ease) both}
.page.active > *:nth-child(1){animation-delay:.03s}
.page.active > *:nth-child(2){animation-delay:.09s}
.page.active > *:nth-child(3){animation-delay:.15s}
.page.active > *:nth-child(4){animation-delay:.21s}
.page.active > *:nth-child(5){animation-delay:.27s}
.page.active > *:nth-child(6){animation-delay:.33s}
.page.active > *:nth-child(7){animation-delay:.39s}
.page.active .pbar i{animation:growW .9s .25s var(--ease) backwards}
.page.active .ring .fill{animation:ringIn 1.1s .2s var(--ease) backwards}

/* ---------- Avatar ---------- */
.avatar{width:40px;height:40px;border-radius:var(--r-full);background:linear-gradient(160deg,#3A3A3A,#1A1A1A);border:1px solid var(--bb-hairline);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--bb-slate);flex:none;overflow:hidden}
.avatar.me{border-color:var(--bb-gold);color:var(--bb-gold)}
.avatar-lg{width:76px;height:76px;font-size:24px}
.avatar-sm{width:34px;height:34px;font-size:12.5px}

/* ---------- Placeholder de imagem (P&B dessaturado) ---------- */
.ph-img{background:linear-gradient(160deg,#3A3A3A,#1A1A1A);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.ph-img svg{height:36%;fill:rgba(255,255,255,.07)}
.ph-img .tag{position:absolute;left:10px;bottom:8px;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--bb-muted);font-family:var(--font-display)}

/* Chip de slot de imagem (placeholders organizados) */
.img-slot{display:inline-flex;align-items:center;gap:8px;border:1.5px dashed rgba(231,157,58,.45);color:var(--bb-gold);background:rgba(22,22,22,.55);backdrop-filter:blur(6px);border-radius:var(--r-full);padding:7px 16px;font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}

/* ============================================================
   LOGIN DO MENTORADO — split: formulário + área de imagem
   ============================================================ */
#login{min-height:100dvh;display:grid;grid-template-rows:220px 1fr;background:var(--bb-canvas)}
.login-art{position:relative;overflow:hidden;background:#0B0B0B}
.login-art .bgpan{position:absolute;inset:-6%;background:
  radial-gradient(640px 420px at 78% 28%,rgba(231,157,58,.34),transparent 62%),
  radial-gradient(520px 420px at 14% 86%,rgba(231,157,58,.22),transparent 60%),
  linear-gradient(118deg,#0B0B0B 30%,#241708 78%,#3A2710 120%);
  animation:pan 16s ease-in-out infinite}
.login-art .lines{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:repeating-linear-gradient(115deg,transparent 0 38px,rgba(231,157,58,.06) 38px 42px);
  mask-image:radial-gradient(75% 80% at 70% 45%,#000,transparent 75%);
  -webkit-mask-image:radial-gradient(75% 80% at 70% 45%,#000,transparent 75%)}
.login-art .box-a,.login-art .box-b{position:absolute;fill:var(--bb-gold);filter:drop-shadow(0 0 28px rgba(231,157,58,.4));opacity:.85}
.login-art .box-a{width:120px;right:8%;top:10%;animation:floaty 9s ease-in-out infinite}
.login-art .box-b{width:74px;left:9%;bottom:12%;opacity:.45;animation:floaty2 11s ease-in-out infinite}
.login-art .center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-md);text-align:center;padding:var(--sp-xl)}
.login-art .center .bb-mark{height:clamp(34px,5.2vw,64px);filter:drop-shadow(0 6px 30px rgba(0,0,0,.6))}
.login-art .center .tagline{font-family:var(--font-notes);color:var(--bb-gold);font-size:clamp(18px,2vw,24px);opacity:.92}
.login-art .slot{position:absolute;top:var(--sp-lg);right:var(--sp-lg)}
.login-art .credits{position:absolute;left:0;right:0;bottom:var(--sp-md);text-align:center;font-size:12.5px;color:var(--bb-steel)}
.login-form{position:relative;display:flex;align-items:center;justify-content:center;padding:var(--sp-xl) var(--sp-lg) var(--sp-section-sm)}
.login-inner{width:100%;max-width:420px;display:flex;flex-direction:column;gap:var(--sp-lg);animation:fadeUp .6s var(--ease) both}
.login-inner .bb-mark{height:26px}
.login-fields{display:flex;flex-direction:column;gap:var(--sp-md)}
.login-aux{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-sm)}
.login-secure{display:flex;align-items:center;gap:8px;color:var(--bb-steel);font-size:13px}
.admin-door{font-size:13px;color:var(--bb-muted);background:none;border:none;cursor:pointer;font-family:var(--font-body);transition:color var(--t-fast)}
.admin-door:hover{color:var(--bb-gold)}
@media (min-width:900px){
  #login{grid-template-rows:none;grid-template-columns:minmax(440px,42%) 1fr}
  .login-art{order:2;min-height:100dvh}
  .login-form{order:1;padding:var(--sp-section-sm)}
}

/* ============================================================
   LOGIN MASTER — mesma paleta, atmosfera própria
   (varredura cônica + acesso restrito; sem split de imagem)
   ============================================================ */
#login-adm{min-height:100dvh;display:none;align-items:center;justify-content:center;padding:var(--sp-xl);position:relative;overflow:hidden;
  background:conic-gradient(from 210deg at 72% 22%,#0B0B0B,#1E1408 32%,#7A4E13 50%,#0B0B0B 72%)}
#login-adm.on{display:flex}
#login-adm::before{content:'';position:absolute;inset:0;background:rgba(11,11,11,.78);backdrop-filter:blur(2px)}
#login-adm::after{content:'';position:absolute;inset:0;opacity:.4;pointer-events:none;
  background-image:repeating-linear-gradient(-30deg,transparent 0 22px,rgba(255,255,255,.025) 22px 24px)}
.adm-login-box{position:relative;z-index:2;width:100%;max-width:430px;display:flex;flex-direction:column;gap:var(--sp-lg);animation:fadeUp .6s var(--ease) both}
.adm-login-card{background:var(--bb-deep);border:1px solid var(--bb-hairline);border-top:2px solid var(--bb-gold);border-radius:var(--r-xxl);padding:var(--sp-xl);display:flex;flex-direction:column;gap:var(--sp-md);box-shadow:var(--el-4)}
.adm-login-head{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-sm)}
.adm-login-head .bb-mark{height:24px}

/* ============================================================
   APP SHELL DO MENTORADO
   ============================================================ */
#app{display:none;min-height:100dvh}
body.in-app #app{display:block}
body.in-app #login{display:none}
body.in-adm #login{display:none}

/* Appbar (DS §15: 64px, translúcido com blur) */
.appbar{
  position:sticky;top:0;z-index:90;height:var(--appbar-h);
  display:flex;align-items:center;gap:var(--sp-md);
  padding:0 var(--sp-md);
  background:var(--bb-appbar);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--bb-hairline-soft);
}
.appbar .bar-title{font-family:var(--font-display);font-weight:600;font-size:17px;color:var(--bb-ink);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bell{position:relative}
/* Alternador de tema — mostra só o ícone do tema oposto */
.theme-toggle .ic-sun{display:none}
.theme-toggle .ic-moon{display:block}
html[data-theme="light"] .theme-toggle .ic-sun{display:block}
html[data-theme="light"] .theme-toggle .ic-moon{display:none}
.theme-toggle:hover .ic{transform:rotate(18deg)}
.theme-toggle .ic{transition:transform var(--t-base)}
.bell .dot{position:absolute;top:9px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--bb-gold);border:2px solid var(--bb-canvas);animation:dotPing 2.6s ease-out infinite}

.bb-mark{height:18px;aspect-ratio:1534/211;width:auto;display:block;overflow:visible;flex:none}
.wordmark{display:inline-flex;align-items:center;text-decoration:none;line-height:1;background:none;border:none;cursor:pointer;padding:0}

/* Conteúdo — largura total */
.page{padding:var(--sp-md) var(--sp-md) calc(var(--bottomnav-h) + var(--sp-xxl));display:none}
.page.active{display:block}
.page-head{margin:var(--sp-xs) 0 var(--sp-lg)}
.page-head p{color:var(--bb-slate);font-size:15px;margin-top:4px;max-width:640px}
.section{margin-top:var(--sp-xl)}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-sm);margin-bottom:var(--sp-sm)}
.section-title h3{font-size:17px}

/* Bottom nav — mobile */
.bottomnav{
  position:fixed;left:0;right:0;bottom:0;z-index:95;height:calc(var(--bottomnav-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  display:grid;grid-template-columns:repeat(5,1fr);
  background:var(--bb-bottomnav);backdrop-filter:blur(14px);
  border-top:1px solid var(--bb-hairline-soft);
}
.bnav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--bb-steel);cursor:pointer;font-family:var(--font-display);font-size:10.5px;font-weight:600;letter-spacing:.04em;transition:color var(--t-fast);min-height:44px}
.bnav-item .ic{width:22px;height:22px}
.bnav-item.active{color:var(--bb-gold)}
.bnav-item.active .ic{animation:pop .35s var(--ease)}
.bnav-item:hover{color:var(--bb-ink-soft)}
.bnav-item.active:hover{color:var(--bb-gold)}

/* Sidebar — desktop, conta no rodapé */
.sidebar{display:none}
.side-label{font-size:11.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--bb-muted);margin:var(--sp-lg) var(--sp-md) var(--sp-xs);font-family:var(--font-display)}
.snav{display:flex;align-items:center;gap:11px;width:100%;color:var(--bb-slate);text-decoration:none;font-size:15px;font-family:var(--font-display);font-weight:500;padding:10px var(--sp-md);border:none;background:none;cursor:pointer;text-align:left;transition:all var(--t-fast);border-left:2px solid transparent;border-radius:0 var(--r-sm) var(--r-sm) 0}
.snav .ic{width:19px;height:19px;transition:transform var(--t-fast)}
.snav:hover{color:var(--bb-ink);background:var(--bb-surface)}
.snav:hover .ic{transform:translateX(2px)}
.snav.active{color:var(--bb-gold);border-left-color:var(--bb-gold);background:var(--bb-surface)}

/* Drawer mobile */
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:96;opacity:0;pointer-events:none;transition:opacity var(--t-base)}
.scrim.on{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;left:0;right:0;bottom:0;z-index:97;background:var(--bb-surface);
  border:1px solid var(--bb-hairline);border-bottom:none;border-radius:var(--r-xxl) var(--r-xxl) 0 0;
  padding:var(--sp-md) var(--sp-md) calc(var(--sp-xl) + env(safe-area-inset-bottom));
  transform:translateY(105%);transition:transform var(--t-slow);max-height:84dvh;overflow:auto;
}
.drawer.on{transform:none}
.drawer-grab{width:40px;height:4px;border-radius:var(--r-full);background:var(--bb-surface-3);margin:0 auto var(--sp-md)}
.drawer .snav{border-left:none;border-radius:var(--r-md);padding:13px var(--sp-md);min-height:50px}
.drawer .snav.active{border-left:none}

/* ---------- Componentes da plataforma ---------- */
.hello{display:flex;align-items:center;gap:var(--sp-sm);margin:var(--sp-xs) 0 var(--sp-lg)}
.hello h2{font-size:22px;letter-spacing:-.3px;line-height:1.2}
.hello .sub{font-size:14px;color:var(--bb-slate)}

.stat{background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-xl);padding:var(--sp-md);transition:border-color var(--t-base),transform var(--t-base)}
.stat:hover{border-color:rgba(231,157,58,.3);transform:translateY(-2px)}
.stat b{display:block;font-family:var(--font-display);font-size:25px;color:var(--bb-ink);line-height:1.1}
.stat span{font-size:13px;color:var(--bb-steel)}
.stat .delta{font-size:12px;color:var(--bb-success-text)}

.li-row{display:flex;align-items:center;gap:var(--sp-sm);padding:var(--sp-sm) 0;border-bottom:1px solid var(--bb-hairline-soft)}
.li-row:last-child{border-bottom:none}
.li-ic{width:40px;height:40px;border-radius:var(--r-full);border:1px solid var(--bb-hairline);display:flex;align-items:center;justify-content:center;color:var(--bb-gold);flex:none;background:var(--bb-surface-2);transition:all var(--t-base)}
.li-row:hover .li-ic{border-color:rgba(231,157,58,.4);box-shadow:var(--el-gold)}
.li-body{flex:1;min-width:0}
.li-body b{display:block;font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--bb-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.li-body span{font-size:13px;color:var(--bb-steel)}

.lesson{padding:0;overflow:hidden;display:flex;flex-direction:column}
.lesson .ph-img{aspect-ratio:16/9;border-bottom:1px solid var(--bb-hairline-soft)}
.lesson .ph-img svg{transition:transform var(--t-slow)}
.lesson:hover .ph-img svg{transform:scale(1.12) rotate(-3deg)}
.lesson .body{padding:var(--sp-md);display:flex;flex-direction:column;gap:8px;flex:1}
.lesson .meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.lesson .meta .micro{color:var(--bb-steel)}
.lesson .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-sm);padding-top:6px}

.hscroll{display:flex;gap:var(--sp-sm);overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px;scrollbar-width:none;margin:0 calc(-1 * var(--sp-md));padding-left:var(--sp-md);padding-right:var(--sp-md)}
.hscroll::-webkit-scrollbar{display:none}
.hscroll>*{flex:0 0 80%;max-width:320px;scroll-snap-align:start}

.gold-frame{position:relative;border-radius:var(--r-xxl);padding:var(--sp-xxl) var(--sp-lg);overflow:hidden;border:1px solid rgba(231,157,58,.24);
  background:radial-gradient(135% 150% at 100% 0%,rgba(231,157,58,.13),transparent 52%),var(--bb-premium-bg)}
.gold-frame::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--bb-gold),var(--bb-gold-deep));pointer-events:none}
.gold-frame::after{content:'';position:absolute;top:-20%;bottom:-20%;left:0;width:34%;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);
  transform:translateX(-160%) skewX(-18deg);animation:sheen 7s 1.2s ease-in-out infinite}
.gold-frame>*{position:relative}

.step{background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-xl);overflow:hidden;transition:border-color var(--t-base)}
.step:hover{border-color:rgba(231,157,58,.25)}
.step + .step{margin-top:var(--sp-sm)}
.step-head{display:flex;align-items:center;gap:var(--sp-sm);width:100%;background:none;border:none;padding:var(--sp-md);cursor:pointer;text-align:left;min-height:58px}
.step-num{width:36px;height:36px;border-radius:var(--r-full);border:1.5px solid var(--bb-hairline);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--bb-slate);flex:none;transition:all var(--t-fast)}
.step.done .step-num{border-color:var(--bb-success-text);color:var(--bb-success-text)}
.step.now .step-num{border-color:var(--bb-gold);color:var(--bb-gold);box-shadow:0 0 0 3px var(--bb-gold-soft)}
.step-head .t{flex:1;min-width:0}
.step-head .t b{display:block;font-family:var(--font-display);font-size:16px;color:var(--bb-ink)}
.step-head .t span{font-size:13px;color:var(--bb-steel)}
.step-head .chev{transition:transform var(--t-base);color:var(--bb-steel)}
.step.open .chev{transform:rotate(180deg)}
.step-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--t-slow)}
.step-body>div{overflow:hidden}
.step.open .step-body{grid-template-rows:1fr}
.step-body .pad{padding:0 var(--sp-md) var(--sp-md);border-top:1px solid var(--bb-hairline-soft)}

.rank-row{display:flex;align-items:center;gap:var(--sp-sm);padding:var(--sp-sm) var(--sp-md);background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-xl);transition:transform var(--t-base),border-color var(--t-base)}
.rank-row:hover{transform:translateX(3px);border-color:rgba(231,157,58,.3)}
.rank-row + .rank-row{margin-top:var(--sp-xs)}
.rank-row.me{border-color:rgba(231,157,58,.45);box-shadow:var(--el-gold);background:var(--bb-premium-bg)}
.rank-pos{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--bb-slate);width:32px;text-align:center;flex:none}
.rank-row.me .rank-pos,.rank-pos.top{color:var(--bb-gold)}
.rank-body{flex:1;min-width:0}
.rank-body b{display:block;font-family:var(--font-display);font-size:15px;color:var(--bb-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-body span{font-size:13px;color:var(--bb-steel)}
.rank-pts{text-align:right;flex:none}
.rank-pts b{display:block;font-family:var(--font-display);font-size:16px;color:var(--bb-ink)}
.rank-pts span{font-size:12px;color:var(--bb-steel)}

.alert{display:flex;gap:var(--sp-sm);padding:var(--sp-md);border-radius:var(--r-lg);border:1px solid var(--bb-hairline);background:var(--bb-surface);font-size:15px;transition:border-color var(--t-base)}
.alert:hover{border-color:rgba(231,157,58,.3)}
.alert .ic{color:var(--bb-gold);margin-top:1px}
.alert b{color:var(--bb-ink);font-family:var(--font-display)}
.alert.gold{border-color:rgba(231,157,58,.35);background:linear-gradient(120deg,var(--bb-gold-soft),transparent 60%),var(--bb-surface)}

.empty{text-align:center;padding:var(--sp-section) var(--sp-lg);border:1px dashed var(--bb-hairline);border-radius:var(--r-xxl)}
.empty .sym{width:68px;height:68px;border-radius:var(--r-full);border:1.5px solid var(--bb-gold);display:flex;align-items:center;justify-content:center;margin:0 auto var(--sp-md);color:var(--bb-gold);animation:floaty 7s ease-in-out infinite}
.empty h3{font-size:18px}
.empty p{color:var(--bb-slate);font-size:15px;max-width:380px;margin:6px auto var(--sp-lg)}

.player{aspect-ratio:16/9;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--bb-hairline);position:relative;max-height:62dvh}
.player .ph-img{position:absolute;inset:0}
.player .play{position:absolute;inset:0;margin:auto;width:68px;height:68px;border-radius:var(--r-full);background:var(--bb-gold);border:none;color:var(--bb-black);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--t-base),box-shadow var(--t-base)}
.player .play:hover{transform:scale(1.08);box-shadow:var(--el-gold)}

.modal-scrim{position:fixed;inset:0;z-index:120;background:rgba(0,0,0,.6);display:none;align-items:flex-end;justify-content:center;padding:0}
.modal-scrim.on{display:flex;animation:fadeIn .2s ease}
.modal{background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-xxl) var(--r-xxl) 0 0;padding:var(--sp-lg) var(--sp-lg) calc(var(--sp-xl) + env(safe-area-inset-bottom));width:100%;max-width:500px;animation:fadeUp .35s var(--ease)}
.modal h3{font-size:19px;margin-bottom:4px}
.modal p{color:var(--bb-slate);font-size:15px}
.modal-acts{display:flex;gap:var(--sp-sm);margin-top:var(--sp-lg)}
.modal-acts .btn{flex:1}

#toast{position:fixed;bottom:calc(var(--bottomnav-h) + 20px);left:50%;transform:translate(-50%,16px);background:var(--bb-gold);color:var(--bb-black);font-family:var(--font-display);font-weight:600;font-size:15px;padding:11px 24px;border-radius:var(--r-full);opacity:0;pointer-events:none;transition:all var(--t-base);z-index:200;box-shadow:var(--el-4);white-space:nowrap}
#toast.show{opacity:1;transform:translate(-50%,0)}

.faq{border:1px solid var(--bb-hairline);border-radius:var(--r-xl);overflow:hidden;background:var(--bb-surface)}
.faq details{border-bottom:1px solid var(--bb-hairline-soft)}
.faq details:last-child{border-bottom:none}
.faq summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-sm);padding:var(--sp-md);cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--bb-ink);min-height:54px;transition:background var(--t-fast)}
.faq summary:hover{background:var(--bb-surface-2)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{color:var(--bb-steel);transition:transform var(--t-base)}
.faq details[open] summary .chev{transform:rotate(180deg)}
.faq .a{padding:0 var(--sp-md) var(--sp-md);color:var(--bb-slate);font-size:15px;animation:fadeUp .3s var(--ease)}

/* Mini gráfico de barras (admin) — CSS puro */
.bars{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:var(--sp-sm)}
.bars .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}
.bars .b i{display:block;width:100%;max-width:34px;border-radius:6px 6px 2px 2px;background:linear-gradient(180deg,var(--bb-gold),var(--bb-gold-deep));transform-origin:bottom;animation:barUp .8s var(--ease) backwards}
.bars .b span{font-size:11px;color:var(--bb-steel);font-family:var(--font-display)}
.bars .b:nth-child(1) i{animation-delay:.05s}.bars .b:nth-child(2) i{animation-delay:.12s}
.bars .b:nth-child(3) i{animation-delay:.19s}.bars .b:nth-child(4) i{animation-delay:.26s}
.bars .b:nth-child(5) i{animation-delay:.33s}.bars .b:nth-child(6) i{animation-delay:.4s}
.bars .b:nth-child(7) i{animation-delay:.47s}

/* ============================================================
   SHELL MASTER — paleta do DS com aplicação própria:
   base mais profunda (#0E0E0E), ativo em pílula dourada sólida,
   filete dourado no topo. Nada de novo fora dos tokens.
   ============================================================ */
#adm{display:none;min-height:100dvh;background:var(--bb-adm-canvas)}
body.in-adm #adm{display:block}
body.in-adm #login-adm{display:none}
#adm .appbar{background:var(--bb-adm-appbar);border-top:2px solid var(--bb-gold)}
#adm .page{background:var(--bb-adm-canvas)}
#adm .card,#adm .stat,#adm .rank-row,#adm .faq{background:var(--bb-adm-surface)}
#adm .data-table th{background:var(--bb-adm-surface-2)}
.adm-snav{display:flex;align-items:center;gap:11px;width:100%;color:var(--bb-slate);font-size:15px;font-family:var(--font-display);font-weight:500;padding:10px var(--sp-md);border:none;background:none;cursor:pointer;text-align:left;transition:all var(--t-fast);border-radius:var(--r-full);margin:1px 0}
.adm-snav .ic{width:19px;height:19px}
.adm-snav:hover{color:var(--bb-ink);background:var(--bb-adm-snav-hover)}
.adm-snav.active{background:var(--bb-gold);color:var(--bb-on-gold);font-weight:600}
.adm-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--bb-gold)}
.adm-tag::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--bb-gold);animation:dotPing 2.4s ease-out infinite}

/* ---------- Capa do dashboard — slot de imagem manual (igual ao login) ---------- */
.cover{position:relative;border-radius:var(--r-hero);overflow:hidden;min-height:188px;display:flex;align-items:flex-end;border:1px solid var(--bb-hairline);background:#0B0B0B}
.cover .cv-bg{position:absolute;inset:-6%;background:
  radial-gradient(620px 360px at 80% 24%,rgba(231,157,58,.34),transparent 62%),
  radial-gradient(460px 360px at 12% 90%,rgba(231,157,58,.2),transparent 60%),
  linear-gradient(118deg,#0B0B0B 30%,#241708 80%,#3A2710 120%);
  animation:pan 16s ease-in-out infinite}
.cover .cv-lines{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:repeating-linear-gradient(115deg,transparent 0 38px,rgba(231,157,58,.06) 38px 42px);
  mask-image:radial-gradient(80% 90% at 75% 40%,#000,transparent 78%);
  -webkit-mask-image:radial-gradient(80% 90% at 75% 40%,#000,transparent 78%)}
.cover .cv-box{position:absolute;right:6%;top:50%;transform:translateY(-50%);width:104px;fill:var(--bb-gold);filter:drop-shadow(0 0 26px rgba(231,157,58,.4));opacity:.5;animation:floaty 9s ease-in-out infinite}
.cover .cv-slot{position:absolute;top:var(--sp-md);right:var(--sp-md);z-index:3}
.cover .cv-overlay{position:relative;z-index:2;display:flex;align-items:center;gap:var(--sp-md);padding:var(--sp-lg);width:100%;background:linear-gradient(0deg,rgba(8,8,8,.66),rgba(8,8,8,.12) 60%,transparent)}
.cover .cv-overlay h2{font-family:var(--font-display);font-weight:600;font-size:24px;color:#fff;line-height:1.15;letter-spacing:-.4px}
.cover .cv-overlay .sub{font-size:14px;color:rgba(255,255,255,.72);margin-top:2px}
.cover .cv-avatar{width:60px;height:60px;border-radius:var(--r-full);border:1.5px solid var(--bb-gold);background:rgba(0,0,0,.35);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:20px;color:var(--bb-gold);flex:none}
@media (min-width:768px){
  .cover{min-height:232px}
  .cover .cv-overlay h2{font-size:30px}
  .cover .cv-box{width:128px}
}

/* Tile de resumo do dashboard */
.dash-tile{position:relative;overflow:hidden}
.dash-tile .ic-bg{position:absolute;right:-10px;bottom:-12px;width:88px;height:88px;color:var(--bb-gold);opacity:.07}
.dash-tile .ic-bg svg{width:100%;height:100%}


/* ============================================================
   MÓDULOS — sistema operacional (Fase 1.5)
   Componentes novos, todos sobre os tokens do Design System.
   ============================================================ */

/* ---------- Roadmap / Mapa de Evolução ---------- */
.trail{position:relative;padding-left:30px}
.trail::before{content:'';position:absolute;left:13px;top:8px;bottom:8px;width:2px;background:var(--bb-hairline)}
.trail-step{position:relative;margin-bottom:var(--sp-sm)}
.trail-dot{position:absolute;left:-30px;top:18px;width:28px;height:28px;border-radius:var(--r-full);background:var(--bb-surface-2);border:2px solid var(--bb-hairline);display:flex;align-items:center;justify-content:center;color:var(--bb-slate);z-index:2;transition:all var(--t-base)}
.trail-dot svg{width:14px;height:14px}
.trail-step.done .trail-dot{border-color:var(--bb-success-text);color:var(--bb-success-text);background:var(--bb-surface)}
.trail-step.now .trail-dot{border-color:var(--bb-gold);color:var(--bb-gold);box-shadow:0 0 0 4px var(--bb-gold-soft)}
.trail-step.now .trail-card{border-color:rgba(231,157,58,.4)}
.trail-card{background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-xl);overflow:hidden;transition:border-color var(--t-base)}
.trail-card:hover{border-color:rgba(231,157,58,.3)}
.trail-head{display:flex;align-items:center;gap:var(--sp-sm);width:100%;background:none;border:none;padding:var(--sp-md);cursor:pointer;text-align:left;min-height:62px}
.trail-head .t{flex:1;min-width:0}
.trail-head .t b{display:block;font-family:var(--font-display);font-size:16px;color:var(--bb-ink)}
.trail-head .t span{font-size:13px;color:var(--bb-steel)}
.trail-head .chev{color:var(--bb-steel);transition:transform var(--t-base)}
.trail-step.open .trail-head .chev{transform:rotate(180deg)}
.trail-pct{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--bb-gold);flex:none}
.trail-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--t-slow)}
.trail-body>div{overflow:hidden}
.trail-step.open .trail-body{grid-template-rows:1fr}
.trail-body .pad{padding:0 var(--sp-md) var(--sp-md);border-top:1px solid var(--bb-hairline-soft)}
.link-chip{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:var(--r-full);border:1px solid var(--bb-hairline);background:var(--bb-surface-2);color:var(--bb-ink-soft);font-size:13px;font-family:var(--font-display);font-weight:500;cursor:pointer;transition:all var(--t-fast);text-decoration:none}
.link-chip:hover{border-color:var(--bb-gold);color:var(--bb-gold)}
.link-chip svg{width:14px;height:14px;color:var(--bb-gold)}

/* ---------- Radar (Diagnóstico / Score) ---------- */
.radar-wrap{display:flex;align-items:center;justify-content:center;padding:var(--sp-sm)}
.radar{width:100%;max-width:340px;height:auto}
.radar .grid-line{fill:none;stroke:var(--bb-hairline);stroke-width:1}
.radar .axis{stroke:var(--bb-hairline-soft);stroke-width:1}
.radar .poly{fill:rgba(231,157,58,.18);stroke:var(--bb-gold);stroke-width:2;stroke-linejoin:round}
.radar .pt{fill:var(--bb-gold)}
.radar .lbl{fill:var(--bb-slate);font-family:var(--font-display);font-size:11px}
.radar .poly,.radar .pt{transition:none}
html[data-theme="light"] .radar .poly{fill:rgba(231,157,58,.22)}

/* Barras de score por categoria */
.score-row{display:flex;align-items:center;gap:var(--sp-md);padding:11px 0;border-bottom:1px solid var(--bb-hairline-soft)}
.score-row:last-child{border-bottom:none}
.score-row .nm{flex:none;width:120px;font-family:var(--font-display);font-weight:500;font-size:14px;color:var(--bb-ink-soft)}
.score-row .track{flex:1;height:8px;background:var(--bb-surface-3);border-radius:var(--r-full);overflow:hidden}
.score-row .track i{display:block;height:100%;border-radius:var(--r-full);background:var(--bb-gold)}
.score-row .track i.low{background:var(--bb-error)}
.score-row .track i.mid{background:#E7B43A}
.score-row .vl{flex:none;width:42px;text-align:right;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--bb-ink)}
.score-big{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.score-big b{font-family:var(--font-display);font-size:54px;line-height:1;color:var(--bb-gold);letter-spacing:-1px}
.score-big span{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--bb-steel);font-family:var(--font-display);margin-top:6px}

/* ---------- Níveis / progressão (Ranking) ---------- */
.levels{display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none;padding:var(--sp-xs) 0}
.levels::-webkit-scrollbar{display:none}
.level{flex:none;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;padding:0 var(--sp-md);min-width:84px}
.level .dot{width:16px;height:16px;border-radius:50%;background:var(--bb-surface-3);border:2px solid var(--bb-hairline);z-index:2}
.level.reached .dot{background:var(--bb-gold);border-color:var(--bb-gold)}
.level.current .dot{background:var(--bb-gold);border-color:var(--bb-gold);box-shadow:0 0 0 4px var(--bb-gold-soft)}
.level::before{content:'';position:absolute;top:7px;left:-50%;width:100%;height:2px;background:var(--bb-hairline)}
.level.reached::before{background:var(--bb-gold)}
.level:first-child::before{display:none}
.level small{font-family:var(--font-display);font-weight:600;font-size:12px;color:var(--bb-steel);white-space:nowrap}
.level.current small,.level.reached small{color:var(--bb-ink)}
.level.current .dot{animation:glowPulse 3.4s ease-in-out infinite}
/* Barra de progresso do nível com leve brilho deslizante */
.gold-frame .pbar{position:relative;overflow:hidden}
.gold-frame .pbar i{position:relative;overflow:hidden}
.gold-frame .pbar i::after{content:'';position:absolute;inset:0;width:40%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  transform:translateX(-150%);animation:sheen 4.5s 1s ease-in-out infinite}

/* ---------- Feed Pingou ---------- */
.post{background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-xl);padding:var(--sp-lg);transition:border-color var(--t-base)}
.post + .post{margin-top:var(--sp-md)}
.post:hover{border-color:rgba(231,157,58,.25)}
.post-head{display:flex;align-items:center;gap:var(--sp-sm);margin-bottom:var(--sp-sm)}
.post-head .who{flex:1;min-width:0}
.post-head .who b{display:block;font-family:var(--font-display);font-size:15px;color:var(--bb-ink)}
.post-head .who span{font-size:12.5px;color:var(--bb-steel)}
.post-win{display:flex;align-items:center;gap:10px;background:linear-gradient(120deg,var(--bb-gold-soft),transparent 70%);border:1px solid rgba(231,157,58,.3);border-radius:var(--r-lg);padding:var(--sp-sm) var(--sp-md);margin:var(--sp-xs) 0}
.post-win svg{width:20px;height:20px;color:var(--bb-gold);flex:none}
.post-win b{font-family:var(--font-display);font-size:17px;color:var(--bb-ink)}
.post-actions{display:flex;align-items:center;gap:var(--sp-lg);margin-top:var(--sp-sm);padding-top:var(--sp-sm);border-top:1px solid var(--bb-hairline-soft)}
.post-act{display:inline-flex;align-items:center;gap:7px;background:none;border:none;color:var(--bb-steel);cursor:pointer;font-family:var(--font-display);font-size:13.5px;font-weight:500;transition:color var(--t-fast)}
.post-act svg{width:18px;height:18px;transition:transform var(--t-fast)}
.post-act:hover{color:var(--bb-ink)}
.post-act.liked{color:var(--bb-gold)}
.post-act.liked svg{fill:var(--bb-gold);transform:scale(1.1)}

/* ---------- Cofre de IA ---------- */
.vault-card{background:var(--bb-surface);border:1px solid var(--bb-hairline);border-radius:var(--r-xl);padding:var(--sp-lg);display:flex;flex-direction:column;gap:10px;transition:transform var(--t-base),border-color var(--t-base)}
.vault-card:hover{transform:translateY(-2px);border-color:rgba(231,157,58,.3)}
.vault-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-sm)}
.vault-ic{width:40px;height:40px;border-radius:var(--r-lg);background:var(--bb-gold-soft);display:flex;align-items:center;justify-content:center;color:var(--bb-gold);flex:none}
.vault-fav{background:none;border:none;color:var(--bb-steel);cursor:pointer;padding:4px;transition:color var(--t-fast)}
.vault-fav svg{width:20px;height:20px;transition:transform var(--t-fast)}
.vault-fav:hover{color:var(--bb-gold)}
.vault-fav.on{color:var(--bb-gold)}
.vault-fav.on svg{fill:var(--bb-gold);transform:scale(1.1)}
.tags{display:flex;flex-wrap:wrap;gap:6px}
.tag-pill{font-size:11.5px;font-family:var(--font-display);font-weight:500;color:var(--bb-slate);background:var(--bb-surface-2);border:1px solid var(--bb-hairline);border-radius:var(--r-full);padding:3px 9px}

/* ---------- BlackBox IA — FAB + painel de chat ---------- */
.ia-fab{position:fixed;right:18px;bottom:calc(var(--bottomnav-h) + 18px);z-index:115;width:56px;height:56px;border-radius:var(--r-full);border:none;background:var(--bb-gold);color:var(--bb-black);display:none;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--el-gold),var(--el-4);transition:transform var(--t-base),box-shadow var(--t-base);animation:glowPulse 4.5s ease-in-out infinite}
body.in-app .ia-fab{display:flex}
.ia-fab:hover{transform:scale(1.07)}
.ia-fab svg{width:26px;height:26px}
.ia-fab .pulse{position:absolute;top:-3px;right:-3px;width:14px;height:14px;border-radius:50%;background:var(--bb-success-text);border:2px solid var(--bb-canvas)}
.ia-panel{position:fixed;z-index:130;right:0;bottom:0;left:0;top:0;display:flex;flex-direction:column;background:var(--bb-canvas);transform:translateY(100%);transition:transform var(--t-slow);visibility:hidden}
.ia-panel.on{transform:none;visibility:visible}
.ia-bar{display:flex;align-items:center;gap:var(--sp-sm);padding:var(--sp-md);border-bottom:1px solid var(--bb-hairline);background:var(--bb-appbar);backdrop-filter:blur(14px)}
.ia-ava{width:40px;height:40px;border-radius:var(--r-full);background:var(--bb-gold-soft);display:flex;align-items:center;justify-content:center;color:var(--bb-gold);flex:none}
.ia-bar .t{flex:1;min-width:0}
.ia-bar .t b{display:block;font-family:var(--font-display);font-size:15px;color:var(--bb-ink)}
.ia-bar .t span{font-size:12px;color:var(--bb-success-text)}
.ia-body{flex:1;overflow-y:auto;padding:var(--sp-lg) var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-md)}
.ia-msg{display:flex;gap:10px;max-width:86%}
.ia-msg .bub{padding:11px 15px;border-radius:var(--r-lg);font-size:14.5px;line-height:1.5}
.ia-msg.bot .bub{background:var(--bb-surface);border:1px solid var(--bb-hairline);color:var(--bb-text);border-top-left-radius:4px}
.ia-msg.me{align-self:flex-end}
.ia-msg.me .bub{background:var(--bb-gold);color:var(--bb-black);border-top-right-radius:4px;font-weight:500}
.ia-msg .mini{width:30px;height:30px;border-radius:var(--r-full);background:var(--bb-gold-soft);display:flex;align-items:center;justify-content:center;color:var(--bb-gold);flex:none}
.ia-suggest{display:flex;gap:8px;flex-wrap:wrap;padding:0 var(--sp-md) var(--sp-sm)}
.ia-chip{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--bb-gold);background:var(--bb-gold-soft);border:1px solid rgba(231,157,58,.25);border-radius:var(--r-full);padding:8px 14px;cursor:pointer;transition:all var(--t-fast)}
.ia-chip:hover{background:var(--bb-gold);color:var(--bb-black)}
.ia-input{display:flex;align-items:center;gap:var(--sp-sm);padding:var(--sp-md);padding-bottom:calc(var(--sp-md) + env(safe-area-inset-bottom));border-top:1px solid var(--bb-hairline);background:var(--bb-surface)}
.ia-input input{flex:1;min-height:46px;background:var(--bb-surface-2);border:1px solid var(--bb-hairline);border-radius:var(--r-full);padding:0 var(--sp-md);color:var(--bb-ink);font-family:var(--font-body);font-size:15px;outline:none;transition:border-color var(--t-fast)}
.ia-input input:focus{border-color:var(--bb-gold);box-shadow:0 0 0 3px var(--bb-gold-soft)}
.ia-send{width:46px;height:46px;border-radius:var(--r-full);border:none;background:var(--bb-gold);color:var(--bb-black);display:flex;align-items:center;justify-content:center;cursor:pointer;flex:none;transition:transform var(--t-base)}
.ia-send:hover{transform:scale(1.06)}
.ia-note{font-size:11.5px;color:var(--bb-steel);text-align:center;padding:6px var(--sp-md) 0}
@media (min-width:768px){
  .ia-panel{left:auto;top:auto;right:24px;bottom:24px;width:404px;height:600px;max-height:84dvh;border:1px solid var(--bb-hairline);border-radius:var(--r-xxl);overflow:hidden;box-shadow:var(--el-4)}
  .ia-bar{border-radius:0}
  .ia-fab{right:24px;bottom:24px}
}

   ============================================================ */
@media (min-width:480px){
  .grid-2{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:768px){
  .page{padding-left:var(--sp-xl);padding-right:var(--sp-xl)}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .modal-scrim{align-items:center;padding:var(--sp-xl)}
  .modal{border-radius:var(--r-xxl);padding-bottom:var(--sp-lg)}
  .hscroll>*{flex-basis:320px}
}
@media (min-width:1024px){
  body.in-app #app{display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr)}
  body.in-adm #adm{display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr)}
  .sidebar{
    display:flex;flex-direction:column;position:sticky;top:0;height:100dvh;overflow:auto;
    border-right:1px solid var(--bb-hairline-soft);
    padding:0 var(--sp-sm) var(--sp-md) 0;scrollbar-width:none;
  }
  #app .sidebar{background:var(--bb-canvas)}
  #adm .sidebar{background:var(--bb-adm-canvas);padding-right:var(--sp-sm);padding-left:var(--sp-xs)}
  .sidebar::-webkit-scrollbar{display:none}
  .sidebar .brand{display:flex;align-items:center;gap:10px;height:var(--appbar-h);padding:0 var(--sp-md) 0 var(--sp-lg);flex:none}
  .sidebar .brand .bb-mark{height:20px}
  .sidebar .side-bottom{margin-top:auto;padding-top:var(--sp-md);border-top:1px solid var(--bb-hairline-soft)}
  .bottomnav{display:none}
  .page{padding:var(--sp-lg) var(--sp-xxl) var(--sp-section)}
  .appbar{padding:0 var(--sp-xxl)}
  .appbar .wordmark{display:none}
  #toast{bottom:28px}
  .hello h2{font-size:26px}
  .gold-frame{padding:var(--sp-section-sm) var(--sp-xxl)}
  .heading-md{font-size:28px}
}
@media (max-width:1023px){
  .menu-btn{display:inline-flex}
}
@media (min-width:1024px){
  .menu-btn{display:none}
}
