/* ============================================================
   初二语文总复习 · 样式
   设计语言：宣纸米色 + 墨色 + 朱砂红，宋体标题，护眼可读
   ============================================================ */

:root{
  --paper:#f7f2e7;
  --paper-2:#f1ead9;
  --card:#fffdf7;
  --ink:#2c2a26;
  --ink-soft:#5a554c;
  --muted:#938b7c;
  --line:#e6ddc9;
  --line-soft:#efe8d8;
  --seal:#b5402e;        /* 朱砂红 */
  --seal-soft:#f3e2dc;
  --jade:#5b8c6e;        /* 已读 / 正确 */
  --jade-soft:#e4efe7;
  --gold:#c4992a;        /* 星标 */
  --blue:#3a6ea5;
  --sidebar:#322f2a;
  --sidebar-soft:#3d3a33;
  --shadow:0 1px 2px rgba(60,50,30,.05),0 8px 24px rgba(60,50,30,.06);
  --shadow-lg:0 12px 40px rgba(60,50,30,.14);
  --serif:"Songti SC","STSong","SimSun","Noto Serif CJK SC",serif;
  --sans:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei","Helvetica Neue",sans-serif;
  --r:14px;
  --sidebar-w:288px;
}

[data-theme="dark"]{
  --paper:#1c1a17;
  --paper-2:#211f1b;
  --card:#26231e;
  --ink:#ece6d8;
  --ink-soft:#c3bcab;
  --muted:#8f877a;
  --line:#3a352d;
  --line-soft:#332f28;
  --seal:#e0795f;
  --seal-soft:#3a2722;
  --jade:#7fb795;
  --jade-soft:#23332a;
  --gold:#d7b454;
  --blue:#7ba6d6;
  --sidebar:#161410;
  --sidebar-soft:#211e19;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.3);
  --shadow-lg:0 12px 40px rgba(0,0,0,.5);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  background-image:radial-gradient(rgba(140,120,80,.05) 1px,transparent 1px);
  background-size:22px 22px;
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:var(--seal);text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--seal-soft);color:var(--seal)}

/* ---------- 布局 ---------- */
#sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);
  background:var(--sidebar);color:#e8e2d4;display:flex;flex-direction:column;
  z-index:60;box-shadow:2px 0 30px rgba(0,0,0,.12);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
}
#main{margin-left:var(--sidebar-w);min-height:100vh}
#view{max-width:860px;margin:0 auto;padding:34px 40px 90px}

