/* Lingeva app styles. Extracted from Lingeva.html as part of the modular architecture migration. */
/* ─── THEME VARIABLES ─────────────────────────────────────────────── */
:root,[data-theme="light"]{
  --bg:#f5f0e8;--surface:#ffffff;--surface2:#f0ece2;--surface3:#e8e3d8;
  --border:#ddd8cc;--border2:#ccc8bc;
  --text:#1a1a16;--text2:#585450;--text3:#9a9690;--text4:#c5c1bb;
  --primary:#1e5c3a;--primary-h:#164828;--primary-lt:#e0f0e6;--primary-dim:#b8ddc8;
  --red:#c03020;--red-lt:#fde8e5;--red-dim:#e88070;
  --gold:#b87800;--gold-lt:#fef3d8;
  --blue:#1a5080;--blue-lt:#dceef8;--blue-dim:#90bcd8;
  --green:#1e7040;--green-lt:#dff0e5;
  --orange:#c85820;--orange-lt:#faeade;
  --purple:#c0392b;--purple-lt:#fdecea;--purple-dim:#e8aca8;
  --shadow:0 2px 12px rgba(0,0,0,.08);
  --shadow-lg:0 12px 48px rgba(0,0,0,.16);
  --r-xs:6px;--r-sm:8px;--r:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;--r-full:9999px;
}
[data-theme="dark"]{
  --bg:#0d1210;--surface:#171f1a;--surface2:#1e2820;--surface3:#252e26;
  --border:#2a3830;--border2:#34423a;
  --text:#e2dfd6;--text2:#7a8878;--text3:#445040;--text4:#2a3830;
  --primary:#4cb870;--primary-h:#60cc80;--primary-lt:#0c2016;--primary-dim:#1a4028;
  --red:#e06050;--red-lt:#280e0a;--red-dim:#a04030;
  --gold:#e0a830;--gold-lt:#281c04;
  --blue:#5a9ad0;--blue-lt:#081a2c;--blue-dim:#1a3c58;
  --green:#5acc7a;--green-lt:#082014;
  --orange:#e07840;--orange-lt:#281408;
  --purple:#e05555;--purple-lt:#2a0d0d;--purple-dim:#7a2828;
  --shadow:0 2px 12px rgba(0,0,0,.4);
  --shadow-lg:0 12px 48px rgba(0,0,0,.7);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased}
body{background:#060806;display:flex;align-items:center;justify-content:center}
#app{
  width:390px;height:844px;max-height:100dvh;max-width:100vw;
  background:var(--bg);border-radius:44px;overflow:hidden;
  display:flex;flex-direction:column;position:relative;color:var(--text);
  box-shadow:0 0 0 1px rgba(255,255,255,.06),var(--shadow-lg);
}
@media(max-width:420px){body{background:var(--bg)}#app{width:100vw;height:100dvh;border-radius:0}}

/* ─── TOP HEADER ──────────────────────────────────────────────────── */
#top-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px 10px;background:var(--surface);
  border-bottom:1px solid var(--border);flex-shrink:0;z-index:10;
}
.logo-wrap{display:flex;align-items:center;gap:9px}
.dm-brand-button{
  appearance:none;background:none;border:0;padding:0;margin:0;color:inherit;
  display:flex;align-items:center;gap:9px;text-align:left;cursor:pointer;
}
.dm-brand-button:focus-visible{outline:2px solid var(--primary);outline-offset:4px;border-radius:var(--r-sm)}
.logo-mark{
  width:32px;height:32px;border-radius:9px;background:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',Georgia,serif;font-size:17px;color:#fff;
  flex-shrink:0;
}
.logo-name{font-family:'DM Serif Display',Georgia,serif;font-size:17px;color:var(--text)}
.logo-tag{font-size:10px;color:var(--text3);letter-spacing:.02em}
.hdr-actions{display:flex;gap:6px}
.icon-btn{
  width:34px;height:34px;border-radius:var(--r-sm);
  background:none;border:1px solid var(--border);
  cursor:pointer;color:var(--text2);display:flex;align-items:center;
  justify-content:center;font-size:15px;transition:background .15s,border-color .15s;
}
.icon-btn:hover{background:var(--surface2);border-color:var(--border2)}
.hdr-actions .icon-btn{min-width:var(--dm-tap-min);min-height:var(--dm-tap-min)}

/* ─── SCREEN CONTAINER ────────────────────────────────────────────── */
#screen-wrap{flex:1;overflow:hidden;position:relative}
.screen{position:absolute;inset:0;overflow-y:auto;display:none;flex-direction:column}
.screen.active{display:flex}

/* ─── BOTTOM TAB BAR ──────────────────────────────────────────────── */
#tab-bar{
  flex-shrink:0;background:var(--surface);border-top:1px solid var(--border);
  display:flex;padding:6px 8px max(10px,env(safe-area-inset-bottom));
}
.tab-item{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  background:none;border:none;cursor:pointer;
  color:var(--text3);font-size:10px;font-weight:600;
  padding:5px 2px;border-radius:var(--r-sm);transition:color .15s;
  font-family:inherit;
}
.tab-item svg{width:20px;height:20px;stroke-width:2}
.tab-item.active{color:var(--primary)}
.tab-item .tab-dot{
  width:4px;height:4px;border-radius:50%;background:var(--primary);
  opacity:0;transition:opacity .2s;margin-top:1px;
}
.tab-item.active .tab-dot{opacity:1}
#app.dm-shell--immersive #tab-bar{display:none}

/* ─── HOME SCREEN ─────────────────────────────────────────────────── */
.home-hero{
  background:linear-gradient(135deg,var(--primary) 0%,#2a7a50 100%);
  padding:20px 20px 24px;color:#fff;flex-shrink:0;
}
.hero-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.75;margin-bottom:6px}
.hero-title{font-family:'DM Serif Display',Georgia,serif;font-size:26px;line-height:1.2;margin-bottom:4px}
.hero-title em{font-style:italic;opacity:.9}
.hero-sub{font-size:13px;opacity:.8;margin-bottom:16px;line-height:1.5}
.hero-stats{display:flex;gap:16px}
.hstat{text-align:center}
.hstat-num{font-family:'DM Serif Display',serif;font-size:22px;font-weight:700}
.hstat-lbl{font-size:10px;opacity:.7;font-weight:600;text-transform:uppercase;letter-spacing:.05em}

.home-body{padding:16px;flex:1}

/* Search */
.search-wrap{position:relative;margin-bottom:14px}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;color:var(--text3)}
.search-wrap #search-input{
  width:100%;background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r-full);padding:10px 14px 10px 36px;
  font-size:14px;color:var(--text);font-family:inherit;transition:border-color .15s;
}
.search-wrap #search-input:focus{outline:none;border-color:var(--primary)}
.search-wrap #search-input::placeholder{color:var(--text3)}
.home-body > .dm-search{margin-bottom:14px}

/* Level pills */
.level-pills{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}
.level-pills::-webkit-scrollbar{display:none}
.level-pill{
  flex-shrink:0;padding:6px 14px;border-radius:var(--r-full);
  border:1.5px solid var(--border);background:var(--surface);
  font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;
  color:var(--text2);font-family:inherit;min-height:var(--dm-tap-min);
}
.level-pill:hover{border-color:var(--primary);color:var(--primary)}
.level-pill.active{background:var(--primary);border-color:var(--primary);color:#fff}
.level-pill.pill-a1.active{background:#1e7040;border-color:#1e7040}
.level-pill.pill-a2.active{background:#b87800;border-color:#b87800}
.level-pill.pill-b1.active{background:var(--orange);border-color:var(--orange)}

/* Category section headers */
.cat-section{margin-bottom:6px}
.cat-header{
  display:flex;align-items:center;gap:8px;
  padding:8px 0 8px;cursor:pointer;user-select:none;
}
.cat-icon{font-size:16px;width:28px;text-align:center}
.cat-title-wrap{flex:1}
.cat-name{font-size:13px;font-weight:700;color:var(--text)}
.cat-meta{font-size:11px;color:var(--text3)}
.cat-chevron{font-size:12px;color:var(--text3);transition:transform .2s}
.cat-section.open .cat-chevron{transform:rotate(90deg)}
.cat-scenarios{display:none;flex-direction:column;gap:4px;padding-bottom:8px}
.cat-section.open .cat-scenarios{display:flex}

/* Scenario rows */
.sc-row{
  display:flex;align-items:center;gap:10px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:11px 14px;cursor:pointer;
  transition:all .15s;
}
.sc-row:hover{border-color:var(--primary);box-shadow:var(--shadow)}
.sc-num{
  width:26px;height:26px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;flex-shrink:0;
}
.sc-num.a1{background:var(--green-lt);color:var(--green)}
.sc-num.a2{background:var(--gold-lt);color:var(--gold)}
.sc-num.b1{background:var(--orange-lt);color:var(--orange)}
.sc-text{flex:1;min-width:0}
.sc-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-persona{font-size:11px;color:var(--text3)}
.sc-arrow{font-size:14px;color:var(--text3);flex-shrink:0}

.home-section-title{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  color:var(--text3);margin:18px 2px 10px;
}
.home-dashboard{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}
.home-mission-card,.home-dash-card,.home-continue-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:14px;box-shadow:var(--shadow);color:var(--text);
}
.home-mission-card{
  background:linear-gradient(180deg,var(--surface),var(--surface2));
  border-color:var(--primary);
}
.home-mission-card h2{
  font-family:'DM Serif Display',Georgia,serif;font-size:22px;line-height:1.22;margin:2px 0 8px;
}
.home-mission-card p{font-size:13px;line-height:1.48;color:var(--text2);margin:6px 0}
.home-dash-actions,.home-dash-card .home-dash-btn{margin-top:10px}
.home-dash-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.home-dash-btn{
  border:0;border-radius:var(--r);background:var(--primary);color:#fff;
  padding:10px 12px;font:inherit;font-size:12px;font-weight:800;cursor:pointer;
}
.home-dash-btn.secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text2)}
.home-dash-grid,.home-continue-grid{display:grid;grid-template-columns:1fr;gap:9px}
.home-continue-card{text-align:left;cursor:pointer;font-family:inherit}
.home-continue-card span,.home-dash-label{
  display:block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:5px;
}
.home-continue-card strong,.home-dash-title{display:block;font-size:14px;font-weight:800;color:var(--text);margin-bottom:4px}
.home-continue-card small,.home-dash-copy,.home-dash-meta{display:block;font-size:12px;color:var(--text2);line-height:1.45}
.home-dash-meta{margin-top:8px;color:var(--primary);font-weight:700}

