/* ============================================================
   DISC 测试系统 v2 — 设计令牌驱动版
   风格: Notion × Linear | 品牌色: #1E40AF
   ============================================================ */

*,*::before,*::after{ margin:0; padding:0; box-sizing:border-box; }
html,body{ height:100%; overflow:hidden; }
html{ -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; }
body{
  font-family: 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height:1.5;
  background: var(--bg-base);
  color: var(--text-primary);
}

/* ============================================================
   设计令牌 — 自定义属性
   ============================================================ */
:root{
  /* --- 品牌色 --- */
  --brand: #1E40AF;
  --brand-hover: #1D4ED8;
  --brand-active: #1E3A8A;
  --brand-light: #DBEAFE;
  --brand-gradient: linear-gradient(135deg, #1E40AF, #3B82F6);

  /* --- DISC 四色 --- */
  --D: #EAB308;
  --I: #EF4444;
  --S: #22C55E;
  --C: #3B82F6;
  --D-light: #FEF9C3;
  --I-light: #FEE2E2;
  --S-light: #DCFCE7;
  --C-light: #DBEAFE;
  --D-border: #FDE047;
  --I-border: #FCA5A5;
  --S-border: #86EFAC;
  --C-border: #93C5FD;
  --D-grad: linear-gradient(135deg, #EAB308, #FACC15);
  --I-grad: linear-gradient(135deg, #EF4444, #F87171);
  --S-grad: linear-gradient(135deg, #22C55E, #4ADE80);
  --C-grad: linear-gradient(135deg, #3B82F6, #60A5FA);
  /* D-黄暗色模式专用（提高对比度） */
  --D-dark: #FBBF24;

  /* --- 背景 --- */
  --bg-base: #FAFBFC;
  --bg-warm: #F8F7F4;
  --bg-card: #FFFFFF;
  --bg-subtle: #F0F1F3;
  --bg-hover: #F0F1F3;
  --bg-nav: rgba(255,255,255,0.82);
  --bg-overlay: rgba(0,0,0,0.45);

  /* --- 文字 --- */
  --text-primary: #1A1D23;
  --text-secondary: #6B7280;
  --text-tertiary: #9CA3AF;
  --text-inverse: #FFFFFF;
  --text-link: #1E40AF;
  --text-link-hover: #2563EB;

  /* --- 边框 --- */
  --border-default: #E5E7EB;
  --border-light: #F0F1F3;
  --border-focus: #1E40AF;
  --border-success: #22C55E;
  --border-error: #EF4444;

  /* --- 阴影 --- */
  --shadow-none: none;
  --shadow-sm: 0 1px 2px 0 rgba(0,0,0,0.04);
  --shadow-base: 0 1px 3px 0 rgba(0,0,0,0.06), 0 1px 2px -1px rgba(0,0,0,0.04);
  --shadow-card: 0 2px 8px 0 rgba(0,0,0,0.06), 0 1px 3px 0 rgba(0,0,0,0.04);
  --shadow-elevated: 0 4px 16px 0 rgba(0,0,0,0.08), 0 2px 6px 0 rgba(0,0,0,0.04);
  --shadow-modal: 0 8px 28px 0 rgba(0,0,0,0.12);
  --shadow-sticky: 0 -2px 12px 0 rgba(0,0,0,0.08);
  --shadow-brand: 0 2px 8px rgba(30,64,175,0.3);
  --shadow-D: 0 2px 8px 0 rgba(234,179,8,0.25);
  --shadow-I: 0 2px 8px 0 rgba(239,68,68,0.25);
  --shadow-S: 0 2px 8px 0 rgba(34,197,94,0.25);
  --shadow-C: 0 2px 8px 0 rgba(59,130,246,0.25);

  /* --- 圆角 --- */
  --radius-none: 0px;
  --radius-sm: 4px;
  --radius-base: 8px;
  --radius-default: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-2xl: 24px;
  --radius-button: 10px;
  --radius-badge: 6px;
  --radius-full: 9999px;

  /* --- 排版 --- */
  --fs-micro: 11px;
  --fs-xs: 12px;
  --fs-sm: 13px;
  --fs-base: 15px;
  --fs-lg: 17px;
  --fs-xl: 19px;
  --fs-2xl: 22px;
  --fs-3xl: 26px;
  --fs-4xl: 32px;
  --fs-5xl: 40px;
  --fw-normal: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;
  --lh-tight: 1.2;
  --lh-normal: 1.5;
  --lh-relaxed: 1.6;
  --lh-loose: 1.75;
  --ls-tighter: -0.02em;
  --ls-tight: -0.01em;
  --ls-normal: 0;
  --ls-wide: 0.02em;
  --ls-wider: 0.05em;

  /* --- 间距 --- */
  --sp-0: 0px;
  --sp-0-5: 2px;
  --sp-1: 4px;
  --sp-1-5: 6px;
  --sp-2: 8px;
  --sp-2-5: 10px;
  --sp-3: 12px;
  --sp-3-5: 14px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
  --sp-7: 28px;
  --sp-8: 32px;
  --sp-9: 36px;
  --sp-10: 40px;
  --sp-11: 44px;
  --sp-12: 48px;
  --sp-14: 56px;
  --sp-16: 64px;

  /* --- 过渡 --- */
  --tr-instant: 0ms;
  --tr-fast: 120ms ease;
  --tr-base: 180ms ease;
  --tr-slow: 250ms ease;
  --tr-slide: 300ms cubic-bezier(0.22,1,0.36,1);
  --tr-spring: 400ms cubic-bezier(0.34,1.56,0.64,1);
  --tr-auto-jump: 600ms;
  --tr-auto-jump-buffer: 100ms;

  /* --- 层级 --- */
  --z-base: 0;
  --z-sticky: 100;
  --z-nav: 200;
  --z-dropdown: 300;
  --z-modal-backdrop: 400;
  --z-modal: 500;
  --z-popover: 600;
  --z-toast: 700;

  /* --- 不透明度 --- */
  --op-disabled: 0.4;
  --op-inactive: 0.6;
  --op-subtle: 0.08;
  --op-medium: 0.2;
  --op-strong: 0.45;
  --op-heavy: 0.6;

  /* --- 安全区 --- */
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 16px);

  /* --- 语义色 --- */
  --success: #10B981;
  --success-light: #D1FAE5;
  --warning: #F59E0B;
  --warning-light: #FEF3C7;
  --error: #EF4444;
  --error-light: #FEE2E2;
  --info: #3B82F6;
  --info-light: #DBEAFE;
}

/* ============================================================
   暗色模式
   ============================================================ */
[data-theme="dark"]{
  --bg-base: #0F1117;
  --bg-card: #1A1D27;
  --bg-subtle: #23262F;
  --bg-hover: #23262F;
  --bg-nav: rgba(15,17,23,0.85);
  --bg-overlay: rgba(0,0,0,0.6);

  --text-primary: #EDEEF0;
  --text-secondary: #9CA3AF;
  --text-tertiary: #6B7280;
  --text-inverse: #0F1117;
  --text-link: #60A5FA;
  --text-link-hover: #93C5FD;

  --border-default: #2D3141;
  --border-light: #23262F;
  --border-focus: #60A5FA;

  --shadow-sm: 0 1px 2px 0 rgba(0,0,0,0.15);
  --shadow-card: 0 2px 8px 0 rgba(0,0,0,0.2);
  --shadow-elevated: 0 4px 16px 0 rgba(0,0,0,0.25);
  --shadow-modal: 0 8px 28px 0 rgba(0,0,0,0.35);
  --shadow-brand: 0 2px 8px rgba(59,130,246,0.3);

  /* D-黄在暗色下使用更亮的变体确保对比度 >= 4.5:1 */
  --D: #FBBF24;
  --D-light: rgba(251,191,36,0.15);
  --D-border: #FBBF24;
}

/* ============================================================
   基础布局
   ============================================================ */
#app{
  width:100%; height:100dvh;
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
}

/* 背景装饰 */
.bg-deco{
  position:fixed; pointer-events:none; z-index:0;
  top:0; left:0; right:0; bottom:0;
  background:
    radial-gradient(ellipse 60% 40% at 85% 10%, rgba(30,64,175,0.06), transparent 60%),
    radial-gradient(ellipse 50% 35% at 15% 90%, rgba(34,197,94,0.05), transparent 50%),
    radial-gradient(ellipse 40% 30% at 90% 80%, rgba(59,130,246,0.04), transparent 40%);
}

/* ============================================================
   页面容器
   ============================================================ */
.page{
  display:none; flex-direction:column;
  height:100%; overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  position:relative; z-index:1;
}
.page.active{ display:flex; }
.page::-webkit-scrollbar{ width:0; }

@keyframes pageIn{
  from{ opacity:0; transform:translateY(10px); }
  to{ opacity:1; transform:translateY(0); }
}
.page{ animation:pageIn 0.25s ease both; }

/* ============================================================
   通用卡片
   ============================================================ */
.card{
  background:var(--bg-card);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  border:1px solid var(--border-light);
  padding:var(--sp-5);
  margin-bottom:var(--sp-3);
  transition: box-shadow var(--tr-base), border-color var(--tr-base);
}

/* ============================================================
   按钮系统
   ============================================================ */
.btn{
  display:flex; align-items:center; justify-content:center; gap:var(--sp-2);
  border:none; border-radius:var(--radius-button);
  font-size:16px; font-weight:var(--fw-semibold); cursor:pointer;
  transition: all var(--tr-spring);
  padding:14px var(--sp-6);
  height:48px;
  -webkit-tap-highlight-color:transparent;
  font-family:inherit;
  letter-spacing:var(--ls-wide);
  position:relative; overflow:hidden;
}
.btn:active{ transform:scale(0.96); }

.btn-primary{
  background:var(--brand-gradient);
  color:var(--text-inverse);
  box-shadow:var(--shadow-brand);
  border:none;
}
.btn-primary:hover{
  background:linear-gradient(135deg, #1D4ED8, #2563EB);
  box-shadow:0 2px 8px rgba(30,64,175,0.3);
  transform:translateY(-1px);
}

.btn-ghost{
  background:transparent;
  border:1.5px solid var(--border-default);
  color:var(--text-secondary);
}
.btn-ghost:hover{ border-color:var(--border-focus); background:var(--bg-subtle); }

/* ============================================================
   顶部导航栏
   ============================================================ */
.top-bar{
  padding:var(--sp-2-5) var(--sp-4); padding-top:calc(var(--sp-2-5) + var(--safe-top));
  background:var(--bg-nav);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border-light);
  flex-shrink:0;
  display:flex; align-items:center;
  gap:var(--sp-2-5);
  height:48px;
}
.top-bar .tb-title{
  flex:1;
  font-size:var(--fs-lg);
  font-weight:var(--fw-semibold);
  color:var(--text-primary);
  letter-spacing:var(--ls-tight);
}
.tb-btn{
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  border-radius:var(--radius-base);
  border:none;
  background:transparent;
  color:var(--text-secondary);
  cursor:pointer;
  transition:background var(--tr-fast);
  -webkit-tap-highlight-color:transparent;
}
.tb-btn:active{ background:var(--bg-subtle); }
.tb-btn svg{ flex-shrink:0; }

/* 主题图标 */
.theme-ic{ position:absolute; }

/* ============================================================
   进度条
   ============================================================ */
.progress-track{
  height:4px;
  background:var(--border-default);
  border-radius:var(--radius-full);
  overflow:hidden;
  margin:0;
}
.progress-fill{
  height:100%;
  border-radius:var(--radius-full);
  background:linear-gradient(90deg, var(--D), var(--I), var(--S), var(--C));
  transition: width 400ms cubic-bezier(0.22,1,0.36,1);
}

/* ============================================================
   欢迎页
   ============================================================ */
#page-welcome{
  justify-content:flex-start;
  padding:0 var(--sp-6);
  padding-top:var(--sp-12);
  padding-bottom:var(--sp-5);
}

.welcome-top{ text-align:center; margin-bottom:var(--sp-5); }
.welcome-top .logo-wrap{
  width:72px; height:72px; margin:0 auto var(--sp-4);
  background:var(--bg-card);
  border-radius:var(--radius-lg);
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-card);
  padding:var(--sp-3-5);
}
.welcome-top h1{
  font-size:var(--fs-4xl);
  font-weight:var(--fw-bold);
  color:var(--text-primary);
  letter-spacing:var(--ls-tight);
  line-height:var(--lh-tight);
}
.welcome-top h1 .t-d{ color:var(--D); }
.welcome-top h1 .t-i{ color:var(--I); }
.welcome-top h1 .t-s{ color:var(--S); }
.welcome-top h1 .t-c{ color:var(--C); }
.welcome-top p{
  font-size:var(--fs-sm);
  color:var(--text-secondary);
  margin-top:var(--sp-1-5);
  letter-spacing:var(--ls-wide);
}

/* DISC 概念说明 */
.disc-intro{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius-default);
  padding:var(--sp-4);
  margin-bottom:var(--sp-4);
  font-size:var(--fs-sm);
  color:var(--text-secondary);
  line-height:var(--lh-relaxed);
  letter-spacing:var(--ls-wide);
  text-align:center;
  box-shadow:var(--shadow-sm);
}
.disc-intro strong{
  color:var(--text-primary);
  font-weight:var(--fw-medium);
}

