/* ① 本地字体 — 仅保留马善政手写体（slogan 专用）；正文/标题用系统字体栈 */
@font-face{font-family:"Ma Shan Zheng";font-weight:400;font-display:swap;src:url("../assets/fonts/MaShanZheng-Regular.woff2") format("woff2");}
/* 系统字体栈：苹方(iOS/macOS) → 冬青黑体(旧 macOS) → 微软雅黑(Windows) → 文泉驿(Linux) */

:root{ --bg:#f4efe6; --ink:#2a2521; --muted:#8a8278; --line:#e4ddd0; --brand:#0e6b73; --brand-d:#0a4d54; }
*{margin:0;padding:0;box-sizing:border-box;}
body{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei","WenQuanYi Micro Hei",sans-serif; background:
    radial-gradient(700px 400px at 15% -5%, #efe7d6 0%, transparent 60%),
    radial-gradient(700px 400px at 95% 105%, #ece3d0 0%, transparent 55%), var(--bg);
  color:var(--ink); min-height:100vh; display:flex; justify-content:center; padding:24px 14px; }
.app{ width:100%; max-width:460px; }

/* ---------- intro ---------- */
.intro{ text-align:center; padding:30px 8px; }
.intro .kicker{ font-size:12px; letter-spacing:4px; color:var(--brand); font-weight:700; }
.intro h1{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:900; font-size:34px; line-height:1.3; margin:16px 0 6px; }
.intro h1 .hl{ color:var(--brand); }
.intro p{ color:var(--muted); font-size:14px; line-height:1.8; margin:14px auto; max-width:330px; }
.btn{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; cursor:pointer; border:none; border-radius:999px; font-weight:700;
  background:var(--brand); color:#fff; padding:15px 40px; font-size:16px; letter-spacing:2px;
  box-shadow:0 10px 24px -8px rgba(14,107,115,.6); transition:transform .15s, box-shadow .15s; }
.btn:hover{ transform:translateY(-2px); box-shadow:0 14px 28px -8px rgba(14,107,115,.7); }
.btn.ghost{ background:transparent; color:var(--brand); box-shadow:none; border:1.5px solid var(--brand);
  padding:11px 26px; font-size:14px; }
.types-teaser{ margin-top:30px; display:flex; flex-wrap:wrap; gap:7px; justify-content:center; }
.types-teaser span{ font-size:11px; color:var(--muted); border:1px solid var(--line); border-radius:999px; padding:5px 11px; background:#fffdf8; }

/* ---------- quiz ---------- */
.quiz{ padding:6px 4px; }
.qtop{ display:flex; align-items:center; gap:12px; margin-bottom:22px; }
.qtop .back{ cursor:pointer; color:var(--muted); font-size:22px; line-height:1; width:30px; user-select:none; }
.prog{ flex:1; height:7px; background:var(--line); border-radius:99px; overflow:hidden; }
.prog i{ display:block; height:100%; background:linear-gradient(90deg,var(--brand),#33a39c); transition:width .3s; }
.qnum{ font-size:12px; color:var(--muted); font-variant-numeric:tabular-nums; }
.qtext{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:700; font-size:23px; line-height:1.5; margin:6px 4px 22px; }
.opts{ display:flex; flex-direction:column; gap:12px; }
.opt{ cursor:pointer; text-align:left; background:#fffdf8; border:1.5px solid var(--line); border-radius:16px;
  padding:17px 18px; font-size:15px; line-height:1.5; color:var(--ink); transition:all .15s; display:flex; gap:12px; align-items:center; }
.opt:hover{ border-color:var(--brand); background:#fff; transform:translateX(3px); box-shadow:0 6px 18px -10px rgba(14,107,115,.5); }
.opt .dot{ width:22px;height:22px;border-radius:50%;border:2px solid var(--line); flex-shrink:0; transition:all .15s; }
.opt:hover .dot{ border-color:var(--brand); background:var(--brand); box-shadow:inset 0 0 0 3px #fffdf8; }

/* ---------- result card ---------- */
.result{ }
.card{ position:relative; border-radius:28px; overflow:hidden; color:#fbf7ef; isolation:isolate;
  background:linear-gradient(165deg, var(--c1) 0%, var(--c2) 100%);
  box-shadow:0 36px 70px -22px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.06) inset; }
/* ② 静态噪声 PNG 取代 SVG fractalNoise + mix-blend-mode（html2canvas 不支持 mix-blend-mode） */
.card::after{ content:""; position:absolute; inset:0; z-index:5; pointer-events:none;
  opacity:.5; background-image:url("../assets/img/noise.png"); background-size:128px 128px; }
/* ③ color-mix() → render.js 注入的 CSS 变量（html2canvas 不支持 color-mix）
   --acc14 / --acc40 / --acc60w 由 renderCard() 按每型主色实时计算后 inline 在 .card 上 */
.glow{ position:absolute; width:260px;height:260px;border-radius:50%; top:-80px;right:-80px; z-index:0;
  background:radial-gradient(circle, var(--acc40), transparent 70%); }
.ci{ position:relative; z-index:6; padding:26px 26px 22px; }
.eyebrow{ display:flex; align-items:center; gap:8px; font-size:11px; letter-spacing:3px; font-weight:700; opacity:.85; }
.eyebrow .d{ width:5px;height:5px;border-radius:50%; background:var(--acc); }
.tname{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:900; font-size:33px; line-height:1.2; margin-top:14px; }
.tname .em{ color:var(--acc); }
.tsub{ margin-top:10px; font-size:13.5px; letter-spacing:1px; opacity:.92; line-height:1.6; }
.rule{ margin:20px 0 16px; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent); position:relative; }
.rule .h{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); color:var(--acc); padding:0 10px;
  background:var(--c2); font-size:15px; }
.cprow{ display:flex; align-items:flex-end; justify-content:space-between; gap:14px; }
.cprow .lab{ font-size:11px; letter-spacing:3px; opacity:.8; }
.cprow .sch{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:700; font-size:28px; margin-top:5px; line-height:1.1; }
.cprow .pct{ text-align:right; flex-shrink:0; }
.cprow .pct .n{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:900; font-size:52px; line-height:.9; color:var(--acc); }
.cprow .pct .c{ font-size:10px; letter-spacing:2px; opacity:.85; margin-top:3px; }
.roast{ margin-top:15px; padding:13px 15px; border-radius:13px; font-size:13px; line-height:1.7;
  background:var(--acc14); border:1px solid var(--acc40); }
.roast b{ color:var(--acc); }
.egg{ margin-top:13px; font-size:12.5px; opacity:.95; display:flex; align-items:center; gap:7px; }
.egg .tag{ font-size:9px; background:rgba(255,255,255,.25); padding:1px 5px; border-radius:4px; letter-spacing:1px; }
/* ④ 贝壳 SVG 图标尺寸 hook（替代 emoji 🐚，各端渲染不一且 html2canvas 易掉字） */
.egg .shell{ width:15px; height:15px; flex-shrink:0; }
.runners{ margin-top:18px; padding-top:14px; border-top:1px dashed rgba(255,255,255,.22); }
.runners .rh{ font-size:11px; letter-spacing:3px; opacity:.75; margin-bottom:9px; }
.runner{ display:flex; align-items:center; font-size:13.5px; padding:5px 0; }
.runner .nm{ width:120px; }
.runner .bar{ flex:1; height:5px; border-radius:3px; margin:0 10px; background:rgba(255,255,255,.14); overflow:hidden; }
.runner .bar i{ display:block; height:100%; border-radius:3px; background:linear-gradient(90deg, var(--acc60w), var(--acc)); }
.runner .p{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:700; width:40px; text-align:right; opacity:.9; }
.axes{ margin-top:18px; padding-top:14px; border-top:1px dashed rgba(255,255,255,.22); }
.axes .rh{ font-size:11px; letter-spacing:3px; opacity:.75; margin-bottom:10px; }
.axrow{ display:flex; align-items:center; font-size:11px; margin:7px 0; opacity:.95; }
.axrow .L{ width:34px; text-align:left; } .axrow .R{ width:34px; text-align:right; }
.axtrack{ flex:1; height:6px; margin:0 8px; border-radius:99px; background:rgba(255,255,255,.16); position:relative; }
.axtrack .mid{ position:absolute; left:50%; top:-3px; bottom:-3px; width:1px; background:rgba(255,255,255,.35); }
.axtrack .dot{ position:absolute; top:50%; width:11px; height:11px; border-radius:50%; background:var(--acc);
  transform:translate(-50%,-50%); box-shadow:0 0 0 2px var(--c2); }
.foot{ margin:22px -26px -22px; padding:16px 26px 20px; background:rgba(0,0,0,.18); display:flex; align-items:center; gap:13px; }
/* ④ .foot .qr 简化为固定尺寸容器；.qr span 假像素规则已移除；真码由 share.js makeQR() 填入 */
.foot .qr{ width:60px;height:60px;border-radius:9px;background:#fbf7ef;flex-shrink:0;padding:5px;display:flex;align-items:center;justify-content:center; }
.foot .ft .a{ font-family:"Ma Shan Zheng",serif; font-size:19px; color:var(--acc); }
.foot .ft .b{ font-size:11px; opacity:.85; margin-top:3px; }
.actions{ display:flex; gap:10px; justify-content:center; margin-top:20px; }

/* ---------- diagnostics ---------- */
.diag{ margin-top:18px; background:#fffdf8; border:1px solid var(--line); border-radius:18px; padding:20px; display:none; }
.diag h3{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-size:17px; margin-bottom:6px; }
.diag .note{ font-size:12px; color:var(--muted); line-height:1.7; margin-bottom:14px; }
.diag .stat{ display:flex; gap:18px; margin-bottom:14px; flex-wrap:wrap; }
.diag .stat div b{ display:block; font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-size:24px; color:var(--brand); }
.diag .stat div span{ font-size:11px; color:var(--muted); }
.dbar{ display:flex; align-items:center; font-size:12px; margin:5px 0; }
.dbar .nm{ width:120px; color:var(--ink); }
.dbar .bar{ flex:1; height:14px; border-radius:4px; background:#eee5d4; overflow:hidden; margin:0 8px; }
.dbar .bar i{ display:block; height:100%; background:linear-gradient(90deg,var(--brand),#46b3aa); }
.dbar .v{ width:42px; text-align:right; color:var(--muted); font-variant-numeric:tabular-nums; }
.hint{ font-size:11px; color:var(--muted); text-align:center; margin-top:14px; line-height:1.6; }

/* ---------- toast + 移动端存图浮层（Task 12 share.js 用） ---------- */
.toast{ position:fixed; left:50%; bottom:64px; transform:translateX(-50%); z-index:99;
  background:rgba(0,0,0,.82); color:#fff; font-size:13px; padding:10px 18px; border-radius:999px; }
.save-ov{ position:fixed; inset:0; z-index:100; background:rgba(0,0,0,.88); overflow:auto;
  display:flex; flex-direction:column; align-items:center; padding:20px 14px; gap:14px; }
.save-ov .save-tip{ color:#fff; font-size:13px; opacity:.9; }
.save-ov img{ width:100%; max-width:420px; border-radius:18px; box-shadow:0 20px 50px -20px rgba(0,0,0,.7); }
.save-ov .save-close{ color:#fff; background:transparent; border:1px solid rgba(255,255,255,.5);
  border-radius:999px; padding:8px 22px; font-size:14px; cursor:pointer; }

/* ---------- 16 型图鉴（Task 11 renderCodex 用） ---------- */
.codex{ padding:6px 2px 30px; }
.cx-top{ display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.cx-top .back{ cursor:pointer; color:var(--muted); font-size:24px; width:30px; }
.cx-title{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:900; font-size:21px; }
.cx-grid{ display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.cx-card{ border-radius:16px; padding:14px 13px; color:#fbf7ef; min-height:150px;
  background:linear-gradient(165deg,var(--c1),var(--c2)); box-shadow:0 10px 24px -14px rgba(0,0,0,.5); position:relative; }
.cx-card.mine{ outline:2px solid var(--acc); outline-offset:2px; }
.cx-code{ font-size:10px; letter-spacing:2px; opacity:.7; }
.cx-name{ font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei New","Microsoft YaHei",sans-serif; font-weight:900; font-size:17px; margin-top:4px; color:var(--acc); }
.cx-sub{ font-size:11px; opacity:.9; margin-top:5px; line-height:1.5; }
.cx-roast{ font-size:11px; opacity:.82; margin-top:8px; line-height:1.6; }
.cx-foot{ display:flex; gap:6px; align-items:center; margin-top:10px; flex-wrap:wrap; }
.cx-rare{ font-size:10px; background:rgba(255,255,255,.18); padding:2px 6px; border-radius:5px; }
.cx-you{ font-size:10px; background:var(--acc); color:#1a1a1a; padding:2px 6px; border-radius:5px; font-weight:700; }
