:root{
  --bg:#f6f7f9;
  --surface:#ffffff;
  --ink:#1d2433;
  --ink-soft:#5b6577;
  --line:#e6e9ef;
  --accent:#b4232a;        /* 沉稳书卷红，点到为止 */
  --accent-soft:#fbeaea;
  --accent-ink:#8c1b21;
  --ok:#15803d; --ok-soft:#e7f5ec;
  --no:#b4232a; --no-soft:#fdecec;
  --warn:#b45309;
  --radius:14px;
  --shadow:0 1px 2px rgba(20,30,50,.04),0 6px 24px rgba(20,30,50,.06);
  --maxw:880px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  line-height:1.65; -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 18px}

/* Topbar */
.topbar{position:sticky; top:0; z-index:50; background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px); border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex; align-items:center; justify-content:space-between; height:58px}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--ink)}
.brand-mark{display:grid; place-items:center; width:30px; height:30px; border-radius:9px;
  background:var(--accent); color:#fff; font-weight:700; font-size:16px}
.brand-text{font-weight:650; font-size:15.5px; letter-spacing:.2px}
.nav{display:flex; align-items:center; gap:6px}
.nav a{text-decoration:none; color:var(--ink-soft); font-size:14.5px; padding:7px 11px; border-radius:9px}
.nav a:hover{background:var(--bg); color:var(--ink)}
.nav a.active{color:var(--accent-ink); background:var(--accent-soft); font-weight:600}
.badge{display:inline-grid; place-items:center; min-width:18px; height:18px; padding:0 5px;
  font-size:11px; border-radius:9px; background:var(--accent); color:#fff; vertical-align:middle}
.icon-btn{border:none; background:transparent; font-size:16px; cursor:pointer; color:var(--ink-soft);
  height:34px; min-width:34px; padding:0 8px; border-radius:9px}
.icon-btn:hover{background:var(--bg)}
.sync-state{font-size:12px; color:var(--ink-soft); padding:0 4px; white-space:nowrap}
.field{display:flex; flex-direction:column; gap:5px; margin:10px 0}
.field span{font-size:13px; color:var(--ink-soft)}
.field input{padding:9px 11px; border:1px solid var(--line); border-radius:9px; font-size:15px; font-family:inherit}
.field input:focus{outline:2px solid var(--accent-soft); border-color:var(--accent)}
.err{color:var(--no); font-size:13px; min-height:18px; margin:4px 0 0}

main{padding:26px 0 60px; min-height:60vh}

/* Hero */
.hero{margin-bottom:22px}
.hero h1{font-size:24px; margin:0 0 6px; letter-spacing:.3px}
.hero p{margin:0; color:var(--ink-soft); font-size:14.5px}
.stat-row{display:flex; gap:10px; flex-wrap:wrap; margin-top:16px}
.stat{background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:12px 16px; flex:1; min-width:120px}
.stat .num{font-size:22px; font-weight:700}
.stat .lbl{font-size:12.5px; color:var(--ink-soft)}

/* Chapter cards */
.section-title{font-size:14px; color:var(--ink-soft); margin:24px 2px 12px; font-weight:600; letter-spacing:.5px}
.cards{display:grid; grid-template-columns:repeat(auto-fill,minmax(255px,1fr)); gap:14px}
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:16px 17px; box-shadow:var(--shadow); cursor:pointer; transition:transform .12s ease, border-color .12s}
.card:hover{transform:translateY(-2px); border-color:#d2d7e0}
.card .ch-no{font-size:12px; color:var(--accent-ink); font-weight:700; letter-spacing:.6px}
.card .ch-title{font-size:15.5px; font-weight:650; margin:3px 0 10px; line-height:1.4}
.card .ch-meta{display:flex; gap:8px; flex-wrap:wrap; font-size:12px; color:var(--ink-soft)}
.pill{background:var(--bg); border-radius:20px; padding:2px 9px}
.card .progress{height:6px; background:var(--bg); border-radius:6px; margin-top:12px; overflow:hidden}
.card .progress > i{display:block; height:100%; background:var(--accent); width:0}
.card .progress-lbl{font-size:11.5px; color:var(--ink-soft); margin-top:6px}

/* Buttons */
.btn{border:1px solid var(--accent); background:var(--accent); color:#fff; font-size:14px;
  padding:9px 16px; border-radius:10px; cursor:pointer; font-weight:600; transition:filter .12s}
.btn:hover{filter:brightness(1.05)}
.btn.ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.btn.ghost:hover{background:var(--bg)}
.btn.ghost.danger{color:var(--no); border-color:#f0c9c9}
.btn.sm{padding:6px 11px; font-size:13px}
.btn:disabled{opacity:.5; cursor:not-allowed; filter:none}

/* Practice toolbar */
.ptools{display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:16px}
.ptools .crumbs{font-size:13px; color:var(--ink-soft)}
.ptools .crumbs a{color:var(--accent-ink); text-decoration:none}
.seg{display:inline-flex; background:var(--surface); border:1px solid var(--line); border-radius:10px; overflow:hidden}
.seg button{border:none; background:transparent; padding:7px 12px; font-size:13px; cursor:pointer; color:var(--ink-soft)}
.seg button.active{background:var(--accent); color:#fff; font-weight:600}
.spacer{flex:1}
.score-chip{font-size:13px; color:var(--ink-soft); background:var(--surface); border:1px solid var(--line);
  padding:6px 12px; border-radius:20px}
.score-chip b{color:var(--ink)}

/* Navigator */
.navigator{display:flex; flex-wrap:wrap; gap:7px; background:var(--surface); border:1px solid var(--line);
  border-radius:12px; padding:12px; margin-bottom:16px; max-height:148px; overflow:auto}
.navigator button{width:34px; height:34px; border-radius:8px; border:1px solid var(--line);
  background:#fff; font-size:12.5px; cursor:pointer; color:var(--ink-soft)}
.navigator button.cur{outline:2px solid var(--accent); outline-offset:1px; color:var(--ink); font-weight:700}
.navigator button.correct{background:var(--ok-soft); border-color:#bfe3cb; color:var(--ok)}
.navigator button.wrong{background:var(--no-soft); border-color:#f0c9c9; color:var(--no)}
.navigator button.seen{background:var(--bg)}

/* Question card */
.qcard{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:22px 24px}
.qhead{display:flex; align-items:center; gap:8px; margin-bottom:12px}
.qtype{font-size:11.5px; font-weight:700; color:var(--accent-ink); background:var(--accent-soft);
  padding:2px 9px; border-radius:20px}
.qnum{font-size:12.5px; color:var(--ink-soft)}
.qstem{font-size:16.5px; font-weight:600; line-height:1.7; white-space:pre-wrap; margin-bottom:16px}
.options{display:flex; flex-direction:column; gap:10px}
.option{display:flex; align-items:flex-start; gap:11px; border:1.5px solid var(--line); border-radius:11px;
  padding:11px 14px; cursor:pointer; background:#fff; transition:border-color .12s, background .12s}
.option:hover{border-color:#cfd4de}
.option .key{flex:none; width:24px; height:24px; border-radius:7px; background:var(--bg);
  display:grid; place-items:center; font-size:13px; font-weight:700; color:var(--ink-soft)}
.option .otext{flex:1; font-size:15px; line-height:1.6}
.option.selected{border-color:var(--accent); background:var(--accent-soft)}
.option.selected .key{background:var(--accent); color:#fff}
.option.correct{border-color:var(--ok); background:var(--ok-soft)}
.option.correct .key{background:var(--ok); color:#fff}
.option.incorrect{border-color:var(--no); background:var(--no-soft)}
.option.incorrect .key{background:var(--no); color:#fff}
.option.locked{cursor:default}

.qactions{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; align-items:center}
.verdict{font-size:14px; font-weight:600; padding:4px 0}
.verdict.ok{color:var(--ok)} .verdict.no{color:var(--no)}
.answer-box{margin-top:16px; border-top:1px dashed var(--line); padding-top:14px}
.answer-box .lbl{font-size:12.5px; color:var(--ink-soft); font-weight:600; margin-bottom:6px}
.answer-box .ans{font-size:15px; color:var(--ink)}
.ref-text{white-space:pre-wrap; font-size:14.5px; line-height:1.8; color:var(--ink)}

/* cloze blanks */
.blank{display:inline-block; min-width:84px; border:none; border-bottom:2px solid var(--accent);
  background:var(--accent-soft); border-radius:4px 4px 0 0; padding:1px 6px; font-size:14.5px;
  font-family:inherit; text-align:center; margin:0 2px; color:var(--accent-ink)}
.blank.ok{border-color:var(--ok); background:var(--ok-soft); color:var(--ok)}
.blank.no{border-color:var(--no); background:var(--no-soft); color:var(--no)}
.blank-answer{color:var(--ok); font-weight:600}

.foot-nav{display:flex; justify-content:space-between; gap:10px; margin-top:18px}

.footer{border-top:1px solid var(--line); color:var(--ink-soft); font-size:12.5px; padding:18px 0}
.footer .wrap{text-align:center}

/* Modal */
.modal{position:fixed; inset:0; background:rgba(20,28,45,.4); display:grid; place-items:center; z-index:100; padding:18px}
.modal.hidden{display:none}
.modal-card{background:#fff; border-radius:16px; padding:22px; width:100%; max-width:420px; box-shadow:var(--shadow)}
.modal-card h3{margin:0 0 14px}
.opt-row{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:8px 0}
.opt-row span{font-size:14.5px; font-weight:500}
.opt-row select{padding:6px 10px; border:1px solid var(--line); border-radius:8px; font-size:14px}
.opt-row input[type=checkbox]{width:20px; height:20px; accent-color:var(--accent)}
.hint{font-size:12.5px; color:var(--ink-soft); margin:0 0 8px}
.modal-actions{display:flex; justify-content:space-between; gap:10px; margin-top:18px}

.empty{text-align:center; color:var(--ink-soft); padding:60px 0}
.empty .big{font-size:42px; margin-bottom:10px}
.hidden{display:none}

@media (max-width:560px){
  .qcard{padding:18px 16px}
  .qstem{font-size:15.5px}
  .brand-text{display:none}
  .hero h1{font-size:21px}
}
