/* WILO 北美出海策略白皮书 — long-form case page
   Inherits the portfolio's dark system; adds report-specific primitives. */
:root{
  --bg:#0a0a0b;
  --panel:#151517;
  --panel-2:#1c1c1f;
  --panel-3:#232327;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(255,255,255,0.14);
  --text:#f5f5f6;
  --ink:#cfcfd4;
  --muted:#8a8a90;
  --muted-2:#6a6a70;
  --green:#3fe17a;
  --green-dim:rgba(63,225,122,0.12);
  --teal:#46a6b8;
  --amber:#e8a13a;
  --rose:#e3685f;
  --font-body:'Noto Sans SC', system-ui, sans-serif;
  --font-serif:'Noto Serif SC', Georgia, serif;
  --font-mono:'Geist Mono', ui-monospace, monospace;
  --read:760px;
  --wide:1040px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);color:var(--text);font-family:var(--font-body);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  line-height:1.6;
}
::selection{background:var(--green);color:#04130a;}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:#2a2a2e;border-radius:20px;border:2px solid var(--bg);}
::-webkit-scrollbar-thumb:hover{background:#3a3a40;}
a{color:inherit;text-decoration:none;}

/* ---------- top bar ---------- */
.topbar{
  position:sticky;top:0;z-index:50;height:58px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(18px,4vw,40px);
  background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.topbar .back{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--ink);transition:color .2s;}
.topbar .back:hover{color:#fff;}
.topbar .back svg{transition:transform .2s;}
.topbar .back:hover svg{transform:translateX(-3px);}
.topbar .doc{font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--muted-2);}
.topbar .ver{font-family:var(--font-mono);font-size:11.5px;color:var(--muted);border:1px solid var(--line);border-radius:100px;padding:4px 11px;}

/* ---------- layout ---------- */
.shell{display:grid;grid-template-columns:248px minmax(0,1fr);gap:0;max-width:1280px;margin:0 auto;}
.toc{position:sticky;top:58px;align-self:start;height:calc(100vh - 58px);overflow-y:auto;
  padding:34px 22px 60px;border-right:1px solid var(--line);}
.toc-kick{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px;}
.toc a{display:flex;gap:12px;align-items:baseline;padding:8px 10px;border-radius:9px;font-size:13.5px;color:var(--muted);transition:background .18s,color .18s;line-height:1.45;}
.toc a .nn{font-family:var(--font-mono);font-size:11.5px;color:var(--muted-2);flex:0 0 auto;}
.toc a:hover{background:rgba(255,255,255,.04);color:var(--ink);}
.toc a.active{background:var(--green-dim);color:#fff;}
.toc a.active .nn{color:var(--green);}

.main{min-width:0;padding:0 clamp(20px,5vw,72px) 120px;}
.wrap{max-width:var(--read);margin:0 auto;}
.wrap.wide{max-width:var(--wide);}

/* ---------- cover ---------- */
.cover{max-width:var(--wide);margin:0 auto;padding:clamp(48px,8vh,96px) 0 40px;}
.wordmark{font-family:var(--font-mono);font-weight:500;letter-spacing:.34em;font-size:14px;color:var(--green);}
.cover h1{font-family:var(--font-serif);font-weight:900;font-size:clamp(40px,6vw,76px);line-height:1.08;letter-spacing:-.01em;margin-top:20px;}
.cover .sub{font-size:clamp(18px,1.7vw,22px);color:var(--text);font-weight:500;margin-top:18px;}
.cover .lede{max-width:760px;font-size:17px;line-height:1.95;color:var(--muted);margin-top:24px;text-wrap:pretty;}
.cover-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-top:40px;}
.cover-meta .cell{background:var(--panel);padding:20px 22px;}
.cover-meta .k{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:9px;}
.cover-meta .v{font-size:14.5px;line-height:1.6;color:var(--ink);}

/* mini table of contents on cover */
.toc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-top:28px;}
.toc-grid a{display:flex;gap:14px;align-items:baseline;background:var(--panel);padding:16px 20px;transition:background .18s;}
.toc-grid a:hover{background:var(--panel-2);}
.toc-grid .nn{font-family:var(--font-mono);font-size:13px;color:var(--green);flex:0 0 auto;}
.toc-grid .tt{font-size:15px;color:var(--text);font-weight:500;}

/* ---------- section ---------- */
.section{padding-top:clamp(64px,9vh,104px);scroll-margin-top:74px;}
.sec-head{max-width:var(--read);margin:0 auto;}
.sec-num{font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;color:var(--green);}
.sec-title{font-family:var(--font-serif);font-weight:900;font-size:clamp(30px,3.8vw,48px);line-height:1.12;letter-spacing:-.01em;margin-top:14px;}
.focus{display:flex;gap:12px;margin-top:24px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-size:14.5px;color:var(--muted);}
.focus b{color:var(--green);font-weight:600;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;flex:0 0 auto;padding-top:2px;}

/* prose */
.wrap h3{font-size:21px;font-weight:700;letter-spacing:-.01em;margin-top:46px;margin-bottom:2px;color:#fff;}
.wrap h3 .ord{font-family:var(--font-mono);font-size:14px;color:var(--green);margin-right:10px;}
.wrap p{font-size:17px;line-height:1.92;color:var(--ink);margin-top:18px;text-wrap:pretty;}
.wrap p.note{font-size:14.5px;line-height:1.8;color:var(--muted);}
.wrap ul{margin-top:18px;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:13px;}
.wrap ul li{position:relative;padding-left:26px;font-size:16px;line-height:1.8;color:var(--ink);text-wrap:pretty;}
.wrap ul li::before{content:"";position:absolute;left:6px;top:13px;width:6px;height:6px;border-radius:50%;background:var(--green);}
.wrap ul li b{color:#fff;font-weight:600;}

/* conclusion-first callout */
.tldr{max-width:var(--read);margin:28px auto 0;background:linear-gradient(180deg,var(--green-dim),rgba(63,225,122,0.04));border:1px solid color-mix(in srgb,var(--green) 32%,transparent);border-radius:16px;padding:22px 26px;}
.tldr .lbl{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:12px;}
.tldr .lbl::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);}
.tldr p{margin:0;font-size:16.5px;line-height:1.85;color:#eaeaec;}

/* figure (white plate on dark) */
figure.fig{margin:38px auto 0;max-width:var(--wide);}
figure.fig .plate{background:#fff;border-radius:14px;padding:18px;box-shadow:0 30px 70px -30px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.05);}
figure.fig img{display:block;width:100%;border-radius:6px;}
figure.fig figcaption{display:flex;gap:12px;margin-top:14px;font-family:var(--font-mono);font-size:12.5px;line-height:1.65;color:var(--muted);}
figure.fig figcaption .fn{color:var(--green);flex:0 0 auto;}

/* data table */
.tablecard{max-width:var(--wide);margin:34px auto 0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel);}
.tablecard .cap{padding:14px 20px;border-bottom:1px solid var(--line);font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--muted);}
table.data{width:100%;border-collapse:collapse;font-size:14.5px;}
table.data th,table.data td{padding:14px 18px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line);line-height:1.55;}
table.data thead th{font-size:12px;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--muted-2);font-weight:500;background:rgba(255,255,255,.02);}
table.data tbody tr:last-child td{border-bottom:none;}
table.data tbody tr:hover td{background:rgba(255,255,255,.018);}
table.data .num{font-family:var(--font-mono);color:#fff;white-space:nowrap;}
table.data .bp{font-weight:700;color:#fff;white-space:nowrap;}
table.data .pct{font-family:var(--font-mono);color:var(--green);font-weight:500;}
table.data td.muted{color:var(--muted);}
.tablecard .foot{padding:12px 20px;border-top:1px solid var(--line);font-size:12.5px;line-height:1.7;color:var(--muted-2);}

/* highlight row (WILO) */
table.data tr.hl td{background:var(--green-dim);}
table.data tr.hl:hover td{background:var(--green-dim);}
table.data tr.hl .bp,table.data tr.hl .num{color:var(--green);}

/* risk pills */
.risk{display:inline-block;font-family:var(--font-mono);font-size:11px;padding:3px 9px;border-radius:100px;white-space:nowrap;}
.risk.mid{color:var(--amber);background:color-mix(in srgb,var(--amber) 14%,transparent);border:1px solid color-mix(in srgb,var(--amber) 34%,transparent);}
.risk.high{color:var(--rose);background:color-mix(in srgb,var(--rose) 14%,transparent);border:1px solid color-mix(in srgb,var(--rose) 34%,transparent);}
.risk.vhigh{color:#fff;background:color-mix(in srgb,var(--rose) 60%,transparent);border:1px solid var(--rose);}
table.data td .yes{color:var(--green);}
table.data td .no{color:var(--rose);}

/* pull quote (用户原声) */
.voice{max-width:var(--read);margin:32px auto 0;background:var(--panel);border:1px solid var(--line);border-left:none;border-radius:16px;padding:26px 28px 22px;position:relative;overflow:hidden;}
.voice::before{content:"\201C";position:absolute;top:-18px;right:18px;font-family:var(--font-serif);font-size:120px;line-height:1;color:rgba(255,255,255,.05);}
.voice .en{font-family:var(--font-serif);font-style:italic;font-size:18.5px;line-height:1.62;color:#eef0ef;position:relative;z-index:1;}
.voice .gloss{margin-top:14px;font-size:14.5px;line-height:1.7;color:var(--muted);}
.voice .src{margin-top:16px;display:flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:11.5px;color:var(--muted-2);}
.voice .src .tag{color:var(--teal);}
.voice .src .qid{margin-left:auto;border:1px solid var(--line);border-radius:100px;padding:3px 9px;}

/* stat strip */
.stats{max-width:var(--wide);margin:34px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;}
.stats .s{background:var(--panel);padding:22px 20px;}
.stats .s .n{font-family:var(--font-mono);font-size:clamp(22px,2.4vw,30px);font-weight:500;color:#fff;letter-spacing:-.01em;}
.stats .s .n .u{font-size:14px;color:var(--muted);margin-left:4px;}
.stats .s .l{font-size:13px;color:var(--muted);margin-top:8px;line-height:1.5;}

/* phase / stepper card grid */
.cardgrid{max-width:var(--wide);margin:34px auto 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;}
.minicard{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px;}
.minicard .ph{font-family:var(--font-mono);font-size:12px;color:var(--green);letter-spacing:.04em;margin-bottom:12px;}
.minicard h4{font-size:17px;font-weight:700;margin-bottom:10px;}
.minicard ul{margin-top:0;}
.minicard ul li{font-size:14px;padding-left:20px;}
.minicard ul li::before{top:10px;width:5px;height:5px;}

/* divider label */
.kicker{max-width:var(--read);margin:0 auto;font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);}

/* footer */
.docfoot{border-top:1px solid var(--line);margin-top:96px;padding:48px clamp(20px,5vw,72px);}
.docfoot .inner{max-width:var(--wide);margin:0 auto;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:flex-end;}
.docfoot .big{font-family:var(--font-serif);font-weight:900;font-size:clamp(24px,3vw,38px);line-height:1.1;}
.docfoot .meta{font-family:var(--font-mono);font-size:12px;color:var(--muted-2);line-height:1.9;max-width:440px;}
.backtop{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink);border:1px solid var(--line-2);border-radius:100px;padding:10px 18px;transition:background .2s;}
.backtop:hover{background:rgba(255,255,255,.06);}

/* reveal — visible by default; JS adds .pending only to below-the-fold items, then reveals.
   This keeps content visible in screenshot/print/no-IO contexts. */
.rv{opacity:1;transform:none;}
.rv.pending{opacity:0;transform:translateY(22px);}
.rv.in{opacity:1;transform:none;transition:opacity .7s cubic-bezier(.16,.84,.44,1),transform .7s cubic-bezier(.16,.84,.44,1);}

@media (max-width:1080px){
  .shell{grid-template-columns:1fr;}
  .toc{display:none;}
}
@media (max-width:680px){
  .toc-grid{grid-template-columns:1fr;}
  .stats{grid-template-columns:repeat(2,1fr);}
  .cover h1{font-size:38px;}
}
@media (prefers-reduced-motion:reduce){
  .rv,.rv.pending{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}
