/* ============================================================
   设计 tokens（详见 docs/UI设计.md）
   移动端优先：默认按移动端写，@media 升级到平板/PC
   ============================================================ */

:root {
  --bg: #0e1726;
  --card: #1a2435;
  --card-2: #232f47;
  --text: #e8eef8;
  --muted: #94a3b8;
  --primary: #7aa2ff;
  --primary-ink: #0a1020;
  --success: #4ade80;
  --error: #f87171;
  --warn: #facc15;
  --border: #2a3550;

  --radius: 12px;
  --radius-sm: 8px;
  --tap: 48px;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-6: 24px;
  --space-8: 32px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
[hidden] { display: none !important; }

html { -webkit-text-size-adjust: 100%; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', Roboto, sans-serif;
  font-size: 16px;
  line-height: 1.5;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

button, input, textarea, select {
  font-family: inherit;
  font-size: 16px;     /* 防 iOS 自动 zoom */
  color: inherit;
}

a { color: var(--primary); text-decoration: none; }
a:hover { opacity: 0.85; }

/* ============================================================
   全局交互：hover 柔切 + 键盘焦点环（minimalist：purposeful motion）
   ============================================================ */

/* 可交互面的 hover/选中不要硬跳，统一 0.15s 过渡 */
a, button,
.card-link, .opt-pick, .side-kp, .kp-row, .kn-kp, .due-item, .class-row,
.tab-btn, .seg-btn, .upvote, .ghost-link, .wl-kp, .click-row, .alert-item {
  transition: background-color 0.15s ease, border-color 0.15s ease,
              color 0.15s ease, opacity 0.15s ease, transform 0.1s ease;
}

/* 键盘焦点环：鼠标点击不显示，Tab 导航才显示（全站统一） */
:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

/* ============================================================
   Landing（root）
   ============================================================ */

.landing { min-height: 100vh; display: flex; }
.landing-wrap {
  max-width: 560px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  width: 100%;
}
.landing h1 { font-size: 28px; }
.muted { color: var(--muted); }
.small { font-size: 14px; }

.landing-nav {
  margin-top: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.card-link {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4) var(--space-6);
  min-height: var(--tap);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  color: var(--text);
}
.card-link:hover { background: var(--card-2); }

/* ============================================================
   Onboarding（S8 透明告知）
   ============================================================ */

.onboarding { min-height: 100vh; display: flex; }
#screens {
  flex: 1;
  display: flex;
  flex-direction: column;
  width: 100%;
}
.screen {
  flex: 1;
  padding: var(--space-8) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  width: 100%;
}

.dots {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.dots span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border);
  transition: background 0.2s;
}
.dots span.active { background: var(--primary); }

.screen h1 { font-size: 28px; line-height: 1.3; }
.screen h2 { font-size: 22px; line-height: 1.3; }

.info-block {
  background: var(--card);
  border-radius: var(--radius);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.info-section ul {
  list-style: none;
  padding: 0;
  margin-top: var(--space-2);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.callout {
  background: rgba(122, 162, 255, 0.12);
  border-left: 3px solid var(--primary);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  font-size: 14px;
}

.how-to {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.how-to li {
  background: var(--card);
  padding: var(--space-4);
  border-radius: var(--radius-sm);
  position: relative;
  padding-left: var(--space-8);
}
.how-to li::before {
  content: '·';
  position: absolute;
  left: var(--space-4);
  color: var(--primary);
  font-size: 24px;
  line-height: 1;
  top: var(--space-3);
}

/* ============================================================
   Buttons
   ============================================================ */

button {
  cursor: pointer;
  min-height: var(--tap);
  padding: 0 var(--space-6);
  border-radius: var(--radius-sm);
  border: none;
  font-weight: 500;
}

button.primary,
a.primary {
  background: var(--primary);
  color: var(--primary-ink);
  font-weight: 600;
}
button.primary {
  width: 100%;
  margin-top: auto;     /* 推到底部 */
}
/* 链接形态的 primary CTA：补足 button 的盒模型 + 48px 点击区（全站统一） */
a.primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--tap);
  padding: 0 var(--space-6);
  border-radius: var(--radius-sm);
}
button.primary:hover, a.primary:hover { opacity: 0.9; }
button.primary:active, a.primary:active { transform: scale(0.98); }
button.primary:disabled { opacity: 0.5; cursor: not-allowed; }

/* ============================================================
   Login form（教师/学生通用）
   ============================================================ */

.login-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-4);
}
.field { display: flex; flex-direction: column; gap: var(--space-1); }
.field input {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 0 var(--space-4);
  min-height: var(--tap);
  color: var(--text);
}
.field input:focus { outline: 2px solid var(--primary); border-color: transparent; }
.login-form button.primary { margin-top: var(--space-2); }
.error-text {
  color: var(--error);
  font-size: 14px;
  background: rgba(248, 113, 113, 0.1);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
}

