:root{
  /* Designer reps — dark luxury palette (区别于上个站的蓝调) */
  --bg:#0c0c0e; --bg-soft:#141417; --panel:#17171b; --panel2:#1e1e23;
  --ink:#f4f1ea; --ink-soft:#b8b4ab; --ink-dim:#827e75;
  --line:#2a2a31; --line-soft:#222228;
  --accent:#c8a24a; --accent-soft:#a6863c; --gold:#d4af37;
  --wa:#25d366; --wa-dark:#1da851;
  --ok:#5ec27a; --warn:#d9a441; --bad:#d96a5e;
  --radius:14px; --radius-sm:9px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font:16px/1.65 "Inter",-apple-system,"Segoe UI",Roboto,sans-serif;
  -webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:"Space Grotesk",sans-serif;font-weight:600;line-height:1.15;color:var(--ink);letter-spacing:-.01em}
h1{font-size:clamp(28px,4.5vw,52px);line-height:1.05;margin:.2em 0 .35em}
h2{font-size:clamp(22px,2.8vw,32px);margin:1.6em 0 .5em}
h3{font-size:19px;margin:1.3em 0 .4em}
p{margin:0 0 1em}
.lede{font-size:clamp(17px,1.9vw,21px);color:var(--ink-soft);line-height:1.5;max-width:62ch}

/* Header */
.site-head{position:sticky;top:0;z-index:50;background:rgba(12,12,14,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Space Grotesk";font-weight:700;
  font-size:18px;color:var(--ink);letter-spacing:.01em}
.brand:hover{color:var(--ink)}
.brand .mark{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,var(--gold),var(--accent-soft));color:#1a1206;
  font-weight:700;font-size:14px;letter-spacing:-.02em}
.nav{display:flex;align-items:center;gap:7px}
.nav a{color:var(--ink-soft);font-size:14.5px;font-weight:500;padding:7px 11px;border-radius:8px}
.nav a:hover{color:var(--ink);background:var(--panel2)}
.nav-cta{background:var(--wa)!important;color:#04210f!important;font-weight:600!important}
.nav-cta:hover{background:var(--wa-dark)!important;color:#04210f!important}
.menu-btn{display:none;background:var(--panel2);border:1px solid var(--line);color:var(--ink);
  font-size:22px;width:42px;height:42px;border-radius:9px;cursor:pointer}

/* Hero */
.hero{padding:54px 0 30px;position:relative;display:grid;grid-template-columns:1.5fr .9fr;gap:44px;align-items:center}
.hero-text{min-width:0}
.hero .eyebrow{display:inline-block;font-family:"Space Mono",monospace;font-size:12.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent);
  border:1px solid var(--line);padding:5px 13px;border-radius:30px;margin-bottom:18px}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;
  padding:13px 22px;border-radius:11px;border:1px solid transparent;cursor:pointer;transition:.15s}
.btn-wa{background:var(--wa);color:#04210f}
.btn-wa:hover{background:var(--wa-dark);color:#04210f;transform:translateY(-1px)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--gold)}
.btn .ic{flex-shrink:0}

/* Content */
main{min-height:50vh}
.content{max-width:940px;margin:0 auto}
.content p,.content li{color:var(--ink-soft)}
.content strong{color:var(--ink);font-weight:600}
.content ul,.content ol{margin:0 0 1.2em;padding-left:1.3em}
.content li{margin:.4em 0}
.crumb{font-size:13.5px;color:var(--ink-dim);padding:16px 0 0}
.crumb a{color:var(--ink-soft)}

/* Quick verdict box (GEO) */
.verdict{background:linear-gradient(135deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-left:3px solid var(--gold);
  border-radius:var(--radius-sm);padding:18px 22px;margin:8px 0 26px}
.verdict .tl{font-family:"Space Mono";font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);margin-bottom:7px}
.verdict p{margin:0;color:var(--ink);font-size:16.5px;line-height:1.55}

/* Product grid */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin:24px 0}
.pcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:.15s;display:flex;flex-direction:column}
.pcard:hover{border-color:var(--accent-soft);transform:translateY(-3px)}
.pcard-img{width:100%;aspect-ratio:1;object-fit:cover;background:var(--panel2);cursor:zoom-in;display:block;border:0;padding:0}
.pcard-b{padding:12px 13px 13px}
.pcard-n{font-size:13.5px;font-weight:500;color:var(--ink);line-height:1.35;margin:0 0 7px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.7em}
.pcard-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}
.pcard-price{font-family:"Space Mono";font-weight:700;color:var(--gold);font-size:15px}
.pcard-count{font-size:11px;color:var(--ink-dim);background:var(--panel2);padding:2px 7px;border-radius:20px}
.pcard-wa{display:block;text-align:center;background:var(--bg-soft);border-top:1px solid var(--line);
  color:var(--wa);font-size:12.5px;font-weight:600;padding:9px;margin-top:auto}
