:root{
  --bg:#f4ece0; --paper:#fbf6ec; --ink:#3a2e22; --ink2:#6b5b48;
  --gold:#a8842c; --red:#9c3b2e; --green:#5a7a52; --line:#e2d5bf;
  --shadow:0 2px 14px rgba(90,60,20,.10);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:"Noto Serif SC","Songti SC",ui-serif,Georgia,serif;
  background:var(--bg);color:var(--ink);line-height:1.7;
  background-image:radial-gradient(circle at 20% 10%,rgba(168,132,44,.05),transparent 40%),radial-gradient(circle at 80% 90%,rgba(156,59,46,.05),transparent 45%);
}
a{color:var(--red);text-decoration:none}
.wrap{max-width:760px;margin:0 auto;padding:0 16px 96px}

/* ── header ── */
header{text-align:center;padding:26px 16px 14px}
header .logo{font-size:34px}
header h1{font-size:25px;margin:6px 0 2px;letter-spacing:2px;color:var(--ink)}
header .sub{color:var(--ink2);font-size:13px;letter-spacing:1px}
header .seal{display:inline-block;margin-top:8px;font-size:12px;color:#fff;background:var(--red);
  padding:3px 12px;border-radius:3px;letter-spacing:3px;box-shadow:var(--shadow)}

/* ── tabs ── */
nav.tabs{position:sticky;top:0;z-index:30;display:flex;gap:6px;justify-content:center;flex-wrap:wrap;
  padding:10px 8px;margin:0 -16px 18px;background:rgba(244,236,224,.92);backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line)}
nav.tabs button{font-family:inherit;font-size:15px;border:1px solid var(--line);background:var(--paper);
  color:var(--ink2);padding:7px 16px;border-radius:22px;cursor:pointer;transition:.2s}
nav.tabs button.on{background:var(--red);color:#fff;border-color:var(--red);box-shadow:var(--shadow)}

/* ── cards ── */
.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:18px;
  margin-bottom:14px;box-shadow:var(--shadow)}
.card h2{margin:0 0 4px;font-size:19px;color:var(--red);letter-spacing:1px}
.muted{color:var(--ink2);font-size:13px}
.hr{height:1px;background:var(--line);margin:12px 0}

/* ── 症状智能分析 ── */
.analyze textarea{width:100%;min-height:96px;font-family:inherit;font-size:16px;line-height:1.6;
  border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;background:#fff;color:var(--ink);
  resize:vertical;margin-top:10px}
.analyze textarea:focus{outline:none;border-color:var(--gold)}
.analyze .ex{font-size:12px;margin:8px 0 12px;line-height:1.7}
.sxg{margin-bottom:12px}
.sxg-h{font-size:13px;color:var(--gold);margin-bottom:6px;letter-spacing:.5px}
.sxg-body{display:flex;flex-wrap:wrap;gap:7px}
.sxpick{font-family:inherit;font-size:13px;border:1px solid var(--line);background:var(--paper);
  color:var(--ink2);padding:5px 11px;border-radius:16px;cursor:pointer;transition:.15s}