/* ============================================================
   Responsive: tablet >=481px, desktop >=1025px
   ============================================================ */

@media (min-width: 481px) {
  .screen, .landing-wrap {
    max-width: 480px;
    margin: 0 auto;
  }
}

@media (min-width: 1025px) {
  .screen, .landing-wrap {
    max-width: 560px;
  }
}

/* ============================================================
   教师题库审核（桌面键盘流，移动端降级为堆叠）
   ============================================================ */

.review-body { min-height: 100vh; display: flex; flex-direction: column; }

.review-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
  background: var(--card);
  position: sticky; top: 0; z-index: 5;
}
.review-top-left { display: flex; flex-direction: column; gap: 2px; }
.review-top-right { display: flex; gap: var(--space-2); }

button.ghost {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  min-height: 40px;
  padding: 0 var(--space-4);
  border-radius: var(--radius-sm);
}
button.ghost:hover { background: var(--card-2); }
button.ghost.danger { color: var(--error); border-color: rgba(248,113,113,0.4); }
button.ghost.danger:hover { background: rgba(248,113,113,0.12); }
button.primary.inline { width: auto; margin: 0; }

.review-shell { flex: 1; display: flex; min-height: 0; }

.review-sidebar {
  width: 300px; flex-shrink: 0;
  border-right: 1px solid var(--border);
  overflow-y: auto;
  padding: var(--space-2);
  display: flex; flex-direction: column; gap: 2px;
}
.sidebar-hint { padding: var(--space-4); }
.side-module {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-3) var(--space-3) var(--space-2);
  font-weight: 600; font-size: 14px; color: var(--muted);
  margin-top: var(--space-2);
}
.side-kp {
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-2);
  background: transparent; border: none; color: var(--text);
  text-align: left; padding: var(--space-3); border-radius: var(--radius-sm);
  min-height: 40px; width: 100%;
}
.side-kp:hover { background: var(--card-2); }
.side-kp.active { background: var(--card-2); outline: 1px solid var(--primary); }
.side-kp-name { font-size: 14px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.badge {
  flex-shrink: 0;
  background: var(--primary); color: var(--primary-ink);
  border-radius: 999px; font-size: 12px; font-weight: 700;
  min-width: 22px; height: 20px; padding: 0 7px;
  display: inline-flex; align-items: center; justify-content: center;
}
.side-module .badge { background: var(--border); color: var(--text); }

.review-stage { flex: 1; overflow-y: auto; padding: var(--space-6); min-width: 0; }
.card-host { max-width: 760px; margin: 0 auto; }

.qcard { display: flex; flex-direction: column; gap: var(--space-4); }
.q-meta { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.tag {
  font-size: 12px; font-weight: 600; padding: 3px 9px; border-radius: 999px;
  background: var(--card-2); color: var(--muted);
}
.tag.type { background: rgba(122,162,255,0.18); color: var(--primary); }
.tag.bloom { background: rgba(74,222,128,0.15); color: var(--success); }
.tag.ai { background: rgba(250,204,21,0.15); color: var(--warn); }
.tag.warn { background: rgba(248,113,113,0.15); color: var(--error); }

.label {
  display: block; font-size: 12px; font-weight: 700;
  color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: var(--space-1);
}
.q-scenario {
  background: rgba(122,162,255,0.08);
  border-left: 3px solid var(--primary);
  padding: var(--space-3) var(--space-4); border-radius: var(--radius-sm);
}
.q-body { font-size: 17px; line-height: 1.6; }
.opts { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.opts.ord { list-style: decimal inside; }
.opts li {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4);
}
.opts li.correct { border-color: var(--success); background: rgba(74,222,128,0.1); }
.opts-2col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.q-answer, .q-expl {
  background: var(--card); border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
}
.q-answer { border: 1px solid var(--success); }

.q-actions { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-2); }

.qcard.editing textarea, .qcard.editing input {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: var(--space-3);
  color: var(--text); width: 100%; resize: vertical; line-height: 1.5;
}
.qcard.editing textarea:focus, .qcard.editing input:focus { outline: 2px solid var(--primary); border-color: transparent; }
.inline-field { max-width: 160px; }

.diff { margin-top: var(--space-2); }
.diff-body {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: var(--space-3); font-size: 13px; white-space: pre-wrap; overflow-x: auto;
}
.diff-body ins { background: rgba(74,222,128,0.25); text-decoration: none; }
.diff-body del { background: rgba(248,113,113,0.25); }

.empty-state { text-align: center; padding: var(--space-8) var(--space-4); }
.empty-state-link { margin-top: var(--space-4); }

.toast {
  position: fixed; bottom: var(--space-6); left: 50%; transform: translateX(-50%);
  background: var(--card-2); color: var(--text);
  padding: var(--space-3) var(--space-6); border-radius: var(--radius);
  border: 1px solid var(--border); z-index: 20; font-weight: 600;
}
.toast.ok { border-color: var(--success); }
.toast.err { border-color: var(--error); color: var(--error); }

.modal {
  position: fixed; inset: 0; background: rgba(0,0,0,0.6);
  display: flex; align-items: center; justify-content: center; z-index: 30;
}
.modal[hidden] { display: none; }
.modal-box {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: var(--space-6);
  max-width: 360px; width: 90%; display: flex; flex-direction: column; gap: var(--space-4);
}
.keys { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.keys li { display: flex; gap: var(--space-2); align-items: center; font-size: 14px; }
kbd {
  background: var(--bg); border: 1px solid var(--border); border-bottom-width: 2px;
  border-radius: 4px; padding: 1px 6px; font-size: 12px; font-family: ui-monospace, monospace;
}

@media (max-width: 720px) {
  .review-shell { flex-direction: column; }
  .review-sidebar { width: 100%; max-height: 30vh; border-right: none; border-bottom: 1px solid var(--border); }
  .opts-2col { grid-template-columns: 1fr; }
}

/* ============================================================
   教师建班 / 解锁
   ============================================================ */

.ghost-link {
  display: inline-flex; align-items: center;
  border: 1px solid var(--border); color: var(--text);
  min-height: 40px; padding: 0 var(--space-4); border-radius: var(--radius-sm);
}
.ghost-link:hover { background: var(--card-2); opacity: 1; }

.classes-shell {
  flex: 1; display: grid; grid-template-columns: 360px 1fr; gap: var(--space-4);
  padding: var(--space-6); align-items: start; min-height: 0;
}
.panel {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: var(--space-4) var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-4);
}
.panel h2 { font-size: 18px; }

.create-class { display: flex; gap: var(--space-2); }
.create-class input {
  flex: 1; background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 0 var(--space-3); min-height: var(--tap); color: var(--text);
}
.create-class input:focus { outline: 2px solid var(--primary); border-color: transparent; }

.class-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.class-row {
  display: flex; align-items: center; gap: var(--space-2);
  border: 1px solid var(--border); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3);
}
.class-row.active { outline: 1px solid var(--primary); background: var(--card-2); }
.class-pick { flex: 1; text-align: left; background: transparent; border: none; color: var(--text); min-height: 36px; }
.invite {
  font-family: ui-monospace, monospace; font-weight: 700; letter-spacing: 0.06em;
  background: var(--bg); border-radius: var(--radius-sm); padding: 2px 8px; color: var(--primary);
}
.copy-btn { min-height: 32px; padding: 0 var(--space-3); font-size: 13px; }

