/* ============================================================
   畅付 / CardNimbus — guide.css  长读版式（NEO-BRUTALISM）
   复用 site.css 的 token 与 class；本文件只加正文页专属组件
   ============================================================ */

.read{background:var(--bg-soft);padding-block:0}
.read__wrap{max-width:1080px;margin-inline:auto;padding-inline:clamp(16px,4vw,32px)}
.read__grid{display:grid;grid-template-columns:1fr 250px;gap:36px;align-items:start;padding-block:clamp(28px,4vw,48px)}
.post{background:#fff;border:var(--bw) solid var(--ink);box-shadow:var(--sh-2);
  padding:clamp(22px,4vw,48px);min-width:0}

/* breadcrumb */
.crumb{font-size:.8rem;color:var(--muted);font-weight:600;margin-bottom:18px;display:flex;flex-wrap:wrap;gap:.4em}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--accent-ink)}
.crumb span{color:var(--ink)}

/* head */
.post__head h1{font-size:clamp(1.7rem,4.2vw,2.7rem);letter-spacing:-.03em;line-height:1.08;margin:0 0 .2em}
.post__head h1 small{display:block;font-size:.46em;font-weight:600;color:var(--muted);letter-spacing:0;
  line-height:1.4;margin-top:.5em}
.post__head h1 .hl{background:var(--accent);color:#fff;padding:0 .08em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.byline{font-size:.85rem;color:var(--muted);font-weight:600;margin:16px 0 0;
  border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:10px 0}
.byline a{color:var(--accent-ink)}

/* lede */
.lede{font-size:1.12rem;line-height:1.6;color:var(--ink);font-weight:500;
  background:var(--yellow);border:var(--bw) solid var(--ink);box-shadow:var(--sh-1);
  padding:18px 20px;margin:24px 0}
.lede strong{font-weight:700}

