:root{
  --bg:#f4efe6; --surface:#fbf8f1; --surface2:#ece5d8;
  --primary:#e8633a; --primary-d:#b94818;
  --text:#1a1614; --muted:#8a827d; --line:#e7e0d6; --line-2:#d8cfc1;
  --ok:#5a7a4a; --no:#c0492f; --radius:10px;
  --ff-serif:"Noto Serif SC",serif; --ff-sans:"Noto Sans SC",-apple-system,system-ui,sans-serif; --ff-mono:"JetBrains Mono",monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--ff-sans);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 12% 8%,rgba(232,99,58,.06),transparent 35%),radial-gradient(circle at 88% 0%,rgba(122,74,90,.05),transparent 40%);min-height:100vh}
.serif{font-family:var(--ff-serif)}
a{color:inherit}
button{font-family:inherit;cursor:pointer}
.loading,.empty{color:var(--muted);text-align:center;padding:50px 20px}
main#app{max-width:min(1680px,95vw);margin:0 auto;padding:24px clamp(16px,2.4vw,40px) 90px}
.btn{background:var(--text);color:var(--bg);border:none;padding:10px 20px;border-radius:8px;font-size:15px;font-weight:500;transition:.15s}
.btn:hover{background:#2a2320}
.btn.accent{background:var(--primary)} .btn.accent:hover{background:var(--primary-d)}
.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line-2)}
.btn.sm{padding:7px 14px;font-size:13.5px}
.kv{color:var(--muted);font-size:13px;font-family:var(--ff-mono)}
.tag{background:var(--surface2);color:var(--muted);padding:2px 9px;border-radius:6px;font-size:12px;font-family:var(--ff-mono)}

/* 登录 */
.login-wrap{max-width:380px;margin:14vh auto 0;text-align:center}
.login-wrap .lg-mark{width:60px;height:60px;border-radius:6px;background:var(--text);color:var(--bg);display:grid;place-items:center;font-family:var(--ff-serif);font-weight:900;font-size:30px;margin:0 auto 18px;transform:rotate(-3deg)}
.login-wrap h1{font-family:var(--ff-serif);font-size:26px;margin:0 0 6px}
.login-wrap .sub{color:var(--muted);font-size:14px;margin-bottom:24px}
.login-wrap input{width:100%;padding:12px 14px;border:1px solid var(--line-2);border-radius:10px;font-size:16px;outline:none;background:var(--surface);text-align:center;letter-spacing:.1em}
.login-wrap input:focus{border-color:var(--primary)}
.login-wrap .btn{width:100%;margin-top:14px;padding:12px}
.login-err{color:var(--no);font-size:13px;margin-top:10px;min-height:18px}