.unlock-toolbar { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.kp-tree { display: flex; flex-direction: column; gap: var(--space-4); max-height: 70vh; overflow-y: auto; }
.kp-module { display: flex; flex-direction: column; gap: 2px; }
.kp-module-head {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-2) 0; position: sticky; top: 0; background: var(--bg); z-index: 1;
}
.kp-module-head strong { flex: 1; }
.kp-row {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); cursor: pointer;
}
.kp-row:hover { background: var(--card); }
.kp-row.unlocked { cursor: default; opacity: 0.85; }
.kp-row .kp-label { flex: 1; font-size: 14px; }
.kp-cb { width: 18px; height: 18px; accent-color: var(--primary); }
.lock-state {
  font-size: 12px; font-weight: 700; color: var(--success);
  background: rgba(74,222,128,0.12); border-radius: 999px; padding: 2px 8px; min-width: 56px; text-align: center;
}

@media (max-width: 860px) {
  .classes-shell { grid-template-columns: 1fr; }
}

/* ============================================================
   学生端（移动优先）
   ============================================================ */

.student-body { min-height: 100vh; display: flex; flex-direction: column; }
.student-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3); padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border); background: var(--card);
  position: sticky; top: 0; z-index: 5;
}

/* 注册/登录切换 */
.seg { display: flex; gap: var(--space-1); background: var(--card); border-radius: var(--radius-sm); padding: 4px; margin-top: var(--space-4); }
.seg-btn { flex: 1; background: transparent; border: none; color: var(--muted); min-height: 40px; border-radius: var(--radius-sm); font-weight: 600; }
.seg-btn.active { background: var(--primary); color: var(--primary-ink); }