/* ---------- 侧栏 ---------- */
.brand{padding:22px 22px 16px;border-bottom:1px solid rgba(255,255,255,.07)}
.brand .seal{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:9px;background:var(--seal);color:#fff;
  font-family:var(--serif);font-size:20px;font-weight:700;
  box-shadow:0 4px 12px rgba(181,64,46,.4);margin-bottom:10px;
}
.brand h1{font-family:var(--serif);font-size:19px;font-weight:700;color:#fff;letter-spacing:1px}
.brand p{font-size:11.5px;color:#9c9485;margin-top:3px;letter-spacing:.5px}

.side-search{padding:14px 16px 10px}
.side-search input{
  width:100%;padding:10px 14px 10px 36px;border:none;border-radius:10px;
  background:var(--sidebar-soft);color:#ece6d8;font-size:13.5px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' fill='none' stroke='%23998' stroke-width='2'%3E%3Ccircle cx='6.5' cy='6.5' r='5'/%3E%3Cpath d='M11 11l3 3'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:12px center;
}
.side-search input:focus{outline:2px solid var(--seal)}
.side-search input::placeholder{color:#8a8270}

.side-nav{flex:1;overflow-y:auto;padding:4px 10px 20px;scrollbar-width:thin}
.side-nav::-webkit-scrollbar{width:6px}
.side-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:3px}

.nav-top a{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  color:#d8d2c4;font-size:14px;font-weight:500;margin:2px 0;transition:background .15s;
}
.nav-top a:hover{background:rgba(255,255,255,.06)}
.nav-top a.active{background:rgba(255,255,255,.1);color:#fff}
.nav-top a .ic{font-size:16px;width:20px;text-align:center}
.nav-quiz{background:linear-gradient(135deg,var(--seal),#9a3322)!important;color:#fff!important;margin:8px 2px!important;font-weight:600!important}
.nav-quiz:hover{filter:brightness(1.06)}

.cat-group{margin-top:12px}
.cat-head{
  display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;
  color:#8f877a;font-size:11px;font-weight:700;letter-spacing:1.5px;
  padding:8px 12px 6px;text-transform:uppercase;
}
.cat-head .ic{font-size:13px}
.cat-head .count{margin-left:auto;font-size:10px;color:#6e675b;font-weight:600;letter-spacing:0}
.cat-head .chev{transition:transform .2s;font-size:9px}
.cat-group.collapsed .chev{transform:rotate(-90deg)}
.cat-group.collapsed .cat-items{display:none}

.cat-items a{
  display:flex;align-items:center;gap:7px;padding:7px 12px 7px 30px;border-radius:8px;
  color:#b8b1a2;font-size:13px;transition:.13s;position:relative;
}
.cat-items a:hover{background:rgba(255,255,255,.05);color:#fff}
.cat-items a.active{background:rgba(181,64,46,.22);color:#fff}
.cat-items a.active::before{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:var(--seal)}
.cat-items a .t{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.cat-items a .star{color:var(--gold);font-size:11px}
.cat-items a .dot{width:6px;height:6px;border-radius:50%;background:var(--jade);flex-shrink:0;opacity:0}
.cat-items a.read .dot{opacity:1}

/* ---------- 顶栏（移动端） ---------- */
#topbar{
  display:none;position:sticky;top:0;z-index:40;align-items:center;gap:12px;
  padding:10px 14px;background:rgba(247,242,231,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
[data-theme="dark"] #topbar{background:rgba(28,26,23,.9)}
#topbar .menu-btn,#topbar .theme-btn{
  width:38px;height:38px;border:1px solid var(--line);border-radius:10px;background:var(--card);
  color:var(--ink);font-size:18px;display:flex;align-items:center;justify-content:center;
}
#topbar .tb-title{font-family:var(--serif);font-weight:700;font-size:16px;flex:1;text-align:center;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

#scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55;opacity:0;transition:opacity .25s}
#scrim.show{display:block;opacity:1}

/* 桌面端右上角主题切换 */
.theme-fab{
  position:fixed;top:20px;right:22px;z-index:30;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line);background:var(--card);color:var(--ink);font-size:18px;
  box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;transition:.15s;
}
.theme-fab:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}

/* ---------- 首页 ---------- */
.home-hero{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:38px 34px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.home-hero::after{content:"语";position:absolute;right:-10px;bottom:-30px;font-family:var(--serif);
  font-size:180px;color:var(--seal);opacity:.05;font-weight:700;line-height:1;pointer-events:none}
.home-hero .eyebrow{font-size:12px;letter-spacing:3px;color:var(--seal);font-weight:700;text-transform:uppercase}
.home-hero h2{font-family:var(--serif);font-size:32px;font-weight:700;margin:8px 0 4px;letter-spacing:1px}
.home-hero .sub{color:var(--muted);font-size:14px}

.stat-row{display:flex;gap:14px;flex-wrap:wrap;margin:22px 0 6px}
.stat{flex:1;min-width:88px;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.stat .n{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--seal);line-height:1}
.stat .l{font-size:12px;color:var(--muted);margin-top:4px}
.stat.jade .n{color:var(--jade)}

.progress-wrap{margin-top:18px}
.progress-wrap .ph{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-soft);margin-bottom:6px}
.bar{height:8px;background:var(--line);border-radius:5px;overflow:hidden}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--jade),#7fb795);border-radius:5px;transition:width .6s cubic-bezier(.4,0,.2,1)}

.cta-quiz{
  display:flex;align-items:center;gap:14px;margin-top:20px;width:100%;text-align:left;
  background:linear-gradient(135deg,var(--seal),#923022);color:#fff;border:none;border-radius:14px;
  padding:18px 22px;box-shadow:0 8px 22px rgba(181,64,46,.3);transition:.18s;
}
.cta-quiz:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(181,64,46,.4)}
.cta-quiz .big{font-size:26px}
.cta-quiz .tt{font-family:var(--serif);font-size:18px;font-weight:700}
.cta-quiz .ds{font-size:12.5px;opacity:.85}
.cta-quiz .go{margin-left:auto;font-size:20px}

.sec-title{font-family:var(--serif);font-size:18px;font-weight:700;margin:30px 0 12px;display:flex;align-items:center;gap:8px}
.sec-title .ic{color:var(--seal)}

.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.acard{
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 15px;
  box-shadow:var(--shadow);transition:.16s;text-align:left;display:flex;flex-direction:column;gap:6px;
  color:var(--ink);position:relative;min-height:74px;
}
.acard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--seal)}
.acard .cat{font-size:10.5px;color:var(--muted);letter-spacing:.5px}
.acard .nm{font-family:var(--serif);font-size:16px;font-weight:600;line-height:1.4}
.acard .star{position:absolute;top:10px;right:12px;color:var(--gold);font-size:13px}
.acard .read-tag{font-size:10.5px;color:var(--jade);font-weight:600;display:none}
.acard.read .read-tag{display:inline}

.chip-row{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  background:var(--card);border:1px solid var(--line);border-radius:20px;padding:7px 14px;font-size:13px;
  color:var(--ink);transition:.14s;
}
.chip:hover{background:var(--seal);color:#fff;border-color:var(--seal)}
.chip .star{color:var(--gold)}
.chip:hover .star{color:#ffe7a0}

/* ---------- 阅读页 ---------- */
.reader-top{position:sticky;top:0;z-index:20;background:var(--paper);padding-top:6px;margin:-6px 0 0}
[data-theme="dark"] .reader-top{background:var(--paper)}
.reader-prog{height:3px;background:var(--line);border-radius:2px;overflow:hidden;margin-bottom:14px}
.reader-prog > i{display:block;height:100%;background:var(--seal);width:0}

.reader-head{margin-bottom:6px}
.reader-head .crumb{font-size:12.5px;color:var(--muted);margin-bottom:6px}
.reader-head .crumb a{color:var(--muted)}
.reader-head h1{font-family:var(--serif);font-size:30px;font-weight:700;letter-spacing:1px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.reader-head h1 .star{color:var(--gold);font-size:22px}
.reader-tools{display:flex;flex-wrap:wrap;gap:9px;margin:14px 0 8px}
.tool{
  display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--card);
  color:var(--ink-soft);border-radius:20px;padding:7px 14px;font-size:13px;font-weight:500;transition:.14s;
}
.tool:hover{border-color:var(--seal);color:var(--seal)}
.tool.on{background:var(--seal);color:#fff;border-color:var(--seal)}
.tool.on.jade{background:var(--jade);border-color:var(--jade)}
.tool.on.gold{background:var(--gold);border-color:var(--gold);color:#3a2f10}

/* 正文 markdown 渲染 */
.prose{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:30px 34px;box-shadow:var(--shadow);margin-top:14px;
}
.prose h1{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--muted);
  border:none;letter-spacing:.5px;margin:0 0 14px}
.prose h2{font-family:var(--serif);font-size:21px;font-weight:700;margin:30px 0 12px;
  padding-bottom:8px;border-bottom:2px solid var(--seal-soft);position:relative}
.prose h2::before{content:"";position:absolute;left:0;bottom:-2px;width:46px;height:2px;background:var(--seal)}
.prose h3{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--seal);margin:22px 0 8px}
.prose h4{font-size:15px;font-weight:600;color:var(--ink-soft);margin:14px 0 6px}
.prose p{margin:9px 0;font-size:15.5px;color:var(--ink)}
.prose strong{color:var(--seal);font-weight:700}
.prose em{color:var(--blue);font-style:normal;font-weight:500}
.prose code{background:var(--paper-2);padding:2px 7px;border-radius:5px;font-size:13.5px;color:#9a3322;
  font-family:var(--serif)}
.prose hr{border:none;border-top:1px dashed var(--line);margin:22px 0}
.prose ul,.prose ol{margin:8px 0 8px 24px}
.prose li{margin:5px 0;font-size:15.5px}
.prose li::marker{color:var(--seal)}

.prose blockquote{
  background:var(--paper-2);border-left:4px solid var(--muted);border-radius:0 10px 10px 0;
  margin:12px 0;padding:12px 16px;font-size:14.5px;color:var(--ink-soft);
}
.prose blockquote p{margin:4px 0;font-size:14.5px}
.prose blockquote.answer-box{background:var(--jade-soft);border-left-color:var(--jade)}
.prose blockquote.answer-box strong{color:var(--jade)}

/* 遮挡答案模式 */
.prose.mask .answer-box{position:relative;cursor:pointer;user-select:none}
.prose.mask .answer-box > *{filter:blur(6px);transition:filter .2s}
.prose.mask .answer-box.revealed{cursor:auto}
.prose.mask .answer-box.revealed > *{filter:none;user-select:text}
.prose.mask .answer-box::after{
  content:"👆 点击查看答案";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:13px;color:var(--jade);font-weight:600;pointer-events:none;
}
.prose.mask .answer-box.revealed::after{display:none}

/* 表格 */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:12px 0;
  border:1px solid var(--line);border-radius:10px}
.prose table{width:100%;border-collapse:collapse;font-size:14px;min-width:440px}
.prose th,.prose td{border-bottom:1px solid var(--line-soft);padding:9px 13px;text-align:left;vertical-align:top}
.prose th{background:var(--paper-2);font-weight:600;font-size:13px;color:var(--ink-soft);white-space:nowrap}
.prose tr:last-child td{border-bottom:none}
.prose tbody tr:nth-child(even) td{background:var(--paper-2)}
.prose td strong{color:var(--seal)}

.reader-nav{display:flex;gap:12px;margin-top:24px}
.reader-nav a{
  flex:1;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  box-shadow:var(--shadow);transition:.15s;color:var(--ink);min-width:0;
}
.reader-nav a:hover{border-color:var(--seal);transform:translateY(-2px)}
.reader-nav a .d{font-size:11px;color:var(--muted)}
.reader-nav a .t{font-family:var(--serif);font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.reader-nav a.next{text-align:right}
.reader-nav a.disabled{opacity:.4;pointer-events:none}

/* ---------- 自测 ---------- */
.quiz-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:30px 32px;box-shadow:var(--shadow)}
.quiz-card h2{font-family:var(--serif);font-size:24px;font-weight:700;margin-bottom:4px}
.quiz-card .lead{color:var(--muted);font-size:14px;margin-bottom:18px}
.q-section-label{font-size:12.5px;font-weight:600;color:var(--ink-soft);margin:18px 0 8px}
.filter-row{display:flex;flex-wrap:wrap;gap:9px}
.filter{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border:2px solid var(--line);
  border-radius:22px;font-size:13.5px;background:var(--paper-2);color:var(--ink-soft);transition:.14s;user-select:none}
.filter.on{border-color:var(--seal);background:var(--seal-soft);color:var(--seal);font-weight:600}
.count-row{display:flex;gap:9px;flex-wrap:wrap}
.count-btn{padding:8px 18px;border:2px solid var(--line);border-radius:22px;background:var(--paper-2);
  color:var(--ink-soft);font-size:13.5px;transition:.14s}
.count-btn.on{border-color:var(--seal);background:var(--seal-soft);color:var(--seal);font-weight:600}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:24px;
  padding:16px;background:linear-gradient(135deg,var(--seal),#923022);color:#fff;border:none;border-radius:14px;
  font-size:16px;font-weight:600;box-shadow:0 8px 22px rgba(181,64,46,.3);transition:.16s}
.btn-primary:hover{transform:translateY(-2px)}
.btn-primary:disabled{opacity:.5;transform:none;cursor:not-allowed}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;
  background:var(--card);border:1.5px solid var(--line);color:var(--ink);border-radius:12px;font-size:14px;font-weight:500}
.btn-ghost:hover{border-color:var(--seal);color:var(--seal)}

.q-progress{display:flex;align-items:center;gap:14px;margin-bottom:18px;font-size:13.5px;color:var(--ink-soft)}
.q-progress .bar{flex:1}
.q-progress .bar > i{background:var(--seal)}
.q-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.q-meta span{background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:4px 12px;font-size:12px;color:var(--ink-soft)}
.q-text{font-family:var(--serif);font-size:19px;font-weight:600;line-height:1.85;margin:6px 0 4px}
.q-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.q-btn{padding:11px 22px;border-radius:22px;font-size:14px;font-weight:600;border:1.5px solid;transition:.14s}
.q-btn.show{background:var(--seal-soft);border-color:var(--seal);color:var(--seal)}
.q-btn.right{background:var(--jade-soft);border-color:var(--jade);color:var(--jade)}
.q-btn.wrong{background:#f6e3df;border-color:var(--seal);color:var(--seal)}
[data-theme="dark"] .q-btn.wrong{background:#3a2722}
.q-btn.next{background:var(--seal);border-color:var(--seal);color:#fff}
.reveal{margin-top:18px;padding:18px;background:var(--jade-soft);border:1.5px solid var(--jade);border-radius:12px;display:none}
.reveal.show{display:block;animation:fade .3s}
.reveal .lbl{font-size:12px;color:var(--jade);font-weight:700;letter-spacing:.5px;margin-bottom:5px}
.reveal .ans{font-size:16px;color:var(--ink);margin-bottom:10px;font-family:var(--serif)}
.reveal .method{font-size:13.5px;color:var(--ink-soft);border-top:1px dashed var(--jade);padding-top:8px}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.result{text-align:center;padding:14px 0}
.result .ring{width:128px;height:128px;border-radius:50%;margin:14px auto;display:flex;align-items:center;
  justify-content:center;font-family:var(--serif);font-size:34px;font-weight:700;
  background:conic-gradient(var(--seal) var(--pct,0%),var(--line) 0)}
.result .ring i{width:104px;height:104px;border-radius:50%;background:var(--card);display:flex;
  align-items:center;justify-content:center;font-style:normal}
.result h2{font-family:var(--serif);font-size:24px}
.result .score-line{color:var(--ink-soft);font-size:14px;margin:6px 0 16px}
.result .btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.wrong-list{text-align:left;margin-top:26px}
.wrong-list h3{font-family:var(--serif);font-size:17px;margin-bottom:10px}
.wrong-item{background:var(--paper-2);border-left:3px solid var(--seal);border-radius:0 10px 10px 0;
  padding:13px 16px;margin:9px 0}
.wrong-item .q{font-weight:600;margin-bottom:5px}
.wrong-item .a{color:var(--jade);font-size:14px}

.empty{text-align:center;color:var(--muted);padding:50px 20px;font-size:14px}
.loading{text-align:center;color:var(--muted);padding:60px 20px;font-size:14px}
.spin{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--seal);border-radius:50%;
  margin:0 auto 14px;animation:rot .8s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}

.view-enter{animation:viewIn .35s cubic-bezier(.4,0,.2,1)}
@keyframes viewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- 响应式 ---------- */
@media(max-width:880px){
  #sidebar{transform:translateX(-100%);width:84vw;max-width:320px}
  #sidebar.open{transform:translateX(0)}
  #main{margin-left:0}
  #topbar{display:flex}
  .theme-fab{display:none}
  #view{padding:18px 16px 80px}
  .home-hero{padding:26px 20px}
  .home-hero h2{font-size:25px}
  .home-hero::after{font-size:120px}
  .prose{padding:20px 18px}
  .prose h2{font-size:19px}
  .reader-head h1{font-size:24px}
  .q-text{font-size:17px}
  .stat{min-width:0;padding:12px}
  .stat .n{font-size:22px}
  .reader-top{top:56px}
}
@media(max-width:430px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .stat-row{gap:10px}
}
