:root{
  --bg:#f4f5f7; --panel:#ffffff; --ink:#1c2430; --muted:#6b7686; --line:#e3e7ee;
  --brand:#3b6ef5; --brand-soft:#e8f0ff; --ok:#16a34a; --warn:#d97706; --bad:#dc2626;
  --ok-soft:#e7f6ec; --warn-soft:#fdf0db; --bad-soft:#fdeaea; --shadow:0 1px 3px rgba(20,30,50,.08),0 6px 24px rgba(20,30,50,.06);
  --radius:14px;
}
[data-theme="dark"]{
  --bg:#0f141b; --panel:#171e28; --ink:#e6ebf2; --muted:#94a1b2; --line:#27313f;
  --brand:#5b8bff; --brand-soft:#1b2740; --ok:#3ecf78; --warn:#e0a44a; --bad:#ef6b6b;
  --ok-soft:#16271d; --warn-soft:#2a2113; --bad-soft:#2a1717; --shadow:0 1px 3px rgba(0,0,0,.4),0 8px 28px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font:15px/1.55 -apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",Segoe UI,Roboto,sans-serif;-webkit-tap-highlight-color:transparent}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
.hidden{display:none !important}

/* top bar */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--panel);border-bottom:1px solid var(--line)}
.brand{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand small{color:var(--muted);font-weight:500}
.topbar .spacer{flex:1}
.iconbtn{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:17px;border:1px solid var(--line)}
.iconbtn:active{transform:scale(.94)}
.primary{background:var(--brand);color:#fff;border-radius:10px;padding:9px 14px;font-weight:600;display:flex;align-items:center;gap:6px}
.primary:active{filter:brightness(.95)}
.badge{background:rgba(255,255,255,.25);border-radius:20px;padding:1px 8px;font-size:12px;font-weight:700;min-width:20px;text-align:center}

/* mode switch */
.modes{display:flex;gap:4px;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:3px}
.modes button{padding:6px 10px;border-radius:8px;font-size:13px;color:var(--muted)}
.modes button.active{background:var(--panel);color:var(--ink);box-shadow:var(--shadow);font-weight:600}

/* tabs */
.tabs{position:sticky;top:59px;z-index:20;display:flex;gap:2px;background:var(--panel);border-bottom:1px solid var(--line);padding:0 8px;overflow-x:auto}
.tabs button{padding:13px 14px;font-size:14px;color:var(--muted);border-bottom:2px solid transparent;white-space:nowrap}
.tabs button.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}

main{max-width:880px;margin:0 auto;padding:16px 14px 120px}
.faceHead{margin:4px 0 14px}
.faceHead h1{font-size:20px;margin:0 0 4px}
.faceHead p{margin:0;color:var(--muted);font-size:13px}

/* cards */
.section{margin:18px 0}
.section>h2{font-size:15px;margin:0 0 10px;display:flex;align-items:center;gap:8px}
.section>h2 .tag{font-size:11px;font-weight:700;color:var(--brand);background:var(--brand-soft);padding:2px 8px;border-radius:20px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin:10px 0}
.card .cid{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.04em}
.card .ctitle{font-weight:600;margin:2px 0 6px}
.card .cbody{font-size:14px;color:var(--ink)}
.card .cbody.muted{color:var(--muted)}
.card ul{margin:6px 0 0;padding-left:18px}
.card li{margin:2px 0}
.ac{font-size:13px;color:var(--muted);margin-top:8px;border-top:1px dashed var(--line);padding-top:8px}
.ac b{color:var(--ink)}

/* verdict controls */
.verdict{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.vbtn{border:1px solid var(--line);border-radius:20px;padding:5px 12px;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:5px}
.vbtn[data-v="ok"].on{background:var(--ok-soft);color:var(--ok);border-color:var(--ok)}
.vbtn[data-v="no"].on{background:var(--bad-soft);color:var(--bad);border-color:var(--bad)}
.vbtn[data-v="q"].on{background:var(--warn-soft);color:var(--warn);border-color:var(--warn)}
.cmt{margin-top:8px;width:100%;border:1px solid var(--line);background:var(--bg);color:var(--ink);border-radius:10px;padding:8px 10px;font:inherit;font-size:13px;resize:vertical;min-height:0;display:none}
.cmt.show{display:block}
.hasNote{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--brand);margin-top:6px}

/* details / gherkin */
details.fold{border:1px solid var(--line);border-radius:10px;margin-top:8px;background:var(--bg);overflow:hidden}
details.fold>summary{padding:8px 12px;cursor:pointer;font-size:13px;color:var(--muted);list-style:none}
details.fold>summary::-webkit-details-marker{display:none}
details.fold>summary:before{content:"▸ ";color:var(--brand)}
details.fold[open]>summary:before{content:"▾ "}
.gherkin{padding:10px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;white-space:pre-wrap;color:var(--ink);border-top:1px solid var(--line)}
.gherkin .kw{color:var(--brand);font-weight:700}

/* matrix table */
.matrix{width:100%;border-collapse:collapse;font-size:13px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.matrix th,.matrix td{padding:9px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.matrix th{background:var(--bg);font-size:12px;color:var(--muted)}
.matrix .impact{color:var(--bad);font-size:12px}
.matrix tr:last-child td{border-bottom:none}

/* architecture */
.diagram{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);overflow:auto}
.diagram svg{max-width:100%;height:auto}

/* prototype */
.protoBar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.protoBar select{padding:8px 10px;border-radius:10px;border:1px solid var(--line);background:var(--panel);color:var(--ink);font:inherit}
.hint{font-size:12px;color:var(--muted)}
.phoneWrap{display:flex;justify-content:center}
.phone{position:relative;width:360px;max-width:94vw;height:740px;background:var(--panel);border:10px solid #11161e;border-radius:38px;box-shadow:var(--shadow);overflow:hidden}
[data-theme="dark"] .phone{border-color:#05080c}
.screen{position:absolute;inset:0;overflow:hidden}
.notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:130px;height:24px;background:#11161e;border-radius:0 0 16px 16px;z-index:5}
[data-theme="dark"] .notch{background:#05080c}
.w{position:absolute;border-radius:10px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:13px;user-select:none;padding:6px}
.w.box{background:var(--bg);border:1px dashed var(--line);color:var(--muted)}
.w.solid{background:var(--brand-soft);border:1px solid var(--brand);color:var(--brand)}
.w.bigbtn{background:var(--brand);color:#fff;border-radius:50%;font-weight:700;box-shadow:var(--shadow)}
.w.bar{background:var(--bg);border:1px solid var(--line);color:var(--muted)}
.w.text{background:transparent;justify-content:flex-start;color:var(--ink)}
.w.label{background:transparent;color:var(--muted);font-size:11px;justify-content:flex-start}
.w.pill{background:var(--ok-soft);color:var(--ok);border-radius:20px;font-size:11px}
.w.nav[data-goto]{cursor:pointer}
.mode-proto-preview .w[data-goto]{cursor:pointer}
.mode-proto-preview .w[data-goto]:active{outline:2px solid var(--brand)}
.mode-proto-edit .w{outline:1px dashed var(--brand);cursor:move;touch-action:none}
.mode-proto-annotate .w{cursor:crosshair}
.w.moved{outline:2px solid var(--warn) !important}

/* pins */
.pin{position:absolute;width:22px;height:22px;border-radius:50% 50% 50% 2px;background:var(--warn);color:#fff;font-size:12px;font-weight:700;display:grid;place-items:center;transform:translate(-50%,-100%);z-index:8;box-shadow:var(--shadow);cursor:pointer}
/* .screen 已是 position:absolute，自身即定位上下文，无需再设 relative */

/* comment popover */
.pop{position:fixed;z-index:60;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);width:300px;max-width:92vw;padding:12px}
.pop h4{margin:0 0 8px;font-size:13px;color:var(--muted)}
.pop textarea{width:100%;border:1px solid var(--line);background:var(--bg);color:var(--ink);border-radius:10px;padding:8px;font:inherit;font-size:13px;min-height:70px;resize:vertical}
.pop .row{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}
.pop .ghost{color:var(--muted);padding:8px 12px}

/* modal */
.modal{position:fixed;inset:0;z-index:80;background:rgba(10,16,24,.5);display:flex;align-items:flex-end;justify-content:center;padding:0}
.modal .sheet{background:var(--panel);width:100%;max-width:520px;border-radius:18px 18px 0 0;padding:18px;max-height:86vh;overflow:auto}
.modal h3{margin:0 0 6px}
.modal .sub{color:var(--muted);font-size:13px;margin:0 0 14px}
.field{margin:10px 0}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}
.field input,.field textarea{width:100%;border:1px solid var(--line);background:var(--bg);color:var(--ink);border-radius:10px;padding:9px 11px;font:inherit}
.summList{font-size:13px;color:var(--muted);background:var(--bg);border-radius:10px;padding:10px 12px;margin:6px 0 0;max-height:160px;overflow:auto}
.summList div{padding:2px 0}
.btnrow{display:flex;gap:10px;margin-top:16px}
.btnrow .primary{flex:1;justify-content:center;padding:12px}
.btnrow .ghost{flex:0 0 auto;border:1px solid var(--line);border-radius:10px;padding:12px 16px;color:var(--muted)}
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:var(--ink);color:var(--bg);padding:11px 18px;border-radius:24px;font-size:14px;z-index:99;box-shadow:var(--shadow)}
.legend{font-size:12px;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 12px;margin-bottom:10px}
.assert{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px dashed var(--line)}
.assert:last-child{border-bottom:none}
.assert .atext{flex:1}