/* 首页卡片 */
.home-wrap {
  flex: 1; width: 100%; max-width: 560px; margin: 0 auto;
  padding: var(--space-6) var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-4);
}
.home-card {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3);
}
.home-card.task { border-color: var(--primary); }
.home-card-head h2 { font-size: 18px; }
.home-line { font-size: 16px; color: var(--text); }
.home-line b { font-size: 22px; color: var(--primary); }
.home-go { align-self: flex-start; width: auto; text-align: center; }
.home-done { color: var(--muted); font-weight: 600; }
.muted-card { opacity: 0.7; }

/* 答题 */
.answer-wrap {
  flex: 1; width: 100%; max-width: 640px; margin: 0 auto;
  padding: var(--space-6) var(--space-4);
}
.answer-card { display: flex; flex-direction: column; gap: var(--space-4); }
.choices, .judge-btns, .match-rows { display: flex; flex-direction: column; gap: var(--space-2); }
.judge-btns { flex-direction: row; }
.opt-pick {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: var(--space-4); min-height: var(--tap); cursor: pointer; line-height: 1.4;
}
.opt-pick:hover { background: var(--card-2); }
.opt-pick input { width: 20px; height: 20px; accent-color: var(--primary); flex-shrink: 0; }
.opt-pick.judge { flex: 1; justify-content: center; font-size: 18px; font-weight: 600; }

.match-row { display: flex; align-items: center; gap: var(--space-3); }
.match-left { flex: 1; background: var(--card); border-radius: var(--radius-sm); padding: var(--space-3); font-size: 14px; }
.match-sel {
  flex: 1; background: var(--card); border: 1px solid var(--border); color: var(--text);
  border-radius: var(--radius-sm); min-height: var(--tap); padding: 0 var(--space-2);
}

.order-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); counter-reset: ord; }
.order-item {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4);
}
.order-item .order-text { flex: 1; }
.order-item::before { counter-increment: ord; content: counter(ord); color: var(--primary); font-weight: 700; min-width: 18px; }
.order-ctrl { display: flex; gap: var(--space-1); }
.order-ctrl button { min-height: 36px; padding: 0 var(--space-3); }