.pcard-wa:hover{background:var(--wa);color:#04210f}

/* Dialog gallery (native, zero-JS) */
.pdlg{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);
  color:var(--ink);max-width:880px;width:92vw;padding:0}
.pdlg::backdrop{background:rgba(0,0,0,.78)}
.pdlg-head{position:sticky;top:0;background:var(--panel);border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;padding:14px 18px;z-index:2}
.pdlg-title{font-size:16px;margin:0;font-weight:600}
.pdlg-x{background:var(--panel2);border:1px solid var(--line);color:var(--ink);width:34px;height:34px;
  border-radius:8px;font-size:18px;cursor:pointer;line-height:1}
.pdlg-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:16px}
.pdlg-imgs img{width:100%;border-radius:8px;background:var(--panel2);display:block}
.pdlg-foot{padding:0 18px 18px;text-align:center}

/* Category nav cards */
.catnav{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:13px;margin:22px 0}
.catnav a{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:16px;color:var(--ink);font-weight:600;font-size:15px;transition:.15s;display:block}
.catnav a:hover{border-color:var(--accent);color:var(--gold);transform:translateY(-2px)}
.catnav a span{display:block;font-size:12.5px;color:var(--ink-dim);font-weight:400;margin-top:4px}

/* Tables */
.ptable{width:100%;border-collapse:collapse;margin:18px 0;font-size:14.5px}
.ptable caption{text-align:left;color:var(--ink-dim);font-size:13px;margin-bottom:8px}
.ptable th,.ptable td{padding:11px 13px;text-align:left;border-bottom:1px solid var(--line)}
.ptable th{font-family:"Space Grotesk";font-weight:600;color:var(--ink);background:var(--panel)}
.ptable td{color:var(--ink-soft)}
.ptable tr:hover td{background:var(--panel)}

/* Trust / steps / price compare */
.pricebox{display:flex;flex-wrap:wrap;gap:16px;margin:24px 0}
.pricecard{flex:1;min-width:200px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:20px}
.pricecard .retail{color:var(--ink-dim);text-decoration:line-through;font-size:15px}
.pricecard .ours{font-family:"Space Mono";font-size:30px;font-weight:700;color:var(--gold);margin:4px 0}
.pricecard .save{display:inline-block;background:rgba(94,194,122,.14);color:var(--ok);
  font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:22px 0}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px}
.step-n{font-family:"Space Mono";font-size:13px;color:var(--accent);font-weight:700;margin-bottom:8px}
.step h4{margin:0 0 6px;font-size:15.5px}
.step p{margin:0;font-size:13.5px;color:var(--ink-soft)}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--panel),var(--panel2));border:1px solid var(--line);
  border-radius:var(--radius);padding:30px;margin:34px 0;text-align:center}
.cta-band h3{margin:0 0 8px;font-size:23px}
.cta-band p{margin:0 0 18px;color:var(--ink-soft);max-width:52ch;margin-inline:auto}

/* FAQ */
.faq{margin:20px 0}
.faq details{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:10px;
  background:var(--panel);overflow:hidden}
.faq summary{padding:15px 18px;font-weight:600;cursor:pointer;font-size:15.5px;color:var(--ink);
  list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:20px}
.faq details[open] summary::after{content:"−"}
.faq details p{padding:0 18px 16px;margin:0;color:var(--ink-soft);font-size:14.5px}

/* Related */
.related{display:flex;flex-wrap:wrap;gap:9px;margin:14px 0}
.related a{background:var(--panel);border:1px solid var(--line);border-radius:30px;
  padding:8px 15px;font-size:13.5px;color:var(--ink-soft)}