/* TOC */
details.toc{border:var(--bw) solid var(--ink);background:#fff;box-shadow:var(--sh-1);margin:24px 0 30px}
details.toc>summary{cursor:pointer;list-style:none;font-weight:700;color:var(--ink);
  padding:13px 18px;background:var(--accent-wash);border-bottom:var(--bw) solid var(--ink);
  display:flex;align-items:center;gap:.5em;font-size:.95rem}
details.toc[open]>summary{border-bottom:var(--bw) solid var(--ink)}
details.toc:not([open])>summary{border-bottom:0}
details.toc>summary::-webkit-details-marker{display:none}
details.toc>summary::before{content:"▸";color:var(--accent);font-size:.9em;transition:transform .15s}
details.toc[open]>summary::before{transform:rotate(90deg)}
details.toc ol{margin:0;padding:14px 20px 16px 20px;counter-reset:toc;list-style:none}
details.toc li{counter-increment:toc;margin:0 0 9px;padding-left:34px;position:relative;line-height:1.4}
details.toc li::before{content:counter(toc,decimal-leading-zero);position:absolute;left:0;top:0;
  font-family:"Space Grotesk",monospace;font-weight:700;color:var(--accent);font-size:.85rem}
details.toc a{color:var(--text);font-weight:500;font-size:.95rem}
details.toc a:hover{color:var(--accent-ink)}

/* body typography */
.post h2{font-size:clamp(1.32rem,2.6vw,1.7rem);letter-spacing:-.02em;margin:42px 0 14px;
  padding-top:10px;scroll-margin-top:84px;line-height:1.2}
.post h2::before{content:"";display:block;width:46px;height:6px;background:var(--accent);
  border:2px solid var(--ink);margin-bottom:14px}
.post h3{font-size:1.12rem;margin:26px 0 10px}
.post p{margin:0 0 1.05em;line-height:1.75;color:var(--text)}
.post>p,.post>ul,.post>ol{max-width:42em}
.post a{color:var(--accent-ink);text-decoration:underline;text-underline-offset:2px;font-weight:600}
.post strong{color:var(--ink);font-weight:700}
.post ul,.post ol{margin:0 0 1.1em;padding-left:0;line-height:1.7}
.post ul{list-style:none}
.post ul>li{position:relative;padding-left:26px;margin-bottom:9px}
.post ul>li::before{content:"";position:absolute;left:2px;top:.55em;width:9px;height:9px;
  background:var(--accent);border:1.5px solid var(--ink)}
.post ol{counter-reset:n;list-style:none;padding-left:0}
.post ol>li{position:relative;padding-left:38px;margin-bottom:12px}
.post ol>li::before{counter-increment:n;content:counter(n);position:absolute;left:0;top:-2px;
  width:26px;height:26px;background:var(--ink);color:#fff;font-weight:700;font-size:.82rem;
  display:grid;place-items:center;font-family:"Space Grotesk",monospace}

/* steps (强调操作序列) */
ol.steps{counter-reset:s}
ol.steps>li{padding-left:42px;margin-bottom:14px}
ol.steps>li::before{counter-increment:s;content:counter(s);background:var(--accent);width:30px;height:30px}

/* checklist (字段核对/可打勾) */
ul.checklist{border:var(--bw) solid var(--ink);box-shadow:var(--sh-1);padding:16px 18px 16px 18px!important;background:#fff;margin:22px 0}
ul.checklist>li{padding-left:30px}
ul.checklist>li::before{content:"";width:14px;height:14px;background:#fff;border:2px solid var(--ink);top:.35em;left:0}

/* ★ 解码卡 (本站签名组件：把现场报错/红旗话术拆给你看) */
.decode{border:var(--bw) solid var(--ink);background:var(--ink);color:#e8eaf2;
  box-shadow:var(--sh-2);margin:26px 0;overflow:hidden}
.decode__bar{display:flex;align-items:center;gap:.5em;background:var(--accent);color:#fff;
  padding:9px 16px;border-bottom:var(--bw) solid #000;font-weight:700;font-size:.82rem;
  letter-spacing:.05em;text-transform:uppercase;font-family:"Space Grotesk",monospace}
.decode__bar::before{content:">_";font-weight:700}
.decode__scene{font-family:"Space Grotesk",monospace;font-size:.95rem;color:#9fffcb;
  padding:16px 18px 14px;border-bottom:2px dashed #3a3e52;line-height:1.5}
.decode__scene .who{color:#7f88aa;display:block;font-size:.78rem;margin-bottom:4px;text-transform:none;letter-spacing:0}
.decode__body{padding:14px 18px}
.decode__row{display:grid;grid-template-columns:auto 1fr;gap:10px 12px;margin-bottom:10px}
.decode__row:last-child{margin-bottom:0}
.decode__k{font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;
  color:var(--ink);background:var(--yellow);border:2px solid #fff;padding:.2em .5em;height:max-content;white-space:nowrap}
.decode__k.do{background:#9fffcb}
.decode__v{color:#dfe4f5;font-size:.92rem;line-height:1.55;align-self:center}

/* note / 该停 / 提醒 boxes (full border, no side-stripe) */
.note{border:var(--bw) solid var(--ink);background:#fff;box-shadow:var(--sh-1);padding:15px 18px;margin:22px 0;font-size:.94rem;line-height:1.65}
.note p{margin:0}
.note p+p{margin-top:.7em}
.note__t{display:inline-flex;align-items:center;gap:.45em;font-weight:700;color:var(--ink);margin-bottom:6px}
.note.caution{background:#fff7e0}
.note.caution .note__t{color:var(--warn)}
.note.stop{background:#fdecea;border-color:var(--bad)}
.note.stop .note__t{color:var(--bad)}
.note.stop{box-shadow:5px 5px 0 var(--bad)}

/* hands-on (自己动手核对) */
.handson{border:var(--bw) solid var(--ink);background:var(--accent-wash);box-shadow:var(--sh-1);padding:18px 20px;margin:24px 0}
.handson .note__t{color:var(--accent-ink)}

/* ratecard / 对比表 (复用 cmp 视觉) */
.ratecard{overflow-x:auto;border:var(--bw) solid var(--ink);box-shadow:var(--sh-1);margin:22px 0;background:#fff}
table.rate{width:100%;border-collapse:collapse;min-width:560px;font-size:.9rem}
table.rate th,table.rate td{padding:11px 14px;text-align:left;border-bottom:2px solid var(--ink);border-right:2px solid var(--ink);vertical-align:top}
table.rate tr td:last-child,table.rate tr th:last-child{border-right:0}
table.rate tbody tr:last-child td,table.rate tbody tr:last-child th{border-bottom:0}
table.rate thead th{background:var(--ink);color:#fff;font-weight:700}
table.rate tbody th{background:var(--bg-soft);color:var(--ink);font-weight:700;white-space:nowrap}
table.rate .sub{display:block;color:var(--muted);font-size:.78rem;font-weight:500;margin-top:3px}

/* FAQ */
.faq{margin:18px 0}
.faq dt{font-weight:700;color:var(--ink);margin:18px 0 6px;font-size:1.02rem}
.faq dt::before{content:"Q ";color:var(--accent);font-family:"Space Grotesk",monospace}
.faq dd{margin:0 0 4px;color:var(--text);line-height:1.7}

/* out-note (桥接出站) */
.out-note{background:var(--accent);color:#fff;border:var(--bw) solid var(--ink);box-shadow:var(--sh-2);
  padding:clamp(20px,3vw,28px);margin:30px 0}
.out-note h3{color:#fff;margin:0 0 .5em;font-size:1.2rem}
.out-note p{color:#dde3ff;margin:0 0 14px;font-size:.92rem;line-height:1.6}
.out-note .btn--light{background:var(--yellow);color:var(--ink)}
.out-note .micro{font-size:.74rem;color:#c2ccff;margin:12px 0 0}

/* author card */
.author-card{display:flex;gap:16px;align-items:flex-start;border:var(--bw) solid var(--ink);
  box-shadow:var(--sh-1);background:var(--bg-soft);padding:18px 20px;margin:30px 0 0}
.author-card .av{flex:none;width:50px;height:50px;background:var(--accent);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:1.2rem;border:2px solid var(--ink)}
.author-card p{margin:0;font-size:.88rem;color:var(--text);line-height:1.6}
.author-card strong{display:block;color:var(--ink);margin-bottom:3px}

/* related */
.related{margin:28px 0 0;border-top:var(--bw) solid var(--ink);padding-top:20px}
.related h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 14px}
.related ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.related a{display:flex;gap:10px;align-items:baseline;color:var(--ink);font-weight:600;
  border:2px solid var(--ink);padding:11px 14px;box-shadow:2px 2px 0 var(--ink);transition:.1s;text-decoration:none}
.related a:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink);background:var(--yellow)}
.related a .ar{color:var(--accent);font-weight:700}

/* updated note */
.updated{font-size:.82rem;color:var(--muted);border-top:2px dashed var(--ink);padding-top:14px;margin-top:26px}

/* sidebar TOC (desktop) */
.aside-toc{position:sticky;top:84px;border:var(--bw) solid var(--ink);background:#fff;box-shadow:var(--sh-1)}
.aside-toc h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--ink);margin:0;padding:11px 16px}
.aside-toc ol{list-style:none;margin:0;padding:12px 16px;counter-reset:a}
.aside-toc li{counter-increment:a;margin-bottom:8px;padding-left:24px;position:relative;line-height:1.35}
.aside-toc li::before{content:counter(a,decimal-leading-zero);position:absolute;left:0;top:.1em;font-family:"Space Grotesk",monospace;font-size:.72rem;font-weight:700;color:var(--accent)}
.aside-toc a{color:var(--text);font-size:.84rem;font-weight:500}
.aside-toc a:hover{color:var(--accent-ink)}

@media (max-width:980px){
  .read__grid{grid-template-columns:1fr}
  .aside-toc{display:none}
}
@media (max-width:380px){
  .post ul>li,.post ol>li{padding-left:24px}
}