/* 反馈 */
.fb-banner {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-4); border-radius: var(--radius); font-size: 18px; font-weight: 700;
}
.fb-banner.ok { background: rgba(74,222,128,0.15); color: var(--success); }
.fb-banner.no { background: rgba(248,113,113,0.15); color: var(--error); }
.fb-icon { font-size: 24px; }
.fb-score { margin-left: auto; }
.fb-mastered { color: var(--success); font-weight: 600; }
.done-card { text-align: center; gap: var(--space-4); padding-top: var(--space-8); }

/* 能力雷达 */
.radar-wrap { display: flex; justify-content: center; }
.radar-svg { width: 100%; max-width: 280px; height: auto; }
.radar-grid { fill: none; stroke: var(--border); stroke-width: 1; }
.radar-touch { fill: rgba(122,162,255,0.12); stroke: var(--primary); stroke-width: 1.5; stroke-dasharray: 4 3; }
.radar-mastered { fill: rgba(74,222,128,0.28); stroke: var(--success); stroke-width: 2; }
.radar-label { fill: var(--muted); font-size: 13px; font-weight: 600; }
.radar-legend { display: flex; justify-content: center; gap: var(--space-4); font-size: 13px; color: var(--muted); }
.radar-legend .dot { display: inline-block; width: 12px; height: 12px; border-radius: 3px; margin-right: 4px; vertical-align: middle; }
.radar-legend .dot.solid { background: var(--success); }
.radar-legend .dot.ring { background: transparent; border: 1.5px dashed var(--primary); }
.radar-stats { text-align: center; font-size: 14px; }
.radar-stats b { color: var(--success); font-size: 18px; }

/* ============================================================
   教师学情仪表盘 (M2)
   ============================================================ */

.inline-sel {
  background: var(--bg); color: var(--text); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 2px 6px; min-height: 28px;
}
.dash-tabs {
  display: flex; gap: var(--space-1); padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--border); background: var(--card); flex-wrap: wrap;
  position: sticky; top: 57px; z-index: 4;
}
.tab-btn {
  background: transparent; border: none; color: var(--muted);
  min-height: 40px; padding: 0 var(--space-4); border-radius: var(--radius-sm); font-weight: 600;
}
.tab-btn.active { background: var(--card-2); color: var(--text); }
.dash-main { flex: 1; overflow-y: auto; padding: var(--space-4) var(--space-6); }
.empty-pad { padding: var(--space-8) 0; text-align: center; }

.dash-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.dash-table th, .dash-table td { text-align: left; padding: var(--space-3); border-bottom: 1px solid var(--border); }
.dash-table th { color: var(--muted); font-weight: 600; font-size: 13px; }
.click-row { cursor: pointer; }
.click-row:hover { background: var(--card); }
.row-warn { background: rgba(248,113,113,0.07); }
.flag { font-size: 12px; font-weight: 700; padding: 2px 8px; border-radius: 999px; background: var(--card-2); color: var(--muted); }
.flag.low { background: rgba(248,113,113,0.18); color: var(--error); }

/* M12 研究指标视图（dashboard 研究 tab） */
.research-bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-4);
}
.research-h { font-size: 15px; margin: var(--space-6) 0 var(--space-3); }

.mini-radar { display: inline-flex; align-items: flex-end; gap: 2px; height: 18px; }
.mini-bar { width: 5px; background: var(--primary); border-radius: 1px; display: inline-block; }

.alert-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.alert-item { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }
.alert-item.read { opacity: 0.55; }
.alert-item button { align-self: flex-start; min-height: 34px; }

