/* =========================================================
   Eu Quero Entrar — APP (logado) · estilo "Dossiê"
   MOBILE-FIRST, fiel ao design (design_mobile/_reference).
   No desktop o conteúdo apenas centra (sem layout inventado).
   ========================================================= */
:root {
  --ink:#1A1D22; --ink-2:#4A4F57; --ink-3:#8C8878;
  --paper:#F5F1E6; --paper-2:#EFEADC; --card:#FCFAF3; --line:#E6DECE; --line-2:#D8CFB8;
  --psp:#16407E; --psp-deep:#0E2A55; --psp-soft:#E7ECF4; --psp-line:#C6D2E5;
  --gnr:#1C5234; --gnr-deep:#0F2E1E; --gnr-soft:#E6EFE8; --gnr-line:#C6D7CA;
  --wine:#7E2A2A; --gold:#C9962F;
  --c:#16407E; --c-deep:#0E2A55; --c-soft:#E7ECF4; --c-line:#C6D2E5; --c-on:#F5F1E6;
  --font-sans:'Geist',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --font-display:'Instrument Serif','Times New Roman',serif;
  --font-mono:'Geist Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --ease:cubic-bezier(.22,.61,.36,1); --snap:cubic-bezier(.34,1.4,.64,1);
  --tabbar-h:76px; --bottom-nav-h:76px;   /* altura do bottom menu — barras .qfoot/quiz assentam acima */
}
[data-force="gnr"] { --c:#1C5234; --c-deep:#0F2E1E; --c-soft:#E6EFE8; --c-line:#C6D7CA; }

* { box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
body.app-dossie { margin:0; background:var(--paper); color:var(--ink); font-family:var(--font-sans); -webkit-font-smoothing:antialiased; }
.app-dossie button { font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
.app-dossie a { text-decoration:none; color:inherit; }
.app-dossie svg { display:block; }
.mono { font-family:var(--font-mono); }
.serif { font-family:var(--font-display); font-weight:400; }

/* ---- Coluna do ecrã (full-bleed mobile, centrada em ecrãs maiores) ---- */
.page { width:100%; max-width:480px; margin:0 auto; min-height:100dvh; padding-bottom:100px; position:relative; }
.pad { padding:0 18px; }

/* ---- App header ---- */
.ah { display:flex; align-items:center; justify-content:space-between; padding:16px 18px 12px; }
.ah-l { display:flex; align-items:center; gap:11px; }
.ah .ava { width:40px; height:40px; border-radius:11px; background:var(--c); color:var(--c-on); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:20px; }
.ah .hi .k { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.ah .hi .nm { font-family:var(--font-display); font-size:20px; line-height:1.05; }
.ah .streak { display:inline-flex; align-items:center; gap:6px; background:var(--card); border:1px solid var(--line-2); border-radius:999px; padding:7px 12px; }
.ah .streak svg { width:15px; height:15px; color:var(--wine); }
.ah .streak b { font-family:var(--font-mono); font-size:13px; font-weight:600; }

.eyebrow { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); display:flex; align-items:center; gap:9px; margin:0 0 12px; }
.eyebrow .ln { flex:1; height:1px; background:var(--line-2); }

/* ---- Goal ring ---- */
.goal { margin:6px 18px 0; display:flex; align-items:center; gap:18px; background:var(--ink); color:var(--paper); border-radius:18px; padding:18px 20px; overflow:hidden; }
.goal .ring { width:74px; height:74px; border-radius:50%; flex:0 0 auto; display:grid; place-items:center; background:conic-gradient(var(--c) var(--goalp,60%),rgba(255,255,255,.14) 0); }
.goal .ring .hole { width:56px; height:56px; border-radius:50%; background:var(--ink); display:grid; place-items:center; text-align:center; }
.goal .ring .hole .n { font-family:var(--font-mono); font-size:17px; font-weight:600; line-height:1; }
.goal .ring .hole .s { font-family:var(--font-mono); font-size:8px; letter-spacing:.08em; color:#B9B2A0; margin-top:2px; }
.goal .gt .k { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--c-on); opacity:.7; }
.goal .gt h3 { font-family:var(--font-display); font-weight:400; font-size:24px; line-height:1.05; margin:5px 0 0; color:var(--paper); }
.goal .gt p { font-size:12.5px; color:#C7C0AE; margin:5px 0 0; }

/* ---- Continue card ---- */
.cont { margin:14px 18px 0; border:1.5px solid var(--ink); border-radius:16px; background:var(--card); padding:15px 16px; box-shadow:3px 3px 0 var(--c); display:flex; align-items:center; gap:14px; width:calc(100% - 36px); }
.cont .ic { width:46px; height:46px; border-radius:12px; background:var(--c-soft); color:var(--c-deep); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.cont .ic svg { width:24px; height:24px; }
.cont .ct { flex:1; min-width:0; text-align:left; }
.cont .ct .k { font-family:var(--font-mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.cont .ct .nm { font-weight:600; font-size:15px; letter-spacing:-.01em; margin-top:2px; }
.cont .ct .pb { height:5px; background:var(--paper-2); border:1px solid var(--line-2); border-radius:99px; margin-top:9px; overflow:hidden; }
.cont .ct .pb i { display:block; height:100%; background:var(--c); }
.cont .go { width:40px; height:40px; border-radius:11px; background:var(--c); color:var(--c-on); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.cont .go svg { width:20px; height:20px; }

/* ---- Quick-access grid ---- */
.exgrid { display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.extile { border:1px solid var(--line-2); border-radius:15px; background:var(--card); padding:15px; transition:transform .15s var(--snap); position:relative; overflow:hidden; display:block; }
.extile:active { transform:translate(1px,1px); }
.extile .ic { width:42px; height:42px; border-radius:11px; display:flex; align-items:center; justify-content:center; color:#fff; }
.extile .ic svg { width:23px; height:23px; }
.extile .nm { font-weight:600; font-size:14.5px; letter-spacing:-.01em; margin-top:13px; }
.extile .d { font-size:11.5px; color:var(--ink-3); margin-top:2px; line-height:1.3; }
.extile .tagn { position:absolute; top:13px; right:13px; font-family:var(--font-mono); font-size:9px; color:var(--ink-3); border:1px solid var(--line-2); border-radius:99px; padding:2px 7px; }

/* ---- Stat strip ---- */
.statstrip { display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--line-2); border-radius:14px; background:var(--card); overflow:hidden; }
.statstrip .s { padding:14px 10px; text-align:center; border-right:1px solid var(--line); }
.statstrip .s:last-child { border-right:none; }
.statstrip .s .n { font-family:var(--font-mono); font-weight:600; font-size:21px; letter-spacing:-.02em; }
.statstrip .s .n em { font-style:normal; color:var(--c); }
.statstrip .s .l { font-family:var(--font-mono); font-size:8.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-top:5px; }

/* ---- Listas agrupadas (hubs) ---- */
.list { border:1px solid var(--line-2); border-radius:15px; background:var(--card); overflow:hidden; }
.lrow { display:flex; align-items:center; gap:14px; padding:14px 15px; border-bottom:1px solid var(--line); transition:background .15s; width:100%; text-align:left; }
.lrow:last-child { border-bottom:none; }
.lrow:active { background:var(--paper-2); }
.lrow .ic { width:40px; height:40px; border-radius:11px; background:var(--c-soft); color:var(--c-deep); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.lrow .ic svg { width:22px; height:22px; }
.lrow.alt .ic { background:var(--paper-2); color:var(--ink); }
.lrow .lt { flex:1; min-width:0; }
.lrow .lt .nm { font-weight:600; font-size:15px; letter-spacing:-.01em; }
.lrow .lt .d { font-size:12px; color:var(--ink-3); margin-top:1px; line-height:1.3; }
.lrow .meta { font-family:var(--font-mono); font-size:10px; color:var(--ink-3); flex:0 0 auto; }
.lrow .arr { color:var(--ink-3); flex:0 0 auto; }
.lrow .arr svg { width:18px; height:18px; }
.lrow .badge { font-family:var(--font-mono); font-size:8.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--c-deep); background:var(--c-soft); border-radius:99px; padding:3px 8px; flex:0 0 auto; }

/* ---- Cartão genérico ---- */
.card { border:1px solid var(--line-2); border-radius:15px; background:var(--card); }

/* ---- Calendário de sequência ---- */
.weekrow { display:flex; justify-content:space-between; gap:7px; }
.wday { flex:1; text-align:center; }
.wday .dn { font-family:var(--font-mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); margin-bottom:7px; }
.wday .dot { width:100%; aspect-ratio:1; border-radius:11px; background:var(--paper-2); border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; }
.wday .dot svg { width:16px; height:16px; color:var(--c-on); opacity:0; }
.wday.done .dot { background:var(--c); border-color:var(--ink); }
.wday.done .dot svg { opacity:1; }
.wday.today .dot { border-color:var(--c); border-width:1.5px; border-style:dashed; }

/* ---- Barras por tema (desempenho) ---- */
.tbar { display:flex; align-items:center; gap:11px; padding:11px 0; }
.tbar .tn { font-size:13.5px; font-weight:500; width:116px; flex:0 0 auto; }
.tbar .track { flex:1; height:8px; border-radius:99px; background:#F0E1DD; overflow:hidden; display:flex; }
.tbar .track .ok { height:100%; }
.tbar .pc { font-family:var(--font-mono); font-size:11px; color:var(--ink-3); width:38px; text-align:right; flex:0 0 auto; }

/* ---- Conquistas ---- */
.achgrid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.ach { border:1px solid var(--line-2); border-radius:13px; background:var(--card); padding:12px; display:flex; gap:11px; align-items:center; }
.ach .md { width:42px; height:42px; border-radius:11px; background:var(--c-soft); color:var(--c-deep); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.ach .md svg { width:22px; height:22px; }
.ach .at { min-width:0; }
.ach .at .nm { font-weight:600; font-size:13px; letter-spacing:-.01em; line-height:1.1; }
.ach .at .d { font-size:10.5px; color:var(--ink-3); margin-top:2px; line-height:1.25; }
.ach.locked { opacity:.5; }
.ach.locked .md { background:var(--paper-2); color:var(--ink-3); }

/* ---- Perfil ---- */
.pf-head { display:flex; align-items:center; gap:15px; padding:6px 18px 4px; }
.pf-ava { width:64px; height:64px; border-radius:18px; background:var(--c); color:var(--c-on); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:32px; flex:0 0 auto; box-shadow:3px 3px 0 var(--ink); }
.pf-head .nm { font-family:var(--font-display); font-size:26px; line-height:1.05; }
.pf-head .chip { display:inline-flex; align-items:center; gap:6px; margin-top:5px; font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--c-deep); background:var(--c-soft); border:1px solid var(--c-line); border-radius:999px; padding:4px 10px; }
.pf-head .chip svg { width:12px; height:12px; }
.pf-premium { margin:16px 18px 0; border:1.5px solid var(--ink); border-radius:16px; background:var(--ink); color:var(--paper); padding:16px 18px; display:flex; align-items:center; gap:13px; position:relative; overflow:hidden; }
.pf-premium::before { content:""; position:absolute; inset:0; background:radial-gradient(70% 80% at 100% 0%, rgba(201,150,47,.28), transparent 60%); }
.pf-premium .ic { width:44px; height:44px; border-radius:12px; background:rgba(201,150,47,.18); color:var(--gold); display:flex; align-items:center; justify-content:center; flex:0 0 auto; position:relative; }
.pf-premium .ic svg { width:24px; height:24px; }
.pf-premium .pt { position:relative; flex:1; }
.pf-premium .pt .k { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.pf-premium .pt .nm { font-family:var(--font-display); font-size:20px; line-height:1.1; margin-top:2px; color:var(--paper); }
.pf-premium .pt .d { font-size:11.5px; color:#B7B0A0; margin-top:2px; }
.pf-premium .pchk { color:var(--gold); width:22px; height:22px; flex:0 0 auto; position:relative; }
.logout { display:flex; align-items:center; justify-content:center; gap:8px; width:100%; margin-top:16px; padding:14px; border-radius:12px; border:1px solid var(--line-2); background:var(--card); color:var(--wine); font-weight:600; font-size:14.5px; }
.logout svg { width:18px; height:18px; }

/* ---- Back header (ecrãs profundos) ---- */
.bh { display:flex; align-items:center; gap:12px; padding:16px 18px 10px; }
.bh .bk { width:40px; height:40px; border-radius:11px; border:1px solid var(--line-2); background:var(--card); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.bh .bk svg { width:20px; height:20px; color:var(--ink); }
.bh .ti { flex:1; min-width:0; }
.bh .ti .k { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.bh .ti .nm { font-family:var(--font-display); font-size:21px; line-height:1.05; }
.bh .step { font-family:var(--font-mono); font-size:11px; color:var(--c-deep); flex:0 0 auto; }
.bh > svg.hicon { width:26px; height:26px; color:var(--c); flex:0 0 auto; }

/* ---- Seta de retroceder transversal (componente _backbtn.html) ---- */
.goback { position:fixed; top:calc(13px + env(safe-area-inset-top,0px)); left:calc(50% - 222px); z-index:60; width:40px; height:40px; border-radius:11px; border:1px solid var(--line-2); background:var(--card); display:flex; align-items:center; justify-content:center; box-shadow:0 3px 12px rgba(26,29,34,.08); }
.goback svg { width:20px; height:20px; color:var(--ink); }
.goback:active { transform:translateY(1px); }
@media (max-width:515px){ .goback { left:18px; } }
/* Empurra o conteúdo para baixo p/ a seta não sobrepor o topo */
.has-goback .page { padding-top:52px; }
.has-goback .lo-nav { top:52px; }   /* resumos: as nav pills sticky ficam abaixo da seta */

/* ---- Sino de notificações global (canto sup. direito; espelha .goback) ---- */
.notifbell { position:fixed; top:calc(13px + env(safe-area-inset-top,0px)); right:calc(50% - 222px); z-index:60; width:40px; height:40px; border-radius:11px; border:1px solid var(--line-2); background:var(--card); color:var(--ink-2); display:flex; align-items:center; justify-content:center; box-shadow:0 3px 12px rgba(26,29,34,.08); text-decoration:none; }
.notifbell svg { width:19px; height:19px; }
.notifbell:active { transform:translateY(1px); }
@media (max-width:515px){ .notifbell { right:18px; } }
.nb-badge { position:absolute; top:-5px; right:-5px; min-width:17px; height:17px; padding:0 4px; border-radius:999px; background:var(--wine); color:#fff; font-family:var(--font-mono); font-size:10px; font-weight:700; display:none; align-items:center; justify-content:center; line-height:1; }
/* Canto superior direito = só o sino: esconde as decorações antigas dos headers */
.ah > .ah-r, .ah > .streak, .bh > svg { display:none !important; }

/* ---- Segmento ---- */
.seg { display:flex; background:var(--paper-2); border:1px solid var(--line-2); border-radius:12px; padding:4px; gap:4px; }
.seg button { flex:1; padding:10px 6px; border-radius:9px; font-weight:600; font-size:13px; color:var(--ink-3); transition:background .2s,color .2s; }
.seg button.on { background:var(--c); color:var(--c-on); }

/* ---- Chips ---- */
.chips { display:flex; flex-wrap:wrap; gap:8px; }
.chip { font-size:13px; font-weight:500; padding:9px 14px; border-radius:999px; border:1.5px solid var(--line-2); background:var(--card); color:var(--ink-2); display:inline-flex; align-items:center; gap:7px; transition:all .15s; }
.chip .x { width:16px; height:16px; border-radius:5px; border:1.5px solid var(--line-2); display:inline-flex; align-items:center; justify-content:center; }
.chip .x svg { width:11px; height:11px; opacity:0; transition:opacity .15s; }
.chip.on { border-color:var(--c); background:var(--c-soft); color:var(--c-deep); }
.chip.on .x { background:var(--c); border-color:var(--c); color:var(--c-on); }
.chip.on .x svg { opacity:1; }
.numchips { display:flex; gap:8px; }
.numchip { flex:1; padding:13px 0; border-radius:11px; border:1.5px solid var(--line-2); background:var(--card); font-family:var(--font-mono); font-weight:600; font-size:16px; color:var(--ink-2); text-align:center; transition:all .15s; }
.numchip.on { border-color:var(--ink); background:var(--c); color:var(--c-on); box-shadow:2px 2px 0 var(--ink); }

/* ---- Barra de ação inferior ---- */
.qfoot { position:fixed; left:50%; transform:translateX(-50%); bottom:var(--tabbar-h,76px); width:100%; max-width:480px; padding:14px 18px; background:color-mix(in srgb,var(--paper) 92%,transparent); backdrop-filter:blur(12px); border-top:1px solid var(--line-2); display:flex; align-items:center; gap:12px; z-index:51; }
/* Quando a página tem barra de ação fixa (.qfoot), o conteúdo limpa a tabbar + a .qfoot */
.page:has(.qfoot) { padding-bottom: calc(var(--tabbar-h,76px) + 104px); }
.qfoot .util { width:48px; height:48px; border-radius:12px; border:1px solid var(--line-2); background:var(--card); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.qfoot .util svg { width:21px; height:21px; color:var(--ink-2); }
.qfoot .btn { flex:1; }
.qfoot .btn.locked { opacity:.4; pointer-events:none; }

/* ---- Info box ---- */
.infobox { display:flex; align-items:center; gap:10px; padding:13px 15px; border:1px solid var(--line-2); border-radius:12px; background:var(--card); }
.infobox svg { width:19px; height:19px; color:var(--ink-3); flex:0 0 auto; }
.infobox .t { font-size:12.5px; color:var(--ink-2); line-height:1.4; }

/* ---- Botões ---- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; font-weight:600; font-size:15.5px; padding:15px 20px; border-radius:12px; border:1.5px solid var(--ink); background:var(--c); color:var(--c-on); box-shadow:3px 3px 0 var(--ink); transition:transform .12s,box-shadow .12s,background .3s; width:100%; text-decoration:none; }
.btn:active { transform:translate(3px,3px); box-shadow:0 0 0 var(--ink); }
.btn svg { width:18px; height:18px; flex:0 0 auto; }
.btn.ghost { background:var(--card); color:var(--ink); box-shadow:2px 2px 0 var(--ink); }
.btn.soft { background:var(--c-soft); color:var(--c-deep); border-color:var(--c-line); box-shadow:none; }

/* ---- Quiz ---- */
.qtop { padding:0 18px; }
.qbar { display:flex; align-items:center; gap:9px; }
.qbar .bar { flex:1; height:7px; background:var(--paper-2); border:1px solid var(--line-2); border-radius:99px; overflow:hidden; }
.qbar .bar i { display:block; height:100%; background:var(--c); transition:width .4s var(--ease),background .3s; }
.qbar .c { font-family:var(--font-mono); font-size:11px; color:var(--ink-3); }
.qbar .sc { font-family:var(--font-mono); font-size:11px; color:var(--c-deep); display:inline-flex; align-items:center; gap:4px; }
.qbar .sc svg { width:13px; height:13px; }
.qtema { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-top:18px; min-height:12px; }
.qq { font-family:var(--font-display); font-weight:400; font-size:28px; line-height:1.12; color:var(--ink); margin:8px 0 0; }
.qimg { margin-top:14px; display:flex; align-items:center; justify-content:center; max-height:220px; overflow:hidden; border-radius:12px; }
.qopts { display:flex; flex-direction:column; gap:9px; margin-top:18px; }
.qopt { display:flex; align-items:center; gap:12px; padding:14px; border-radius:13px; border:1.5px solid var(--line-2); background:var(--card); font-size:15.5px; font-weight:500; color:var(--ink); text-align:left; width:100%; transition:border-color .15s,background .15s,transform .1s; }
.qopt:active { transform:translate(1px,1px); }
.qopt .k { width:28px; height:28px; border-radius:8px; background:var(--paper-2); border:1px solid var(--line-2); color:var(--ink-2); display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-weight:600; font-size:13px; flex:0 0 auto; transition:all .15s; }
.qopt .k svg { width:15px; height:15px; }
.qopt.correct { border-color:var(--gnr); background:var(--gnr-soft); color:var(--gnr-deep); }
.qopt.correct .k { background:var(--gnr); color:#fff; border-color:var(--gnr); }
.qopt.wrong { border-color:var(--wine); background:#F3E7E3; color:var(--wine); }
.qopt.wrong .k { background:var(--wine); color:#fff; border-color:var(--wine); }
.qopt.dim { opacity:.5; }
.qfb { margin-top:13px; border:1px solid; border-radius:12px; padding:13px 14px; font-size:13px; line-height:1.45; display:none; }
.qfb.show { display:block; animation:pop .3s var(--snap); }
.qfb.ok { background:var(--gnr-soft); border-color:var(--gnr-line); color:var(--gnr-deep); }
.qfb.no { background:#F3E7E3; border-color:#E2C7C0; color:var(--wine); }
.qfb .ai { display:inline-flex; align-items:center; gap:6px; margin-top:9px; font-family:var(--font-mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-2); cursor:pointer; }
.qfb .ai svg { width:13px; height:13px; }
@keyframes pop { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }

/* ---- Resultado ---- */
.res-ring { width:168px; height:168px; border-radius:50%; margin:6px auto 0; display:grid; place-items:center; background:conic-gradient(var(--c) var(--resp,0%),var(--line) 0); transition:background .6s var(--ease); }
.res-ring .hole { width:134px; height:134px; border-radius:50%; background:var(--paper); display:grid; place-items:center; text-align:center; }
.res-ring .hole .big { font-family:var(--font-mono); font-weight:600; font-size:40px; letter-spacing:-.03em; color:var(--ink); line-height:1; }
.res-ring .hole .big span { font-size:22px; color:var(--ink-3); }
.res-ring .hole .of { font-family:var(--font-mono); font-size:12px; color:var(--ink-3); margin-top:4px; }
.res-stamp { display:inline-flex; align-items:center; gap:7px; border:2px solid var(--gnr); color:var(--gnr-deep); border-radius:8px; padding:7px 14px 6px; font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:600; transform:rotate(-3deg); }
.res-stamp svg { width:15px; height:15px; }
.res-stamp.low { border-color:var(--wine); color:var(--wine); }

/* ---- Tab bar (fixa em baixo, centrada com a coluna) ---- */
.tabbar { position:fixed; left:50%; transform:translateX(-50%); bottom:0; width:100%; max-width:480px; height:76px; background:color-mix(in srgb,var(--paper) 92%,transparent); backdrop-filter:blur(12px); border-top:1px solid var(--line-2); display:flex; padding:8px 8px calc(8px + env(safe-area-inset-bottom)); z-index:50; }
.tab { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; padding-top:6px; color:var(--ink-3); }
.tab svg { width:23px; height:23px; }
.tab .tl { font-size:10px; font-weight:500; }
.tab.on { color:var(--c); }
.tab.on .tl { font-weight:600; }

/* ---- Físico ---- */
.fcard2 { border:1.5px solid var(--ink); border-radius:16px; background:var(--card); overflow:hidden; box-shadow:3px 3px 0 var(--c); transition:box-shadow .3s; }
.fcard2 .vid { height:150px; background:var(--ink); position:relative; display:flex; align-items:center; justify-content:center; }
.fcard2 .vid .play { width:54px; height:54px; border-radius:50%; background:rgba(245,241,230,.16); border:1.5px solid var(--paper); display:flex; align-items:center; justify-content:center; }
.fcard2 .vid .play svg { width:24px; height:24px; color:var(--paper); margin-left:3px; }
.fcard2 .vid .vtag { position:absolute; left:12px; bottom:12px; font-family:var(--font-mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper); background:rgba(0,0,0,.3); border-radius:6px; padding:4px 9px; }
.fcard2 .fb { padding:16px; }
.fcard2 .fb h3 { font-family:var(--font-display); font-weight:400; font-size:24px; color:var(--ink); }
.fcard2 .fb .cond { font-size:12.5px; color:var(--ink-3); margin-top:3px; }
.sexrow { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:14px; }
.sexcard { border:1px solid var(--line-2); border-radius:12px; padding:12px 14px; background:var(--paper); }
.sexcard .l { font-family:var(--font-mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); display:flex; align-items:center; gap:6px; }
.sexcard .l svg { width:13px; height:13px; }
.sexcard .v { font-family:var(--font-mono); font-weight:600; font-size:20px; color:var(--ink); margin-top:5px; }
.sexcard .v small { font-size:11px; color:var(--ink-3); font-weight:400; }
.inputrow { display:flex; align-items:center; gap:10px; margin-top:14px; }
.inputrow .field { flex:1; border:1.5px solid var(--line-2); border-radius:12px; background:var(--card); padding:13px 15px; display:flex; align-items:baseline; justify-content:space-between; }
.inputrow .field .v { font-family:var(--font-mono); font-weight:600; font-size:22px; color:var(--ink); }
.inputrow .field .u { font-family:var(--font-mono); font-size:11px; color:var(--ink-3); }

/* ---- Psicotécnica ---- */
.ps-timer { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono); font-weight:600; font-size:14px; color:var(--wine); background:#F4E7E3; border:1px solid #E6C9C2; border-radius:999px; padding:7px 13px; }
.ps-timer svg { width:15px; height:15px; }
.matrix { display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-top:16px; }
.mcell { aspect-ratio:1; border:1.5px solid var(--line-2); border-radius:12px; background:var(--card); display:flex; align-items:center; justify-content:center; }
.mcell.q { border-style:dashed; border-color:var(--c); background:var(--c-soft); color:var(--c-deep); font-family:var(--font-display); font-size:34px; }
.mcell svg { width:46px; height:46px; color:var(--ink); }
.mcell img { max-width:80%; max-height:80%; object-fit:contain; }
.optrow { display:grid; grid-template-columns:repeat(4,1fr); gap:9px; margin-top:16px; }
.ocell { aspect-ratio:1; border:1.5px solid var(--line-2); border-radius:12px; background:var(--card); display:flex; align-items:center; justify-content:center; transition:border-color .15s, background .15s, transform .1s; }
.ocell:active { transform:translate(1px,1px); }
.ocell svg { width:38px; height:38px; color:var(--ink); }
.ocell.sel { border-color:var(--c); background:var(--c-soft); box-shadow:2px 2px 0 var(--c); }

/* ---- Ranking ---- */
.rk-podium { display:grid; grid-template-columns:1fr 1.15fr 1fr; gap:9px; align-items:end; margin-top:6px; }
.pod { border:1.5px solid var(--line-2); border-radius:14px; background:var(--card); padding:14px 8px 12px; text-align:center; position:relative; }
.pod.p1 { border-color:var(--ink); background:var(--c-soft); box-shadow:3px 3px 0 var(--ink); }
.pod .rkav { width:44px; height:44px; border-radius:50%; margin:0 auto; background:var(--c); color:var(--c-on); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:16px; transition:background .3s; }
.pod.p1 .rkav { width:52px; height:52px; font-size:19px; }
.pod .pos { position:absolute; top:-9px; left:50%; transform:translateX(-50%); width:22px; height:22px; border-radius:50%; background:var(--ink); color:var(--paper); display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-size:11px; font-weight:600; }
.pod.p1 .pos { background:var(--gold); color:var(--ink); }
.pod .rknm { font-size:12px; font-weight:600; margin-top:9px; letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pod .rkpc { font-family:var(--font-mono); font-size:14px; font-weight:600; color:var(--c-deep); margin-top:2px; transition:color .3s; }
.rk-list { border:1px solid var(--line-2); border-radius:14px; background:var(--card); overflow:hidden; margin-top:14px; }
.rk-row { display:flex; align-items:center; gap:13px; padding:12px 15px; border-bottom:1px solid var(--line); }
.rk-row:last-child { border-bottom:none; }
.rk-row .n { font-family:var(--font-mono); font-size:13px; color:var(--ink-3); width:22px; flex:0 0 auto; text-align:center; }
.rk-row .rkav { width:34px; height:34px; border-radius:50%; background:var(--paper-2); color:var(--ink-2); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; flex:0 0 auto; }
.rk-row .who { flex:1; font-size:14px; font-weight:500; }
.rk-row .pc { font-family:var(--font-mono); font-size:13px; font-weight:600; color:var(--ink); }
.rk-row .pc small { color:var(--ink-3); font-weight:400; font-size:10px; }
.rk-row.me { background:var(--c-soft); }
.rk-row.me .rkav { background:var(--c); color:var(--c-on); }
.rk-row.me .who { color:var(--c-deep); font-weight:700; }
.rk-row.me .pc { color:var(--c-deep); }

/* ---- Lição (leitura editorial) ---- */
.lz { padding:4px 20px 0; }
.lz .vid { height:158px; border-radius:14px; background:var(--ink); position:relative; display:flex; align-items:center; justify-content:center; margin-bottom:20px; overflow:hidden; }
.lz .vid .play { width:56px; height:56px; border-radius:50%; background:rgba(245,241,230,.16); border:1.5px solid var(--paper); display:flex; align-items:center; justify-content:center; }
.lz .vid .play svg { width:25px; height:25px; color:var(--paper); margin-left:3px; }
.lz .vid .dur { position:absolute; right:12px; bottom:12px; font-family:var(--font-mono); font-size:10px; color:var(--paper); background:rgba(0,0,0,.32); border-radius:6px; padding:4px 9px; }
.lz h3.lzh { font-family:var(--font-display); font-weight:400; font-size:27px; line-height:1.1; color:var(--ink); margin:4px 0 0; }
.lz .lzsub { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:8px; }
.lz p { font-size:15.5px; line-height:1.62; color:var(--ink-2); margin:14px 0 0; }
.lz .key { margin:18px 0 0; border-left:3px solid var(--c); background:var(--c-soft); border-radius:0 12px 12px 0; padding:14px 16px; transition:background .3s, border-color .3s; }
.lz .key .kk { font-family:var(--font-mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--c-deep); transition:color .3s; }
.lz .key p { font-size:14.5px; color:var(--ink); margin-top:6px; line-height:1.5; }
.lz ul.art { list-style:none; padding:0; margin:16px 0 0; }
.lz ul.art li { display:flex; gap:12px; padding:9px 0; border-top:1px solid var(--line); font-size:14.5px; line-height:1.5; color:var(--ink-2); }
.lz ul.art li:first-child { border-top:none; }
.lz ul.art li .ar { font-family:var(--font-mono); font-size:11px; color:var(--c-deep); flex:0 0 auto; padding-top:2px; transition:color .3s; }

/* ---- Áudio player ---- */
.au-now { margin:8px 18px 0; border:1.5px solid var(--ink); border-radius:18px; background:var(--ink); color:var(--paper); padding:22px 20px; box-shadow:3px 3px 0 var(--c); transition:box-shadow .3s; }
.au-now .crestwrap { display:flex; align-items:center; gap:12px; }
.au-now .crestwrap .cr { width:46px; height:46px; border-radius:12px; background:rgba(245,241,230,.12); color:var(--paper); display:flex; align-items:center; justify-content:center; }
.au-now .ttl { font-family:var(--font-display); font-size:22px; line-height:1.1; color:var(--paper); }
.au-now .ttl + .sub { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:#A39E8C; margin-top:3px; }
.au-wave { display:flex; align-items:center; gap:3px; height:40px; margin:20px 0 8px; }
.au-wave i { flex:1; background:rgba(245,241,230,.25); border-radius:2px; }
.au-wave i.on { background:var(--c); transition:background .3s; }
.au-time { display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:10.5px; color:#A39E8C; }
.au-ctrl { display:flex; align-items:center; justify-content:center; gap:24px; margin-top:16px; }
.au-ctrl .sk { color:var(--paper); opacity:.8; }
.au-ctrl .sk svg { width:26px; height:26px; }
.au-ctrl .pp { width:60px; height:60px; border-radius:50%; background:var(--paper); color:var(--ink); display:flex; align-items:center; justify-content:center; }
.au-ctrl .pp svg { width:26px; height:26px; }
.au-trk { display:flex; align-items:center; gap:13px; padding:13px 15px; border-bottom:1px solid var(--line); width:100%; text-align:left; }
.au-trk:last-child { border-bottom:none; }
.au-trk .num { font-family:var(--font-mono); font-size:12px; color:var(--ink-3); width:20px; flex:0 0 auto; }
.au-trk.playing .num { color:var(--c); }
.au-trk .tt { flex:1; }
.au-trk .tt .nm { font-weight:600; font-size:14px; }
.au-trk .tt .nm.playing { color:var(--c-deep); }
.au-trk .tt .meta { font-size:11.5px; color:var(--ink-3); margin-top:1px; }
.au-trk .du { font-family:var(--font-mono); font-size:11px; color:var(--ink-3); }

/* ---- Flash Cards ---- */
.fc-wrap { padding:16px 20px 0; }
.fc { width:100%; height:380px; position:relative; cursor:pointer; }
.fc-face { position:absolute; inset:0; border:1.5px solid var(--ink); border-radius:20px; background:var(--card); box-shadow:4px 4px 0 var(--c); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:28px; transition:opacity .28s var(--ease), transform .42s var(--ease), box-shadow .3s; }
.fc-face .tg { position:absolute; top:16px; left:16px; font-family:var(--font-mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.fc-face .hint { position:absolute; bottom:16px; font-family:var(--font-mono); font-size:10px; color:var(--ink-3); display:inline-flex; align-items:center; gap:6px; }
.fc-face .hint svg { width:13px; height:13px; }
.fc-front { opacity:1; transform:scale(1); }
.fc-front .q { font-family:var(--font-display); font-size:30px; line-height:1.15; color:var(--ink); }
.fc-back { opacity:0; transform:scale(.96); background:var(--c); border-color:var(--ink); pointer-events:none; }
.fc-back .a { font-size:18px; line-height:1.45; color:var(--c-on); font-weight:500; }
.fc-back .tg, .fc-back .hint { color:rgba(245,241,230,.7); }
.fc.flipped .fc-front { opacity:0; transform:scale(.96); pointer-events:none; }
.fc.flipped .fc-back { opacity:1; transform:scale(1); pointer-events:auto; }
.fc-actions { display:flex; gap:11px; margin-top:18px; }
.fc-actions button { flex:1; padding:15px; border-radius:13px; border:1.5px solid; font-weight:600; font-size:14.5px; display:inline-flex; align-items:center; justify-content:center; gap:8px; }
.fc-actions .no { border-color:var(--wine); color:var(--wine); background:#F4E7E3; }
.fc-actions .yes { border-color:var(--gnr); color:var(--gnr-deep); background:var(--gnr-soft); }
.fc-actions svg { width:17px; height:17px; }

/* ---- Swipe V/F ---- */
.sw-stack { position:relative; height:360px; margin:18px 20px 0; }
.sw-card { position:absolute; inset:0; border:1.5px solid var(--ink); border-radius:20px; background:var(--card); padding:26px; display:flex; flex-direction:column; box-shadow:4px 4px 0 var(--c); transition:box-shadow .3s, transform .3s var(--ease); }
.sw-card.b2 { transform:scale(.94) translateY(14px); z-index:1; box-shadow:none; opacity:.55; }
.sw-card.b3 { transform:scale(.88) translateY(28px); z-index:0; box-shadow:none; opacity:.3; }
.sw-card.top { z-index:2; }
.sw-card .tg { font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.sw-card .st { font-family:var(--font-display); font-size:27px; line-height:1.18; color:var(--ink); margin:auto 0; }
.sw-card .badge-vf { position:absolute; top:20px; font-family:var(--font-mono); font-weight:700; font-size:15px; letter-spacing:.1em; padding:6px 12px; border-radius:8px; border:2px solid; opacity:0; transition:opacity .15s; }
.sw-card .badge-v { right:20px; color:var(--gnr); border-color:var(--gnr); transform:rotate(8deg); }
.sw-card .badge-f { left:20px; color:var(--wine); border-color:var(--wine); transform:rotate(-8deg); }
.sw-actions { display:flex; justify-content:center; gap:22px; margin-top:22px; }
.sw-actions button { width:66px; height:66px; border-radius:50%; border:1.5px solid var(--ink); display:flex; align-items:center; justify-content:center; box-shadow:3px 3px 0 var(--ink); transition:transform .12s, box-shadow .12s; }
.sw-actions button:active { transform:translate(3px,3px); box-shadow:0 0 0 var(--ink); }
.sw-actions button svg { width:28px; height:28px; }
.sw-actions .f { background:#F4E7E3; color:var(--wine); }
.sw-actions .v { background:var(--gnr-soft); color:var(--gnr-deep); }
.sw-actions .lbl { display:block; text-align:center; font-family:var(--font-mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-top:7px; }

@media (prefers-reduced-motion:reduce){ *{transition:none!important;animation:none!important;} }
