/* ===== 考公重考模拟器 · 国风热血风格 ===== */
:root{
  --ink:#0d0b09;          /* 墨底 */
  --ink-2:#171310;
  --paper:#f3e7cf;        /* 宣纸 */
  --paper-2:#e7d6b3;
  --cinnabar:#c8322b;     /* 朱红 */
  --cinnabar-2:#e0483c;
  --gold:#d9a94e;         /* 鎏金 */
  --gold-2:#f0cd85;
  --jade:#3f7d6b;         /* 石青/黛 */
  --muted:#9a8a72;
  --ok:#4f9d6b;
  --bad:#c8322b;
  --radius:14px;
  --shadow:0 18px 50px rgba(0,0,0,.55);
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:"Noto Serif SC","Songti SC",STSong,"SimSun",Georgia,serif;
  color:var(--paper);
  background:
    radial-gradient(1200px 700px at 50% -10%, #2a1a12 0%, transparent 60%),
    radial-gradient(900px 600px at 90% 110%, #1a2620 0%, transparent 55%),
    linear-gradient(160deg,#0f0b08 0%,#140f0b 55%,#0b0908 100%);
  min-height:100vh;
  overflow-x:hidden;
}

/* ---- 背景装饰 ---- */
.bg-decor{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.bg-ink{
  position:absolute;inset:-20%;
  background:
    radial-gradient(600px 380px at 20% 30%, rgba(200,50,43,.08), transparent 70%),
    radial-gradient(700px 460px at 80% 70%, rgba(217,169,78,.07), transparent 70%);
  filter:blur(2px);
}
.bg-seal{
  position:absolute;right:-4vw;bottom:-6vh;
  font-size:44vh;line-height:1;font-weight:900;
  color:rgba(200,50,43,.05);
  transform:rotate(-6deg);
  user-select:none;
}

#app{position:relative;z-index:1;max-width:920px;margin:0 auto;padding:18px 18px 60px;min-height:100vh;display:flex;flex-direction:column;}

/* ---- HUD ---- */
.hud{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:12px 16px;margin-bottom:16px;
  background:linear-gradient(180deg,rgba(30,22,16,.9),rgba(20,15,11,.9));
  border:1px solid rgba(217,169,78,.28);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  position:sticky;top:10px;z-index:5;
  backdrop-filter:blur(6px);
}
.hud-left{display:flex;align-items:center;gap:10px;}
.hud-title{font-weight:900;letter-spacing:2px;color:var(--gold-2);}
.hud-stage{font-size:.82rem;color:var(--paper);background:rgba(200,50,43,.85);padding:2px 10px;border-radius:999px;}
.hud-stats{display:flex;gap:8px;flex-wrap:wrap;flex:1;justify-content:center;}
.stat-chip{font-size:.78rem;color:var(--paper);background:rgba(63,125,107,.22);border:1px solid rgba(217,169,78,.25);padding:3px 9px;border-radius:999px;white-space:nowrap;}
.stat-chip b{color:var(--gold-2);font-weight:700;}
.stat-chip.alt{background:rgba(200,50,43,.14);}
.hud-right{margin-left:auto;}

/* ---- 舞台/卡片 ---- */
.stage{flex:1;display:flex;flex-direction:column;}
.card{
  background:linear-gradient(180deg,rgba(28,21,15,.92),rgba(18,13,9,.94));
  border:1px solid rgba(217,169,78,.22);
  border-radius:20px;
  box-shadow:var(--shadow);
  padding:30px 30px 26px;
  position:relative;
  overflow:hidden;
  animation:rise .5s ease both;
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:20px;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(240,205,133,.06), inset 0 0 60px rgba(0,0,0,.5);
}
@keyframes rise{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}

.kicker{color:var(--cinnabar-2);letter-spacing:6px;font-size:.78rem;margin-bottom:10px;text-transform:uppercase;}
h1.title{font-size:2.1rem;margin:0 0 6px;color:var(--gold-2);letter-spacing:3px;text-shadow:0 2px 20px rgba(200,50,43,.3);}
h2.sub{font-size:1.35rem;margin:0 0 14px;color:var(--paper);letter-spacing:1px;}
.lead{color:var(--paper-2);line-height:1.9;font-size:1.02rem;}
.narr{color:#d8c7a6;line-height:2;font-size:1.02rem;white-space:pre-line;}
.narr.dim{color:#8f8069;}
.hr{height:1px;background:linear-gradient(90deg,transparent,rgba(217,169,78,.4),transparent);margin:20px 0;}

/* ---- 按钮 ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-size:1rem;font-weight:700;letter-spacing:1px;
  color:#2a1206;cursor:pointer;border:none;border-radius:12px;
  padding:13px 26px;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  box-shadow:0 8px 22px rgba(217,169,78,.28), inset 0 1px 0 rgba(255,255,255,.4);
  transition:transform .12s ease, box-shadow .2s ease, filter .2s ease;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.05);}
.btn:active{transform:translateY(0);}
.btn.cinnabar{background:linear-gradient(180deg,var(--cinnabar-2),var(--cinnabar));color:#fff;box-shadow:0 8px 22px rgba(200,50,43,.32), inset 0 1px 0 rgba(255,255,255,.25);}
.btn.big{font-size:1.12rem;padding:16px 34px;}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;filter:grayscale(.4);}
.btn-ghost{
  font-family:inherit;font-size:.82rem;color:var(--muted);cursor:pointer;
  background:transparent;border:1px solid rgba(217,169,78,.28);border-radius:999px;padding:6px 14px;
  transition:.2s;
}
.btn-ghost:hover{color:var(--gold-2);border-color:var(--gold);}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;}
.actions.center{justify-content:center;}

/* ---- 选项列表（备考/答题/面试通用） ---- */
.opts{display:flex;flex-direction:column;gap:12px;margin-top:8px;}
.opts.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));}
.opt{
  text-align:left;font-family:inherit;font-size:1rem;color:var(--paper);
  background:linear-gradient(180deg,rgba(40,30,22,.7),rgba(26,19,13,.7));
  border:1px solid rgba(217,169,78,.22);border-radius:12px;
  padding:14px 16px;cursor:pointer;line-height:1.6;
  transition:.16s;display:flex;gap:12px;align-items:flex-start;
}
.opt:hover:not(:disabled){border-color:var(--gold);transform:translateX(4px);background:linear-gradient(180deg,rgba(52,39,27,.85),rgba(32,24,16,.85));}
.opt .tag{flex:0 0 auto;width:26px;height:26px;border-radius:7px;display:grid;place-items:center;background:rgba(200,50,43,.85);color:#fff;font-weight:800;font-size:.9rem;}
.opt .body{flex:1;}
.opt.selected{border-color:var(--gold-2);box-shadow:0 0 0 2px rgba(240,205,133,.25);}
.opt.correct{border-color:var(--ok);background:linear-gradient(180deg,rgba(50,90,64,.6),rgba(28,50,36,.6));}
.opt.correct .tag{background:var(--ok);}
.opt.wrong{border-color:var(--bad);background:linear-gradient(180deg,rgba(90,40,36,.6),rgba(50,24,22,.6));}
.opt.wrong .tag{background:var(--bad);}
.opt:disabled{cursor:default;}
.opt-card{min-height:132px;}
.mini-delta{display:inline-block;margin-top:10px;color:var(--gold-2);font-size:.85rem;line-height:1.6;}

/* ---- 进度/计时 ---- */
.qbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;}
.qmeta{color:var(--muted);font-size:.86rem;letter-spacing:1px;}
.qmeta b{color:var(--gold-2);}
.timer{font-variant-numeric:tabular-nums;font-weight:800;letter-spacing:2px;color:var(--gold-2);
  background:rgba(0,0,0,.35);border:1px solid rgba(217,169,78,.3);border-radius:10px;padding:6px 14px;font-size:1.1rem;}
.timer.warn{color:#fff;background:rgba(200,50,43,.85);animation:pulse .9s infinite;}
@keyframes pulse{50%{filter:brightness(1.3);}}
.progress{height:8px;border-radius:999px;background:rgba(0,0,0,.4);overflow:hidden;border:1px solid rgba(217,169,78,.2);}
.progress > i{display:block;height:100%;background:linear-gradient(90deg,var(--cinnabar),var(--gold));transition:width .3s;}

.qstem{font-size:1.08rem;line-height:1.9;color:var(--paper);margin:6px 0 14px;white-space:pre-line;}
.qmod{display:inline-block;font-size:.76rem;color:var(--gold-2);border:1px solid rgba(217,169,78,.35);border-radius:999px;padding:2px 10px;margin-bottom:8px;letter-spacing:1px;}
.material{background:rgba(243,231,207,.06);border-left:3px solid var(--cinnabar);border-radius:8px;padding:14px 16px;line-height:1.9;color:#d8c7a6;font-size:.96rem;white-space:pre-line;margin:10px 0 18px;}

.explain{margin-top:14px;padding:12px 14px;border-radius:10px;background:rgba(63,125,107,.14);border:1px solid rgba(63,125,107,.35);color:#cfe3d8;line-height:1.8;font-size:.94rem;white-space:pre-line;}
.explain.bad{background:rgba(200,50,43,.12);border-color:rgba(200,50,43,.4);color:#f0cfca;}

/* ---- 申论简答题 ---- */
.sl-note{background:rgba(217,169,78,.1);border:1px dashed rgba(217,169,78,.42);color:var(--gold-2);border-radius:10px;padding:10px 14px;font-size:.9rem;line-height:1.7;margin:0 0 16px;}
.answer-box{width:100%;min-height:150px;resize:vertical;font-family:inherit;font-size:1rem;line-height:1.9;color:var(--paper);background:rgba(243,231,207,.05);border:1px solid rgba(217,169,78,.3);border-radius:12px;padding:14px 16px;margin-top:6px;outline:none;}
.answer-box:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(240,205,133,.2);}
.answer-box::placeholder{color:#7a6c55;}
.sl-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:.82rem;margin-top:8px;}
.sl-meta span:last-child{font-variant-numeric:tabular-nums;color:var(--gold-2);}
.answer-review{background:rgba(243,231,207,.06);border-left:3px solid var(--gold);border-radius:8px;padding:12px 16px;line-height:1.9;color:#d8c7a6;white-space:pre-line;margin:6px 0 12px;font-size:.96rem;}
.pt{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:.95rem;border-top:1px solid rgba(217,169,78,.12);}
.pt-ic{width:20px;text-align:center;font-weight:800;}
.pt.ok .pt-ic{color:var(--ok);}
.pt.no .pt-ic{color:var(--cinnabar-2);}
.pt-l{flex:1;color:var(--paper);}
.pt.no .pt-l{color:#9a8a72;}
.pt-s{font-variant-numeric:tabular-nums;color:var(--gold-2);font-weight:700;}
.pt.no .pt-s{color:#9a8a72;}

/* ---- 备考行动点 ---- */
.ap-bar{display:flex;align-items:center;gap:10px;margin:6px 0 16px;}
.ap-dots{display:flex;gap:6px;}
.ap-dot{width:16px;height:16px;border-radius:50%;background:rgba(217,169,78,.18);border:1px solid rgba(217,169,78,.4);}
.ap-dot.on{background:radial-gradient(circle at 40% 35%,var(--gold-2),var(--cinnabar));box-shadow:0 0 10px rgba(217,169,78,.6);}
.log{margin-top:16px;display:flex;flex-direction:column;gap:8px;}
.log .line{font-size:.92rem;color:#c6b590;line-height:1.6;padding-left:14px;position:relative;}
.log .line::before{content:"◆";position:absolute;left:0;color:var(--cinnabar-2);font-size:.7rem;top:4px;}

/* ---- 结果/成绩 ---- */
.scoreboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin:18px 0;}
.sb{background:rgba(0,0,0,.3);border:1px solid rgba(217,169,78,.25);border-radius:14px;padding:16px;text-align:center;}
.sb .n{font-size:2rem;font-weight:900;color:var(--gold-2);font-variant-numeric:tabular-nums;}
.sb .l{font-size:.82rem;color:var(--muted);margin-top:4px;letter-spacing:1px;}
.verdict{text-align:center;font-size:1.5rem;font-weight:900;letter-spacing:3px;margin:14px 0;}
.verdict.pass{color:var(--gold-2);text-shadow:0 2px 24px rgba(217,169,78,.4);}
.verdict.fail{color:var(--cinnabar-2);}

/* 面试评委 */
.judges{display:flex;gap:10px;justify-content:center;margin:14px 0;flex-wrap:wrap;}
.judge{text-align:center;font-size:.82rem;color:var(--muted);}
.judge .face{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;font-size:1.6rem;margin:0 auto 4px;
  background:linear-gradient(180deg,rgba(40,30,22,.9),rgba(24,18,12,.9));border:1px solid rgba(217,169,78,.3);}

/* 机关生涯界面 */
.career-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px;}
.dept-badge{font-size:1rem;font-weight:800;color:#fff;background:linear-gradient(180deg,var(--cinnabar-2),var(--cinnabar));padding:10px 16px;border-radius:999px;white-space:nowrap;}
.career-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(260px,.95fr);gap:18px;align-items:start;}
.career-panel{background:rgba(0,0,0,.24);border:1px solid rgba(217,169,78,.2);border-radius:16px;padding:16px;}
.career-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.career-stat{background:rgba(63,125,107,.14);border:1px solid rgba(63,125,107,.3);border-radius:12px;padding:12px;}
.career-stat.bad{background:rgba(200,50,43,.1);border-color:rgba(200,50,43,.25);}
.cs-label{font-size:.82rem;color:var(--muted);}
.cs-value{font-size:1.6rem;font-weight:900;color:var(--gold-2);margin-top:4px;}
.log.compact{gap:6px;}

/* 固定重置按钮 */
.btn-float-reset{
  position:fixed;right:18px;bottom:18px;z-index:20;
  font-family:inherit;font-size:.92rem;font-weight:700;letter-spacing:1px;
  color:#fff;background:linear-gradient(180deg,var(--cinnabar-2),var(--cinnabar));
  border:none;border-radius:999px;padding:12px 18px;cursor:pointer;
  box-shadow:0 14px 30px rgba(200,50,43,.28);
}
.btn-float-reset:hover{filter:brightness(1.05);}

/* 结局 */
.ending-badge{font-size:3rem;text-align:center;margin:6px 0;}
.ending-title{text-align:center;font-size:1.8rem;font-weight:900;letter-spacing:4px;color:var(--gold-2);margin:0 0 10px;text-shadow:0 2px 30px rgba(200,50,43,.4);}

/* ---- toast ---- */
.toast{
  position:fixed;left:50%;bottom:40px;transform:translateX(-50%) translateY(20px);
  background:linear-gradient(180deg,rgba(40,30,22,.98),rgba(24,18,12,.98));
  border:1px solid var(--gold);color:var(--gold-2);
  padding:12px 22px;border-radius:999px;font-weight:700;letter-spacing:1px;
  box-shadow:var(--shadow);z-index:50;opacity:0;transition:.3s;pointer-events:none;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

.foot{text-align:center;color:#6b5f4c;font-size:.78rem;letter-spacing:1px;margin-top:22px;}
.hidden{display:none !important;}

/* 差量提示 */
.delta{font-size:.8rem;margin-left:6px;}
.delta.up{color:var(--ok);}
.delta.down{color:var(--cinnabar-2);}

@media (max-width:640px){
  .card{padding:22px 18px;}
  h1.title{font-size:1.7rem;}
  .hud-stats{order:3;width:100%;justify-content:flex-start;}
  .bg-seal{font-size:34vh;}
  .opts.grid-two{grid-template-columns:1fr;}
  .career-grid{grid-template-columns:1fr;}
  .career-top{flex-direction:column;}
  .btn-float-reset{right:12px;bottom:12px;padding:10px 14px;}
}