.drawer { position: fixed; inset: 0; background: rgba(0,0,0,0.5); display: flex; justify-content: flex-end; z-index: 25; }
.drawer-box {
  width: 460px; max-width: 92%; background: var(--card); height: 100%; overflow-y: auto;
  padding: var(--space-6); position: relative; border-left: 1px solid var(--border);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.drawer-close { position: absolute; top: var(--space-3); right: var(--space-3); min-height: 36px; }
.drawer-box h2 { font-size: 20px; }
.drawer-box h3 { font-size: 15px; color: var(--muted); margin-top: var(--space-3); }

/* ============================================================
   教师问答审核 (M7)
   ============================================================ */

.qna-review-toolbar {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-3);
  padding: var(--space-3) var(--space-6); border-bottom: 1px solid var(--border);
  background: var(--card); flex-wrap: wrap;
}
.qna-review-main {
  flex: 1; width: 100%; max-width: 900px; margin: 0 auto;
  padding: var(--space-6); overflow-y: auto;
}
.qna-review-list { display: flex; flex-direction: column; gap: var(--space-4); }
.qna-review-card {
  display: flex; flex-direction: column; gap: var(--space-3);
  padding: var(--space-4) var(--space-6); border: 1px solid var(--border);
  border-radius: var(--radius); background: var(--card);
}
.qna-review-card-head { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.qna-review-check { display: inline-flex; align-items: center; gap: var(--space-2); }
.qna-review-check input { width: 18px; height: 18px; accent-color: var(--primary); }
.qna-review-question { font-size: 17px; line-height: 1.6; }
.qna-review-answers { display: flex; flex-direction: column; gap: var(--space-2); }
.qna-review-answer {
  display: flex; flex-direction: column; gap: var(--space-1);
  padding: var(--space-3); border: 1px solid var(--border);
  border-radius: var(--radius-sm); background: var(--bg);
}
.qna-review-card textarea {
  width: 100%; min-height: 88px; resize: vertical; line-height: 1.5;
  padding: var(--space-3); color: var(--text); background: var(--bg);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
}
.qna-review-card textarea:focus { outline: 2px solid var(--primary); border-color: transparent; }

/* ============================================================
   学生·今日复习 hub (M6) + streak + 错题本
   移动优先；遵循 minimalist：token / 层级 / 安静元信息
   ============================================================ */

.srs-wrap, .wl-wrap {
  flex: 1; width: 100%; max-width: 600px; margin: 0 auto;
  padding: var(--space-8) var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-4);
}

/* streak 卡：复习的动力来源，连续天数是焦点 */
.streak-card {
  display: flex; align-items: center; gap: var(--space-4);
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: var(--space-4) var(--space-6);
}
.streak-fire { font-size: 32px; line-height: 1; flex-shrink: 0; }
.streak-line { font-size: 16px; color: var(--text); }
.streak-num { font-size: 28px; font-weight: 700; color: var(--primary); }
.streak-sub { font-size: 13px; color: var(--muted); margin-top: 2px; }

/* 待复习摘要 + 主行动 */
.srs-summary { font-size: 16px; color: var(--muted); }
.srs-summary b { font-size: 22px; font-weight: 700; color: var(--primary); }

/* 复习页主 CTA 占满整行（填充/点击区由全站 a.primary 统一提供） */
.srs-start { width: 100%; }

/* 待复习列表 */
.due-list { display: flex; flex-direction: column; gap: var(--space-2); }
.due-item {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4);
}
.due-main { flex: 1; min-width: 0; }
.due-kp { font-weight: 600; }
.due-meta { font-size: 13px; color: var(--muted); margin-top: 4px;
  display: flex; gap: var(--space-2); flex-wrap: wrap; align-items: center; }
.due-skip { min-height: 36px; padding: 0 var(--space-3); font-size: 13px; flex-shrink: 0; }

/* 复习 / 错题 空态 */
.srs-empty, .wl-empty {
  text-align: center; padding: var(--space-8) var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-3); align-items: center;
}
.srs-empty .big, .wl-empty .big { font-size: 40px; }

/* 次级链接（→ 错题本 / → 复习） */
.srs-foot { margin-top: var(--space-2); text-align: center; }

/* 错题本：按 kp · 题型汇总 */
.wl-group { display: flex; flex-direction: column; gap: var(--space-2); }
.wl-kp { font-weight: 600; font-size: 15px; color: var(--text); }
.wl-kp:hover { color: var(--primary); opacity: 1; }
.wl-types { display: flex; flex-direction: column; gap: var(--space-2); }
.wl-row {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4);
}
.wl-when { font-size: 13px; color: var(--muted); }
.wl-row .count { margin-left: auto; font-weight: 700; color: var(--error); }