.related a:hover{border-color:var(--accent);color:var(--gold)}

/* EEAT */
.eeat{display:flex;gap:14px;align-items:flex-start;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;margin:26px 0;font-size:13.5px;color:var(--ink-dim)}
.eeat .av{width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold),var(--accent-soft));color:#1a1206;
  display:grid;place-items:center;font-weight:700;font-family:"Space Grotesk"}
.eeat b{color:var(--ink-soft)}

/* Footer */
.site-foot{border-top:1px solid var(--line);margin-top:50px;padding:38px 0 30px;background:var(--bg-soft)}
.site-foot .wrap{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:30px}
.fbrand{font-family:"Space Grotesk";font-weight:700;font-size:17px;margin-bottom:8px}
.site-foot p{font-size:13.5px;color:var(--ink-dim);line-height:1.6}
.site-foot h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin:0 0 12px}
.site-foot a{display:block;color:var(--ink-dim);font-size:13.5px;padding:3px 0}
.site-foot a:hover{color:var(--gold)}
.disc{grid-column:1/-1;border-top:1px solid var(--line);padding-top:18px;margin-top:8px;
  font-size:12px;color:var(--ink-dim);line-height:1.6}
.disc a{display:inline;color:var(--ink-soft)}

/* Sticky mobile CTA */
.sticky-wa{display:none}

@media(max-width:860px){
  .hero{grid-template-columns:1fr;gap:20px}
  .hero-video{max-width:100%;order:2}
  .proof-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:680px){
  .proof-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .menu-btn{display:block}
  .nav{position:absolute;top:64px;left:0;right:0;flex-direction:column;align-items:stretch;
    background:var(--panel);border-bottom:1px solid var(--line);padding:10px;gap:4px;display:none}
  .nav.open{display:flex}
  .site-foot .wrap{grid-template-columns:1fr 1fr}
  .pdlg-imgs{grid-template-columns:repeat(2,1fr)}
  .sticky-wa{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;
    background:var(--wa);color:#04210f;align-items:center;justify-content:center;gap:8px;
    padding:14px;font-weight:700;border-top:1px solid var(--wa-dark)}
  body{padding-bottom:54px}
}

/* ===== Product Finds Table (规则 K 章电子表格式) ===== */
.pf-wrap{margin:22px 0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.pf-table{width:100%;border-collapse:collapse;font-size:14.5px}
.pf-table thead th{background:var(--panel);color:var(--ink-soft);font-family:"Space Grotesk";
  font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.06em;
  text-align:left;padding:12px 16px;border-bottom:1px solid var(--line)}
.pf-row{border-bottom:1px solid var(--line-soft);transition:.12s}
.pf-row:last-child{border-bottom:0}
.pf-row:hover{background:var(--panel)}
.pf-row td{padding:13px 16px;vertical-align:middle}
.pf-name{font-weight:500;color:var(--ink);max-width:340px}
.pf-name span{color:var(--ink)}
.pf-badge{display:inline-block;background:rgba(200,162,74,.16);color:var(--gold);
  font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 7px;border-radius:4px;
  vertical-align:middle;margin-right:4px}
.pf-price{font-family:"Space Mono";font-weight:700;color:var(--gold);white-space:nowrap}
.pf-photo{width:168px}
.pf-thumb{width:150px;height:150px;border-radius:10px;border:1px solid var(--line);
  background-size:cover;background-position:center;background-color:var(--panel2);
  cursor:zoom-in;position:relative;padding:0;display:block}
.pf-thumb:hover{border-color:var(--accent)}
.pf-corner{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.72);color:#fff;
  font-size:11px;padding:2px 7px;border-radius:5px;font-family:"Space Mono";font-weight:700}
.pf-why{color:var(--ink-soft);font-size:13.5px;max-width:220px}

@media(max-width:680px){
  .pf-wrap{border:0;overflow:visible}
  .pf-table thead{display:none}
  .pf-table,.pf-table tbody,.pf-row,.pf-row td{display:block}
  .pf-row{position:relative;border:1px solid var(--line);border-radius:var(--radius-sm);
    margin-bottom:10px;padding:14px;padding-right:84px}
  .pf-row td{padding:2px 0;border:0}
  .pf-name{max-width:none;font-size:15px}
  .pf-photo{position:absolute;top:14px;right:14px;width:84px}
  .pf-thumb{width:84px;height:84px}
  .pf-price{font-size:15px}
  .pf-why{max-width:none;font-size:13px;color:var(--ink-dim)}
  .pf-why::before{content:"✓ ";color:var(--ok)}
}