/* 数据统计 */
.welcome-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-2-5);
  margin-bottom:var(--sp-5);
}
.welcome-stats .item{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius-default);
  padding:var(--sp-4) var(--sp-3);
  text-align:center;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--sp-1-5);
}
.welcome-stats .item svg{
  color:var(--brand);
  opacity:0.7;
}
.welcome-stats .item .num{
  font-size:var(--fs-sm);
  font-weight:var(--fw-medium);
  color:var(--text-secondary);
  letter-spacing:var(--ls-wide);
}

/* 环境 Banner */
.welcome-actions{ display:flex; flex-direction:column; gap:var(--sp-2-5); }

/* 继续测试按钮（欢迎页，有未完成测试时显示） */
.btn-continue{
  background:var(--S-light);
  border:1.5px solid var(--S-border);
  color:var(--S);
}
.btn-continue:hover{ background:var(--S-light); box-shadow:0 0 0 1px var(--S-border); }
[data-theme="dark"] .btn-continue{ background:rgba(34,197,94,0.12); border-color:rgba(34,197,94,0.3); }

.welcome-disclaimer{
  text-align:center;
  font-size:var(--fs-micro);
  color:var(--text-tertiary);
  margin-top:var(--sp-4);
  letter-spacing:var(--ls-wider);
}