/* Phase 05 Home coach dashboard */
.dm-home-dashboard{
  display:flex;flex-direction:column;gap:14px;
  max-width:720px;margin:0 auto 22px;
}
.dm-home-band{display:flex;flex-direction:column;gap:8px}
.dm-home-band__eyebrow,.dm-home-kicker{
  font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);
}
.dm-home-kicker small{
  display:block;margin-top:2px;color:var(--text3);letter-spacing:.08em;
}
.dm-home-band__head h2{
  font-family:'DM Serif Display',Georgia,serif;font-size:22px;line-height:1.1;margin:0;color:var(--text);
}
.dm-home-mission-card,.dm-home-recommended-card,.dm-home-grammar-card,.dm-home-continue-card,.dm-home-triage-card,.dm-goal-picker{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--dm-shadow-card);color:var(--text);
}
.dm-home-mission-card{
  padding:18px;background:linear-gradient(180deg,var(--surface),var(--surface2));
  border-color:color-mix(in srgb,var(--primary) 60%,var(--border));
}
.dm-home-mission-card__top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.dm-home-reroll{
  min-height:36px;border:1px solid var(--border);border-radius:var(--r-full);
  background:var(--surface2);color:var(--text2);padding:0 12px;font:inherit;font-size:12px;font-weight:800;cursor:pointer;
}
.dm-home-mission-card h2{
  font-family:'DM Serif Display',Georgia,serif;font-size:30px;line-height:1.05;margin:8px 0;color:var(--text);
}
.dm-home-mission-card p,.dm-home-recommended-card p,.dm-home-grammar-card p{
  margin:0;color:var(--text2);font-size:13px;line-height:1.5;
}
.dm-home-mission-meta{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.dm-home-mission-meta span,.dm-home-card-meta{
  display:inline-flex;align-items:center;min-height:28px;border-radius:var(--r-full);
  background:var(--surface2);border:1px solid var(--border);padding:0 10px;
  font-size:11px;font-weight:800;color:var(--text2);
}
.dm-home-mini-brief{display:grid;gap:8px;margin:12px 0}
.dm-home-mini-brief div{border:1px solid var(--border);border-radius:var(--r);padding:10px;background:var(--surface)}
.dm-home-mini-brief strong{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:4px}
.dm-home-mini-brief span{display:block;font-size:13px;color:var(--text)}
.dm-home-wide-btn{width:100%;min-height:var(--dm-tap-min)}
.dm-home-continue-card,.dm-home-triage-card{
  width:100%;text-align:left;padding:14px;font:inherit;cursor:pointer;min-height:var(--dm-tap-min);
}
.dm-home-continue-card span,.dm-home-triage-card span{
  display:block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:5px;
}
.dm-home-continue-card strong,.dm-home-triage-card strong{
  display:block;font-size:15px;color:var(--text);margin-bottom:4px;
}
.dm-home-continue-card small,.dm-home-triage-card small{
  display:block;font-size:12px;line-height:1.4;color:var(--text2);
}
.dm-home-triage-row{display:grid;grid-template-columns:1fr;gap:9px}
.dm-home-recommended-card,.dm-home-grammar-card{padding:15px;display:flex;flex-direction:column;gap:10px}
.dm-home-recommended-card h3,.dm-home-grammar-card h3{
  font-family:'DM Serif Display',Georgia,serif;font-size:23px;line-height:1.12;margin:0;color:var(--text);
}
.dm-home-mastery-line{display:flex;align-items:center;gap:8px;color:var(--text2);font-size:12px;font-weight:700}
.dm-goal-picker{max-width:720px;margin:0 auto 22px;padding:20px}
.dm-goal-picker__top{
  align-items:center;
  display:flex;
  gap:12px;
  justify-content:space-between;
  margin-bottom:12px;
}
.dm-goal-picker h1{
  font-family:'DM Serif Display',Georgia,serif;font-size:32px;line-height:1.05;margin:8px 0;color:var(--text);
}
.dm-goal-picker p{font-size:14px;line-height:1.5;color:var(--text2);margin:0 0 16px}
.dm-goal-picker__grid{display:grid;gap:10px}
.dm-goal-card{
  min-height:var(--dm-tap-min);text-align:left;border:1px solid var(--border);border-radius:var(--r);
  background:var(--surface2);color:var(--text);padding:14px;font:inherit;cursor:pointer;
}
.dm-goal-card span{display:block;font-size:17px;font-weight:900;margin-bottom:4px}
.dm-goal-card small{display:block;color:var(--text2);line-height:1.45;margin-bottom:10px}
.dm-goal-card strong{display:block;color:var(--primary);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.dm-goal-card:hover,.dm-home-triage-card:hover,.dm-home-continue-card:hover,.dm-home-reroll:hover{
  border-color:var(--primary);box-shadow:var(--shadow);
}

.scenarios-body{display:flex;flex-direction:column;gap:12px}
.scenarios-hero{
  background:linear-gradient(135deg,var(--primary) 0%,#2a7a50 100%);
  border-radius:var(--r-lg);padding:18px;color:#fff;box-shadow:var(--shadow);
}
.scenarios-hero h1{font-family:'DM Serif Display',Georgia,serif;font-size:30px;line-height:1;margin:4px 0 8px}
.scenarios-hero p{font-size:13px;line-height:1.45;opacity:.92}
.scenario-context-pills{padding-top:0}
.dm-header-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.44);z-index:80}
.dm-account-drawer,.dm-dictionary-overlay{
  position:fixed;z-index:81;background:var(--surface);border:1px solid var(--border);
  box-shadow:0 18px 70px rgba(0,0,0,.35);color:var(--text);
}
.dm-account-drawer{
  top:0;right:0;height:100%;width:min(360px,92vw);padding:18px;
  display:flex;flex-direction:column;gap:14px;
}
.dm-account-head,.dm-dictionary-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.dm-account-head h2,.dm-dictionary-head h2{font-family:'DM Serif Display',Georgia,serif;font-size:28px;margin:2px 0 4px}
.dm-account-head p{font-size:12px;color:var(--text2)}
.dm-account-section{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border);padding-top:12px}
.dm-account-row,.dm-dictionary-result{
  width:100%;min-height:46px;text-align:left;border:1px solid var(--border);
  border-radius:var(--r-sm);background:var(--surface2);color:var(--text);
  padding:10px 12px;display:flex;flex-direction:column;gap:3px;cursor:pointer;
  font-family:inherit;
}
.dm-account-row:hover,.dm-dictionary-result:hover,.dm-dictionary-result.active{border-color:var(--primary)}
.dm-account-row small,.dm-dictionary-result span{font-size:12px;color:var(--text2)}
.dm-dictionary-overlay{
  background:var(--dm-surface);
  border:1px solid var(--dm-line);
  border-radius:24px;
  box-shadow:var(--dm-shadow-modal);
  color:var(--dm-ink);
  display:flex;
  flex-direction:column;
  gap:14px;
  height:min(720px, calc(var(--dm-dictionary-vh, 100vh) - 96px));
  left:50%;
  max-height:min(720px, calc(var(--dm-dictionary-vh, 100vh) - 96px));
  overflow:hidden;
  padding:18px;
  top:70px;
  transform:translateX(-50%);
  width:min(580px, calc(100vw - 32px));
}
.dm-dictionary-head{
  align-items:center;
  flex:0 0 auto;
}
.dm-dictionary-head h2{
  color:var(--dm-ink);
  font:400 30px/1.08 var(--dm-font-serif);
  margin:2px 0 0;
}
.dm-dictionary-close{
  align-items:center;
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:999px;
  color:var(--dm-ink-2);
  display:flex;
  flex:0 0 auto;
  font:600 22px/1 var(--dm-font-sans);
  height:44px;
  justify-content:center;
  padding:0;
  width:44px;
}
.dm-dictionary-close:hover,.dm-dictionary-close:focus-visible{
  border-color:var(--dm-brass);
  box-shadow:var(--dm-focus-ring);
  color:var(--dm-ink);
  outline:0;
}
.dm-dictionary-search{
  background:var(--dm-surface-sunken);
  border:1.5px solid var(--dm-line-2);
  border-radius:18px;
  box-shadow:0 8px 24px rgba(60,45,25,.07);
  flex:0 0 auto;
  margin:0;
  min-height:54px;
}
.dm-dictionary-search:focus-within{
  border-color:var(--dm-brass);
  box-shadow:0 0 0 3px rgba(196,146,74,.18),0 10px 28px rgba(60,45,25,.08);
}
.dm-dictionary-search .dm-search-icon{
  color:var(--dm-ink-3);
  flex:0 0 auto;
  height:21px;
  width:21px;
}
.dm-dictionary-search .dm-search-input{
  color:var(--dm-ink);
  font:500 16px/1.25 var(--dm-font-sans);
  min-height:50px;
  padding:12px 8px 12px 10px;
}
.dm-dictionary-body{
  display:flex;
  flex:1 1 auto;
  min-height:0;
  overflow:hidden;
}
.dm-dictionary-view{
  display:flex;
  flex:1 1 auto;
  min-height:0;
  width:100%;
}
.dm-dictionary-view--search,
.dm-dictionary-view--detail{
  flex-direction:column;
  gap:10px;
}
.dm-dictionary-results{
  display:flex;
  flex:1 1 auto;
  flex-direction:column;
  gap:10px;
  min-height:0;
  overflow:auto;
  overscroll-behavior:contain;
  padding:2px 4px 6px 2px;
  -webkit-overflow-scrolling:touch;
}
.dm-dictionary-overlay .dm-dictionary-result{
  background:var(--dm-surface-raised);
  border:1px solid var(--dm-line);
  border-radius:16px;
  box-shadow:var(--dm-shadow-soft);
  color:var(--dm-ink);
  display:flex;
  flex-direction:column;
  gap:5px;
  min-height:70px;
  padding:12px 14px;
  transition:background var(--dm-d-fast) var(--dm-ease-default),border-color var(--dm-d-fast) var(--dm-ease-default),box-shadow var(--dm-d-fast) var(--dm-ease-default),transform var(--dm-d-fast) var(--dm-ease-default);
}
.dm-dictionary-overlay .dm-dictionary-result:hover,
.dm-dictionary-overlay .dm-dictionary-result:focus-visible,
.dm-dictionary-overlay .dm-dictionary-result.active{
  background:#fffdf8;
  border-color:var(--dm-brass);
  box-shadow:0 8px 22px rgba(60,45,25,.10);
  outline:0;
}
.dm-dictionary-overlay .dm-dictionary-result:active{transform:scale(.995)}
.dm-dictionary-overlay .dm-dictionary-result strong{
  color:var(--dm-ink);
  font:700 17px/1.25 var(--dm-font-sans);
  overflow-wrap:anywhere;
}
.dm-dictionary-overlay .dm-dictionary-result span{
  color:var(--dm-ink-2);
  font:400 13px/1.35 var(--dm-font-sans);
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
  overflow-wrap:anywhere;
}
.dm-dictionary-overlay .dm-dictionary-result small{
  color:var(--dm-ink-3);
  font:700 11px/1.2 var(--dm-font-sans);
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:1;
  overflow:hidden;
  overflow-wrap:anywhere;
}
.dm-dictionary-empty{
  background:var(--dm-surface-sunken);
  border:1px dashed var(--dm-line-2);
  border-radius:16px;
  color:var(--dm-ink-2);
  font:400 13px/1.45 var(--dm-font-sans);
  padding:12px 14px;
}
.dm-dictionary-empty--quiet{
  background:transparent;
  border-color:var(--dm-line);
  color:var(--dm-ink-3);
  padding:10px 12px;
}
.dm-dictionary-detail{
  display:flex;
  flex:1 1 auto;
  flex-direction:column;
  gap:10px;
  min-height:0;
  overflow:auto;
  overscroll-behavior:contain;
  padding:0 4px 6px 2px;
  -webkit-overflow-scrolling:touch;
}
.dm-dictionary-back{
  align-items:center;
  align-self:flex-start;
  background:transparent;
  border:0;
  border-radius:999px;
  color:var(--dm-brass-strong);
  display:inline-flex;
  font:800 13px/1 var(--dm-font-sans);
  min-height:38px;
  padding:0 4px;
}
.dm-dictionary-back:focus-visible{
  box-shadow:var(--dm-focus-ring);
  outline:0;
}
.dm-dictionary-overlay-detail{
  background:var(--dm-surface-raised);
  border:1px solid var(--dm-line);
  border-radius:20px;
  box-shadow:var(--dm-shadow-card);
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:16px;
}
.dm-dictionary-detail-head{display:flex;flex-direction:column;gap:5px}
.dm-dictionary-detail-head strong{
  color:var(--dm-ink);
  font:700 21px/1.18 var(--dm-font-sans);
  overflow-wrap:anywhere;
}
.dm-dictionary-detail-head span,.dm-dictionary-muted{
  color:var(--dm-ink-2);
  font:400 13px/1.45 var(--dm-font-sans);
}
.dm-dictionary-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.dm-dictionary-detail-grid div{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:14px;
  min-width:0;
  padding:10px 11px;
}
.dm-dictionary-detail-grid small,.dm-dictionary-detail-block small{
  color:var(--dm-ink-3);
  display:block;
  font:700 10px/1.3 var(--dm-font-sans);
  margin-bottom:4px;
  text-transform:uppercase;
}
.dm-dictionary-detail-grid span,.dm-dictionary-detail-block p{
  color:var(--dm-ink);
  font:400 13px/1.48 var(--dm-font-sans);
  overflow-wrap:anywhere;
}
.dm-dictionary-detail-block{display:flex;flex-direction:column;gap:7px}
.dm-dictionary-detail-block p{margin:0}
.dm-dictionary-overlay-chips{display:flex;flex-wrap:wrap;gap:7px}
.dm-dictionary-overlay-chips span{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:999px;
  color:var(--dm-ink);
  font:700 12px/1 var(--dm-font-sans);
  padding:7px 10px;
}
@supports (height: 100dvh){
  .dm-dictionary-overlay{
    height:min(720px, calc(var(--dm-dictionary-vh, 100dvh) - 96px));
    max-height:min(720px, calc(var(--dm-dictionary-vh, 100dvh) - 96px));
  }
}
@media (max-width:520px){
  .dm-dictionary-overlay{
    border-radius:24px 24px 0 0;
    bottom:max(8px, env(safe-area-inset-bottom));
    height:min(82vh, calc(var(--dm-dictionary-vh, 100vh) - 18px));
    left:10px;
    max-height:calc(var(--dm-dictionary-vh, 100vh) - 18px);
    padding:16px;
    top:auto;
    transform:none;
    width:calc(100vw - 20px);
  }
  .dm-dictionary-head h2{font-size:28px}
  .dm-dictionary-search .dm-search-input{font-size:15px}
  .dm-dictionary-detail-grid{grid-template-columns:1fr}
}
@supports (height: 100dvh){
  @media (max-width:520px){
    .dm-dictionary-overlay{
      height:min(82dvh, calc(var(--dm-dictionary-vh, 100dvh) - 18px));
      max-height:calc(var(--dm-dictionary-vh, 100dvh) - 18px);
    }
  }
}
@media (min-width:520px){
  .home-dash-grid,.home-continue-grid{grid-template-columns:1fr 1fr}
}

/* ─── PRACTICE SCREEN ─────────────────────────────────────────────── */
.practice-inner{flex:1;overflow:hidden;display:flex;flex-direction:column;font-family:inherit}
.practice-inner,.practice-inner *{font-family:inherit}
.practice-inner .practice-hub-hero h2,.practice-inner .prep-title,.practice-inner .sc-title,.practice-inner .sc-stat-num{font-family:'DM Serif Display',Georgia,serif}
.practice-inner button,.practice-inner input,.practice-inner textarea{font-family:inherit}
.practice-hub{height:100%;overflow-y:auto;background:var(--bg);font-family:inherit}
.practice-hub-hero{padding:18px 20px 20px;background:linear-gradient(135deg,var(--primary) 0%,#1d6b62 100%);color:#fff}
.practice-hub-hero h2{font-family:'DM Serif Display',Georgia,serif;font-size:26px;line-height:1.2;margin:2px 0 6px}
.practice-hub-hero p{font-size:13px;opacity:.82;line-height:1.45;max-width:310px}
.practice-hub-body{padding:14px 14px 24px}
.practice-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin:16px 2px 9px}
.practice-continue-card,.practice-mode-card,.persona-card,.challenge-card,.pron-card,.practice-settings-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:13px;box-shadow:var(--shadow);
  color:var(--text);font-family:inherit;text-align:left;
}
.practice-continue-card{display:flex;align-items:center;gap:12px;cursor:pointer}
.practice-continue-icon,.practice-mode-icon,.persona-avatar-sm,.challenge-icon,.pron-icon{
  width:38px;height:38px;border-radius:var(--r);background:var(--primary-lt);color:var(--primary);
  display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;
}
.practice-card-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
.practice-card-sub{font-size:12px;color:var(--text2);line-height:1.4}
.practice-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.practice-mode-card{cursor:pointer;min-height:112px;display:flex;flex-direction:column;gap:9px}
.practice-mode-card:hover,.persona-card:hover,.challenge-card:hover,.pron-card:hover{border-color:var(--primary)}
.persona-grid,.challenge-grid,.pron-grid{display:flex;gap:9px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.persona-grid::-webkit-scrollbar,.challenge-grid::-webkit-scrollbar,.pron-grid::-webkit-scrollbar{display:none}
.persona-card{width:218px;flex:0 0 218px;cursor:pointer}
.persona-card.active{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary-dim),var(--shadow)}
.persona-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.persona-name{font-size:14px;font-weight:700;color:var(--text)}
.persona-style{font-size:11px;color:var(--text3);font-weight:700;text-transform:uppercase}
.persona-tags,.topic-chip-row,.practice-badge-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.practice-chip,.topic-chip,.practice-badge{
  border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:var(--r-full);
  padding:5px 9px;font-size:11px;font-weight:700;font-family:inherit;
}
.topic-chip{cursor:pointer}
.topic-chip.active,.practice-chip.active{background:var(--primary);border-color:var(--primary);color:white}
.challenge-card,.pron-card{width:210px;flex:0 0 210px;cursor:pointer}
.challenge-card .practice-card-title,.pron-card .practice-card-title{margin-top:8px}
.practice-settings-card{margin-top:10px}
.setting-row{margin-bottom:12px}
.setting-label{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;margin-bottom:7px}
.setting-pills{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}
.setting-pills button{
  border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:var(--r-full);
  padding:7px 10px;font-size:11px;font-weight:700;font-family:inherit;white-space:nowrap;
}
.setting-pills button.active{background:var(--primary);border-color:var(--primary);color:white}
.practice-topic-input{width:100%;border:1px solid var(--border);background:var(--surface2);color:var(--text);border-radius:var(--r);padding:10px 12px;font-family:inherit;font-size:13px}
.practice-primary-btn,.practice-secondary-btn{
  width:100%;border:none;border-radius:var(--r);padding:12px 14px;font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;
}
.practice-primary-btn{background:var(--primary);color:white}
.practice-secondary-btn{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.practice-session{height:100%;display:flex;flex-direction:column;background:var(--bg)}
.practice-session-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}
.practice-session-back{border:none;background:var(--surface2);color:var(--text2);border-radius:var(--r-sm);width:32px;height:32px;font-size:16px;cursor:pointer}
.practice-session-avatar{width:38px;height:38px;border-radius:var(--r);background:var(--primary-lt);display:flex;align-items:center;justify-content:center;font-size:20px}
.practice-session-name{font-size:14px;font-weight:700}
.practice-session-meta{font-size:11px;color:var(--text3);line-height:1.4}
.practice-session-timer{margin-left:auto;text-align:right;font-size:11px;color:var(--text3);font-weight:700}
.practice-chat{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.practice-bubble{max-width:84%;border-radius:var(--r-lg);padding:10px 12px;font-size:13px;line-height:1.48;position:relative}
.practice-bubble.ai{align-self:flex-start;background:var(--surface);border:1px solid var(--border)}
.practice-bubble.user{align-self:flex-end;background:var(--primary);color:white}
.practice-bubble .bubble-meta{font-size:10px;opacity:.65;margin-top:5px}
.practice-inline-tip{margin-top:8px;background:var(--gold-lt);border:1px solid var(--gold);color:var(--text2);border-radius:var(--r);padding:8px;font-size:12px}
.practice-input-panel{flex-shrink:0;background:var(--surface);border-top:1px solid var(--border);padding:10px 12px max(12px,env(safe-area-inset-bottom))}
.practice-quick-row{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px}
.practice-quick-row button{border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:var(--r-full);padding:6px 10px;font-size:11px;font-weight:700;white-space:nowrap}
.practice-input-row{display:flex;gap:8px;align-items:center}
.practice-input-row input{flex:1;border:1px solid var(--border);background:var(--surface2);color:var(--text);border-radius:var(--r-full);padding:11px 13px;font-family:inherit}
.practice-input-row .practice-primary-btn,.practice-input-row .practice-secondary-btn{width:auto;white-space:nowrap}
.practice-round-btn{width:42px;height:42px;border-radius:50%;border:none;background:var(--primary);color:white;font-weight:700;font-size:16px;cursor:pointer}
.practice-round-btn.recording{background:var(--red);animation:pulse 1s infinite}
.practice-round-btn:disabled,.practice-primary-btn:disabled,.practice-secondary-btn:disabled{opacity:.55;cursor:not-allowed}
.practice-round-btn.secondary{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.pronunciation-screen{height:100%;overflow-y:auto;padding:14px;background:var(--bg)}
.pronunciation-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow);text-align:center}
.pron-target{font-size:22px;font-weight:700;line-height:1.35;margin:14px 0;color:var(--text)}
.pron-translation{font-size:13px;color:var(--text2);line-height:1.4}
.pron-controls{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:14px 0}
.pron-wave{height:42px;border-radius:var(--r);background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:12px;font-weight:700;margin:12px 0}
.pron-wave:not(.recording){display:none}
.pron-wave.recording{background:var(--red-lt);color:var(--red);border-color:var(--red-dim);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.65}}
.pron-score-wrap{display:flex;align-items:center;gap:12px;text-align:left;margin-top:12px}
.pron-score-ring{width:72px;height:72px;border-radius:50%;background:conic-gradient(var(--primary) calc(var(--score,0)*1%),var(--surface2) 0);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--text);flex-shrink:0}
.pron-feedback{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:10px;text-align:left;font-size:12px;color:var(--text2);line-height:1.45}
.sound-chip{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--border);background:var(--surface2);border-radius:var(--r-full);padding:4px 8px;font-size:11px;font-weight:700;margin:3px;color:var(--text2)}
.pron-provider-badge{display:inline-flex;align-items:center;gap:6px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface2);color:var(--text2);font-size:10px;font-weight:700;letter-spacing:.2px;text-transform:uppercase;padding:5px 8px;margin-top:8px}
.pron-provider-badge.pro{border-color:var(--green-dim);background:var(--green-lt);color:var(--green)}
.pron-provider-badge.fallback{border-color:var(--gold);background:var(--gold-lt);color:var(--gold)}
.pron-breakdown{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:12px 0;text-align:left}
.pron-metric{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:9px}
.pron-metric-label{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text3);letter-spacing:.2px}
.pron-metric-value{font-size:18px;font-weight:700;color:var(--text);margin-top:3px}
.pron-section-title{font-size:12px;font-weight:700;color:var(--text);text-align:left;margin:14px 0 8px}
.pron-word-grid{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0 12px}
.pron-word-token{border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:var(--r-full);padding:6px 9px;font-size:12px;font-weight:700;cursor:pointer}
.pron-word-token.good{border-color:var(--green-dim);background:var(--green-lt);color:var(--green)}
.pron-word-token.warn{border-color:var(--gold);background:var(--gold-lt);color:var(--gold)}
.pron-word-token.bad{border-color:var(--red-dim);background:var(--red-lt);color:var(--red)}
.pron-word-detail,.pron-sound-card,.pron-drill-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:10px;text-align:left;font-size:12px;color:var(--text2);line-height:1.45;margin-top:8px}
.pron-sound-card strong,.pron-drill-card strong{color:var(--text)}
.pron-drill-items{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px}
.pron-drill-items span{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-full);padding:4px 8px;color:var(--text2);font-weight:700}
.pron-warning{border-color:var(--gold);background:var(--gold-lt);color:var(--text)}
.pron-wave span{width:4px;height:10px;border-radius:4px;background:currentColor;margin:0 2px;opacity:.45}
.pron-wave.recording span:nth-child(1){animation:waveBar .8s infinite ease-in-out}
.pron-wave.recording span:nth-child(2){animation:waveBar .8s .1s infinite ease-in-out}
.pron-wave.recording span:nth-child(3){animation:waveBar .8s .2s infinite ease-in-out}
.pron-wave.recording span:nth-child(4){animation:waveBar .8s .3s infinite ease-in-out}
.pron-wave.recording span:nth-child(5){animation:waveBar .8s .4s infinite ease-in-out}
@keyframes waveBar{0%,100%{height:8px}50%{height:26px}}
.dm-practice-clean .practice-hub-body{display:flex;flex-direction:column;gap:12px}
.dm-practice-panel,.dm-speaking-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;box-shadow:var(--shadow-sm)}
.dm-practice-panel.primary{border-color:var(--primary);background:linear-gradient(180deg,var(--surface),var(--surface2))}
.dm-practice-mode-selector{display:flex;gap:8px;overflow-x:auto;padding:2px 0 8px}
.dm-practice-mode-pill{border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:var(--r-full);padding:9px 12px;font-size:12px;font-weight:800;white-space:nowrap;cursor:pointer}
.dm-practice-mode-pill.active{background:var(--primary);border-color:var(--primary);color:#fff}
.dm-sentence-filters{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:8px 0 12px}
.dm-sentence-filters label{display:flex;flex-direction:column;gap:5px;color:var(--text2);font-size:11px;font-weight:800}
.dm-sentence-filters select,.dm-sentence-filters input{width:100%;border:1px solid var(--border);background:var(--surface2);color:var(--text);border-radius:var(--r);padding:9px 10px;font:inherit;font-size:12px}
.dm-progress-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:10px 0 12px}
.dm-progress-bar{height:6px;border-radius:var(--r-full);background:var(--surface2);overflow:hidden;margin-top:7px}
.dm-progress-bar span{display:block;height:100%;border-radius:inherit;background:var(--primary)}
.dm-practice-flow-card{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.dm-focus-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dm-secondary-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.dm-step-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin:12px 0}
.dm-step-row span{border:1px solid var(--border);background:var(--surface2);border-radius:var(--r);padding:8px 6px;text-align:center;color:var(--text2);font-size:11px;font-weight:800}
.dm-current-task{margin:10px 0 12px}
.dm-current-task .pron-target{
  font-size:20px;
  line-height:1.18;
  margin:8px 0 8px;
}
.dm-current-task.is-medium .pron-target{
  font-size:17px;
  line-height:1.18;
}
.dm-current-task.is-long .pron-target{
  font-size:15.5px;
  line-height:1.16;
  max-height:min(28vh,220px);
  overflow-y:auto;
  padding-right:6px;
}
.dm-current-task.is-medium .pron-translation,
.dm-current-task.is-long .pron-translation{
  font-size:12px;
  line-height:1.32;
}
.dm-current-task.is-long .pron-feedback{
  font-size:11px;
  line-height:1.35;
  padding:9px;
}
.dm-speaking-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:12px 0}
.dm-speaking-actions.compact{grid-template-columns:repeat(3,minmax(0,1fr))}
.dm-hold-speak-btn{width:100%;min-height:86px;border:0;border-radius:var(--r-lg);background:var(--primary);color:#fff;font:inherit;font-weight:900;font-size:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 8px 22px rgba(76,184,112,.28);cursor:pointer;touch-action:none;user-select:none;margin:10px 0 12px}
.dm-hold-speak-btn small{font-size:11px;opacity:.78;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.dm-hold-speak-btn.recording{background:var(--red);box-shadow:0 8px 26px rgba(224,96,80,.38);animation:mic-pulse 1.1s ease-in-out infinite}
.dm-hold-speak-btn.sending{background:var(--gold);box-shadow:0 8px 22px rgba(224,168,48,.25);cursor:wait}
.dm-hold-speak-btn:disabled{opacity:.68;cursor:not-allowed;animation:none}
.dm-speaking-status{display:flex;align-items:center;gap:8px;justify-content:space-between;border:1px solid var(--border);background:var(--surface2);border-radius:var(--r);padding:10px;color:var(--text2);font-size:12px;line-height:1.35}
.dm-speaking-status.recording{border-color:var(--red-dim);background:var(--red-lt);color:var(--red)}
.dm-speaking-status.sending{border-color:var(--gold);background:var(--gold-lt);color:var(--gold)}
.dm-speaking-status.result{border-color:var(--green-dim);background:var(--green-lt);color:var(--green)}
.dm-speaking-status.error{border-color:var(--red-dim);background:var(--red-lt);color:var(--red)}
.dm-countdown{font-size:18px;font-weight:900;color:inherit}
.dm-speaking-results{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.dm-result-score-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:2px 0 4px}
.dm-result-section{display:flex;flex-direction:column;gap:4px}
.dm-feedback-list{margin:0;padding-left:18px;color:var(--text2);font-size:12px;line-height:1.45}
.dm-speaking-footer{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}
.dm-speaking-footer.three{grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:430px){
  .dm-speaking-actions,.dm-speaking-actions.compact,.dm-secondary-actions,.dm-sentence-filters,.dm-progress-grid,.dm-result-score-grid,.dm-speaking-footer.three{grid-template-columns:1fr}
  .dm-step-row{grid-template-columns:1fr 1fr}
  .dm-current-task .pron-target{font-size:18px}
  .dm-current-task.is-medium .pron-target{font-size:15.5px}
  .dm-current-task.is-long .pron-target{font-size:14px;max-height:min(24vh,180px)}
}

/* Phase: Prep */
.prep-header{
  padding:16px 20px 12px;background:var(--surface);
  border-bottom:1px solid var(--border);flex-shrink:0;
}
.prep-back{
  display:flex;align-items:center;gap:8px;cursor:pointer;
  font-size:13px;color:var(--text2);margin-bottom:12px;
  background:none;border:none;font-family:inherit;padding:0;
}
.prep-back:hover{color:var(--primary)}
.prep-scenario-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--primary-lt);border-radius:var(--r-full);
  padding:4px 10px;font-size:11px;font-weight:700;color:var(--primary);
  margin-bottom:10px;
}
.prep-title{font-family:'DM Serif Display',serif;font-size:20px;margin-bottom:4px}
.prep-persona-row{display:flex;align-items:center;gap:10px}
.prep-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--surface2);display:flex;align-items:center;
  justify-content:center;font-size:18px;flex-shrink:0;
}
.prep-persona-name{font-size:14px;font-weight:700}
.prep-persona-role{font-size:12px;color:var(--text3)}