/* ===== Hero video ===== */
.hero-video{margin:0;max-width:300px;justify-self:center}
.hero-video video{width:100%;border-radius:var(--radius);border:1px solid var(--line);
  background:var(--panel2);display:block;aspect-ratio:9/16;object-fit:cover}
.hero-video-cap{font-size:13px;color:var(--ink-dim);margin:8px 2px 0}

/* ===== Proof grid (real transactions) ===== */
.proof-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:20px 0}
.proof-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;margin:0;display:flex;flex-direction:column}
.proof-card img{width:100%;height:200px;object-fit:cover;object-position:top;display:block;border-bottom:1px solid var(--line);background:var(--panel2)}
.proof-card figcaption{padding:11px 13px;font-size:12.5px;color:var(--ink-soft);line-height:1.45;flex:1}

@media(max-width:680px){
  .hero-video{margin:0;max-width:300px;justify-self:center}
  .hero-video video{aspect-ratio:auto;max-height:60vh}
  .proof-grid{grid-template-columns:repeat(2,1fr)}
}


/* ===== Viz library ===== */
.viz-block{margin:24px 0}
/* ============================================================
   viz_library.css — 41种可视化组件样式
   配合 viz_library.py。依赖站点CSS变量:
   --accent --accent-ink --gold --wa --ink --ink-soft --line --bg --card --radius --font-display --font-mono
   ============================================================ */

.viz{margin:24px 0;padding:22px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow,0 1px 3px rgba(0,0,0,.06))}
.viz-cap{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--ink);margin-bottom:16px;padding:0}
.viz-foot{font-size:.82rem;color:var(--ink-soft);margin:14px 0 0;line-height:1.5}
.viz-center{display:flex;justify-content:center;align-items:center}
.vz-dot{width:13px;height:13px;border-radius:4px;flex:none;display:inline-block}
.vz-key{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-wrap:wrap;gap:8px 18px}
.vz-key li{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--ink-soft)}
.vz-key b{color:var(--ink);font-family:var(--font-mono)}