/* ============================================================
   答题页
   ============================================================ */
.quiz-body{
  flex:1; overflow-y:auto;
  padding:var(--sp-5) var(--sp-5) var(--sp-8);
  -webkit-overflow-scrolling:touch;
}

.quiz-q{
  font-size:var(--fs-lg);
  font-weight:var(--fw-semibold);
  color:var(--text-primary);
  line-height:var(--lh-relaxed);
  margin-bottom:var(--sp-6);
  letter-spacing:var(--ls-wide);
}
.quiz-q .q-num{
  display:inline-block;
  font-size:var(--fs-micro);
  font-weight:var(--fw-semibold);
  color:var(--brand);
  background:var(--brand-light);
  padding:2px var(--sp-2-5);
  border-radius:var(--radius-full);
  margin-right:var(--sp-2);
  letter-spacing:var(--ls-wider);
  vertical-align:middle;
}

/* 选项 */
.quiz-opt{
  display:flex; align-items:flex-start; gap:var(--sp-3);
  padding:var(--sp-3-5) var(--sp-4);
  background:var(--bg-card);
  border:1.5px solid var(--border-default);
  border-radius:var(--radius-default);
  margin-bottom:var(--sp-2-5);
  cursor:pointer;
  transition: all var(--tr-base);
  -webkit-tap-highlight-color:transparent;
  text-align:left; width:100%;
  font-family:inherit; font-size:inherit;
  letter-spacing:var(--ls-wide);
  position:relative;
}
.quiz-opt:active{ transform:scale(0.99); }
.quiz-opt .opt-letter{
  width:30px; height:30px; border-radius:var(--radius-base);
  background:var(--bg-subtle);
  display:flex; align-items:center; justify-content:center;
  font-size:var(--fs-sm);
  font-weight:var(--fw-bold);
  color:var(--text-tertiary);
  flex-shrink:0;
  transition: all var(--tr-base);
}
.quiz-opt .opt-text{
  flex:1;
  font-size:var(--fs-base);
  color:var(--text-secondary);
  line-height:var(--lh-relaxed);
  padding-top:var(--sp-1);
}
.quiz-opt .opt-check{
  width:22px; height:22px; border-radius:50%;
  border:2px solid var(--border-default);
  flex-shrink:0; margin-top:var(--sp-1);
  display:flex; align-items:center; justify-content:center;
  transition: all var(--tr-base);
}
.quiz-opt .opt-check svg{ display:none; }