.prep-body{flex:1;overflow-y:auto;padding:16px}
.prep-section-title{
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--text3);margin-bottom:10px;
}
.phrase-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.phrase-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:13px 14px;
  display:flex;align-items:center;gap:12px;
}
.phrase-num{
  width:22px;height:22px;border-radius:50%;background:var(--primary-lt);
  font-size:10px;font-weight:700;color:var(--primary);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.phrase-text{flex:1}
.phrase-de{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}
.phrase-en{font-size:12px;color:var(--text3)}
.phrase-audio{
  width:30px;height:30px;border-radius:50%;
  background:var(--surface2);border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:13px;flex-shrink:0;transition:all .15s;
}
.phrase-audio:hover{background:var(--primary-lt);border-color:var(--primary)}
.phrase-audio.playing{background:var(--primary-lt);border-color:var(--primary);animation:pulse-border 1s infinite}

.tip-box{
  background:var(--gold-lt);border:1px solid var(--gold);
  border-radius:var(--r);padding:12px 14px;margin-bottom:20px;
}
.tip-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);margin-bottom:4px}
.tip-text{font-size:13px;color:var(--text2);line-height:1.5}

.prep-footer{padding:12px 16px 16px;flex-shrink:0}
.btn-start{
  width:100%;padding:15px;border-radius:var(--r-lg);
  background:var(--primary);color:#fff;border:none;
  font-size:16px;font-weight:700;cursor:pointer;
  transition:background .15s;font-family:inherit;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-start:hover{background:var(--primary-h)}

/* Phase: Conversation */
.conv-header{
  padding:10px 14px;background:var(--surface);
  border-bottom:1px solid var(--border);flex-shrink:0;
  display:flex;align-items:center;gap:10px;
}
.conv-back{background:none;border:none;cursor:pointer;color:var(--text2);font-size:20px;padding:2px 6px;margin-right:2px}
.conv-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-lt);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.conv-info{flex:1;min-width:0}
.conv-name{font-size:14px;font-weight:700}
.conv-scenario{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}
.conv-timer{font-size:12px;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums}
.conv-timer.warning{color:var(--red)}
.conv-turns{font-size:10px;color:var(--text3)}

.practice-session .practice-session-header{
  background:#fff;
  border-bottom:1px solid var(--dm-line);
  gap:10px;
  padding:14px 16px;
}
.practice-session .conv-back{
  align-items:center;
  background:transparent;
  border:0;
  color:var(--dm-ink-2);
  display:inline-flex;
  font-size:13px;
  font-weight:800;
  min-height:38px;
  padding:0 4px;
}
.practice-session .conv-back::before{
  content:"";
  border-bottom:2px solid currentColor;
  border-left:2px solid currentColor;
  display:inline-block;
  height:8px;
  margin-right:6px;
  transform:rotate(45deg);
  width:8px;
}
.practice-session .conv-avatar{
  background:var(--dm-surface-sunken);
  color:var(--dm-brass);
  height:42px;
  width:42px;
}
.practice-session .conv-name{
  color:var(--dm-ink);
  font-size:16px;
  font-weight:900;
}
.practice-session .conv-scenario{
  color:var(--dm-ink-3);
  font-size:12px;
}
.practice-session .conv-timer{
  display:none;
}
.practice-session .conv-meta .practice-secondary-btn{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:12px;
  color:var(--dm-ink-2);
  font-size:13px;
  font-weight:800;
  min-height:40px;
  padding:0 12px;
  width:auto;
}
.practice-session .practice-input-row{
  align-items:center;
  display:flex;
  gap:8px;
}
.practice-session .practice-input-row .practice-primary-btn{
  width:auto;
}

/* Timer bar */
.timer-bar{height:3px;background:var(--border);flex-shrink:0}
.timer-bar-fill{height:100%;background:var(--primary);transition:width 1s linear}
.timer-bar-fill.warning{background:var(--red)}

.chat-messages{flex:1;overflow-y:auto;padding:14px 14px 6px}
.chat-messages::-webkit-scrollbar{width:3px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* Bubbles */
.msg-group{display:flex;flex-direction:column;margin-bottom:10px}
.msg-group.user{align-items:flex-end}
.msg-group.ai{align-items:flex-start}
.msg-bubble{
  max-width:82%;padding:10px 13px;
  border-radius:var(--r-lg);font-size:14px;line-height:1.5;
}
.msg-group.ai .msg-bubble{
  background:var(--surface);border:1px solid var(--border);
  border-bottom-left-radius:4px;color:var(--text);
}
.msg-group.user .msg-bubble{
  background:var(--primary);color:#fff;
  border-bottom-right-radius:4px;
}
.msg-time{font-size:10px;color:var(--text3);margin-top:3px;padding:0 3px}
.feedback-chip{
  align-self:flex-start;  /* left-align inside the right-aligned msg-group */
  max-width:90%;margin-top:5px;padding:9px 13px;
  background:var(--gold-lt);border:1px solid var(--gold);
  border-radius:var(--r);font-size:12px;line-height:1.6;color:var(--text2);
  display:flex;flex-direction:column;gap:3px;
}
.feedback-chip strong{color:var(--gold);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.fb-original{text-decoration:line-through;opacity:.55}
.fb-corrected{color:var(--green);font-weight:700}
.fb-natural{color:var(--blue);font-style:italic;font-size:12px}
.fb-explanation{font-size:11px;color:var(--text3);margin-top:1px}
.typing-indicator{
  display:flex;align-items:center;gap:4px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);border-bottom-left-radius:4px;
  padding:12px 14px;max-width:70px;
}
.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--text3);animation:blink 1.3s infinite}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25}40%{opacity:1}}

/* Input area */
.conv-input-wrap{
  padding:10px 14px 14px;background:var(--surface);
  border-top:1px solid var(--border);flex-shrink:0;
}
.transcript-preview{
  min-height:32px;padding:6px 12px;
  background:var(--surface2);border-radius:var(--r);
  font-size:13px;color:var(--text2);margin-bottom:10px;
  font-style:italic;line-height:1.4;
  border:1.5px dashed var(--border2);
}
.transcript-preview.has-text{color:var(--text);font-style:normal;border-style:solid;border-color:var(--primary)}

/* Input row: text + mic + send */
.input-row{display:flex;align-items:center;gap:8px}
.text-input-wrap{flex:1;position:relative}
.chat-text-input{
  width:100%;background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--r-full);padding:9px 16px;
  font-size:14px;color:var(--text);font-family:inherit;
  transition:border-color .15s;
}
.chat-text-input:focus{outline:none;border-color:var(--primary)}
.chat-text-input::placeholder{color:var(--text3)}

/* The HERO mic button */
.mic-btn{
  width:52px;height:52px;border-radius:50%;
  background:var(--primary);color:#fff;border:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;transition:all .2s;
  box-shadow:0 4px 16px rgba(74,184,104,.35);
  position:relative;overflow:visible;
}
.mic-btn:hover{background:var(--primary-h);transform:scale(1.06)}
.mic-btn.recording{
  background:var(--red);
  box-shadow:0 4px 20px rgba(224,96,80,.5);
  animation:mic-pulse 1.5s ease-in-out infinite;
}
.mic-btn.processing{background:var(--gold);animation:spin .7s linear infinite}
.mic-ring{
  position:absolute;inset:-6px;border-radius:50%;
  border:2px solid var(--red);opacity:0;pointer-events:none;
}
.mic-btn.recording .mic-ring{animation:ring-expand 1.5s ease-out infinite}
.send-btn{
  width:40px;height:40px;border-radius:50%;background:var(--primary);
  color:#fff;border:none;cursor:pointer;font-size:16px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .15s;
}
.send-btn:hover{background:var(--primary-h)}
.send-btn:disabled{opacity:.4;cursor:not-allowed}

