/* ============================================================
   畅付 / CardNimbus — site.css  (NEO-BRUTALISM)
   粗黑描边 + 硬阴影偏移 + 0 圆角 + 实色块分区
   电蓝 #2f50ff 主 + 柠檬黄 #ffd23f 高亮 + 纯黑描边
   Space Grotesk / Noto Sans SC
   ★ class 名与 token 名保持不变（index.html / app.js / go 页依赖）
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-soft:#eceef3;          /* 冷灰色块 */
  --bg-deep:#111114;          /* 黑块 */
  --ink:#111114;
  --text:#1a1c25;             /* 高对比正文 */
  --muted:#4c5160;            /* 次要，白底约 7:1 */
  --faint:#6b7180;
  --line:#111114;             /* 描边=黑 */
  --line-strong:#111114;
  --accent:#2f50ff;           /* 主电蓝 */
  --accent-press:#1c34c9;
  --accent-ink:#1f33c0;       /* 浅底上的蓝字，AA */
  --accent-wash:#e6ebff;
  --accent-wash2:#cdd8ff;
  --yellow:#ffd23f;           /* 柠檬黄高亮 */
  --yellow-deep:#f5b800;
  --ok:#0c7a44;
  --warn:#9a5b00;
  --bad:#c0271f;
  --r:0; --r-lg:0; --pill:0;  /* 直角 */
  --bw:3px;                   /* 标准描边宽 */
  --sh-1:4px 4px 0 var(--ink);
  --sh-2:7px 7px 0 var(--ink);
  --sh-3:10px 10px 0 var(--ink);
  --font:"Space Grotesk","Noto Sans SC",system-ui,-apple-system,"Segoe UI",Roboto,"PingFang SC","Microsoft YaHei",sans-serif;
  --maxw:1160px;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--font);color:var(--text);background:var(--bg);
  font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-ink);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{color:var(--ink);font-weight:700;line-height:1.08;margin:0 0 .5em;
  letter-spacing:-.02em;text-wrap:balance}
p{margin:0 0 1em}
strong{color:var(--ink);font-weight:700}
hr{border:0;border-top:var(--bw) solid var(--ink);margin:0}
::selection{background:var(--yellow);color:var(--ink)}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(18px,5vw,40px)}
.section{padding-block:clamp(50px,8vw,90px)}
.section--soft{background:var(--bg-soft);border-top:var(--bw) solid var(--ink);border-bottom:var(--bw) solid var(--ink)}
.section--tight{padding-block:clamp(0px,0vw,0px)}
.kicker{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);background:var(--yellow);border:var(--bw) solid var(--ink);padding:.32em .7em;margin:0 0 16px;
  box-shadow:var(--sh-1)}
.sec-head{max-width:48em;margin-bottom:34px}
.sec-head h2{font-size:clamp(1.7rem,4vw,2.6rem);letter-spacing:-.03em}
.sec-head p{color:var(--muted);font-size:1.05rem;margin:0;max-width:42em}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  font-family:var(--font);font-weight:700;font-size:.98rem;line-height:1;
  padding:.92em 1.5em;border:var(--bw) solid var(--ink);background:#fff;color:var(--ink);
  cursor:pointer;box-shadow:var(--sh-1);transition:transform .1s ease,box-shadow .1s ease}