/* 选中态 - 品牌蓝 */
.quiz-opt.selected{ border-color:var(--brand); box-shadow:0 0 0 1px rgba(30,64,175,0.2), var(--shadow-sm); }
.quiz-opt.selected .opt-check{
  border-color:var(--brand);
  background:var(--brand);
  color:#fff;
}
.quiz-opt.selected .opt-check svg{ display:block; }
.quiz-opt.selected .opt-letter{ background:var(--brand); color:#fff; }
.quiz-opt.selected .opt-text{ color:var(--text-primary); }

/* ============================================================
   底部导航
   ============================================================ */
.quiz-footer{
  padding:var(--sp-3) var(--sp-4);
  padding-bottom:calc(var(--sp-3) + var(--safe-bottom));
  background:var(--bg-card);
  border-top:1px solid var(--border-light);
  flex-shrink:0; flex-grow:0;
  display:flex; gap:var(--sp-2-5);
  box-shadow:var(--shadow-sticky);
  z-index:10;
}
.qf-btn{
  flex:1; padding:var(--sp-3-5);
  border-radius:var(--radius-button);
  font-size:var(--fs-base);
  font-weight:var(--fw-medium);
  border:none; cursor:pointer;
  transition: all var(--tr-spring);
  display:flex; align-items:center; justify-content:center; gap:var(--sp-1-5);
  font-family:inherit; letter-spacing:var(--ls-wide);
}
.qf-btn:active{ transform:scale(0.97); }
.qf-btn:disabled{ opacity:var(--op-inactive); cursor:not-allowed; transform:none !important; }
.qf-prev{
  background:var(--bg-card);
  border:1.5px solid var(--border-default);
  color:var(--text-secondary);
}
.qf-next{
  background:var(--brand-gradient);
  color:var(--text-inverse);
  box-shadow:var(--shadow-brand);
}

/* ============================================================
   题号导航（浮动按钮 + 弹出面板）
   ============================================================ */
.qn-float{
  position:fixed;
  right:var(--sp-5);
  bottom:calc(var(--sp-5) + 64px + var(--safe-bottom));
  width:48px; height:48px;
  border-radius:50%;
  background:var(--brand-gradient);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-brand);
  cursor:pointer;
  z-index:var(--z-nav);
  transition: transform var(--tr-spring), box-shadow var(--tr-base);
  -webkit-tap-highlight-color:transparent;
}
.qn-float:active{ transform:scale(0.92); }
.qn-float::after{
  content: attr(data-count);
  position:absolute;
  top:-6px; right:-6px;
  min-width:20px; height:18px;
  padding:0 5px;
  border-radius:var(--radius-full);
  background:var(--error);
  color:#fff;
  font-size:9px;
  font-weight:var(--fw-bold);
  line-height:18px;
  text-align:center;
  box-shadow:0 2px 6px rgba(239,68,68,0.4);
}