@keyframes mic-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes ring-expand{0%{inset:-2px;opacity:.6}100%{inset:-14px;opacity:0}}
@keyframes pulse-border{0%,100%{border-color:var(--primary)}50%{border-color:var(--primary-h)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── SESSION COMPLETE ────────────────────────────────────────────── */
.session-complete{padding:20px;overflow-y:auto}
.sc-hero{text-align:center;padding:12px 0 20px}
.sc-icon{font-size:52px;margin-bottom:12px}
.sc-title{font-family:'DM Serif Display',serif;font-size:24px;margin-bottom:6px}
.sc-sub{font-size:13px;color:var(--text2);margin-bottom:20px;line-height:1.5}
.sc-stats-row{display:flex;gap:10px;margin-bottom:20px}
.sc-stat{
  flex:1;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:14px 8px;text-align:center;
}
.sc-stat-num{font-family:'DM Serif Display',serif;font-size:26px;color:var(--primary)}
.sc-stat-lbl{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}

.mistakes-section{margin-bottom:20px}
.mistakes-header{
  font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text3);margin-bottom:10px;
}
.mistake-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:14px;margin-bottom:10px;
}
.mistake-original{
  font-size:13px;color:var(--text2);margin-bottom:8px;
  padding:6px 10px;background:var(--red-lt);border-radius:var(--r-sm);
  display:flex;align-items:flex-start;gap:6px;
}
.mistake-original::before{content:"✗";color:var(--red);flex-shrink:0;font-weight:700}
.mistake-corrected{
  font-size:13px;margin-bottom:4px;
  padding:6px 10px;background:var(--green-lt);border-radius:var(--r-sm);
  display:flex;align-items:flex-start;gap:6px;
}
.mistake-corrected::before{content:"✓";color:var(--green);flex-shrink:0;font-weight:700}
.mistake-natural{
  font-size:13px;margin-bottom:8px;
  padding:6px 10px;background:var(--blue-lt);border-radius:var(--r-sm);
  display:flex;align-items:flex-start;gap:6px;
}
.mistake-natural::before{content:"⭐";flex-shrink:0}
.mistake-feedback{font-size:12px;color:var(--text3);margin-bottom:10px;font-style:italic;line-height:1.5}
.retry-btn{
  display:flex;align-items:center;gap:6px;background:var(--primary-lt);
  border:1.5px solid var(--primary);border-radius:var(--r-full);
  padding:7px 14px;font-size:12px;font-weight:700;color:var(--primary);
  cursor:pointer;font-family:inherit;transition:all .15s;
}
.retry-btn:hover{background:var(--primary);color:#fff}
.retry-btn.retrying{background:var(--red);border-color:var(--red);color:#fff}

.btn-done{
  width:100%;padding:14px;border-radius:var(--r-lg);
  background:var(--primary);color:#fff;border:none;
  font-size:15px;font-weight:700;cursor:pointer;
  transition:background .15s;font-family:inherit;margin-bottom:20px;
}
.btn-done:hover{background:var(--primary-h)}

/* ── AI Feedback panel ── */
.feedback-overall{background:var(--surface-2);border-radius:var(--r-lg);padding:14px 16px;font-size:14px;line-height:1.6;color:var(--text1);margin-bottom:12px}
.feedback-section{margin-bottom:16px}
.feedback-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text2);margin-bottom:8px}
.feedback-strength{display:flex;gap:8px;align-items:flex-start;padding:8px 12px;background:var(--green-lt);border-radius:var(--r-md);margin-bottom:6px;font-size:13px;color:var(--green);font-weight:600}
.feedback-strength::before{content:'✓';flex-shrink:0;font-weight:700}
.mistake-category{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 7px;border-radius:var(--r-full);background:var(--red-lt);color:var(--red);margin-bottom:6px}
.next-focus-box{background:var(--blue-lt);border-radius:var(--r-lg);padding:14px 16px;margin-top:4px;margin-bottom:16px}
.next-focus-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--blue);margin-bottom:6px}
.next-focus-text{font-size:14px;font-weight:600;color:var(--text1)}
/* TTS button on AI message bubbles */
.ai-msg-tts{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;font-size:14px;padding:1px 3px;margin-left:5px;opacity:.55;transition:opacity .15s;vertical-align:middle;border-radius:4px}
.ai-msg-tts:hover{opacity:1}
.ai-msg-tts.loading{pointer-events:none;opacity:.4}
/* Score ring */
.sc-score{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;font-weight:700;font-size:22px;margin:0 auto 8px;border:4px solid var(--border)}
.sc-score.s-great{border-color:var(--green);color:var(--green);background:var(--green-lt)}
.sc-score.s-ok{border-color:var(--gold);color:var(--gold);background:#fffbea}
.sc-score.s-low{border-color:var(--red);color:var(--red);background:var(--red-lt)}

/* Session warning banner */
.session-warning{
  background:var(--red-lt);border-bottom:1px solid var(--red-dim);
  padding:8px 14px;font-size:12px;font-weight:600;color:var(--red);
  display:none;align-items:center;gap:6px;flex-shrink:0;
}
.session-warning.visible{display:flex}

/* ─── REVIEW SCREEN ───────────────────────────────────────────────── */
.review-screen-inner{flex:1;overflow-y:auto;padding:16px}
.review-empty{
  text-align:center;padding:60px 20px;
}
.review-empty-icon{font-size:48px;margin-bottom:14px}
.review-empty-title{font-family:'DM Serif Display',serif;font-size:20px;margin-bottom:8px}
.review-empty-sub{font-size:13px;color:var(--text2);line-height:1.5}

.review-section-title{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text3);margin-bottom:10px;
}
.session-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:14px;margin-bottom:10px;
  cursor:pointer;transition:all .15s;
}
.session-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}
.session-card-top{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.session-card-avatar{width:38px;height:38px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.session-card-info{flex:1}
.session-card-title{font-size:14px;font-weight:700;margin-bottom:2px}
.session-card-meta{font-size:11px;color:var(--text3)}
.session-card-badge{
  font-size:10px;font-weight:700;padding:3px 8px;
  border-radius:var(--r-full);flex-shrink:0;
}
.badge-a1{background:var(--green-lt);color:var(--green)}
.badge-a2{background:var(--gold-lt);color:var(--gold)}
.badge-b1{background:var(--orange-lt);color:var(--orange)}
.session-card-stats{display:flex;gap:10px}
.sstat{font-size:11px;color:var(--text2)}
.sstat strong{color:var(--text);font-weight:700}
.session-detail{display:none;padding-top:12px;border-top:1px solid var(--border);margin-top:10px}
.session-card.expanded .session-detail{display:block}
.session-card-chevron{font-size:12px;color:var(--text3);transition:transform .2s;float:right}
.session-card.expanded .session-card-chevron{transform:rotate(180deg)}

.progress-screen{display:flex;flex-direction:column;gap:12px;padding-bottom:18px}
.progress-overview-card,.progress-section{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:14px;box-shadow:var(--shadow);color:var(--text);
}
.progress-overview-card{
  display:flex;flex-direction:column;gap:12px;
  background:linear-gradient(180deg,var(--surface),var(--surface2));border-color:var(--primary);
}
.progress-overview-card h2{
  font-family:'DM Serif Display',Georgia,serif;font-size:24px;line-height:1.2;margin:2px 0 6px;
}
.progress-overview-card p{font-size:13px;line-height:1.45;color:var(--text2)}
.progress-action-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.progress-btn{
  border:0;border-radius:var(--r);background:var(--primary);color:#fff;
  padding:10px 12px;font:inherit;font-size:12px;font-weight:800;cursor:pointer;
}
.progress-btn.secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text2)}
.progress-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.progress-metric,.progress-info-card,.progress-recommendation{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:11px;
}
.progress-metric-value,.progress-big-number{font-size:22px;font-weight:900;color:var(--text);line-height:1}
.progress-metric-label,.progress-label{
  font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-top:5px;
}
.progress-metric-sub,.progress-muted,.progress-empty-line{font-size:12px;color:var(--text2);line-height:1.45;margin-top:4px}
.progress-section-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.progress-section-title{font-size:13px;font-weight:900;color:var(--text)}
.progress-score-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.progress-score-ring{
  width:66px;height:66px;border-radius:50%;background:conic-gradient(var(--primary) calc(var(--score,0)*1%),var(--surface2) 0);
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;flex-shrink:0;
}
.progress-card-title{font-size:14px;font-weight:800;color:var(--text);line-height:1.3}
.progress-score-bars{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:10px}
.progress-score-bar>div:first-child{display:flex;justify-content:space-between;font-size:12px;color:var(--text2);font-weight:700;margin-bottom:4px}
.progress-mini-bar{height:6px;border-radius:var(--r-full);background:var(--surface);overflow:hidden}
.progress-mini-bar span{display:block;height:100%;border-radius:inherit;background:var(--primary)}
.progress-two-col{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:8px}
.progress-subblock{margin-top:10px}
.progress-chip-list{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px}
.progress-chip-list span{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-full);padding:5px 9px;font-size:11px;font-weight:800;color:var(--text2)}
.progress-empty-compact{padding:22px 12px}
.progress-screen--phase06{gap:14px}
.progress-topline{border-color:var(--dm-accent,#7c6cff)}
.progress-metric-grid--compact .progress-metric-value{font-size:18px}
.dm-improve-panel{border-color:var(--dm-accent,#7c6cff)}
.dm-improve-list{display:grid;gap:8px}
.dm-improve-row{
  width:100%;min-height:58px;border:1px solid var(--border);border-radius:var(--r);
  background:var(--surface2);color:var(--text);display:grid;grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;gap:10px;padding:10px;text-align:left;font:inherit;cursor:pointer;
}
.dm-improve-row__body{display:grid;gap:2px;min-width:0}
.dm-improve-row__body strong{font-size:13px;line-height:1.25;color:var(--text)}
.dm-improve-row__body small{font-size:12px;line-height:1.35;color:var(--text2)}
.dm-improve-row__cta{font-size:11px;font-weight:900;color:var(--primary);white-space:nowrap}
.dm-progress-empty{
  min-height:112px;border:1px dashed var(--border);border-radius:var(--r);
  background:var(--surface2);display:grid;align-content:center;gap:6px;padding:18px;text-align:center;
}
.dm-progress-empty h3{font-size:16px;margin:0;color:var(--text)}
.dm-progress-empty p{font-size:13px;line-height:1.45;margin:0;color:var(--text2)}
.dm-cefr-rail{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:7px;margin-bottom:8px}
.dm-cefr-rail span{
  min-height:38px;border:1px solid var(--border);border-radius:var(--r);
  background:var(--surface2);display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;color:var(--text3);
}
.dm-cefr-rail span.reached{color:var(--text);border-color:var(--primary)}
.dm-cefr-rail span.active{background:var(--primary);color:#fff}
.dm-readiness-bar{height:10px;border-radius:var(--r-full);background:var(--surface2);overflow:hidden;margin-bottom:10px}
.dm-readiness-bar span{display:block;height:100%;border-radius:inherit;background:var(--primary)}
.dm-readiness-copy{display:grid;gap:3px}
.dm-readiness-copy strong{font-size:14px;color:var(--text)}
.dm-readiness-copy small{font-size:12px;line-height:1.45;color:var(--text2)}
.progress-history-secondary[hidden]{display:none}
@media (min-width:520px){
  .progress-metric-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .progress-two-col{grid-template-columns:1fr 1fr}
}

/* ─── CONTEXT BOX ────────────────────────────────────────────────── */
.context-box{
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:var(--r);padding:12px 14px;margin-bottom:16px;
  display:flex;align-items:flex-start;gap:10px;
}
.context-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.context-text{font-size:13px;color:var(--text2);line-height:1.6;font-style:italic}

/* ─── GRAMMAR SPOTLIGHT ───────────────────────────────────────────── */
.grammar-spotlight{
  background:var(--gold-lt);border:1px solid var(--gold);
  border-radius:var(--r-lg);padding:14px;margin-bottom:16px;
}
.gs-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.gs-tag{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  background:var(--gold);color:#fff;padding:3px 8px;border-radius:var(--r-full);
  flex-shrink:0;
}
.gs-concept{font-size:13px;font-weight:700;color:var(--text)}
.gs-rule{font-size:13px;color:var(--text2);line-height:1.55;margin-bottom:8px}
.gs-examples{display:flex;flex-direction:column;gap:4px}
.gs-ex{
  font-size:12px;font-family:'Courier New',Courier,monospace;
  color:var(--text);background:var(--surface);
  border-radius:var(--r-sm);padding:5px 9px;line-height:1.5;
}

/* ─── PHRASE NOTE ─────────────────────────────────────────────────── */
.phrase-note{
  font-size:11px;color:var(--text3);margin-top:3px;line-height:1.45;
  border-left:2px solid var(--border2);padding-left:6px;
}

/* ─── UTILITY ─────────────────────────────────────────────────────── */
.label-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:10px;font-weight:700;padding:2px 8px;
  border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.05em;
}
.badge-green{background:var(--green-lt);color:var(--green)}
.badge-gold{background:var(--gold-lt);color:var(--gold)}
.badge-blue{background:var(--blue-lt);color:var(--blue)}
.badge-c1{background:var(--purple-lt);color:var(--purple)}
.divider{height:1px;background:var(--border);margin:12px 0}
.section-gap{height:20px}

/* No results */
.no-results{text-align:center;padding:40px 20px}
.no-results-icon{font-size:32px;margin-bottom:10px}
.no-results-text{font-size:13px;color:var(--text3)}

/* ─── GRAMMAR SCREEN ──────────────────────────────────────────────── */
.grammar-hero{
  background:linear-gradient(135deg,#0a2240 0%,#163660 60%,#1e4a7c 100%);
  padding:20px 20px 22px;color:#fff;flex-shrink:0;
}
[data-theme="light"] .grammar-hero{background:linear-gradient(135deg,#1a3a5c 0%,#2558a0 100%)}
.grammar-hero-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.7;margin-bottom:5px}
.grammar-hero-title{font-family:'DM Serif Display',Georgia,serif;font-size:22px;line-height:1.25;margin-bottom:4px}
.grammar-hero-sub{font-size:13px;opacity:.8;margin-bottom:14px;line-height:1.5}
.grammar-hero-stats{display:flex;gap:18px}
.gstat{text-align:center}
.gstat-num{font-family:'DM Serif Display',serif;font-size:21px;font-weight:700}
.gstat-lbl{font-size:10px;opacity:.7;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.grammar-body{padding:16px}
.grammar-search-wrap{position:relative;margin-bottom:12px}
.grammar-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;color:var(--text3)}
#grammar-search-input{
  width:100%;background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r-full);padding:10px 14px 10px 36px;
  font-size:14px;color:var(--text);font-family:inherit;transition:border-color .15s;
}
#grammar-search-input:focus{outline:none;border-color:var(--blue)}
#grammar-search-input::placeholder{color:var(--text3)}
.grammar-level-pills{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}
.grammar-level-pills::-webkit-scrollbar{display:none}
.grammar-level-pill{
  flex-shrink:0;padding:6px 14px;border-radius:var(--r-full);
  border:1.5px solid var(--border);background:var(--surface);
  font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;
  color:var(--text2);font-family:inherit;
}
.grammar-level-pill:hover{border-color:var(--blue);color:var(--blue)}
.grammar-level-pill.active{background:var(--blue);border-color:var(--blue);color:#fff}
.grammar-level-pill.gpill-a1.active{background:var(--green);border-color:var(--green);color:#fff}
.grammar-level-pill.gpill-a2.active{background:var(--gold);border-color:var(--gold);color:#fff}
.grammar-level-pill.gpill-b1.active{background:var(--orange);border-color:var(--orange);color:#fff}
.grammar-level-group{margin-bottom:6px}
.grammar-level-group-header{
  display:flex;align-items:center;gap:8px;
  padding:8px 0;cursor:pointer;user-select:none;
}
.grammar-level-group-icon{font-size:16px;width:28px;text-align:center}
.grammar-level-group-name{font-size:13px;font-weight:700;color:var(--text);flex:1}
.grammar-level-group-meta{font-size:11px;color:var(--text3)}
.grammar-level-group-chevron{font-size:12px;color:var(--text3);transition:transform .2s;flex-shrink:0}
.grammar-level-group.open .grammar-level-group-chevron{transform:rotate(90deg)}
.grammar-topics-list{display:none;flex-direction:column;gap:6px;padding-bottom:8px}
.grammar-level-group.open .grammar-topics-list{display:flex}
.grammar-topic-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;
  transition:border-color .15s,box-shadow .15s;
}
.grammar-topic-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.grammar-topic-card.expanded{border-color:var(--blue)}
.grammar-topic-header{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;cursor:pointer;
}
.grammar-topic-level-badge{
  flex-shrink:0;font-size:10px;font-weight:700;padding:3px 8px;
  border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.04em;
}
.gtbadge-a1{background:var(--green-lt);color:var(--green)}
.gtbadge-a2{background:var(--gold-lt);color:var(--gold)}
.gtbadge-b1{background:var(--orange-lt);color:var(--orange)}
.grammar-topic-name{flex:1;font-size:13px;font-weight:600;color:var(--text);line-height:1.3}
.grammar-topic-chevron{font-size:13px;color:var(--text3);transition:transform .2s;flex-shrink:0}
.grammar-topic-card.expanded .grammar-topic-chevron{transform:rotate(180deg)}
.grammar-topic-detail{
  display:none;padding:12px 14px 14px;
  border-top:1px solid var(--border);
}
.grammar-topic-card.expanded .grammar-topic-detail{display:block}
.grammar-explanation{font-size:13px;color:var(--text2);line-height:1.65;margin-bottom:12px}
.grammar-section-lbl{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--text3);margin-bottom:7px;margin-top:4px;
}
.grammar-examples{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.grammar-ex-row{background:var(--surface2);border-radius:var(--r-sm);padding:8px 11px}
.grammar-ex-de{
  font-size:13px;font-weight:600;color:var(--text);
  font-family:'Courier New',Courier,monospace;margin-bottom:2px;
}
.grammar-ex-en{font-size:11px;color:var(--text3)}
.grammar-mistakes{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.grammar-mistake-item{
  font-size:12px;color:var(--text2);line-height:1.5;
  padding:7px 10px;background:var(--red-lt);
  border-radius:var(--r-sm);border-left:3px solid var(--red-dim);
}
.grammar-linked{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}
.grammar-linked-chip{
  font-size:11px;font-weight:600;padding:4px 10px;
  border-radius:var(--r-full);background:var(--primary-lt);
  color:var(--primary);border:1px solid var(--primary-dim);
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.grammar-linked-chip:hover{background:var(--primary);color:#fff}
/* ─── B2 LEVEL STYLES ─────────────────────────────────────────── */
.sc-num.b2{background:var(--blue-lt);color:var(--blue)}
.badge-b2{background:var(--blue-lt);color:var(--blue)}
.level-pill.pill-b2.active{background:var(--blue);border-color:var(--blue);color:#fff}
.level-pill.pill-c1:hover{border-color:var(--purple);color:var(--purple)}
.level-pill.pill-c1.active{background:var(--purple);border-color:var(--purple);color:#fff}
.sc-num.c1{background:var(--purple-lt);color:var(--purple)}
.badge-c1{background:var(--purple-lt);color:var(--purple)}
.session-card-badge.badge-c1{background:var(--purple-lt);color:var(--purple)}
.grammar-level-pill.gpill-b2.active{background:var(--blue);border-color:var(--blue);color:#fff}
.grammar-level-pill.gpill-c1:hover{border-color:var(--purple);color:var(--purple)}
.grammar-level-pill.gpill-c1.active{background:var(--purple);border-color:var(--purple);color:#fff}
.gtbadge-b2{background:var(--blue-lt);color:var(--blue)}
.gtbadge-c1{background:var(--purple-lt);color:var(--purple)}
.session-card-badge.badge-b2{background:var(--blue-lt);color:var(--blue)}

/* ─── DISCUSS SCREEN ──────────────────────────────────────────── */
.discuss-hero{
  background:linear-gradient(135deg,#081828 0%,#0d3060 60%,#1a5a98 100%);
  padding:20px 20px 22px;color:#fff;flex-shrink:0;
}
[data-theme="light"] .discuss-hero{background:linear-gradient(135deg,#0a2040 0%,#1a5090 100%)}
.discuss-hero-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.7;margin-bottom:5px}
.discuss-hero-title{font-family:'DM Serif Display',Georgia,serif;font-size:22px;line-height:1.25;margin-bottom:4px}
.discuss-hero-sub{font-size:13px;opacity:.8;margin-bottom:14px;line-height:1.5}
.discuss-hero-stats{display:flex;gap:18px}
.dstat{text-align:center}
.dstat-num{font-family:'DM Serif Display',serif;font-size:21px;font-weight:700}
.dstat-lbl{font-size:10px;opacity:.7;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.discuss-body{padding:16px}
.discuss-search-wrap{position:relative;margin-bottom:12px}
.discuss-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;color:var(--text3)}
#discuss-search-input{
  width:100%;background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r-full);padding:10px 14px 10px 36px;
  font-size:14px;color:var(--text);font-family:inherit;transition:border-color .15s;
}
#discuss-search-input:focus{outline:none;border-color:var(--blue)}
#discuss-search-input::placeholder{color:var(--text3)}
.discuss-theme-pills{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}
.discuss-theme-pills::-webkit-scrollbar{display:none}
.discuss-theme-pill{
  flex-shrink:0;padding:6px 14px;border-radius:var(--r-full);
  border:1.5px solid var(--border);background:var(--surface);
  font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;
  color:var(--text2);font-family:inherit;
}
.discuss-theme-pill:hover{border-color:var(--blue);color:var(--blue)}
.discuss-theme-pill.active{background:var(--blue);border-color:var(--blue);color:#fff}
.discuss-level-pills{display:flex;gap:6px;margin-bottom:10px}
.discuss-level-pill{flex-shrink:0;padding:5px 12px;border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;color:var(--text2);font-family:inherit}
.discuss-level-pill.dlp-all:hover,.discuss-level-pill.dlp-b2:hover{border-color:var(--blue);color:var(--blue)}
.discuss-level-pill.dlp-all.active,.discuss-level-pill.dlp-b2.active{background:var(--blue);border-color:var(--blue);color:#fff}
.discuss-level-pill.dlp-c1:hover{border-color:var(--purple);color:var(--purple)}
.discuss-level-pill.dlp-c1.active{background:var(--purple);border-color:var(--purple);color:#fff}
.dtopic-lvl{display:inline-block;font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--r-full);margin-right:4px;flex-shrink:0}
.dtopic-lvl-b2{background:var(--blue-lt);color:var(--blue)}
.dtopic-lvl-c1{background:var(--purple-lt);color:var(--purple)}
.discuss-theme-group{margin-bottom:6px}
.discuss-theme-group-header{
  display:flex;align-items:center;gap:8px;
  padding:8px 0;cursor:pointer;user-select:none;
}
.discuss-theme-group-icon{font-size:16px;width:28px;text-align:center}
.discuss-theme-group-name{font-size:13px;font-weight:700;color:var(--text);flex:1}
.discuss-theme-group-meta{font-size:11px;color:var(--text3)}
.discuss-theme-group-chevron{font-size:12px;color:var(--text3);transition:transform .2s;flex-shrink:0}
.discuss-theme-group.open .discuss-theme-group-chevron{transform:rotate(90deg)}
.discuss-topics-list{display:flex;flex-direction:column;gap:6px;padding-bottom:8px}
.discuss-theme-group .discuss-topics-list{display:none}
.discuss-theme-group.open .discuss-topics-list{display:flex}
.discuss-topic-title-wrap{flex:1;min-width:0}
.discuss-topic-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3}
.discuss-topic-subtitle{font-size:11px;color:var(--blue);font-weight:500;margin-top:2px;opacity:.85}
.discuss-topic-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;
  transition:border-color .15s,box-shadow .15s;
}
.discuss-topic-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.discuss-topic-card.expanded{border-color:var(--blue)}
.discuss-topic-header{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer}
.discuss-topic-icon{font-size:18px;flex-shrink:0}
.discuss-topic-name{flex:1;font-size:13px;font-weight:600;color:var(--text);line-height:1.3}
.discuss-topic-level{
  flex-shrink:0;font-size:10px;font-weight:700;padding:3px 8px;
  border-radius:var(--r-full);background:var(--blue-lt);color:var(--blue);
  text-transform:uppercase;letter-spacing:.04em;
}
.discuss-topic-chevron{font-size:13px;color:var(--text3);transition:transform .2s;flex-shrink:0}
.discuss-topic-card.expanded .discuss-topic-chevron{transform:rotate(180deg)}
.discuss-topic-detail{display:none;padding:12px 14px 14px;border-top:1px solid var(--border)}
.discuss-topic-card.expanded .discuss-topic-detail{display:block}
.discuss-section-lbl{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--text3);margin-bottom:7px;margin-top:4px;
}
.discuss-prompts{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.discuss-prompt-item{
  font-size:13px;color:var(--text2);line-height:1.55;
  padding:8px 11px;background:var(--surface2);border-radius:var(--r-sm);
  border-left:3px solid var(--blue-dim);
}
.discuss-connectors{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.discuss-connector-chip{
  font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--r-full);
  background:var(--blue-lt);color:var(--blue);border:1px solid var(--blue-dim);
}
.discuss-phrases{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.discuss-phrase-row{background:var(--surface2);border-radius:var(--r-sm);padding:8px 11px}
.discuss-phrase-de{font-size:13px;font-weight:600;color:var(--text);font-family:'Courier New',Courier,monospace;margin-bottom:2px}
.discuss-phrase-en{font-size:11px;color:var(--text3)}
.btn-discuss-practice{
  width:100%;padding:12px;border-radius:var(--r-lg);
  background:var(--blue);color:#fff;border:none;
  font-size:14px;font-weight:700;cursor:pointer;
  font-family:inherit;transition:background .15s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-discuss-practice:hover{background:#134070}
.discuss-vocab-grid{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.discuss-vocab-row{background:var(--surface2);border-radius:var(--r-sm);padding:7px 11px;display:flex;align-items:baseline;flex-wrap:wrap;gap:4px}
.discuss-vocab-hw{font-size:12px;font-weight:700;color:var(--text);flex-shrink:0}
.discuss-vocab-arrow{font-size:11px;color:var(--text3);flex-shrink:0;margin:0 2px}
.discuss-vocab-syn{font-size:11px;color:var(--text2);background:var(--surface3);padding:2px 8px;border-radius:var(--r-full);border:1px solid var(--border)}
/* ─── MODULE CARD ─────────────────────────────────────────────── */
.module-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:13px 14px;margin-bottom:8px;
  cursor:pointer;transition:all .15s;
}
.module-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.module-card-top{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.module-card-icon{font-size:20px;flex-shrink:0}
.module-card-name{font-size:13px;font-weight:700;color:var(--text)}
.module-card-goal{font-size:11px;color:var(--text3);line-height:1.45}
.module-card-meta{font-size:11px;color:var(--text2);display:flex;gap:10px;margin-top:6px}
.grammar-feedback-toast{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%);
  background:var(--surface);border:1.5px solid var(--blue);
  border-radius:var(--r-lg);padding:12px 16px;max-width:340px;width:90%;
  box-shadow:var(--shadow-lg);z-index:999;animation:slideUp .25s ease;
}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(12px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ─── EXERCISES SCREEN ─────────────────────────────────────────────── */
.ex-hub{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.ex-hub-hero{
  background:linear-gradient(135deg,var(--blue) 0%,#1a3a70 100%);
  padding:18px 20px 20px;color:#fff;flex-shrink:0;
}
.ex-hub-hero .hero-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.75;margin-bottom:5px}
.ex-hub-hero h2{font-family:'DM Serif Display',serif;font-size:22px;margin-bottom:4px}
.ex-hub-hero p{font-size:13px;opacity:.8;line-height:1.4}
.ex-hub-body{padding:14px 16px;flex:1}
.ex-search-wrap{position:relative;margin-bottom:12px}
.ex-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;color:var(--text3)}
#exercise-search-input{
  width:100%;padding:11px 14px 11px 36px;border:1px solid var(--border);
  background:var(--surface);border-radius:var(--r);font-size:14px;color:var(--text);
  font-family:inherit;
}
#exercise-search-input:focus{outline:none;border-color:var(--blue)}
#exercise-search-input::placeholder{color:var(--text3)}
.ex-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:10px;margin-top:14px}
.ex-continue-card{
  background:var(--surface);border:1.5px solid var(--primary);border-radius:var(--r-lg);
  padding:14px 16px;margin-bottom:16px;cursor:pointer;transition:box-shadow .15s;
}
.ex-continue-card:hover{box-shadow:var(--shadow)}
.ex-continue-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.ex-continue-title{font-size:14px;font-weight:700;color:var(--text)}
.ex-continue-level{font-size:11px;font-weight:700;color:var(--primary);background:var(--primary-lt);padding:2px 8px;border-radius:var(--r-full)}
.ex-continue-sub{font-size:12px;color:var(--text3);margin-bottom:10px}
.ex-progress-bar{height:6px;background:var(--surface3);border-radius:3px;overflow:hidden;margin-bottom:4px}
.ex-progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .3s}
.ex-progress-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text3)}
.ex-set-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.ex-set-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:13px 14px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:12px;
}
.ex-set-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.ex-set-badge{
  width:36px;height:36px;border-radius:var(--r-sm);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;
  background:var(--blue-lt);color:var(--blue);
}
.ex-set-badge.a1{background:var(--green-lt);color:var(--green)}
.ex-set-badge.a2{background:var(--gold-lt);color:var(--gold)}
.ex-set-badge.b1{background:var(--orange-lt);color:var(--orange)}
.ex-set-badge.b2{background:var(--blue-lt);color:var(--blue)}
.ex-set-badge.c1{background:var(--purple-lt);color:var(--purple)}
.ex-set-info{flex:1;min-width:0}
.ex-set-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.ex-set-sub{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ex-set-topic{font-size:10px;color:var(--text4);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ex-set-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.ex-set-count{font-size:11px;color:var(--text3)}
.ex-set-done{font-size:11px;color:var(--green);font-weight:600}

/* Drill screen */
.ex-drill{flex:1;display:flex;flex-direction:column;overflow:hidden}
.ex-drill-header{
  padding:12px 16px 10px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;
}
.ex-drill-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.ex-drill-back{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;color:var(--text2);background:none;border:none;font-family:inherit;padding:0}
.ex-drill-back:hover{color:var(--primary)}
.ex-drill-counter{font-size:12px;font-weight:600;color:var(--text3)}
.ex-drill-prog-bar{height:5px;background:var(--surface3);border-radius:3px;overflow:hidden}
.ex-drill-prog-fill{height:100%;background:var(--blue);border-radius:3px;transition:width .4s ease}
.ex-drill-body{flex:1;overflow-y:auto;padding:16px}
.ex-item-type-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:10px}
.ex-item-instruction{font-size:13px;color:var(--text2);margin-bottom:8px;font-style:italic}
.ex-item-prompt{
  font-size:18px;font-family:'DM Serif Display',serif;color:var(--text);
  line-height:1.5;margin-bottom:18px;
}
.ex-blank{
  display:inline-block;border-bottom:2.5px solid var(--blue);
  min-width:60px;text-align:center;color:var(--blue);font-weight:700;
  padding:0 6px;
}
.ex-text-input{
  width:100%;background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r);padding:12px 14px;font-size:15px;color:var(--text);
  font-family:inherit;transition:border-color .15s;margin-bottom:14px;
}
.ex-text-input:focus{outline:none;border-color:var(--blue)}
.ex-text-input.correct{border-color:var(--green);background:var(--green-lt)}
.ex-text-input.wrong{border-color:var(--red);background:var(--red-lt)}
.ex-mcq-opts{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.ex-mcq-opt{
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);
  padding:12px 14px;cursor:pointer;font-size:14px;color:var(--text);
  font-family:inherit;text-align:left;transition:all .15s;
}
.ex-mcq-opt:hover:not(:disabled){border-color:var(--blue);background:var(--blue-lt)}
.ex-mcq-opt.selected{border-color:var(--blue);background:var(--blue-lt);font-weight:600}
.ex-mcq-opt.correct{border-color:var(--green);background:var(--green-lt);color:var(--green);font-weight:600}
.ex-mcq-opt.wrong{border-color:var(--red);background:var(--red-lt);color:var(--red)}
.ex-mcq-opt:disabled{cursor:default}
.ex-word-bank{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.ex-word-tile{
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);
  padding:7px 12px;cursor:pointer;font-size:14px;color:var(--text);font-family:inherit;
  transition:all .15s;
}
.ex-word-tile:hover:not(:disabled){border-color:var(--blue);background:var(--blue-lt)}
.ex-word-tile.used{opacity:.35;cursor:default;text-decoration:line-through}
.ex-built-sentence{
  min-height:44px;background:var(--surface2);border:1.5px dashed var(--border2);
  border-radius:var(--r);padding:10px 12px;display:flex;flex-wrap:wrap;gap:6px;
  margin-bottom:14px;cursor:pointer;
}
.ex-built-word{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);
  padding:4px 8px;font-size:13px;cursor:pointer;
}
.ex-built-word:hover{background:var(--red-lt);border-color:var(--red)}
.ex-built-placeholder{font-size:13px;color:var(--text4);align-self:center}
.ex-feedback-box{
  border-radius:var(--r);padding:12px 14px;margin-bottom:14px;
  border-left:4px solid;
}
.ex-feedback-box.correct{background:var(--green-lt);border-color:var(--green);color:var(--green)}
.ex-feedback-box.wrong{background:var(--red-lt);border-color:var(--red)}
.ex-feedback-icon{font-size:15px;font-weight:700;margin-bottom:4px}
.ex-feedback-answer{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}
.ex-feedback-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin:8px 0 3px}
.ex-feedback-sentence{font-size:14px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;margin-bottom:6px;line-height:1.45}
.ex-feedback-explain{font-size:13px;color:var(--text2);line-height:1.5}
.ex-hint-btn{
  background:none;border:none;font-family:inherit;font-size:12px;
  color:var(--text3);cursor:pointer;padding:4px 0;margin-bottom:10px;text-decoration:underline;
}
.ex-hint-btn:hover{color:var(--text2)}
.ex-hint-box{
  background:var(--gold-lt);border-radius:var(--r-sm);padding:10px 12px;
  font-size:13px;color:var(--text2);margin-bottom:12px;display:none;
}
.ex-hint-box.visible{display:block}
.ex-drill-footer{
  padding:12px 16px;background:var(--surface);border-top:1px solid var(--border);
  display:flex;gap:8px;flex-shrink:0;
}
.ex-btn-check{
  flex:1;background:var(--blue);color:#fff;border:none;border-radius:var(--r);
  padding:13px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;
  transition:background .15s;
}
.ex-btn-check:hover{background:#1a3a80}
.ex-btn-check:disabled{background:var(--surface3);color:var(--text3);cursor:default}
.ex-btn-next{
  flex:1;background:var(--primary);color:#fff;border:none;border-radius:var(--r);
  padding:13px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;
  transition:background .15s;display:none;
}
.ex-btn-next:hover{background:var(--primary-h)}
.ex-btn-skip{
  background:none;border:1.5px solid var(--border);border-radius:var(--r);
  padding:13px 16px;font-size:14px;color:var(--text3);cursor:pointer;font-family:inherit;
  transition:all .15s;
}
.ex-btn-skip:hover{border-color:var(--border2);color:var(--text2)}

/* Session complete screen */
.ex-complete{flex:1;overflow-y:auto;display:flex;flex-direction:column;padding:20px 16px;gap:16px}
.ex-complete-score{
  background:var(--surface);border-radius:var(--r-xl);padding:20px;text-align:center;
  border:1px solid var(--border);
}
.ex-score-ring{
  width:80px;height:80px;border-radius:50%;margin:0 auto 12px;
  background:conic-gradient(var(--green) var(--pct,0%), var(--surface3) 0%);
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;font-size:22px;font-weight:700;color:var(--text);
  position:relative;
}
.ex-score-ring::before{
  content:'';position:absolute;inset:10px;background:var(--surface);border-radius:50%;
}
.ex-score-num{position:relative;z-index:1}
.ex-complete-title{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:4px}
.ex-complete-sub{font-size:13px;color:var(--text3)}
.ex-stat-row{display:flex;gap:10px}
.ex-stat-box{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;text-align:center}
.ex-stat-num{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text);margin-bottom:2px}
.ex-stat-lbl{font-size:11px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.ex-weak-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px}
.ex-weak-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:10px}
.ex-weak-item{font-size:13px;color:var(--text2);padding:6px 0;border-bottom:1px solid var(--border);display:flex;gap:8px}
.ex-weak-item:last-child{border-bottom:none}
.ex-weak-item::before{content:'•';color:var(--red)}
.ex-complete-actions{display:flex;flex-direction:column;gap:8px}
.ex-action-btn{
  padding:14px;border-radius:var(--r);font-size:15px;font-weight:700;
  cursor:pointer;font-family:inherit;border:none;transition:all .15s;
}
.ex-action-btn.primary{background:var(--blue);color:#fff}
.ex-action-btn.primary:hover{background:#1a3a80}
.ex-action-btn.secondary{background:var(--surface);border:1.5px solid var(--border);color:var(--text2)}
.ex-action-btn.secondary:hover{border-color:var(--border2);color:var(--text)}
/* Grammar ↔ Exercise bridge */
.grammar-ex-btn{
  display:flex;align-items:center;gap:8px;
  width:100%;margin-top:16px;padding:12px 16px;
  background:var(--blue);color:#fff;border:none;border-radius:var(--r);
  font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;
  transition:background .15s;
}
.grammar-ex-btn:hover{background:#1a3a80}
.grammar-ex-btn svg{flex-shrink:0}
.grammar-ex-btn-empty{
  display:flex;align-items:center;gap:8px;
  width:100%;margin-top:14px;padding:10px 14px;
  background:var(--surface2);color:var(--text3);border:1.5px dashed var(--border2);
  border-radius:var(--r);font-size:13px;cursor:default;font-family:inherit;
}
.ex-grammar-source{
  background:var(--blue-lt);border:1px solid var(--blue);border-radius:var(--r-sm);
  padding:8px 12px;margin-bottom:12px;font-size:12px;color:var(--blue);
  display:flex;align-items:center;gap:8px;
}
.ex-grammar-source strong{font-weight:700}
.ex-learning-goal{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);
  padding:9px 12px;margin-bottom:12px;font-size:12px;color:var(--text2);line-height:1.45;
}
.ex-launch-context{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);
  padding:8px 12px;margin-bottom:10px;font-size:12px;color:var(--text3);
}
.ex-return-grammar-btn{
  padding:14px;border-radius:var(--r);font-size:15px;font-weight:700;
  cursor:pointer;font-family:inherit;border:none;transition:all .15s;
  background:var(--surface);border:1.5px solid var(--blue);color:var(--blue);
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.ex-return-grammar-btn:hover{background:var(--blue-lt)}

/* Learn hub: Exam Prep + Vocabulary */
.learn-switcher{
  display:flex;gap:6px;margin-bottom:14px;overflow-x:auto;scrollbar-width:none;
}
.learn-switcher button{
  flex:1;min-width:max-content;padding:9px 11px;border-radius:var(--r-full);
  border:1px solid var(--border);background:var(--surface);color:var(--text2);
  font-family:inherit;font-size:12px;font-weight:700;cursor:pointer;
}
.learn-switcher button.active{background:var(--blue);border-color:var(--blue);color:#fff}
.learn-dashboard{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:14px;
}
.learn-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:12px;cursor:pointer;transition:all .15s;min-height:92px;
}
.learn-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.learn-card-core{border-color:var(--blue);background:linear-gradient(180deg,var(--surface),var(--surface2))}
.learn-card-support{opacity:.92}
.learn-card-icon{font-size:20px;margin-bottom:7px}
.learn-card-title{font-size:13px;font-weight:800;color:var(--text);margin-bottom:3px}
.learn-card-sub{font-size:11px;color:var(--text3);line-height:1.35}
.exam-filter-row,.vocab-filter-row{
  display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin-bottom:10px;
}
.exam-filter-row button,.vocab-filter-row button{
  padding:7px 10px;border-radius:var(--r-full);border:1px solid var(--border);
  background:var(--surface);color:var(--text2);font-family:inherit;font-size:11px;font-weight:700;
  cursor:pointer;white-space:nowrap;
}
.exam-filter-row button.active,.vocab-filter-row button.active{background:var(--blue-lt);border-color:var(--blue);color:var(--blue)}
.exam-card,.vocab-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:13px 14px;margin-bottom:8px;transition:all .15s;
}
.exam-card:hover,.vocab-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.exam-card-top,.vocab-card-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px}
.exam-title,.vocab-word{font-size:14px;font-weight:800;color:var(--text);line-height:1.25}
.exam-meta,.vocab-meta{font-size:11px;color:var(--text3);line-height:1.45}
.exam-badges,.vocab-badges{display:flex;gap:5px;flex-wrap:wrap;margin:8px 0}
.exam-badge,.vocab-badge{
  font-size:10px;font-weight:800;border-radius:var(--r-full);padding:3px 8px;
  background:var(--surface2);border:1px solid var(--border);color:var(--text2);
}
.exam-badge.hot{background:var(--gold-lt);border-color:var(--gold-dim);color:var(--gold)}
.exam-actions,.vocab-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.exam-btn,.vocab-btn{
  border:none;border-radius:var(--r);padding:10px 12px;background:var(--blue);
  color:#fff;font-family:inherit;font-size:12px;font-weight:800;cursor:pointer;
}
.exam-btn.secondary,.vocab-btn.secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text2)}
.exam-strategy{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:11px 12px;margin-bottom:10px;
}
.exam-strategy summary{cursor:pointer;font-size:12px;font-weight:800;color:var(--text)}
.exam-strategy-grid{display:grid;gap:8px;margin-top:10px}
.exam-tip-card{
  background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--blue);
  border-radius:var(--r-sm);padding:9px 10px;
}
.exam-tip-card.trap{border-left-color:var(--red)}
.exam-tip-card.score{border-left-color:var(--green)}
.exam-tip-card.phrase{border-left-color:var(--gold)}
.exam-tip-label{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:4px}
.exam-tip-text{font-size:12px;color:var(--text2);line-height:1.45}
.exam-section-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:13px 14px;margin-bottom:12px;
}
.exam-section-title{font-size:14px;font-weight:800;color:var(--text);margin-bottom:4px}
.exam-question-card{background:var(--surface2);border-radius:var(--r);padding:11px 12px;margin-top:10px}
.exam-question-prompt{font-size:13px;color:var(--text);line-height:1.5;margin-bottom:8px}
.exam-input,.vocab-search-input{
  width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:10px 12px;color:var(--text);font-family:inherit;font-size:13px;margin-top:7px;
}
.exam-input:focus,.vocab-search-input:focus{outline:none;border-color:var(--blue)}
.exam-review-item{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px;margin-bottom:8px;
}
.vocab-progress-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.vocab-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px;text-align:center}
.vocab-stat-num{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text)}
.vocab-stat-lbl{font-size:10px;color:var(--text3);font-weight:800;text-transform:uppercase}
.vocab-card{cursor:pointer}
.vocab-meaning{font-size:12px;color:var(--text2);line-height:1.4}
.vocab-master{font-size:11px;color:var(--green);font-weight:700}
.vocab-practice-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:20px 16px;text-align:center;margin-bottom:14px;
}
.vocab-front{font-family:'DM Serif Display',serif;font-size:26px;color:var(--text);margin-bottom:8px}
.vocab-back{font-size:14px;color:var(--text2);line-height:1.55;text-align:left;background:var(--surface2);border-radius:var(--r);padding:12px;margin-top:12px}
.vocab-mode-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}
.vocab-mode-grid button{min-height:48px}
.vocab-memory-card{
  background:var(--blue-lt);border:1px solid var(--blue-dim);border-radius:var(--r-lg);
  padding:11px 12px;margin:12px 0;text-align:left;color:var(--text2);font-size:12px;line-height:1.45;
}
.vocab-clue-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;margin:10px 0}
.vocab-clue{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px;font-size:11px;color:var(--text2);text-align:left}
.dictionary-entry-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:13px 14px;margin-bottom:8px;cursor:pointer;transition:all .15s;
}
.dictionary-entry-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.dictionary-headword{font-size:15px;font-weight:800;color:var(--text);margin-bottom:5px}
.dictionary-translation{font-size:13px;color:var(--text2);line-height:1.45;margin:5px 0}
.dictionary-result-meta{font-size:11px;color:var(--text3);font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.dictionary-synonyms{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.dictionary-chip{font-size:11px;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-full);padding:3px 8px}
.dictionary-chip.source{background:var(--blue-lt);border-color:var(--blue-dim);color:var(--text)}
.dictionary-source-note{background:var(--gold-lt);border:1px solid var(--gold-dim);color:var(--text2);border-radius:var(--r-lg);padding:11px 12px;font-size:12px;line-height:1.45;margin-bottom:12px}
.dictionary-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:10px 0 12px}
.dictionary-stat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-lg);padding:9px;text-align:center}
.dictionary-stat strong{display:block;color:var(--text);font-size:17px}
.dictionary-stat span{font-size:10px;color:var(--text3);font-weight:800;text-transform:uppercase}
.dictionary-direction-toggle{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin:0 0 10px}
.dictionary-direction-toggle button{border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:var(--r-lg);padding:10px 8px;font-size:12px;font-weight:900;font-family:inherit}
.dictionary-direction-toggle button.active{background:var(--blue);border-color:var(--blue);color:white}
.dictionary-result-count{font-size:12px;color:var(--text3);font-weight:800;margin:9px 0 12px}
.dictionary-grammar-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.dictionary-grammar-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-lg);padding:8px;font-size:12px;color:var(--text2);line-height:1.35}
.dictionary-license{font-size:11px;color:var(--text3);line-height:1.45;margin-top:10px}
.dictionary-filter-row{display:flex;gap:7px;overflow-x:auto;padding:3px 0 10px;margin-bottom:6px}
.dictionary-filter-row button{white-space:nowrap;border:1px solid var(--border);background:var(--surface2);color:var(--text2);border-radius:var(--r-full);padding:7px 11px;font-size:11px;font-weight:800;font-family:inherit}
.dictionary-filter-row button.active{background:var(--blue);border-color:var(--blue);color:white}
.dictionary-detail-section{margin-top:12px}
.dictionary-detail-title{font-size:11px;color:var(--text3);font-weight:900;text-transform:uppercase;margin:10px 0 6px}
.dictionary-example{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-lg);padding:9px 10px;color:var(--text2);font-size:12px;line-height:1.5;margin-top:6px}
.dictionary-upload-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
/* Grammar spotlight clickable */
.grammar-spotlight{cursor:default}
.gs-grammar-link{
  display:inline-flex;align-items:center;gap:6px;margin-top:10px;
  padding:7px 12px;background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--r-sm);font-size:12px;color:var(--text2);cursor:pointer;
  transition:all .15s;font-family:inherit;
}
.gs-grammar-link:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-lt)}
.gs-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.gs-mistake{
  margin-top:8px;background:var(--red-lt);border-left:3px solid var(--red-dim);
  border-radius:var(--r-sm);padding:7px 10px;font-size:12px;color:var(--text2);line-height:1.45;
}
.gs-topic-title{font-weight:700;color:var(--text);margin-top:8px;font-size:12px}

