/* CAIE 9618 A-Level syllabus prototype — visual system adapted from the
   "题库-A3数据库" Claude Design reference (航铂教育). Bare static CSS. */
:root{
  --bg:#eef1f4; --ink:#11161d; --muted:#46505c; --faint:#7d8794; --fainter:#9aa3b0;
  --panel:#f3f5f8; --panel2:#f7f9fb; --white:#fff;
  --bd:#dfe4ea; --bd2:#e7ebf0; --bd3:#f0f2f5;
  --amber:#b9791b; --amber2:#c2891f;
  --p3:#4f7fb0; --p4:#b9791b;
  --topbar:#1f2530; --topbar-sep:#3a414e;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:'IBM Plex Sans','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--bg)}
.mono{font-family:var(--mono)}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:#cfd6de;border:3px solid #fff;border-radius:0}
::-webkit-scrollbar-track{background:var(--panel)}

.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}

/* TOPBAR */
.topbar{display:flex;align-items:center;gap:13px;padding:12px 22px;background:var(--topbar);flex:none}
.brand{font-size:15px;font-weight:700;color:#fff;letter-spacing:.5px}
.sep{width:1px;height:15px;background:var(--topbar-sep)}
.topbar-sub{font-size:12px;color:var(--fainter);letter-spacing:.4px;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar-legend{margin-left:auto;display:flex;gap:14px;font-size:11px;color:var(--fainter);flex:none;white-space:nowrap}
.topbar-legend span{display:inline-flex;align-items:center;gap:5px}
.dot{width:8px;height:8px;display:inline-block}
.dot-p3{background:var(--p3)} .dot-p4{background:var(--p4)}

.body{flex:1;display:flex;min-height:0;position:relative}

/* SIDEBAR */
.sidebar{width:332px;flex:none;border-right:1px solid var(--bd);background:var(--white);display:flex;flex-direction:column;min-height:0}
.sidebar[hidden]{display:none}
.side-search{padding:10px 12px;border-bottom:1px solid var(--bd2);flex:none}
.side-search-row{display:flex;gap:6px;align-items:stretch}
.side-search-row input{flex:1;min-width:0}
.side-toggle{flex:none;cursor:pointer;width:32px;border:1px solid var(--bd);background:var(--panel);border-radius:2px;color:var(--faint);font-size:15px;line-height:1}
.side-toggle:hover{border-color:var(--amber);color:var(--amber)}
.side-reopen{position:absolute;left:0;top:12px;z-index:20;cursor:pointer;width:22px;height:38px;border:1px solid var(--bd);border-left:none;background:#fff;color:var(--faint);border-radius:0 3px 3px 0;font-size:14px;box-shadow:1px 1px 4px rgba(15,25,50,.08)}
.side-reopen[hidden]{display:none}
.side-reopen:hover{color:var(--amber);border-color:var(--amber)}
.side-search input{width:100%;background:var(--panel);border:1px solid var(--bd);border-radius:2px;padding:8px 11px;font-size:12px;color:var(--ink);outline:none}
.side-search input:focus{border-color:var(--amber);background:#fff}
.paper-chips{display:flex;gap:6px;margin-top:8px}
.chip{cursor:pointer;font-size:11px;color:var(--muted);background:var(--panel);border:1px solid var(--bd);border-radius:2px;padding:3px 10px}
.chip:hover{border-color:var(--amber)}
.chip.active{color:#fff;background:var(--amber);border-color:var(--amber)}
.side-nav{flex:1;overflow-y:auto;min-height:0}
.mini-papers{display:inline-flex;gap:3px;flex:none}
.mini-paper{font-size:9px;font-weight:600;border:1px solid;border-radius:2px;padding:0 3px;flex:none}
.mini-paper.p3{color:var(--p3);border-color:#cadaeb}
.mini-paper.p4{color:var(--p4);border-color:#ecd8b3}
.mini-paper.p1{color:#4f9c6b;border-color:#bfe0cc}
.mini-paper.p2{color:#8268a6;border-color:#ddd0f0}

.paper-divider{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:1px;color:#fff;padding:8px 12px;display:flex;align-items:center;gap:7px}
.paper-divider.p3{background:#2c3d52} .paper-divider.p4{background:#5a4419}
.paper-divider .pd-sub{color:#c9d2dc;font-weight:500;letter-spacing:.3px}

.topic-label{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.7px;color:var(--faint);background:var(--panel);padding:7px 12px;border-top:1px solid var(--bd2);border-bottom:1px solid var(--bd2)}

.sub-row{display:flex;cursor:pointer;border-bottom:1px solid var(--bd3)}
.sub-row:hover{background:var(--panel2)}
.sub-row.active{background:#fbf4e8}
.sub-row .rail{width:3px;flex:none}
.sub-row .rail.p3{background:var(--p3)} .sub-row .rail.p4{background:var(--p4)}
.sub-row .rc{flex:1;min-width:0;padding:7px 11px;display:flex;align-items:center;gap:8px}
.sub-row .code{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--muted)}
.sub-row.active .code{color:var(--amber)}
.sub-row .nm{font-size:12px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0}
.sub-row .cnt{font-family:var(--mono);font-size:11px;color:var(--fainter);flex:none}

/* CONTENT */
.content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--white)}
.detail-head{padding:13px 22px;border-bottom:1px solid var(--bd);flex:none}
.dh-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.dh-code{font-family:var(--mono);font-size:19px;font-weight:600;color:var(--ink)}
.dh-name{font-size:15px;font-weight:600;color:var(--muted)}
.badge{font-family:var(--mono);font-size:10px;font-weight:600;border-radius:2px;padding:1px 6px}
.badge-p3{color:var(--p3);border:1px solid #cadaeb}
.badge-p4{color:var(--p4);border:1px solid #ecd8b3}
.dh-meta{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--faint);display:flex;gap:12px}
.dh-desc{font-size:12.5px;color:var(--muted);margin-top:8px;line-height:1.55;max-width:760px}

.tabs{display:flex;padding:0 22px;border-bottom:1px solid var(--bd);flex:none}
.tab{cursor:pointer;font-family:var(--mono);font-size:12.5px;font-weight:500;color:var(--faint);padding:10px 0;margin-right:24px;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab:hover{color:var(--muted)}
.tab.active{color:var(--ink);font-weight:600;border-bottom-color:var(--amber)}

.tab-body{flex:1;overflow-y:auto;min-height:0}
.pane{padding:18px 24px 48px;max-width:960px}

.card{background:#fff;border:1px solid var(--bd);border-radius:3px;padding:16px 18px;margin-bottom:14px}
.card-kicker{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--faint);margin-bottom:12px}

.obj{padding:9px 0;border-top:1px solid var(--bd3)}
.obj:first-of-type{border-top:none}
.obj-stmt{display:flex;gap:9px;font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.5}
.obj-num{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--amber);flex:none;margin-top:2px}
.obj-guide{margin:6px 0 0 22px;padding:0;list-style:none}
.obj-guide li{position:relative;font-size:12.5px;color:var(--muted);margin:4px 0;line-height:1.55;padding-left:14px}
.obj-guide li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;background:#cfd6de}

.concepts-card{background:var(--panel2);border:1px solid var(--bd)}
.patterns-card{background:#fbf7ef;border:1px solid #ecd8b3}
.pattern-tags{display:flex;flex-wrap:wrap;gap:7px}
.ptag{cursor:pointer;display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink);background:#fff;border:1px solid #e6cfa0;border-radius:3px;padding:4px 6px 4px 10px}
.ptag:hover{border-color:var(--amber);background:#fff}
.ptag-n{font-family:var(--mono);font-size:10.5px;font-weight:600;color:#fff;background:var(--amber);border-radius:2px;padding:1px 5px}
.ptag.active{background:var(--amber);border-color:var(--amber)}
.ptag.active,.ptag.active *{color:#fff}
.ptag.active .ptag-n{background:#fff;color:var(--amber)}
/* two-level 题组 -> 题型 */
.pg-block{margin-top:10px}
.pg-block:first-child{margin-top:2px}
.pg-head{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--muted);border-left:3px solid var(--amber);padding:2px 0 2px 8px;margin-bottom:6px}
.pg-head:hover{color:var(--amber)}
.pg-head.active{color:var(--amber)}
.pg-name{}
.pg-n{font-family:var(--mono);font-size:10.5px;font-weight:600;color:var(--faint)}
.pg-head.active .pg-n{color:var(--amber)}
.pg-subs{display:flex;flex-wrap:wrap;gap:6px;padding-left:11px}
.pf-top{display:flex;align-items:center;gap:6px;margin-bottom:2px}
.pt-filter{font-size:11.5px;color:var(--muted);background:#fbf4e8;border:1px solid #ecd8b3;border-radius:2px;padding:2px 8px}
.pt-filter b{color:var(--amber)}
.pt-clear{cursor:pointer;color:var(--faint);margin-left:4px}
.pt-clear:hover{color:#c25a45}
.concept-tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{font-family:var(--mono);font-size:11.5px;color:var(--muted);background:#fff;border:1px solid var(--bd);border-radius:2px;padding:3px 8px}
.tag:hover{border-color:var(--amber);color:var(--amber)}

/* answer-strategy report */
.strategy-card{background:#f6faf7;border:1px solid #cfe6d5}
.strat-overview{font-size:13px;color:var(--muted);line-height:1.65}
.def-list{display:flex;flex-direction:column;gap:7px}
.def-item{font-size:12.5px;color:var(--muted);line-height:1.55}
.def-item b{color:var(--ink)}
.cmp-item{padding:8px 0;border-top:1px solid var(--bd3)}
.cmp-item:first-child{border-top:none}
.cmp-title{font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:4px}
.cmp-points{margin:0;padding-left:18px}
.cmp-points li{font-size:12px;color:var(--muted);margin:3px 0;line-height:1.5}
.strat-pat{padding:11px 0;border-top:1px solid var(--bd3)}
.strat-pat:first-of-type{border-top:none}
.sp-head{display:flex;align-items:center;gap:9px;margin-bottom:6px;flex-wrap:wrap}
.sp-name{font-size:13px;font-weight:600;color:var(--ink)}
.sp-group{font-family:var(--mono);font-size:10px;color:var(--amber);border:1px solid #ecd8b3;border-radius:2px;padding:0 5px}
.sp-row{font-size:12.5px;color:var(--muted);line-height:1.55;margin:4px 0}
.sp-lbl{display:inline-block;font-size:10.5px;font-weight:600;color:#fff;background:#8aa0b4;border-radius:2px;padding:1px 6px;margin-right:7px;vertical-align:1px}
.sp-row.sp-warn .sp-lbl{background:#c2891f}
.sp-points{margin:5px 0 0;padding-left:20px}
.sp-points li{font-size:12.5px;color:var(--muted);margin:3px 0;line-height:1.5}
.mindmap-card{background:#fff}
.mindmap-card .mermaid{overflow-x:auto;text-align:center}
.placeholder{background:var(--panel2);border:1px dashed #cfd6de;border-radius:3px;padding:16px 18px}
.placeholder .ph-title{font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:6px}
.placeholder .ph-text{font-size:12.5px;color:var(--faint);line-height:1.6}

.info{background:#eef3fb;border:1px solid #d6e2f2;border-radius:3px;padding:13px 16px;font-size:12.5px;color:var(--muted);line-height:1.6;margin-bottom:16px}
.info b{color:var(--ink)}

/* landing / overview */
.overview-text{font-size:13px;color:var(--muted);line-height:1.7;white-space:pre-line;max-width:760px}
.stat-row{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}
.stat{border:1px solid var(--bd);border-radius:3px;padding:10px 14px;min-width:96px}
.stat .n{font-family:var(--mono);font-size:20px;font-weight:600;color:var(--ink)}
.stat .l{font-size:11px;color:var(--faint);margin-top:2px}
.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-top:8px}
.tg-card{border:1px solid var(--bd);border-radius:3px;padding:11px 13px;cursor:pointer}
.tg-card:hover{border-color:var(--amber);background:var(--panel2)}
.tg-code{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--amber)}
.tg-name{font-size:12.5px;color:var(--ink);margin-top:3px;line-height:1.4}
.tg-sub{font-size:11px;color:var(--faint);margin-top:4px}

.empty{text-align:center;color:var(--faint);padding:48px 20px;font-size:13px}

/* papers tab */
.papers-toolbar{position:sticky;top:0;z-index:6;display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:9px 22px;background:var(--panel2);border-bottom:1px solid var(--bd2)}
.papers-toolbar .pt-note{font-family:var(--mono);font-size:11px;color:var(--faint)}
.papers-toolbar .pt-stat{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--muted);display:flex;gap:12px}
.papers-filter{padding:10px 22px 12px;background:#fff;border-bottom:1px solid var(--bd2)}
.fchip-label{font-size:10.5px;font-weight:600;letter-spacing:.5px;color:var(--faint);margin-right:2px}
.fchip{cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--muted);background:var(--panel);border:1px solid var(--bd);border-radius:2px;padding:3px 8px}
.fchip:hover{border-color:var(--amber);color:var(--amber)}
.fchip.active{color:#fff;background:var(--amber);border-color:var(--amber)}
.fchip-n{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--muted);background:#fff;border-radius:2px;padding:0 4px}
.fchip.active .fchip-n{color:var(--amber)}
.syl-filter{display:flex;align-items:center;gap:6px;padding:9px 22px 0}
.q-row{display:flex;align-items:center;border-bottom:1px solid var(--bd3)}
.q-row:hover{background:var(--panel2)}
.q-row .rail{width:3px;align-self:stretch;flex:none}
.q-row .qc{flex:1;min-width:0;padding:11px 16px}
/* PRIMARY: scenario */
.q-scn{font-size:13.5px;color:var(--ink);line-height:1.45;margin-bottom:6px;
       display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* SECONDARY: provenance + meta */
.q-meta2{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.q-syl{font-family:var(--mono);font-size:9.5px;font-weight:600;border-radius:2px;padding:1px 5px;flex:none}
.q-syl.syl-9618{color:#fff;background:var(--p3)}
.q-syl.syl-9608{color:var(--faint);background:#eceff3;border:1px solid var(--bd)}
.q-prov{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.2px}
.q-meta2 .q-mk{font-size:11px;font-weight:600;color:var(--muted)}
.q-meta2 .q-cmd{font-family:var(--mono);font-size:10.5px;color:#4f7fb0}
.q-meta2 .q-pat{font-size:11px;color:var(--faint)}
.q-btns{display:flex;gap:5px;flex:none;margin-right:14px}
.q-btn{cursor:pointer;font-family:var(--mono);font-size:11px;color:var(--muted);border:1px solid var(--bd);border-radius:2px;padding:5px 10px;text-decoration:none}
.q-btn:hover{border-color:var(--amber);color:var(--amber)}

/* modal */
.modal[hidden]{display:none}
.modal{position:fixed;inset:0;background:rgba(17,22,29,.55);display:flex;align-items:center;justify-content:center;z-index:100;padding:22px}
.modal-box{background:#fff;border-radius:4px;width:min(1040px,96vw);height:93vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px rgba(15,25,50,.4)}
.modal-head{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--bd);background:var(--panel);flex:none}
.modal-title{font-size:12.5px;color:var(--ink);flex:1 1 auto;min-width:40px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal-tabs{display:flex;gap:5px;flex:none}
.modal-tab{cursor:pointer;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--muted);border:1px solid var(--bd);border-radius:2px;padding:6px 12px;white-space:nowrap;flex:none}
.modal-tab.active{color:var(--amber);border-color:var(--amber);background:#fbf4e8}
.modal-new{font-family:var(--mono);font-size:11.5px;color:var(--muted);border:1px solid var(--bd);border-radius:2px;padding:6px 10px;text-decoration:none;white-space:nowrap;flex:none}
.modal-close{cursor:pointer;font-size:15px;font-weight:700;color:var(--faint);border:1px solid var(--bd);border-radius:2px;width:30px;height:28px;display:inline-flex;align-items:center;justify-content:center;flex:none}
.modal-close:hover{color:#c25a45;border-color:#f1cabd}
.modal-body{flex:1;background:#eceff3;min-height:0}
.modal-body iframe{width:100%;height:100%;border:0}

.obj-paper{font-size:9.5px;font-weight:600;color:var(--p4);border:1px solid #ecd8b3;border-radius:2px;padding:0 4px;vertical-align:middle}
.q-mk{font-size:10.5px;font-weight:600;color:var(--muted)}

/* responsive: narrow screens */
@media (max-width:820px){
  .topbar{gap:9px;padding:12px 14px}
  .topbar-sub{display:none}
  .modal{padding:0}
  .modal-box{width:100vw;height:100vh;max-width:none;border-radius:0}
  .modal-title{font-size:11.5px}
  .q-row .q-scn{max-width:300px}
}
@media (max-width:560px){
  .topbar-legend{gap:9px;font-size:10px}
  .modal-head{flex-wrap:wrap;gap:6px}
  .modal-new{margin-left:0}
}