/* 题号面板（弹出层） */
.qn-overlay{
  position:fixed; inset:0;
  z-index:var(--z-modal-backdrop);
  background:var(--bg-overlay);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center;
  animation: fadeIn var(--tr-slow) ease both;
}
@keyframes fadeIn{ from{opacity:0} to{opacity:1} }

.qn-panel{
  background:var(--bg-card);
  border-radius:var(--radius-xl);
  padding:var(--sp-5);
  width:calc(100% - 48px);
  max-width:340px;
  box-shadow:var(--shadow-modal);
  animation: scaleIn var(--tr-slide) both;
}
@keyframes scaleIn{
  from{ opacity:0; transform:scale(0.9) translateY(10px); }
  to{ opacity:1; transform:scale(1) translateY(0); }
}
.qn-panel-header{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:var(--sp-4);
  font-size:var(--fs-lg);
  font-weight:var(--fw-semibold);
  color:var(--text-primary);
}
.qn-close{
  width:32px; height:32px; border-radius:50%;
  border:none; background:var(--bg-subtle);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-tertiary); cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
.qn-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:var(--sp-2);
  justify-content:center;
}
.q-dot{
  width:100%; aspect-ratio:1;
  max-width:48px;
  border-radius:var(--radius-base);
  border:1.5px solid var(--border-default);
  background:var(--bg-card);
  display:flex; align-items:center; justify-content:center;
  font-size:var(--fs-sm);
  font-weight:var(--fw-semibold);
  color:var(--text-tertiary);
  cursor:pointer;
  transition: all var(--tr-spring);
  -webkit-tap-highlight-color:transparent;
  font-family:inherit;
  justify-self:center;
}
.q-dot:active{ transform:scale(0.88); }
.q-dot.answered{
  border-color:var(--brand);
  color:var(--brand);
  background:var(--brand-light);
}
.q-dot.current{
  border-color:var(--brand);
  color:var(--text-inverse);
  background:var(--brand);
  box-shadow:0 2px 8px rgba(30,64,175,0.3);
  transform:scale(1.1);
}

/* ============================================================
   结果页
   ============================================================ */
.result-body{
  flex:1; overflow-y:auto;
  padding:var(--sp-4) var(--sp-5) var(--sp-8);
  -webkit-overflow-scrolling:touch;
}

/* 结果页头 */
.result-banner{
  text-align:center;
  margin-bottom:var(--sp-5);
  padding-top:var(--sp-3);
}
.result-banner .rb-icon{
  width:56px; height:56px; margin:0 auto var(--sp-3);
  border-radius:var(--radius-xl);
  display:flex; align-items:center; justify-content:center;
}
.result-banner h2{
  font-size:var(--fs-2xl);
  font-weight:var(--fw-bold);
  color:var(--text-primary);
  letter-spacing:var(--ls-tight);
  margin-bottom:var(--sp-1);
}
.result-banner p{
  font-size:var(--fs-sm);
  color:var(--text-secondary);
  letter-spacing:var(--ls-wide);
}

/* 环形图 + 图例 */
.donut-card{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius-lg);
  padding:var(--sp-6) var(--sp-5);
  margin-bottom:var(--sp-3);
  box-shadow:var(--shadow-card);
}
.donut-wrap{
  display:flex;
  align-items:center;
  gap:var(--sp-6);
}
.donut-wrap svg{
  width:140px;
  height:140px;
  flex-shrink:0;
}
.donut-legend{
  display:flex;
  flex-direction:column;
  gap:var(--sp-2-5);
  flex:1;
}
.donut-legend .di{
  display:flex;
  align-items:center;
  gap:var(--sp-2);
  padding:var(--sp-2-5) var(--sp-3);
  background:var(--bg-subtle);
  border-radius:var(--radius-base);
}
.donut-legend .di .dot{
  width:12px; height:12px; border-radius:50%;
  flex-shrink:0;
}
.donut-legend .di .lbl{
  font-size:var(--fs-sm);
  font-weight:var(--fw-medium);
  color:var(--text-primary);
  flex:1;
}
.donut-legend .di .pct{
  font-size:var(--fs-sm);
  font-weight:var(--fw-bold);
  color:var(--text-primary);
}