/* Phase 01 scenario cards keep the legacy .sc-row hook for smoke tests/old onclick paths. */
.dm-scenario-card.sc-row{
  width:100%;
  min-height:118px;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:var(--dm-s-3);
  margin:0 0 var(--dm-s-2);
  padding:var(--dm-s-4);
  background:var(--dm-surface);
  color:var(--dm-ink);
  border:1px solid var(--dm-line);
  border-radius:var(--dm-r-sm);
  box-shadow:var(--dm-shadow-card);
  text-align:left;
}
.dm-scenario-card.sc-row:hover{
  border-color:var(--dm-line-2);
  box-shadow:var(--dm-shadow-raised);
}

/* Phase 08 desktop polish, accessibility affordances, and scalable shell layout. */
:where(button, a, input, select, textarea, [tabindex]):focus-visible{
  outline:2px solid var(--dm-focus-ring, var(--primary));
  outline-offset:3px;
}

.tab-item,
.level-pill,
.dm-btn,
.dm-home-reroll,
.dm-account-row,
.dm-dictionary-result,
.phrase-audio,
.practice-round-btn,
.progress-btn,
.dm-practice-mode-pill{
  min-height:var(--dm-tap-min, 44px);
}

.dm-range-control{
  display:grid;
  grid-template-columns:minmax(140px,1fr) auto;
  align-items:center;
  gap:10px;
  min-width:190px;
}
.dm-range-control input{accent-color:var(--primary)}
.dm-range-control span{
  color:var(--text2);
  font-size:12px;
  font-weight:800;
  min-width:52px;
  text-align:right;
}