/* ============================================================
   学生·知识点浏览 (knowledge.html) + 学习页 (kp.html) + Q&A 三层 (M7)
   ============================================================ */

.kn-wrap, .kp-wrap {
  flex: 1; width: 100%; max-width: 640px; margin: 0 auto;
  padding: var(--space-8) var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-6);
}

/* 首页雷达卡里的次级入口 */
.kn-link { align-self: flex-start; font-size: 14px; }

/* 知识点浏览：按模块分组 */
.kn-module { display: flex; flex-direction: column; gap: var(--space-2); }
.kn-module-name { font-size: 15px; font-weight: 700; color: var(--muted); }
.kn-kp {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4);
  color: var(--text); min-height: var(--tap);
}
.kn-kp:hover { background: var(--card-2); opacity: 1; }
.kn-kp-name { flex: 1; min-width: 0; }
.kn-code { color: var(--muted); font-size: 13px; margin-right: var(--space-2); }
.kn-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; background: var(--border); }
.kn-dot.touched { background: var(--primary); }
.kn-dot.mastered { background: var(--success); }
.kn-dot.skipped { background: transparent; border: 1px solid var(--muted); }

/* 学习页 */
.kp-head { display: flex; flex-direction: column; gap: var(--space-2); }
.kp-head h1 { font-size: 22px; line-height: 1.3; }
.kp-content { font-size: 16px; line-height: 1.7; color: var(--text); }
.kp-content.empty { color: var(--muted); }
.kp-supp { display: flex; flex-direction: column; gap: var(--space-2); }
.kp-supp a {
  display: flex; align-items: center; gap: var(--space-2);
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4); min-height: var(--tap);
}
.kp-section-label { font-size: 12px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }

/* Q&A 三层：提问 → 同伴互答 → 老师精华 */
.qna-sec { display: flex; flex-direction: column; gap: var(--space-3); }
.qna-head h2 { font-size: 18px; }
.qna-compose {
  display: flex; flex-direction: column; gap: var(--space-3);
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-4);
}
.qna-compose textarea {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: var(--space-3); color: var(--text); width: 100%; resize: vertical; min-height: 84px; line-height: 1.5;
}
.qna-compose textarea:focus { outline: 2px solid var(--primary); border-color: transparent; }
.qna-compose-row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.anon-toggle { display: flex; align-items: center; gap: var(--space-2); font-size: 14px; color: var(--muted); }
.anon-toggle input { width: 18px; height: 18px; accent-color: var(--primary); }

.qna-list { display: flex; flex-direction: column; gap: var(--space-3); }
.qna-post {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-3);
}
.qna-q { font-size: 16px; line-height: 1.5; }
.qna-meta { font-size: 13px; color: var(--muted); display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; }
.qna-curated {
  background: rgba(74, 222, 128, 0.1); border-left: 3px solid var(--success);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4); line-height: 1.6;
  display: flex; flex-direction: column; gap: var(--space-1);
}
.qna-curated .kp-section-label { color: var(--success); }
.qna-answers { display: flex; flex-direction: column; gap: var(--space-2); }
.qna-ans {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: var(--space-3); display: flex; gap: var(--space-3); align-items: flex-start;
}
.qna-ans-body { flex: 1; min-width: 0; line-height: 1.5; }
.qna-ans-meta { font-size: 12px; color: var(--muted); margin-top: 4px; }
.upvote {
  flex-shrink: 0; display: inline-flex; align-items: center; gap: 4px;
  background: transparent; border: 1px solid var(--border); color: var(--muted);
  border-radius: 999px; min-height: 32px; padding: 0 var(--space-3); font-size: 13px; font-weight: 600;
}
.upvote:hover { border-color: var(--primary); color: var(--primary); }
.qna-empty { color: var(--muted); }