/* 较上次测试变化 */
.diff-card{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius-xl);
  padding:var(--sp-5);
  margin:0 var(--sp-4) var(--sp-3);
}
.diff-title{
  display:flex;
  align-items:center;
  gap:var(--sp-1-5);
  font-size:var(--fs-xs);
  font-weight:var(--fw-semibold);
  color:var(--text-tertiary);
  margin-bottom:var(--sp-3);
  letter-spacing:var(--ls-wide);
}
.diff-title svg{ color:var(--brand); }
.diff-list{
  display:flex;
  flex-direction:column;
  gap:var(--sp-2);
}
.diff-item{
  display:flex;
  align-items:center;
  gap:var(--sp-2);
  padding:var(--sp-2) var(--sp-3);
  background:var(--bg-subtle);
  border-radius:var(--radius-base);
}
.diff-item .diff-dot{
  width:22px; height:22px;
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-inverse);
  font-size:10px;
  font-weight:var(--fw-bold);
  flex-shrink:0;
}
.diff-item .diff-label{
  flex:1;
  font-size:var(--fs-sm);
  color:var(--text-primary);
  font-weight:var(--fw-medium);
}
.diff-item .diff-val{
  font-size:var(--fs-sm);
  font-weight:var(--fw-bold);
  color:var(--text-primary);
  min-width:20px;
  text-align:right;
}
.diff-item .diff-arrow{
  font-size:var(--fs-xs);
  font-weight:var(--fw-bold);
  min-width:44px;
  text-align:right;
}

/* 转发到微信群 */
.share-wechat-btn{
  display:flex;
  flex-direction:column;
  gap:var(--sp-2-5);
  padding:0 var(--sp-4) var(--sp-6);
}

/* ============================================================
   历史页 - 卡片式设计
   ============================================================ */
.hist-body{
  flex:1; overflow-y:auto;
  padding:var(--sp-4) var(--sp-5) var(--sp-8);
  -webkit-overflow-scrolling:touch;
}
.hist-body-inner{
  display:flex;
  flex-direction:column;
  gap:var(--sp-3);
}

/* 历史卡片 */
.hist-card{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius-xl);
  padding:var(--sp-5);
  cursor:pointer;
  transition: all var(--tr-base);
}
.hist-card:active{ transform:scale(0.99); border-color:var(--border-default); }

/* 卡片顶部：类型标识 + 信息 + 删除按钮 */
.hist-card .hc-top{
  display:flex;
  align-items:center;
  gap:var(--sp-3);
  margin-bottom:var(--sp-4);
}
.hist-card .hc-badge{
  width:44px; height:44px;
  border-radius:var(--radius-default);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-inverse);
  font-weight:var(--fw-bold);
  font-size:var(--fs-base);
  flex-shrink:0;
  box-shadow:0 3px 10px rgba(0,0,0,0.1);
}
.hist-card .hc-info{ flex:1; min-width:0; }
.hist-card .hc-info .hc-name{
  font-size:var(--fs-sm);
  font-weight:var(--fw-semibold);
  color:var(--text-primary);
}
.hist-card .hc-info .hc-date{
  font-size:var(--fs-micro);
  color:var(--text-tertiary);
  margin-top:var(--sp-0-5);
  display:flex;
  align-items:center;
  gap:var(--sp-1);
}
.hist-card .hc-del{
  width:32px; height:32px;
  border-radius:50%;
  border:none;
  background:transparent;
  color:var(--text-tertiary);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition: all var(--tr-fast);
  flex-shrink:0;
}
.hist-card .hc-del:hover{ background:var(--I-light); color:var(--I); }

/* 卡片内柱状图 */
.hist-card .hc-bars{
  display:flex;
  flex-direction:column;
  gap:var(--sp-1-5);
}
.hist-card .hb-row{
  display:flex;
  align-items:center;
  gap:var(--sp-2);
}
.hist-card .hb-tag{
  width:18px; height:18px;
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  font-size:10px;
  font-weight:var(--fw-bold);
  color:var(--text-inverse);
  flex-shrink:0;
}
.hist-card .hb-track{
  flex:1;
  height:6px;
  background:var(--border-light);
  border-radius:var(--radius-full);
  overflow:hidden;
}
.hist-card .hb-fill{
  height:100%;
  border-radius:var(--radius-full);
  transition: width var(--tr-slow);
}
.hist-card .hb-val{
  font-size:var(--fs-micro);
  font-weight:var(--fw-bold);
  color:var(--text-tertiary);
  min-width:14px;
  text-align:right;
}

/* 空状态 */
.hist-empty{
  text-align:center;
  padding:var(--sp-12) var(--sp-5);
}
.hist-empty .he-icon{
  width:64px; height:64px;
  margin:0 auto var(--sp-3-5);
  background:var(--bg-subtle);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.hist-empty h3{
  font-size:var(--fs-base);
  font-weight:var(--fw-semibold);
  color:var(--text-secondary);
  margin-bottom:var(--sp-1);
}
.hist-empty p{
  font-size:var(--fs-sm);
  color:var(--text-tertiary);
}

/* 查看更多按钮 */
.hist-more{
  width:100%;
  padding:var(--sp-3);
  border:1.5px dashed var(--border-default);
  border-radius:var(--radius-default);
  background:transparent;
  color:var(--text-tertiary);
  font-size:var(--fs-sm);
  font-weight:var(--fw-medium);
  cursor:pointer;
  transition: all var(--tr-base);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:var(--sp-1-5);
  font-family:inherit;
}
.hist-more:hover{ border-color:var(--brand); color:var(--brand); background:var(--brand-light); }
.hist-more:active{ transform:scale(0.99); }

/* ============================================================
   弹窗（底部弹出式）
   ============================================================ */
.modal-overlay{
  display:none;
  position:fixed; inset:0;
  z-index:var(--z-modal-backdrop);
  background:var(--bg-overlay);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  align-items:flex-end; justify-content:center;
}
.modal-overlay.active{ display:flex; }

.modal-sheet{
  width:100%;
  max-width:500px;
  background:var(--bg-card);
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  padding:var(--sp-6) var(--sp-5) calc(var(--sp-6) + var(--safe-bottom));
  animation: slideUp var(--tr-slide) both;
  max-height:85vh;
  overflow-y:auto;
  position:relative;
}
@keyframes slideUp{
  from{ transform:translateY(100%); }
  to{ transform:translateY(0); }
}

.modal-close{
  width:32px; height:32px; border-radius:50%;
  background:var(--bg-subtle); border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-tertiary);
  position:absolute; top:var(--sp-4); right:var(--sp-4);
}

