:root{
  --bg:#e9edf1; --surface:#ffffff; --surface-2:#f6f8fa;
  --ink:#14202b; --muted:#5f6e7c; --faint:#8a97a3; --line:#e2e7ed;
  --accent:#0d7d86; --accent-d:#0a5b62; --accent-soft:#e4f2f3;
  --warm:#9a6212; --warm-soft:#fbf3e3; --warm-line:#ecd9b3;
  --ok:#1f8a4c; --bad:#c0392b;
  --r:13px; --rc:9px;
  --mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,"Segoe UI",Roboto,"Helvetica Neue","PingFang SC","Microsoft YaHei",Arial,sans-serif;
  --shadow:0 1px 2px rgba(20,32,43,.04),0 8px 24px rgba(20,32,43,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h2,h3,h4{margin:.2em 0}
.muted{color:var(--muted);font-size:13px}
.sec-h{font-size:15px;font-weight:700;letter-spacing:.2px;color:var(--ink)}

/* ---------- global nav ---------- */
.nav{display:flex;align-items:center;gap:22px;height:58px;padding:0 22px;background:rgba(255,255,255,.86);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:60}
.nav-brand{font-weight:800;letter-spacing:.3px;font-size:16px;display:flex;align-items:center;gap:8px}
.nav-brand .logo{color:var(--accent);font-size:20px;transform:translateY(1px)}
.nav-links{display:flex;gap:4px;margin-left:8px}
.nav-links a{padding:7px 14px;border-radius:999px;color:var(--muted);font-size:14px;font-weight:500;transition:.14s}
.nav-links a:hover{background:var(--surface-2);color:var(--ink)}
.nav-links a.on{background:var(--accent-soft);color:var(--accent-d);font-weight:600}
.nav-acct{margin-left:auto;color:var(--muted);font-size:13px;border:1px solid var(--line);padding:6px 13px;border-radius:999px}
.nav-acct:hover{color:var(--bad);border-color:#f0c8c2}
.wrap{max-width:1180px;margin:0 auto;padding:22px}

/* ---------- login ---------- */
body.login-bg{background:
  radial-gradient(900px 520px at 82% -12%, rgba(13,125,134,.16), transparent 60%),
  radial-gradient(760px 480px at 8% 112%, rgba(13,125,134,.10), transparent 55%),
  var(--bg)}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login{width:100%;max-width:420px;background:var(--surface);padding:40px 38px;border-radius:22px;box-shadow:0 1px 2px rgba(20,32,43,.05),0 24px 60px rgba(20,32,43,.12);text-align:center;border:1px solid #eef2f5}
.login .mark{font-size:46px;line-height:1;color:var(--accent);margin-bottom:6px}
.login h1{margin:.1em 0 .15em;font-size:27px;letter-spacing:.4px;font-weight:800}
.login .sub{color:var(--muted);font-size:13.5px;margin-bottom:24px;line-height:1.7}
.login form{display:flex;flex-direction:column;gap:11px}
.login input{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:13px;font-size:15px;background:var(--surface-2);text-align:center}
.login input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent);background:#fff}
.login button{width:100%;padding:13px;border:0;border-radius:13px;background:var(--accent);color:#fff;font-size:15px;font-weight:700;letter-spacing:.5px}
.login button:hover{background:var(--accent-d)}
.login .err{color:var(--bad);font-size:13px}
.login .feats{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-top:24px}
.login .feats span{font-size:12px;color:var(--accent-d);background:var(--accent-soft);border-radius:999px;padding:5px 12px}

/* ---------- dashboard ---------- */
.search{display:flex;gap:9px;margin-bottom:16px}
.search input{flex:1;padding:11px 15px;border:1px solid var(--line);border-radius:12px;font-size:15px;background:var(--surface)}
.search input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}
.search button{padding:0 20px;border:0;border-radius:12px;background:var(--accent);color:#fff;font-weight:600}
.search .clear{align-self:center;color:var(--muted);font-size:13px}
.stats{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:18px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 13px;font-size:13px;color:var(--muted)}
.stat b{color:var(--accent-d);font-family:var(--mono)}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:13px;color:#3a4854}
.chip:hover{border-color:var(--accent)}
.chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;transition:.14s;display:block;box-shadow:0 1px 2px rgba(20,32,43,.03)}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:#cfd9e1}
.card-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.card-top .when{margin-left:auto;color:var(--faint);font-size:12px;font-family:var(--mono)}
.read{color:var(--ok);font-size:12px;font-weight:600}
.ti{font-weight:650;font-size:15px;line-height:1.42;margin-bottom:10px}
.meta{display:flex;flex-wrap:wrap;gap:7px;font-size:12px;color:var(--muted);align-items:center}
.meta .venue{color:var(--accent-d);font-weight:600}
.meta .sc{background:var(--surface-2);border-radius:6px;padding:1px 7px;font-family:var(--mono)}
.meta .aid{font-family:var(--mono);color:var(--faint)}
.empty{color:var(--muted);padding:48px;text-align:center}

.cat{font-size:11.5px;font-weight:600;padding:2px 10px;border-radius:999px;background:var(--surface-2);color:#3a4854;white-space:nowrap}
.cat-医学分割{background:#e6f5ec;color:#1c7a45}
.cat-通用分割{background:#e7f0fb;color:#2061a8}
.cat-大模型{background:#f1ebfb;color:#6f37a8}
.cat-生成模型{background:#fdeee2;color:#b9651a}
.cat-Agent·RAG·评测安全{background:#fdeae8;color:#b53a2e}

/* ---------- reader top bar ---------- */
body.is-reader{height:100vh;overflow:hidden}
.rbar{display:flex;align-items:center;gap:14px;height:52px;padding:0 16px;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:60}
.rbar-back{font-size:14px;font-weight:600;color:var(--accent-d);padding:7px 12px;border-radius:9px;background:var(--accent-soft);white-space:nowrap}
.rbar-back:hover{background:#d2ebec}
.rbar-mid{flex:1;min-width:0;display:flex;align-items:center;gap:9px}
.rbar-title{font-weight:600;font-size:14.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rbar-actions{display:flex;align-items:center;gap:8px}
.rbar-sc{font-family:var(--mono);font-size:12px;color:var(--muted);background:var(--surface-2);border-radius:6px;padding:2px 7px}
.rbtn{border:1px solid var(--line);background:var(--surface);border-radius:9px;padding:7px 13px;font-size:13px;color:var(--accent-d);font-weight:500}
.rbtn:hover{border-color:var(--accent)}
.rbtn.done{background:var(--ok);color:#fff;border-color:var(--ok)}
.rbtn.ghost{color:var(--muted)}
.rbar-out{margin-left:4px;color:var(--faint);font-size:18px;padding:4px 8px;border-radius:8px}
.rbar-out:hover{color:var(--bad);background:#fdeae8}

/* ---------- reader split ---------- */
.reader-main{height:calc(100vh - 52px);padding:12px}
.reader,.split{height:100%}
.split{display:flex;gap:0}
.pane{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 1px 2px rgba(20,32,43,.03)}
.pane.left{flex:0 0 54%;min-width:260px}
.pane.right{flex:1;min-width:300px}
.pane-bar{display:flex;align-items:center;justify-content:space-between;padding:7px 11px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.pane-label{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.3px}
.mini{border:1px solid var(--line);background:#fff;border-radius:7px;padding:3px 9px;font-size:13px;color:var(--accent-d)}
.mini:hover{border-color:var(--accent)}
.pane.left iframe{flex:1;width:100%;border:0;background:#54585c;display:block}
.splitter{flex:0 0 14px;cursor:col-resize;display:flex;align-items:center;justify-content:center}
.splitter span{width:4px;height:46px;border-radius:3px;background:#c4ced7;transition:.14s}
.splitter:hover span{background:var(--accent);height:64px}

/* tabs */
.tabs{display:flex;gap:3px;padding:8px 9px;border-bottom:1px solid var(--line);background:var(--surface-2);flex-wrap:wrap}
.tab{border:0;background:transparent;padding:7px 14px;border-radius:9px;color:var(--muted);font-size:13.5px;font-weight:500}
.tab:hover{background:#eef1f4;color:var(--ink)}
.tab.on{background:var(--accent);color:#fff;font-weight:600}
.tabp{display:none;flex:1;min-height:0}
.tabp.on{display:block}
.tabp.scroll{overflow:auto;padding:16px 18px}
.tabp[data-p="sum"].on{padding:0;display:flex;flex-direction:column}
.sum-bar{display:flex;align-items:center;gap:9px;padding:7px 11px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.sumframe{flex:1;width:100%;border:0;background:#54585c}
.sum-editor{flex:1;display:flex;flex-direction:column;min-height:0}
.se-tools{display:flex;align-items:center;gap:9px;padding:8px 11px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.se-tools .spacer{flex:1}
.sum-form{flex:1;overflow:auto;padding:14px 16px}
.sf-cell{margin-bottom:13px}
.sf-cell label{display:block;font-size:12.5px;font-weight:700;color:var(--accent-d);margin-bottom:4px}
.sf{width:100%;border:1px solid var(--line);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:13.5px;line-height:1.65;background:var(--surface-2);resize:vertical}
.sf:focus{outline:2px solid var(--accent-soft);border-color:var(--accent);background:#fff}
textarea.sf{overflow:hidden}

/* ---------- ask / qa thread ---------- */
.lead{font-size:13px;color:var(--muted);background:var(--surface-2);border-radius:10px;padding:10px 12px;margin:0 0 12px}
.lead b{color:var(--accent-d)}
.ask-compose{position:sticky;top:-16px;background:var(--surface);padding-top:2px;z-index:2}
.sel-box{display:flex;gap:8px;align-items:flex-start;font-size:13px;background:var(--warm-soft);border:1px solid var(--warm-line);border-radius:10px;padding:8px 10px;margin-bottom:8px;max-height:108px;overflow:auto}
.sel-box .sel-lab{flex:none;font-weight:700;color:var(--warm)}
.sel-box #selClear{margin-left:auto;border:0;background:none;color:var(--bad);font-size:16px;cursor:pointer;line-height:1}
#askQ{width:100%;border:1px solid var(--line);border-radius:11px;padding:11px;font-family:inherit;font-size:14.5px;resize:vertical}
#askQ:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}
.ask-row{display:flex;gap:9px;margin-top:9px}
button.primary{border:0;background:var(--accent);color:#fff;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:600}
button.primary:hover{background:var(--accent-d)}
button.accent2{border:0;background:#0e6f63;color:#fff;border-radius:10px;padding:9px 16px;font-size:13.5px;font-weight:600}
button.ghost{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:10px;padding:9px 14px;font-size:13.5px}
button[disabled]{opacity:.6;cursor:default}
.qa-list{margin-top:16px;display:flex;flex-direction:column;gap:14px}
.qa{border:1px solid var(--line);border-radius:13px;padding:0;overflow:hidden;background:#fff}
.qa .qsel{font-size:12.5px;color:var(--warm);background:var(--warm-soft);padding:7px 12px;border-bottom:1px solid var(--warm-line)}
.qa .qq{font-weight:600;font-size:14px;padding:10px 13px 4px;color:var(--ink)}
.qa .qa-ans{padding:4px 13px 13px;border-left:3px solid var(--accent);margin:0 0 0 0;background:linear-gradient(90deg,var(--accent-soft) 0,#fff 22px)}
.qa .followup{display:flex;gap:8px;padding:0 13px 12px}
.qa .followup input{flex:1;border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:13.5px}
.qa .followup button{border:0;background:var(--surface-2);color:var(--accent-d);border-radius:9px;padding:0 14px;font-size:13px;font-weight:600}
.qa-hist{margin-top:18px}
.qa-hist summary{cursor:pointer;color:var(--muted);font-size:13px;padding:6px 0}
.qa-hist .qa{margin-top:10px}

/* markdown + katex in AI output */
.md{font-size:14px;line-height:1.7;color:#22323f}
.md h1,.md h2,.md h3{font-size:15px;margin:12px 0 6px;color:var(--accent-d)}
.md p{margin:7px 0}
.md ul,.md ol{margin:6px 0;padding-left:20px}
.md li{margin:3px 0}
.md code{background:var(--surface-2);border-radius:5px;padding:1px 5px;font-family:var(--mono);font-size:12.5px}
.md pre{background:#0f1f29;color:#e6edf3;border-radius:10px;padding:12px;overflow:auto}
.md pre code{background:none;color:inherit}
.md hr{border:0;border-top:1px solid var(--line);margin:12px 0}
.katex-display{overflow-x:auto;overflow-y:hidden;padding:4px 0;margin:8px 0}

/* ---------- fields ---------- */
.fd-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:8px}
.fld-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:14px}
.fld-cell label{display:block;font-size:13px;font-weight:700;color:var(--accent-d);margin-bottom:5px}
.fld{width:100%;min-height:60px;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:14px;line-height:1.65;resize:vertical;background:var(--surface-2)}
.fld:focus{outline:2px solid var(--accent-soft);border-color:var(--accent);background:#fff}
.fd-foot{margin-top:18px;display:flex;align-items:center;gap:10px}
.grow{overflow:hidden}

/* notes */
#note{width:100%;min-height:300px;border:1px solid var(--line);border-radius:12px;padding:14px;font-size:14.5px;font-family:inherit;line-height:1.75;background:var(--surface-2)}
#note:focus{outline:2px solid var(--accent-soft);border-color:var(--accent);background:#fff}
.saved{height:16px;margin-top:5px;color:var(--ok)}

/* comprehension */
.cq-intro{margin-bottom:8px}
.qcard{border:1px solid var(--line);border-radius:13px;padding:14px;margin:12px 0;background:#fff}
.qcard .q{font-weight:600;margin-bottom:3px}
.qcard .point{font-size:12px;color:var(--muted);margin-bottom:9px}
.qcard textarea{width:100%;min-height:72px;border:1px solid var(--line);border-radius:9px;padding:10px;font-family:inherit;font-size:14px}
.ans-submit{margin-top:9px;border:0;background:var(--accent2,#0e6f63);color:#fff;border-radius:9px;padding:8px 15px;font-size:13px}
.feedback{margin-top:11px;border-left:3px solid var(--ok);background:#f0f8f3;padding:10px 13px;border-radius:0 8px 8px 0;font-size:14px}
.feedback .score,.sh-head .score{display:inline-block;background:var(--ok);color:#fff;border-radius:6px;padding:0 8px;font-weight:700;font-family:var(--mono)}
.self-box{margin-top:20px;border-top:1px dashed var(--line);padding-top:16px}
#selfSummary{width:100%;min-height:96px;border:1px solid var(--line);border-radius:11px;padding:11px;font-family:inherit;font-size:14px}
#selfResult,.sh-eval{margin-top:11px;border-left:3px solid var(--warm);background:var(--warm-soft);padding:11px 13px;border-radius:0 8px 8px 0;font-size:14px}
.self-hist{margin-top:15px;border:1px solid var(--line);border-radius:12px;padding:13px}
.sh-head{font-size:12px;color:var(--muted);margin-bottom:7px}
.sh-user{font-size:13.5px;background:var(--surface-2);border-radius:8px;padding:9px;white-space:pre-wrap}

/* floating ask pill */
#askFloat{position:fixed;z-index:200;border:0;background:var(--accent);color:#fff;border-radius:999px;padding:8px 16px;font-size:13px;font-weight:600;box-shadow:0 6px 18px rgba(13,125,134,.4);animation:pop .12s ease-out}
#askFloat:hover{background:var(--accent-d)}
@keyframes pop{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}

/* literature table */
.littable-wrap{border:1px solid var(--line);border-radius:14px;overflow:auto;max-height:calc(100vh - 200px);background:var(--surface);box-shadow:var(--shadow)}
.littable{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;line-height:1.6;table-layout:fixed}
.littable th,.littable td{padding:11px 13px;vertical-align:top;text-align:left;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.littable th:last-child,.littable td:last-child{border-right:0}
.littable thead th{position:sticky;top:0;z-index:2;background:var(--surface-2);font-size:12px;font-weight:700;color:var(--accent-d);letter-spacing:.3px;border-bottom:2px solid #d7dee5}
.littable tbody tr:nth-child(even){background:var(--surface-2)}
.littable tbody tr:hover{background:var(--accent-soft)}
.littable col.c-title{width:18%}.littable col.c-f{width:13.6%}
.littable td.t-title b{font-size:13.5px}
.littable td.t-title .sub{font-size:11.5px;color:var(--accent2,#0e6f63);margin-top:3px}
.lib-actions{display:flex;gap:10px;margin:6px 0 16px;align-items:center}
.lib-actions a.btn{border:1px solid var(--line);background:#fff;border-radius:9px;padding:8px 14px;color:var(--accent-d);font-size:13px;font-weight:600}
.lib-actions a.btn:hover{border-color:var(--accent);background:var(--accent-soft)}

/* arch library */
.arch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;margin-top:16px}
.arch-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 1px 2px rgba(20,32,43,.03)}
.arch-card img{width:100%;display:block;background:#f0f2f5;cursor:zoom-in;max-height:200px;object-fit:contain}
.arch-card .ac-body{padding:10px 12px}
.arch-card .ac-title{font-weight:650;font-size:14px}
.arch-card .ac-tags{font-size:12px;color:var(--accent-d);margin-top:4px}
.arch-card .ac-note{font-size:12.5px;color:var(--muted);margin-top:4px}
.arch-card .ac-del{float:right;color:var(--bad);cursor:pointer;border:0;background:none;font-size:17px}
.upload-form{background:var(--surface);border:1px dashed #c7d0d8;border-radius:var(--r);padding:16px;display:grid;gap:9px;max-width:540px;margin-top:6px}
.upload-form input[type=text],.upload-form input[type=file]{border:1px solid var(--line);border-radius:9px;padding:9px;font-size:14px}
.upload-form button{border:0;background:var(--accent);color:#fff;border-radius:9px;padding:10px;font-size:14px;font-weight:600}

@media(max-width:840px){
  body.is-reader{height:auto;overflow:auto}
  .reader-main{height:auto;padding:8px}
  .reader,.split{height:auto}
  .split{flex-direction:column}
  .pane{flex:none !important;height:auto}
  .pane.left{height:66vh}
  .splitter{display:none}
  .tabp[data-p="sum"]{height:72vh}
  .nav{gap:10px;padding:0 12px}
  .nav-links a{padding:7px 10px}
  .rbar-sc,.rbtn.ghost{display:none}
}
