/* ============================================================
   styles.css — "Noche" design system (v2.0.0)
   C base (aurora violet/teal, near-black, refined serif + geometric
   sans) fused with A's idea: semantic CATEGORY colors, pulled into
   the Noche family so the eye always knows what zone it's in.

   Architecture: existing component CSS references semantic names
   (--bg, --surface, --accent, --good, --hairline...). We keep those
   names and remap their VALUES, so the redesign is a token swap.
   New system tokens (--brand-*, --cat-*, --space-*, --text-*) layer
   on top for the redesigned pieces.
   ============================================================ */

/* ---------- DESIGN TOKENS ---------- */
:root,
[data-theme="dark"]{
  /* brand spine — the aurora */
  --brand-violet:#8b5cf6;
  --brand-teal:#2dd4bf;
  --brand-pink:#f472b6;
  --aurora:linear-gradient(135deg,var(--brand-violet),var(--brand-teal));
  --aurora-soft:linear-gradient(135deg,rgba(139,92,246,0.22),rgba(45,212,191,0.16));

  /* semantic category colors (A's idea, in C's family) */
  --cat-foundations:#8b5cf6;
  --cat-grammar:#2dd4bf;
  --cat-practice:#e0a82e;   /* amber-gold: reward/mastery, sits with violet+teal as a jewel trio */
  --cat-food:#fb923c;
  --cat-people:#60a5fa;
  --cat-home:#a78bfa;
  --cat-time:#34d399;
  --cat-animals:#facc15;
  --cat-body:#f87171;
  --cat-places:#22d3ee;
  --cat-colors:#e879f9;
  --cat-verbs:#818cf8;
  --cat-clothing:#f472b6;
  --cat-weather:#38bdf8;
  --cat-work:#fbbf24;

  /* surfaces — near-black with cool violet undertone, layered */
  --bg:#0b0b12;
  --bg-glow-1:rgba(139,92,246,0.20);
  --bg-glow-2:rgba(45,212,191,0.13);
  --surface:#14141f;
  --surface-2:#1b1b2b;
  --surface-3:#23233599;
  --elevated:linear-gradient(180deg,#1b1b2b,#14141f);

  /* text */
  --ink:#f0eefa;
  --muted:#aeacc4;
  --muted-2:#cac8dd;

  /* mapped legacy roles → Noche (keeps old component CSS alive) */
  --accent:#8b5cf6;
  --accent-soft:rgba(139,92,246,0.16);
  --good:#2dd4bf;
  --good-soft:rgba(45,212,191,0.16);
  --hairline:rgba(255,255,255,0.08);
  --shadow:rgba(0,0,0,0.5);

  /* type scale (1.250 major third) */
  --text-xs:0.75rem; --text-sm:0.875rem; --text-base:1rem;
  --text-lg:1.25rem; --text-xl:1.563rem; --text-2xl:1.953rem;
  --text-3xl:2.441rem; --text-4xl:3.052rem; --text-5xl:3.815rem;

  /* spacing rhythm (4px base) */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-5:24px; --space-6:32px; --space-7:48px; --space-8:64px;

  /* radius + elevation */
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --shadow-card:0 14px 40px -20px rgba(139,92,246,0.45);
  --shadow-pop:0 10px 30px -10px rgba(0,0,0,0.6);
}
[data-theme="light"]{
  --bg:#f5f4fb;
  --bg-glow-1:rgba(139,92,246,0.12);
  --bg-glow-2:rgba(45,212,191,0.10);
  --surface:#ffffff;
  --surface-2:#f0eff7;
  --surface-3:#e9e8f4;
  --elevated:linear-gradient(180deg,#ffffff,#f6f5fc);
  --ink:#1a1726;
  --muted:#6b6880;
  --muted-2:#4a4860;
  --accent:#7c3aed;
  --accent-soft:rgba(124,58,237,0.10);
  --good:#0d9488;
  --good-soft:rgba(13,148,136,0.12);
  --hairline:rgba(26,23,38,0.12);
  --shadow:rgba(80,70,120,0.18);
  --shadow-card:0 14px 40px -22px rgba(124,58,237,0.3);
  --shadow-pop:0 10px 30px -12px rgba(80,70,120,0.25);
  --cat-food:#ea7317; --cat-animals:#ca9a04; --cat-colors:#c026d3; --cat-practice:#b07d12; --cat-clothing:#db2777; --cat-weather:#0284c7; --cat-work:#b45309;
}

*{margin:0;padding:0;box-sizing:border-box}

body{
  background:
    radial-gradient(900px 460px at 100% -5%, var(--bg-glow-1), transparent 60%),
    radial-gradient(760px 420px at -5% 105%, var(--bg-glow-2), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  color:var(--ink);
  font-family:'Sora',system-ui,sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  transition:background .3s ease,color .3s ease;
  padding-bottom:80px;
}

.wrap{max-width:1000px;margin:0 auto;padding:0 24px}

/* ---------- TYPE HELPERS ---------- */
.mono{font-family:'DM Mono',monospace}
.serif{font-family:'Spectral',serif;font-optical-sizing:auto}
.eyebrow{
  font-family:'DM Mono',monospace;
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
}

/* ---------- TOP BAR ---------- */
header.bar{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--hairline);
}
.bar-inner{
  max-width:1000px;margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.brand{display:flex;align-items:baseline;gap:10px}
.brand .logo{font-family:'Spectral',serif;font-weight:600;font-size:23px;letter-spacing:-0.01em;
  background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand .ver{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.theme-toggle{
  background:transparent;border:1px solid var(--hairline);border-radius:2px;
  color:var(--ink);cursor:pointer;padding:8px 12px;
  font-family:'DM Mono',monospace;font-size:12px;letter-spacing:0.06em;
  transition:.15s;display:flex;align-items:center;gap:7px;
}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
.bar-actions{display:flex;gap:8px;align-items:center}
@media(max-width:440px){
  .bar-actions{gap:6px}
  .theme-toggle{padding:8px 10px;font-size:11px}
}

/* ---------- VOICE / AUDIO PANEL ---------- */
.voice-panel{
  display:none;max-width:1000px;margin:0 auto;padding:0 24px;
}
.voice-panel.open{
  display:block;padding-top:16px;padding-bottom:20px;
  animation:fade .2s ease;
}
.voice-panel .vp-head{font-family:'Spectral',serif;font-weight:600;font-size:20px;margin-bottom:14px}
.vp-section-label{
  font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--muted);margin:14px 0 8px;
}
.vp-voices{display:flex;flex-direction:column;gap:6px;max-height:260px;overflow-y:auto}
.vp-voice{
  display:flex;align-items:center;gap:10px;cursor:pointer;
  background:var(--surface);border:1px solid var(--hairline);border-radius:5px;
  padding:10px 14px;transition:.12s;
}
.vp-voice:hover{border-color:var(--muted)}
.vp-voice.selected{border-color:var(--accent);background:var(--accent-soft)}
.vp-voice input{accent-color:var(--accent)}
.vp-voice-name{flex:1;font-size:15px}
.vp-voice-lang{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.vp-badge{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.06em;text-transform:uppercase;padding:3px 8px;border-radius:2px}
.vp-badge.good{background:var(--good-soft);color:var(--good)}
.vp-badge.poor{background:var(--accent-soft);color:var(--accent)}
.vp-empty{color:var(--muted);font-size:14px;line-height:1.55;background:var(--surface);border:1px solid var(--hairline);border-radius:5px;padding:14px 16px;max-width:70ch}
.vp-rate{display:flex;align-items:center;gap:12px;max-width:360px}
.vp-rate input[type=range]{flex:1;accent-color:var(--accent)}
.vp-rate-val{font-family:'DM Mono',monospace;font-size:13px;color:var(--accent);min-width:46px;text-align:right}
.vp-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}

/* ---------- NAV TABS ---------- */
nav.tabs{
  display:flex;gap:4px;flex-wrap:wrap;
  padding:16px 0 4px;border-bottom:1px solid var(--hairline);margin-bottom:32px;
}
.tab{
  background:transparent;border:none;cursor:pointer;
  color:var(--muted);font-family:'DM Mono',monospace;
  font-size:13px;letter-spacing:0.04em;padding:10px 14px;border-radius:2px;
  transition:.15s;border-bottom:2px solid transparent;white-space:nowrap;
}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
/* On phones, a single swipeable row reads better than 3 wrapped rows. */
@media(max-width:680px){
  nav.tabs{
    flex-wrap:nowrap;overflow-x:auto;gap:2px;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
    margin-bottom:24px;
  }
  nav.tabs::-webkit-scrollbar{display:none}
  .tab{padding:10px 12px;flex-shrink:0}
}

/* ---------- HERO ---------- */
.hero{padding:40px 0 36px}
.hero .eyebrow{margin-bottom:14px;display:block}
.hero-word{
  font-family:'Spectral',serif;font-weight:500;
  font-size:clamp(56px,11vw,112px);line-height:0.9;letter-spacing:-0.025em;
  margin-bottom:10px;
  background:linear-gradient(135deg,var(--ink) 28%,#c4b5fd 68%,var(--brand-teal));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding-bottom:0.08em;
}
.hero-ipa{font-family:'DM Mono',monospace;color:var(--brand-teal);font-size:clamp(15px,2.2vw,19px)}
.hero-gloss{color:var(--muted);font-size:18px;margin-top:16px;max-width:48ch}
.hero-hint{color:var(--muted-2);font-size:13px;margin-top:16px;opacity:.8}
.hero-hint strong{background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:600}

/* ---------- SECTION HEADING ---------- */
.view{display:none;animation:fade .25s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

h2.section{
  font-family:'Spectral',serif;font-weight:600;font-size:30px;letter-spacing:-0.01em;
  margin:8px 0 6px;
}
.section-sub{color:var(--muted);margin-bottom:28px;max-width:60ch}

h3.group{
  font-family:'DM Mono',monospace;font-size:12px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--muted);
  border-bottom:1px solid var(--hairline);padding-bottom:10px;margin:36px 0 20px;
}

/* ---------- WORD CARDS GRID ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.wcard{
  background:var(--elevated);border:1px solid var(--hairline);border-radius:var(--r-lg);
  padding:22px 20px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
  position:relative;overflow:hidden;
}
/* category accent stripe — set via --cat on the element/container */
.wcard::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--cat,var(--accent));opacity:.9}
.wcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:transparent}
.wcard .es{font-family:'Spectral',serif;font-weight:500;font-size:27px;letter-spacing:-0.01em;line-height:1.15}
.wcard .ipa{font-family:'DM Mono',monospace;font-size:13px;color:var(--brand-teal);margin-top:4px}
.wcard .en{color:var(--muted);margin-top:10px;font-size:15px}
.wcard .note{color:var(--muted);font-size:13px;margin-top:8px;font-style:italic;opacity:.85}
.gender-dot{
  position:absolute;top:16px;right:16px;font-family:'DM Mono',monospace;
  font-size:11px;padding:3px 8px;border-radius:20px;letter-spacing:0.05em;
}
.gender-dot.m{background:var(--accent-soft);color:#c4b5fd}
.gender-dot.f{background:var(--good-soft);color:var(--brand-teal)}

/* ---------- SPEAK BUTTON ---------- */
.speak{
  margin-top:16px;width:42px;height:42px;border-radius:50%;
  background:transparent;border:1px solid var(--brand-violet);color:#c4b5fd;
  cursor:pointer;font-size:13px;transition:.15s;display:inline-flex;align-items:center;justify-content:center;
}
.speak:hover{background:var(--aurora);border-color:transparent;color:#fff}
.speak:active{transform:scale(.94)}
.speak.speaking{background:var(--aurora);border-color:transparent;color:#fff;animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* ---------- NUMBERS GRID ---------- */
.numgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
.numcard{
  background:var(--surface);border:1px solid var(--hairline);border-radius:5px;
  padding:16px;text-align:center;cursor:pointer;transition:.15s;
}
.numcard:hover{border-color:var(--accent);transform:translateY(-2px)}
.numcard .digit{font-family:'DM Mono',monospace;font-size:13px;color:var(--muted)}
.numcard .es{font-family:'Spectral',serif;font-weight:600;font-size:24px;margin:4px 0 2px}
.numcard .ipa{font-family:'DM Mono',monospace;font-size:11px;color:var(--accent)}

/* ---------- NUMBER BUILDER ---------- */
.numbuild-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}
.numbuild{
  background:var(--surface);border:1px solid var(--hairline);border-radius:5px;
  padding:16px;cursor:pointer;transition:.15s;border-left:3px solid var(--accent);
}
.numbuild:hover{transform:translateY(-2px);border-left-color:var(--accent)}
.nb-n{font-family:'DM Mono',monospace;font-size:13px;color:var(--muted)}
.nb-word{font-family:'Spectral',serif;font-weight:600;font-size:22px;margin:3px 0}
.nb-break{font-size:12px;color:var(--muted)}
.bd-y{color:var(--accent);font-weight:600}

/* ---------- NUMBER DRILL ---------- */
.nd-card{
  background:var(--surface);border:1px solid var(--hairline);border-radius:8px;
  padding:32px 24px;text-align:center;max-width:420px;
}
.nd-prompt{font-family:'DM Mono',monospace;font-size:56px;font-weight:500;color:var(--accent);line-height:1}
.nd-answer{font-family:'Spectral',serif;font-weight:600;font-size:30px;margin:16px 0 22px;min-height:38px}
.nd-hidden{color:var(--muted);font-family:'DM Mono',monospace;font-size:15px;font-weight:400}
.nd-controls{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* ---------- PRONUNCIATION ---------- */
.pron-block{
  background:var(--surface);border:1px solid var(--hairline);border-radius:6px;
  padding:24px;margin-bottom:16px;
}
.pron-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.pron-letter{font-family:'Spectral',serif;font-weight:700;font-size:44px;color:var(--accent);line-height:1}
.pron-title{font-family:'Spectral',serif;font-weight:600;font-size:22px}
.pron-rule{color:var(--ink);margin:14px 0 18px;max-width:64ch}
.pron-ex{display:flex;flex-wrap:wrap;gap:10px}
.exchip{
  display:flex;align-items:center;gap:10px;
  background:var(--surface-2);border:1px solid var(--hairline);border-radius:4px;padding:10px 14px;
}
.exchip .es{font-family:'Spectral',serif;font-weight:600;font-size:18px}
.exchip .ipa{font-family:'DM Mono',monospace;font-size:12px;color:var(--accent)}
.exchip .en{font-size:13px;color:var(--muted)}
.exchip .speak{margin-top:0;width:32px;height:32px;font-size:11px}

/* ---------- GENDER ---------- */
.gender-summary{
  background:var(--surface);border-left:3px solid var(--accent);border-radius:0 5px 5px 0;
  padding:20px 22px;margin-bottom:14px;max-width:72ch;
}
.gender-summary p{margin-bottom:0}
.gender-rule{
  background:var(--good-soft);border-left:3px solid var(--good);border-radius:0 5px 5px 0;
  padding:16px 22px;margin-bottom:28px;max-width:72ch;font-size:15px;
}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:640px){.two-col{grid-template-columns:1fr}.cards{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.cards{grid-template-columns:1fr}.bar-inner{padding:14px 18px}}

/* ---------- FLASHCARDS ---------- */
.flash-stage{max-width:480px;margin:10px auto 0;text-align:center}
.flash{
  perspective:1200px;height:280px;margin-bottom:22px;cursor:pointer;
}
.flash-inner{
  position:relative;width:100%;height:100%;transition:transform .55s;
  transform-style:preserve-3d;
}
.flash.flipped .flash-inner{transform:rotateY(180deg)}
.flash-face{
  position:absolute;inset:0;backface-visibility:hidden;
  background:var(--surface);border:1px solid var(--hairline);border-radius:10px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px;
}
.flash-face.back{transform:rotateY(180deg)}
.flash-face .es{font-family:'Spectral',serif;font-weight:600;font-size:46px;letter-spacing:-0.02em}
.flash-face .ipa{font-family:'DM Mono',monospace;font-size:15px;color:var(--accent)}
.flash-face .en{font-family:'Spectral',serif;font-weight:500;font-size:38px}
.flash-face .hint{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase;position:absolute;bottom:18px}
.flash-controls{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.btn{
  font-family:'DM Mono',monospace;font-size:13px;letter-spacing:0.06em;
  border:1px solid var(--hairline);background:transparent;color:var(--ink);
  border-radius:20px;padding:11px 18px;cursor:pointer;transition:.15s;
}
.btn:hover{border-color:var(--muted)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{filter:brightness(1.08)}
.flash-counter{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin-bottom:14px}

/* ---------- MATCHING DRILL ---------- */
.match-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:560px;margin:0 auto}
.match-col-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.match-item{
  background:var(--surface);border:1px solid var(--hairline);border-radius:5px;
  padding:14px 16px;cursor:pointer;transition:.15s;margin-bottom:10px;font-size:17px;
}
.match-item .ipa{font-family:'DM Mono',monospace;font-size:11px;color:var(--accent);display:block;margin-top:2px}
.match-item.es-item{font-family:'Spectral',serif;font-weight:600}
.match-item:hover{border-color:var(--muted)}
.match-item.selected{border-color:var(--accent);background:var(--accent-soft)}
.match-item.matched{border-color:var(--good);background:var(--good-soft);cursor:default;opacity:.75}
.match-item.wrong{border-color:var(--accent);animation:shake .35s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.match-result{text-align:center;font-family:'DM Mono',monospace;font-size:14px;color:var(--good);margin-top:20px;min-height:20px}

/* ---------- PROGRESS / FOOTER ---------- */
.progress-strip{
  display:flex;gap:18px;flex-wrap:wrap;margin:8px 0 28px;
  font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);
}
.progress-strip b{color:var(--accent);font-weight:500}
footer{
  border-top:1px solid var(--hairline);margin-top:60px;padding-top:24px;
  font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
}

/* ---------- VOCAB FILTERS ---------- */
.vocab-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.vfilter{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--surface);border:1px solid var(--hairline);border-radius:20px;
  color:var(--muted);font-family:'DM Mono',monospace;font-size:12px;
  letter-spacing:0.03em;padding:9px 14px;cursor:pointer;transition:.15s;border-radius:20px;
}
.vfilter:hover{border-color:var(--muted);color:var(--ink)}
.vfilter.active{border-color:var(--cat,var(--accent));color:var(--cat,var(--accent));background:color-mix(in srgb,var(--cat,var(--accent)) 14%,transparent)}
.vicon{font-size:14px;line-height:1}
.vcount{
  font-size:10px;background:var(--surface-2);color:var(--muted);
  padding:1px 6px;border-radius:8px;
}
.vfilter.active .vcount{background:var(--cat,var(--accent));color:#fff}
h3.group .vicon{font-size:15px;margin-right:4px}
/* category-colored section header: tints the left edge + icon */
h3.group.cat-head{border-bottom-color:color-mix(in srgb,var(--cat,var(--accent)) 40%,var(--hairline));
  color:var(--cat,var(--muted));padding-left:12px;
  border-left:3px solid var(--cat,var(--accent));border-bottom:1px solid var(--hairline)}

/* ---------- DRILL CATEGORY SELECT ---------- */
.drill-cat{margin-bottom:18px;text-align:center}
.cat-select{
  background:var(--surface);border:1px solid var(--hairline);border-radius:20px;
  color:var(--ink);font-family:'DM Mono',monospace;font-size:13px;
  padding:9px 14px;cursor:pointer;transition:.15s;min-width:220px;
}
.cat-select:hover{border-color:var(--accent)}

/* ============================================================
   SER vs ESTAR
   ser = sage (grounded/permanent), estar = terracotta (state/active)
   ============================================================ */
.conj-wrap{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:8px}
@media(max-width:560px){.conj-wrap{grid-template-columns:1fr}}
.conj-card{background:var(--surface);border:1px solid var(--hairline);border-radius:6px;padding:18px 20px;border-top:3px solid}
.conj-card.ser{border-top-color:var(--good)}
.conj-card.estar{border-top-color:var(--accent)}
.conj-title{font-family:'Spectral',serif;font-weight:600;font-size:24px;margin-bottom:12px}
.conj-card.ser .conj-title{color:var(--good)}
.conj-card.estar .conj-title{color:var(--accent)}
.conj-table{width:100%;border-collapse:collapse}
.conj-table td{padding:7px 6px;border-bottom:1px solid var(--hairline);vertical-align:middle}
.conj-table tr:last-child td{border-bottom:none}
.conj-p{color:var(--muted);font-size:14px;white-space:nowrap}
.conj-f{font-family:'Spectral',serif;font-weight:600;font-size:18px}
.conj-ipa{font-family:'DM Mono',monospace;font-size:11px;color:var(--accent)}
.conj-table .speak{margin-top:0;width:30px;height:30px;font-size:10px}

.use-list{display:flex;flex-direction:column;gap:10px}
.use-row{display:flex;align-items:flex-start;gap:14px;background:var(--surface);border:1px solid var(--hairline);border-radius:5px;padding:14px 16px;border-left:3px solid}
.use-row.ser{border-left-color:var(--good)}
.use-row.estar{border-left-color:var(--accent)}
.use-tag{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;padding:4px 9px;border-radius:2px;white-space:nowrap;flex-shrink:0;margin-top:2px}
.use-row.ser .use-tag{background:var(--good-soft);color:var(--good)}
.use-row.estar .use-tag{background:var(--accent-soft);color:var(--accent)}
.use-body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.use-es{font-family:'Spectral',serif;font-weight:600;font-size:19px}
.use-ipa{font-family:'DM Mono',monospace;font-size:11px;color:var(--accent)}
.use-en{color:var(--ink);font-size:14px}
.use-why{color:var(--muted);font-size:13px;font-style:italic;margin-top:2px}
.use-row .speak{margin-top:2px;flex-shrink:0}

.contrast-list{display:flex;flex-direction:column;gap:12px}
.contrast-row{background:var(--surface);border:1px solid var(--hairline);border-radius:6px;padding:16px 18px}
.contrast-adj{font-family:'Spectral',serif;font-weight:600;font-size:20px;display:block;margin-bottom:12px}
.contrast-adj::before{content:"“";color:var(--muted)}
.contrast-adj::after{content:"”";color:var(--muted)}
.contrast-pair{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.contrast-pair{grid-template-columns:1fr}}
.contrast-side{padding:12px 14px;border-radius:4px;border:1px solid var(--hairline)}
.contrast-side.ser{background:var(--good-soft);border-color:transparent}
.contrast-side.estar{background:var(--accent-soft);border-color:transparent}
.cs-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;display:block;margin-bottom:5px}
.contrast-side.ser .cs-label{color:var(--good)}
.contrast-side.estar .cs-label{color:var(--accent)}
.cs-es{font-family:'Spectral',serif;font-weight:600;font-size:17px;display:block}
.cs-en{color:var(--muted);font-size:14px}

/* ---------- SER/ESTAR QUIZ ---------- */
.se-quiz-card{background:var(--surface);border:1px solid var(--hairline);border-radius:8px;padding:26px 24px;max-width:560px}
.se-counter{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin-bottom:14px}
.se-prompt{font-family:'Spectral',serif;font-weight:600;font-size:26px;line-height:1.3;margin-bottom:6px}
.se-blank{color:var(--accent);border-bottom:2px dashed var(--accent);padding:0 6px}
.se-en{color:var(--muted);font-size:15px;margin-bottom:20px}
.se-choices{display:flex;gap:12px}
.se-choice{flex:1;font-family:'Spectral',serif;font-weight:600;font-size:18px;padding:14px}
.se-choice.se-correct{background:var(--good-soft);border-color:var(--good);color:var(--good)}
.se-choice.se-wrong{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.se-feedback{margin-top:18px}
.se-result{font-size:15px;margin-bottom:14px;padding:12px 14px;border-radius:4px;border-left:3px solid}
.se-result.ok{background:var(--good-soft);border-left-color:var(--good)}
.se-result.no{background:var(--accent-soft);border-left-color:var(--accent)}
.se-done{background:var(--surface);border:1px solid var(--hairline);border-radius:8px;padding:36px 24px;text-align:center;max-width:560px}
.se-done-score{font-family:'Spectral',serif;font-weight:700;font-size:46px;color:var(--accent)}
.se-done-label{color:var(--muted);margin:8px 0 22px;font-size:16px}

/* ============================================================
   REGULAR VERB CONJUGATION
   stem = ink, ending = terracotta (the part that changes)
   ============================================================ */
.vfam-wrap{display:flex;flex-direction:column;gap:18px}
.vfam{background:var(--surface);border:1px solid var(--hairline);border-radius:8px;padding:20px 22px;border-top:3px solid var(--accent)}
.vfam-head{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:14px}
.vfam-ending{
  font-family:'Spectral',serif;font-weight:700;font-size:40px;color:var(--accent);
  line-height:1;background:var(--accent-soft);padding:8px 16px;border-radius:5px;
}
.vfam-model{font-family:'Spectral',serif;font-weight:600;font-size:24px;line-height:1.1}
.vfam-modelen{color:var(--muted);font-size:14px;display:flex;align-items:center;gap:6px;margin-top:2px}
.vfam-modelen .speak{margin-top:0;width:26px;height:26px;font-size:9px}
.vfam-endings{
  margin-left:auto;font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);
  letter-spacing:0.04em;
}
@media(max-width:560px){.vfam-endings{margin-left:0;width:100%}}
.vstem{color:var(--ink)}
.vend{color:var(--accent);font-weight:700}
.vfam-table{width:100%;border-collapse:collapse;margin-bottom:12px}
.vfam-table td{padding:8px 6px;border-bottom:1px solid var(--hairline);vertical-align:middle}
.vfam-table tr:last-child td{border-bottom:none}
.conj-en{color:var(--muted);font-size:13px}
.vfam-also{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.also-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.06em;text-transform:uppercase}
.also-chip{background:var(--surface-2);border:1px solid var(--hairline);border-radius:20px;padding:3px 9px;font-size:13px}

.vinsight{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--good-soft);border-left:3px solid var(--good);border-radius:0 6px 6px 0;
  padding:16px 20px;margin:6px 0 8px;max-width:74ch;
}
.vinsight-mark{font-size:22px;line-height:1.2}
.vinsight p{margin:0;font-size:15px}

/* ---------- CONJUGATION DRILL ---------- */
.conj-q{margin-bottom:4px}
.conj-q-verb{font-family:'Spectral',serif;font-weight:600;font-size:30px}
.conj-q-en{color:var(--muted);font-size:16px;margin-left:8px}
.conj-q-person{color:var(--ink);font-size:16px;margin-bottom:18px}
.conj-q-person strong{color:var(--accent)}
.conj-input-row{display:flex;gap:10px;flex-wrap:wrap}
.conj-input{
  flex:1;min-width:160px;background:var(--bg);border:1px solid var(--hairline);border-radius:4px;
  color:var(--ink);font-family:'Spectral',serif;font-weight:600;font-size:20px;padding:12px 14px;
  transition:.15s;
}
.conj-input:focus{outline:none;border-color:var(--accent)}
.conj-input.input-ok{border-color:var(--good);background:var(--good-soft)}
.conj-input.input-no{border-color:var(--accent);background:var(--accent-soft)}

/* ---------- IRREGULAR VERBS ---------- */
.irr-group{margin-bottom:24px}
.irr-group-head{margin-bottom:6px}
.irr-group-title{font-family:'Spectral',serif;font-weight:600;font-size:21px}
.irr-explain{color:var(--muted);font-size:15px;margin-bottom:16px;max-width:70ch}
.irr-verbs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.irr-verbs{grid-template-columns:1fr}}
.irr-verb{background:var(--surface);border:1px solid var(--hairline);border-radius:7px;padding:18px 20px;border-left:3px solid var(--accent)}
.irr-verb-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.irr-inf{font-family:'Spectral',serif;font-weight:600;font-size:23px}
.irr-en{color:var(--muted);font-size:14px}
.irr-verb-head .speak{margin-top:0;width:30px;height:30px;font-size:10px}
.irr-note{font-size:13px;color:var(--muted);font-style:italic;margin:6px 0 12px}

/* ---------- DRILL MODE TOGGLE ---------- */
.drill-mode{display:flex;gap:6px;margin-bottom:16px}
.mode-btn{
  background:var(--surface);border:1px solid var(--hairline);border-radius:20px;
  color:var(--muted);font-family:'DM Mono',monospace;font-size:12px;letter-spacing:0.04em;
  padding:8px 16px;cursor:pointer;transition:.15s;
}
.mode-btn:hover{border-color:var(--muted);color:var(--ink)}
.mode-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.irr-flag{color:var(--accent);text-transform:uppercase;letter-spacing:0.06em}

/* ============================================================
   LISTENING DRILL
   ============================================================ */
.listen-card{background:var(--surface);border:1px solid var(--hairline);border-radius:8px;padding:28px 24px;max-width:520px;text-align:center}
.listen-card .se-counter{text-align:left}
.listen-play{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  width:130px;height:130px;margin:8px auto 22px;border-radius:50%;
  background:var(--accent-soft);border:2px solid var(--accent);color:var(--accent);
  cursor:pointer;transition:.15s;
}
.listen-play:hover{background:var(--accent);color:#fff}
.listen-play:active{transform:scale(.96)}
.listen-play-icon{font-size:34px;line-height:1}
.listen-play-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.08em;text-transform:uppercase}
.listen-prompt{font-family:'Spectral',serif;font-weight:600;font-size:22px;margin-bottom:18px}
.listen-choices{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:440px){.listen-choices{grid-template-columns:1fr}}
.listen-choice{font-size:16px;padding:14px}
.listen-choice.se-correct{background:var(--good-soft);border-color:var(--good);color:var(--good)}
.listen-choice.se-wrong{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.listen-reveal{font-family:'Spectral',serif;font-weight:600}
.listen-ipa{font-family:'DM Mono',monospace;font-size:12px;color:var(--accent);margin:0 4px}

/* ============================================================
   HOME / LEARNING PATH
   ============================================================ */
.home-tips{margin-top:40px;padding-top:24px;border-top:1px solid var(--hairline);display:flex;flex-direction:column;gap:14px}
.home-tip{display:flex;gap:14px;align-items:flex-start;color:var(--muted);font-size:14px;max-width:72ch;line-height:1.55}
.home-tip strong{color:var(--ink)}
.tip-icon{
  flex-shrink:0;width:28px;height:28px;border-radius:50%;
  background:var(--surface);border:1px solid var(--hairline);color:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:13px;
}
.path-progress{margin-bottom:18px}
.path-progress-bar{height:8px;background:var(--surface);border:1px solid var(--hairline);border-radius:4px;overflow:hidden}
.path-progress-bar i{display:block;height:100%;background:var(--accent);transition:width .5s ease}
.path-progress-label{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin-top:8px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}

.path-continue{margin-bottom:32px;font-family:'Spectral',serif;font-weight:600;font-size:17px;padding:14px 24px}
.path-complete{background:var(--good-soft);border-left:3px solid var(--good);border-radius:0 6px 6px 0;padding:16px 20px;margin-bottom:32px;color:var(--ink);max-width:70ch}

.path-stages{display:flex;flex-direction:column;gap:32px}
.path-stage-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}
.path-stage-num{
  flex-shrink:0;width:36px;height:36px;border-radius:50%;
  background:var(--cat,var(--accent));color:#0b0b12;
  font-family:'Spectral',serif;font-weight:700;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 18px -8px var(--cat,var(--accent));
}
.path-stage-name{font-family:'Spectral',serif;font-weight:600;font-size:22px;line-height:1.1}
.path-stage-tag{color:var(--muted);font-size:14px;margin-top:3px;max-width:62ch}

.path-steps{display:flex;flex-direction:column;gap:10px;padding-left:48px}
@media(max-width:520px){.path-steps{padding-left:0}}
.path-step{
  display:flex;align-items:center;gap:14px;text-align:left;width:100%;
  background:var(--elevated);border:1px solid var(--hairline);border-radius:var(--r-md);
  padding:15px 17px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;color:var(--ink);
}
.path-step:hover{border-color:color-mix(in srgb,var(--cat,var(--accent)) 50%,transparent);transform:translateX(3px);box-shadow:var(--shadow-card)}
.path-step.done{border-left:3px solid var(--cat,var(--good))}
.path-step.next{border-color:var(--cat,var(--accent));box-shadow:0 0 0 1px var(--cat,var(--accent))}
.path-check{
  flex-shrink:0;width:24px;height:24px;border-radius:50%;
  border:1px solid var(--hairline);color:var(--cat,var(--good));
  display:flex;align-items:center;justify-content:center;font-size:13px;
}
.path-step.done .path-check{background:color-mix(in srgb,var(--cat,var(--good)) 18%,transparent);border-color:var(--cat,var(--good))}
.path-step-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.path-step-title{font-family:'Spectral',serif;font-weight:600;font-size:18px}
.path-step-desc{color:var(--muted);font-size:13px}
.path-kind{
  flex-shrink:0;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.08em;
  text-transform:uppercase;padding:4px 9px;border-radius:2px;
}
.kind-lesson{background:var(--accent-soft);color:var(--accent)}
.kind-reference{background:var(--good-soft);color:var(--good)}
.kind-practice{background:var(--surface-2);color:var(--muted)}

/* ---------- RESET LINK ---------- */
.reset-link{color:var(--accent);text-decoration:none;border-bottom:1px dotted var(--accent);font-size:14px}
.reset-link:hover{opacity:.8}

/* ---------- SRS METER ---------- */
.srs-meter{
  display:flex;align-items:flex-end;gap:6px;justify-content:center;
  margin-bottom:18px;flex-wrap:wrap;
}
.meter-cell{
  position:relative;width:30px;height:46px;border:1px solid var(--hairline);
  border-radius:20px;background:var(--surface);overflow:hidden;
  display:flex;align-items:flex-end;justify-content:center;
}
.meter-cell i{display:block;width:100%;background:var(--accent);opacity:.85;transition:height .4s ease}
.meter-cell.box-1 i{background:var(--accent)}
.meter-cell.box-2 i{background:#c07a4e}
.meter-cell.box-3 i{background:var(--muted)}
.meter-cell.box-4 i{background:#8a9079}
.meter-cell.box-5 i{background:var(--good)}
.meter-cell em{
  position:absolute;top:3px;left:0;right:0;text-align:center;
  font-family:'DM Mono',monospace;font-size:10px;color:var(--ink);font-style:normal;
}
.meter-label{
  width:100%;text-align:center;font-family:'DM Mono',monospace;
  font-size:11px;color:var(--muted);letter-spacing:0.05em;margin-top:4px;
}

/* ---------- FLASH GRADE BUTTONS ---------- */
.btn.miss{border-color:var(--muted);color:var(--muted-2)}
.btn.miss:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- FLASH EMPTY STATE ---------- */
.flash-empty{
  background:var(--surface);border:1px solid var(--hairline);border-radius:10px;
  padding:44px 28px;text-align:center;
}
.flash-empty-mark{
  font-size:34px;color:var(--good);width:64px;height:64px;margin:0 auto 16px;
  border:2px solid var(--good);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.flash-empty-title{font-family:'Spectral',serif;font-weight:600;font-size:24px;margin-bottom:10px}
.flash-empty-sub{color:var(--muted);font-size:15px;max-width:46ch;margin:0 auto 22px;line-height:1.55}

/* ============================================================
   TEACHING TOOLTIPS  (data-tip on any element)
   ============================================================ */
[data-tip]{position:relative;cursor:help;border-bottom:1px dotted color-mix(in srgb,var(--brand-teal) 60%,transparent)}
[data-tip]::after{
  content:attr(data-tip);
  position:absolute;left:50%;bottom:calc(100% + 10px);transform:translateX(-50%) translateY(4px);
  background:var(--surface-2);color:var(--ink);border:1px solid var(--hairline);
  border-radius:var(--r-sm);padding:10px 13px;width:max-content;max-width:260px;
  font-family:'Sora',sans-serif;font-size:13px;line-height:1.45;font-weight:400;letter-spacing:0;text-transform:none;
  box-shadow:var(--shadow-pop);opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease;z-index:60;
  white-space:normal;text-align:left;
}
[data-tip]::before{
  content:"";position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--surface-2);opacity:0;transition:opacity .16s ease;z-index:60;
}
[data-tip]:hover::after,[data-tip]:focus-visible::after{opacity:1;transform:translateX(-50%) translateY(0)}
[data-tip]:hover::before,[data-tip]:focus-visible::before{opacity:1}
@media(max-width:560px){[data-tip]::after{max-width:200px;left:0;transform:translateX(0) translateY(4px)}
  [data-tip]:hover::after{transform:translateX(0)}}

/* ============================================================
   EASTER EGGS — subtle, rewarding, teaching
   ============================================================ */
/* word of the day reveal (click the logo) */
.wotd{
  margin-top:14px;background:var(--elevated);border:1px solid var(--hairline);
  border-left:3px solid var(--brand-pink);border-radius:0 var(--r-md) var(--r-md) 0;
  padding:16px 18px;max-width:560px;animation:fade .3s ease;
}
.wotd-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--brand-pink)}
.wotd-es{font-family:'Spectral',serif;font-weight:500;font-size:28px;margin:6px 0 2px}
.wotd-ipa{font-family:'DM Mono',monospace;font-size:13px;color:var(--brand-teal)}
.wotd-en{color:var(--muted);margin-top:8px}
.wotd-extra{color:var(--muted);font-size:14px;margin-top:10px;font-style:italic}

/* unlocked idiom toast (Konami-style code) */
.egg-toast{
  position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);
  background:var(--elevated);border:1px solid var(--hairline);border-radius:var(--r-md);
  padding:18px 22px;max-width:380px;box-shadow:var(--shadow-pop);z-index:200;
  opacity:0;transition:opacity .3s ease,transform .3s ease;
}
.egg-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.egg-toast .et-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.egg-toast .et-es{font-family:'Spectral',serif;font-weight:500;font-size:22px;margin:6px 0 2px}
.egg-toast .et-en{color:var(--muted);font-size:14px}
.egg-toast .et-lit{color:var(--muted-2);font-size:13px;margin-top:8px;font-style:italic}

/* ---------- ACCESSIBILITY ---------- */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .flash-inner{transition:none}
}
.tts-warn{
  background:var(--accent-soft);border:1px solid var(--accent);border-radius:4px;
  padding:12px 16px;font-size:14px;color:var(--ink);margin-bottom:20px;display:none;
}

/* ============================================================
   v3.0.0 — APPLICATION SHELL (rail + subnav + content)
   Concept 4 layout: wide labelled icon rail, contextual lesson
   list, content area. Dashboard is the front door.
   ============================================================ */
.app{display:grid;grid-template-columns:auto auto minmax(0,1fr);min-height:100vh;align-items:stretch}
body{padding-bottom:0}

/* ---------- ICONS ---------- */
.ic{fill:none !important;stroke:currentColor;vertical-align:middle}

/* ---------- RAIL ---------- */
.rail{
  width:188px;background:var(--surface);border-right:1px solid var(--hairline);
  display:flex;flex-direction:column;padding:18px 12px;position:sticky;top:0;height:100vh;
}
.rail-brand{display:flex;align-items:center;gap:10px;padding:6px 10px 18px;cursor:pointer;
  font-family:'Spectral',serif;font-weight:600;font-size:19px}
.rail-brand span{background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.rail-brand .ic{width:22px;height:22px;color:var(--brand-violet)}
.rail-nav{display:flex;flex-direction:column;gap:3px;flex:1}
.rail-foot{display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--hairline);padding-top:10px;margin-top:10px}
.rail-item{
  display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  background:transparent;border:none;cursor:pointer;color:var(--muted);
  font-family:'Sora',sans-serif;font-size:14px;padding:10px 11px;border-radius:10px;transition:.14s;
}
.rail-item .ic{width:19px;height:19px;flex-shrink:0}
.rail-item:hover{background:rgba(255,255,255,0.04);color:var(--ink)}
.rail-item.on{color:var(--ink);background:color-mix(in srgb,var(--cat,var(--accent)) 16%,transparent)}
.rail-item.on .ic{color:var(--cat,var(--accent))}

/* ---------- SUBNAV ---------- */
.subnav{
  width:0;overflow:hidden;background:rgba(20,20,31,0.45);border-right:1px solid transparent;
  position:sticky;top:0;height:100vh;transition:width .18s ease;
}
.subnav.show{width:230px;border-right-color:var(--hairline);padding:22px 0;overflow-y:auto}
.sn-head{font-family:'Spectral',serif;font-weight:600;font-size:18px;padding:0 20px 14px;color:var(--cat,var(--ink))}
.sn-unit{margin-bottom:14px}
.sn-unit-name{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.13em;text-transform:uppercase;
  color:var(--muted-2);padding:6px 20px}
.sn-lesson{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:transparent;border:none;
  cursor:pointer;color:var(--muted);font-family:'Sora',sans-serif;font-size:13.5px;padding:8px 20px;
  border-left:2px solid transparent;transition:.12s}
.sn-lesson:hover{color:var(--ink);background:rgba(255,255,255,0.03)}
.sn-lesson.on{color:var(--ink);border-left-color:var(--cat,var(--accent));background:color-mix(in srgb,var(--cat,var(--accent)) 12%,transparent)}
.sn-lesson.done .sn-label{color:var(--muted-2)}
.sn-check{width:15px;height:15px;flex-shrink:0;color:var(--cat,var(--good))}
.sn-check .ic{width:15px;height:15px}
.sn-label{flex:1}

/* ---------- CONTENT AREA ---------- */
.content{padding:34px 40px 90px;max-width:920px;width:100%;min-width:0;position:relative;overflow-x:hidden}
@media(max-width:900px){.content{padding:26px 22px 90px}}

/* ---------- DASHBOARD ---------- */
.db-hero{margin-bottom:22px}
.db-eyebrow{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--brand-teal)}
.db-h1{font-family:'Spectral',serif;font-weight:600;font-size:clamp(30px,5vw,44px);letter-spacing:-0.02em;margin:8px 0 16px;
  background:linear-gradient(135deg,var(--ink) 35%,#c4b5fd 75%,var(--brand-teal));-webkit-background-clip:text;background-clip:text;color:transparent;padding-bottom:.06em}
.db-overall{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.db-overall-bar{flex:1;min-width:180px;height:8px;background:var(--surface-2);border-radius:5px;overflow:hidden}
.db-overall-bar i{display:block;height:100%;background:var(--aurora);transition:width .5s ease}
.db-overall-lab{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted)}

.db-resume{background:var(--elevated);border:1px solid var(--hairline);border-left:3px solid var(--cat,var(--brand-violet));
  border-radius:var(--r-lg);padding:24px 26px;box-shadow:var(--shadow-card);margin-bottom:18px}
.db-resume-lab{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--cat,var(--brand-violet))}
.db-resume-title{font-family:'Spectral',serif;font-weight:500;font-size:30px;margin:6px 0 4px;color:var(--ink)}
.db-resume-sub{color:var(--muted);font-size:15px}
.db-resume-btn{margin-top:16px;background:var(--aurora);color:#fff;border:none;border-radius:10px;
  padding:11px 20px;font-family:'Sora',sans-serif;font-weight:600;font-size:14px;cursor:pointer}
.db-resume-btn:hover{filter:brightness(1.08)}

.db-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:26px}
@media(max-width:680px){.db-row{grid-template-columns:1fr}}
.db-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:20px 22px}
.db-card-h{display:flex;align-items:center;gap:9px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.db-card-h .ic{width:16px;height:16px;color:var(--brand-teal);stroke-width:2}
.db-review-num{font-family:'Spectral',serif;font-weight:600;font-size:46px;line-height:1;color:var(--brand-teal)}
.db-review-sub{color:var(--muted);font-size:14px;margin-top:6px}
.db-mini-btn{margin-top:14px;background:transparent;border:1px solid var(--hairline);border-radius:8px;
  color:var(--ink);font-family:'Sora',sans-serif;font-size:13px;padding:8px 14px;cursor:pointer;transition:.14s}
.db-mini-btn:hover{border-color:var(--brand-violet);color:#c4b5fd}
.db-next{display:flex;flex-direction:column;gap:2px;width:100%;text-align:left;background:var(--surface-2);
  border:1px solid var(--hairline);border-radius:10px;padding:12px 14px;cursor:pointer;color:var(--ink);margin-bottom:4px}
.db-next:hover{border-color:var(--brand-violet)}
.db-next-lab{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted)}
.db-next b{font-family:'Spectral',serif;font-weight:500;font-size:18px}

.db-sec{font-family:'Spectral',serif;font-weight:600;font-size:22px;margin:8px 0 16px}
.db-tracks{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:760px){.db-tracks{grid-template-columns:1fr}}
.db-track{text-align:left;background:var(--elevated);border:1px solid var(--hairline);border-top:3px solid var(--cat,var(--accent));
  border-radius:var(--r-lg);padding:20px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease;color:var(--ink)}
.db-track:hover{transform:translateY(-3px);box-shadow:var(--shadow-card)}
.db-track-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.db-track-top .ic{width:21px;height:21px;color:var(--cat,var(--accent));stroke-width:2}
.db-track-top .ic{filter:drop-shadow(0 0 6px color-mix(in srgb,var(--cat,var(--accent)) 45%,transparent))}
.db-track-name{font-family:'Spectral',serif;font-weight:600;font-size:19px;color:var(--ink)}
.db-track-blurb{color:var(--muted);font-size:13.5px;line-height:1.5;margin-bottom:14px;min-height:40px}
.db-track-bar{height:6px;background:var(--surface-2);border-radius:4px;overflow:hidden}
.db-track-bar i{display:block;height:100%;background:var(--cat,var(--accent));transition:width .5s ease}
.db-track-meta{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);margin-top:8px}

