/* ============================================================
   小禾志愿 · 设计系统「刻度 / Caliper」
   产品灵魂 = 位次温度计 → 升格为全页签名仪器：精密位次卡尺。
   你=基准线；学校=轴上刻痕；冲/稳/保=轴上渐变场。
   极简 · 留白 · 仪表读数。数字 Space Grotesk 自托管（缺则系统等宽）。
   —— 阶段接入：home 先用；plan/其余页随后纳入同一文件。
   ============================================================ */

/* Space Grotesk 自托管（拉丁/数字三 subset，与 x2.css 同源）——绝不引外链 */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500 700;font-display:swap;src:url(/static/fonts/sg-3.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500 700;font-display:swap;src:url(/static/fonts/sg-2.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500 700;font-display:swap;src:url(/static/fonts/sg-1.woff2) format('woff2');unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;}

:root{
  --paper:#FBFAF6;        /* 暖中性近白，非奶油 */
  --paper-2:#F2F0E9;
  --bg:#ffffff;
  --ink:#16181C;          /* 近黑 */
  --ink-2:#595E66;
  --ink-3:#9AA0A6;
  --ink-4:#B7BBC0;
  --hair:#E9E6DD;         /* 发丝线·暖灰 */
  --hair-2:#DAD6C9;

  --signal:#0B5C3B;       /* 仪器绿（品牌线，深而锐）*/
  --signal-2:#0E7049;
  --signal-soft:#E4EFE9;
  --signal-line:#BFD9CC;

  /* 冲稳保 = 轴上场 */
  --risk:#A7ACB2;
  --reach:#D8472A; --reach-soft:#FBE7E1; --reach-line:#F1C7BC;
  --match:#C2861B; --match-soft:#FAF0DA; --match-line:#EDD8AA;
  --safe:#1E8F5E;  --safe-soft:#E2F2EA;  --safe-line:#BBE0CC;

  --mono:'Space Grotesk',ui-monospace,'SF Mono',Menlo,monospace;
  --sans:-apple-system,'PingFang SC','Noto Sans SC','Microsoft YaHei',sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  font-family:var(--sans);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{background:var(--paper);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;}
button{font:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;}
a{color:inherit;}
:focus-visible{outline:2px solid var(--signal);outline-offset:3px;}
input:focus-visible,textarea:focus-visible{outline:none;}

.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em;}
.tick-lbl{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);}
.av-sprout{flex:0 0 auto;}

/* 蓝图网格氛围层 — 固定最底，边缘渐隐，绝不veil内容 */
.grid-bg{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(20,24,28,.028) .5px,transparent .5px),
    linear-gradient(90deg,rgba(20,24,28,.028) .5px,transparent .5px);
  background-size:104px 104px;background-position:-1px -1px;
  -webkit-mask-image:radial-gradient(130% 90% at 50% 22%,#000 42%,transparent 100%);
          mask-image:radial-gradient(130% 90% at 50% 22%,#000 42%,transparent 100%);}

/* ===================================================================
   首页
   =================================================================== */
.home{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;overflow:auto;position:relative;}
.home-top{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:22px 30px;}
.home-top .av-sprout{width:25px;height:31px;}
.home-top .bname{font-size:15px;font-weight:800;letter-spacing:.01em;white-space:nowrap;}
.home-top .reg{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.22em;
  color:var(--ink-3);padding:2px 6px;border:1px solid var(--hair-2);border-radius:3px;}
.home-top .sp{flex:1;}
.home-resume{font-size:12.5px;font-weight:600;color:var(--ink-3);text-decoration:none;
  transition:color .14s;white-space:nowrap;}
.home-resume:hover{color:var(--signal);}

.home-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:12px 18px 48px;text-align:center;}
.home-eyebrow{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.3em;
  text-transform:uppercase;color:var(--signal);margin-bottom:20px;}
.home-h1{font-size:clamp(28px,6.4vw,46px);font-weight:800;line-height:1.08;
  letter-spacing:-.02em;color:var(--ink);text-wrap:balance;max-width:14em;}
.home-h1 .em{color:var(--signal);}
.home-lede{margin-top:15px;color:var(--ink-2);font-size:14.5px;line-height:1.7;max-width:32em;text-wrap:balance;}
.home-lede b{color:var(--ink);font-weight:700;}

/* madlib = 仪器输入卡 */
.madlib{margin-top:34px;width:100%;max-width:580px;background:var(--bg);
  border:1px solid var(--hair-2);border-radius:18px;padding:24px 26px 20px;text-align:left;
  box-shadow:0 1px 0 var(--hair),0 22px 48px -32px rgba(20,24,28,.5);position:relative;z-index:40;}
.mad-head{display:flex;align-items:center;gap:8px;margin-bottom:16px;}
.mad-head .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 0 0 var(--signal);animation:pulse 2.6s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(11,92,59,.32)}70%{box-shadow:0 0 0 7px rgba(11,92,59,0)}100%{box-shadow:0 0 0 0 rgba(11,92,59,0)}}