.sxpick.on{background:var(--red);color:#fff;border-color:var(--red)}
.tag.sx-on{background:#fbeee9;border-color:var(--red);color:var(--red);cursor:pointer}
/* ── consult grid ── */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.tile{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:18px 14px;
  text-align:center;cursor:pointer;transition:.2s;box-shadow:var(--shadow)}
.tile:active{transform:scale(.97)}
.tile .ic{font-size:32px}
.tile .nm{font-size:17px;margin-top:6px;color:var(--ink);letter-spacing:1px}
.tile .ds{font-size:12px;color:var(--ink2);margin-top:4px;line-height:1.5}

/* ── question flow ── */
.qstep{animation:fade .3s}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.qbar{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.qbar .prog{flex:1;height:6px;background:var(--line);border-radius:4px;overflow:hidden}
.qbar .prog i{display:block;height:100%;background:var(--gold);transition:.3s}
.qbar .step{font-size:12px;color:var(--ink2)}
.qtitle{font-size:18px;margin:4px 0 14px;letter-spacing:1px}
.opt{display:block;width:100%;text-align:left;font-family:inherit;font-size:16px;
  background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;
  margin-bottom:10px;cursor:pointer;color:var(--ink);transition:.15s;position:relative}
.opt:active{transform:scale(.99)}
.opt.sel{border-color:var(--red);background:#fbeee9}
.opt.sel::after{content:"✓";position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--red);font-weight:bold}
.btnrow{display:flex;gap:10px;margin-top:8px}
.btn{flex:1;font-family:inherit;font-size:16px;border:none;border-radius:12px;padding:13px;
  cursor:pointer;letter-spacing:1px;transition:.2s}
.btn.primary{background:var(--red);color:#fff;box-shadow:var(--shadow)}
.btn.ghost{background:var(--paper);border:1px solid var(--line);color:var(--ink2)}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ── result / prescription ── */
.matchscore{float:right;font-size:12px;color:#fff;background:var(--gold);padding:2px 9px;border-radius:10px}
.rx{margin-top:8px}
.rx table{width:100%;border-collapse:collapse;font-size:15px}
.rx th,.rx td{text-align:left;padding:7px 6px;border-bottom:1px dashed var(--line)}
.rx th{color:var(--ink2);font-weight:normal;font-size:13px}
.rx td.dose{text-align:right;color:var(--red);white-space:nowrap}
.rx td.hb{cursor:pointer;color:var(--ink);border-bottom:1px dashed var(--gold)}
/* ── 对应中成药 ── */
.otc{margin-top:12px;background:#eef3ea;border:1px solid #d3e0cc;border-radius:10px;padding:12px 14px}
.otc-h{font-size:14px;color:var(--green);font-weight:600;margin-bottom:8px;letter-spacing:.5px}
.otc-item{padding:7px 0;border-bottom:1px dashed #cfe0c8}
.otc-item:last-of-type{border-bottom:none}
.otc-nm{font-size:16px;color:var(--ink)}
.otc-sim{font-size:11px;background:#cfe0c8;color:#46603c;border-radius:8px;padding:0 7px;margin-left:6px}
.otc-form{font-size:12px;color:#fff;background:var(--green);border-radius:8px;padding:1px 9px;margin-left:8px}
.otc-use{font-size:13px;color:var(--ink2);margin-top:3px}
.otc-none{font-size:13px;color:var(--ink2)}
.otc-note{font-size:12px;color:var(--ink2);margin-top:8px;line-height:1.6}
.otc-tip{font-size:12px;color:var(--red);margin-top:8px}
.tagline{margin:10px 0 0;font-size:12px;color:var(--ink2)}
.tag{display:inline-block;background:#efe6d4;border:1px solid var(--line);border-radius:10px;
  padding:1px 9px;margin:2px 4px 2px 0;font-size:12px;color:var(--ink2)}
.note{background:#f6efe0;border-left:3px solid var(--gold);padding:10px 12px;border-radius:6px;
  font-size:13px;color:var(--ink2);margin-top:10px}
.warn{background:#fbe9e6;border-left:3px solid var(--red);padding:10px 12px;border-radius:6px;
  font-size:13px;color:#7a2b22;margin:14px 0}

/* ── search & lists ── */
.search{display:flex;gap:8px;margin-bottom:14px}
.search input{flex:1;font-family:inherit;font-size:16px;padding:12px 14px;border:1px solid var(--line);
  border-radius:12px;background:var(--paper);color:var(--ink)}
.search input:focus{outline:none;border-color:var(--gold)}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}
.chip{font-family:inherit;font-size:13px;border:1px solid var(--line);background:var(--paper);
  color:var(--ink2);padding:5px 13px;border-radius:18px;cursor:pointer}
.chip.on{background:var(--green);color:#fff;border-color:var(--green)}
.item{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:13px 15px;
  margin-bottom:10px;cursor:pointer;transition:.15s}
.item:active{background:#f6efe0}
.item .nm{font-size:17px;color:var(--ink);letter-spacing:.5px}
.item .nm .py{font-size:12px;color:var(--ink2);margin-left:6px;letter-spacing:0}
.item .meta{font-size:13px;color:var(--ink2);margin-top:3px}
.badge{display:inline-block;font-size:11px;background:#efe6d4;border:1px solid var(--line);
  border-radius:8px;padding:1px 8px;margin-right:6px;color:var(--ink2)}
.kv{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:15px;margin-top:6px}
.kv b{color:var(--gold);font-weight:normal;white-space:nowrap}

/* ── modal ── */
.mask{position:fixed;inset:0;background:rgba(40,28,14,.5);z-index:50;display:none;
  align-items:flex-end;justify-content:center}
.mask.show{display:flex}
.sheet{background:var(--paper);width:100%;max-width:760px;border-radius:18px 18px 0 0;
  padding:20px 18px 30px;max-height:86vh;overflow:auto;animation:up .25s}
@keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
.sheet h3{margin:0 0 2px;font-size:21px;color:var(--red)}
.sheet .x{float:right;font-size:24px;color:var(--ink2);cursor:pointer;line-height:1;border:none;background:none}
@media(min-width:760px){.mask{align-items:center}.sheet{border-radius:18px}}

footer{text-align:center;color:var(--ink2);font-size:12px;padding:10px 0 30px;line-height:1.8}
.empty{text-align:center;color:var(--ink2);padding:40px 10px;font-size:15px}