.modal-title{
  font-size:var(--fs-lg);
  font-weight:var(--fw-bold);
  color:var(--text-primary);
  letter-spacing:var(--ls-tight);
  margin-bottom:var(--sp-1-5);
}
.modal-sub{
  font-size:var(--fs-sm);
  color:var(--text-secondary);
  margin-bottom:var(--sp-5);
  letter-spacing:var(--ls-wide);
}

/* 恢复/退出信息 */
.rs-info{
  background:var(--bg-subtle);
  border:1px solid var(--border-light);
  border-radius:var(--radius-default);
  padding:var(--sp-4);
  margin-bottom:var(--sp-5);
}
.rs-info-row{
  display:flex;
  align-items:center;
  gap:var(--sp-2-5);
  margin-bottom:var(--sp-2-5);
  font-size:var(--fs-sm);
  color:var(--text-primary);
}
.rs-info-row strong{ color:var(--brand); }
.rs-info-icon{
  width:28px; height:28px;
  border-radius:50%;
  background:var(--brand-light);
  display:flex; align-items:center; justify-content:center;
  color:var(--brand);
  flex-shrink:0;
}
.rs-progress{ margin-top:var(--sp-1); }

.modal-actions{
  display:flex;
  gap:var(--sp-2-5);
}
.ma-btn{
  flex:1;
  padding:var(--sp-3-5);
  border-radius:var(--radius-button);
  font-size:var(--fs-base);
  font-weight:var(--fw-semibold);
  border:none; cursor:pointer;
  transition: all var(--tr-spring);
  display:flex; align-items:center; justify-content:center; gap:var(--sp-1-5);
  font-family:inherit; letter-spacing:var(--ls-wide);
}
.ma-btn:active{ transform:scale(0.96); }
.ma-btn.primary{
  background:var(--brand-gradient);
  color:var(--text-inverse);
}
.ma-btn.primary-outline{
  background:transparent;
  border:1.5px solid var(--brand);
  color:var(--brand);
}
.ma-btn.ghost{
  background:var(--bg-subtle);
  border:1px solid var(--border-default);
  color:var(--text-secondary);
}
.ma-btn.danger{
  background:var(--error);
  color:var(--text-inverse);
}

/* 分享卡片 */
.share-card{
  background:var(--bg-subtle);
  border-radius:var(--radius-lg);
  padding:var(--sp-5);
  border:1px solid var(--border-light);
  margin-bottom:var(--sp-5);
}
.share-card .sc-top{
  height:4px;
  border-radius:var(--radius-sm);
  margin-bottom:var(--sp-4);
  background:linear-gradient(90deg, var(--D), var(--I), var(--S), var(--C));
}
.share-card .sc-logo{
  text-align:center;
  margin-bottom:var(--sp-4);
}
.share-card .sc-logo img{ width:48px; height:48px; }
.share-card .sc-title{
  text-align:center;
  font-size:var(--fs-base);
  font-weight:var(--fw-semibold);
  color:var(--text-primary);
  margin-bottom:var(--sp-4);
}
.share-card .sc-result{
  background:var(--bg-card);
  border-radius:var(--radius-default);
  padding:var(--sp-4);
  border:1px solid var(--border-light);
  margin-bottom:var(--sp-3);
}
.share-card .sc-result .sc-main{
  display:flex;
  align-items:center;
  gap:var(--sp-2-5);
  margin-bottom:var(--sp-3);
}
.share-card .sc-result .sc-main .sc-b{
  font-size:var(--fs-xl);
  font-weight:var(--fw-extrabold);
  padding:3px var(--sp-3-5);
  border-radius:var(--radius-sm);
  color:var(--text-inverse);
}
.share-card .sc-result .sc-main .sc-n{
  font-size:var(--fs-base);
  font-weight:var(--fw-semibold);
  color:var(--text-primary);
}
.share-card .sc-result .sc-main .sc-p{
  font-size:var(--fs-sm);
  color:var(--text-tertiary);
}
.share-card .sc-bars{
  display:flex;
  flex-direction:column;
  gap:var(--sp-1-5);
}
.share-card .sc-bars .sb-row{
  display:flex;
  align-items:center;
  gap:var(--sp-1-5);
}
.share-card .sc-bars .sb-tag{
  font-size:var(--fs-micro);
  font-weight:var(--fw-bold);
  color:var(--text-inverse);
  padding:2px var(--sp-1-5);
  border-radius:var(--radius-sm);
  min-width:22px;
  text-align:center;
}
.share-card .sc-bars .sb-bar{
  flex:1;
  height:5px;
  background:var(--border-default);
  border-radius:var(--radius-full);
  overflow:hidden;
}
.share-card .sc-bars .sb-bar .sb-fill{
  height:100%;
  border-radius:var(--radius-full);
}
.share-card .sc-bars .sb-score{
  font-size:var(--fs-micro);
  font-weight:var(--fw-bold);
  width:20px;
  text-align:right;
}
.share-tip{
  text-align:center;
  font-size:var(--fs-micro);
  color:var(--text-tertiary);
  letter-spacing:var(--ls-wide);
}