.btn:hover{text-decoration:none;transform:translate(-1px,-1px);box-shadow:var(--sh-2)}
.btn:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}
.btn--primary{background:var(--accent);color:#fff}
.btn--ghost{background:#fff;color:var(--ink)}
.btn--light{background:var(--yellow);color:var(--ink)}
.btn--block{display:flex;width:100%}

/* ---------- Disclosure strip ---------- */
.strip{background:var(--ink);color:#e8eaf2;font-size:.82rem}
.strip__in{display:flex;flex-wrap:wrap;gap:6px 18px;align-items:center;justify-content:space-between;padding-block:9px}
.strip b{color:var(--yellow);font-weight:700}
.strip .lang a{color:#c2c7da;font-weight:600}
.strip .lang a[aria-current]{color:#fff;text-decoration:underline}
/* language dropdown */
.langsel{position:relative;display:inline-block}
.langsel>summary{list-style:none;cursor:pointer;color:#fff;font-weight:700;font-size:.82rem;display:inline-flex;align-items:center;gap:.35em;padding:.1em .25em}
.langsel>summary::-webkit-details-marker{display:none}
.langsel>summary::after{content:"▾";font-size:.8em;color:var(--yellow)}
.langsel__menu{position:absolute;right:0;top:calc(100% + 7px);background:#fff;border:var(--bw) solid var(--ink);box-shadow:var(--sh-1);min-width:130px;z-index:80;display:flex;flex-direction:column}
.langsel__menu a{padding:.6em .9em;color:var(--ink)!important;font-weight:600;font-size:.85rem;border-bottom:2px solid var(--ink)}
.langsel__menu a:last-child{border-bottom:0}
.langsel__menu a:hover{background:var(--yellow);text-decoration:none}
.langsel__menu a[aria-current]{color:var(--accent-ink)!important;background:var(--accent-wash)}

/* ---------- Header ---------- */
.site-head{position:sticky;top:0;z-index:60;background:#fff;border-bottom:var(--bw) solid var(--ink)}
.site-head__in{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:.5em;font-weight:700;color:var(--ink);font-size:1.15rem;letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand__mark{flex:none;width:32px;height:32px;background:var(--accent);border:var(--bw) solid var(--ink);
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:.95rem}
.brand__en{color:var(--muted);font-weight:600;font-size:.8rem;letter-spacing:.02em}
.nav{display:flex;align-items:center;gap:8px}
.nav a{color:var(--ink);font-weight:600;font-size:.92rem;padding:.5em .7em}
.nav a:hover{color:var(--accent-ink);text-decoration:none;background:var(--yellow)}
.nav__cta{border:var(--bw) solid var(--ink);background:var(--accent);color:#fff!important;
  padding:.55em 1em!important;box-shadow:3px 3px 0 var(--ink)}
.nav__cta:hover{background:var(--accent)!important;transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}
.nav-toggle{display:none;border:var(--bw) solid var(--ink);background:#fff;box-shadow:3px 3px 0 var(--ink);
  width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;
  width:18px;height:2.5px;background:var(--ink);position:relative;transition:.2s}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--bg);border-bottom:var(--bw) solid var(--ink);
  background-image:linear-gradient(90deg,rgba(17,17,20,.05) 1px,transparent 1px),linear-gradient(rgba(17,17,20,.05) 1px,transparent 1px);
  background-size:42px 42px}
.hero__in{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:start;
  padding-block:clamp(44px,7vw,80px)}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.5em;background:var(--yellow);
  border:var(--bw) solid var(--ink);color:var(--ink);font-weight:700;font-size:.8rem;
  padding:.4em .85em;margin-bottom:22px;box-shadow:var(--sh-1)}
.hero__eyebrow .dot{width:8px;height:8px;background:var(--accent);border:1.5px solid var(--ink)}
.hero h1{font-size:clamp(2.2rem,6vw,4rem);letter-spacing:-.035em;line-height:1.02;margin-bottom:.4em;font-weight:700}
.hero h1 .hl{background:var(--accent);color:#fff;padding:0 .08em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.hero__lede{font-size:clamp(1.02rem,1.7vw,1.2rem);color:var(--text);max-width:32em;margin-bottom:26px;font-weight:500}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:24px;color:var(--muted);font-size:.86rem;font-weight:600}
.hero__trust span{display:inline-flex;align-items:center;gap:.45em}
.hero__trust svg{color:var(--accent)}

/* precheck card */
.precheck{background:#fff;border:var(--bw) solid var(--ink);box-shadow:var(--sh-3)}
.precheck__top{display:flex;align-items:center;gap:.55em;padding:15px 18px;background:var(--accent);
  color:#fff;border-bottom:var(--bw) solid var(--ink)}
.precheck__top svg{color:#fff}
.precheck__top h2{font-size:1.04rem;margin:0;color:#fff}
.precheck__top .tag{margin-left:auto;font-size:.68rem;font-weight:700;color:var(--ink);background:var(--yellow);
  border:2px solid var(--ink);padding:.22em .6em;text-transform:uppercase;letter-spacing:.04em}
.precheck dl{margin:0;padding:4px 18px}
.precheck dl>div{padding:14px 0;border-bottom:2px solid var(--ink)}
.precheck dl>div:last-child{border-bottom:0}
.precheck dt{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.precheck dd{margin:0;color:var(--ink);font-weight:700;font-size:1rem}
.precheck dd.dom{font-family:"Space Grotesk",monospace;letter-spacing:.01em}
.precheck dd small,.precheck small{display:block;font-weight:500;color:var(--muted);font-size:.8rem;margin-top:5px;line-height:1.55}
.precheck__disc{margin:0;padding:14px 18px;font-size:.78rem;color:var(--muted);background:var(--bg-soft);border-top:2px solid var(--ink)}
.precheck__cta{padding:16px 18px;border-top:var(--bw) solid var(--ink)}

/* ---------- Chip strip (bold band) ---------- */
.section--tight.section--soft{background:var(--yellow);padding-block:18px}
.chips{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.chips .lbl{color:var(--ink);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-right:4px}
.chip{display:inline-flex;align-items:center;gap:.4em;background:#fff;border:var(--bw) solid var(--ink);
  padding:.4em .85em;font-size:.84rem;color:var(--ink);font-weight:600;box-shadow:3px 3px 0 var(--ink)}
.chip b{color:var(--accent-ink);font-weight:700}

/* ---------- Decision tool ---------- */
.tool{display:grid;grid-template-columns:.84fr 1.16fr;gap:0;border:var(--bw) solid var(--ink);
  background:#fff;box-shadow:var(--sh-3)}
.tool__form{background:var(--accent-wash);padding:clamp(22px,3vw,30px);border-right:var(--bw) solid var(--ink)}
.tool__form h3{font-size:1.05rem;margin:0 0 4px}
.tool__form .hint{color:var(--muted);font-size:.85rem;margin:0 0 16px;font-weight:500}
.field{margin-bottom:14px}
.seg{display:flex;flex-wrap:wrap;gap:8px}
.seg button{font-family:var(--font);font-size:.84rem;font-weight:600;color:var(--ink);
  background:#fff;border:2.5px solid var(--ink);padding:.5em .85em;cursor:pointer;transition:.1s;box-shadow:2px 2px 0 var(--ink)}
.seg button:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}
.seg button[aria-pressed="true"]{background:var(--accent);color:#fff;box-shadow:2px 2px 0 var(--ink)}
.tool__note{margin:14px 0 0;font-size:.76rem;color:var(--muted);line-height:1.55}
.tool__out{padding:clamp(22px,3vw,30px);background:#fff}
.tool__out-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:16px;
  border-bottom:var(--bw) solid var(--ink);padding-bottom:12px}
.tool__out-head h3{font-size:1.06rem;margin:0}
.tool__out-head .est{font-size:.68rem;color:var(--ink);font-weight:700;background:var(--yellow);
  border:2px solid var(--ink);padding:.25em .6em;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}
.tool__empty{display:flex;flex-direction:column;gap:10px;align-items:flex-start;justify-content:center;
  min-height:210px;color:var(--muted);border:2.5px dashed var(--ink);padding:24px;text-align:left;font-weight:500}
.tool__empty svg{color:var(--accent)}
.route{border:var(--bw) solid var(--ink);padding:14px 16px;margin-bottom:12px;background:#fff;box-shadow:3px 3px 0 var(--ink)}
.route.is-best{background:var(--accent-wash);box-shadow:5px 5px 0 var(--accent)}
.route__head{display:flex;align-items:center;gap:9px;margin-bottom:10px;flex-wrap:wrap}
.route__name{font-weight:700;color:var(--ink);font-size:1rem}
.route__verdict{font-size:.68rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  border:2px solid var(--ink);padding:.26em .6em}
.v-best{background:var(--accent);color:#fff}
.v-ok{background:var(--yellow);color:var(--ink)}
.v-care{background:#fff;color:var(--ink)}
.v-no{background:#e6e7ec;color:var(--muted)}
.route__bars{display:flex;flex-wrap:wrap;gap:8px 16px;margin-bottom:9px}
.bar{display:inline-flex;align-items:center;gap:.5em;font-size:.78rem;color:var(--muted);font-weight:500}
.bar b{color:var(--ink);font-weight:700}
.dots{display:inline-flex;gap:3px}
.dots i{width:9px;height:9px;background:#fff;border:1.5px solid var(--ink);display:block}
.dots i.on{background:var(--accent)}
.dots.warn i.on{background:var(--warn)}
.route__why{margin:0;font-size:.87rem;color:var(--text)}
.tool__cta{margin-top:16px;display:flex;flex-wrap:wrap;gap:12px;align-items:center;
  border-top:var(--bw) solid var(--ink);padding-top:16px}
.tool__cta .micro{flex:1;min-width:200px;font-size:.74rem;color:var(--muted);margin:0}

/* ---------- Comparison table ---------- */
.tbl-scroll{overflow-x:auto;border:var(--bw) solid var(--ink);box-shadow:var(--sh-2);background:#fff}
table.cmp{width:100%;border-collapse:collapse;min-width:680px;font-size:.92rem;background:#fff}
table.cmp th,table.cmp td{padding:14px 16px;text-align:left;border-bottom:2px solid var(--ink);
  border-right:2px solid var(--ink);vertical-align:top}
table.cmp tr td:last-child,table.cmp tr th:last-child{border-right:0}
table.cmp tbody tr:last-child td,table.cmp tbody tr:last-child th{border-bottom:0}
table.cmp thead th{background:var(--ink);color:#fff;font-weight:700;font-size:.86rem}
table.cmp tbody th{background:var(--bg-soft);color:var(--ink);font-weight:700;font-size:.82rem;white-space:nowrap}
table.cmp td .sub{display:block;color:var(--muted);font-size:.78rem;font-weight:500;margin-top:4px}
.lv{display:inline-flex;align-items:center;gap:.4em;font-weight:700}
.lv::before{content:"";width:10px;height:10px;border:1.5px solid var(--ink)}
.lv-good{color:var(--ok)} .lv-good::before{background:var(--ok)}
.lv-mid{color:var(--warn)} .lv-mid::before{background:var(--yellow)}
.lv-bad{color:var(--bad)} .lv-bad::before{background:var(--bad)}
.cmp-foot{font-size:.8rem;color:var(--muted);margin:16px 2px 0}

/* ---------- Paths ---------- */
.paths{display:flex;flex-direction:column;gap:14px}
.path{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;
  background:#fff;border:var(--bw) solid var(--ink);padding:18px 20px;box-shadow:var(--sh-1);transition:.1s}
.path:hover{transform:translate(-2px,-2px);box-shadow:var(--sh-2);text-decoration:none;background:var(--accent-wash)}
.path__k{font-size:.74rem;font-weight:700;color:var(--ink);background:var(--yellow);
  border:2px solid var(--ink);padding:.45em .8em;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}
.path__t{color:var(--ink);font-weight:700;font-size:1.04rem}
.path__t small{display:block;color:var(--muted);font-weight:500;font-size:.86rem;margin-top:4px;line-height:1.5}
.path__arrow{color:var(--accent);font-size:1.5rem;font-weight:700;transition:transform .1s}
.path:hover .path__arrow{transform:translateX(5px)}

/* ---------- Guides ---------- */
.guides{display:flex;flex-direction:column;border:var(--bw) solid var(--ink);background:#fff;box-shadow:var(--sh-2)}
.guide{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;
  padding:20px 22px;border-bottom:2px solid var(--ink);transition:.1s}
.guide:last-child{border-bottom:0}
.guide:hover{background:var(--yellow);text-decoration:none}
.guide__n{font-family:"Space Grotesk",monospace;font-size:1.5rem;font-weight:700;color:#fff;
  background:var(--accent);border:2px solid var(--ink);width:42px;height:42px;display:grid;place-items:center}
.guide:hover .guide__n{background:var(--ink)}
.guide__t{color:var(--ink);font-weight:700;font-size:1.08rem;line-height:1.3}
.guide__t .d{display:block;color:var(--muted);font-weight:500;font-size:.9rem;margin-top:5px;line-height:1.55}
.guide:hover .guide__t .d{color:#3a2f00}
.guide__r{color:var(--ink);font-size:.78rem;font-weight:700;white-space:nowrap;border:2px solid var(--ink);padding:.3em .6em;background:#fff}

/* ---------- Bridge (black block) ---------- */
.bridge{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center;
  background:var(--ink);color:#e8eaf2;border:var(--bw) solid var(--ink);box-shadow:var(--sh-3);
  padding:clamp(26px,4vw,46px);position:relative}
.bridge h2{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:.5em}
.bridge h2 .hl,.bridge .hl{background:var(--yellow);color:var(--ink);padding:0 .08em}
.bridge p{color:#c2c7da;margin:0;font-weight:500}
.bridge .check{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-direction:column;gap:12px}
.bridge .check li{display:flex;gap:12px;align-items:flex-start;color:#e8eaf2;font-size:.92rem;line-height:1.5;font-weight:500}
.bridge .check svg{flex:none;margin-top:2px;color:var(--ink);background:var(--yellow);border:2px solid #fff;padding:2px;width:22px;height:22px}
.bridge__cta .micro{margin:12px 0 0;font-size:.76rem;color:#9aa1bb;line-height:1.6}

/* ---------- Closing (blue block) ---------- */
.section.close{background:var(--accent);border-top:var(--bw) solid var(--ink);border-bottom:var(--bw) solid var(--ink);text-align:center}
.close h2{color:#fff;font-size:clamp(1.9rem,5vw,3rem);letter-spacing:-.03em}
.close h2 .hl{background:var(--yellow);color:var(--ink);padding:0 .1em}
.close p{color:#dde3ff;max-width:38em;margin:0 auto 24px;font-weight:500}
.close .btn--primary{background:var(--yellow);color:var(--ink);border-color:var(--ink);box-shadow:4px 4px 0 #0a1a8c}
.close .btn--primary:hover{box-shadow:6px 6px 0 #0a1a8c}

/* ---------- Footer ---------- */
.foot{background:var(--ink);color:#b8bdd0;font-size:.9rem;padding-block:46px 30px}
.foot__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:34px;padding-bottom:28px;border-bottom:2px solid #3a3e52}
.foot__brand .brand{color:#fff;margin-bottom:14px}
.foot__brand .brand__mark{border-color:#fff}
.author{display:flex;gap:12px;align-items:flex-start;margin:6px 0 0}
.author__mark{flex:none;width:42px;height:42px;background:var(--accent);color:#fff;
  display:grid;place-items:center;font-weight:700;border:2px solid #fff}
.author p{margin:0;color:#aab0c8;font-size:.84rem;line-height:1.6;font-weight:500}
.author a{color:var(--yellow)}
.foot h4{color:#fff;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;margin:0 0 14px}
.foot__links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot__links a{color:#b8bdd0;font-weight:500}
.foot__links a:hover{color:var(--yellow)}
.foot__legal{padding-top:22px;color:#8b91a8;font-size:.78rem;line-height:1.7}
.foot__copy{margin-top:14px;color:#787e96;font-size:.78rem;display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between}

/* ---------- Reveal ---------- */
.js [data-reveal]{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s cubic-bezier(.2,.7,.2,1)}
.js [data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js [data-reveal]{opacity:1!important;transform:none!important;transition:none}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero__in{grid-template-columns:1fr;gap:30px}
  .precheck{max-width:520px}
  .tool{grid-template-columns:1fr}
  .tool__form{border-right:0;border-bottom:var(--bw) solid var(--ink)}
  .bridge{grid-template-columns:1fr;gap:22px}
  .foot__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .nav{display:none}
  .nav-toggle{display:inline-flex}
  .nav.is-open{display:flex;position:absolute;top:66px;left:0;right:0;flex-direction:column;
    align-items:stretch;gap:0;background:#fff;border-bottom:var(--bw) solid var(--ink);padding:0}
  .nav.is-open a{padding:14px clamp(18px,5vw,40px);border-bottom:2px solid var(--ink)}
  .nav.is-open .nav__cta{margin:0;box-shadow:none;text-align:center}
  .path{grid-template-columns:1fr auto;gap:10px 14px}
  .path__k{grid-column:1/-1;justify-self:start}
  .guide{grid-template-columns:auto 1fr;gap:14px}
  .guide__r{display:none}
  .foot__grid{grid-template-columns:1fr}
  /* 触摸目标尺寸 (手机适配) */
  .seg button{min-height:42px}
  .btn{min-height:46px}
  .nav-toggle{width:46px;height:46px}
  .langsel>summary{min-height:40px;padding:.45em .4em}
  .chip{min-height:38px}
}
@media (max-width:380px){
  body{font-size:15.5px}
  .hero__cta .btn,.tool__cta .btn{width:100%}
  .chips .lbl{width:100%}
}