.ml-sent{font-size:21px;font-weight:500;line-height:2.0;color:var(--ink);}
.ml-seg{white-space:nowrap;}   /* 词组级折行，只在逗号处断 */
.hslot{position:relative;display:inline-block;margin:0 3px;}
.hslot-btn{display:inline-flex;align-items:center;gap:5px;border:none;font:inherit;
  background:var(--signal-soft);color:var(--signal);font-size:20px;font-weight:700;
  padding:1px 11px 3px;border-radius:9px;box-shadow:inset 0 -2px 0 var(--signal-line);
  cursor:pointer;transition:background .14s;white-space:nowrap;}
.hslot-btn:hover{background:#d6ebe0;}
.hslot-btn.ph{color:var(--ink-3);background:#F1F0EA;box-shadow:inset 0 -2px 0 var(--hair-2);font-weight:500;}
.hslot-btn.ph:hover{background:#EAE8E0;}
.hslot-btn.err{background:var(--reach-soft);color:var(--reach);box-shadow:inset 0 -2px 0 var(--reach-line),0 0 0 1.5px var(--reach-line);}
.hslot-btn.err:hover{background:#f8d9cf;}
.hslot .cv{display:inline-flex;color:var(--signal);opacity:.5;}
.hslot-btn.ph + .cv{color:var(--ink-3);}
.hslot-btn.err + .cv{color:var(--reach);}
.hslot .cv svg{transition:transform .18s var(--ease);}
.hslot.open .cv svg{transform:rotate(180deg);}
.hslot.shake{animation:shake .4s;}
@keyframes shake{10%,90%{transform:translateX(-1px)}30%,70%{transform:translateX(2px)}50%{transform:translateX(-3px)}}

.hpop{position:absolute;left:50%;top:46px;z-index:30;transform:translateX(-50%);
  padding:12px;width:max-content;border-radius:13px;background:var(--bg);
  border:1px solid var(--hair-2);box-shadow:0 16px 40px -12px rgba(20,24,28,.28);
  animation:hpopIn .18s var(--ease) both;}
@keyframes hpopIn{from{transform:translateX(-50%) translateY(5px) scale(.97);opacity:0;}to{transform:translateX(-50%) translateY(0) scale(1);opacity:1;}}
.hpop-head{display:flex;align-items:baseline;gap:10px;padding:2px 6px 10px;
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.04em;
  color:var(--ink-3);text-align:left;white-space:nowrap;}
.hpop-head .sp{flex:1;min-width:18px;}
.hpop-head .warn{color:var(--reach);}
.hpop-count{font-size:13px;font-weight:700;color:var(--ink-3);}
.hpop-count small{font-size:10px;color:var(--ink-4);}
.hpop-count.ok{color:var(--signal);}
.hgrid{display:grid;gap:5px;}
.hgrid.p4{grid-template-columns:repeat(4,84px);}
.hgrid.p3{grid-template-columns:repeat(3,94px);}
.hcell{position:relative;height:40px;border-radius:10px;border:1px solid var(--hair);
  background:var(--bg);font-size:13.5px;font-weight:600;color:var(--ink-2);
  display:inline-flex;align-items:center;justify-content:center;gap:5px;transition:all .13s;white-space:nowrap;}
.hcell:hover{border-color:var(--signal-line);background:var(--signal-soft);color:var(--signal);}
.hcell.on{border-color:transparent;background:var(--signal);color:#fff;font-weight:700;}
.hcell.on:hover{background:var(--signal-2);}
.hcell.anchor::after{content:"";position:absolute;top:6px;right:7px;width:4.5px;height:4.5px;border-radius:50%;background:var(--signal-line);}
.hcell.anchor.on::after{background:rgba(255,255,255,.6);}

.ml-score{display:inline-block;width:104px;margin:0 4px;border:none;outline:none;
  background:var(--signal-soft);box-shadow:inset 0 -2px 0 var(--signal-line);border-radius:9px;
  padding:1px 10px 3px;font-size:20px;font-weight:700;color:var(--signal);text-align:center;
  font-family:var(--mono);transition:background .14s,box-shadow .14s;}
.ml-score:focus{background:#d6ebe0;box-shadow:inset 0 -2px 0 var(--signal);}
.ml-score::placeholder{color:#9cc7b4;font-weight:600;}
.ml-score.ph{color:var(--ink-3);background:#F1F0EA;box-shadow:inset 0 -2px 0 var(--hair-2);}
.ml-score.ph::placeholder{color:#B7BBC0;}
.ml-score.ph:focus{background:#d6ebe0;box-shadow:inset 0 -2px 0 var(--signal);}

/* 读数行（#rankline）+ CTA — 卡内底部，仪表脚注 */
.mad-foot{display:flex;align-items:center;gap:14px;margin-top:20px;padding-top:16px;
  border-top:1px dashed var(--hair-2);}
.ml-rank{flex:1;font-size:12.5px;color:var(--ink-2);font-weight:500;min-height:20px;line-height:1.5;}
.ml-rank b{font-family:var(--mono);color:var(--ink);font-weight:700;font-size:14px;}
.ml-rank .num{color:var(--signal);}
.ml-rank .warn{color:var(--reach);font-weight:600;}
.ml-rank .rl-sub{color:var(--ink-3);}
.home-cta{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--paper);
  border:none;padding:11px 20px;border-radius:999px;font-size:14px;font-weight:700;letter-spacing:.01em;
  text-decoration:none;white-space:nowrap;transition:transform .15s var(--ease),background .2s,opacity .2s;}
.home-cta:hover{transform:translateX(2px);background:var(--signal);}
.home-cta:active{transform:scale(.97);}
.home-cta.mute{background:#C9C7BD;cursor:default;transform:none;}
.home-cta.mute:hover{background:#C9C7BD;transform:none;}

.home-noscore{margin-top:24px;display:flex;align-items:center;justify-content:center;gap:9px;flex-wrap:wrap;}
.home-noscore .ns-lab{font-size:12px;color:var(--ink-3);}
.ns-chip{font-size:12.5px;color:var(--ink-2);border:1px solid var(--hair-2);background:var(--bg);
  padding:6px 13px;border-radius:999px;text-decoration:none;transition:.18s;}
.ns-chip:hover{border-color:var(--signal);color:var(--signal);}

/* 功能索引 = 仪器面板按钮列，编号编码功能序 */
.home-index{margin:40px auto 0;width:100%;max-width:580px;border-top:1px solid var(--hair-2);}
.ixrow{display:flex;align-items:center;gap:16px;padding:14px 4px;border-bottom:1px solid var(--hair);
  text-decoration:none;color:inherit;transition:.18s;}
.ixrow:hover{padding-left:12px;background:linear-gradient(90deg,var(--signal-soft),transparent);}
.ixrow .no{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--ink-3);width:24px;}
.ixrow .nm{font-weight:600;font-size:15px;flex:0 0 auto;}
.ixrow .ds{flex:1;font-size:12px;color:var(--ink-3);text-align:right;}
.ixrow .ar{color:var(--ink-3);transition:.18s;}
.ixrow:hover .ar{color:var(--signal);transform:translateX(3px);}
.ixrow:hover .no{color:var(--signal);}

.home-foot{flex:0 0 auto;text-align:center;padding:22px 20px 30px;
  font-size:11px;color:var(--ink-4);line-height:1.7;}

@media(prefers-reduced-motion:reduce){*{animation:none!important;}}
@media(min-width:760px){.ml-sent{font-size:22px;line-height:2.1;}}
@media(max-width:600px){
  .home-top{padding:16px 18px;}
  .madlib{padding:20px 18px 18px;}
  .ml-sent{font-size:18px;line-height:1.95;}
  .hslot-btn{font-size:17px;}
  .ml-score{font-size:17px;width:84px;}
  .hgrid.p4{grid-template-columns:repeat(4,minmax(60px,1fr));}
  .hgrid.p3{grid-template-columns:repeat(3,minmax(78px,1fr));}
  .hpop{max-width:calc(100vw - 36px);}
  .mad-foot{flex-direction:column;align-items:stretch;gap:12px;}
  .home-cta{justify-content:center;}
  .ixrow .ds{display:none;}
}