@media (min-width: 720px){
  .dm-home-mini-brief,
  .dm-home-triage-row,
  .home-dash-grid,
  .home-continue-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .practice-mode-grid,
  .dm-focus-grid,
  .progress-two-col{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .dm-practice-mode-selector{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    overflow:visible;
  }
  .dm-speaking-card,
  .dm-practice-panel{
    max-width:720px;
    margin-inline:auto;
    width:100%;
  }
}

@media (min-width: 1024px){
  body{
    background:linear-gradient(135deg,#060806,#141a16);
    padding:24px;
  }
  #app{
    width:min(1180px,calc(100vw - 48px));
    height:min(900px,calc(100dvh - 48px));
    border-radius:28px;
    display:grid;
    grid-template-columns:220px minmax(0,1fr);
    grid-template-rows:auto minmax(0,1fr);
  }
  #top-header{
    grid-column:1 / -1;
    padding-inline:24px;
  }
  #screen-wrap{
    grid-column:2;
    grid-row:2;
    min-width:0;
  }
  #tab-bar{
    grid-column:1;
    grid-row:2;
    display:flex;
    flex-direction:column;
    gap:8px;
    padding:18px 14px;
    border-top:0;
    border-right:1px solid var(--border);
    overflow:auto;
  }
  .tab-item{
    width:100%;
    flex:0 0 auto;
    flex-direction:row;
    justify-content:flex-start;
    gap:12px;
    padding:12px 14px;
    font-size:13px;
    text-align:left;
  }
  .tab-item svg{width:22px;height:22px}
  .tab-item .tab-dot{
    margin-left:auto;
    margin-top:0;
  }
  .home-body{
    padding:24px;
  }
  .dm-home-dashboard{
    max-width:900px;
  }
  .scenarios-body{
    display:flex;
    flex-direction:column;
    gap:16px;
    max-width:1120px;
    margin-inline:auto;
    width:100%;
  }
  .scenarios-body > .dm-search{
    max-width:420px;
  }
  .scenarios-body > .level-pills,
  .scenario-context-pills{
    flex-wrap:wrap;
    overflow:visible;
    margin-bottom:4px;
  }
  #scenarios-list{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    align-items:start;
  }
  .dm-scenario-card.sc-row{
    margin:0;
  }
  .prep-body{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(280px,360px);
    gap:18px;
    align-items:start;
  }
  .phrase-cards{
    grid-column:1;
  }
  .context-box,
  .grammar-spotlight{
    grid-column:2;
    position:sticky;
    top:16px;
  }
  .dm-grammar-topic-flow{
    max-width:980px;
    margin-inline:auto;
    grid-template-columns:minmax(0,640px) minmax(240px,1fr);
    align-items:start;
  }
  .dm-grammar-topic-hero{
    grid-column:1 / -1;
  }
  .dm-grammar-flow-progress{
    grid-column:2;
    grid-row:2 / span 4;
    position:sticky;
    top:16px;
    align-content:start;
    flex-direction:column;
    overflow:visible;
  }
  .progress-screen{
    max-width:980px;
    margin-inline:auto;
  }
  .progress-metric-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .progress-metric-grid--compact{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .dm-cefr-rail{
    grid-template-columns:repeat(5,minmax(0,1fr));
  }
}

