/* Logos — acelerador de língua. Dark, denso, mobile-first, CSP-safe (zero inline; DOM via JS). */
@font-face{font-family:'Inter';src:url('/fonts/inter-latin.woff2') format('woff2');font-weight:100 900;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122}
@font-face{font-family:'Inter';src:url('/fonts/inter-latin-ext.woff2') format('woff2');font-weight:100 900;font-display:swap;unicode-range:U+0100-024F,U+1E00-1EFF}
@font-face{font-family:'JetBrains Mono';src:url('/fonts/jetbrains-mono-latin.woff2') format('woff2');font-weight:400 700;font-display:swap}
:root{
  --bg:#11131a;--bg2:#171a23;--panel:#1c2030;--panel2:#232838;--line:rgba(255,255,255,.10);--line2:rgba(255,255,255,.16);
  --ink:#f2f4fa;--muted:#9aa2b8;--muted2:#6d7591;--accent:#7c9cff;--accent2:#a98bff;--ok:#5bd6a0;--warn:#f1c87a;--err:#ff8a8a;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:840px;margin:0 auto;padding:20px 18px 64px}
/* header */
.top{display:flex;align-items:center;gap:11px;flex-wrap:wrap;margin-bottom:6px}
.brand{font-family:var(--mono);font-weight:700;font-size:21px;letter-spacing:.02em}
.brand .g{background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.beta{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--accent);color:var(--accent);border-radius:999px;padding:3px 8px}
.lang{font-family:var(--mono);font-size:11px;color:var(--muted2);border:1px solid var(--line);border-radius:6px;padding:3px 8px}
.tagline{font-size:14px;color:var(--muted);margin:2px 0 20px;max-width:60ch}
/* setup */
.setup{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:18px}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.row.t{margin-bottom:10px}
select,input[type=text],textarea{background:var(--bg2);border:1px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:15px;border-radius:9px;padding:11px 13px}
select{flex:0 0 auto}
input[type=text]{flex:1;min-width:180px}
textarea{width:100%;resize:vertical;min-height:74px;line-height:1.5}
button{font-family:var(--sans);font-size:14px;font-weight:700;border:none;border-radius:9px;padding:11px 16px;cursor:pointer;background:var(--accent);color:#10131c}
button:hover{filter:brightness(1.07)}
button.ghost{background:transparent;border:1px solid var(--line2);color:var(--muted)}
button[disabled]{opacity:.55;cursor:default}
.toggle{font-size:13px;color:var(--accent);background:none;border:none;cursor:pointer;padding:8px 0 0;font-weight:600}
.hide{display:none}
/* cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:16px}
.card h2{font-size:12px;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.titel{font-size:18px;font-weight:700;margin-bottom:10px}
.reader{font-size:17px;line-height:1.85}
.reader .w{cursor:pointer;border-bottom:1px dotted transparent;border-radius:3px;padding:0 1px}
.reader .w:hover{background:rgba(124,156,255,.16);border-bottom-color:var(--accent)}
.pat{border-left:3px solid var(--accent2);padding:6px 0 6px 14px;margin:0 0 14px}
.pat .p{font-family:var(--mono);font-size:14px;color:var(--ink);font-weight:700}
.pat .r{font-size:14.5px;color:#d7dbe8;margin-top:4px}
.pat .ex{font-size:13.5px;color:var(--muted);margin-top:5px;font-style:italic}
/* produce */
.fb{margin-top:12px;border-radius:10px;padding:13px 15px;font-size:15px}
.fb.ok{background:rgba(91,214,160,.12);border:1px solid rgba(91,214,160,.4)}
.fb.fix{background:rgba(255,138,138,.10);border:1px solid rgba(255,138,138,.35)}
.fb .corr{font-size:16px;font-weight:700;margin-bottom:8px}
.fb .corr .add{color:var(--ok)} .fb .corr del{color:var(--err);text-decoration:line-through;opacity:.8}
.fb .err{font-size:14px;color:#e7dcdc;padding:5px 0;border-top:1px solid rgba(255,255,255,.08)}
.fb .err b{color:var(--warn);font-family:var(--mono)}
/* gloss popover */
#gloss{position:fixed;z-index:60;max-width:260px;background:var(--panel2);border:1px solid var(--line2);border-radius:10px;padding:11px 13px;box-shadow:0 8px 28px rgba(0,0,0,.5);font-size:14px;display:none}
#gloss .lem{font-family:var(--mono);font-weight:700;color:var(--accent)}
#gloss .cl{font-size:11px;color:var(--muted2);text-transform:uppercase;letter-spacing:.06em}
#gloss .tr{margin-top:6px;color:var(--ink)}
#gloss .tr .lbl{color:var(--muted2);font-family:var(--mono);font-size:11px}
/* states */
.spin{width:26px;height:26px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:sp 1s linear infinite;margin:8px auto}
@keyframes sp{to{transform:rotate(360deg)}}
.muted{color:var(--muted)}
.errline{color:var(--err);font-size:14px}
/* footer */
footer{border-top:1px solid var(--line);margin-top:28px;padding-top:18px}
footer p{font-size:12.5px;color:var(--muted);max-width:72ch;margin-bottom:7px}
footer b{color:#cfd3e4}
.prov{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);margin-top:10px}
.prov .g{color:var(--accent)}