/* shared bar primitives (001,002,012,064) */
.vz-hbar{display:flex;flex-direction:column;gap:11px}
.vz-r{display:flex;align-items:center;gap:12px}
.vz-l{flex:0 0 120px;font-size:.88rem;color:var(--ink)}
.vz-t{flex:1;height:14px;background:var(--bg);border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.vz-f{height:100%;background:#b9cce6;border-radius:6px;transition:width .4s}
.vz-f.hl{background:var(--accent)}
.vz-f.grad{background:linear-gradient(90deg,var(--accent),#5a9bf0)}
.vz-v{flex:0 0 46px;text-align:right;font-family:var(--font-mono);font-weight:700;font-size:.85rem;color:var(--accent-ink)}

/* 003 radar / svg centering handled by .vz-center */

/* 004 score ring */
.vz-ring{width:130px;height:130px;border-radius:50%;position:relative}
.vz-ring-c{position:absolute;inset:18px;background:var(--card);border-radius:50%;display:grid;place-items:center;text-align:center}
.vz-ring-c b{font-family:var(--font-display);font-size:1.8rem;color:var(--accent-ink);line-height:1}
.vz-ring-c span{font-size:.72rem;color:var(--ink-soft)}

/* 005 stars */
.vz-stars-wrap{display:flex;flex-direction:column;gap:9px}
.vz-star-r{display:flex;align-items:center;gap:12px}
.vz-stars{color:var(--gold);letter-spacing:2px;font-size:1.05rem}
.vz-star-r .vz-l{flex:0 0 140px}

/* 006 heatmap */
.vz-heat{border-collapse:collapse;width:100%;font-size:.85rem}
.vz-heat th{padding:7px 10px;text-align:left;font-family:var(--font-display);font-weight:600;color:var(--ink-soft);font-size:.8rem}
.vz-heat td{padding:9px 12px;text-align:center;font-family:var(--font-mono);font-weight:700;border:2px solid var(--card)}

/* 007 dual cards */
.vz-dual{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.vz-dc{border:1px solid var(--line);border-radius:10px;padding:14px}
.vz-dc.a{border-top:3px solid var(--accent)}
.vz-dc.b{border-top:3px solid var(--gold)}
.vz-dc-h{font-family:var(--font-display);font-weight:700;margin-bottom:8px;color:var(--ink)}
.vz-dc ul{margin:0;padding-left:18px;font-size:.88rem;color:var(--ink-soft)}
.vz-dc li{margin:4px 0}

/* 008 rank badges */
.vz-ranks{display:flex;flex-direction:column;gap:9px}
.vz-rank{display:flex;align-items:center;gap:13px;padding:10px 14px;background:var(--bg);border:1px solid var(--line);border-radius:9px}
.vz-medal{font-size:1.3rem;flex:none;min-width:30px;text-align:center;font-family:var(--font-mono);font-weight:700;color:var(--accent-ink)}
.vz-rank b{display:block;color:var(--ink);font-size:.95rem}
.vz-rank span{font-size:.82rem;color:var(--ink-soft)}

/* 009 progress cluster */
.vz-cluster{display:flex;gap:14px;align-items:flex-end;justify-content:space-around;flex-wrap:wrap}
.vz-pc{display:flex;flex-direction:column;align-items:center;gap:5px}
.vz-pc-bar{width:34px;height:90px;background:var(--bg);border:1px solid var(--line);border-radius:6px;display:flex;align-items:flex-end;overflow:hidden}
.vz-pc-fill{width:100%;background:linear-gradient(0deg,var(--accent),#5a9bf0);border-radius:5px}
.vz-pc-l{font-size:.78rem;color:var(--ink-soft)}
.vz-pc-v{font-family:var(--font-mono);font-weight:700;font-size:.8rem;color:var(--accent-ink)}

/* 010 slide compare */
.vz-slide-bar{display:flex;height:40px;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.vz-slide-l{background:var(--accent);color:#fff;display:flex;align-items:center;padding:0 12px;font-size:.85rem;font-weight:600}
.vz-slide-r{background:var(--gold);color:#fff;display:flex;align-items:center;padding:0 12px;font-size:.85rem;font-weight:600;flex:1;justify-content:flex-end}

/* 011 vbar */
.vz-vbars{display:flex;gap:14px;align-items:flex-end;justify-content:space-around;height:160px;flex-wrap:wrap}
.vz-vb{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;height:100%;justify-content:flex-end;min-width:40px}
.vz-vb-track{width:38px;flex:1;display:flex;align-items:flex-end}
.vz-vb-fill{width:100%;background:var(--accent);border-radius:6px 6px 0 0;min-height:3px}
.vz-vb-v{font-family:var(--font-mono);font-weight:700;font-size:.78rem;color:var(--accent-ink)}
.vz-vb-l{font-size:.76rem;color:var(--ink-soft);text-align:center}

/* 013 grouped */
.vz-grouped{display:flex;gap:18px;align-items:flex-end;justify-content:space-around;height:170px}
.vz-gb-col{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;height:100%;justify-content:flex-end}
.vz-gb-bars{display:flex;gap:3px;align-items:flex-end;flex:1;width:100%;justify-content:center}
.vz-gb-bar{width:16px;border-radius:4px 4px 0 0;min-height:3px}
.vz-gb-l{font-size:.78rem;color:var(--ink-soft)}

/* 014 stacked / 083 risk segs */
.vz-stack{display:flex;height:30px;border-radius:7px;overflow:hidden;border:1px solid var(--line)}
.vz-seg{height:100%}

/* 019 bubble */
.vz-bubbles{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:center;padding:10px}
.vz-bubble{border-radius:50%;display:grid;place-items:center;color:#fff;text-align:center}
.vz-bubble span{font-size:.72rem;font-weight:600;padding:4px}

/* 020 waterfall */
.vz-waterfall{display:flex;gap:10px;align-items:flex-end;height:160px;justify-content:space-around}
.vz-wf{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;height:100%}
.vz-wf-track{position:relative;width:100%;flex:1;display:flex;justify-content:center}
.vz-wf-bar{position:absolute;width:60%;border-radius:3px}
.vz-wf-l{font-size:.74rem;color:var(--ink-soft);text-align:center}

/* 021 pie / 022 donut / 024 sunburst */
.vz-pie-wrap{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.vz-pie{width:130px;height:130px;border-radius:50%;flex:none}
.vz-donut{width:130px;height:130px;border-radius:50%;flex:none;position:relative}
.vz-donut-h{position:absolute;inset:32px;background:var(--card);border-radius:50%}
.vz-sun{width:140px;height:140px;border-radius:50%;flex:none;position:relative}
.vz-sun-mid{position:absolute;inset:24px;border-radius:50%;background:var(--card);opacity:.35}
.vz-sun-h{position:absolute;inset:46px;border-radius:50%;background:var(--card)}

/* 023 gauge */
.vz-gauge-wrap{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.vz-gauge{width:120px;height:120px;border-radius:50%;flex:none;position:relative}
.vz-gauge-c{position:absolute;inset:16px;background:var(--card);border-radius:50%;display:grid;place-items:center;text-align:center}
.vz-gauge-c b{font-family:var(--font-display);font-size:1.4rem;color:var(--accent-ink);line-height:1}
.vz-gauge-c span{font-size:.7rem;color:var(--ink-soft)}
.vz-gauge-side{flex:1;min-width:160px;font-size:.9rem;color:var(--ink-soft)}

/* 025 treemap */
.vz-treemap{display:flex;gap:4px;height:130px;border-radius:8px;overflow:hidden}
.vz-tm{display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;text-align:center;padding:6px;min-width:0}
.vz-tm b{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.vz-tm span{font-family:var(--font-mono);font-size:.78rem;opacity:.9}

/* 026 mosaic */
.vz-mosaic{display:flex;gap:4px;height:140px}
.vz-mos-col{display:flex;flex-direction:column;gap:4px}
.vz-mos-stack{flex:1;display:flex;flex-direction:column;border-radius:5px;overflow:hidden}
.vz-mos-col span{font-size:.74rem;color:var(--ink-soft);text-align:center}

/* 027 htimeline */
.vz-htl{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px}
.vz-htl-item{flex:1;min-width:90px;display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center;position:relative}
.vz-htl-dot{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-family:var(--font-mono);font-weight:700;font-size:.8rem}
.vz-htl-item b{font-size:.85rem;color:var(--ink)}
.vz-htl-sub{font-size:.74rem;color:var(--ink-soft)}

/* 028 vtimeline */
.vz-vtl{list-style:none;padding:0;margin:0;position:relative}
.vz-vtl:before{content:"";position:absolute;left:13px;top:6px;bottom:6px;width:2px;background:var(--line)}
.vz-vtl-item{display:flex;gap:14px;align-items:flex-start;padding:7px 0;position:relative}
.vz-vtl-dot{flex:0 0 28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-family:var(--font-mono);font-weight:700;font-size:.8rem;z-index:1}
.vz-vtl-item b{display:block;color:var(--ink);font-size:.92rem}
.vz-vtl-sub{font-size:.8rem;color:var(--ink-soft)}

/* 029 stepflow */
.vz-stepflow{display:flex;align-items:stretch;gap:6px;flex-wrap:wrap}
.vz-sf-step{flex:1;min-width:120px;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:12px;text-align:center}
.vz-sf-n{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:6px;background:var(--accent);color:#fff;font-family:var(--font-mono);font-weight:700;font-size:.78rem;margin-bottom:6px}
.vz-sf-step b{display:block;font-size:.9rem;color:var(--ink);margin-bottom:3px}
.vz-sf-step span{font-size:.8rem;color:var(--ink-soft)}
.vz-sf-arrow{display:flex;align-items:center;color:var(--accent);font-size:1.2rem;font-weight:700}

/* 031 funnel */
.vz-funnel{display:flex;flex-direction:column;gap:6px;align-items:center}
.vz-fun-row{width:100%;display:flex;justify-content:center}
.vz-fun-bar{background:linear-gradient(90deg,var(--accent),#5a9bf0);color:#fff;text-align:center;padding:9px;border-radius:5px;font-size:.85rem;font-weight:600}

/* 032 pyramid */
.vz-pyramid{display:flex;flex-direction:column;gap:5px;align-items:center}
.vz-pyr-row{width:100%;display:flex;justify-content:center}
.vz-pyr-bar{color:#fff;text-align:center;padding:9px;border-radius:5px;font-size:.85rem;font-weight:600}

/* 060 qc checklist */
.vz-qclist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.vz-qc-item{display:flex;align-items:center;gap:11px;font-size:.9rem;color:var(--ink)}
.vz-qc-box{width:22px;height:22px;border-radius:6px;border:2px solid var(--line);display:grid;place-items:center;color:#fff;font-size:.8rem;flex:none}
.vz-qc-box.on{background:var(--wa);border-color:var(--wa)}

/* 063 size chart / 071 feature matrix */
.vz-size{border-collapse:collapse;width:100%;font-size:.86rem}
.vz-size th,.vz-size td{padding:8px 12px;border:1px solid var(--line);text-align:center}
.vz-size thead th{background:var(--bg);font-family:var(--font-display);color:var(--ink-soft)}
.vz-size tbody th{background:var(--bg);font-weight:700}

/* 064 batch */
.vz-batches{display:flex;flex-direction:column;gap:14px}
.vz-batch-h{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}
.vz-batch-sc{font-family:var(--font-mono);font-weight:700;color:var(--accent-ink)}
.vz-batch-note{font-size:.8rem;color:var(--ink-soft);margin-top:3px;display:block}

/* 067 number cards */
.vz-numcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.vz-numcard{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:16px;text-align:center}
.vz-numcard b{display:block;font-family:var(--font-display);font-size:1.7rem;color:var(--accent-ink);line-height:1}
.vz-numcard span{font-size:.8rem;color:var(--ink-soft)}

/* 070 compare cards */
.vz-comparecards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.vz-cc{border:1px solid var(--line);border-radius:10px;overflow:hidden}
.vz-cc-h{background:var(--bg);padding:10px 14px;font-family:var(--font-display);font-weight:700;color:var(--ink)}
.vz-cc-row{display:flex;justify-content:space-between;padding:8px 14px;border-top:1px solid var(--line);font-size:.86rem}
.vz-cc-row span{color:var(--ink-soft)}
.vz-cc-row b{color:var(--ink);font-family:var(--font-mono)}

/* 073 price tier */
.vz-tiers{display:flex;flex-direction:column;gap:9px}
.vz-tier{background:var(--bg);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:8px;padding:12px 15px}
.vz-tier-h{display:flex;justify-content:space-between;align-items:baseline}
.vz-tier-p{font-family:var(--font-mono);font-weight:700;color:var(--accent-ink)}
.vz-tier-note{font-size:.8rem;color:var(--ink-soft)}

/* 077 pros cons */
.vz-pc-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.vz-pros,.vz-cons{border:1px solid var(--line);border-radius:10px;padding:14px}
.vz-pros{background:#f0fbf4}.vz-cons{background:#fdf2f6}
.vz-pc-h{font-family:var(--font-display);font-weight:700;margin-bottom:8px;font-size:.92rem}
.vz-pros ul,.vz-cons ul{margin:0;padding-left:18px;font-size:.86rem;color:var(--ink-soft)}
.vz-pros li,.vz-cons li{margin:4px 0}

/* 080 thermometer */
.vz-thermo-wrap{display:flex;gap:22px;align-items:center}
.vz-thermo{width:34px;height:130px;background:var(--bg);border:1px solid var(--line);border-radius:17px;position:relative;display:flex;align-items:flex-end}
.vz-thermo-fill{width:100%;background:linear-gradient(0deg,var(--wa),var(--gold));border-radius:17px;transition:height .4s}
.vz-thermo-bulb{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:30px;height:30px;border-radius:50%;background:var(--wa)}
.vz-thermo-side b{display:block;font-family:var(--font-display);font-size:1.6rem;color:var(--accent-ink)}
.vz-thermo-side span{font-size:.82rem;color:var(--ink-soft)}

/* 083 risk bar */
.vz-risk{display:flex;gap:5px}
.vz-risk-seg{flex:1;height:16px;border-radius:4px;background:var(--line)}
.vz-risk-lbl{margin-top:8px;font-size:.85rem;font-weight:600;color:var(--ink)}

/* 085 verdict banner */
.vz-verdict-b{background:linear-gradient(180deg,#10243e,#173255);color:#dce8f6;border-radius:10px;padding:18px 20px}
.vz-vb-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#6ea8f0;font-weight:700;margin-bottom:6px}
.vz-vb-main{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:#fff;margin-bottom:4px}
.vz-verdict-b p{margin:0;color:#b9cde4;font-size:.88rem}

@media(max-width:560px){
  .vz-dual,.vz-pc-grid,.vz-comparecards{grid-template-columns:1fr}
  .vz-l{flex-basis:90px;font-size:.8rem}
  .vz-star-r .vz-l,.vz-key li{font-size:.8rem}
}

/* ===== Interactive tool box ===== */
.tool-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin:20px 0}
.tool-row{display:flex;gap:16px;align-items:end;flex-wrap:wrap}
.tool-row label{font-size:13px;color:var(--ink-soft)}
.tool-row input{margin-top:5px;background:var(--panel2);color:var(--ink);border:1px solid var(--line);
  border-radius:8px;padding:10px 12px;width:130px;font-size:15px}
.tool-out{display:flex;gap:14px;margin-top:18px;flex-wrap:wrap}
.tool-result{flex:1;min-width:120px;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:16px;text-align:center}
.tool-result b{display:block;font-family:"Space Mono";font-size:26px;color:var(--gold);font-weight:700}
.tool-result span{font-size:12.5px;color:var(--ink-dim)}

/* ===== Catalog page ===== */
.cat-filters{display:flex;flex-direction:column;gap:12px;margin:20px 0;padding:18px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius)}
.cat-fgroup{display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.cat-flabel{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-dim);
  font-family:"Space Grotesk";font-weight:600;width:54px;flex-shrink:0}
.cat-filter{background:var(--panel2);border:1px solid var(--line);color:var(--ink-soft);
  font-size:13px;padding:6px 13px;border-radius:30px;cursor:pointer;transition:.12s}
.cat-filter:hover{border-color:var(--accent);color:var(--ink)}
.cat-filter.on{background:var(--gold);color:#1a1206;border-color:var(--gold);font-weight:600}
.cat-meta{font-size:13.5px;color:var(--ink-dim);margin:14px 0}
.cat-meta span{color:var(--gold);font-weight:700}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;margin:18px 0}
.cat-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.12s}
.cat-card:hover{border-color:var(--accent-soft);transform:translateY(-2px)}
.cat-thumb{width:100%;aspect-ratio:1;background-size:cover;background-position:center;
  background-color:var(--panel2);border:0;cursor:zoom-in;position:relative;display:block;padding:0}
.cat-corner{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.72);color:#fff;
  font-size:11px;padding:2px 7px;border-radius:5px;font-family:"Space Mono";font-weight:700}
.cat-info{padding:13px 15px}
.cat-name{font-size:14px;color:var(--ink);line-height:1.35;margin-bottom:6px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}
.cat-price{font-family:"Space Mono";font-weight:700;color:var(--gold);font-size:15px}
@media(max-width:680px){.cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}.cat-flabel{width:100%}}

/* ===== Total cost calculator ===== */
.calc-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin:20px 0}
.calc-slider-row{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.calc-lbl{font-size:14px;color:var(--ink-soft);white-space:nowrap}
.calc-slider-row input[type=range]{flex:1;min-width:160px;accent-color:var(--gold);height:6px}
.calc-val{font-family:"Space Mono";font-size:26px;font-weight:700;color:var(--gold);min-width:80px;text-align:right}
.calc-rows{display:flex;flex-direction:column;gap:10px}
.calc-row{display:flex;justify-content:space-between;align-items:center;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 18px}
.calc-row.calc-best{border-color:var(--gold);background:linear-gradient(135deg,rgba(200,162,74,.08),var(--bg-soft))}
.calc-mname{font-weight:600;color:var(--ink);font-size:15px}
.calc-mnote{display:block;font-size:12px;color:var(--ink-dim);font-weight:400;margin-top:2px}
.calc-star{color:var(--gold);font-size:11px;font-weight:700;margin-left:6px}
.calc-mtotal{font-family:"Space Mono";font-weight:700;font-size:19px;color:var(--gold)}
.calc-note{font-size:12.5px;color:var(--ink-dim);margin:16px 0 0;line-height:1.5}
.calc-cta{margin-top:16px;width:100%;justify-content:center}