@media (min-width: 1280px){
  #scenarios-list{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

/* -----------------------------------------------------------------
   Claude Design alignment pass
   Product shape: coach dashboard -> scenarios -> grammar -> practice
   engine -> improve-next progress. This layer intentionally changes
   visible hierarchy without touching data, backend, sync, quota, or
   speech evaluation plumbing.
   ----------------------------------------------------------------- */
:root,
[data-theme="light"]{
  --bg:var(--dm-canvas);
  --surface:var(--dm-surface);
  --surface2:var(--dm-surface-sunken);
  --surface3:#eee7dc;
  --border:var(--dm-line);
  --border2:var(--dm-line-2);
  --text:var(--dm-ink);
  --text2:var(--dm-ink-2);
  --text3:var(--dm-ink-3);
  --primary:#17633d;
  --primary-h:#124f31;
  --gold:var(--dm-brass);
  --gold-lt:var(--dm-brass-tint);
  --green:#17633d;
  --green-lt:#e5efdf;
  --shadow:var(--dm-shadow-card);
  --shadow-lg:var(--dm-shadow-modal);
}

body{background:#0d1014}
#app{background:var(--dm-canvas);color:var(--dm-ink)}
#top-header{display:none}
#screen-wrap{background:var(--dm-canvas)}
.screen{background:var(--dm-canvas)}
.home-body,
.scenarios-body,
.practice-inner,
.progress-screen-inner,
#grammar-inner{padding:16px 16px calc(18px + env(safe-area-inset-bottom))}

.dm-screen-local-head{
  align-items:center;
  display:flex;
  justify-content:space-between;
  margin:0 0 16px;
  min-height:48px;
}
.dm-screen-local-head h1{
  color:var(--dm-ink);
  font:700 22px/1.15 var(--dm-font-sans);
  margin:0;
}
.dm-screen-local-head p{
  color:var(--dm-ink-3);
  font-size:12px;
  margin:2px 0 0;
}
.dm-local-head-actions{display:flex}
.dm-floating-action-rail,
#top-header .hdr-actions{
  align-items:center;
  background:rgba(255,253,248,.86);
  border:1px solid rgba(222,213,199,.9);
  border-radius:999px;
  box-shadow:0 10px 26px rgba(50,38,24,.11);
  display:inline-flex;
  flex:0 0 auto;
  gap:3px;
  min-height:52px;
  padding:4px;
}
.dm-floating-action-btn,
.dm-local-icon,
.dm-local-avatar{
  align-items:center;
  border:0;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  flex:0 0 44px;
  font:800 12px var(--dm-font-sans);
  height:44px;
  justify-content:center;
  min-width:44px;
  transition:background .15s ease, color .15s ease, transform .15s ease;
}
.dm-floating-action-btn svg,
.dm-local-icon svg,
.dm-local-avatar svg{
  height:23px;
  width:23px;
}
.dm-local-icon,
.dm-floating-action-btn{
  background:transparent;
  color:var(--dm-ink-2);
}
.dm-local-avatar,
.dm-floating-action-btn--account{
  background:#2b2a35;
  color:#fff;
}
.dm-floating-action-btn:hover,
.dm-local-icon:hover{background:var(--dm-surface-sunken);color:var(--dm-ink)}
.dm-floating-action-btn:active,
.dm-local-icon:active,
.dm-local-avatar:active{transform:scale(.96)}
.dm-floating-action-btn:focus-visible,
.dm-local-icon:focus-visible,
.dm-local-avatar:focus-visible{box-shadow:var(--dm-focus-ring);outline:none}

/* Navigation */
#tab-bar{
  background:rgba(255,255,255,.92);
  border-top:1px solid var(--dm-line);
  backdrop-filter:blur(16px);
}
.tab-item{color:var(--dm-ink-3);font-size:10px;text-transform:uppercase}
.tab-item.active{color:var(--dm-brass)}
.tab-item.active .tab-dot{background:var(--dm-brass)}

