/* ============================================================
   余地 Yudi · 站点样式 v2（瑞士金融数据网格 / Swiss grid）
   复刻方向：Httpster「Grid」族真实站(c23 / Clairoux) 的瑞士现代主义 ——
   大号 grotesk 无衬线 + 严格网格 + 发丝分隔线 + 等宽数字当主角 + 黑白灰 + 钴蓝/信号红。
   保留全部 class / 变量名（HTML 不动），只换视觉。纯系统字体，0 webfont。
   ============================================================ */

:root{
  --paper:      #ffffff;
  --paper-2:    #f4f4f4;
  --paper-3:    #ededed;
  --ink:        #0f0f0f;
  --ink-soft:   #4a4a4a;
  --ink-faint:  #8c8c8c;
  --rule:       #e2e2e2;
  --rule-dark:  #111111;

  --teal:       #1d3df5;   /* 主强调 = 钴蓝（信息/操作） */
  --teal-deep:  #122ec4;
  --teal-tint:  #e9edff;
  --oxblood:    #ec1c24;   /* 风险红（亏损/警示） */
  --oxblood-tint:#fdebec;
  --gold:       #1d3df5;   /* 旧金 → 钴蓝 */

  --serif: "Inter","Helvetica Neue",Helvetica,Arial,"PingFang SC","Noto Sans SC","Microsoft YaHei",sans-serif;
  --sans:  "Inter","Helvetica Neue",Helvetica,Arial,"PingFang SC","Noto Sans SC","Microsoft YaHei",sans-serif;
  --mono:  "Roboto Mono","DM Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;

  --measure: 42rem;
  --rail: 15rem;
  --maxw: 78rem;
}

*,*::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; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1;
}
img{ max-width:100%; height:auto; }
a{ color:var(--teal); text-decoration:none; }
a:hover{ text-decoration:underline; text-underline-offset:.16em; text-decoration-thickness:.08em; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 6vw; }
@media (min-width:1100px){ .wrap{ padding:0 4rem; } }

.eyebrow{ font-family:var(--mono); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink); margin:0 0 1rem; display:flex; align-items:center; gap:.6rem; }
.eyebrow::before{ content:""; width:.7rem; height:.7rem; background:var(--teal); display:inline-block; }
.eyebrow.warn{ color:var(--oxblood); }
.eyebrow.warn::before{ background:var(--oxblood); }

/* 报头 */
.masthead{ border-bottom:2px solid var(--ink); background:var(--paper); }
.masthead__bar{ max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:.55rem 6vw; border-bottom:1px solid var(--rule);
  font-family:var(--mono); font-size:.68rem; letter-spacing:.14em; color:var(--ink-faint); text-transform:uppercase; }
@media (min-width:1100px){ .masthead__bar{ padding:.55rem 4rem; } }
.masthead__bar .motto{ color:var(--teal); }
.masthead__main{ max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1rem 6vw 1.05rem; }
@media (min-width:1100px){ .masthead__main{ padding:1.1rem 4rem; } }
.brand{ display:flex; align-items:center; gap:.7rem; text-decoration:none; color:var(--ink); }
.brand:hover{ text-decoration:none; }
.brand__seal{ width:40px; height:40px; flex:0 0 40px; display:grid; place-items:center; background:var(--ink); color:#fff;
  font-family:var(--sans); font-weight:800; font-size:1.2rem; line-height:1; border-radius:0; }
.brand__name{ font-family:var(--sans); font-weight:800; font-size:1.5rem; letter-spacing:-.02em; line-height:1; }
.brand__name small{ display:block; font-family:var(--mono); font-weight:400; font-size:.58rem; letter-spacing:.22em; color:var(--ink-faint); margin-top:.34rem; text-transform:uppercase; }

.masthead__nav{ display:flex; align-items:center; gap:1.2rem; }
.nav{ display:flex; align-items:center; gap:1.4rem; font-family:var(--sans); font-size:.92rem; font-weight:500; }
.nav a{ color:var(--ink); text-decoration:none; padding:.4rem 0; }
.nav a:hover{ color:var(--teal); text-decoration:none; }
.nav a[aria-current="page"]{ box-shadow:inset 0 -3px var(--teal); }
.nav-toggle{ display:none; }
@media (max-width:860px){
  .nav{ display:none; position:absolute; left:0; right:0; top:100%; flex-direction:column; align-items:flex-start; gap:0;
    background:var(--paper); border-bottom:2px solid var(--ink); padding:.5rem 6vw 1rem; z-index:40; }
  .nav.open{ display:flex; }
  .nav a{ width:100%; padding:.85rem 0; border-bottom:1px solid var(--rule); min-height:44px; }
  .masthead__main{ position:relative; }
  .masthead__nav{ gap:.55rem; }
  .nav-toggle{ display:inline-grid; place-items:center; width:44px; height:44px; background:none; border:1px solid var(--ink); border-radius:0; cursor:pointer; }
  .nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{ content:""; display:block; width:20px; height:2px; background:var(--ink); position:relative; }
  .nav-toggle span::before{ position:absolute; top:-6px; }
  .nav-toggle span::after{ position:absolute; top:6px; }
}

