/* ===== 大三下学习系统 · 共享样式 ===== */
:root{
  --bg:#0f1729;--bg-soft:#16213e;--card:#1b2745;--card-2:#212f52;
  --ink:#e8edf7;--ink-soft:#a9b4cc;--line:#2c3a5e;
  --accent:#5b9dff;--accent-2:#7c5cff;--green:#36d399;--amber:#fbbd23;--red:#f87272;--pink:#f472b6;--cyan:#22d3ee;
  --radius:16px;--shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;
  background:linear-gradient(160deg,#0f1729 0%,#131d38 100%);color:var(--ink);line-height:1.75;font-size:16px}
#progress{position:fixed;top:0;left:0;height:4px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:999;transition:width .1s}

/* 章节切换栏 */
.chapnav{position:sticky;top:0;z-index:200;display:flex;gap:4px;flex-wrap:wrap;align-items:center;
  background:rgba(10,16,30,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:8px 14px}
.chapnav a{color:var(--ink-soft);text-decoration:none;font-size:13px;padding:5px 11px;border-radius:8px;white-space:nowrap;transition:.15s}
.chapnav a:hover{background:var(--card-2);color:var(--ink)}
.chapnav a.cur{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}
.chapnav a.home{background:var(--card-2);color:var(--accent)}
.chapnav .sp{flex:1}

.wrap{max-width:1180px;margin:0 auto;padding:0 22px;display:flex;gap:26px}
nav.side{position:sticky;top:52px;align-self:flex-start;width:230px;flex:0 0 230px;height:calc(100vh - 52px);overflow-y:auto;padding:26px 8px 40px 0;font-size:14px}
nav.side .nav-title{font-weight:700;color:var(--accent);letter-spacing:1px;margin:0 0 14px 10px;font-size:13px}
nav.side a{display:block;color:var(--ink-soft);text-decoration:none;padding:8px 12px;border-radius:10px;margin:2px 0;border-left:3px solid transparent;transition:.2s}
nav.side a:hover{background:var(--card);color:var(--ink)}
nav.side a.active{background:var(--card-2);color:#fff;border-left-color:var(--accent)}
main{flex:1;min-width:0;padding:30px 0 90px}

header.hero{background:radial-gradient(120% 140% at 0% 0%,#26356b 0%,#1a234a 60%,#161f3e 100%);
  border:1px solid var(--line);border-radius:24px;padding:36px 36px 30px;margin-bottom:26px;box-shadow:var(--shadow);position:relative;overflow:hidden}
header.hero .tag{display:inline-block;background:rgba(91,157,255,.18);color:var(--accent);padding:4px 14px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:14px}
header.hero h1{margin:0 0 8px;font-size:30px;letter-spacing:.5px}
header.hero p{margin:0;color:var(--ink-soft);font-size:15px}

section{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 28px;margin-bottom:22px;box-shadow:var(--shadow);scroll-margin-top:60px}
h2{font-size:22px;margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid var(--line);display:flex;align-items:center;gap:10px}
h2 .num{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;min-width:34px;height:34px;padding:0 8px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:15px;flex:0 0 auto}
h3{font-size:18px;margin:20px 0 10px;color:#cfe0ff}
p{margin:10px 0}
a{color:var(--accent)}

table{width:100%;border-collapse:collapse;margin:16px 0;font-size:15px;overflow:hidden;border-radius:12px}
th,td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line)}
th{background:var(--card-2);color:#cfe0ff;font-weight:600}
tr:hover td{background:rgba(91,157,255,.06)}
code{background:#0d1530;color:#8fd6ff;padding:2px 7px;border-radius:6px;font-size:13.5px}
pre{background:#0d1530;border:1px solid var(--line);border-radius:10px;padding:14px 16px;overflow-x:auto;font-size:13.5px;line-height:1.6}
pre code{background:none;padding:0}

.box{border-radius:12px;padding:14px 18px;margin:16px 0;border-left:4px solid;font-size:15px}
.box .bt{font-weight:700;display:block;margin-bottom:4px}
.box.tip{background:rgba(54,211,153,.08);border-color:var(--green)}
.box.warn{background:rgba(251,189,35,.08);border-color:var(--amber)}
.box.key{background:rgba(124,92,255,.10);border-color:var(--accent-2)}
.box.quote{background:rgba(244,114,182,.07);border-color:var(--pink);font-style:italic}
.box.ex{background:rgba(34,211,238,.08);border-color:var(--cyan)}

.fig{background:#0d1530;border:1px solid var(--line);border-radius:14px;padding:20px;margin:18px 0;text-align:center}
.fig svg{max-width:100%;height:auto}
.fig .cap{color:var(--ink-soft);font-size:13px;margin-top:10px}
.fig text{font-family:-apple-system,"PingFang SC","Microsoft YaHei",sans-serif}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:18px 0}
.ccard{background:var(--card-2);border:1px solid var(--line);border-radius:14px;padding:18px;transition:.2s}
.ccard:hover{transform:translateY(-4px);box-shadow:0 12px 26px rgba(0,0,0,.35)}
.ccard .emoji{font-size:32px}
.ccard h4{margin:8px 0 6px;font-size:17px}
.ccard .en{color:var(--ink-soft);font-size:13px}

ul,ol{padding-left:22px}
li{margin:6px 0}
.pill{display:inline-block;background:var(--card-2);border:1px solid var(--line);border-radius:999px;padding:3px 12px;font-size:13px;margin:3px}

/* 分层堆叠 */
.layers{display:flex;flex-direction:column;gap:8px;max-width:620px;margin:0 auto}
.layer{display:flex;align-items:center;border-radius:12px;padding:13px 18px;color:#fff;font-weight:600;box-shadow:var(--shadow)}
.layer .ln{flex:0 0 96px;font-size:15px}
.layer .ld{font-weight:400;font-size:13.5px;opacity:.95}
.layer.l1{background:linear-gradient(90deg,#7c5cff,#9d7bff)}
.layer.l2{background:linear-gradient(90deg,#5b9dff,#7bb4ff)}
.layer.l3{background:linear-gradient(90deg,#36d399,#5be0b0)}
.layer.l4{background:linear-gradient(90deg,#fbbd23,#fccf57)}
.layer.l5{background:linear-gradient(90deg,#f472b6,#f99fd0)}
.layer.l6{background:linear-gradient(90deg,#22d3ee,#67e3f5);color:#06303a}

/* 翻转卡 */
.flip-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:14px 0}
.flip{perspective:1000px;height:175px;cursor:pointer}
.flip-inner{position:relative;width:100%;height:100%;transition:transform .6s;transform-style:preserve-3d}
.flip.on .flip-inner{transform:rotateY(180deg)}
.flip-front,.flip-back{position:absolute;inset:0;backface-visibility:hidden;border-radius:14px;padding:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border:1px solid var(--line);background:var(--card-2)}
.flip-back{transform:rotateY(180deg);font-size:14px;line-height:1.6}
.flip-front .emoji{font-size:36px}
.flip-front h4{margin:8px 0 2px;font-size:18px}
.flip-front .en{color:var(--ink-soft);font-size:12px}
.flip-front{border-top:3px solid var(--accent)}.flip-back{border-top:3px solid var(--green)}
.flip-back small{color:var(--ink-soft);display:block;margin-top:6px}

/* 折叠自测 */
details{background:var(--card-2);border:1px solid var(--line);border-radius:12px;padding:6px 18px;margin:12px 0}
details summary{cursor:pointer;font-weight:600;padding:10px 0;list-style:none}
details summary::before{content:"❓ "}
details[open] summary{color:var(--accent)}
details .ans{color:var(--ink-soft);padding:6px 0 14px;border-top:1px dashed var(--line)}

/* 学习进度 */
.checkbar{position:sticky;top:46px;z-index:50;background:rgba(15,23,41,.92);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:12px;padding:10px 16px;margin-bottom:20px;display:flex;align-items:center;gap:12px}
.checkbar .lbl{font-size:13px;color:var(--ink-soft);white-space:nowrap}
.checkbar .track{flex:1;height:10px;background:var(--card);border-radius:999px;overflow:hidden}
.checkbar .fill{height:100%;width:0;background:linear-gradient(90deg,var(--green),var(--accent));transition:width .4s}
.checkbar .pct{font-weight:700;color:var(--green);font-size:14px;min-width:42px;text-align:right}

/* 题库 */
.tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.tab{flex:1;min-width:140px;background:var(--card-2);border:1px solid var(--line);color:var(--ink-soft);padding:11px;border-radius:12px;cursor:pointer;font-family:inherit;font-size:15px;font-weight:600;transition:.15s}
.tab.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-color:transparent}
.tabpane{display:none}.tabpane.active{display:block}
.score{position:sticky;top:46px;z-index:40;display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:rgba(15,23,41,.92);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:12px;padding:10px 16px;margin-bottom:16px}
.score b{color:var(--green);font-size:18px}
.score .mini{font-size:13px;color:var(--ink-soft)}
.score .resetb{margin-left:auto;background:var(--card-2);border:1px solid var(--line);color:var(--ink-soft);border-radius:8px;padding:6px 14px;cursor:pointer;font-family:inherit;font-size:13px}
.score .resetb:hover{border-color:var(--accent);color:var(--ink)}
.qitem{background:var(--card-2);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:14px}
.qitem .qh{font-weight:600;margin-bottom:10px;line-height:1.6}
.qitem .qh .no{display:inline-block;background:var(--accent);color:#fff;border-radius:7px;padding:1px 9px;font-size:13px;margin-right:8px}
.qitem .qh .src{display:inline-block;background:var(--amber);color:#3a2c00;border-radius:7px;padding:1px 8px;font-size:11.5px;margin-left:8px;font-weight:700}
.qopt{display:block;width:100%;text-align:left;background:var(--card);border:1px solid var(--line);color:var(--ink);padding:9px 14px;border-radius:9px;margin:6px 0;cursor:pointer;transition:.12s;font-size:14px;font-family:inherit}
.qopt:hover{border-color:var(--accent)}
.qopt.correct{background:rgba(54,211,153,.18);border-color:var(--green);color:#aef5d4}
.qopt.wrong{background:rgba(248,114,114,.16);border-color:var(--red);color:#ffc2c2}
.qopt.lock{pointer-events:none}
.qexp{font-size:13.5px;color:var(--ink-soft);margin-top:8px;padding:9px 13px;background:rgba(91,157,255,.08);border-radius:9px;border-left:3px solid var(--accent);display:none}
.qexp.show{display:block}
.blank-in{background:var(--card);border:1px solid var(--line);border-radius:8px;color:var(--ink);padding:7px 12px;font-size:14.5px;font-family:inherit;width:210px;margin:0 4px}
.blank-in:focus{outline:none;border-color:var(--accent)}
.blank-in.ok{border-color:var(--green);background:rgba(54,211,153,.12)}
.blank-in.bad{border-color:var(--red);background:rgba(248,114,114,.10)}
.blank-btns{margin-top:10px;display:flex;gap:8px}
.sbtn{background:var(--card);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:7px 14px;cursor:pointer;font-family:inherit;font-size:13.5px}
.sbtn:hover{border-color:var(--accent)}
.sbtn.primary{background:var(--accent);color:#fff;border-color:transparent}
.ansline{font-size:13.5px;color:var(--green);margin-top:8px;display:none}
.ansline.show{display:block}

footer{text-align:center;color:var(--ink-soft);font-size:13px;padding:30px 0 10px}
#top{position:fixed;right:26px;bottom:26px;width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:none;font-size:20px;cursor:pointer;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.3s;z-index:300}
#top.show{opacity:1;pointer-events:auto}

@media(max-width:880px){
  nav.side{display:none}
  .wrap{padding:0 14px}
  header.hero{padding:24px 20px}
  section{padding:18px 16px}
}