/* Home coach dashboard */
.dm-home-dashboard{
  display:grid;
  gap:14px;
  margin:0 auto;
  max-width:440px;
}
.dm-home-band{margin:0}
.dm-home-band__eyebrow{
  color:var(--dm-ink-3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  margin:0 0 8px;
  text-transform:uppercase;
}
.dm-home-mission-card{
  background:var(--dm-brass);
  border:0;
  border-radius:14px;
  box-shadow:0 18px 36px rgba(196,146,74,.26);
  color:var(--dm-ink-on-brass);
  padding:18px 18px 16px;
}
.dm-home-kicker{
  color:rgba(28,24,21,.62);
  display:block;
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  margin-bottom:8px;
  text-transform:uppercase;
}
.dm-home-kicker small{display:none}
.dm-home-mission-card h2{
  color:var(--dm-ink-on-brass);
  font:400 24px/1.1 var(--dm-font-serif);
  margin:0 0 6px;
}
.dm-home-mission-card p{
  color:rgba(28,24,21,.74);
  font-size:14px;
  line-height:1.35;
  margin:0;
}
.dm-home-mission-card .dm-home-wide-btn{
  background:#1c1815;
  border:0;
  border-radius:999px;
  box-shadow:none;
  color:#fff;
  font-weight:900;
  margin:16px 0 10px;
  min-height:52px;
  width:100%;
}
.dm-home-reason{
  font-size:12px !important;
  text-align:center;
}
.dm-home-mini-brief,
.dm-home-mission-meta{display:none}
.dm-home-continue-card,
.dm-home-recommended-card,
.dm-home-grammar-card,
.dm-home-triage-card{
  background:var(--dm-surface);
  border:1px solid var(--dm-line);
  border-radius:13px;
  box-shadow:var(--dm-shadow-card);
  color:var(--dm-ink);
  text-align:left;
}
.dm-home-continue-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:2px 10px;
  padding:15px 18px;
  width:100%;
}
.dm-home-continue-card span,
.dm-practice-chooser .practice-section-title,
.dm-practice-recent .practice-section-title{
  color:var(--dm-ink-3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.dm-home-continue-card strong{font-size:16px}
.dm-home-continue-card small{color:var(--dm-ink-2);font-size:12px}
.dm-home-continue-card em{
  align-self:center;
  color:var(--dm-brass);
  font-size:22px;
  font-style:normal;
  grid-row:1 / span 3;
  grid-column:2;
}
.dm-home-triage-row{
  display:grid;
  gap:10px;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.dm-home-triage-card{
  min-height:92px;
  padding:12px;
}
.dm-home-triage-card strong{
  display:block;
  font-size:14px;
  line-height:1.2;
  margin:6px 0 4px;
}
.dm-home-triage-card small{color:var(--dm-ink-2);font-size:11px}
.dm-home-recommended-card,
.dm-home-grammar-card{padding:16px}
.dm-home-recommended-card h3,
.dm-home-grammar-card h3{font-size:18px;line-height:1.2;margin:6px 0}
.dm-home-recommended-card .dm-btn,
.dm-home-grammar-card .dm-btn{display:none}

/* Scenarios */
.scenarios-body{gap:18px}
.scenarios-hero{
  background:var(--dm-brass);
  border:0;
  border-radius:18px;
  box-shadow:0 18px 36px rgba(196,146,74,.24);
  color:var(--dm-ink-on-brass);
  margin:0 0 18px;
  padding:24px;
}
.scenarios-hero__top{
  align-items:center;
  display:flex;
  gap:12px;
  justify-content:space-between;
  margin-bottom:8px;
}
.scenarios-hero__top .hero-eyebrow{min-width:0}
.scenarios-hero .dm-floating-action-rail{
  background:rgba(255,253,248,.72);
  border-color:rgba(255,253,248,.6);
  box-shadow:0 12px 24px rgba(28,24,21,.12);
}
.scenarios-hero h1{
  color:var(--dm-ink-on-brass);
  font:400 34px/1.05 var(--dm-font-serif);
  margin:8px 0;
}
.scenarios-hero p{color:rgba(28,24,21,.74);font-size:16px;line-height:1.35}
.scenarios-hero .hero-eyebrow{color:rgba(28,24,21,.62)}
.dm-search{
  align-items:center;
  background:#fffdf8;
  border:1.5px solid #ded5c7;
  border-radius:16px;
  box-shadow:0 6px 16px rgba(60,45,25,.045);
  display:flex;
  min-height:52px;
  padding:0 14px;
}
.dm-search--scenario{margin:0 0 18px}
.dm-search--scenario:focus-within{
  border-color:var(--dm-brass);
  box-shadow:0 0 0 3px rgba(196,146,74,.16);
}
.dm-search-icon{color:var(--dm-ink-3);height:20px;width:20px}
.dm-search-input{
  -webkit-appearance:none;
  appearance:none;
  background:transparent;
  border:0;
  box-shadow:none;
  color:var(--dm-ink);
  flex:1;
  font:500 16px/1.25 var(--dm-font-sans);
  height:auto;
  min-width:0;
  outline:0;
  padding:12px 8px;
}
.dm-search-input:focus{box-shadow:none;outline:0}
.dm-search-input::-webkit-search-decoration,
.dm-search-input::-webkit-search-cancel-button,
.dm-search-input::-webkit-search-results-button,
.dm-search-input::-webkit-search-results-decoration{-webkit-appearance:none}
.dm-search-input::placeholder{color:#9c9285;opacity:1}
.level-pills{
  gap:10px;
  margin-bottom:20px;
  overflow-x:auto;
  padding-bottom:2px;
}
.level-pill{
  background:#fffdf8;
  border:2px solid #e0d7c9;
  border-radius:999px;
  color:var(--dm-ink-2);
  font-size:15px;
  min-height:54px;
  padding:0 20px;
}
.level-pill.active{
  background:var(--dm-brass);
  border-color:var(--dm-brass);
  color:var(--dm-ink-on-brass);
}
.level-pill.pill-a1.active,
.level-pill.pill-a2.active,
.level-pill.pill-b1.active,
.level-pill.pill-b2.active,
.level-pill.pill-c1.active,
.level-pill.dm-pill--context.active{
  background:var(--dm-brass);
  border-color:var(--dm-brass);
  color:var(--dm-ink-on-brass);
}
.level-pill.active .dm-pill-dot{background:rgba(28,24,21,.55)}
.cat-header{padding:16px 0 10px}
.cat-name{font-size:20px;line-height:1.2}
.cat-meta{font-size:14px;line-height:1.25}
.cat-chevron{transform:rotate(90deg)}
.cat-section.open .cat-chevron{transform:rotate(-90deg)}
.cat-scenarios{gap:10px}
.dm-scenario-card.sc-row{
  border-radius:8px;
  min-height:128px;
  padding:18px;
}
.dm-scenario-card .sc-title,
.dm-scenario-card__title{font-size:20px;font-weight:700;line-height:1.12}

/* Scenario prep */
.dm-prep-screen{
  background:var(--dm-canvas);
  min-height:100%;
}
.dm-prep-header,
.dm-topic-top,
.dm-feedback-top{
  align-items:center;
  display:grid;
  grid-template-columns:44px 1fr 44px;
  min-height:56px;
  padding:10px 16px 4px;
}
.dm-prep-header-title,
.dm-topic-top span{
  color:var(--dm-ink-3);
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-align:center;
  text-transform:uppercase;
}
.dm-prep-close,
.dm-topic-close{
  background:var(--dm-surface-sunken);
  border:0;
  border-radius:999px;
  color:var(--dm-ink-2);
}
.dm-prep-shell{padding:0 18px 92px}
.dm-prep-label{display:none}
.dm-prep-meta{margin:8px 0 16px}
.dm-prep-intro h2{
  font:400 32px/1.05 var(--dm-font-serif);
  margin:0 0 8px;
}
.dm-prep-card{
  border-radius:14px;
  box-shadow:var(--dm-shadow-card);
}
.dm-prep-phrase{
  align-items:center;
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:13px;
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  padding:12px 14px;
}
.dm-prep-phrase-audio{
  grid-column:1;
  grid-row:1;
  margin-right:10px;
}
.dm-prep-phrase-num{display:none}
.dm-prep-footer{
  background:linear-gradient(to top,var(--dm-canvas) 72%,rgba(250,247,241,0));
  bottom:0;
  padding:28px 18px 18px;
  position:sticky;
}
.dm-prep-start{
  background:var(--dm-brass);
  border:0;
  border-radius:999px;
  color:#1c1815;
  min-height:54px;
  width:100%;
}

/* Scenario conversation */
.dm-convo-screen{
  background:#14100c;
  color:#eee4d6;
  display:flex;
  flex-direction:column;
  height:100%;
  overflow:hidden;
  padding:18px 18px 22px;
}
.dm-convo-screen .conv-header{
  background:transparent;
  border:0;
  color:#b9ae9d;
  display:grid;
  grid-template-columns:44px 1fr 44px;
  padding:0;
}
.dm-convo-screen .conv-back,
.dm-convo-screen .conv-menu{
  background:rgba(255,255,255,.06);
  border:0;
  border-radius:999px;
  color:#b9ae9d;
  height:44px;
  width:44px;
}
.dm-convo-screen .conv-scenario{
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  text-align:center;
  text-transform:uppercase;
}
.dm-convo-screen .conv-meta,
.dm-convo-screen .timer-bar,
.dm-convo-screen .session-warning{display:none !important}
.dm-convo-screen .chat-messages{
  background:transparent;
  display:flex;
  flex:1;
  flex-direction:column;
  gap:10px;
  justify-content:flex-end;
  overflow-y:auto;
  padding:24px 0;
}
.dm-convo-screen .msg-group{max-width:100%}
.dm-convo-screen .msg-bubble{
  background:#262018;
  border:1px solid rgba(255,255,255,.04);
  border-radius:14px;
  color:#e8ded0;
  font-size:20px;
  line-height:1.25;
  padding:16px;
}
.dm-convo-screen .msg-group.user .msg-bubble{
  background:#221d18;
  color:#bfb4a4;
  font-size:18px;
}
.dm-convo-screen .conv-input-wrap{
  background:transparent;
  border:0;
  padding:0;
}
.dm-convo-screen .transcript-preview{
  background:transparent;
  border:0;
  color:#9fbf73;
  font-weight:800;
  margin:8px 0;
  min-height:20px;
  text-align:center;
}
.dm-convo-screen .scenario-quick-row{
  display:grid;
  gap:8px;
  grid-template-columns:repeat(2,minmax(0,1fr));
  margin:0 0 10px;
}
.dm-convo-screen .scenario-quick-row button{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  color:#e5d9c8;
  font:800 12px/1 var(--dm-font-sans);
  min-height:38px;
  padding:0 10px;
}
.dm-convo-screen .scenario-quick-row button:disabled{opacity:.55}
.dm-convo-screen .input-row{
  display:flex;
  align-items:center;
  flex-direction:column;
  gap:10px;
}
.dm-convo-screen .scenario-text-row{
  display:flex;
  gap:8px;
  width:100%;
}
.dm-convo-screen .text-input-wrap{
  display:block;
  flex:1;
  min-width:0;
}
.dm-convo-screen .chat-text-input{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  color:#f8f0e6;
  font:600 14px/1.2 var(--dm-font-sans);
  min-height:44px;
  padding:0 14px;
  width:100%;
}
.dm-convo-screen .chat-text-input::placeholder{color:#8f8476}
.dm-convo-screen .chat-text-input:focus{
  border-color:rgba(196,146,74,.74);
  outline:0;
}
.dm-convo-screen .send-btn{
  align-items:center;
  background:var(--dm-brass);
  border:0;
  border-radius:999px;
  color:#14100c;
  display:inline-flex;
  font:900 13px/1 var(--dm-font-sans);
  justify-content:center;
  min-height:44px;
  min-width:70px;
  padding:0 16px;
}
.dm-convo-screen .send-btn:disabled{
  background:rgba(255,255,255,.1);
  color:#756b5f;
}
.dm-convo-screen .scenario-action-status{
  color:#cfc5b7;
  font-size:12px;
  line-height:1.35;
  min-height:16px;
  text-align:center;
}
.dm-convo-screen .scenario-action-status[data-status="error"]{color:#f0a89c}
.dm-convo-screen .scenario-action-status[data-status="result"]{color:#9fbf73}
.dm-convo-screen .dm-mic{
  align-self:center;
  background:var(--dm-brass);
  border-radius:999px;
  box-shadow:0 0 0 8px rgba(196,146,74,.18),0 14px 34px rgba(0,0,0,.28);
  color:#14100c;
  height:88px;
  min-width:88px;
  padding:0;
  width:88px;
}
.dm-convo-screen .dm-mic-copy{display:none}
.dm-convo-screen .dm-mic-icon{font-size:32px}

/* Scenario feedback */
.dm-feedback-panel{
  background:var(--dm-canvas);
  min-height:100%;
  padding:0 18px 24px;
}
.dm-feedback-hero h2{
  font:400 28px/1.08 var(--dm-font-serif);
  margin:8px 0 14px;
}
.dm-feedback-kicker{
  color:var(--dm-ink-3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.dm-feedback-score-row{display:flex;flex-wrap:wrap;gap:8px}
.dm-feedback-score-row span{
  background:#f0dfc4;
  border-radius:999px;
  color:#6a4f23;
  font-size:12px;
  font-weight:800;
  padding:8px 10px;
}
.dm-feedback-score-row span + span{background:#efd8d0;color:#8d483c}
.dm-feedback-tier--t2{
  background:var(--dm-brass);
  border:0;
  border-radius:14px;
  color:#1c1815;
  margin:18px 0;
  padding:16px;
}
.dm-feedback-tier--t2 span{color:rgba(28,24,21,.62)}
.dm-feedback-drill{
  background:#1c1815 !important;
  border:0 !important;
  border-radius:999px !important;
  color:#fff !important;
  width:100%;
}
.dm-feedback-next{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:14px;
  display:grid;
  gap:6px;
  margin-top:16px;
  padding:16px;
}

/* Grammar */
.dm-grammar-index{
  display:grid;
  gap:12px;
  padding:16px;
}
.dm-grammar-index-head{
  align-items:center;
  background:transparent !important;
  border:0 !important;
  display:flex;
  gap:16px;
  justify-content:space-between;
  box-shadow:none !important;
  padding:0;
}
.dm-grammar-index-head > div:first-child,
.dm-screen-local-head > div:first-child,
.dm-progress-claude-head > h2{
  min-width:0;
}
.dm-progress-claude-head{
  gap:16px;
}
.dm-grammar-index-head h2,
.dm-grammar-topic-hero h2,
.progress-topline h2,
.dm-paywall-hero h2{
  color:var(--dm-ink);
  font:400 30px/1.08 var(--dm-font-serif);
}
.dm-grammar-index-intro{
  color:var(--dm-ink-2);
  display:grid;
  gap:6px;
  grid-template-columns:minmax(0,1fr) auto;
}
.dm-grammar-index-intro .dm-kicker,
.dm-grammar-index-intro p{grid-column:1}
.dm-grammar-count{grid-column:2;grid-row:1 / span 2;align-self:start}
.dm-grammar-improve{
  background:var(--dm-brass);
  border:0;
  border-radius:12px;
  box-shadow:0 18px 36px rgba(196,146,74,.22);
  color:#1c1815;
  padding:18px;
}
.dm-grammar-improve span,
.dm-grammar-improve em{color:rgba(28,24,21,.64)}
.dm-grammar-improve strong{font-size:20px}
.dm-grammar-topic-row{
  border-radius:13px;
  grid-template-columns:minmax(0,1fr) auto;
  min-height:72px;
}
.dm-grammar-topic-row-level{display:none}
.dm-grammar-topic-row-main strong{font-size:18px}
.dm-grammar-topic-flow{padding:0 16px 24px}
.dm-topic-top{padding-inline:0}
.dm-grammar-topic-hero{padding:0}
.dm-grammar-flow-progress{
  display:grid;
  gap:6px;
  grid-template-columns:repeat(7,1fr);
  overflow:visible;
}
.dm-grammar-flow-progress a{
  background:#d8c4a4;
  border:0;
  border-radius:999px;
  color:transparent;
  height:4px;
  overflow:hidden;
  padding:0;
}
.dm-grammar-flow-progress a:first-child,
.dm-grammar-flow-progress a:nth-child(2),
.dm-grammar-flow-progress a:nth-child(3){background:var(--dm-brass)}
.dm-grammar-topic-level{
  background:transparent;
  border:0;
  color:var(--dm-ink-3);
  font-size:11px;
  letter-spacing:.1em;
  padding:0;
  text-transform:uppercase;
}
.dm-grammar-stage{
  background:transparent;
  border:0;
  padding:16px 0;
}
.dm-grammar-stage-head h3{
  font:400 26px/1.1 var(--dm-font-serif);
}
.dm-grammar-mistake-pair,
.dm-grammar-example,
.dm-grammar-drill-item,
.dm-grammar-apply-card,
.dm-grammar-mastery-panel{
  background:#fff;
  border-radius:14px;
  padding:16px;
}
.dm-grammar-stage-actions .dm-btn-primary{
  background:var(--dm-brass);
  border:0;
  border-radius:999px;
  color:#1c1815;
  min-height:52px;
  width:100%;
}

/* Practice chooser and sentence repeat */
.dm-practice-clean{background:var(--dm-canvas);min-height:100%}
.dm-practice-clean .practice-hub-body{
  display:grid;
  gap:18px;
  padding:0;
}
.dm-practice-chooser{
  display:grid;
  gap:12px;
  padding:0 14px;
}
.dm-practice-choice,
.dm-practice-recent-card{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:14px;
  box-shadow:var(--dm-shadow-card);
  color:var(--dm-ink);
  display:grid;
  gap:4px;
  min-height:96px;
  padding:18px;
  position:relative;
  text-align:left;
  width:100%;
}
.dm-practice-choice--recommended{
  background:var(--dm-brass);
  border:0;
}
.dm-practice-drill-group{
  background:rgba(255,255,255,.62);
  border:1px solid var(--dm-line);
  border-radius:18px;
  display:grid;
  gap:10px;
  padding:10px;
}
.dm-practice-drill-head{
  align-items:center;
  display:flex;
  justify-content:space-between;
  padding:2px 4px 0;
}
.dm-practice-drill-head span{
  color:var(--dm-ink);
  font-size:13px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.dm-practice-drill-head small{
  color:var(--dm-ink-3);
  font-size:12px;
  font-weight:700;
}
.dm-practice-choice--grammar{
  background:#fff;
  border-color:rgba(203,151,73,.42);
}
.dm-practice-choice span{
  color:rgba(28,24,21,.62);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.dm-practice-choice strong{font-size:20px;font-weight:600}
.dm-practice-choice small,
.dm-practice-recent-card small{color:var(--dm-ink-2);font-size:14px;line-height:1.35}
.challenge-desc{
  color:var(--dm-ink-2);
  font-size:15px;
  line-height:1.42;
  margin:0;
}
.dm-practice-choice em,
.dm-practice-recent-card em{
  bottom:18px;
  color:var(--dm-brass);
  font-style:normal;
  position:absolute;
  right:18px;
}
.dm-practice-choice em.practice-primary-btn{
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  color:rgba(28,24,21,.72);
  display:inline;
  font-size:13px;
  font-weight:800;
  min-height:0;
  padding:0;
  width:auto;
}
.dm-practice-choice--recommended em.practice-primary-btn{color:rgba(28,24,21,.78)}
.dm-practice-recent{padding:0 14px}

/* Free conversation setup uses the Phase 00 card system instead of the
   legacy green Practice cards, so the screen feels like the rest of the app. */
.dm-free-setup{
  background:var(--dm-canvas);
}
.dm-free-setup .practice-hub-body{
  display:grid;
  gap:14px;
  padding:18px 14px 24px;
}
.dm-free-back{
  color:var(--dm-ink-2);
  font-size:15px;
  margin:0;
  min-height:36px;
}
.dm-free-back::before{
  content:"";
  border-bottom:2px solid currentColor;
  border-left:2px solid currentColor;
  display:inline-block;
  height:8px;
  margin-right:3px;
  transform:rotate(45deg);
  width:8px;
}
.dm-free-persona-card{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:16px;
  box-shadow:var(--dm-shadow-card);
  display:grid;
  gap:8px;
  padding:18px;
}
.dm-free-eyebrow,
.dm-free-setup .setting-label{
  color:var(--dm-ink-3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.dm-free-persona-card h2{
  color:var(--dm-ink);
  font:400 28px/1.08 var(--dm-font-serif);
  margin:0;
}
.dm-free-persona-card p{
  color:var(--dm-ink-2);
  font-size:15px;
  line-height:1.42;
  margin:0;
}
.dm-free-meta{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-top:4px;
}
.dm-free-meta span{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:999px;
  color:var(--dm-ink-2);
  font-size:12px;
  font-weight:800;
  padding:6px 10px;
}
.dm-free-setup .practice-settings-card{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:16px;
  box-shadow:var(--dm-shadow-card);
  margin:0;
  padding:16px;
}
.dm-free-setup .practice-topic-input{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:12px;
  color:var(--dm-ink);
  font-size:16px;
  min-height:50px;
}
.dm-free-setup .setting-row{
  margin:0 0 16px;
}
.dm-free-setup .setting-pills{
  gap:8px;
}
.dm-free-setup .setting-pills button{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:999px;
  color:var(--dm-ink-2);
  font-size:14px;
  min-height:40px;
  padding:9px 14px;
}
.dm-free-setup .setting-pills button.active{
  background:var(--dm-brass);
  border-color:var(--dm-brass);
  color:#1c1815;
}
.dm-free-setup .challenge-desc{
  color:var(--dm-ink-2);
  font-size:16px;
  line-height:1.4;
}
.dm-free-setup .prep-footer{
  padding:2px 2px 10px;
}
.dm-free-setup .btn-start{
  background:var(--dm-brass);
  border:0;
  border-radius:999px;
  box-shadow:var(--dm-shadow-card);
  color:#1c1815;
  min-height:54px;
}
.dm-free-setup .btn-start:hover{
  background:var(--dm-brass-hover);
}
.pronunciation-screen{background:var(--dm-canvas);min-height:100%}
.pronunciation-screen .prep-back{
  background:transparent;
  border:0;
  color:var(--dm-ink-2);
  margin:8px 0;
}
.dm-speaking-card{
  background:transparent;
  border:0;
  box-shadow:none;
  padding:16px;
}
.dm-speaking-card h2{font:400 28px/1.1 var(--dm-font-serif)}
.dm-speaking-actions.compact{display:grid;gap:10px}
.dm-speaking-actions.compact .practice-secondary-btn,
.practice-secondary-btn{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:13px;
  color:var(--dm-ink-2);
  min-height:54px;
}
.pronunciation-screen .dm-mic{
  background:#79975b;
  border-radius:999px;
  box-shadow:0 18px 34px rgba(121,151,91,.2);
  color:#fff;
  margin:16px auto 0;
  max-width:360px;
  min-height:86px;
  padding:18px 24px;
  width:100%;
}
.pronunciation-screen .dm-mic-icon{
  background:rgba(255,255,255,.16);
  border-radius:999px;
  display:grid;
  height:56px;
  place-items:center;
  width:56px;
}
.dm-current-task--grammar{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:16px;
  box-shadow:var(--dm-shadow-card);
  padding:14px;
}
.dm-current-task--grammar .pron-target{
  color:var(--dm-ink);
  font-size:18px;
  line-height:1.28;
  margin:8px 0 10px;
}
.dm-grammar-task-label{
  color:var(--dm-brass);
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  margin-bottom:8px;
  text-transform:uppercase;
}
.dm-model-answer{
  background:var(--dm-surface-sunken);
  border:1px solid var(--dm-line);
  border-radius:13px;
  color:var(--dm-ink-2);
  font-size:13px;
  line-height:1.4;
  margin-top:10px;
  padding:10px 12px;
}
.dm-model-answer summary{
  color:var(--dm-ink);
  cursor:pointer;
  font-weight:900;
}
.dm-model-answer div{
  margin-top:8px;
}
.dm-speaking-results.is-grammar .pron-score-ring{
  background:conic-gradient(var(--dm-brass) calc(var(--score,0)*1%),var(--dm-surface-sunken) 0);
}
.dm-result-section--primary .pron-feedback{
  background:#fff;
  border-color:var(--dm-line);
}
.dm-speaking-status{
  background:#e7f4e8;
  border:1px solid #70aa80;
  border-radius:13px;
  color:#17633d;
  display:flex;
  justify-content:space-between;
  margin:0;
  padding:12px 14px;
}
.pron-wave{display:none !important}
.dm-result-score-grid{
  display:grid;
  gap:10px;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.dm-result-score-grid .pron-metric{
  background:#fff;
  border-radius:13px;
  padding:14px;
}

/* Progress */
.progress-screen{display:grid;gap:12px;padding:16px}
.dm-progress-claude-head{
  align-items:center;
  display:flex;
  justify-content:space-between;
}
.dm-progress-opener{
  color:var(--dm-ink-2);
  font-size:14px;
  margin:0 0 4px;
}
.dm-improve-panel,
.progress-section{
  background:transparent;
  border:0;
  box-shadow:none;
  padding:0;
}
.progress-section-head{margin-bottom:12px}
.dm-improve-list{display:grid;gap:10px}
.dm-improve-panel .progress-section-head{display:none}
.dm-improve-row{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:14px;
  box-shadow:var(--dm-shadow-card);
  min-height:96px;
  padding:16px 18px;
}
.dm-improve-row__cta{color:var(--dm-brass)}
.dm-cefr-map,
.progress-score-bars,
.progress-score-row,
.progress-two-col{display:none}

/* Paywall */
.dm-paywall-screen{background:var(--dm-canvas);padding:16px 18px 24px}
.dm-paywall-header{
  align-items:center;
  display:grid;
  grid-template-columns:44px 1fr auto;
  min-height:48px;
}
.dm-paywall-header span{
  color:var(--dm-ink-3);
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-align:center;
  text-transform:uppercase;
}
.dm-paywall-restore{
  background:transparent;
  border:0;
  color:var(--dm-brass);
  font-weight:800;
}
.dm-paywall-hero{padding:26px 0 12px}
.dm-paywall-hero h2{font-size:32px;margin:0 0 10px}
.dm-paywall-hero p{color:var(--dm-ink-2);font-size:15px;line-height:1.45}
.dm-paywall-toggle{
  display:grid;
  grid-template-columns:1fr 1fr;
  margin:12px 0;
}
.dm-paywall-toggle button{
  background:transparent;
  border:0;
  border-radius:999px;
  color:var(--dm-ink-2);
  min-height:42px;
}
.dm-paywall-toggle button.active{
  background:#1c1815;
  color:#fff;
}
.dm-tier-matrix{display:grid;gap:12px}
.dm-tier-card{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:14px;
  box-shadow:var(--dm-shadow-card);
  padding:16px 18px;
}
.dm-tier-card--popular{
  border-color:var(--dm-brass);
  box-shadow:0 0 0 1px var(--dm-brass),var(--dm-shadow-card);
}
.dm-tier-card__head{align-items:start}
.dm-tier-card h3{font-size:20px}
.dm-tier-price{font-size:22px}
.dm-tier-card .dm-btn-primary{
  background:var(--dm-brass);
  border:0;
  border-radius:999px;
  color:#1c1815;
  width:100%;
}
.dm-paywall-footer-note{
  display:grid;
  gap:8px;
  padding:8px;
  text-align:center;
}
.dm-paywall-manage{
  background:transparent;
  border:0;
  color:var(--dm-brass);
  font-weight:800;
  min-height:44px;
}

/* Account drawer */
.dm-header-backdrop{
  background:rgba(20,17,12,.48);
  inset:0;
  position:fixed;
  z-index:999;
}
.dm-account-drawer{
  background:var(--dm-canvas);
  bottom:0;
  box-shadow:var(--dm-shadow-modal);
  display:flex;
  flex-direction:column;
  max-width:360px;
  padding:28px 22px;
  position:fixed;
  right:0;
  top:0;
  width:78vw;
  z-index:1000;
}
/* The dictionary uses the same shared backdrop class as the account drawer.
   Keep its panel above that backdrop so search results stay visible/editable. */
#dm-dictionary-overlay-root .dm-header-backdrop{z-index:999}
#dm-dictionary-overlay-root .dm-dictionary-overlay{
  z-index:1000;
}
.dm-account-identity{
  align-items:center;
  display:flex;
  gap:14px;
  margin-bottom:18px;
}
.dm-account-avatar{
  background:#2b2a35;
  border-radius:999px;
  color:#fff;
  display:grid;
  font-weight:900;
  height:58px;
  place-items:center;
  width:58px;
}
.dm-account-identity h2{font-size:18px;margin:0}
.dm-account-identity p{color:var(--dm-ink-3);font-size:12px;margin:2px 0 0}
.dm-account-identity p span{
  background:#f2ddb8;
  border-radius:999px;
  color:#b37d2f;
  font-size:10px;
  font-weight:900;
  margin-right:6px;
  padding:3px 8px;
  text-transform:uppercase;
}
.dm-account-minutes{
  background:#fff;
  border:1px solid var(--dm-line);
  border-radius:12px;
  box-shadow:var(--dm-shadow-card);
  display:grid;
  gap:5px;
  margin-bottom:22px;
  padding:12px 14px;
}
.dm-account-minutes span,
.dm-account-minutes small{
  color:var(--dm-ink-3);
  font-size:11px;
}
.dm-account-minutes strong{font-size:18px}
.dm-account-minutes div{
  background:var(--dm-line);
  border-radius:999px;
  height:4px;
  overflow:hidden;
}
.dm-account-minutes i{
  background:var(--dm-brass);
  display:block;
  height:100%;
}
.dm-account-section{border:0;margin:0}
.dm-account-row{
  align-items:center;
  background:transparent;
  border:0;
  border-bottom:1px solid var(--dm-line);
  border-radius:0;
  box-shadow:none;
  color:var(--dm-ink);
  display:flex;
  justify-content:space-between;
  min-height:50px;
  padding:0 4px;
}
.dm-account-row span{font-size:16px;font-weight:500}
.dm-account-row small{color:var(--dm-brass);font-size:13px}
.dm-account-signout{
  background:transparent;
  border:1px solid var(--dm-line-2);
  border-radius:999px;
  color:var(--dm-ink-2);
  margin-top:auto;
  min-height:50px;
}

@media (min-width:1024px){
  #top-header{display:none}
  #app{
    grid-template-rows:minmax(0,1fr);
  }
  #screen-wrap{grid-column:2;grid-row:1}
  #tab-bar{grid-row:1}
}

/* Fallback global quick-action rail. Main screens render their own rail; this
   stays available for legacy/simple screens without creating loose circles. */
#top-header{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  display:flex !important;
  height:auto;
  padding:0 !important;
  pointer-events:none;
  position:absolute;
  right:max(14px, env(safe-area-inset-right));
  top:max(14px, env(safe-area-inset-top));
  width:auto;
  z-index:60;
}
#top-header .logo-wrap,
#top-header #account-btn .sr-only{display:none !important}
#top-header .logo-wrap{display:none !important}
#top-header .hdr-actions{
  pointer-events:auto;
}
#top-header #dictionary-btn{
  background:transparent;
  border:0;
  border-radius:999px;
  color:var(--dm-ink-2);
  height:44px;
  width:44px;
}
#top-header #account-btn{
  background:#2b2a35;
  border:0;
  border-radius:999px;
  color:#fff;
  height:44px;
  width:44px;
}
#app:has(.screen.active .dm-floating-action-rail) #top-header{
  display:none !important;
}

/* Focused speaking surfaces have their own controls. Hide the floating
   dictionary/account chrome there so it cannot overlap Settings or mic UI. */
#app:has(.practice-session) #top-header,
#app:has(.dm-convo-screen) #top-header,
#app:has(.dm-prep-screen) #top-header,
#app:has(.dm-feedback-panel) #top-header,
#app:has(.dm-grammar-topic-flow) #top-header,
#app:has(.dm-paywall-screen) #top-header,
#app:has(.dm-free-setup) #top-header,
#app:has(.pronunciation-screen) #top-header{
  display:none !important;
}