/* ============================================================
   响应式适配
   ============================================================ */
/* 320px - 小屏手机 */
@media (max-width:374px){
  :root{
    --fs-4xl: 28px;
    --sp-5: 16px;
    --sp-6: 20px;
  }
  #page-welcome{ padding:0 var(--sp-5); padding-top:var(--sp-10); }
  .welcome-stats{ gap:var(--sp-2); }
  .welcome-stats .item{ padding:var(--sp-3) var(--sp-2); }
  .welcome-stats .item .num{ font-size:var(--fs-xs); }
  .quiz-opt{ padding:var(--sp-3) var(--sp-3-5); }
  .quiz-opt .opt-text{ font-size:var(--fs-sm); }
  .donut-wrap{ flex-direction:column; gap:var(--sp-4); }
  .donut-wrap svg{ width:120px; height:120px; }
  .qn-grid{ gap:var(--sp-1-5); }
}

/* 428px+ - 大屏优化 */
@media (min-width:428px){
  #page-welcome{ padding:0 var(--sp-8); padding-top:var(--sp-14); }
  .quiz-body{ padding:var(--sp-6) var(--sp-8); }
  .result-body{ padding:var(--sp-5) var(--sp-8); }
  .hist-body{ padding:var(--sp-5) var(--sp-8); }
  .donut-wrap{ gap:var(--sp-8); }
  .donut-wrap svg{ width:160px; height:160px; }
}

/* 平板及以上 */
@media (min-width:640px){
  #app{
    max-width:520px;
    margin:0 auto;
    border-left:1px solid var(--border-light);
    border-right:1px solid var(--border-light);
  }
  .modal-sheet{ max-width:480px; }
}

/* ============================================================
   动画特效
   ============================================================ */

/* 页面进入：带弹性缓出 */
@keyframes pageSlideIn{
  0%{ opacity:0; transform:translateY(24px) scale(0.98); }
  100%{ opacity:1; transform:translateY(0) scale(1); }
}
.page.active{ animation:pageSlideIn 0.45s cubic-bezier(0.16,1,0.3,1) both; }

/* 选中态弹性反馈 */
.quiz-opt.selected{
  animation:optSelected 0.35s cubic-bezier(0.34,1.56,0.64,1) !important;
  animation-delay:0s !important;
}
@keyframes optSelected{
  0%{ transform:scale(1); }
  50%{ transform:scale(1.02); }
  100%{ transform:scale(1); }
}

/* 环形图入场 */
.donut-wrap svg{
  animation:donutReveal 0.6s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes donutReveal{
  0%{ opacity:0; transform:scale(0.8); }
  100%{ opacity:1; transform:scale(1); }
}

/* 弹窗滑入弹性 */
.modal-overlay.active .modal-sheet{
  animation:sheetSlideUp 0.4s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes sheetSlideUp{
  0%{ transform:translateY(100%); }
  100%{ transform:translateY(0); }
}

/* 按钮点击波纹（轻） */
.btn:not(:disabled):active,
.qf-btn:not(:disabled):active,
.ra-btn:active,
.ma-btn:active{
  animation:btnTap 0.2s ease both;
}
@keyframes btnTap{
  0%{ transform:scale(1); }
  40%{ transform:scale(0.96); }
  100%{ transform:scale(1); }
}

/* 弹窗叠加层淡入 */
.modal-overlay.active{
  animation:overlayFade 0.25s ease both;
}
@keyframes overlayFade{
  0%{ opacity:0; }
  100%{ opacity:1; }
}

/* 欢迎页LOGO轻微浮动 */
@keyframes logoFloat{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-4px); }
}
.logo-wrap{
  animation:logoFloat 3s ease-in-out infinite;
}

/* 题号导航弹出动画 */
.qn-overlay.active{
  animation:overlayFade 0.25s ease both;
}
.qn-panel{
  animation:panelScale 0.3s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes panelScale{
  0%{ opacity:0; transform:scale(0.9); }
  100%{ opacity:1; transform:scale(1); }
}