.db-tip{margin-top:30px;color:var(--muted-2);font-size:13px}
.db-tip b{background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:600}
.db-resetwrap{margin-top:24px;padding-top:18px;border-top:1px solid var(--hairline)}

/* ---------- LESSON VIEW ---------- */
.lessonView{--cat:var(--accent)}
.lx-head{margin-bottom:26px}
.lx-crumb{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--cat,var(--muted));margin-bottom:12px}
.lx-title{font-family:'Spectral',serif;font-weight:600;font-size:clamp(30px,5vw,42px);letter-spacing:-0.02em;line-height:1.05;
  background:linear-gradient(135deg,var(--ink) 40%,color-mix(in srgb,var(--cat,#c4b5fd) 70%,#fff) 90%);-webkit-background-clip:text;background-clip:text;color:transparent;padding-bottom:.05em}
.lx-sub{color:var(--muted);font-size:17px;margin-top:8px}
.lx-hint{display:inline-block;margin-left:6px;font-size:13px;color:var(--muted-2)}
.lx-hint a{color:var(--cat,var(--brand-teal));cursor:pointer;border-bottom:1px dotted}
.lx-body > *{margin-bottom:8px}
.lx-prose{font-size:16px;line-height:1.65;color:var(--ink);max-width:64ch;margin:18px 0}
.lx-prose b{font-weight:600}
.lx-callout{display:flex;flex-direction:column;gap:4px;border-radius:0 var(--r-md) var(--r-md) 0;padding:16px 20px;margin:20px 0;max-width:72ch;
  border-left:3px solid var(--brand-violet);background:var(--accent-soft)}
.lx-callout.tone-good{border-left-color:var(--brand-teal);background:var(--good-soft)}
.lx-callout.tone-link{border-left-color:var(--brand-pink);background:color-mix(in srgb,var(--brand-pink) 12%,transparent)}
.lx-callout.tone-warn{border-left-color:#f0a830;background:rgba(240,168,48,0.12)}
.lx-callout-title{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted-2)}

.lx-foot{margin-top:40px;padding-top:24px;border-top:1px solid var(--hairline)}
.lx-complete{background:transparent;border:1px solid var(--cat,var(--accent));color:var(--cat,var(--accent));
  border-radius:10px;padding:11px 22px;font-family:'Sora',sans-serif;font-weight:600;font-size:14px;cursor:pointer;transition:.14s}
.lx-complete:hover{background:var(--cat,var(--accent));color:#0b0b12}
.lx-complete.is-done{background:color-mix(in srgb,var(--cat,var(--good)) 18%,transparent);border-color:var(--cat,var(--good));color:var(--cat,var(--good))}
.lx-navrow{display:flex;justify-content:space-between;gap:14px;margin-top:22px}
.lx-nav{display:flex;flex-direction:column;gap:3px;background:var(--surface);border:1px solid var(--hairline);
  border-radius:var(--r-md);padding:13px 18px;cursor:pointer;color:var(--ink);min-width:0;max-width:48%}
.lx-nav.next{text-align:right;align-items:flex-end}
.lx-nav:hover{border-color:var(--brand-violet)}
.lx-nav span{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.lx-nav b{font-family:'Spectral',serif;font-weight:500;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}

/* voice panel repositioned inside content */
.content .voice-panel{padding:0;margin-bottom:18px}
.content .voice-panel.open{padding:18px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md)}

/* ---------- MOBILE ---------- */
.mobilebar{display:none}
@media(max-width:760px){
  .app{grid-template-columns:1fr}
  .rail{display:none}
  .subnav{position:fixed;top:0;left:0;z-index:40;box-shadow:var(--shadow-pop)}
  .subnav.show{width:min(280px,82vw)}
  .content{padding-bottom:90px}
  .mobilebar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;
    background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(10px);
    border-top:1px solid var(--hairline);padding:8px 6px}
  .mb-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;background:transparent;border:none;
    cursor:pointer;color:var(--muted);font-family:'Sora',sans-serif;font-size:10.5px;padding:6px 2px}
  .mb-item .ic{width:20px;height:20px}
  .mb-item:active{color:var(--brand-violet)}
}

/* ============================================================
   v3.2.0 — DASHBOARD STATS (streak · goal ring · heat-map)
   The signature: a calendar of consistency, not a lonely number.
   ============================================================ */
.db-top{margin-bottom:20px}
.db-eyebrow{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:0.12em;text-transform:lowercase;color:var(--brand-teal)}

/* --- the streak card (hero) --- */
.streakcard{
  display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;
  background:var(--elevated);border:1px solid var(--hairline);border-radius:var(--r-xl);
  padding:28px 30px;margin-bottom:20px;position:relative;overflow:hidden;
  box-shadow:var(--shadow-card);
}
.streakcard::before{ /* ambient aurora wash, very subtle */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(420px 200px at 88% -20%, rgba(139,92,246,0.14), transparent 70%);
}
@media(max-width:620px){.streakcard{grid-template-columns:1fr;gap:22px;justify-items:center;text-align:center}}

/* ring */
.sc-ring{position:relative;width:132px;height:132px;flex-shrink:0}
.ring{display:block;transform:rotate(0)}
.ring-fill{filter:drop-shadow(0 0 6px rgba(139,92,246,0.45))}
.ring-fill.met{filter:drop-shadow(0 0 9px rgba(45,212,191,0.6))}
.sc-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.sc-ring-num{font-family:'Spectral',serif;font-weight:600;font-size:34px;line-height:1;color:var(--ink)}
.sc-ring-num span{font-size:17px;color:var(--muted)}
.sc-ring-lab{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted-2);margin-top:3px}

/* streak + goal line + heatmap stack */
.sc-main{width:100%;min-width:0}
.sc-streak{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.sc-flame{width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:var(--surface-2);transition:.3s}
.sc-flame svg{fill:currentColor}
.sc-flame.lit{color:#e0a82e;filter:drop-shadow(0 0 8px rgba(224,168,46,0.5))}
.sc-streak-num{font-family:'Spectral',serif;font-weight:700;font-size:40px;line-height:1;color:var(--ink)}
.sc-streak-lab{font-family:'DM Mono',monospace;font-size:11px;line-height:1.2;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted)}
.sc-goal{font-size:13.5px;color:var(--muted);margin-bottom:16px}
.dg-met{color:var(--brand-teal);display:inline-flex;align-items:center;gap:5px}
.dg-met .ic{width:14px;height:14px}
.dg-rem{color:var(--muted-2)}
.sc-goallink{color:var(--brand-teal);cursor:pointer;border-bottom:1px dotted}

/* heat-map */
.hm{display:flex;gap:3px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.hm::-webkit-scrollbar{display:none}
.hm-col{display:flex;flex-direction:column;gap:3px}
.hm-cell{width:13px;height:13px;border-radius:3px;background:var(--surface-2);display:block;flex-shrink:0}
.hm-cell.lvl-1{background:color-mix(in srgb,var(--brand-violet) 38%,var(--surface-2))}
.hm-cell.lvl-2{background:color-mix(in srgb,var(--brand-violet) 66%,var(--brand-teal))}
.hm-cell.lvl-3{background:linear-gradient(135deg,var(--brand-violet),var(--brand-teal));box-shadow:0 0 6px rgba(45,212,191,0.4)}
.hm-cell.future{background:transparent}
.sc-legend{display:flex;justify-content:space-between;align-items:center;margin-top:10px;
  font-family:'DM Mono',monospace;font-size:11px;color:var(--muted-2)}
.sc-legend-key{display:flex;align-items:center;gap:4px}
.sc-legend-key .hm-cell{width:11px;height:11px}

/* --- resume / review as buttons --- */
.db-resume{text-align:left;cursor:pointer;display:block;width:100%;font-family:inherit;color:var(--ink)}
.db-resume-go{display:inline-block;margin-top:14px;font-family:'DM Mono',monospace;font-size:12px;
  letter-spacing:0.04em;color:var(--cat,var(--brand-violet))}
.db-review{text-align:left;cursor:pointer;font-family:inherit;color:var(--ink)}

/* --- compact stat strip --- */
.db-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:6px 0 28px}
@media(max-width:620px){.db-stats{grid-template-columns:repeat(2,1fr)}}
.db-stat{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:16px 18px;text-align:center}
.db-stat-num{font-family:'Spectral',serif;font-weight:600;font-size:30px;line-height:1;color:var(--ink)}
.db-stat-lab{font-family:'DM Mono',monospace;font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);margin-top:7px}

/* --- footer actions --- */
.db-foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  margin-top:30px;padding-top:20px;border-top:1px solid var(--hairline)}
.db-foot-actions{display:flex;gap:16px}
.reset-link.danger{color:var(--muted-2)}
.reset-link.danger:hover{color:#f87171}

/* --- milestone toast --- */
.ms-toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(24px);
  display:flex;align-items:center;gap:16px;background:var(--elevated);border:1px solid var(--hairline);
  border-radius:var(--r-lg);padding:18px 24px 18px 18px;box-shadow:var(--shadow-pop);z-index:200;
  opacity:0;transition:opacity .4s ease,transform .4s cubic-bezier(.2,.8,.2,1);overflow:hidden}
.ms-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.ms-glow{position:absolute;inset:0;background:radial-gradient(200px 80px at 10% 0%,rgba(224,168,46,0.25),transparent 70%);pointer-events:none}
.ms-mark{width:46px;height:46px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#e0a82e,#f0c860);color:#0b0b12}
.ms-mark .ic{width:24px;height:24px;stroke-width:2.4}
.ms-lab{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:#e0a82e}
.ms-title{font-family:'Spectral',serif;font-weight:600;font-size:20px;margin:2px 0}
.ms-note{color:var(--muted);font-size:13px;max-width:34ch}
@media(prefers-reduced-motion:reduce){.ring-fill{transition:none !important}.ms-toast{transition:opacity .2s}}

/* ============================================================
   QUESTION WORDS lesson + quiz
   ============================================================ */
.qw-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.qw-row{display:grid;grid-template-columns:160px 1fr auto;gap:16px;align-items:center;
  background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:14px 18px}
@media(max-width:620px){.qw-row{grid-template-columns:1fr;gap:8px}}
.qw-word{display:flex;flex-direction:column;gap:2px}
.qw-es{font-family:'Spectral',serif;font-weight:600;font-size:22px;color:var(--ink)}
.qw-ipa{font-family:'DM Mono',monospace;font-size:12px;color:var(--brand-teal)}
.qw-en{font-size:13px;color:var(--muted)}
.qw-ex{display:flex;flex-direction:column;gap:2px;border-left:2px solid var(--hairline);padding-left:16px}
.qw-ex-es{font-family:'Spectral',serif;font-size:17px;color:var(--ink)}
.qw-ex-en{font-size:13px;color:var(--muted)}
.qw-callout{background:var(--accent-soft);border:1px solid var(--hairline);border-left:3px solid var(--brand-violet);
  border-radius:0 var(--r-md) var(--r-md) 0;padding:14px 18px;margin:20px 0;font-size:14px;color:var(--muted-2);max-width:72ch}

/* accent on/off pairs */
.qw-pairs{display:flex;flex-direction:column;gap:12px}
.qw-pair{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;
  background:var(--elevated);border:1px solid var(--hairline);border-radius:var(--r-md);padding:16px 18px;position:relative}
.qw-pair-side{display:flex;flex-direction:column;gap:3px;text-align:center}
.qw-pair-side.q .qw-pair-w{color:var(--brand-teal)}
.qw-pair-side.flat .qw-pair-w{color:var(--muted-2)}
.qw-pair-w{font-family:'Spectral',serif;font-weight:600;font-size:22px}
.qw-pair-en{font-size:12px;color:var(--muted);font-family:'DM Mono',monospace}
.qw-pair-arrow{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted-2);text-transform:uppercase}
.qw-pair-note{grid-column:1/-1;text-align:center;font-size:13px;color:var(--muted);border-top:1px solid var(--hairline);padding-top:10px;margin-top:4px}

/* quiz */
.qw-quiz-head{display:flex;justify-content:space-between;font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin-bottom:14px}
.qw-quiz-sentence{font-family:'Spectral',serif;font-size:30px;text-align:center;color:var(--ink);margin-bottom:6px}
.qw-blank{color:var(--brand-violet);border-bottom:2px dashed var(--brand-violet);padding:0 8px}
.qw-quiz-en{text-align:center;color:var(--muted);font-size:14px;margin-bottom:22px}
.qw-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:480px;margin:0 auto}
@media(max-width:520px){.qw-opts{grid-template-columns:1fr}}
.qw-opt{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:14px;
  font-family:'Spectral',serif;font-size:18px;color:var(--ink);cursor:pointer;transition:.14s}
.qw-opt:hover:not(:disabled){border-color:var(--brand-violet);transform:translateY(-2px)}
.qw-opt.right{background:color-mix(in srgb,var(--brand-teal) 20%,transparent);border-color:var(--brand-teal);color:var(--ink)}
.qw-opt.wrong{background:color-mix(in srgb,var(--bad,#f87171) 18%,transparent);border-color:#f87171}
.qw-opt:disabled{cursor:default}
.qw-quiz-next{text-align:center;margin-top:20px;min-height:44px}
.quiz-done{text-align:center;padding:20px}
.quiz-done-score{font-family:'Spectral',serif;font-weight:700;font-size:56px;background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.quiz-done-lab{color:var(--muted);font-size:15px;margin:10px 0 20px}

/* ============================================================
   GAMES — Relámpago (speed round)
   ============================================================ */
.rl-intro{text-align:center;padding:30px 20px;max-width:520px;margin:0 auto}
.rl-bolt{color:var(--cat-practice);display:flex;justify-content:center;margin-bottom:10px;
  filter:drop-shadow(0 0 12px color-mix(in srgb,var(--cat-practice) 50%,transparent))}
.rl-title{font-family:'Spectral',serif;font-weight:700;font-size:34px;letter-spacing:-0.01em;margin-bottom:8px}
.rl-tag{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:18px}
.rl-hs{font-family:'DM Mono',monospace;font-size:13px;color:var(--muted-2);margin-bottom:20px}
.rl-hs b{color:var(--cat-practice)}
.rl-modes{display:flex;flex-direction:column;gap:10px;align-items:center}
.rl-start{background:var(--aurora);color:#fff;border:none;border-radius:12px;padding:15px 30px;
  font-family:'Sora',sans-serif;font-weight:600;font-size:16px;cursor:pointer;transition:.14s}
.rl-start:hover{filter:brightness(1.08);transform:translateY(-1px)}
.rl-relaxed{background:transparent;border:1px solid var(--hairline);color:var(--muted);border-radius:12px;
  padding:12px 26px;font-family:'Sora',sans-serif;font-size:14px;cursor:pointer;transition:.14s}
.rl-relaxed:hover{border-color:var(--muted);color:var(--ink)}
.rl-note{font-size:12px;color:var(--muted-2);margin-top:14px}

.rl-stage{max-width:560px;margin:0 auto;text-align:center}
.rl-hud{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.rl-meter,.rl-scorebox{text-align:center}
.rl-meter-num{font-family:'Spectral',serif;font-weight:700;font-size:42px;line-height:1;color:var(--ink)}
.rl-meter.low .rl-meter-num{color:#f87171}
.rl-meter.relaxed .rl-meter-num{color:var(--brand-teal)}
.rl-score-num{font-family:'Spectral',serif;font-weight:700;font-size:42px;line-height:1;
  background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.rl-meter-lab{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.rl-bar{height:6px;background:var(--surface-2);border-radius:4px;overflow:hidden;margin-bottom:30px}
.rl-bar i{display:block;height:100%;width:100%;background:var(--aurora);transition:width 1s linear}
.rl-prompt{font-family:'Spectral',serif;font-weight:600;font-size:48px;letter-spacing:-0.01em;margin-bottom:6px}
.rl-sub{font-family:'DM Mono',monospace;color:var(--brand-teal);font-size:14px;margin-bottom:30px}
.rl-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.rl-opts{grid-template-columns:1fr}}
.rl-opt{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:18px;
  font-family:'Sora',sans-serif;font-size:17px;color:var(--ink);cursor:pointer;transition:.12s}
.rl-opt:hover:not(:disabled){border-color:var(--brand-violet);transform:translateY(-2px)}
.rl-opt.right{background:color-mix(in srgb,var(--brand-teal) 22%,transparent);border-color:var(--brand-teal)}
.rl-opt.wrong{background:color-mix(in srgb,#f87171 18%,transparent);border-color:#f87171}
.rl-opt:disabled{cursor:default}
.rl-combo{font-family:'DM Mono',monospace;font-size:13px;color:var(--cat-practice);height:20px;margin-top:16px}

.rl-end{text-align:center;padding:24px 0}
.rl-record{font-family:'DM Mono',monospace;font-size:13px;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--cat-practice);display:flex;align-items:center;justify-content:center;gap:7px;margin-bottom:8px}
.rl-record svg{filter:drop-shadow(0 0 8px color-mix(in srgb,var(--cat-practice) 60%,transparent))}
.rl-final{font-family:'Spectral',serif;font-weight:700;font-size:72px;line-height:1;
  background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.rl-final-lab{color:var(--muted);font-size:15px;margin:8px 0 2px}
.rl-final-hs{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted-2);margin-bottom:22px}
.rl-end-actions{display:flex;flex-direction:column;gap:10px;align-items:center;margin-top:16px}

/* ============================================================
   v3.6.0 — HOME (the handshake landing) + fun Word of the Day
   ============================================================ */
#homeView{max-width:880px}

/* hero: warm welcome, not a stats wall */
.hm-hero{padding:18px 0 10px}
.hm-greeting{font-family:'DM Mono',monospace;font-size:13px;letter-spacing:0.1em;color:var(--brand-teal);margin-bottom:18px}
.hm-greeting-en{color:var(--muted-2);text-transform:lowercase}
.hm-title{font-family:'Spectral',serif;font-weight:600;font-size:clamp(34px,6vw,56px);line-height:1.04;letter-spacing:-0.025em;
  background:linear-gradient(135deg,var(--ink) 30%,#c4b5fd 72%,var(--brand-teal));-webkit-background-clip:text;background-clip:text;color:transparent;padding-bottom:.06em}
.hm-lede{color:var(--muted);font-size:18px;line-height:1.62;max-width:60ch;margin:20px 0 28px}
.hm-lede em{color:var(--brand-teal);font-style:italic}
.hm-cta-row{display:flex;gap:12px;flex-wrap:wrap}
.hm-cta{background:var(--aurora);color:#fff;border:none;border-radius:13px;padding:16px 30px;
  font-family:'Sora',sans-serif;font-weight:600;font-size:16px;cursor:pointer;transition:.15s;
  box-shadow:0 10px 30px -12px rgba(139,92,246,0.6)}
.hm-cta:hover{transform:translateY(-2px);box-shadow:0 16px 40px -14px rgba(139,92,246,0.7);filter:brightness(1.05)}
.hm-streakline{margin-top:18px;font-size:14px;color:var(--muted-2);display:flex;align-items:center;gap:8px}
.hm-streakline svg{fill:var(--cat-practice);filter:drop-shadow(0 0 6px rgba(224,168,46,0.5));width:18px;height:18px}
.hm-streakline a{color:var(--brand-teal);cursor:pointer;border-bottom:1px dotted}
.hm-streakline.subtle{color:var(--muted)}

/* section scaffolding */
.hm-section-eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:12px}
.hm-wotd-section{margin:44px 0}
.hm-tracks-section{margin:44px 0}
.hm-section-title{font-family:'Spectral',serif;font-weight:600;font-size:26px;margin-bottom:6px}
.hm-section-sub{color:var(--muted);font-size:15px;max-width:60ch;margin-bottom:22px}

/* ---- WORD OF THE DAY: flip-to-reveal card ---- */
.wotd-flip{perspective:1400px;cursor:pointer;max-width:440px}
.wotd-inner{position:relative;width:100%;min-height:230px;transition:transform .7s cubic-bezier(.4,.1,.2,1);transform-style:preserve-3d}
.wotd-flip.flipped .wotd-inner{transform:rotateY(180deg)}
.wotd-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:var(--r-xl);padding:28px 30px;border:1px solid var(--hairline);display:flex;flex-direction:column;overflow:hidden}
.wotd-front{background:
  radial-gradient(340px 160px at 88% -10%,rgba(139,92,246,0.28),transparent 70%),
  radial-gradient(280px 150px at 0% 110%,rgba(45,212,191,0.2),transparent 70%),
  var(--elevated);box-shadow:var(--shadow-card)}
.wotd-front-deco{position:absolute;top:20px;right:22px;color:var(--cat-practice);filter:drop-shadow(0 0 8px rgba(224,168,46,0.5));animation:wotd-twinkle 3s ease-in-out infinite}
@keyframes wotd-twinkle{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.12)}}
.wotd-front-word{font-family:'Spectral',serif;font-weight:600;font-size:42px;letter-spacing:-0.01em;margin-top:auto;
  background:linear-gradient(120deg,var(--ink),#c4b5fd);-webkit-background-clip:text;background-clip:text;color:transparent}
.wotd-front-ipa{font-family:'DM Mono',monospace;color:var(--brand-teal);font-size:15px;margin-top:4px}
.wotd-front-hint{font-size:13px;color:var(--muted-2);margin-top:16px;display:flex;align-items:center;gap:6px}
.wotd-front-hint::before{content:"↻";font-size:15px;color:var(--brand-violet)}
.wotd-back{background:
  radial-gradient(340px 180px at 10% -10%,rgba(45,212,191,0.22),transparent 70%),
  var(--elevated);transform:rotateY(180deg);box-shadow:var(--shadow-card);justify-content:center;padding:26px 30px}
.wotd-back-en{font-family:'Spectral',serif;font-weight:600;font-size:25px;color:var(--ink);line-height:1.2}
.wotd-back-extra{color:var(--muted);font-size:14px;line-height:1.55;margin-top:10px}
.wotd-hear{align-self:flex-start;margin-top:18px;background:transparent;border:1px solid var(--brand-teal);color:var(--brand-teal);
  border-radius:9px;padding:8px 15px;font-family:'Sora',sans-serif;font-size:13px;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;transition:.14s}
.wotd-hear:hover{background:color-mix(in srgb,var(--brand-teal) 16%,transparent)}
.wotd-hear .ic{width:15px;height:15px}
.wotd-back-foot{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted-2);margin-top:16px}
.wotd-why{font-size:13px;color:var(--muted-2);margin-top:16px;max-width:440px;line-height:1.55}
.wotd-why-mark{color:var(--cat-practice)}

/* ---- home track cards ---- */
.hm-tracks{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:740px){.hm-tracks{grid-template-columns:1fr}}
.hm-track{text-align:left;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-lg);
  padding:22px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s;color:var(--ink);
  display:flex;flex-direction:column;gap:8px}
.hm-track:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:color-mix(in srgb,var(--cat) 40%,var(--hairline))}
.hm-track-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb,var(--cat) 16%,transparent);color:var(--cat);margin-bottom:4px}
.hm-track-icon .ic{width:22px;height:22px;stroke-width:2}
.hm-track-name{font-family:'Spectral',serif;font-weight:600;font-size:20px;color:var(--ink)}
.hm-track-blurb{color:var(--muted);font-size:13.5px;line-height:1.5;flex:1}
.hm-track-meta{font-family:'DM Mono',monospace;font-size:12px;color:var(--cat)}

.hm-foot{margin:44px 0 10px;text-align:center;font-family:'Spectral',serif;font-style:italic;font-size:18px;color:var(--muted-2)}

@media(prefers-reduced-motion:reduce){.wotd-inner{transition:none}.wotd-front-deco{animation:none}}

/* past-tense irregular notes */
.irr-en{color:var(--muted);font-weight:400;font-size:14px}
.irr-note{color:var(--muted-2);font-size:13px;margin:4px 0 12px;line-height:1.5}

/* preterite vs imperfect contrast table */
.pi-table{display:flex;flex-direction:column;gap:12px}
.pi-row{display:grid;grid-template-columns:130px 1fr 1fr;gap:14px;align-items:stretch;
  background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:16px 18px}
@media(max-width:680px){.pi-row{grid-template-columns:1fr}}
.pi-use{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:0.04em;color:var(--muted-2);
  display:flex;align-items:center;text-transform:uppercase}
.pi-side{display:flex;flex-direction:column;gap:3px;padding:12px 14px;border-radius:var(--r-sm);position:relative}
.pi-side.pret{background:color-mix(in srgb,var(--brand-violet) 12%,transparent);border:1px solid color-mix(in srgb,var(--brand-violet) 30%,transparent)}
.pi-side.imp{background:color-mix(in srgb,var(--brand-teal) 12%,transparent);border:1px solid color-mix(in srgb,var(--brand-teal) 30%,transparent)}
.pi-tag{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase}
.pi-side.pret .pi-tag{color:var(--brand-violet)}
.pi-side.imp .pi-tag{color:var(--brand-teal)}
.pi-es{font-family:'Spectral',serif;font-size:17px;color:var(--ink)}
.pi-en{font-size:12.5px;color:var(--muted)}
.pi-side .speak{position:absolute;top:10px;right:10px}

/* ============================================================
   PALABRA — daily word puzzle
   ============================================================ */
.pb{max-width:400px;margin:0 auto}
.pb-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.pb-eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--cat-practice)}
.pb-date{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted-2)}
.pb-instr{color:var(--muted);font-size:13.5px;line-height:1.5;margin-bottom:16px}
.pb-msg{text-align:center;min-height:22px;font-family:'DM Mono',monospace;font-size:13px;color:var(--cat-practice);margin-bottom:8px}
.pb-grid{display:grid;grid-template-rows:repeat(6,1fr);gap:7px;margin-bottom:18px}
.pb-row{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.pb-tile{aspect-ratio:1;border:2px solid var(--hairline);border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-family:'Spectral',serif;font-weight:600;font-size:30px;text-transform:uppercase;color:var(--ink);
  transition:transform .12s,background .3s,border-color .3s;background:var(--surface)}
.pb-tile.filled{border-color:var(--muted-2);animation:pbpop .14s}
@keyframes pbpop{50%{transform:scale(1.09)}}
.pb-tile.correct{background:var(--aurora);border-color:transparent;color:#fff}
.pb-tile.present{background:var(--cat-practice);border-color:transparent;color:#0b0b12}
.pb-tile.absent{background:var(--surface-2);border-color:transparent;color:var(--muted-2)}
.pb-keys{display:flex;flex-direction:column;gap:6px}
.pb-krow{display:flex;gap:5px;justify-content:center}
.pb-key{flex:1;max-width:38px;height:52px;border:none;border-radius:8px;background:var(--surface-2);color:var(--ink);
  font-family:'Sora',sans-serif;font-weight:600;font-size:15px;cursor:pointer;transition:.12s;text-transform:uppercase}
.pb-key:hover{background:#2a2a40}
.pb-key.wide{max-width:58px;font-size:10px;text-transform:uppercase;letter-spacing:0.04em}
.pb-key.correct{background:var(--brand-violet);color:#fff}
.pb-key.present{background:var(--cat-practice);color:#0b0b12}
.pb-key.absent{background:#0d0d15;color:var(--muted-2)}

/* result */
.pb-result{margin:4px 0}
.pb-done{text-align:center;padding:8px 0 4px}
.pb-done-head{font-family:'Spectral',serif;font-weight:600;font-size:24px;margin-bottom:12px;
  background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.pb-reveal{display:flex;flex-direction:column;align-items:center;gap:2px;margin-bottom:18px}
.pb-reveal-word{font-family:'Spectral',serif;font-weight:600;font-size:30px;color:var(--ink)}
.pb-reveal-en{color:var(--muted);font-size:15px}
.pb-hear{margin-top:8px;background:transparent;border:1px solid var(--brand-teal);color:var(--brand-teal);
  border-radius:9px;padding:7px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.pb-hear .ic{width:15px;height:15px}
.pb-stats{display:flex;justify-content:center;gap:22px;margin-bottom:18px}
.pb-stat{display:flex;flex-direction:column;gap:2px}
.pb-stat b{font-family:'Spectral',serif;font-weight:600;font-size:26px;color:var(--ink)}
.pb-stat span{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted)}
.pb-share{background:var(--aurora);color:#fff;border:none;border-radius:11px;padding:13px 28px;
  font-family:'Sora',sans-serif;font-weight:600;font-size:15px;cursor:pointer;transition:.14s}
.pb-share:hover{filter:brightness(1.08);transform:translateY(-1px)}
.pb-next{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted-2);margin-top:14px}

/* ============================================================
   ADJECTIVES & AGREEMENT lesson
   ============================================================ */
.adj-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px}
@media(max-width:560px){.adj-grid{grid-template-columns:1fr}}
.adj-cell{background:var(--elevated);border:1px solid var(--hairline);border-radius:var(--r-md);padding:16px 18px;position:relative}
.adj-cell-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--cat-grammar);margin-bottom:8px}
.adj-cell-es{font-family:'Spectral',serif;font-size:21px;color:var(--ink);display:flex;align-items:center;gap:8px}
.adj-cell-en{color:var(--muted);font-size:13px;margin-top:3px}
.adj-inv{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.adj-inv-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:13px 16px}
.adj-inv-es{font-family:'Spectral',serif;font-size:18px;color:var(--ink);min-width:170px}
.adj-inv-en{color:var(--muted);font-size:13.5px;flex:1}
.adj-chips{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:8px}
@media(max-width:620px){.adj-chips{grid-template-columns:1fr 1fr}}
@media(max-width:400px){.adj-chips{grid-template-columns:1fr}}
.adj-chip{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-sm);padding:11px 13px;display:flex;flex-direction:column;gap:2px;position:relative}
.adj-chip-es{font-family:'Spectral',serif;font-size:16px;color:var(--ink);padding-right:28px}
.adj-chip-en{font-size:12.5px;color:var(--muted)}
.adj-chip .speak,.adj-inv-row .speak{margin-left:auto}
.adj-chip .speak{position:absolute;top:9px;right:9px}