/* 首页 */
.rx-hero{text-align:center;margin:18px 0 30px}
.rx-hero .eyebrow{font-family:var(--ff-mono);font-size:12px;letter-spacing:.2em;color:var(--muted)}
.rx-hero h1{font-family:var(--ff-serif);font-weight:900;font-size:clamp(28px,3.4vw,40px);margin:6px 0}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;max-width:900px;margin:0 auto}
.card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:26px;cursor:pointer;transition:.15s;text-align:center}
.card:hover{transform:translateY(-3px);border-color:var(--text);box-shadow:0 16px 32px -22px rgba(0,0,0,.4)}
.card .ico{font-size:40px;margin-bottom:12px}
.card .t{font-family:var(--ff-serif);font-weight:700;font-size:20px}
.card .c{color:var(--muted);font-size:13.5px;margin-top:8px;line-height:1.6}
.card.q{border-top:4px solid #5a7a4a}.card.f{border-top:4px solid var(--primary)}.card.r{border-top:4px solid #3e4a5a}
.topbar{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.topbar .back{color:var(--muted);font-family:var(--ff-mono);font-size:13px;cursor:pointer}
.topbar .back:hover{color:var(--text)}
.topbar .spacer{flex:1}

/* 弹窗(姓名) */
.modal-ov{position:fixed;inset:0;background:rgba(26,22,20,.45);display:grid;place-items:center;z-index:100;padding:20px}
.modal{background:var(--surface);border-radius:16px;padding:26px;width:100%;max-width:380px}
.modal h3{font-family:var(--ff-serif);font-size:19px;margin:0 0 4px}
.modal .sub{color:var(--muted);font-size:13px;margin-bottom:16px}
.modal input{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:10px;font-size:16px;outline:none;background:var(--bg)}
.modal input:focus{border-color:var(--primary)}
.modal .row{display:flex;gap:8px;margin-top:16px}
.modal .row .btn{flex:1}

/* 考试外壳 */
.exam-top{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;background:var(--text);color:var(--bg);border-radius:10px;padding:11px 16px;margin:0 0 14px}
.exam-top .et-title{font-weight:600;font-size:15px;flex:1}
.exam-top .et-name{font-family:var(--ff-mono);font-size:12px;opacity:.7}
.exam-top .et-timer{font-family:var(--ff-mono);font-weight:700;font-size:17px;background:rgba(255,255,255,.12);padding:4px 12px;border-radius:8px}
.exam-top .et-btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600}
.exam-top .et-btn:hover{background:var(--primary-d)}
.mk-steps{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-family:var(--ff-mono);font-size:12px;color:var(--muted);margin:0 0 12px}
.mk-step{padding:4px 10px;border-radius:999px;border:1px solid var(--line)}
.mk-step.cur{background:var(--text);color:var(--bg);font-weight:700}
.mk-step.done{color:var(--ok);border-color:#cdddbe}
.mk-arrow{color:var(--line-2)}
.exam-audio{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:10px 14px;margin:0 0 12px}
.exam-audio audio{width:100%}
.mk-ph{font-family:var(--ff-serif);font-weight:700;font-size:18px;margin:18px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.split{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(16px,2vw,26px);align-items:start;margin-top:6px}
@media(max-width:980px){.split{grid-template-columns:1fr}}
.pane{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(16px,2vw,24px)}
.pane.sticky{position:sticky;top:74px;max-height:calc(100vh - 96px);overflow:auto}
.article{font-family:Cambria,Georgia,"Noto Serif SC",serif;font-size:16px;line-height:1.9}
.article p{margin:0 0 12px}

/* 题目(与 vocab 真考式一致) */
.qgroup-req{background:var(--surface2);border-radius:6px;padding:12px 14px;margin:16px 0 12px;font-size:14px;white-space:pre-wrap}
.q{padding:14px 0;border-bottom:1px dashed var(--line-2)}
.q .qt{display:flex;gap:8px;align-items:flex-start;margin-bottom:6px}
.q .qt .qnum{flex:0 0 auto;min-width:22px;height:22px;line-height:22px;text-align:center;background:var(--surface2);border-radius:5px;color:var(--primary-d);font-weight:700}
.q .qt .qtx{flex:1;font-weight:600}
.opts.vert{display:flex;flex-direction:column;gap:8px;margin:8px 0 2px}
.opts.vert .opt{display:flex;align-items:flex-start;gap:10px;margin:0}
.opt{display:block;padding:9px 12px;border:1px solid var(--line-2);border-radius:8px;cursor:pointer;transition:.12s;font-size:15px}
.opt:hover{background:var(--surface2)}
.opt.sel{border-color:var(--primary);background:#fbe9df}
.opt .opt-mark{flex:0 0 auto;width:18px;height:18px;margin-top:1px;border:2px solid var(--line-2);border-radius:50%;display:grid;place-items:center;transition:.12s}
.opts.multi .opt .opt-mark{border-radius:5px}
.opt .opt-mark::after{content:"";width:8px;height:8px;border-radius:50%;background:transparent}
.opts.multi .opt .opt-mark::after{border-radius:2px}
.opt.sel .opt-mark{border-color:var(--primary)} .opt.sel .opt-mark::after{background:var(--primary)}
.opt .opt-label{flex:1;line-height:1.5}
.fill{font-family:inherit;font-size:15px;padding:7px 11px;border:1px solid var(--line-2);border-radius:7px;min-width:150px}
.blank{min-width:120px;margin:0 4px}
.match-table{margin:10px 0 6px;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.mt-row{display:grid;grid-template-columns:1fr repeat(var(--mtcols,6),38px);align-items:stretch;border-bottom:1px solid var(--line)}
.mt-row:last-child{border-bottom:0}
.mt-head{background:var(--surface2);font-family:var(--ff-mono);font-weight:700}
.mt-head .mt-col{display:grid;place-items:center;padding:8px 0;border-left:1px solid var(--line)}
.mt-stmt{padding:11px 13px;font-size:14.5px;line-height:1.5;display:flex;gap:6px;align-items:flex-start}
.mt-stmt .qnum{flex:0 0 auto;min-width:22px;height:22px;line-height:22px;text-align:center;background:var(--surface2);border-radius:5px;color:var(--primary-d);font-weight:700}
.opt.mt-cell{border:0;border-left:1px solid var(--line);border-radius:0;display:grid;place-items:center;cursor:pointer;min-height:40px;background:var(--surface)}
.opt.mt-cell::after{content:"";width:14px;height:14px;border:2px solid var(--line-2);border-radius:50%}
.opt.mt-cell:hover{background:var(--surface2)}
.opt.mt-cell.sel{background:#fbe9df}.opt.mt-cell.sel::after{background:var(--primary);border-color:var(--primary)}

/* 底部题号导航 */
.exam-nav{position:sticky;bottom:0;z-index:30;display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 12px;margin-top:16px;box-shadow:0 -6px 18px -14px rgba(0,0,0,.4)}
.en-chips{flex:1;display:flex;gap:6px;flex-wrap:wrap;overflow-x:auto}
.en-chip{min-width:30px;height:30px;padding:0 6px;border:1px solid var(--line-2);background:var(--surface);color:var(--muted);border-radius:6px;font-family:var(--ff-mono);font-size:12px;cursor:pointer}
.en-chip.wide{min-width:84px}
.en-chip:hover{border-color:var(--primary)}
.en-chip.done{background:var(--text);color:var(--bg);border-color:var(--text)}
.en-arrows{display:flex;gap:6px}
.en-arrow{width:36px;height:30px;border:1px solid var(--line-2);background:var(--surface);border-radius:6px;cursor:pointer;font-size:18px;line-height:1}

/* 写作 */
.prompt-box{font-size:16px;line-height:1.85;background:var(--surface2);border-radius:8px;padding:16px 18px;margin-bottom:14px}
.chart-img{max-width:100%;border:1px solid var(--line);border-radius:8px;margin:6px 0 14px;background:#fff}
textarea.essay{width:100%;min-height:55vh;font-family:Cambria,Georgia,serif;font-size:16px;line-height:1.8;padding:16px;border:1px solid var(--line-2);border-radius:8px;outline:none;resize:vertical;background:var(--surface)}
textarea.essay:focus{border-color:var(--primary)}
.wc{color:var(--muted);font-size:13px;font-family:var(--ff-mono);margin-top:8px}

/* 完成页 */
.finish{text-align:center;padding:40px 20px}
.finish .big{font-size:54px}
.finish h2{font-family:var(--ff-serif);font-size:26px;margin:10px 0 6px}

/* 结果 */
.res-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:10px;overflow:hidden;font-size:14px}
.res-table th,.res-table td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left}
.res-table th{background:var(--surface2);font-size:12px;color:var(--muted);font-family:var(--ff-mono)}
.res-table tr{cursor:pointer}
.res-table tr:hover td{background:var(--surface2)}
.res-band{font-family:var(--ff-mono);font-weight:700;color:var(--primary-d)}
.res-sec{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin:0 0 18px}
.res-sec h3{font-family:var(--ff-serif);font-size:18px;margin:0 0 12px;display:flex;align-items:center;gap:10px}
.res-stat{display:flex;gap:22px;flex-wrap:wrap;margin-bottom:14px}
.res-stat .b{font-family:var(--ff-serif);font-weight:900;font-size:28px;line-height:1}
.res-stat .b.acc{color:var(--primary-d)}
.res-stat .l{font-size:11px;color:var(--muted);font-family:var(--ff-mono);margin-top:4px}
.res-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.res-grid{grid-template-columns:1fr}}
.res-list{font-size:13.5px}
.res-list .row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed var(--line)}
.res-list .row b{color:var(--text)}
.wrong-item{font-size:13px;padding:7px 10px;border-radius:7px;background:#f6ddd4;margin-bottom:6px}
.wrong-item .yi{color:var(--no)} .wrong-item .ri{color:var(--ok)}
.essay-ro{font-family:Cambria,Georgia,serif;font-size:15px;line-height:1.85;background:var(--surface2);border-radius:8px;padding:14px 16px;white-space:pre-wrap}
.label{font-family:var(--ff-mono);font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:14px 0 6px}
.pill{display:inline-block;font-size:12px;font-family:var(--ff-mono);background:var(--surface2);border-radius:6px;padding:2px 8px;margin:0 6px 6px 0}

/* 限时(到点自动交卷):剩余 ≤60s 红色脉冲 */
.et-timer.low{color:#ff6b6b;animation:tpulse 1s ease-in-out infinite}
@keyframes tpulse{50%{opacity:.5}}
/* 快速测试范围选择 */
.scope-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.scope-opt{flex:1;min-width:80px;padding:8px 6px;border:1.5px solid var(--line-2);border-radius:8px;background:var(--bg);font:inherit;font-size:13px;cursor:pointer}
.scope-opt.sel{border-color:var(--primary);background:#fbe9df;color:var(--primary-d);font-weight:600}
/* 打印 */
@media print{
  body{background:#fff;background-image:none}
  .no-print,.exam-nav,.exam-top,.topbar{display:none!important}
  main#app{max-width:100%;padding:0}
  .res-sec,.res-table,.card{box-shadow:none}
  .res-sec,.wrong-item,.res-grid>div{break-inside:avoid}
}