.langsw{ position:relative; font-family:var(--mono); font-size:.78rem; }
.langsw__btn{ background:none; border:1px solid var(--ink); border-radius:0; padding:.45rem .7rem; min-height:38px; cursor:pointer;
  color:var(--ink); display:inline-flex; align-items:center; gap:.4rem; letter-spacing:.06em; text-transform:uppercase; }
.langsw__menu{ display:none; position:absolute; right:0; top:calc(100% + 4px); background:var(--paper); border:1px solid var(--ink); border-radius:0; padding:0; min-width:11rem; z-index:50; }
.langsw:hover .langsw__menu,.langsw.open .langsw__menu{ display:block; }
.langsw__menu a{ display:block; padding:.6rem .8rem; color:var(--ink); text-decoration:none; min-height:40px; border-bottom:1px solid var(--rule); font-family:var(--sans); }
.langsw__menu a:last-child{ border-bottom:0; }
.langsw__menu a:hover{ background:var(--ink); color:#fff; text-decoration:none; }
.langsw__menu a[aria-current="true"]{ color:var(--teal); font-weight:700; }

/* 首页封面 */
.cover{ padding:3rem 0 0; border-bottom:2px solid var(--ink); }
.cover__grid{ display:grid; gap:0; }
@media (min-width:980px){ .cover__grid{ grid-template-columns:1.55fr 1fr; } .cover__grid > div:first-child{ padding-right:3rem; border-right:1px solid var(--rule); } }
.cover__grid > div:first-child{ padding-bottom:2.4rem; }
.cover h1{ font-family:var(--sans); font-weight:800; line-height:1.03; letter-spacing:-.025em; font-size:clamp(2.4rem,7vw,4.6rem); margin:.2rem 0 1.2rem; max-width:15ch; }
.cover h1 em{ font-style:normal; color:var(--oxblood); }
.cover .standfirst{ font-size:1.15rem; color:var(--ink-soft); max-width:40ch; margin:0 0 1.6rem; line-height:1.5; }
.cover__meta{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; color:var(--ink-faint); text-transform:uppercase; display:flex; flex-wrap:wrap; gap:0; margin-top:1.6rem; border-top:1px solid var(--rule); }
.cover__meta span{ padding:.7rem 1.1rem .7rem 0; border-right:1px solid var(--rule); margin-right:1.1rem; }
.cover__meta span:last-child{ border-right:0; }
@media (min-width:980px){ .cover aside.codecard{ padding-left:3rem; } }

/* 邀请码卡（黑框数据块） */
.codecard{ background:var(--ink); color:#f4f4f4; border-radius:0; padding:1.7rem 1.6rem; position:relative; overflow:hidden; height:100%; }
.codecard h2{ font-family:var(--sans); font-weight:700; font-size:1.05rem; margin:0 0 .5rem; color:#fff; letter-spacing:-.01em; }
.codecard .why{ font-size:.95rem; line-height:1.55; color:#c9c9c9; margin:.2rem 0 1.2rem; font-family:var(--sans); }
.codeline{ display:flex; align-items:center; justify-content:space-between; gap:.8rem; background:#1c1c1c; border:1px solid #333; border-radius:0; padding:.7rem .9rem; margin-bottom:.8rem; }
.codeline .label{ font-family:var(--mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:#9a9a9a; }
.codeline .val{ font-family:var(--mono); font-size:1.35rem; font-weight:700; letter-spacing:.1em; color:#fff; }
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-family:var(--sans); font-weight:700; font-size:.98rem; min-height:48px; padding:.8rem 1.3rem; border-radius:0; text-decoration:none; cursor:pointer; border:0; letter-spacing:.01em; }
.btn--gold{ background:var(--teal); color:#fff; width:100%; }
.btn--gold:hover{ background:var(--teal-deep); text-decoration:none; }
.btn--ink{ background:#fff; color:var(--ink); width:100%; }
.btn--ink:hover{ background:#e6e6e6; text-decoration:none; }
.btn--ghost{ background:transparent; color:var(--teal); border:1.5px solid var(--teal); }
.btn--ghost:hover{ background:var(--teal); color:#fff; text-decoration:none; }
.codecard .fineprint{ font-family:var(--sans); font-size:.72rem; line-height:1.5; color:#9a9a9a; margin:.9rem 0 0; }
.codecard .fineprint a{ color:#dcdcdc; }

/* 区块 */
.sec{ padding:3rem 0; border-bottom:1px solid var(--rule); }
.sec__head{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:1.8rem; border-bottom:2px solid var(--ink); padding-bottom:.7rem; }
.sec__head h2{ font-family:var(--sans); font-weight:800; font-size:1.7rem; margin:0; letter-spacing:-.02em; }
.sec__head a{ font-family:var(--mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; white-space:nowrap; }

/* 文章列表 */
.entries{ display:grid; gap:0; }
.entry{ display:grid; grid-template-columns:auto 1fr; gap:1.6rem; padding:1.5rem 0; border-bottom:1px solid var(--rule); text-decoration:none; color:var(--ink); align-items:start; transition:background-color .12s, padding .12s; }
.entry:first-child{ border-top:1px solid var(--rule); }
.entry:hover{ background:var(--paper-2); padding-left:1rem; padding-right:1rem; }
.entry:hover .entry__title{ color:var(--teal); }
.entry__num{ font-family:var(--mono); font-size:.82rem; color:var(--teal); padding-top:.35rem; letter-spacing:.04em; font-weight:600; }
.entry__title{ font-family:var(--sans); font-weight:700; font-size:1.32rem; line-height:1.25; margin:0 0 .4rem; letter-spacing:-.01em; }
.entry__dek{ font-size:.98rem; color:var(--ink-soft); margin:0 0 .55rem; max-width:62ch; }
.entry__meta{ font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); display:flex; flex-wrap:wrap; gap:1rem; }
.entry__meta .tag{ color:var(--teal); }
@media (max-width:560px){ .entry{ grid-template-columns:1fr; gap:.3rem; } .entry__num{ display:none; } }

/* 卡片网格 */
.cards{ display:grid; gap:0; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); border-top:1px solid var(--rule); }
.card{ background:var(--paper); border:1px solid var(--rule); border-left:0; border-top:0; padding:1.4rem 1.3rem; display:flex; flex-direction:column; gap:.5rem; }
.cards .card:first-child{ border-left:1px solid var(--rule); }
.card h3{ font-family:var(--sans); font-weight:700; font-size:1.15rem; margin:0; letter-spacing:-.01em; }
.card p{ font-size:.92rem; color:var(--ink-soft); margin:0; flex:1; }
.card .btn{ margin-top:.6rem; }

/* 文章正文 + 页边批注 */
.article{ padding:2.6rem 0 3rem; }
.article__header{ margin-bottom:2.2rem; border-bottom:2px solid var(--ink); padding-bottom:1.6rem; }
.article__header h1{ font-family:var(--sans); font-weight:800; line-height:1.08; font-size:clamp(2rem,5vw,3.2rem); margin:.4rem 0 .9rem; max-width:24ch; letter-spacing:-.025em; }
.article__standfirst{ font-size:1.18rem; color:var(--ink-soft); max-width:44ch; margin:0 0 1.2rem; line-height:1.5; }
.article__byline{ font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint); display:flex; flex-wrap:wrap; gap:.4rem 1.4rem; align-items:center; }
.article__byline b{ color:var(--ink); font-weight:600; }

.prose > *{ max-width:var(--measure); }
.prose h2{ font-family:var(--sans); font-weight:800; font-size:1.55rem; margin:2.6rem 0 .9rem; padding-top:1rem; border-top:1px solid var(--rule); letter-spacing:-.02em; }
.prose h3{ font-family:var(--sans); font-weight:700; font-size:1.18rem; margin:1.9rem 0 .6rem; letter-spacing:-.01em; }
.prose p{ margin:0 0 1.15rem; }
.prose ul,.prose ol{ margin:0 0 1.2rem; padding-left:1.3rem; }
.prose li{ margin:.45rem 0; }
.prose strong{ font-weight:700; }
.prose .lead::first-letter{ font-size:3rem; line-height:.82; float:left; padding:.05rem .5rem 0 0; color:var(--teal); font-weight:800; font-family:var(--sans); }

.mnote{ font-family:var(--mono); font-size:.78rem; line-height:1.5; color:var(--ink-soft); }
@media (min-width:1080px){
  .mnote{ float:right; clear:right; width:var(--rail); margin-right:calc(-1 * (var(--rail) + 2.5rem)); margin-top:.3rem; margin-bottom:1rem; padding-left:1rem; border-left:2px solid var(--teal); }
  .mnote.warn{ border-left-color:var(--oxblood); }
  .mnote.warn .mnote__k{ color:var(--oxblood); }
}
.mnote__k{ display:block; font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--teal); margin-bottom:.3rem; font-weight:600; }
@media (max-width:1079px){
  .mnote{ display:block; background:var(--paper-2); border-left:3px solid var(--teal); border-radius:0; padding:.8rem 1rem; margin:1.3rem 0; max-width:var(--measure); }
  .mnote.warn{ border-left-color:var(--oxblood); background:var(--oxblood-tint); }
}

.callout{ background:var(--paper-2); border:1px solid var(--rule); border-left:4px solid var(--ink); border-radius:0; padding:1.1rem 1.2rem; margin:1.7rem 0; max-width:var(--measure); }
.callout.warn{ background:var(--oxblood-tint); border-color:#f3c2c4; border-left-color:var(--oxblood); }
.callout.warn .callout__k{ color:var(--oxblood); }
.callout.note{ background:var(--teal-tint); border-color:#c7d2ff; border-left-color:var(--teal); }
.callout.note .callout__k{ color:var(--teal-deep); }
.callout__k{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; margin:0 0 .4rem; color:var(--ink-faint); font-weight:600; }
.callout p:last-child{ margin-bottom:0; }

.figure{ margin:1.9rem 0; max-width:var(--measure); }
.figure img,.figure svg{ border:1px solid var(--ink); border-radius:0; display:block; width:100%; height:auto; }
.figure figcaption{ font-family:var(--mono); font-size:.72rem; letter-spacing:.04em; color:var(--ink-faint); margin-top:.5rem; text-transform:uppercase; }

.prose blockquote{ margin:1.7rem 0; padding:.2rem 0 .2rem 1.3rem; border-left:3px solid var(--teal); color:var(--ink-soft); font-size:1.08rem; }

.tablewrap{ overflow-x:auto; margin:1.7rem 0; max-width:var(--measure); }
table.data{ border-collapse:collapse; width:100%; font-family:var(--mono); font-size:.9rem; }
table.data th,table.data td{ text-align:right; padding:.6rem .85rem; border-bottom:1px solid var(--rule); white-space:nowrap; }
table.data th:first-child,table.data td:first-child{ text-align:left; font-family:var(--sans); }
table.data thead th{ border-bottom:2px solid var(--ink); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink); }
table.data tbody tr:hover{ background:var(--paper-2); }

.toc{ background:var(--paper-2); border:1px solid var(--ink); border-radius:0; padding:1.2rem 1.4rem; margin:0 0 2.2rem; max-width:var(--measure); }
.toc h2{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink); margin:0 0 .7rem; padding:0; border:0; font-weight:600; }
.toc ol{ margin:0; padding-left:1.4rem; font-family:var(--sans); font-size:.95rem; }
.toc li{ margin:.35rem 0; }
.toc a{ color:var(--ink); text-decoration:none; }
.toc a:hover{ color:var(--teal); text-decoration:underline; }

/* 计算器（数据终端块） */
.calc{ background:var(--paper); border:2px solid var(--ink); border-radius:0; padding:1.5rem 1.5rem 1.7rem; margin:1.9rem 0; max-width:var(--measure); }
.calc__title{ font-family:var(--sans); font-weight:800; font-size:1.2rem; margin:0 0 .3rem; letter-spacing:-.01em; }
.calc__sub{ font-size:.93rem; color:var(--ink-soft); margin:0 0 1.2rem; }
.calc__row{ display:grid; gap:1rem; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); }
.field{ display:flex; flex-direction:column; gap:.35rem; }
.field label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
.field input,.field select{ font-family:var(--mono); font-size:1.05rem; padding:.6rem .7rem; min-height:46px; border:1px solid var(--ink); border-radius:0; background:var(--paper); color:var(--ink); }
.field input:focus,.field select:focus{ outline:2px solid var(--teal); outline-offset:-1px; border-color:var(--teal); }
.calc__out{ margin-top:1.4rem; padding-top:1.2rem; border-top:2px solid var(--ink); display:grid; gap:0; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); }
.stat{ padding:.2rem 1.1rem .2rem 0; border-right:1px solid var(--rule); }
.stat:last-child{ border-right:0; }
.stat .stat__k{ font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); }
.stat .stat__v{ font-family:var(--mono); font-size:2rem; font-weight:700; color:var(--ink); line-height:1.1; letter-spacing:-.01em; }
.stat .stat__v.warn{ color:var(--oxblood); }
.calc__note{ font-family:var(--sans); font-size:.78rem; color:var(--ink-faint); margin:1.1rem 0 0; line-height:1.5; }

.endcta{ background:var(--ink); color:#f4f4f4; border-radius:0; padding:1.9rem 1.7rem; margin:2.8rem 0 0; max-width:var(--measure); }
.endcta h2{ font-family:var(--sans); font-weight:800; font-size:1.5rem; margin:0 0 .6rem; color:#fff; padding:0; border:0; letter-spacing:-.02em; }
.endcta p{ color:#c9c9c9; font-size:.98rem; margin:0 0 1.2rem; }
.endcta .row{ display:flex; flex-wrap:wrap; gap:.8rem; }

.authorcard{ display:flex; gap:1rem; align-items:flex-start; background:var(--paper-2); border:1px solid var(--ink); border-radius:0; padding:1.2rem; margin:2.6rem 0 0; max-width:var(--measure); }
.authorcard img{ width:54px; height:54px; border-radius:0; border:1px solid var(--ink); }
.authorcard .name{ font-family:var(--sans); font-weight:700; font-size:1.05rem; margin:0 0 .2rem; }
.authorcard .bio{ font-size:.9rem; color:var(--ink-soft); margin:0; }

.sources{ margin:2.6rem 0 0; max-width:var(--measure); font-size:.9rem; }
.sources h2{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink); border:0; padding:0; }
.sources ol{ padding-left:1.3rem; color:var(--ink-soft); }
.sources li{ margin:.4rem 0; }

.foot{ background:var(--ink); color:#cfcfcf; margin-top:3rem; position:relative; }
.foot__grid{ max-width:var(--maxw); margin:0 auto; padding:2.8rem 6vw; display:grid; gap:1.8rem; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); }
@media (min-width:1100px){ .foot__grid{ padding:2.8rem 4rem; } }
.foot h4{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 .9rem; }
.foot a{ display:block; color:#cfcfcf; text-decoration:none; padding:.28rem 0; font-size:.93rem; }
.foot a:hover{ color:#fff; text-decoration:underline; }
.foot .brand{ color:#fff; }
.foot .brand__seal{ background:#fff; color:var(--ink); }
.foot .brand__name{ color:#fff; }
.foot__bottom{ border-top:1px solid #333; }
.foot__bottom .inner{ max-width:var(--maxw); margin:0 auto; padding:1.4rem 6vw; font-size:.8rem; color:var(--ink-faint); line-height:1.7; }
@media (min-width:1100px){ .foot__bottom .inner{ padding:1.4rem 4rem; } }
.disclosure{ background:var(--paper-2); border:1px solid var(--rule); border-left:4px solid var(--ink); border-radius:0; padding:.9rem 1.1rem; margin-bottom:1.2rem; font-size:.8rem; color:var(--ink-soft); line-height:1.6; }

.page-body{ padding:2.6rem 0 3rem; }
.page-body h1{ font-family:var(--sans); font-weight:800; font-size:clamp(1.9rem,4vw,2.7rem); margin:.3rem 0 1.3rem; max-width:24ch; letter-spacing:-.025em; }

.skip{ position:absolute; left:-9999px; top:0; background:var(--ink); color:#fff; padding:.6rem 1rem; z-index:100; }
.skip:focus{ left:0; }
.mono{ font-family:var(--mono); }
.muted{ color:var(--ink-faint); }
.center{ text-align:center; }
@media (max-width:680px){ .hide-mobile{ display:none !important; } }

::selection{ background:var(--teal); color:#fff; }
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,.btn:focus-visible{ outline:2px solid var(--teal); outline-offset:2px; }
h2[id],h3[id],section[id]{ scroll-margin-top:1.2rem; }
.btn:active{ transform:translateY(1px); }
.toc a.active{ color:var(--teal); font-weight:700; }

@media print{
  .masthead,.foot,.endcta,.codecard,.nav-toggle{ display:none !important; }
  body{ background:#fff; }
  .prose > *{ max-width:none; }
  .mnote{ float:none; width:auto; margin:1rem 0; }
}
