/* ═══════════════════════════════════════════════════════
   EARTH.ONLINE — Shared Stylesheet
   v2026.5.4 / rust palette
   ═══════════════════════════════════════════════════════ */

/* ── tokens ─────────────────────────────────────────── */
:root{
  --bg-0:#08080a;
  --bg-1:#0d0d10;
  --bg-2:#13131a;
  --bg-3:#1c1c25;
  --bg-4:#23232c;
  --line:rgba(232,230,225,.07);
  --line-2:rgba(232,230,225,.14);
  --line-3:rgba(232,230,225,.28);

  --ink-0:#e8e6e1;
  --ink-1:#a8a39a;
  --ink-2:#6c6760;
  --ink-3:#3e3a35;

  /* rust palette (legacy) */
  --rust:#9b3a2b;
  --rust-2:#b54836;
  --rust-3:#c95a44;
  --rust-deep:#7a2a1f;
  --rust-soft:rgba(155,58,43,.14);
  --rust-edge:rgba(155,58,43,.4);

  /* constructivist / accel palette */
  --rev:#e23725;          /* propaganda red — wedge / number / 标记 */
  --rev-2:#c12a1a;
  --rev-deep:#7a1a10;
  --rev-soft:rgba(226,55,37,.14);
  --bone:#ece7da;         /* 米白 / 海报底色 */
  --bone-2:#d8d2c2;
  --mustard:#e0b833;      /* 构成主义芥黄 / 标号点 */
  --ink-rev:#0a0807;       /* 更深的近黑 */

  --amber:#c5832d;
  --amber-soft:rgba(197,131,45,.14);
  --green:#5a9b6a;
  --green-soft:rgba(90,155,106,.14);
  --blue:#4f6b8a;

  --mono:'JetBrains Mono','IBM Plex Mono','Cascadia Code',Consolas,Menlo,monospace;
  --sans:'Space Grotesk','Inter','Noto Sans SC',system-ui,sans-serif;
  --cn:'Noto Sans SC','PingFang SC','Microsoft YaHei',system-ui,sans-serif;
  --cn-serif:'Noto Serif SC','Songti SC',serif;

  --pad-x: clamp(20px, 4vw, 56px);
  --maxw: 1480px;

  /* 主题色（meta theme-color 用） */
  --theme-bg: #08080a;
  --grid-line: rgba(232,230,225,.022);
  --chrome-bg: #000;
  --nav-bg: rgba(8,8,10,.78);
  --hover-fill: rgba(232,230,225,.04);
}

/* ── reset ──────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;color-scheme:dark}
html,body{
  background:var(--bg-0);color:var(--ink-0);
  font-family:var(--sans);font-size:15px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
body{overflow-x:hidden;font-feature-settings:"ss01","ss02","cv11";min-height:100vh}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
img,svg{display:block;max-width:100%}
::selection{background:var(--rust);color:#fff}

.save-mask,
.intercept-mask{
  --ink-0:#e8e6e1;
  --ink-1:#a8a39a;
  --ink-2:#6c6760;
  --ink-3:#3e3a35;
  --line:rgba(232,230,225,.07);
  --line-2:rgba(232,230,225,.14);
  --line-3:rgba(232,230,225,.28);
}

.cn{font-family:var(--cn)}
.mono{font-family:var(--mono);font-weight:400;letter-spacing:.02em}
.up{text-transform:uppercase;letter-spacing:.18em}
.muted{color:var(--ink-1)}
.faint{color:var(--ink-2)}
.dim{color:var(--ink-3)}
.tabnum{font-variant-numeric:tabular-nums}

/* ── 全站底纹 ───────────────────────────────────────── */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    linear-gradient(to right, var(--grid-line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--grid-line) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:2;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ── 顶部状态条 ─────────────────────────────────────── */
.strip{
  position:sticky;top:0;z-index:60;
  background:var(--chrome-bg);border-bottom:1px solid var(--line);
  height:30px;
  display:flex;align-items:center;
  padding:0 var(--pad-x);
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-1);
  white-space:nowrap;overflow:hidden;
}
.strip > * + *{margin-left:24px}
.strip .sep{color:var(--ink-3)}
.strip .ver{color:var(--ink-0)}
.strip .num{color:var(--ink-0);font-variant-numeric:tabular-nums}
.strip .dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--green);box-shadow:0 0 0 0 rgba(90,155,106,.5);
  animation:pulse 2.4s ease-in-out infinite;
  vertical-align:middle;margin-right:6px;transform:translateY(-1px);
}
.strip .dot.warn{background:var(--amber);animation-name:pulseAmber}
.strip .dot.err{background:var(--rust);animation-name:pulseRust}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(90,155,106,.55)}50%{box-shadow:0 0 0 6px rgba(90,155,106,0)}}
@keyframes pulseAmber{0%,100%{box-shadow:0 0 0 0 rgba(197,131,45,.55)}50%{box-shadow:0 0 0 6px rgba(197,131,45,0)}}
@keyframes pulseRust{0%,100%{box-shadow:0 0 0 0 rgba(155,58,43,.55)}50%{box-shadow:0 0 0 6px rgba(155,58,43,0)}}
.strip .spacer{flex:1 1 auto;margin-left:24px;border-bottom:1px dashed var(--line);height:1px}
.strip .logout{
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  padding:4px 10px;border:1px solid var(--line);
  letter-spacing:.14em;text-transform:uppercase;cursor:pointer;
  transition:all .25s;
}
.strip .logout:hover{color:var(--ink-0);border-color:var(--line-3);background:var(--hover-fill)}
@media (max-width:760px){
  .strip{font-size:10px}
  .strip > * + *{margin-left:12px}
  .strip .lat,.strip .uptime{display:none}
}

/* ── 顶部导航 ───────────────────────────────────────── */
.nav{
  position:sticky;top:30px;z-index:55;
  background:var(--nav-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--pad-x);max-width:var(--maxw);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:12px;min-width:max-content}
.brand-logo-link{
  width:46px;height:46px;display:grid;place-items:center;flex:0 0 auto;
  transition:transform .2s, filter .2s;
}
.brand-logo-link:hover{transform:translateY(-1px);filter:saturate(1.08)}
.brand-logo{
  width:46px;height:46px;object-fit:contain;
  filter:drop-shadow(0 0 8px rgba(201,90,68,.14));
}
.brand-name{
  font-family: var(--cn-serif);font-weight:600;letter-spacing:.02em;font-size:16px;
  display:inline-flex;align-items:baseline;gap:.18em;
  color:var(--ink-0);
  transition:color .2s;
}
.brand-name:hover{color:var(--rust-3)}
.brand-name .en{
  font-family: var(--sans);font-weight:600;letter-spacing:.04em;font-size:15px;
}
.brand-name .accent{color:var(--rust)}
.nav-links{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px}
.nav-links a{
  position:relative;padding:8px 14px;color:var(--ink-1);
  letter-spacing:.1em;text-transform:uppercase;transition:color .25s;
}
.nav-links a:hover{color:var(--ink-0)}
.nav-links a.active{color:var(--ink-0)}
.nav-links a.active::before,
.nav-links a:hover::before{transform:scaleX(1)}
.nav-links a::before{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1px;
  background:var(--rust);transform:scaleX(0);transform-origin:left;transition:transform .35s;
}
@media (max-width:1180px){
  .nav-links{display:none}
  .nav.nav-open .nav-links{
    display:flex;position:absolute;left:0;right:0;top:100%;
    flex-direction:column;align-items:stretch;gap:0;
    background:rgba(8,8,10,.96);border-bottom:1px solid var(--line);
    padding:8px var(--pad-x) 14px;
  }
  .nav.nav-open .nav-links a{padding:13px 0;border-bottom:1px solid var(--line)}
  .nav.nav-open .nav-links a::before{left:0;right:0;bottom:7px}
}
.nav-burger{
  display:none;width:36px;height:36px;border:1px solid var(--line);
  align-items:center;justify-content:center;cursor:pointer;color:var(--ink-1);
}
@media (max-width:1180px){.nav-burger{display:flex}}

/* ── 通用按钮 ───────────────────────────────────────── */
.btn{
  font-family:var(--mono);font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  padding:16px 26px;border:1px solid var(--ink-0);color:var(--ink-0);
  background:transparent;cursor:pointer;position:relative;overflow:hidden;
  transition:color .25s;display:inline-flex;align-items:center;gap:10px;
}
.btn::before{
  content:"";position:absolute;inset:0;background:var(--ink-0);transform:translateX(-101%);transition:transform .35s ease;z-index:-1;
}
.btn:hover{color:var(--bg-0)}
.btn:hover::before{transform:translateX(0)}
.btn.primary{border-color:var(--rust);color:#fff;background:var(--rust)}
.btn.primary::before{background:var(--ink-0)}
.btn.primary:hover{color:var(--rust)}
.btn.ghost{border-color:var(--line-3);color:var(--ink-1)}
.btn.ghost:hover{color:var(--ink-0);border-color:var(--ink-0)}
.btn.ghost::before{background:var(--ink-0)}
.btn.sm{padding:11px 18px;font-size:11px}
.btn .arr{width:14px;height:1px;background:currentColor;position:relative}
.btn .arr::before,.btn .arr::after{content:"";position:absolute;right:0;width:6px;height:1px;background:currentColor}
.btn .arr::before{top:-2px;transform:rotate(35deg);transform-origin:right}
.btn .arr::after{top:2px;transform:rotate(-35deg);transform-origin:right}

/* ── 区段通用 ───────────────────────────────────────── */
.section{padding: clamp(42px, 5vw, 76px) var(--pad-x);position:relative;border-bottom:1px solid var(--line)}
.section.tight{padding: clamp(30px, 3.2vw, 52px) var(--pad-x)}
.section-inner{max-width:var(--maxw);margin:0 auto;width:100%}
.section-head{
  display:grid;grid-template-columns: 1fr auto;gap:24px;align-items:end;
  margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--line);
}
.section-eyebrow{
  font-family:var(--mono);font-size:11px;color:var(--rust-3);letter-spacing:.24em;text-transform:uppercase;margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.section-eyebrow::before{content:"";width:24px;height:1px;background:var(--rust)}
.section-title{
  font-family:var(--sans);font-weight:600;font-size:clamp(26px,3.3vw,44px);line-height:1.08;letter-spacing:0;
}
.section-title .zh{font-family:var(--cn);font-weight:500}
.section-title .accent{color:var(--rust-3)}
.section-num{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.18em;text-align:right;line-height:1.7;
}
.section-num .v{color:var(--ink-0)}
.section-num .v.g{color:var(--green)}
.section-num .v.r{color:var(--rust-3)}
.section-num .v.a{color:var(--amber)}

.hr-tick{display:flex;align-items:center;gap:8px;color:var(--ink-2);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:24px}
.hr-tick::before{content:"";width:6px;height:6px;background:var(--rust)}
.hr-tick::after{content:"";flex:1;height:1px;background:var(--line)}

/* ── 模态弹窗 ───────────────────────────────────────── */
.modal-mask{
  position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.78);
  display:none;align-items:center;justify-content:center;padding:24px;
  backdrop-filter:blur(6px);
}
.modal-mask.show{display:flex;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{
  width:min(440px, 100%);background:var(--bg-1);border:1px solid var(--line-2);
  position:relative;
}
.modal-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.16em;text-transform:uppercase;
}
.modal-bar .x{cursor:pointer;color:var(--ink-1);transition:color .2s;font-size:16px;line-height:1}
.modal-bar .x:hover{color:var(--rust-3)}
.modal-body{padding:32px 28px}
.modal-body .icon{
  width:48px;height:48px;border:1px solid var(--amber);color:var(--amber);
  display:grid;place-items:center;font-family:var(--mono);font-size:22px;font-weight:500;
  margin-bottom:20px;
}
.modal-body h3{
  font-family:var(--cn);font-weight:500;font-size:20px;color:var(--ink-0);margin-bottom:10px;letter-spacing:0;
}
.modal-body p{font-family:var(--cn);font-size:14px;color:var(--ink-1);line-height:1.8}
.modal-foot{
  padding:14px 20px;border-top:1px solid var(--line);
  display:flex;justify-content:flex-end;gap:10px;
}
.modal-btn{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:10px 18px;color:var(--ink-1);border:1px solid var(--line-2);cursor:pointer;transition:all .2s;
}
.modal-btn:hover{color:var(--ink-0);border-color:var(--ink-0)}
.modal-btn.primary{background:var(--rust);color:#fff;border-color:var(--rust)}
.modal-btn.primary:hover{background:#fff;color:var(--rust);border-color:#fff}

/* ── reveal 动画 ────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ─────────────────────────────────────────────────────
   HOME / Hero
   ───────────────────────────────────────────────────── */
.hero{
  position:relative;
  padding: clamp(56px, 8vw, 100px) var(--pad-x) 0;
  border-bottom:1px solid var(--line);
  overflow:hidden;
  background:
    radial-gradient(ellipse 60% 60% at 80% 50%, rgba(155,58,43,.07), transparent 60%),
    radial-gradient(ellipse 80% 60% at 10% 100%, rgba(91,142,201,.04), transparent 70%),
    linear-gradient(180deg,#08080a 0%,#0a0a0e 60%,#08080a 100%);
}
.hero-inner{max-width:var(--maxw);margin:0 auto;width:100%;position:relative;z-index:2}
.hero-grid{
  display:grid;grid-template-columns: 1.25fr 1fr;gap:clamp(40px, 6vw, 96px);
  align-items:center;
  min-height: clamp(540px, 70vh, 720px);
}
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;min-height:0;gap:48px}
}

.hero-tag{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  text-transform:uppercase;letter-spacing:.22em;
  padding:8px 0;
  border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);
  margin-bottom:36px;
  flex-wrap:wrap;
}
.hero-tag .pip{width:6px;height:6px;background:var(--rust);display:inline-block}
.hero-tag .dim{color:var(--ink-3)}

.hero-title{
  font-family:var(--sans);font-weight:700;
  font-size: clamp(56px, 9.5vw, 168px);
  line-height:.85;letter-spacing:0;
  color:var(--ink-0);
}
.hero-title .accent{color:var(--rust)}
.hero-title .glitch{position:relative;display:inline-block}
.hero-title .glitch::before,
.hero-title .glitch::after{
  content:attr(data-text);position:absolute;left:0;top:0;width:100%;pointer-events:none;
}
.hero-title .glitch::before{color:var(--rust);transform:translate(-2px,0);mix-blend-mode:screen;opacity:0;animation:glitch 7s steps(1,end) infinite}
.hero-title .glitch::after{color:var(--blue);transform:translate(2px,0);mix-blend-mode:screen;opacity:0;animation:glitch 7s steps(1,end) infinite .12s}
@keyframes glitch{
  0%, 92%, 100%{opacity:0;transform:translate(0,0)}
  93%{opacity:.7;transform:translate(-3px,0)}
  94%{opacity:.7;transform:translate(2px,0)}
  95%{opacity:0;transform:translate(0,0)}
}

/* hero 副标 — 切片式 */
.hero-slogan{
  margin-top:36px;display:flex;flex-wrap:wrap;gap:0;
  border-top:1px solid var(--line);
  font-family:var(--sans);
}
.hero-slogan span{
  flex:1 1 auto;padding:18px 22px 18px 0;
  border-right:1px solid var(--line);
  font-size:clamp(13px,1.1vw,16px);
  color:var(--ink-0);letter-spacing:.02em;
  display:flex;align-items:center;gap:10px;
}
.hero-slogan span:last-child{border-right:0}
.hero-slogan .num{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.18em}

.hero-cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-cta .hint{margin-left:8px;font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.12em}

/* hero 仪表盘 */
.hero-dial{
  position:relative;aspect-ratio:1/1;width:100%;max-width:540px;margin:0 auto;
  display:grid;place-items:center;
}
.hero-dial svg{width:100%;height:100%;display:block}
.hero-dial .ring-1{fill:none;stroke:var(--line-2);stroke-width:1}
.hero-dial .ring-2{fill:none;stroke:var(--line);stroke-width:1}
.hero-dial .ring-bold{fill:none;stroke:var(--line-3);stroke-width:1.4}
.hero-dial .tick{stroke:var(--ink-2);stroke-width:1}
.hero-dial .tick-major{stroke:var(--ink-1);stroke-width:1.2}
.hero-dial .lat{fill:none;stroke:var(--line);stroke-width:1}
.hero-dial .meridian{fill:none;stroke:var(--line);stroke-width:1}
.hero-dial .land{fill:rgba(168,163,154,.12);stroke:var(--line-2);stroke-width:.6}
.hero-dial .anchor{fill:var(--rust)}
.hero-dial .anchor.beat{animation:beat 3s ease-in-out infinite}
@keyframes beat{0%,100%{opacity:.55}50%{opacity:1}}
.hero-dial .label{
  fill:var(--ink-2);font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;
}
.hero-dial .label-strong{fill:var(--ink-0)}
.hero-dial .label-rust{fill:var(--rust-3)}
.hero-dial .crosshair{fill:none;stroke:var(--ink-2);stroke-width:.8}
.hero-dial .needle{stroke:var(--rust-2);stroke-width:1.4;transform-origin:center}
.hero-dial .needle.slow{animation:needleSway 9s ease-in-out infinite}
@keyframes needleSway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(2deg)}}
.hero-dial .glow{
  filter:drop-shadow(0 0 28px rgba(155,58,43,.18));
}
.hero-dial::after{
  content:"";position:absolute;inset:auto;left:50%;top:50%;width:140%;height:140%;transform:translate(-50%,-50%);
  background: radial-gradient(circle, rgba(155,58,43,.08), transparent 60%);
  pointer-events:none;z-index:-1;
}

/* hero 公告 ticker */
.hero-news{
  margin-top:48px;border-top:1px solid var(--line-2);
  display:grid;grid-template-columns: 220px 1fr auto;align-items:stretch;
  font-family:var(--mono);font-size:12px;
}
.hero-news .head{
  padding:18px 0;display:flex;align-items:center;gap:10px;
  font-size:11px;color:var(--rust-3);letter-spacing:.22em;text-transform:uppercase;
  border-right:1px solid var(--line-2);padding-right:24px;
}
.hero-news .head::before{content:"";width:6px;height:6px;background:var(--rust);animation:pulseRust 2.4s ease-in-out infinite;border-radius:50%}
.hero-news .feed{
  display:flex;flex-direction:column;justify-content:center;
  padding:14px 24px;gap:8px;overflow:hidden;
}
.hero-news .feed .row{display:flex;gap:14px;align-items:baseline;color:var(--ink-1);line-height:1.6}
.hero-news .feed .ts{color:var(--ink-2);font-size:11px;min-width:11ch;flex-shrink:0}
.hero-news .feed .lvl{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;min-width:6ch;flex-shrink:0}
.hero-news .feed .lvl.ok{color:var(--green)}
.hero-news .feed .lvl.warn{color:var(--amber)}
.hero-news .feed .lvl.err{color:var(--rust-3)}
.hero-news .feed .lvl.info{color:var(--blue)}
.hero-news .feed .msg{font-family:var(--cn);font-weight:300;color:var(--ink-0);font-size:13px}
.hero-news .more{
  padding:18px 0 18px 24px;border-left:1px solid var(--line-2);
  display:flex;align-items:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-1);
  cursor:pointer;transition:color .25s;
}
.hero-news .more:hover{color:var(--ink-0)}
@media (max-width:880px){
  .hero-news{grid-template-columns:1fr}
  .hero-news .head{border-right:0;border-bottom:1px solid var(--line-2);padding-right:0}
  .hero-news .more{border-left:0;border-top:1px solid var(--line-2);padding-left:0}
}

/* ─────────────────────────────────────────────────────
   HOME / 6 模块入口
   ───────────────────────────────────────────────────── */
.mods-grid{
  display:grid;grid-template-columns: repeat(12, 1fr);grid-auto-rows: minmax(180px, auto);
  border-top:1px solid var(--line);border-left:1px solid var(--line);
}
.mod{
  position:relative;padding:32px 28px;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-0);
  display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;cursor:pointer;
  transition:background .25s, transform .35s;
}
.mod:hover{background:var(--bg-1)}
.mod::before{
  content:"";position:absolute;top:0;left:-100%;width:100%;height:1px;background:var(--rust);
  transition:left .55s cubic-bezier(.7,0,.2,1);
}
.mod:hover::before{left:100%}
.mod-num{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.2em}
.mod-name{
  font-family:var(--sans);font-weight:600;font-size:clamp(20px,2.4vw,30px);line-height:1.1;
  margin-top:12px;
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;letter-spacing:0;
}
.mod-name .zh{font-family:var(--cn);font-weight:500}
.mod-name .en{color:var(--ink-2);font-weight:400;font-size:.55em;letter-spacing:.18em;text-transform:uppercase}
.mod-desc{
  font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.7;
  margin-top:14px;max-width:46ch;
}
.mod-foot{
  margin-top:28px;display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.12em;text-transform:uppercase;
}
.mod-status{
  display:inline-flex;align-items:center;gap:8px;padding:4px 10px;
  border:1px solid var(--line-2);color:var(--ink-1);
}
.mod-status .dot{width:6px;height:6px;border-radius:50%}
.mod-status.live{border-color:var(--green);color:var(--green)}
.mod-status.live .dot{background:var(--green)}
.mod-status.beta{border-color:var(--amber);color:var(--amber)}
.mod-status.beta .dot{background:var(--amber)}
.mod-status.danger{border-color:var(--rust);color:var(--rust-3)}
.mod-status.danger .dot{background:var(--rust)}
.mod-status.legacy{border-color:var(--ink-2);color:var(--ink-2)}
.mod-status.legacy .dot{background:var(--ink-2)}
.mod-arrow{
  width:32px;height:32px;border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--ink-1);
  transition:all .25s;
}
.mod:hover .mod-arrow{background:var(--rust);border-color:var(--rust);color:#fff;transform:translate(2px,-2px)}

.mod.m1{grid-column: span 4;grid-row: span 1;background:var(--bg-1)}
.mod.m2{grid-column: span 4}
.mod.m3{grid-column: span 4}
.mod.m4{grid-column: span 4}
.mod.m5{grid-column: span 4}
.mod.m6{grid-column: span 4}
.mod.m1 .mod-name{font-size:clamp(28px,3.4vw,42px)}
.mod.m1 .mod-desc{font-size:14.5px;max-width:54ch}
.mod.m1 .mod-tag{
  margin-top:24px;display:inline-block;font-family:var(--mono);font-size:11px;color:var(--rust-3);
  padding:6px 12px;border:1px dashed var(--rust);letter-spacing:.14em;text-transform:uppercase;
}
@media (max-width:1080px){
  .mod.m1{grid-column:span 12;grid-row:span 1}
  .mod.m2,.mod.m3{grid-column:span 6}
  .mod.m4,.mod.m5,.mod.m6{grid-column:span 4}
}
@media (max-width:720px){
  .mods-grid{grid-template-columns:1fr}
  .mod{grid-column:span 1 !important}
}

/* ─────────────────────────────────────────────────────
   HOME / 世界任务横幅
   ───────────────────────────────────────────────────── */
.wq-banner{
  display:grid;grid-template-columns: auto 1fr auto;gap:32px;align-items:center;
  padding:28px 32px;background:var(--bg-1);border:1px solid var(--line-2);
  position:relative;overflow:hidden;
}
.wq-banner::after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:var(--wp,47.3%);background:var(--rust);
}
.wq-banner .meta{font-family:var(--mono);font-size:11px;color:var(--rust-3);letter-spacing:.22em;text-transform:uppercase;display:flex;align-items:center;gap:10px}
.wq-banner .meta::before{content:"";width:6px;height:6px;background:var(--rust);border-radius:50%;animation:pulseRust 2.4s ease-in-out infinite}
.wq-banner .name{font-family:var(--cn);font-weight:500;font-size:clamp(20px,2vw,28px);line-height:1.2;color:var(--ink-0);margin-bottom:8px}
.wq-banner .name .br{color:var(--rust)}
.wq-banner .body{display:flex;flex-direction:column;gap:14px;min-width:0}
.wq-banner .pbar{height:8px;background:var(--bg-3);position:relative;overflow:hidden}
.wq-banner .pbar .fill{
  position:absolute;inset:0;width:var(--wp,47.3%);
  background:repeating-linear-gradient(90deg, var(--rust) 0 12px, var(--rust-deep) 12px 14px);
}
.wq-banner .pinfo{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.04em}
.wq-banner .pinfo .v{color:var(--ink-0)}
.wq-banner .cta{flex-shrink:0}
@media (max-width:900px){
  .wq-banner{grid-template-columns:1fr}
}

/* ─────────────────────────────────────────────────────
   HOME / 评价摘要
   ───────────────────────────────────────────────────── */
.rv-summary{
  display:grid;grid-template-columns: 280px 1fr 1fr;gap:32px;
  padding:32px;background:var(--bg-1);border:1px solid var(--line);
}
.rv-summary .score{text-align:center;border-right:1px solid var(--line);padding-right:28px}
.rv-summary .score .num{
  font-family:var(--sans);font-weight:700;font-size:84px;line-height:1;color:var(--green);letter-spacing:0;
}
.rv-summary .score .deno{font-family:var(--mono);font-size:12px;color:var(--ink-1);margin-top:4px;letter-spacing:.1em}
.rv-summary .score .lab{
  margin-top:16px;display:inline-block;
  font-family:var(--cn);font-weight:500;font-size:13px;color:var(--green);
  padding:6px 14px;border:1px solid var(--green);
}
.rv-summary .score .ct{font-family:var(--mono);font-size:11px;color:var(--ink-2);margin-top:12px;letter-spacing:.06em}
.rv-summary .quote{font-family:var(--cn);color:var(--ink-0);font-size:14px;line-height:1.8;display:flex;flex-direction:column;justify-content:space-between;gap:14px}
.rv-summary .quote .meta{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.06em;display:flex;justify-content:space-between}
.rv-summary .quote .vote{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500}
.rv-summary .quote .vote.up{color:var(--green)}
.rv-summary .quote .vote.down{color:var(--rust-3)}
@media (max-width:900px){
  .rv-summary{grid-template-columns:1fr}
  .rv-summary .score{border-right:0;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:24px}
}

/* ─────────────────────────────────────────────────────
   FOOTER
   ───────────────────────────────────────────────────── */
footer{background:#040406;padding: clamp(50px, 5vw, 80px) var(--pad-x) 30px;color:var(--ink-1)}
.foot-inner{max-width:var(--maxw);margin:0 auto}
.foot-top{
  display:grid;grid-template-columns: 1.4fr repeat(4, 1fr);gap:48px;
  padding-bottom:40px;border-bottom:1px solid var(--line);
}
@media (max-width:980px){.foot-top{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:560px){.foot-top{grid-template-columns:1fr}}
.foot-brand{display:flex;flex-direction:column;gap:14px}
.foot-brand .b{display:flex;align-items:center;gap:12px}
.foot-brand .desc{font-family:var(--cn);font-size:13px;color:var(--ink-2);line-height:1.7;max-width:34ch}
.foot-col h5{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px;font-weight:500}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-family:var(--cn);font-size:13px;color:var(--ink-2);transition:color .2s}
.foot-col a:hover{color:var(--ink-0)}
.foot-col a .ext{font-family:var(--mono);font-size:9px;color:var(--ink-3);margin-left:6px;letter-spacing:.1em}

.foot-bot{
  margin-top:28px;padding-top:20px;
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.06em;
}
.foot-bot .legal{font-family:var(--cn);font-size:12px;color:var(--ink-2);max-width:60ch;line-height:1.7}
.foot-bot .stamp{display:inline-flex;align-items:center;gap:8px}
.foot-bot .stamp .dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2.4s ease-in-out infinite}

/* ═══════════════════════════════════════════════════════
   PAGE: character.html — 角色档案
   ═══════════════════════════════════════════════════════ */
.subpage-hero{
  padding: clamp(28px,3vw,44px) var(--pad-x) clamp(20px,2.5vw,32px);
  border-bottom:1px solid var(--line);
  position:relative;
  background: radial-gradient(ellipse 50% 60% at 80% 50%, rgba(155,58,43,.06), transparent 60%);
}
.subpage-hero-inner{max-width:var(--maxw);margin:0 auto;width:100%}
.subpage-crumbs{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px;display:flex;gap:10px;flex-wrap:wrap}
.subpage-crumbs a{color:var(--ink-1);transition:color .2s}
.subpage-crumbs a:hover{color:var(--ink-0)}
.subpage-crumbs .sep{color:var(--ink-3)}
.subpage-crumbs .now{color:var(--rust-3)}
.subpage-h{
  display:grid;grid-template-columns: auto 1fr;gap:24px;align-items:center;
}
.subpage-h h1{
  display:flex;align-items:baseline;flex-wrap:wrap;gap:0 14px;
  font-family:var(--sans);font-weight:700;font-size:clamp(22px,2.6vw,32px);
  line-height:1.15;letter-spacing:0;margin:0;
}
.subpage-h h1 br{display:none}
.subpage-h h1 .zh{font-family:var(--cn);font-weight:500}
.subpage-h h1 .accent{color:var(--rust)}
/* .lead 保留样式以兼容其他位置（save-warn / continue-card 仍在用），hero 内不再使用 */
.subpage-h .lead{font-family:var(--cn);font-weight:300;font-size:15px;color:var(--ink-1);line-height:1.7;margin-top:18px;max-width:54ch}
.subpage-h .stat{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:0;
  font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.06em;
  line-height:1.5;text-align:right;
}
.subpage-h .stat > div{display:inline-flex;align-items:baseline;white-space:nowrap}
.subpage-h .stat > div:not(:last-child)::after{
  content:"·";margin:0 10px;color:var(--ink-3);
}
.subpage-h .stat .v{color:var(--ink-0)}
.subpage-h .stat .v.r{color:var(--rust-3)}
.subpage-h .stat .v.g{color:var(--green)}
.community-hero-panel{
  justify-self:end;display:flex;flex-direction:column;align-items:flex-end;gap:10px;min-width:0;
}
.community-hero-actions{
  display:flex;justify-content:flex-end;flex-wrap:wrap;gap:8px;
}
.community-hero-btn{
  min-width:126px;justify-content:center;
}
.community-hero-btn.guide{
  border-color:rgba(224,184,51,.45);color:var(--mustard);
}
.community-hero-btn.log{
  border-color:rgba(90,155,106,.45);color:var(--green);
}
.community-hero-btn::before{
  display:none;
}
.community-hero-btn.guide:hover{
  color:var(--mustard);border-color:var(--mustard);background:rgba(224,184,51,.08);
}
.community-hero-btn.log:hover{
  color:var(--green);border-color:var(--green);background:rgba(90,155,106,.08);
}
.community-hero-btn.bug:hover{
  color:#fff;border-color:var(--rust-3);background:var(--rust-2);
}
.subpage-h .community-hero-stat{
  justify-content:flex-end;
}
@media (max-width:760px){
  .subpage-h{grid-template-columns:1fr;gap:12px}
  .subpage-h .stat{justify-content:flex-start;text-align:left}
  .community-hero-panel{justify-self:stretch;align-items:stretch}
  .community-hero-actions{justify-content:flex-start}
  .community-hero-btn{flex:1 1 150px}
  .subpage-h .community-hero-stat{justify-content:flex-start}
}
@media (max-width:420px){
  .community-hero-btn{flex-basis:100%}
}

.steps{
  margin-top:36px;display:flex;gap:0;border-top:1px solid var(--line);
}
.step{
  flex:1;padding:14px 16px;border-right:1px solid var(--line);
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;
  display:flex;flex-direction:column;gap:4px;
}
.step:last-child{border-right:0}
.step.done{color:var(--ink-1);background:rgba(255,255,255,.02)}
.step.now{color:var(--rust-3);background:var(--rust-soft);border-bottom:2px solid var(--rust)}
.step .n{font-size:10px;letter-spacing:.2em;color:var(--ink-3)}
.step.done .n{color:var(--green)}
.step.now .n{color:var(--rust-3)}
.step .t{font-family:var(--cn);font-size:12px;font-weight:500;letter-spacing:.02em;text-transform:none}
@media (max-width:760px){.steps{flex-wrap:wrap}.step{flex:1 1 50%;border-bottom:1px solid var(--line)}}

/* pre-birth account gate */
.account-gate-section{
  background:
    radial-gradient(ellipse 48% 60% at 20% 20%, rgba(90,155,106,.08), transparent 68%),
    linear-gradient(180deg, rgba(155,58,43,.05), transparent 45%);
}
.account-gate-card{
  max-width:860px;margin:0 auto;
  border:1px solid var(--line-2);
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  padding:clamp(24px,4vw,42px);
  box-shadow:0 24px 80px rgba(0,0,0,.32);
}
.account-gate-console{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-1);margin-bottom:26px;padding-bottom:14px;border-bottom:1px solid var(--line);
}
.account-gate-console .dot{
  width:8px;height:8px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 5px rgba(90,155,106,.12);
}
.account-gate-summary{
  display:flex;align-items:end;justify-content:space-between;gap:18px;flex-wrap:wrap;
  margin-bottom:24px;
}
.account-gate-summary span{
  display:block;font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px;
}
.account-gate-summary strong{
  font-family:var(--cn);font-size:clamp(24px,3vw,36px);font-weight:700;color:var(--ink-0);line-height:1.1;
}
.account-gate-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.account-gate-chips em{
  font-style:normal;border:1px solid var(--line-2);padding:6px 10px;
  font-family:var(--cn);font-size:12px;color:var(--ink-1);background:rgba(255,255,255,.018);
}
.account-form-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;
}
.account-form-grid .bf-row > span,
.policy-check span{
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  letter-spacing:.12em;text-transform:uppercase;
}
.account-code-row{display:grid;grid-template-columns:1fr auto;gap:10px}
.account-code-row .btn{white-space:nowrap}
.policy-check{
  margin-top:24px;display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;
  padding:16px;border:1px dashed var(--line-2);background:rgba(255,255,255,.02);
  cursor:pointer;
}
.policy-check input{margin-top:3px;accent-color:var(--rust)}
.policy-check span{
  font-family:var(--cn);letter-spacing:0;text-transform:none;line-height:1.7;color:var(--ink-1);
}
.account-gate-feedback{
  margin-top:16px;min-height:22px;font-family:var(--cn);font-size:13px;color:var(--ink-2);line-height:1.7;
}
.account-gate-feedback.ok{color:var(--green)}
.account-gate-feedback.err{color:var(--rust-3)}
.account-gate-actions{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:760px){
  .account-form-grid{grid-template-columns:1fr}
  .account-code-row{grid-template-columns:1fr}
}

/* species list */
.species-grid{
  display:grid;grid-template-columns: repeat(3, 1fr);gap:0;
  border-top:1px solid var(--line);border-left:1px solid var(--line);
}
@media (max-width:980px){.species-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.species-grid{grid-template-columns:1fr}}
.species{
  padding:22px 24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-0);display:flex;flex-direction:column;gap:8px;position:relative;
  cursor:not-allowed;opacity:.55;
}
.species .name{font-family:var(--cn);font-size:18px;font-weight:500;color:var(--ink-1);display:flex;align-items:center;justify-content:space-between;gap:12px}
.species .name .lock{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line-2);padding:3px 8px}
.species .err{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.04em;line-height:1.6}
.species .err .red{color:var(--rust-3)}
.species.avail{
  opacity:1;cursor:pointer;background:var(--rust-soft);border-bottom:2px solid var(--rust);
}
.species.avail .name{color:var(--ink-0);font-weight:600}
.species.avail .name .lock{color:#fff;background:var(--rust);border-color:var(--rust)}
.species.avail .err{color:var(--rust-3)}
.species.avail::before{
  content:"";position:absolute;top:0;right:0;width:0;height:0;
  border-top:14px solid var(--rust);border-left:14px solid transparent;
}

/* gender input */
.gender-row{
  display:grid;grid-template-columns: 1fr;gap:24px;
}
.gender-input{
  width:100%;padding:18px 20px;background:var(--bg-1);border:1px solid var(--line-2);
  font-family:var(--cn);font-size:18px;color:var(--ink-0);outline:none;transition:border-color .2s;
}
.gender-input:focus{border-color:var(--rust)}
.gender-input::placeholder{color:var(--ink-2)}
.gender-tags{display:flex;flex-wrap:wrap;gap:8px}
.gender-tag{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);
  padding:7px 14px;border:1px solid var(--line-2);cursor:pointer;transition:all .2s;
}
.gender-tag:hover{color:#fff;background:var(--rust);border-color:var(--rust)}
.gender-note{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.04em;line-height:1.7}

/* six-stat radar + breakdown */
.stats-row{display:grid;grid-template-columns: 1fr 1fr;gap:48px;align-items:start}
@media (max-width:900px){.stats-row{grid-template-columns:1fr}}
.radar{aspect-ratio:1/1;width:100%;max-width:480px;margin:0 auto}
.radar svg{width:100%;height:100%;display:block}
.radar .ax{stroke:var(--line-2);stroke-width:1}
.radar .grid{fill:none;stroke:var(--line);stroke-width:1}
.radar .area{fill:rgba(155,58,43,.18);stroke:var(--rust);stroke-width:1.4}
.radar .dot{fill:var(--rust)}
.radar .lab{fill:var(--ink-1);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.radar .lab-cn{fill:var(--ink-0);font-family:var(--cn);font-size:13px;font-weight:500}
.radar .num{fill:var(--rust-3);font-family:var(--mono);font-size:12px;font-weight:600}

.stat-rows{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.stat-row{
  padding:14px 4px;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns: 1fr auto;gap:12px;align-items:baseline;
}
.stat-row .k{font-family:var(--cn);font-size:14px;color:var(--ink-0);font-weight:500}
.stat-row .k .en{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;margin-left:8px;text-transform:uppercase}
.stat-row .v{font-family:var(--mono);font-size:18px;font-weight:600;color:var(--rust-3);font-variant-numeric:tabular-nums}
.stat-row .note{
  grid-column:1 / -1;font-family:var(--cn);font-size:13px;color:var(--ink-1);
  font-style:italic;line-height:1.7;margin-top:6px;
}
.stat-row .bar{
  grid-column:1 / -1;height:3px;background:var(--bg-3);position:relative;overflow:hidden;margin-top:8px;
}
.stat-row .bar::before{
  content:"";position:absolute;left:0;top:0;height:100%;width:var(--p,50%);background:var(--rust);
}

/* free talent */
.talent-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);background:var(--bg-1)}
.talent{padding:18px 20px;border-bottom:1px solid var(--line);display:grid;grid-template-columns: auto 1fr auto;gap:18px;align-items:center}
.talent:last-child{border-bottom:0}
.talent .icon{
  width:36px;height:36px;border:1px solid var(--rust);color:var(--rust-3);
  display:grid;place-items:center;font-family:var(--mono);font-size:14px;font-weight:600;
}
.talent .name{font-family:var(--cn);font-size:15px;font-weight:500;color:var(--ink-0)}
.talent .name .en{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;margin-left:8px;text-transform:uppercase}
.talent .desc{font-family:var(--cn);font-size:13px;color:var(--ink-1);margin-top:4px;line-height:1.6}
.talent .v{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.14em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--line-2)}
.v.sealed{
  animation:sealedPulse 3s ease-in-out infinite;
  border:1px solid var(--line-2);
  padding:2px 8px;
  border-radius:2px;
}
@keyframes sealedPulse{
  0%,100%{border-color:var(--line-2)}
  50%{border-color:var(--ink-0);opacity:.7}
}

/* job mapping */
.job-mapping{display:grid;grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.job-cell{padding:18px 20px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
.job-cell .src{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.1em;text-transform:uppercase}
.job-cell .arr{color:var(--ink-3);font-family:var(--mono);font-size:11px}
.job-cell .dst{font-family:var(--cn);font-size:16px;color:var(--ink-0);font-weight:500}
.job-cell .dst.rust{color:var(--rust-3)}

/* character card preview */
.char-card{
  margin:0 auto;max-width:420px;background:var(--bg-1);border:1px solid var(--rust);
  position:relative;
  box-shadow:0 0 0 6px rgba(155,58,43,.06), 0 30px 80px rgba(0,0,0,.6);
}
.char-card::before{
  content:"OFFICIAL";position:absolute;top:-1px;right:-1px;
  background:var(--rust);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.2em;padding:4px 10px;
}
.char-card .head{
  padding:18px 20px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-1);
  display:flex;justify-content:space-between;
}
.char-card .head .uid{color:var(--ink-0)}
.char-card .body{padding:24px 22px;display:grid;grid-template-columns: 130px 1fr;gap:20px}
.char-card .avatar{
  aspect-ratio:1/1;background:var(--bg-2);border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--ink-1);position:relative;
}
.char-card .avatar svg{width:60%;opacity:.4}
.char-card .info{display:flex;flex-direction:column;gap:8px;font-family:var(--cn);font-size:13px;color:var(--ink-0);line-height:1.6}
.char-card .info .k{color:var(--ink-2);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;margin-top:4px}
.char-card .info .v{color:var(--ink-0);font-size:14px;font-weight:500}
.char-card .info .v.rust{color:var(--rust-3)}
.char-card .lifebar{padding:14px 22px;border-top:1px solid var(--line);font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em}
.char-card .lifebar .lb{margin-top:8px;height:6px;background:var(--bg-3);position:relative;overflow:hidden}
.char-card .lifebar .lb::before{content:"";position:absolute;left:0;top:0;bottom:0;width:var(--card-life-pct, 35%);background:linear-gradient(90deg,var(--rust),var(--amber));transition:width .8s ease}
.char-card .foot{padding:12px 22px;border-top:1px solid var(--line);font-family:var(--cn);font-size:10px;color:var(--ink-2);line-height:1.6}

.char-export-row{
  margin-top:36px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
}

/* registered profile dashboard */
.profile-dashboard-section{
  background:
    radial-gradient(ellipse 44% 50% at 82% 20%, rgba(155,58,43,.08), transparent 70%),
    var(--bg-0);
}
.profile-home-grid{
  display:grid;grid-template-columns:minmax(320px, .9fr) minmax(360px, 1.1fr);gap:22px;align-items:stretch;
}
.profile-summary-strip{
  display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap;
  margin-bottom:18px;padding:10px 0;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.08em;
}
.profile-summary-strip span{margin-right:auto;color:var(--rust-3);letter-spacing:.18em;text-transform:uppercase}
.profile-summary-strip strong,.profile-summary-strip b{color:var(--ink-0);font-weight:600}
.profile-summary-strip em{
  font-style:normal;border:1px solid var(--line);padding:5px 9px;color:var(--ink-1);
}
.player-card,
.profile-stat-board{
  border:1px solid var(--line-2);background:var(--bg-1);padding:clamp(22px,3vw,34px);
}
.player-card{
  position:relative;overflow:hidden;
  box-shadow:0 0 0 6px rgba(155,58,43,.035);
}
.player-card::before{
  content:"ACTIVE";position:absolute;top:0;right:0;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:#fff;
  background:var(--rust);padding:5px 12px;
}
.player-card-top{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;margin-bottom:24px}
.player-avatar{
  width:78px;height:78px;border:1px solid var(--rust);display:grid;place-items:center;
  font-family:var(--cn);font-size:34px;font-weight:700;color:var(--ink-0);
  background:linear-gradient(135deg, rgba(155,58,43,.26), rgba(255,255,255,.03));
}
.player-label{
  font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px;
}
.player-card h3{font-family:var(--cn);font-size:28px;font-weight:600;color:var(--ink-0);line-height:1.2}
.player-card p{font-family:var(--mono);font-size:12px;color:var(--ink-2);letter-spacing:.08em;margin-top:6px}
.blood-panel{
  padding:18px;border:1px solid var(--line);background:rgba(0,0,0,.22);margin-bottom:18px;
}
.blood-head{display:flex;justify-content:space-between;gap:14px;align-items:center;font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.14em;text-transform:uppercase}
.blood-head strong{color:var(--green);font-weight:600}
.blood-bar{height:12px;margin-top:12px;background:var(--bg-3);border:1px solid var(--line);position:relative;overflow:hidden}
.blood-bar span{display:block;height:100%;width:var(--hp,72%);background:linear-gradient(90deg,var(--rust),var(--amber),var(--green));transition:width .7s ease}
.blood-note{font-family:var(--cn);font-size:12px;color:var(--ink-2);line-height:1.7;margin-top:10px}
.player-fields{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.player-fields div{padding:13px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-width:0}
.player-fields span{display:block;font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.16em;text-transform:uppercase;margin-bottom:5px}
.player-fields strong{display:block;font-family:var(--cn);font-size:14px;color:var(--ink-0);font-weight:500;line-height:1.45;overflow-wrap:anywhere}
.profile-stat-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line);margin-top:18px;
}
.profile-stat-grid div{padding:20px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.015)}
.profile-stat-grid span{display:block;font-family:var(--cn);font-size:13px;color:var(--ink-1);margin-bottom:8px}
.profile-stat-grid strong{font-family:var(--mono);font-size:30px;color:var(--rust-3);font-weight:700;font-variant-numeric:tabular-nums}
.profile-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.profile-save-section{background:linear-gradient(180deg, rgba(155,58,43,.035), transparent 30%)}
@media (max-width:980px){
  .profile-home-grid{grid-template-columns:1fr}
}
@media (max-width:620px){
  .player-card-top{grid-template-columns:1fr}
  .player-fields,.profile-stat-grid{grid-template-columns:1fr 1fr}
}

/* —— Step 03: 六维加减点提示条 + 加减按钮 —— */
.point-hint{
  display:flex;align-items:center;gap:12px;
  margin-bottom:24px;padding:12px 18px;
  background:rgba(197,131,45,.06);border:1px solid var(--amber);border-left-width:3px;
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.6;
}
.point-hint .ph-icon{
  font-family:var(--mono);font-size:16px;color:var(--amber);
  flex-shrink:0;
}
.point-hint .ph-text strong{color:var(--amber);font-weight:600}
.point-hint.depleted{
  background:var(--rust-soft);border-color:var(--rust);
}
.point-hint.depleted .ph-icon{color:var(--rust-3)}
.point-hint.depleted .ph-text strong{color:var(--rust-3)}

/* 数值 + 加减按钮容器（替代原 .v 单独占第二列） */
.stat-row .v-wrap{
  display:flex;align-items:center;gap:8px;
}
.stat-row .v-wrap .v{
  font-family:var(--mono);font-size:18px;font-weight:600;
  color:var(--rust-3);font-variant-numeric:tabular-nums;
  min-width:32px;text-align:right;
}
.sc-btn{
  width:30px;height:30px;background:transparent;
  border:1px solid var(--line-2);border-radius:0;
  font-family:var(--mono);font-size:16px;font-weight:500;color:var(--ink-1);
  cursor:pointer;transition:all .15s ease;line-height:1;padding:0;
}
.sc-btn:hover:not(:disabled){
  border-color:var(--rust-3);color:var(--rust-3);
}
.sc-btn:active:not(:disabled){transform:scale(.9)}
.sc-btn:disabled{opacity:.25;cursor:not-allowed}
.sc-btn.is-pressed{
  background:var(--rust-soft);border-color:var(--rust);color:var(--rust-3);
  transform:scale(.92);
}
.sc-btn.is-undo:not(:disabled){
  border-color:var(--green);color:var(--green);
}
.sc-btn.is-undo:not(:disabled):hover{
  border-color:var(--green);color:#fff;background:var(--green);
}

/* —— Step 01: 降生信息表单 —— */
.birth-form{
  display:flex;flex-direction:column;gap:32px;max-width:720px;margin:0 auto;
}
.bf-row{display:flex;flex-direction:column;gap:10px}
.bf-row > label{
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  letter-spacing:.18em;text-transform:uppercase;
}
.bf-input{
  width:100%;background:transparent;outline:0;
  border:1px solid var(--line-3);padding:14px 18px;
  font-family:var(--cn);font-size:15px;color:var(--ink-0);
  transition:border-color .2s;
}
.bf-input:focus{border-color:var(--rust)}
.bf-input::placeholder{color:var(--ink-2)}
.bf-date{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.bf-region{display:grid;grid-template-columns:1fr 2fr;gap:8px}
@media (max-width:680px){
  .bf-date{grid-template-columns:1fr}
  .bf-region{grid-template-columns:1fr}
}
.bf-select{
  width:100%;background:var(--bg-1);outline:0;
  border:1px solid var(--line-3);padding:12px 14px;
  font-family:var(--cn);font-size:14px;color:var(--ink-0);
  cursor:pointer;
  appearance:none;-webkit-appearance:none;
  background-image:linear-gradient(45deg, transparent 50%, var(--ink-2) 50%),
                   linear-gradient(135deg, var(--ink-2) 50%, transparent 50%);
  background-position:calc(100% - 18px) calc(50% - 2px),
                      calc(100% - 13px) calc(50% - 2px);
  background-size:5px 5px,5px 5px;
  background-repeat:no-repeat;
  padding-right:32px;
}
.bf-select:focus{border-color:var(--rust)}
.bf-select:disabled{opacity:.4;cursor:not-allowed}
.bf-hint{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.04em;line-height:1.6;
}

.uid-preview{
  margin-top:16px;padding:18px 22px;
  border:1px solid var(--rust-edge);background:var(--rust-soft);
  display:flex;flex-direction:column;gap:6px;text-align:center;
}
.up-label{
  font-family:var(--mono);font-size:10px;color:var(--rust-3);
  letter-spacing:.22em;text-transform:uppercase;
}
.up-value{
  font-family:var(--mono);font-size:22px;font-weight:600;color:var(--ink-0);
  letter-spacing:.06em;font-variant-numeric:tabular-nums;
}
.up-value.is-pending{color:var(--ink-3);opacity:.45}
.up-note{
  font-family:var(--cn);font-size:11px;color:var(--ink-2);
  font-style:italic;margin-top:4px;
}

/* —— Step 02: 生理性别选择 —— */
.bio-sex-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line);border-left:1px solid var(--line);
  margin-top:14px;
}
@media (max-width:680px){.bio-sex-grid{grid-template-columns:1fr}}
.bio-sex-card{
  padding:22px 24px;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-0);cursor:pointer;
  display:flex;flex-direction:column;gap:8px;
  transition:all .2s;position:relative;
}
.bio-sex-card:hover{background:var(--bg-1)}
.bio-sex-card input{position:absolute;opacity:0;pointer-events:none}
.bio-sex-card .bs-name{
  font-family:var(--cn);font-size:18px;font-weight:500;color:var(--ink-1);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.bio-sex-card .bs-tag{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
  border:1px solid var(--line-2);padding:3px 8px;
}
.bio-sex-card .bs-note{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.04em;line-height:1.6;
}
.bio-sex-card.is-selected{
  background:var(--rust-soft);
}
.bio-sex-card.is-selected::before{
  content:"";position:absolute;top:0;left:0;width:48px;height:2px;background:var(--rust);
}
.bio-sex-card.is-selected .bs-name{color:var(--ink-0);font-weight:600}
.bio-sex-card.is-selected .bs-tag{color:#fff;background:var(--rust);border-color:var(--rust)}
.bio-sex-card.is-selected .bs-note{color:var(--rust-3)}

/* —— Step 01: 昵称 / 生日 实时校验状态 —— */
.bf-validate{
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;
  min-height:1.4em;line-height:1.4;
}
.bf-validate.ok{color:var(--green)}
.bf-validate.ok::before{content:"✓ ";font-weight:600}
.bf-validate.err{color:var(--rust-3)}
.bf-validate.err::before{content:"✗ ";font-weight:600}

/* —— 雷达数字极值高亮 —— */
.radar .num.is-max{fill:var(--amber);font-weight:700}
.radar .num.is-min{fill:var(--ink-3);opacity:.55}

/* —— Step 03: 极值 toast —— */
.stat-toast{
  position:fixed;left:50%;bottom:80px;z-index:1000;
  transform:translateX(-50%) translateY(8px);
  padding:12px 22px;
  background:rgba(0,0,0,.92);border:1px solid var(--rust);
  font-family:var(--mono);font-size:13px;letter-spacing:.04em;
  color:var(--rust-3);white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease, transform .35s ease;
}
.stat-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.stat-toast.amber{border-color:var(--amber);color:var(--amber)}
@media(max-width:560px){
  .stat-toast{
    left:16px;right:16px;transform:translateY(8px);
    white-space:normal;text-align:center;
  }
  .stat-toast.show{transform:translateY(0)}
}

/* —— Step 04: 职业映射输入区 —— */
.job-input-wrap{
  display:grid;grid-template-columns:1fr auto;gap:12px;margin-bottom:20px;
}
@media (max-width:680px){.job-input-wrap{grid-template-columns:1fr}}
.job-input-big{
  width:100%;background:transparent;outline:0;
  border:1px solid var(--line-3);padding:18px 22px;
  font-family:var(--cn);font-size:16px;color:var(--ink-0);letter-spacing:.02em;
  transition:border-color .2s;
}
.job-input-big:focus{border-color:var(--rust)}
.job-input-big::placeholder{color:var(--ink-2)}
.job-map-btn{padding:18px 26px;letter-spacing:.16em}

.job-tags{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;
}
.job-tag{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);
  padding:7px 14px;border:1px solid var(--line-2);background:transparent;
  cursor:pointer;transition:all .15s;
}
.job-tag:hover{color:#fff;background:var(--rust);border-color:var(--rust)}

.job-result{
  display:none;margin:36px 0;padding:32px 28px;
  border:1px solid var(--rust-edge);
  background:linear-gradient(180deg,rgba(155,58,43,.06) 0%,rgba(155,58,43,.02) 100%);
  text-align:center;
}
.job-result.show{display:block;animation:jobResultIn .45s ease}
@keyframes jobResultIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.job-result .jr-label{
  display:block;margin-bottom:8px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}
.job-result .jr-text{
  display:inline-block;
  font-family:var(--cn);font-size:22px;font-weight:500;color:var(--ink-0);
  line-height:1.3;letter-spacing:.005em;min-height:1em;
}
.job-result .jr-to .jr-text.rust{
  color:var(--rust-3);font-size:32px;font-weight:600;
}
.job-result .jr-arrow{
  margin:18px 0;font-family:var(--mono);font-size:11px;
  color:var(--rust-3);letter-spacing:.22em;text-transform:uppercase;
}
.job-result .jr-note{
  margin:18px 0 0;padding-top:14px;
  border-top:1px dashed var(--rust-edge);
  font-family:var(--cn);font-size:12px;color:var(--ink-2);
  font-style:italic;line-height:1.7;min-height:1em;
}

/* —— Step 05: 生命进度条（戏剧化） —— */
.life-progress-section{
  padding: clamp(72px,12vw,140px) var(--pad-x);
  background:
    radial-gradient(ellipse 60% 40% at 50% 50%, rgba(155,58,43,.10), transparent 70%),
    var(--bg-0);
  position:relative;overflow:hidden;
}
.life-progress-section::before,
.life-progress-section::after{
  content:"";position:absolute;left:0;right:0;height:1px;background:var(--line-2);
}
.life-progress-section::before{top:0}
.life-progress-section::after{bottom:0}

.lp-header{text-align:center;margin-bottom:60px}
.lp-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;
  color:var(--rust-3);text-transform:uppercase;margin-bottom:14px;
}
.lp-eyebrow::before,
.lp-eyebrow::after{
  content:"";width:32px;height:1px;background:var(--rust);
}
.lp-meta{font-family:var(--cn);font-size:13px;color:var(--ink-2);letter-spacing:.04em}

.lp-bar-container{max-width:1100px;margin:0 auto 80px}
.lp-labels{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--mono);font-size:12px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;
}
.lp-label-c{
  font-family:var(--mono);font-size:22px;font-weight:600;
  color:var(--rust-3);letter-spacing:0;font-variant-numeric:tabular-nums;
  text-transform:none;
}
.lp-bar{
  position:relative;height:32px;
  background:var(--bg-1);border:1px solid var(--line-2);
  overflow:visible;
}
.lp-bar-fill{
  position:absolute;inset:0;width:0%;
  background:linear-gradient(90deg, var(--rust) 0%, var(--rust-3) 50%, var(--amber) 100%);
  transition:width 1.5s cubic-bezier(.2,.9,.35,1);
  box-shadow:0 0 24px rgba(155,58,43,.3);
}
.lp-bar.is-animating .lp-bar-fill{
  animation:lpHeartbeat 1.6s ease-in-out infinite;
}
@keyframes lpHeartbeat{
  0%,100%{box-shadow:0 0 24px rgba(155,58,43,.30)}
  50%   {box-shadow:0 0 36px rgba(155,58,43,.62)}
}
.lp-bar-marker{
  position:absolute;top:50%;left:0%;
  transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;gap:4px;
  pointer-events:none;white-space:nowrap;
  transition:left 1.5s cubic-bezier(.2,.9,.35,1);
}
.lp-bar-marker::after{
  content:"";position:absolute;top:42px;
  width:1px;height:18px;background:var(--amber);
}
.lp-marker-num{
  font-family:var(--mono);font-size:24px;font-weight:600;color:var(--ink-0);
  font-variant-numeric:tabular-nums;letter-spacing:0;
}
.lp-marker-tag{
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;
  color:var(--amber);text-transform:uppercase;
}
.lp-bar-grid{
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;color:var(--ink-3);
  letter-spacing:.06em;margin-top:28px;
}

.lp-narrative{
  max-width:720px;margin:0 auto;text-align:center;
  font-family:var(--cn);line-height:1.8;
}
.lp-line{
  margin:0 0 16px;
  font-size:clamp(15px,1.8vw,19px);color:var(--ink-1);
  opacity:0;transform:translateY(8px);
  transition:opacity .8s ease, transform .8s ease;
}
.lp-line strong{color:var(--ink-0);font-weight:500}
.lp-line .lp-highlight{color:var(--rust-3);font-size:1.18em;font-weight:600}
.lp-line.show{opacity:1;transform:translateY(0)}
.lp-line[data-line="4"]{
  font-size:clamp(13px,1.5vw,15px);color:var(--ink-2);font-style:italic;
  margin-top:24px;padding-top:16px;border-top:1px dashed var(--line);
}
.lp-line[data-line="4"] strong{color:var(--rust-3)}

.lp-heartbeat{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:56px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--green);text-transform:uppercase;
}
.lp-hb-dot{
  width:8px;height:8px;border-radius:50%;background:var(--green);
  animation:lpHbPulse 1.4s ease-in-out infinite;
}
@keyframes lpHbPulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%   {opacity:.4;transform:scale(.85)}
}

/* —— Step 06: 角色卡迷你六维 + 装备栏 —— */
.char-card .card-radar{
  padding:20px 22px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center;
}
.card-radar .cr-label{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl;
  transform:rotate(180deg);
}
.card-radar svg{width:160px;height:160px;display:block;margin:0 auto}
.card-radar .grid{fill:none;stroke:var(--line-2);stroke-width:1}
.card-radar .area{fill:rgba(155,58,43,.20);stroke:var(--rust);stroke-width:1.4}
.card-radar .lab{fill:var(--ink-0);font-family:var(--cn);font-size:13px;font-weight:500}

.char-card .card-equip{
  padding:16px 22px 6px;border-top:1px solid var(--line);
}
.card-equip .ce-label{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px;
}
.card-equip .ce-slots{display:flex;flex-direction:column;gap:6px}
.card-equip .ce-slot{
  padding:8px 12px;border:1px dashed var(--line-2);background:rgba(255,255,255,.02);
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
  font-family:var(--cn);font-size:12px;
}
.card-equip .ce-tag{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;flex-shrink:0;
}
.card-equip .ce-name{color:var(--ink-1);font-weight:500;flex-shrink:0}
.card-equip .ce-name.sealed{color:var(--ink-3)}
.card-equip .ce-eff{
  flex:1;min-width:120px;font-size:11px;color:var(--ink-2);
  font-style:italic;text-align:right;
}

/* ═══════════════════════════════════════════════════════
   PAGE: save.html — 死亡存档
   ═══════════════════════════════════════════════════════ */
.save-warn{
  background:var(--bg-1);border:1px solid var(--rust-edge);
  padding:32px;display:grid;grid-template-columns: auto 1fr;gap:24px;align-items:start;
}
.save-warn .icon{
  width:48px;height:48px;border:1px solid var(--rust);color:var(--rust-3);
  display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:22px;
  flex-shrink:0;
}
.save-warn .body{font-family:var(--cn);color:var(--ink-0);line-height:1.9}
.save-warn .body p{margin-bottom:6px}
.save-warn .body .lead{font-size:18px;color:#fff;font-weight:500;margin-bottom:14px}
.save-warn .body .small{font-size:13px;color:var(--ink-1)}
.save-warn .actions{margin-top:18px;display:flex;gap:12px;flex-wrap:wrap}

.save-grid{
  display:grid;grid-template-columns: repeat(2,1fr);gap:0;
  border-top:1px solid var(--line);border-left:1px solid var(--line);
}
@media (max-width:880px){.save-grid{grid-template-columns:1fr}}
.save-block{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:32px;background:var(--bg-1);display:flex;flex-direction:column;gap:18px;
}
.save-block .head{display:flex;justify-content:space-between;align-items:baseline;gap:14px;border-bottom:1px solid var(--line);padding-bottom:12px}
.save-block .head h3{font-family:var(--cn);font-weight:500;font-size:20px;color:var(--ink-0)}
.save-block .head .en{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase}
.save-block .head .qt{font-family:var(--cn);font-size:13px;color:var(--ink-2);font-style:italic}
.save-rows{display:flex;flex-direction:column;gap:0}
.save-r{display:grid;grid-template-columns: 1fr auto;gap:14px;align-items:baseline;padding:10px 0;border-bottom:1px dashed var(--line)}
.save-r:last-child{border-bottom:0}
.save-r .k{font-family:var(--cn);font-size:13.5px;color:var(--ink-1)}
.save-r .v{font-family:var(--mono);font-size:14px;color:var(--ink-0);font-weight:500;font-variant-numeric:tabular-nums;text-align:right}
.save-r .v.rust{color:var(--rust-3)}
.save-r .v.green{color:var(--green)}
.save-r .v.amber{color:var(--amber)}
.save-r .v .small{font-size:11px;color:var(--ink-2);margin-left:6px;font-weight:400}

.continue-card{
  background:radial-gradient(ellipse at center, rgba(155,58,43,.06) 0%, transparent 70%);
  animation:shimmer 4s ease-in-out infinite;
}
@keyframes shimmer{
  0%,100%{opacity:1}
  50%{opacity:.92}
}
@keyframes endFloat{
  0%,100%{transform:translateY(0);opacity:0.3}
  50%{transform:translateY(-10px);opacity:0.5}
}
.continue-card{
  margin-top:48px;padding: clamp(36px, 5vw, 64px);
  border:1px solid var(--rust);background:linear-gradient(180deg, rgba(155,58,43,.06) 0%, rgba(155,58,43,.02) 100%);
  text-align:center;position:relative;overflow:hidden;
}
.continue-card::before{
  content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 100%, rgba(155,58,43,.18), transparent 60%);
  pointer-events:none;
}
.continue-card .lead{font-family:var(--cn);font-weight:500;font-size:clamp(22px,2.6vw,32px);color:#fff;line-height:1.5;letter-spacing:0;position:relative}
.continue-card .lead .accent{color:var(--rust-3)}
.continue-card .sub{font-family:var(--cn);color:var(--ink-1);font-size:14px;margin-top:14px;line-height:1.7;position:relative}
.continue-card .actions{margin-top:32px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;position:relative}

/* 心理援助行 (save 专用底部) */
.help-strip{
  margin-top:0;padding:32px;
  border:1px solid var(--amber);background:rgba(197,131,45,.05);
  display:grid;grid-template-columns: auto 1fr;gap:24px;align-items:start;
}
.help-strip .icon{
  width:42px;height:42px;border:1px solid var(--amber);color:var(--amber);
  display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:20px;
}
.help-strip h6{font-family:var(--mono);font-size:11px;color:var(--amber);letter-spacing:.22em;text-transform:uppercase;margin-bottom:10px;font-weight:500}
.help-strip p{font-family:var(--cn);font-size:14px;color:var(--ink-0);line-height:1.85}
.help-strip a{color:var(--amber);border-bottom:1px dashed var(--amber);padding:0 2px 1px}
.help-strip .hot{display:flex;flex-wrap:wrap;gap:18px;margin-top:14px;font-family:var(--mono);font-size:12px;color:var(--ink-1)}
.help-strip .hot strong{color:var(--ink-0);font-weight:500;letter-spacing:.04em}

/* ═══════════════════════════════════════════════════════
   PAGE: foundation.html / join.html
   ═══════════════════════════════════════════════════════ */
.foundation-hero,
.join-hero{
  background:
    radial-gradient(ellipse 40% 55% at 82% 35%, rgba(90,155,106,.08), transparent 70%),
    radial-gradient(ellipse 50% 60% at 20% 40%, rgba(155,58,43,.08), transparent 68%),
    var(--bg-0);
}
.foundation-hero-copy{
  margin-top:12px;max-width:66ch;
  font-family:var(--cn);font-size:14px;color:var(--ink-1);line-height:1.8;
}
.foundation-overview-section{
  background:
    linear-gradient(180deg, rgba(90,155,106,.04), transparent 38%),
    var(--bg-0);
}
.foundation-command{
  display:grid;grid-template-columns:minmax(360px,520px) minmax(0,1fr);gap:18px;align-items:stretch;
}
.foundation-pool-card{
  border:1px solid var(--line-2);background:
    linear-gradient(135deg, rgba(90,155,106,.14), rgba(197,131,45,.08) 42%, rgba(155,58,43,.1));
  padding:clamp(26px,3.4vw,40px);display:flex;flex-direction:column;justify-content:space-between;gap:28px;min-height:300px;
}
.foundation-pool-card > span{
  font-family:var(--mono);font-size:11px;color:var(--green);letter-spacing:.22em;text-transform:uppercase;
}
.foundation-pool-card > strong{
  font-family:var(--mono);font-size:clamp(38px,5vw,70px);line-height:.98;color:var(--ink-0);font-weight:800;letter-spacing:0;
}
.pool-split{display:grid;gap:12px}
.pool-split em{
  display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;
  font-style:normal;font-family:var(--cn);font-size:13px;color:var(--ink-1);
  position:relative;padding-bottom:16px;
}
.pool-split em::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:7px;background:var(--bg-3);border:1px solid var(--line);
}
.pool-split em::before{
  content:"";position:absolute;left:0;bottom:0;height:7px;width:var(--p);background:linear-gradient(90deg,var(--green),var(--amber));z-index:1;
}
.pool-split b{font-weight:500;color:var(--ink-0)}
.pool-split i{font-style:normal;font-family:var(--mono);color:var(--ink-0)}
.foundation-principles{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line);
}
.foundation-principles article,
.foundation-steps article{
  padding:22px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.018);
}
.foundation-principles span,
.foundation-steps span{
  display:block;font-family:var(--mono);font-size:11px;color:var(--rust-3);letter-spacing:.18em;margin-bottom:10px;
}
.foundation-principles strong,
.foundation-steps strong{
  display:block;font-family:var(--cn);font-size:18px;color:var(--ink-0);font-weight:600;margin-bottom:8px;
}
.foundation-principles p,
.foundation-steps p{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.75;
}
.foundation-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fund-card{
  border:1px solid var(--line-2);
  padding:clamp(26px,3.4vw,42px);background:var(--bg-1);display:flex;flex-direction:column;gap:22px;
}
.fund-card.aid{background:linear-gradient(180deg, rgba(90,155,106,.09), rgba(255,255,255,.015))}
.fund-card.dream{background:linear-gradient(180deg, rgba(197,131,45,.09), rgba(255,255,255,.015))}
.fund-head span{font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.2em;text-transform:uppercase}
.fund-head strong{display:block;margin-top:8px;font-family:var(--cn);font-size:clamp(23px,2.5vw,32px);color:var(--ink-0);font-weight:700;line-height:1.2}
.fund-card p{font-family:var(--cn);font-size:14px;color:var(--ink-1);line-height:1.9}
.fund-meter{height:10px;background:var(--bg-3);border:1px solid var(--line);position:relative;overflow:hidden}
.fund-meter span{display:block;height:100%;width:var(--p);background:linear-gradient(90deg,var(--green),var(--amber),var(--rust))}
.fund-rows{border-top:1px solid var(--line)}
.fund-rows div{display:grid;grid-template-columns:1fr auto;gap:16px;padding:11px 0;border-bottom:1px dashed var(--line)}
.fund-rows span{font-family:var(--cn);font-size:13px;color:var(--ink-1)}
.fund-rows strong{font-family:var(--mono);font-size:13px;color:var(--ink-0);font-weight:500;text-align:right}
.fund-card .btn{align-self:flex-start}
.foundation-process{display:grid;grid-template-columns:280px minmax(0,1fr);gap:28px;align-items:start}
.foundation-process-head p{
  margin-top:12px;font-family:var(--cn);font-size:13px;color:var(--ink-2);line-height:1.8;
}
.foundation-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line);
}
.foundation-donate-panel{
  display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;
  border:1px solid var(--line-2);background:linear-gradient(135deg, rgba(255,255,255,.035), rgba(90,155,106,.035));padding:28px;
}
.foundation-donate-panel h3{font-family:var(--cn);font-size:22px;font-weight:500;color:var(--ink-0);margin-top:8px}
.foundation-donate-panel p{font-family:var(--cn);font-size:13px;color:var(--ink-2);line-height:1.7;margin-top:6px}
.donate-options{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.donate-options button{
  min-width:74px;border:1px solid var(--line-2);padding:10px 14px;
  font-family:var(--mono);font-size:12px;color:var(--ink-1);background:rgba(255,255,255,.02);
}
.donate-options button.active,
.donate-options button:hover{color:#fff;border-color:var(--rust);background:var(--rust)}
.foundation-note{
  grid-column:1 / -1;font-family:var(--cn);font-size:13px;color:var(--ink-2);padding-top:12px;border-top:1px dashed var(--line);
}
.foundation-note.ok{color:var(--green)}

.join-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,460px);gap:26px;align-items:start}
.join-wizard-layout{align-items:start}
.join-wizard{
  border:1px solid var(--line-2);background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012));
  padding:clamp(22px,3vw,34px);min-height:520px;display:flex;flex-direction:column;justify-content:space-between;gap:24px;
}
.join-progress-rail{height:6px;background:var(--bg-3);border:1px solid var(--line);overflow:hidden}
.join-progress-rail span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--rust),var(--amber));transition:width .35s ease}
.join-question-shell{display:flex;flex-direction:column;gap:20px}
.join-q-meta{font-family:var(--mono);font-size:11px;color:var(--rust-3);letter-spacing:.2em;text-transform:uppercase}
.join-question-shell h3{font-family:var(--cn);font-size:clamp(24px,3vw,36px);line-height:1.35;color:var(--ink-0);font-weight:700;max-width:22ch}
.join-options{display:grid;gap:10px}
.join-options button{
  display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;text-align:left;
  padding:16px 18px;border:1px solid var(--line);background:rgba(255,255,255,.018);
  font-family:var(--cn);font-size:14px;color:var(--ink-1);line-height:1.7;transition:border-color .18s,color .18s,background .18s,transform .18s;
}
.join-options button span{
  width:24px;height:24px;display:grid;place-items:center;border:1px solid var(--line-2);
  font-family:var(--mono);font-size:11px;color:var(--ink-2);line-height:1;margin-top:1px;
}
.join-options button:hover,
.join-options button.is-selected{color:var(--ink-0);border-color:var(--rust-3);background:rgba(155,58,43,.11);transform:translateX(2px)}
.join-options button.is-selected span{border-color:var(--rust-3);color:var(--rust-3)}
.join-nav-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:18px}
.join-question{
  border:1px solid var(--line-2);background:var(--bg-1);padding:22px;
}
.join-question h3{
  font-family:var(--cn);font-size:17px;font-weight:500;color:var(--ink-0);line-height:1.55;margin-bottom:14px;
}
.join-question button{
  display:block;width:100%;text-align:left;margin-top:8px;padding:13px 14px;
  border:1px solid var(--line);background:rgba(255,255,255,.018);
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.6;
  transition:border-color .18s,color .18s,background .18s;
}
.join-question button:hover,
.join-question button.is-selected{
  color:var(--ink-0);border-color:var(--rust-3);background:rgba(155,58,43,.11);
}
.join-result-card{
  position:sticky;top:104px;border:1px solid var(--line-2);background:var(--bg-1);padding:18px;display:flex;flex-direction:column;gap:18px;
}
.join-badge-art{position:relative;overflow:hidden;border:1px solid var(--line);background:#111;aspect-ratio:16/10}
.join-badge-art img{width:100%;height:100%;object-fit:cover;filter:saturate(.94) contrast(1.04)}
.join-badge-art.css-badge{
  background:
    linear-gradient(135deg,#e8e1cf 0 62%,#c95a44 62% 72%,#161613 72% 100%);
  border:1px solid rgba(236,231,218,.46);
  box-shadow:inset 0 0 0 10px rgba(10,8,7,.08);
}
.css-badge .badge-grid{
  position:absolute;inset:0;
  background:
    linear-gradient(rgba(10,8,7,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(10,8,7,.08) 1px,transparent 1px);
  background-size:22px 22px;opacity:.55;
}
.css-badge .badge-hole{
  position:absolute;top:14px;left:50%;width:54px;height:10px;transform:translateX(-50%);
  border-radius:20px;background:rgba(10,8,7,.28);box-shadow:0 0 0 1px rgba(255,255,255,.35);
}
.css-badge .badge-brand{
  position:absolute;left:18px;top:18px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:rgba(10,8,7,.58);
}
.css-badge .badge-watermark{
  position:absolute;right:14px;bottom:-18px;font-family:var(--sans);font-size:118px;font-weight:900;line-height:.8;color:rgba(10,8,7,.08);
}
.join-badge-overlay{
  position:absolute;inset:21% 17% 13% 17%;
  display:flex;flex-direction:column;justify-content:center;gap:8px;
  color:#101014;text-shadow:0 1px 0 rgba(255,255,255,.35);
}
.join-badge-overlay .badge-k,
.join-badge-overlay em{
  font-family:var(--mono);font-size:clamp(8px,1vw,11px);letter-spacing:.16em;text-transform:uppercase;font-style:normal;color:rgba(10,10,12,.62);
}
.join-badge-overlay strong{font-family:var(--cn);font-size:clamp(18px,2.2vw,30px);font-weight:800;color:#171719;line-height:1.1}
.join-badge-overlay span:not(.badge-k){font-family:var(--cn);font-size:clamp(12px,1.35vw,17px);font-weight:600;color:#8a2d20}
.join-role-copy{padding:4px 2px}
.join-role-copy h3{font-family:var(--cn);font-size:22px;color:var(--ink-0);font-weight:600;margin-top:8px}
.join-role-copy p{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.8;margin-top:8px}
.join-result-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.join-result-actions .btn{justify-content:center}
.join-submit-note{font-family:var(--cn);font-size:12px;color:var(--ink-2);line-height:1.7}
.join-submit-note.ok{color:var(--green)}
@media (max-width:980px){
  .foundation-command,.foundation-principles,.foundation-grid,.foundation-process,.foundation-steps,.foundation-donate-panel,.join-layout{grid-template-columns:1fr}
  .join-result-card{position:relative;top:auto}
  .donate-options{justify-content:flex-start}
}
@media (max-width:560px){
  .fund-rows div{grid-template-columns:1fr}
  .fund-rows strong{text-align:left}
  .join-badge-overlay{inset:18% 14% 11% 14%}
  .join-result-actions{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════
   PAGE: bug.html
   ═══════════════════════════════════════════════════════ */
.bug-layout{display:grid;grid-template-columns: 240px 1fr;gap:32px;align-items:start}
@media (max-width:980px){.bug-layout{grid-template-columns:1fr}}
.bug-side{position:sticky;top:90px;display:flex;flex-direction:column;gap:24px}
.bug-side .group h6{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.2em;text-transform:uppercase;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.bug-side .filter{display:flex;flex-direction:column;gap:0}
.bug-side .filter a{
  padding:8px 0;font-family:var(--cn);font-size:13px;color:var(--ink-1);display:flex;justify-content:space-between;
  border-bottom:1px solid var(--line);cursor:pointer;transition:color .2s;
}
.bug-side .filter a:hover{color:var(--ink-0)}
.bug-side .filter a.on{color:var(--rust-3);border-bottom-color:var(--rust)}
.bug-side .filter a .ct{font-family:var(--mono);font-size:11px;color:var(--ink-2)}

.bug-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:13px}
.bug-table thead th{
  text-align:left;padding:12px 14px;border-bottom:1px solid var(--line-2);
  font-size:10px;color:var(--ink-1);letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  background:var(--bg-1);
}
.bug-table tbody td{padding:14px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink-1)}
.bug-table tbody tr{cursor:pointer;transition:background .2s}
.bug-table tbody tr.hot{border-left:3px solid var(--rust)}
.bug-table tbody tr:hover{background:var(--bg-1)}
.bug-table .id{color:var(--ink-2);font-size:11px;letter-spacing:.06em;width:100px}
.bug-table .title{font-family:var(--cn);font-size:14px;color:var(--ink-0);font-weight:500;line-height:1.5;max-width:480px}
.bug-table .title .gloss{display:block;font-family:var(--mono);font-size:11px;color:var(--ink-2);margin-top:4px;letter-spacing:.04em;font-weight:400}
.bug-table .uid{color:var(--ink-2);font-size:11px;letter-spacing:.06em;width:140px}
.bug-table .sev{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;width:100px}
.bug-table .sev.high{color:var(--rust-3)}
.bug-table .sev.mid{color:var(--amber)}
.bug-table .sev.low{color:var(--ink-1)}
.bug-table .status{font-size:10px;letter-spacing:.16em;text-transform:uppercase;width:140px}
.bug-table .status .pill{display:inline-block;padding:3px 8px;border:1px solid currentColor;font-weight:500}
.bug-table .status.wai{color:var(--amber)}
.bug-table .status.wf{color:var(--ink-2)}
.bug-table .status.ack{color:var(--blue)}
.bug-table .status.dup{color:var(--ink-2)}
.bug-table .status.open{color:var(--green)}
.bug-table .votes{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-0);font-size:12px;width:80px}
.bug-table .votes .small{display:block;font-size:10px;color:var(--ink-2);letter-spacing:.04em;margin-top:2px}
@media (max-width:760px){
  .bug-table .uid,.bug-table .sev{display:none}
}

.bug-detail{
  margin-top:32px;padding:28px;background:var(--bg-1);border:1px solid var(--line-2);
}
.bug-detail .head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:14px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.bug-detail .head .id{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.14em}
.bug-detail .head .title{font-family:var(--cn);font-weight:500;font-size:22px;color:var(--ink-0)}
.bug-detail .grid{display:grid;grid-template-columns: 1fr 1fr;gap:24px}
@media (max-width:680px){.bug-detail .grid{grid-template-columns:1fr}}
.bug-detail .grid h6{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.bug-detail .grid p{font-family:var(--cn);font-size:13.5px;color:var(--ink-0);line-height:1.8}
.bug-detail .reply{margin-top:24px;padding:18px;background:rgba(255,255,255,.02);border-left:2px solid var(--amber)}
.bug-detail .reply .by{font-family:var(--mono);font-size:11px;color:var(--amber);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.bug-detail .reply p{font-family:var(--cn);font-size:13px;color:var(--ink-0);line-height:1.8}

/* —— 反馈提交 CTA —— */
.bug-cta{
  position:relative;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;
  padding:32px 36px;border:1px solid var(--rust-edge);
  background:
    linear-gradient(180deg, rgba(155,58,43,.10) 0%, rgba(155,58,43,.02) 100%),
    var(--bg-1);
}
.bug-cta::before{
  content:"";position:absolute;top:-1px;left:-1px;width:64px;height:2px;background:var(--rust);
}
.bug-cta::after{
  content:"";position:absolute;top:-1px;right:-1px;width:8px;height:8px;
  border-top:1px solid var(--rust);border-right:1px solid var(--rust);
}
.bug-cta-tag{
  position:absolute;top:-9px;left:24px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--rust-3);
  background:var(--bg-0);padding:2px 10px;text-transform:uppercase;
}
.bug-cta-eyebrow{
  font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:10px;
}
.bug-cta-title{
  font-size:clamp(22px,2.6vw,30px);line-height:1.25;margin:0;font-weight:500;letter-spacing:0;
}
.bug-cta-title .zh{font-family:var(--cn);font-weight:500}
.bug-cta-title .accent{color:var(--rust-3)}
.bug-cta-lead{
  font-family:var(--cn);font-weight:300;font-size:14px;color:var(--ink-1);
  line-height:1.75;margin-top:14px;max-width:60ch;
}
.bug-cta-tips{
  list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:6px;
}
.bug-cta-tips li{
  font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.6;
  display:flex;gap:10px;align-items:baseline;
}
.bug-cta-tips .n{
  font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.14em;
  border:1px solid var(--rust-edge);padding:1px 6px;flex-shrink:0;
}
.bug-cta-action{display:flex;flex-direction:column;align-items:flex-end;gap:18px;min-width:220px}
.bug-cta-btn{font-size:13px;padding:18px 28px;letter-spacing:.16em}
.bug-cta-meta{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.04em;
  display:flex;flex-direction:column;gap:4px;text-align:right;line-height:1.7;
}
.bug-cta-meta .v{color:var(--ink-0)}
@media (max-width:780px){
  .bug-cta{grid-template-columns:1fr;padding:28px 24px;gap:28px}
  .bug-cta-action{align-items:stretch;min-width:0}
  .bug-cta-btn{justify-content:center}
  .bug-cta-meta{text-align:left}
}

/* —— 列表上方提示条 —— */
.bug-list-hint{
  display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;
  border-left:2px solid var(--amber);background:rgba(197,131,45,.05);
  font-family:var(--cn);font-size:12.5px;color:var(--ink-1);
}
.bug-list-hint .dot{
  width:6px;height:6px;border-radius:50%;background:var(--amber);flex-shrink:0;
  animation:pulseAmber 2.4s ease-in-out infinite;
}

/* —— 侧栏底部"再次提交"提示块 —— */
.bug-side-tip{padding-top:6px;border-top:1px dashed var(--line-2)}
.bug-side-tip h6{color:var(--ink-1)!important;border-bottom:0!important;padding-bottom:0!important;margin-bottom:10px!important}

/* ═══════════════════════════════════════════════════════
   PAGE: task.html
   ═══════════════════════════════════════════════════════ */
.task-tabs{display:flex;gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:32px}
.task-tab{
  padding:18px 24px;border-right:1px solid var(--line);
  font-family:var(--mono);font-size:12px;color:var(--ink-1);letter-spacing:.18em;text-transform:uppercase;
  cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:10px;
}
.task-tab:hover{color:var(--ink-0)}
.task-tab.on{color:var(--rust-3);background:var(--rust-soft)}
.task-tab .ct{font-family:var(--mono);font-size:10px;color:var(--ink-2)}
.task-tab.on .ct{color:var(--rust-3)}
@media (max-width:760px){
  .task-tabs{max-width:100%;overflow-x:auto;overscroll-behavior-x:contain}
  .task-tab{flex:0 0 auto;padding:14px 16px}
}

.task-grid{display:grid;grid-template-columns: repeat(3, 1fr);gap:20px}
@media (max-width:1080px){.task-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.task-grid{grid-template-columns:1fr}}
.task-card{
  background:var(--bg-1);border:1px solid var(--line);padding:22px;
  display:flex;flex-direction:column;gap:14px;
  transition:border-color .25s, transform .25s;
  position:relative;overflow:hidden;
}
.task-card:hover{border-color:var(--rust);transform:translateY(-2px)}
.task-card .meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase}
.task-card .meta .type{color:var(--rust-3)}
.task-card .title{font-family:var(--cn);font-size:17px;font-weight:500;color:var(--ink-0);line-height:1.4}
.task-card .by{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.04em;display:flex;justify-content:space-between}
.task-card .diff{color:var(--amber)}
.task-card .reward{
  padding:10px 12px;background:var(--bg-2);border:1px dashed var(--line-2);
  font-family:var(--cn);font-size:12px;color:var(--ink-1);
}
.task-card .reward strong{color:var(--ink-0);font-weight:500}
.task-card .actions{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:8px;border-top:1px dashed var(--line)}
.task-card .actions .ct{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.04em}

/* —— 任务页粘性子导航 —— */
.quest-nav{
  position:sticky;top:0;z-index:30;
  background:rgba(13,13,16,.94);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);
}
.quest-nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);
  display:flex;gap:8px;align-items:center;height:54px;overflow-x:auto;
}
.quest-nav a{
  display:flex;align-items:center;gap:10px;padding:8px 14px;
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.16em;text-transform:uppercase;
  white-space:nowrap;transition:color .2s;border-bottom:2px solid transparent;
}
.quest-nav a:hover{color:var(--ink-0)}
.quest-nav a.active{color:var(--rust-3);border-bottom-color:var(--rust)}
.quest-nav a .n{font-size:10px;color:var(--ink-3);font-weight:600}
.quest-nav a.active .n{color:var(--rust-3)}
.quest-nav-spacer{flex:1}
.quest-nav-shop{
  border:1px solid var(--rust-edge);color:var(--rust-3)!important;
  padding:7px 14px!important;border-bottom:1px solid var(--rust-edge)!important;
}
.quest-nav-shop:hover{background:var(--rust-soft);border-color:var(--rust)!important}
.quest-nav-shop.active{background:var(--rust);color:#fff!important;border-color:var(--rust)!important}

/* —— 货币徽章 —— */
.coin{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:13px;font-variant-numeric:tabular-nums;letter-spacing:.04em;
}
.coin .ic{
  display:inline-grid;place-items:center;width:20px;height:20px;
  border:1px solid currentColor;font-size:10px;font-weight:600;
  font-family:var(--cn);
}
.coin .n{font-weight:500}
.coin.coin-dirt{color:#b5894a}      /* 土：暖棕 */
.coin.coin-stone{color:#9aa0a6}     /* 石：冷灰 */
.coin.coin-brick{color:var(--rust-3)} /* 砖：锈红 */
.coin.inline{font-size:11px}
.coin.inline .ic{width:16px;height:16px;font-size:9px}
.coin-eq{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.06em;
  margin-left:8px;
}
.coin-mini{
  display:inline-grid;place-items:center;width:16px;height:16px;
  border:1px solid currentColor;font-family:var(--cn);font-size:9px;font-weight:600;
}
.coin-mini.coin-dirt{color:#b5894a}
.coin-mini.coin-stone{color:#9aa0a6}
.coin-mini.coin-brick{color:var(--rust-3)}

/* —— ② 系统每日委托 —— */
.daily-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
@media (max-width:780px){.daily-grid{grid-template-columns:1fr}}
.daily-card{
  position:relative;padding:28px 28px 24px;background:var(--bg-1);
  border:1px solid var(--line-2);overflow:hidden;
  display:flex;flex-direction:column;gap:14px;
}
.daily-card::before{
  content:"";position:absolute;top:0;left:0;width:48px;height:2px;background:var(--amber);
}
.dc-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}
.dc-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--amber);
}
.dc-tag.rotate{color:var(--ink-1)}
.dc-time{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.06em}
.dc-title{
  font-family:var(--cn);font-weight:500;font-size:24px;color:var(--ink-0);line-height:1.3;
  letter-spacing:0;
}
.dc-sub{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7}
.dc-foot{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  margin-top:auto;padding-top:14px;border-top:1px dashed var(--line);
}
.dc-reward{display:flex;align-items:center;gap:10px}
.dc-reward-label{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase}

/* —— 连签条 —— */
.daily-streak{margin-top:32px;padding:20px 24px;background:var(--bg-1);border:1px solid var(--line)}
.streak-bar{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.streak-label{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.22em;text-transform:uppercase}
.streak-dots{display:flex;gap:6px}
.streak-dots .d{
  width:28px;height:28px;display:grid;place-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:.04em;
  border:1px solid var(--line-2);color:var(--ink-2);
}
.streak-dots .d.done{border-color:var(--green);color:var(--green);background:rgba(90,155,106,.08)}
.streak-dots .d.today{border-color:var(--amber);color:var(--amber);background:rgba(197,131,45,.08);animation:pulseAmber 2.4s ease-in-out infinite}
.streak-tail{font-family:var(--cn);font-size:13px;color:var(--ink-1);flex:1;min-width:200px}
.streak-note{
  margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);
  font-family:var(--cn);font-size:12.5px;color:var(--ink-2);line-height:1.7;
}
.streak-note .coin{margin:0 4px}

/* —— ③ 主线/支线 卡片 —— */
.goal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:1080px){.goal-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.goal-grid{grid-template-columns:1fr}}
.goal-card{
  position:relative;padding:22px;background:var(--bg-1);border:1px solid var(--line);
  display:flex;flex-direction:column;gap:14px;transition:border-color .2s, transform .2s;
}
.goal-card:hover{border-color:var(--ink-1);transform:translateY(-2px)}
.goal-card.mainline{border-left:3px solid var(--rust)}
.goal-card.sideline{border-left:3px solid var(--amber)}
.gc-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.gtype{color:var(--rust-3)}
.gprog{color:var(--ink-1);font-variant-numeric:tabular-nums}
.gtitle{font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);line-height:1.4}
.gnote{font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.7}
.gbar{position:relative;width:100%;height:3px;background:var(--line);overflow:hidden}
.gbar-fill{position:absolute;inset:0;width:var(--gp,50%);background:var(--rust);transition:width .4s}
.gc-foot{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:auto;padding-top:14px;border-top:1px dashed var(--line)}
.gr-text{font-family:var(--cn);font-size:11.5px;color:var(--ink-1);letter-spacing:.02em}

/* —— 空卡片（"+ 新建" 占位） —— */
.empty-card{
  border:1px dashed var(--line-2)!important;background:transparent!important;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  min-height:200px;cursor:pointer;transition:all .25s;text-align:center;padding:24px;
}
.empty-card:hover{border-color:var(--rust)!important;background:var(--rust-soft)!important;transform:translateY(-2px)}
.empty-plus{font-family:var(--mono);font-size:32px;color:var(--ink-2);font-weight:300;line-height:1}
.empty-card:hover .empty-plus{color:var(--rust-3)}
.empty-text{font-family:var(--cn);font-size:14px;color:var(--ink-1)}
.empty-card:hover .empty-text{color:var(--ink-0)}
.empty-hint{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase}

/* —— ④ 悬赏抽成提醒条 —— */
.bounty-fee-note{
  display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;
  padding:20px 24px;margin-bottom:28px;
  background:linear-gradient(180deg, rgba(155,58,43,.08) 0%, rgba(155,58,43,.02) 100%);
  border:1px solid var(--rust-edge);border-left-width:3px;
}
.bounty-fee-note .fn-icon{
  width:36px;height:36px;display:grid;place-items:center;
  border:1px solid var(--rust);color:var(--rust-3);font-size:18px;
}
.fn-title{
  font-family:var(--mono);font-size:11px;color:var(--rust-3);letter-spacing:.22em;text-transform:uppercase;margin-bottom:8px;
}
.fn-text{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.75;margin:0}
.fn-text strong{color:var(--ink-0);font-weight:500}
.fn-tail{
  font-family:var(--cn);font-size:11.5px;color:var(--ink-2);line-height:1.6;margin:8px 0 0;
  padding-top:8px;border-top:1px dashed var(--line);font-style:italic;
}

/* —— 层级说明小字 —— */
.layer-note{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7;
  padding:14px 18px;background:rgba(255,255,255,.02);border-left:2px solid var(--ink-2);
}
.layer-note strong{color:var(--ink-0);font-weight:500}

/* —— task.html 落地页底部"另外两个房间"入口卡 —— */
.quest-jump-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:18px}
@media (max-width:780px){.quest-jump-grid{grid-template-columns:1fr}}
.quest-jump{
  position:relative;padding:32px 32px 26px;background:var(--bg-1);
  border:1px solid var(--line-2);transition:all .25s;overflow:hidden;
  display:flex;flex-direction:column;gap:14px;
}
.quest-jump::after{
  content:"";position:absolute;top:0;left:0;width:0;height:2px;
  background:var(--rust);transition:width .35s ease;
}
.quest-jump:hover{border-color:var(--rust);transform:translateY(-3px)}
.quest-jump:hover::after{width:100%}
.qj-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--rust-3);text-transform:uppercase;
}
.qj-title{
  font-family:var(--cn);font-weight:500;font-size:24px;color:var(--ink-0);
  line-height:1.3;letter-spacing:0;
}
.qj-desc{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.75;flex:1;
}
.qj-desc strong{color:var(--ink-0);font-weight:500}
.qj-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px dashed var(--line);
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}
.quest-jump:hover .qj-foot{color:var(--rust-3)}
.qj-foot .arr{font-size:14px;letter-spacing:0;transition:transform .25s}
.quest-jump:hover .qj-foot .arr{transform:translate(4px,-4px)}

/* ═══════════════════════════════════════════════════════
   PAGE: shop.html
   ═══════════════════════════════════════════════════════ */

/* —— 钱包入口按钮（shop.html hero 右上角） —— */
.shop-wallet-entry{
  display:inline-flex;align-items:center;gap:12px;justify-self:end;
  padding:12px 20px;border:1px solid var(--rust);
  background:var(--rust-soft);color:var(--rust-3);
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;transition:all .25s;white-space:nowrap;
}
.shop-wallet-entry:hover{background:var(--rust);color:#fff}
.shop-wallet-entry .swe-icon{
  font-size:14px;letter-spacing:0;line-height:1;
  display:inline-grid;place-items:center;
}
.shop-wallet-entry .swe-arr{
  font-size:13px;letter-spacing:0;line-height:1;
  transition:transform .2s;
}
.shop-wallet-entry:hover .swe-arr{transform:translateX(3px)}
.shop-hero-panel{
  justify-self:end;display:flex;flex-direction:column;align-items:flex-end;gap:10px;min-width:0;
}
.shop-hero-panel .stat{justify-content:flex-end}
@media (max-width:760px){
  .shop-hero-panel{justify-self:stretch;align-items:flex-start}
  .shop-hero-panel .stat{justify-content:flex-start;text-align:left}
  .shop-wallet-entry{justify-self:start}
}
.shop-catalog-section{padding-top:clamp(28px,3vw,44px)}

/* —— 三货币柜台 —— */
.vault-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:32px;
}
@media (max-width:980px){.vault-grid{grid-template-columns:1fr}}
.vault-card{
  position:relative;padding:28px 28px 24px;background:var(--bg-1);
  border:1px solid var(--line-2);overflow:hidden;
  display:flex;flex-direction:column;gap:18px;
}
.vault-card.dirt{border-top:2px solid #b5894a}
.vault-card.stone{border-top:2px solid #9aa0a6}
.vault-card.brick{border-top:2px solid var(--rust);background:linear-gradient(180deg,rgba(155,58,43,.06) 0%,var(--bg-1) 100%)}

.vc-head{display:flex;align-items:center;gap:16px}
.coin.big .ic{width:40px;height:40px;font-size:20px;font-weight:600}
.vc-name h3{
  font-family:var(--cn);font-weight:500;font-size:20px;color:var(--ink-0);
  margin:0;line-height:1.2;
}
.vc-tag{
  display:inline-block;margin-top:4px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}
.vc-balance{
  font-family:var(--mono);font-weight:300;font-size:56px;
  color:var(--ink-0);letter-spacing:0;line-height:1;
  font-variant-numeric:tabular-nums;
}
.vault-card.brick .vc-balance{color:var(--rust-3)}
.vc-meta{
  display:flex;flex-direction:column;gap:6px;
  padding-top:14px;border-top:1px dashed var(--line);
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;
}
.vc-meta > div{display:flex;justify-content:space-between;gap:14px}
.vc-meta .k{color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase;font-size:10px}
.vc-meta .v{color:var(--ink-1);text-align:right}
.vc-action{margin-top:auto}
.vc-action.ghost{
  display:inline-block;text-align:center;padding:11px 18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-2);border:1px dashed var(--line-3);cursor:default;
}

/* —— 兑换链 —— */
.exchange-loop{
  margin-top:36px;padding:28px 32px;background:var(--bg-1);
  border:1px solid var(--line-2);
}
.el-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line);
  flex-wrap:wrap;gap:8px;
}
.el-eyebrow{
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  letter-spacing:.22em;text-transform:uppercase;
}
.el-warn{
  font-family:var(--mono);font-size:10px;color:var(--rust-3);
  letter-spacing:.18em;text-transform:uppercase;
  padding:3px 10px;border:1px solid var(--rust-edge);
}
.el-rows{display:flex;flex-direction:column;gap:14px}
.el-row{
  display:grid;grid-template-columns:36px 1fr 24px 1fr;gap:18px;align-items:center;
  font-family:var(--cn);font-size:13px;color:var(--ink-1);
}
@media (max-width:680px){
  .el-row{grid-template-columns:32px 1fr;gap:10px}
  .el-row .el-arrow{display:none}
  .el-row .el-from{grid-column:2}
  .el-row .el-to{grid-column:2;font-size:12px;color:var(--ink-2)}
}
.el-coin .ic{width:28px;height:28px;font-size:13px}
.el-from{color:var(--ink-2);font-size:12.5px}
.el-arrow{color:var(--rust-3);font-family:var(--mono);text-align:center}
.el-to strong{color:var(--ink-0);font-weight:500}
.el-note{
  margin-top:18px;padding-top:14px;border-top:1px dashed var(--line);
  font-family:var(--cn);font-size:12.5px;color:var(--ink-2);line-height:1.75;
}
.el-note strong{color:var(--ink-0);font-weight:500}

/* —— 砖块提现窗口 —— */
.cashout-card{
  margin-top:28px;position:relative;
  border:1px solid var(--rust);
  background:linear-gradient(180deg, rgba(155,58,43,.08) 0%, var(--bg-1) 100%);
}
.cc-tag{
  position:absolute;top:-1px;left:0;
  font-family:var(--mono);font-size:10px;color:#fff;letter-spacing:.22em;
  background:var(--rust);padding:5px 14px;text-transform:uppercase;
}
.cc-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;padding:42px 32px 28px;
}
@media (max-width:780px){.cc-grid{grid-template-columns:1fr;padding:42px 24px 24px}}
.cc-side{display:flex;flex-direction:column;gap:14px}
.cc-row{display:flex;align-items:center;justify-content:space-between;gap:14px}
.cc-label{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}
.cc-input-wrap{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end}
.cc-input{
  width:80px;padding:8px 12px;text-align:right;
  background:transparent;border:1px solid var(--line-3);
  font-family:var(--mono);font-size:18px;color:var(--ink-0);
  font-variant-numeric:tabular-nums;
}
.cc-input:focus{outline:0;border-color:var(--rust)}
.cc-coin .ic{width:24px;height:24px;font-size:11px}
.cc-arrow{
  text-align:center;font-family:var(--mono);font-size:18px;color:var(--rust-3);
  letter-spacing:.04em;padding:4px 0;
}
.cc-result{
  font-family:var(--mono);font-weight:300;font-size:32px;color:var(--rust-3);
  letter-spacing:0;font-variant-numeric:tabular-nums;
}
.cc-btn{margin-top:18px;justify-content:center}
.cc-fine{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.75}
.cc-fine h6{
  font-family:var(--mono);font-size:11px;color:var(--rust-3);
  letter-spacing:.22em;text-transform:uppercase;font-weight:500;margin-bottom:8px;
}
.cc-fine p{margin:0 0 10px}
.cc-fine strong{color:var(--ink-0);font-weight:500}
.cc-fine-tail{
  padding-top:10px;border-top:1px dashed var(--line);
  font-size:12px;color:var(--ink-2);font-style:italic;
}

/* —— 商品卡 —— */
.product-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
@media (max-width:1080px){.product-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.product-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.product-grid{grid-template-columns:1fr}}

.product-card{
  position:relative;padding:18px 20px;background:var(--bg-1);
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:10px;overflow:hidden;
  transition:border-color .25s, transform .25s;
}
.product-card:hover{border-color:var(--rust);transform:translateY(-2px)}
.product-card.featured{border-color:var(--amber);background:rgba(197,131,45,.04)}
.product-card.featured::before{
  content:"";position:absolute;top:0;left:0;width:48px;height:2px;background:var(--amber);
}
.product-card.limited{border-style:dashed;background:rgba(255,255,255,.02)}
.product-card.limited:hover{border-color:var(--ink-1)}

.pc-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.pc-cat{
  font-family:var(--mono);font-size:10px;color:var(--rust-3);
  letter-spacing:.18em;text-transform:uppercase;
}
.product-card.featured .pc-cat{color:var(--amber)}
.product-card.limited .pc-cat{color:var(--ink-2)}
.pc-stock{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.06em;
}
.pc-name{
  font-family:var(--cn);font-weight:500;font-size:15.5px;color:var(--ink-0);
  line-height:1.4;margin:0;
}
.pc-eff{
  display:inline-block;margin-left:4px;
  font-family:var(--mono);font-size:11px;color:var(--ink-1);font-weight:400;
  letter-spacing:.04em;
}
.pc-desc{
  font-family:var(--cn);font-size:12px;color:var(--ink-1);line-height:1.65;
  margin:0;flex:1;
}
.pc-price{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding-top:10px;border-top:1px dashed var(--line);
}
.pc-price-old{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.04em;text-decoration:line-through;
}
.pc-btn{align-self:stretch;justify-content:center}
.pc-btn-disabled{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 18px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-2);border:1px dashed var(--line-3);cursor:default;
}
.coin-locked{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.04em;
}

/* —— 已售罄区 —— */
.soldout-intro,.soldout-bottom{
  font-family:var(--cn);font-size:13px;color:var(--ink-2);line-height:1.75;
  margin:0 0 20px;padding:14px 18px;
  background:rgba(0,0,0,.2);border-left:2px solid var(--ink-3);
}
.soldout-bottom{margin:24px 0 0;font-style:italic}
.soldout-grid .product-card.soldout{
  background:rgba(0,0,0,.25);border-color:var(--line);
  border-style:dashed;cursor:default;
}
.soldout-grid .product-card.soldout:hover{
  border-color:var(--line-2);transform:none;
}
.product-card.soldout .pc-cat{color:var(--ink-3)}
.product-card.soldout .pc-name{color:var(--ink-2);text-decoration:line-through;text-decoration-color:var(--ink-3);text-decoration-thickness:1px}
.product-card.soldout .pc-desc{color:var(--ink-3)}
.pc-stock-sold{
  color:var(--rust-3)!important;
  font-weight:600;letter-spacing:.18em!important;
}
.pc-price-strike{
  font-family:var(--mono);font-size:13px;color:var(--ink-3);
  text-decoration:line-through;letter-spacing:.04em;
}
.pc-soldout-stamp{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(-12deg);
  font-family:var(--mono);font-weight:600;font-size:34px;
  color:var(--rust);letter-spacing:.12em;
  border:3px solid var(--rust);padding:4px 18px;
  pointer-events:none;opacity:.32;
  text-transform:uppercase;
}

/* ═══════════════════════════════════════════════════════
   PAGE: review.html
   ═══════════════════════════════════════════════════════ */
.rv-top{
  display:grid;grid-template-columns: 320px 1fr;gap:48px;
  padding:32px;background:var(--bg-1);border:1px solid var(--line);
  margin-bottom:32px;align-items:center;
}
.rv-top .score{text-align:center;border-right:1px solid var(--line);padding-right:32px}
.rv-top .score .num{font-family:var(--sans);font-weight:700;font-size:96px;line-height:1;color:var(--green);letter-spacing:0}
.rv-top .score .deno{font-family:var(--mono);font-size:13px;color:var(--ink-1);margin-top:4px;letter-spacing:.1em}
.rv-top .score .lab{margin-top:18px;display:inline-block;font-family:var(--cn);font-weight:500;font-size:14px;color:var(--green);padding:6px 16px;border:1px solid var(--green)}
.rv-top .score .ct{font-family:var(--mono);font-size:11px;color:var(--ink-2);margin-top:14px;letter-spacing:.06em}

.rv-bars{display:flex;flex-direction:column;gap:10px}
.rv-bar{display:grid;grid-template-columns: 60px 1fr 80px;align-items:center;gap:16px;font-family:var(--mono);font-size:11px;color:var(--ink-1)}
.rv-bar .stars{color:var(--amber);letter-spacing:0;font-size:13px}
.rv-bar .track{height:8px;background:var(--bg-3);position:relative;overflow:hidden}
.rv-bar .track .fill{position:absolute;inset:0;background:var(--green);width:var(--p,0)}
.rv-bar.bad .track .fill{background:var(--rust)}
.rv-bar.mid .track .fill{background:var(--amber)}
.rv-bar .pct{text-align:right;color:var(--ink-0);font-variant-numeric:tabular-nums}

.subpage-h .rv-hero-scorecard{
  justify-self:end;width:min(100%,640px);
  grid-template-columns:112px minmax(300px,1fr);gap:18px;
  padding:0;margin:0;background:transparent;border:0;align-items:center;
}
.subpage-h .rv-hero-scorecard > div:not(.score):not(.rv-bars){display:none}
.subpage-h .rv-hero-scorecard .score{
  padding-right:16px;border-right:1px solid var(--line);text-align:center;
}
.subpage-h .rv-hero-scorecard .score .num{font-size:46px}
.subpage-h .rv-hero-scorecard .score .deno{font-size:9px;margin-top:2px;letter-spacing:.08em}
.subpage-h .rv-hero-scorecard .score .lab{
  margin-top:8px;padding:3px 8px;font-size:11px;
}
.subpage-h .rv-hero-scorecard .score .ct{
  margin-top:7px;font-size:8px;letter-spacing:.04em;white-space:nowrap;
}
.subpage-h .rv-hero-scorecard .rv-bars{gap:6px}
.subpage-h .rv-hero-scorecard .rv-bar{
  grid-template-columns:54px minmax(160px,1fr) 46px;gap:8px;font-size:9px;
}
.subpage-h .rv-hero-scorecard .rv-bar .stars{font-size:10px}
.subpage-h .rv-hero-scorecard .rv-bar .track{height:5px}

.rv-tags-row{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;
  padding:24px 32px;background:var(--bg-1);border:1px solid var(--line);
}
.rv-tags-row .lab{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.18em;text-transform:uppercase;margin-right:14px;align-self:center}
.rv-tag{font-family:var(--cn);font-size:12px;color:var(--ink-1);padding:6px 12px;border:1px solid var(--line-2);cursor:pointer;transition:all .2s}
.rv-tag:hover{color:var(--ink-0);border-color:var(--ink-0)}
.rv-tag.hot{color:var(--rust-3);border-color:var(--rust)}
.rv-list-head{
  display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px;
}
.rv-list-head .hr-tick{margin-bottom:0}
.rv-publish-btn{flex-shrink:0}

.rv-grid{display:grid;grid-template-columns: repeat(2, 1fr);gap:24px}
@media (max-width:880px){.rv-grid{grid-template-columns:1fr}}
.rv-card{
  background:var(--bg-1);border:1px solid var(--line);padding:24px;
  display:flex;flex-direction:column;gap:14px;
  transition:border-color .25s;position:relative;
}
.rv-card:hover{border-color:var(--line-3)}
.rv-card .badge{position:absolute;top:0;right:0;font-family:var(--mono);font-size:10px;padding:3px 8px;letter-spacing:.14em;text-transform:uppercase}
.rv-card.veteran .badge{background:var(--amber);color:#000}
.rv-card.young .badge{background:var(--blue);color:#fff}
.rv-card.dead{opacity:.55;filter:grayscale(.6)}
.rv-card.dead .badge{background:var(--ink-2);color:#000}
.rv-vote{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500}
.rv-vote.up{color:var(--green)}
.rv-vote.down{color:var(--rust-3)}
.rv-vote svg{width:14px;height:14px}
.rv-stars{font-family:var(--mono);color:var(--amber);font-size:13px}
.rv-time{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.04em;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rv-time .v{color:var(--ink-1)}
.rv-body{font-family:var(--cn);font-size:14px;color:var(--ink-0);line-height:1.75;flex:1}
.rv-foot{display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:14px;border-top:1px dashed var(--line);font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.04em}
.rv-foot .uid{color:var(--ink-1)}
.rv-reply{padding:12px;background:rgba(255,255,255,.03);border-left:2px solid var(--amber);font-family:var(--cn);font-size:13px;color:var(--ink-0);line-height:1.75}
.rv-reply .by{font-family:var(--mono);font-size:11px;color:var(--amber);letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;display:block}
.rv-load-wrap{
  display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:48px;
}
.rv-load-wrap .btn[disabled]{
  opacity:.46;cursor:not-allowed;filter:saturate(.55);
}
.rv-load-status{
  min-height:18px;font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;text-align:center;
}
.rv-load-status.ok{color:var(--green)}
.rv-load-status.warn{color:var(--amber)}
.rv-load-status.done{color:var(--ink-3)}
.rv-load-sentinel{height:1px}

.rv-publish-shell{
  display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:start;
}
.rv-publish-card{
  border:1px solid var(--line);background:var(--bg-1);padding:28px;display:flex;flex-direction:column;gap:18px;
}
.rv-profile-snapshot{
  display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);background:var(--bg-0);
}
.rv-profile-snapshot>div{
  min-height:92px;padding:16px 18px;display:flex;flex-direction:column;justify-content:center;gap:6px;
}
.rv-profile-snapshot>div:first-child{border-right:1px solid var(--line)}
.rv-profile-snapshot span{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.16em;text-transform:uppercase;
}
.rv-profile-snapshot strong{
  font-family:var(--mono);font-size:20px;color:var(--ink-0);font-weight:600;line-height:1.2;
}
.rv-profile-snapshot em{
  font-style:normal;font-family:var(--mono);font-size:11px;color:var(--ink-2);line-height:1.5;
}
.rv-publish-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.rv-field{display:flex;flex-direction:column;gap:8px}
.rv-field.full{grid-column:1/-1}
.rv-field label{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.16em;text-transform:uppercase;
}
.rv-label-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.rv-label-row span:last-child{color:var(--ink-3);letter-spacing:.08em}
.rv-input,.rv-select,.rv-textarea{
  width:100%;background:var(--bg-0);border:1px solid var(--line);color:var(--ink-0);outline:none;
  font-family:var(--cn);font-size:14px;padding:12px 14px;
}
.rv-textarea{min-height:220px;resize:vertical;line-height:1.75}
.rv-textarea::placeholder{color:var(--ink-2);opacity:1}
.rv-input:focus,.rv-select:focus,.rv-textarea:focus{border-color:var(--rust)}
.rv-segment{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);background:var(--bg-0)}
.rv-segment label{position:relative;display:block}
.rv-segment input,.rv-star-select input{position:absolute;opacity:0;pointer-events:none}
.rv-segment span{
  display:flex;align-items:center;justify-content:center;min-height:44px;font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);border-right:1px solid var(--line);cursor:pointer;
}
.rv-segment label:last-child span{border-right:0}
.rv-segment input:checked + span{color:var(--ink-0);background:rgba(255,255,255,.04)}
.rv-segment input[value="up"]:checked + span{color:var(--green)}
.rv-segment input[value="down"]:checked + span{color:var(--rust-3)}
.rv-star-select{
  display:flex;align-items:center;gap:4px;flex-wrap:wrap;min-height:44px;
}
.rv-star-btn{
  width:30px;height:36px;border:0;padding:0;display:grid;place-items:center;
  font-family:var(--mono);font-size:28px;line-height:1;color:#4a4031;cursor:pointer;background:transparent;
  text-shadow:0 1px 0 #000;transition:color .14s ease,filter .14s ease,transform .14s ease;
}
.rv-star-btn:focus{outline:none}
.rv-star-btn:focus-visible{outline:none;color:var(--amber);filter:drop-shadow(0 0 9px rgba(197,131,45,.28))}
.rv-star-btn:hover{color:var(--amber);filter:brightness(1.08);transform:translateY(-1px)}
.rv-star-btn.is-on{color:var(--amber);filter:drop-shadow(0 0 8px rgba(197,131,45,.14))}
.rv-publish-status{
  min-height:20px;font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.08em;
}
.rv-form-actions{
  display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:4px;
}
.rv-form-actions>span{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.08em;line-height:1.6}
.rv-publish-card .btn:disabled{opacity:.42;cursor:not-allowed;filter:saturate(.5)}
.rv-publish-side{
  border-top:1px solid var(--line-2);padding-top:18px;display:flex;flex-direction:column;gap:14px;
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7;
}
.rv-publish-side .k{font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.18em;text-transform:uppercase}
.rv-publish-side strong{font-family:var(--mono);font-size:22px;color:var(--ink-0);font-weight:600}
.rv-profile-link{
  width:max-content;font-family:var(--mono);font-size:10px;color:var(--green);letter-spacing:.14em;text-transform:uppercase;
  border-bottom:1px solid rgba(98,168,120,.4);padding-bottom:3px;
}

@media (max-width:680px){
  .rv-top{grid-template-columns:1fr;gap:22px;padding:22px;margin-bottom:24px}
  .rv-top .score{border-right:0;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:20px}
  .rv-top .score .num{font-size:76px}
  .rv-bar{grid-template-columns:58px minmax(0,1fr) 54px;gap:10px}
  .rv-bar .stars{font-size:12px}
  .rv-tags-row{padding:18px;margin-bottom:24px}
  .rv-list-head{align-items:stretch;flex-direction:column}
  .rv-publish-btn{justify-content:center}
  .rv-card{padding:20px}
  .rv-foot{align-items:flex-start;flex-direction:column}
  .rv-publish-shell{grid-template-columns:1fr}
  .rv-publish-card{padding:22px}
  .rv-profile-snapshot{grid-template-columns:1fr}
  .rv-profile-snapshot>div:first-child{border-right:0;border-bottom:1px solid var(--line)}
  .rv-form-actions{align-items:stretch;flex-direction:column}
  .rv-publish-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  .subpage-h .rv-hero-scorecard{
    justify-self:stretch;grid-template-columns:1fr;gap:14px;margin-top:6px;
  }
  .subpage-h .rv-hero-scorecard .score{
    border-right:0;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:12px;
  }
  .subpage-h .rv-hero-scorecard .score .num{font-size:54px}
  .subpage-h .rv-hero-scorecard .rv-bar{
    grid-template-columns:58px minmax(0,1fr) 54px;
  }
}

/* ═══════════════════════════════════════════════════════
   PAGE: world.html
   ═══════════════════════════════════════════════════════ */
.wq-card{
  border:1px solid var(--line-2);background:var(--bg-1);
  padding: clamp(28px, 4vw, 48px);
  position:relative;
  display:grid;grid-template-columns: 1.4fr 1fr;gap:48px;
}
.wq-card::after{content:"";position:absolute;top:0;left:0;height:3px;width:var(--wp, 47.3%);background:var(--rust)}
.wq-meta{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.18em;text-transform:uppercase;display:flex;align-items:center;gap:12px}
.wq-meta .pip{width:6px;height:6px;background:var(--rust);border-radius:50%;animation:pulseRust 2.4s ease-in-out infinite}
.wq-name{font-family:var(--cn);font-weight:500;font-size:clamp(28px,3.4vw,46px);line-height:1.1;margin-top:18px;letter-spacing:0}
.wq-name .br{color:var(--rust);font-weight:300}
.wq-desc{font-family:var(--cn);font-size:15px;color:var(--ink-1);margin-top:18px;max-width:48ch;line-height:1.7}
.wq-progress{margin-top:32px}
.wq-pbar{height:24px;background:var(--bg-3);position:relative;overflow:hidden;border:1px solid var(--line)}
.wq-pbar .fill{position:absolute;inset:0;width:var(--wp,47.3%);background:repeating-linear-gradient(90deg, var(--rust) 0 12px, var(--rust-deep) 12px 14px)}
.wq-pbar .head{position:absolute;top:0;bottom:0;width:2px;background:#fff;left:var(--wp,47.3%);transform:translateX(-1px)}
.wq-pinfo{margin-top:12px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.06em}
.wq-pinfo .v{color:var(--ink-0)}
.wq-anchors{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.wq-a{display:grid;grid-template-columns: 1fr auto auto;align-items:center;gap:18px;padding:14px 0;border-bottom:1px solid var(--line);font-family:var(--cn);font-size:14px;color:var(--ink-0)}
.wq-a .pts{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.06em;min-width:64px;text-align:right}
.wq-a .pts.rare{color:var(--amber)}
.wq-a .do{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:6px 10px;border:1px solid var(--line-2);color:var(--ink-1);cursor:pointer;transition:all .2s}
.wq-a .do:hover{border-color:var(--rust);color:var(--rust-3);background:var(--rust-soft)}
.wq-a .do.done{border-color:var(--green);color:var(--green) !important;background:rgba(90,155,106,.1);cursor:default;pointer-events:none}
@media (max-width:980px){.wq-card{grid-template-columns:1fr;gap:36px}}

.wq-stats{display:grid;grid-template-columns: repeat(4, 1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line);margin-top:32px}
.wq-stats .it{padding:24px 22px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.wq-stats .it .k{font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.16em;text-transform:uppercase}
.wq-stats .it .v{font-family:var(--mono);font-size:28px;font-weight:500;color:var(--ink-0);margin-top:8px;font-variant-numeric:tabular-nums}
.wq-stats .it .n{font-family:var(--mono);font-size:11px;color:var(--ink-2);margin-top:6px;letter-spacing:.04em}
@media (max-width:880px){.wq-stats{grid-template-columns:repeat(2,1fr)}}

.past-quests{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.pq{display:grid;grid-template-columns: auto 1fr auto;gap:20px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line)}
.pq .id{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.12em}
.pq .nm{font-family:var(--cn);font-size:15px;color:var(--ink-0);font-weight:500}
.pq .nm .yr{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;margin-left:10px}
.pq .res{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:4px 10px;border:1px solid currentColor}
.pq .res.win{color:var(--green)}
.pq .res.fail{color:var(--rust-3)}
.pq .res.partial{color:var(--amber)}

/* ═══════════════════════════════════════════════════════
   util / tweaks
   ═══════════════════════════════════════════════════════ */
.tile-block{display:grid;gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.tile-block.c2{grid-template-columns:1fr 1fr}
.tile-block.c3{grid-template-columns:repeat(3,1fr)}
@media (max-width:880px){.tile-block.c2,.tile-block.c3{grid-template-columns:1fr}}
.tile{padding:24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-1)}
.tile h4{font-family:var(--cn);font-weight:500;font-size:17px;margin-bottom:8px;color:var(--ink-0)}
.tile p{font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.7}

/* ═══════════════════════════════════════════════════════
   ⚑ HERO V4 — 构成主义 × 技术加速主义
   红楔 / 巨数 / 排印为主体 / 无浮动地球
   ═══════════════════════════════════════════════════════ */
.home-hero{
  position:relative;
  min-height: clamp(660px, 84vh, 900px);
  border-bottom: 0;
  overflow: hidden;
  isolation: isolate;
  background: var(--ink-rev);
  color: var(--ink-0);
  display:flex;flex-direction:column;
}

/* ── 英雄图背景层（hero.webp） ── */
.home-hero .hero-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:
    url('hero.webp') center/cover no-repeat,
    radial-gradient(ellipse 55% 45% at 0% 0%, rgba(226,55,37,.08), transparent 60%),
    linear-gradient(180deg, rgba(8,8,10,.18) 0%, rgba(8,8,10,.04) 44%, rgba(8,8,10,.18) 100%);
  filter: brightness(.78) saturate(.88) contrast(1.04);
}


/* ── 顶部 meta 信息条 ── */
.home-hero .meta-bar{
  position:relative;z-index:8;
  width:100%;max-width:var(--maxw);margin:0 auto;
  padding: clamp(20px, 2.6vw, 34px) var(--pad-x) 0;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;color:var(--bone);letter-spacing:.24em;text-transform:uppercase;
}
.home-hero .meta-bar .num{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.04em;
  color:var(--ink-rev);background:var(--bone);padding:5px 11px 4px;
}
.home-hero .meta-bar .num::before{content:"";width:6px;height:6px;background:var(--rev);display:inline-block}
.home-hero .meta-bar .rule{flex:0 0 64px;height:1px;background:var(--bone);opacity:.6}
.home-hero .meta-bar .pip{width:7px;height:7px;background:var(--mustard);display:inline-block}
.home-hero .meta-bar .grow{flex:1 1 auto;height:1px;background:rgba(236,231,218,.18)}
.home-hero .meta-bar .right{color:var(--bone);opacity:.7}

/* ── 内容主舞台 ── */
.home-hero .stage{
  position:relative;z-index:8;
  flex:1;display:grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr);
  column-gap: clamp(40px, 5vw, 72px);
  row-gap: 0;
  width:100%;max-width: var(--maxw);margin:0 auto;
  padding: clamp(34px, 4.2vw, 58px) var(--pad-x) clamp(34px, 4vw, 56px);
  align-items: center;
}
@media (max-width: 1100px){
  .home-hero .stage{
    grid-template-columns:1fr;row-gap:40px;
    padding-bottom: clamp(80px, 12vw, 120px);
  }
  .home-hero .stage .lead{order:-1}
  /* 单列布局下 news 必须显式高度，否则 flex:1 + overflow:hidden 失效 */
  .home-hero .news{
    height: clamp(360px, 56vh, 480px);
    min-height: 0;
  }
  /* 移动端 modules 不上压，避免 ::before 渐变压到 news 底 */
  #modules{margin-top:0}
  #modules::before{
    top:-90px;height:90px;
    background: linear-gradient(180deg,
      transparent 0%,
      transparent 30%,
      rgba(10,8,7,.4) 65%,
      var(--ink-rev) 100%);
  }
}

/* ── 标题 + 描述 + CTA ── */
.home-hero .lead{
  position:relative;display:flex;flex-direction:column;
}

.home-hero .lead .kicker{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--bone);
  padding:7px 12px;background:var(--ink-rev);border:1px solid var(--bone);
  align-self:flex-start;margin-bottom:clamp(18px, 2.2vw, 30px);
}
.home-hero .lead .kicker .pip{width:6px;height:6px;background:var(--rev);border-radius:50%;animation:pulseRev 2.4s ease-in-out infinite}
@keyframes pulseRev{0%,100%{box-shadow:0 0 0 0 rgba(226,55,37,.6)}50%{box-shadow:0 0 0 6px rgba(226,55,37,0)}}

.home-hero .title{
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(58px, 8vw, 128px);
  line-height: .9;
  letter-spacing: 0;
  color: var(--bone);
  margin: 0;
  position:relative;
}
.home-hero .title .zh{
  font-family: var(--cn);font-weight: 900;
  display:block;
  letter-spacing:0;
}
.home-hero .title .en{
  font-family: var(--sans);font-weight: 800;
  display:block;
  font-size:.74em;
  letter-spacing:0;
  color: var(--bone);
  margin-top: .04em;
  text-transform: uppercase;
}

/* ── № 01 — 主页 / SECTION 横条 ── */
.home-hero .lead .rule{
  display:flex;align-items:center;gap:14px;
  margin-top: clamp(18px, 2vw, 28px);
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-1);
}
.home-hero .lead .rule .ed{
  color:var(--bone);background:var(--rev);
  padding:5px 11px 4px;font-weight:600;letter-spacing:.18em;
  flex-shrink:0;
}
.home-hero .lead .rule .bar{
  flex:1;height:1px;background:rgba(236,231,218,.22);
  min-width:24px;
}

.home-hero .desc{
  margin-top: clamp(14px, 1.6vw, 22px);
  padding-left: 16px;
  border-left: 2px solid var(--rev);
  font-family: var(--cn);
  font-weight: 400;
  font-size: clamp(15px, 1.18vw, 18px);
  color: var(--bone);
  line-height: 1.75;
  max-width: 44ch;
  opacity:.94;
}
.home-hero .desc strong{
  color:var(--ink-rev);background:var(--mustard);padding:0 6px 1px;font-weight:700;letter-spacing:.01em;
}

/* CTA — 主按钮 */
.home-hero .cta{
  margin-top: clamp(18px, 2vw, 28px);
  display:flex;gap:0;flex-wrap:wrap;align-items:stretch;
  position:relative;z-index:9;
}
.home-hero .cta .btn-a{
  font-family:var(--cn);font-size:15px;font-weight:600;letter-spacing:.04em;
  padding:18px 28px;
  background: var(--rev);color:var(--bone);border:1px solid var(--rev);
  cursor:pointer;transition:transform .2s ease, background .2s, color .2s;
  display:inline-flex;align-items:center;gap:14px;
  text-decoration:none;position:relative;
  overflow:visible;
}
.home-hero .cta .btn-a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:4px;background:var(--mustard);
  transition: transform .25s ease;transform-origin:left;
  transform: scaleX(.35);
}
.home-hero .cta .btn-a:hover{background:var(--bone);color:var(--ink-rev);border-color:var(--bone)}
.home-hero .cta .btn-a:hover::after{transform: scaleX(1)}
.home-hero .cta .btn-a .arr{width:16px;height:10px;display:inline-block;position:relative;vertical-align:middle;
  background:linear-gradient(currentColor,currentColor) center/100% 1px no-repeat;
}
.home-hero .cta .btn-a .arr::before,.home-hero .cta .btn-a .arr::after{content:"";position:absolute;right:0;width:7px;height:1px;background:currentColor}
.home-hero .cta .btn-a .arr::before{top:4px;transform:rotate(35deg);transform-origin:right}
.home-hero .cta .btn-a .arr::after{top:6px;transform:rotate(-35deg);transform-origin:right}
.home-hero .cta .btn-wide{
  padding:18px 48px;
}
/* 次按钮：空心描边 + hover 反色，与主按钮形成主次对比 */
.home-hero .cta .btn-a.btn-ghost{
  background:transparent;color:var(--bone);
  border:1px solid var(--bone);
  margin-left:-1px;       /* 与主按钮无缝相接，构成连体 CTA */
  font:inherit;cursor:pointer;
}
.home-hero .cta .btn-a.btn-ghost::after{
  background:var(--rev);
  transform:scaleX(.35);
}
.home-hero .cta .btn-a.btn-ghost:hover{
  background:var(--bone);color:var(--ink-rev);
  border-color:var(--bone);
}
.home-hero .cta .btn-a.btn-ghost:hover::after{transform:scaleX(1)}

/* ── 右：服务器公告 · 纯文字终端日志 ── */
.home-hero .news{
  position:relative;
  display:flex;flex-direction:column;
  overflow:hidden;
  align-self:center;
  margin-top: 0;
  height: clamp(420px, 52vh, 540px);
  min-height: 0;
  padding: 16px 18px 14px 18px;
  /* 单独的暗罩：让 news 在亮星球区也清晰可读 */
  background: linear-gradient(180deg, rgba(8,8,10,.84) 0%, rgba(8,8,10,.7) 100%);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border-left: 1px solid rgba(236,231,218,.22);
}
.home-hero .news.is-synced{min-height:0}
/* 顶部细线（与 meta-bar 呼应） */
.home-hero .news::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:var(--bone);opacity:.55;
}
/* 顶部细线右端的红色端点 */
.home-hero .news::after{
  content:"";position:absolute;top:-2px;right:0;width:32px;height:5px;
  background:var(--rev);
}
/* 头部 */
.home-hero .news .news-hd{
  display:flex;align-items:center;gap:10px;
  padding: 4px 0 14px 0;
  border-bottom:1px solid rgba(236,231,218,.18);
  font-family:var(--mono);font-size:10px;color:var(--bone);
  letter-spacing:.2em;text-transform:uppercase;
  flex-shrink:0;
}
.home-hero .news .news-hd .blip{
  width:6px;height:6px;background:var(--green);
  border-radius:50%;flex-shrink:0;
  animation:pulse 2.4s ease-in-out infinite;
}
.home-hero .news .news-hd .ver-tag{
  margin-left:auto;color:var(--ink-2);letter-spacing:.1em;font-size:9px;
}
/* 滚动容器 */
.home-hero .news .news-feed{
  flex:1;overflow:hidden;position:relative;
  mask-image: linear-gradient(to bottom, #000 0%, #000 85%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 85%, transparent 100%);
}
.home-hero .news .news-track{
  animation: newsScroll 120s linear infinite;
  padding: 8px 0;
}
.home-hero .news .news-track:hover{animation-play-state:paused}
@keyframes newsScroll{
  0%{transform:translateY(0)}
  100%{transform:translateY(-50%)}
}
/* 底部查看更多（与头部对称的底部栏） */
.home-hero .news .news-more{
  display:flex;align-items:center;justify-content:space-between;
  padding: 12px 0 0 0;
  margin-top: 4px;
  border-top:1px solid rgba(236,231,218,.18);
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-1);cursor:pointer;transition:color .2s, letter-spacing .25s;
  flex-shrink:0;
}
.home-hero .news .news-more:hover{color:var(--bone);letter-spacing:.24em}

/* 公告条目 */
.home-hero .news .item{
  display:block;cursor:pointer;
  padding: 11px 0;
  border-bottom:1px solid rgba(236,231,218,.06);
  display:flex;flex-direction:column;gap:6px;
  transition:background .25s;
}
.home-hero .news .item:hover{background:rgba(236,231,218,.03)}
.home-hero .news .item .meta{
  display:flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:9px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.home-hero .news .item .meta .lvl{
  font-weight:600;padding:1px 6px;font-size:8px;letter-spacing:.12em;
  border:1px solid;flex-shrink:0;
}
.home-hero .news .item .meta .lvl.info{color:var(--blue);border-color:var(--blue)}
.home-hero .news .item .meta .lvl.ok{color:var(--green);border-color:var(--green)}
.home-hero .news .item .meta .lvl.warn{color:var(--mustard);border-color:var(--mustard)}
.home-hero .news .item .meta .lvl.err{color:var(--rev);border-color:var(--rev)}
.home-hero .news .item .msg{
  font-family:var(--cn);font-size:12.5px;color:var(--bone);
  line-height:1.65;opacity:.82;
}


/* 移动端再压缩 */
@media (max-width: 720px){
  .home-hero{min-height:auto}
  /* 标题单行：地球 ONLINE 同行 */
  .home-hero .title{font-size:clamp(44px, 13vw, 86px);line-height:1;letter-spacing:0}
  .home-hero .title .zh{display:inline;letter-spacing:0}
  .home-hero .title .en{display:inline;font-size:.7em;margin:0 0 0 .14em}
  .home-hero .desc{max-width:none}
  .home-hero .meta-bar .grow{display:none}
  /* 移动端 news 紧凑模式：只显示一行公告 */
  .home-hero .news{
    height:auto;
    min-height:0;
    padding:12px 14px;
  }
  .home-hero .news .news-feed{
    flex:0 0 auto;
    height:62px;
    mask-image: linear-gradient(to bottom, #000 0%, #000 60%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 60%, transparent 100%);
  }
  .home-hero .news .news-track{padding:4px 0}
  .home-hero .news .item{padding:8px 0;gap:4px}
  /* 移动端 news-more 提亮：避免被 feed mask 渐隐遮蔽 */
  .home-hero .news .news-more{
    color: var(--bone);
    font-size: 11.5px;
    letter-spacing: .14em;
    padding: 12px 0 2px;
    margin-top: 6px;
    border-top: 1px solid rgba(236,231,218,.3);
  }
}

/* 浮动按钮：news 滚出视口 + 向上滑 时浮现（桌面 & 移动端） */
.news-more-float{
  display:flex;align-items:center;gap:18px;
  position:fixed;
  bottom: 28px;right: 28px;
  z-index:50;
  background: rgba(8,8,10,.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border:1px solid rgba(236,231,218,.22);
  border-left: 3px solid var(--rev);
  color: var(--bone);
  padding: 12px 18px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  white-space: nowrap;
  cursor: pointer;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .35s ease, transform .35s ease, background .2s, border-color .2s;
  pointer-events: none;
  box-shadow: 0 6px 28px rgba(0,0,0,.45);
}
.news-more-float.is-visible{
  opacity:1;
  transform: translateY(0);
  pointer-events: auto;
}
.news-more-float:hover{
  background: var(--rev);
  border-color: var(--rev);
  border-left-color: var(--bone);
}
@media (max-width: 720px){
  .news-more-float{
    left:14px;right:14px;bottom:16px;
    justify-content: space-between;
    padding: 13px 16px;
    font-size: 11.5px;
    letter-spacing: .16em;
    white-space: normal;
  }
}

/* ═══════════════════════════════════════════════════════
   ⚑ HOME V4 — 6 模块栅格（构成主义改写）
   ═══════════════════════════════════════════════════════ */
#modules{
  background: var(--ink-rev);
  border-bottom:1px solid var(--bone);
  margin-top: 0;
  padding-top: clamp(36px, 3.6vw, 60px);
  position: relative;
  z-index: 5;
}
/* 透明渐变切入边界：避免 hero 背景图突变到纯黑 */
#modules::before{
  content:none;
  pointer-events:none;
}
#modules .section-head{
  border-bottom: 2px solid var(--bone);
  padding-bottom: 24px;align-items:end;
}
#modules .section-eyebrow{color:var(--rev);}
#modules .section-eyebrow::before{background:var(--rev)}
#modules .section-title{color:var(--bone)}
#modules .section-title .accent{color:var(--mustard)}
#modules .section-num{color:rgba(236,231,218,.6)}
#modules .section-num .v{color:var(--bone)}
#modules .section-num .v.g{color:var(--mustard)}

/* 栅格容器：硬实线骨白边界 */
#modules .mods-grid{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  grid-auto-rows:minmax(190px,auto);
  border-top:1px solid var(--bone);
  border-left:1px solid var(--bone);
  background: var(--ink-rev);
}
#modules .mod{
  position:relative;
  border-right:1px solid var(--bone);
  border-bottom:1px solid var(--bone);
  background: var(--ink-rev);
  color: var(--bone);
  padding: 36px 30px 28px;
  overflow:hidden;
  transition:background .3s, color .25s;
  min-height:220px;
}
#modules .mod:hover{background: var(--bone);color: var(--ink-rev)}
#modules .mod::before{
  /* 顶部红条 hover slide */
  content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--rev);
  transform-origin:left;transform:scaleX(0);transition:transform .45s cubic-bezier(.7,0,.2,1);
}
#modules .mod:hover::before{transform:scaleX(1)}

/* 巨型背景编号字符 */
#modules .mod .mod-num{
  position:absolute;top:14px;right:18px;
  font-family:var(--mono);font-size:11px;color:rgba(236,231,218,.55);
  letter-spacing:.22em;text-transform:uppercase;
  z-index:2;
}
#modules .mod:hover .mod-num{color:rgba(10,8,7,.6)}
#modules .mod::after{
  /* 巨型水印数字 */
  content:attr(data-numeral);
  position:absolute;left:-12px;bottom:-44px;
  font-family:var(--sans);font-weight:900;
  font-size: clamp(140px, 18vw, 260px);
  line-height:.78;letter-spacing:0;
  color: rgba(236,231,218,.06);
  z-index:0;pointer-events:none;
  transition:color .3s;
}
#modules .mod:hover::after{color: rgba(226,55,37,.12)}

#modules .mod > div:first-of-type{position:relative;z-index:2}
#modules .mod-name{
  margin-top: 28px;color:inherit;font-weight:700;letter-spacing:0;
}
#modules .mod-name .zh{font-weight:700}
#modules .mod-name .en{color:rgba(236,231,218,.5)}
#modules .mod:hover .mod-name .en{color:rgba(10,8,7,.5)}
#modules .mod-desc{color:rgba(236,231,218,.7)}
#modules .mod:hover .mod-desc{color:rgba(10,8,7,.75)}

#modules .mod-foot{
  position:relative;z-index:2;
  border-top:1px dashed rgba(236,231,218,.2);padding-top:14px;margin-top:24px;
  color:rgba(236,231,218,.55);
}
#modules .mod:hover .mod-foot{border-top-color:rgba(10,8,7,.2);color:rgba(10,8,7,.6)}
#modules .mod-status{border-color:currentColor;color:inherit}
#modules .mod-status.live{border-color:var(--mustard);color:var(--mustard)}
#modules .mod-status.live .dot{background:var(--mustard)}
#modules .mod-status.beta{border-color:var(--mustard);color:var(--mustard)}
#modules .mod-status.danger{border-color:var(--rev);color:var(--rev)}
#modules .mod-status.danger .dot{background:var(--rev)}
#modules .mod-arrow{
  border:1px solid currentColor;color:inherit;
  width:36px;height:36px;
}
#modules .mod:hover .mod-arrow{background:var(--rev);border-color:var(--rev);color:var(--bone)}

/* 模块 1（角色档案）— 主推：直接用红背景 + 大编号 */
#modules .mod.m1{
  grid-column:span 5;grid-row:span 2;
  background: var(--rev);color:var(--bone);
  min-height:460px;
}
#modules .mod.m1::after{
  color: rgba(236,231,218,.16);
}
#modules .mod.m1::before{background:var(--mustard)}
#modules .mod.m1:hover{background:var(--bone);color:var(--ink-rev)}
#modules .mod.m1:hover::after{color: rgba(226,55,37,.14)}
#modules .mod.m1 .mod-num{color:var(--mustard)}
#modules .mod.m1:hover .mod-num{color:var(--rev)}
#modules .mod.m1 .mod-tag{
  border-color:var(--mustard);color:var(--mustard);background:rgba(224,184,51,.08);
}
#modules .mod.m1:hover .mod-tag{background:transparent;border-color:var(--rev);color:var(--rev)}
#modules .mod.m1 .mod-foot{border-top-color:rgba(236,231,218,.3)}
#modules .mod.m1:hover .mod-foot{border-top-color:rgba(10,8,7,.2)}
#modules .mod.m2{grid-column:span 4;grid-row:span 1}
#modules .mod.m3{grid-column:span 3;grid-row:span 1;background:rgba(236,231,218,.06)}
#modules .mod.m4{grid-column:span 7;grid-row:span 1}
#modules .mod.m5{grid-column:span 3;grid-row:span 1}
#modules .mod.m6{grid-column:span 4;grid-row:span 1;background:rgba(226,55,37,.08)}
#modules .mod.m3,
#modules .mod.m6{
  clip-path:polygon(0 0, calc(100% - 28px) 0, 100% 28px, 100% 100%, 0 100%);
}
#modules .mod.m4{
  clip-path:polygon(0 0, 100% 0, 100% calc(100% - 26px), calc(100% - 26px) 100%, 0 100%);
}
@media (max-width:1080px){
  #modules .mod.m1{grid-column:span 12;grid-row:span 1;min-height:320px}
  #modules .mod.m2,#modules .mod.m3,#modules .mod.m4,#modules .mod.m5,#modules .mod.m6{grid-column:span 6;grid-row:span 1}
}
@media (max-width:720px){
  #modules .mods-grid{grid-template-columns:1fr}
  #modules .mod{grid-column:span 1!important;grid-row:span 1!important;min-height:220px;clip-path:none!important}
}

/* ═══════════════════════════════════════════════════════
   ⚑ HOME V4 — 世界任务横幅（构成主义重写）
   ═══════════════════════════════════════════════════════ */
/* 主页专属 — 通过 :has() 仅匹配 home 上紧跟 wq/rv 的 section */
.section:has(> .section-inner > .wq-banner) .hr-tick,
.section:has(> .section-inner > .rv-summary) .hr-tick{color:var(--bone);font-weight:600}
.section:has(> .section-inner > .wq-banner) .hr-tick::before,
.section:has(> .section-inner > .rv-summary) .hr-tick::before{background:var(--rev);width:10px;height:10px}
.section:has(> .section-inner > .wq-banner) .hr-tick::after,
.section:has(> .section-inner > .rv-summary) .hr-tick::after{background:var(--bone);opacity:.3}

.wq-banner{
  background: var(--bone);
  border:1px solid var(--ink-rev);
  color: var(--ink-rev);
  padding: 32px 36px;
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:auto 1fr auto;gap:36px;align-items:center;
}
.wq-banner::before{
  /* 红楔角 */
  content:"";position:absolute;left:0;top:0;width:90px;height:90px;
  background:var(--rev);
  clip-path: polygon(0 0, 100% 0, 0 100%);
  z-index:0;
}
.wq-banner::after{
  content:"";position:absolute;left:0;bottom:0;height:6px;width:var(--wp,47.3%);background:var(--rev);
}
.wq-banner > *{position:relative;z-index:1}
.wq-banner .meta{
  font-family:var(--mono);font-size:11px;color:var(--bone);background:var(--ink-rev);
  padding:6px 12px;letter-spacing:.22em;text-transform:uppercase;
  align-self:start;
  display:inline-flex;align-items:center;gap:10px;
}
.wq-banner .meta::before{background:var(--rev);width:7px;height:7px;border-radius:0;animation:none}
.wq-banner .name{
  font-family:var(--cn);font-weight:700;font-size:clamp(22px,2.4vw,32px);line-height:1.15;
  color:var(--ink-rev);margin-bottom:14px;letter-spacing:0;
}
.wq-banner .name .br{color:var(--rev);font-family:var(--sans);font-weight:900}
.wq-banner .pbar{height:10px;background:rgba(10,8,7,.1);position:relative;overflow:hidden;border:1px solid var(--ink-rev)}
.wq-banner .pbar .fill{
  position:absolute;inset:0;width:var(--wp,47.3%);
  background: var(--rev);
  background-image: repeating-linear-gradient(135deg, var(--rev) 0 8px, var(--rev-2) 8px 10px);
}
.wq-banner .pinfo{color:var(--ink-rev);opacity:.85}
.wq-banner .pinfo .v{color:var(--rev);font-weight:700}
.wq-banner .cta.btn{
  font-family:var(--cn);font-weight:600;
  background:var(--ink-rev);color:var(--bone);border:1px solid var(--ink-rev);
  padding:14px 22px;letter-spacing:.06em;text-transform:none;
}
.wq-banner .cta.btn::before{background:var(--rev)}
.wq-banner .cta.btn:hover{color:var(--bone)}

/* ═══════════════════════════════════════════════════════
   ⚑ HOME V4 — 商城横幅（构成主义）
   ═══════════════════════════════════════════════════════ */
.section:has(> .section-inner > .shop-banner) .hr-tick{color:var(--bone);font-weight:600}
.section:has(> .section-inner > .shop-banner) .hr-tick::before{background:var(--mustard);width:10px;height:10px}
.section:has(> .section-inner > .shop-banner) .hr-tick::after{background:var(--bone);opacity:.3}

.shop-banner{
  background: var(--bone);
  border: 1px solid var(--ink-rev);
  color: var(--ink-rev);
  padding: 28px 32px;
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center;
}
.shop-banner::before{
  /* 黄楔角（区别于 wq 的红楔角，呼应 mustard 货币色） */
  content:"";position:absolute;left:0;top:0;width:90px;height:90px;
  background:var(--mustard);
  clip-path: polygon(0 0, 100% 0, 0 100%);
  z-index:0;
}
.shop-banner::after{
  /* 底部三段彩条：土 / 石 / 砖 */
  content:"";position:absolute;left:0;bottom:0;height:6px;width:100%;
  background:linear-gradient(90deg,
    #8a6a35 0 33.3%,
    #5a5a5e 33.3% 66.6%,
    var(--rev) 66.6% 100%);
}
.shop-banner > *{position:relative;z-index:1}

.shop-banner .sb-meta{
  font-family:var(--mono);font-size:11px;color:var(--bone);background:var(--ink-rev);
  padding:6px 12px;letter-spacing:.22em;text-transform:uppercase;
  align-self:start;display:inline-flex;align-items:center;gap:10px;
}
.shop-banner .sb-meta::before{content:"";width:7px;height:7px;background:var(--mustard)}

.shop-banner .sb-body{display:flex;flex-direction:column;gap:14px;min-width:0}
.shop-banner .sb-name{
  font-family:var(--cn);font-weight:700;font-size:clamp(20px,2.2vw,28px);
  line-height:1.2;color:var(--ink-rev);margin:0;letter-spacing:0;
}
.shop-banner .sb-name .br{color:var(--rev);font-family:var(--sans);font-weight:900}

/* 三货币条：覆盖默认 coin 颜色以适配 bone 底 */
.shop-banner .sb-coins{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.shop-banner .sb-coins .coin{font-size:14px;font-weight:600}
.shop-banner .sb-coins .coin .ic{width:24px;height:24px;font-size:12px;font-weight:700}
.shop-banner .sb-coins .coin-dirt{color:#8a6a35}
.shop-banner .sb-coins .coin-stone{color:#4a4a4e}
.shop-banner .sb-coins .coin-brick{color:var(--rev)}
.shop-banner .sb-eq{
  font-family:var(--mono);font-size:11px;color:var(--ink-rev);opacity:.65;
  padding-left:14px;margin-left:2px;border-left:1px solid var(--ink-rev);
  letter-spacing:.08em;font-weight:600;
}

.shop-banner .sb-info{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;color:var(--ink-rev);opacity:.85;
  letter-spacing:.04em;
}
.shop-banner .sb-info .v{color:var(--rev);font-weight:700;font-variant-numeric:tabular-nums}
.shop-banner .sb-info .sep{opacity:.35}

.shop-banner .cta.btn{
  font-family:var(--cn);font-weight:600;
  background:var(--ink-rev);color:var(--bone);border:1px solid var(--ink-rev);
  padding:14px 22px;letter-spacing:.06em;text-transform:none;flex-shrink:0;
}
.shop-banner .cta.btn::before{background:var(--rev)}
.shop-banner .cta.btn:hover{color:var(--bone)}

@media (max-width:780px){
  .shop-banner{grid-template-columns:1fr;gap:18px;padding:24px}
  .shop-banner .sb-meta{align-self:start}
}

/* ═══════════════════════════════════════════════════════
   ⚑ HOME V4 — 评价摘要（构成主义重写）
   ═══════════════════════════════════════════════════════ */
.rv-summary{
  background: var(--ink-rev);
  border: 1px solid var(--bone);
  padding: 0;
  grid-template-columns: 320px 1fr 1fr;
}
.rv-summary .score{
  background: var(--rev);color:var(--bone);
  border-right:1px solid var(--bone);padding:36px 28px;
  display:flex;flex-direction:column;align-items:flex-start;text-align:left;
  position:relative;
}
.rv-summary .score::after{
  content:"";position:absolute;right:0;bottom:0;width:0;height:0;
  border-bottom:24px solid var(--mustard);border-left:24px solid transparent;
}
.rv-summary .score .num{
  font-family:var(--sans);font-weight:900;font-size:128px;line-height:.85;color:var(--bone);
  letter-spacing:0;
}
.rv-summary .score .deno{color:var(--bone);opacity:.65;letter-spacing:.18em;font-weight:600}
.rv-summary .score .lab{
  margin-top:18px;background:var(--mustard);color:var(--ink-rev);border:0;
  padding:6px 14px;font-weight:700;
}
.rv-summary .score .ct{color:var(--bone);opacity:.55;margin-top:18px}
.rv-summary .quote{
  padding:32px 28px;color:var(--bone);font-size:14.5px;line-height:1.85;
  border-right:1px solid var(--bone);
}
.rv-summary .quote:last-child{border-right:0}
.rv-summary .quote .vote{
  display:inline-block;padding:5px 11px;font-weight:700;
  letter-spacing:.18em;
}
.rv-summary .quote .vote.up{background:var(--mustard);color:var(--ink-rev)}
.rv-summary .quote .vote.down{background:var(--rev);color:var(--bone)}
.rv-summary .quote p{flex:1;color:var(--bone);opacity:.92}
.rv-summary .quote .meta{color:var(--bone);opacity:.55;border-top:1px dashed rgba(236,231,218,.2);padding-top:12px}
@media (max-width:900px){
  .rv-summary{grid-template-columns:1fr}
  .rv-summary .score{border-right:0;border-bottom:1px solid var(--bone)}
  .rv-summary .quote{border-right:0;border-bottom:1px solid var(--bone)}
  .rv-summary .quote:last-child{border-bottom:0}
}

/* ─────────── 玩家社区 · Tab 切换 ─────────── */
.tab-nav{
  display:flex;gap:0;border-bottom:1px solid var(--line-2);
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
}
.tab-nav button{
  appearance:none;background:none;border:none;
  padding:16px 28px;color:var(--ink-2);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .2s,border-color .2s,background .2s;
  font-family:inherit;font-size:inherit;letter-spacing:inherit;text-transform:inherit;
}
.tab-nav button:hover{color:var(--ink-1);background:var(--bg-1)}
.tab-nav button.on{color:var(--rust-3);border-bottom-color:var(--rust)}
.tab-nav button .ct{color:var(--ink-3);margin-left:6px;font-size:11px;letter-spacing:.14em}
.tab-pane{display:none}
.tab-pane.on{display:block;animation:tabFade .25s ease-out}
@keyframes tabFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.community-tabs-section{padding-bottom:clamp(22px,2.4vw,32px)}
.community-list-section{padding-top:clamp(30px,3vw,42px)}
@media (max-width:680px){
  .tab-nav button{padding:14px 16px;font-size:11px;letter-spacing:.14em}
  .tab-nav button .ct{display:none}
}

/* ─────────── 玩家社区 · 攻略投稿 CTA ─────────── */
.guide-cta{
  display:grid;grid-template-columns:1fr auto;gap:36px;align-items:center;
  border:1px solid var(--line-2);background:linear-gradient(180deg,var(--bg-2),var(--bg-1));
  padding:36px 40px;position:relative;
}
.guide-cta::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--mustard);
}
.guide-cta-tag{
  position:absolute;top:14px;right:18px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--mustard);
}
.guide-cta-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-2);margin-bottom:14px;
}
.guide-cta h2{
  font-family:var(--cn);font-size:clamp(22px,2.4vw,30px);font-weight:500;
  line-height:1.35;letter-spacing:0;margin-bottom:14px;color:var(--ink-0);
}
.guide-cta h2 .accent{color:var(--mustard)}
.guide-cta p{color:var(--ink-1);font-size:14px;line-height:1.7;max-width:62ch}
.guide-cta-action{display:flex;flex-direction:column;align-items:flex-end;gap:18px;min-width:220px}
@media (max-width:780px){
  .guide-cta{grid-template-columns:1fr;padding:28px 24px;gap:24px}
  .guide-cta-action{align-items:stretch;min-width:0}
  .guide-cta-action .bug-cta-meta{text-align:left}
}

/* ─────────── 玩家社区 · 攻略筛选 ─────────── */
.guide-filter{
  display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 24px;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;
}
.guide-filter a{
  padding:8px 14px;border:1px solid var(--line);color:var(--ink-1);cursor:pointer;
  transition:color .15s,border-color .15s,background .15s;
}
.guide-filter a:hover{color:var(--ink-0);border-color:var(--line-2)}
.guide-filter a.on{color:var(--mustard);border-color:var(--mustard);background:rgba(224,184,51,.06)}
.guide-filter a .ct{color:var(--ink-3);margin-left:6px;font-size:11px}

/* ─────────── 玩家社区 · 攻略卡片网格 ─────────── */
.guide-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:8px;
}
.guide-card{
  grid-column:span 4;border:1px solid var(--line);background:var(--bg-1);
  padding:22px 24px 18px;display:flex;flex-direction:column;gap:12px;
  cursor:pointer;text-decoration:none;color:inherit;
  transition:background .2s,border-color .2s;position:relative;overflow:hidden;
}
.guide-card::before{
  content:"";position:absolute;left:0;top:0;height:100%;width:2px;background:transparent;
  transition:background .2s;
}
.guide-card:hover{background:var(--bg-2);border-color:var(--line-2)}
.guide-card:hover::before{background:var(--mustard)}
.guide-card.feat{
  grid-column:span 8;grid-row:span 2;background:var(--bg-2);padding:30px 32px 24px;
}
.guide-card.feat::before{background:var(--mustard)}
.guide-card-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-2);
}
.guide-card h4{
  font-family:var(--cn);font-size:17px;font-weight:500;line-height:1.45;color:var(--ink-0);
  margin:0;
}
.guide-card.feat h4{font-size:24px;line-height:1.35}
.guide-card .lead{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.65;margin:0}
.guide-card.feat .lead{font-size:14px}
.guide-card .meta{
  margin-top:auto;padding-top:14px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-2);
}
.guide-card .diff{font-weight:500}
.guide-card .diff.s1{color:var(--green)}
.guide-card .diff.s2{color:var(--amber)}
.guide-card .diff.s3{color:var(--rust-3)}
.guide-card .diff.s4{color:var(--rev)}
@media (max-width:980px){
  .guide-grid{grid-template-columns:repeat(6,1fr)}
  .guide-card,.guide-card.feat{grid-column:span 6;grid-row:auto}
  .guide-card.feat h4{font-size:20px}
}
@media (max-width:600px){
  .guide-grid{grid-template-columns:1fr}
  .guide-card,.guide-card.feat{grid-column:span 1}
}

/* ─────────── 攻略 tip 条 ─────────── */
.guide-tip{
  margin-top:28px;padding:14px 18px;border:1px dashed var(--line-2);
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;color:var(--ink-2);letter-spacing:.04em;
}
.guide-tip .dot{width:6px;height:6px;border-radius:50%;background:var(--mustard);flex-shrink:0}

/* ─────────── 玩家社区 · 信息流主页 ─────────── */
.community-app-section{padding-top:clamp(34px,4vw,56px)}
.community-shell{
  display:grid;grid-template-columns:220px minmax(0,1fr);gap:28px;align-items:start;
}
.community-left{
  position:sticky;top:92px;display:flex;flex-direction:column;gap:18px;min-width:0;
}
.community-main{min-width:0}
.community-profile-mini{
  border:1px solid var(--line-2);background:rgba(255,255,255,.02);padding:16px;
  display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:center;
}
.community-profile-mini .avatar,.post-author .avatar,.profile-sync-avatar{
  width:44px;height:44px;border:1px solid var(--rust-edge);background:var(--rust-soft);
  color:var(--rust-3);display:grid;place-items:center;font-family:var(--cn);font-size:18px;font-weight:700;
}
.community-profile-mini strong,.profile-sync-card h3{
  display:block;font-family:var(--cn);font-size:15px;color:var(--ink-0);font-weight:500;
}
.community-profile-mini em{
  display:block;font-family:var(--mono);font-size:10px;color:var(--ink-2);font-style:normal;letter-spacing:.06em;margin-top:4px;
}
.community-profile-mini a{
  grid-column:1/-1;font-family:var(--mono);font-size:11px;color:var(--mustard);letter-spacing:.12em;
  border-top:1px solid var(--line);padding-top:12px;text-transform:uppercase;
}
.community-side-block{
  border-top:1px solid var(--line-2);padding-top:14px;
}
.community-side-block h6{
  font-family:var(--mono);font-size:11px;color:var(--ink-1);letter-spacing:.22em;text-transform:uppercase;margin-bottom:12px;
}
.community-side-block a{
  display:flex;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);
  font-family:var(--cn);font-size:13px;color:var(--ink-1);
}
.community-side-block a.on{color:var(--rust-3);border-bottom-color:var(--rust)}
.community-side-block a span,.sync-row span{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.12em}
.community-tag-cloud{display:flex;flex-wrap:wrap;gap:7px}
.community-tag-cloud span,.post-tags span,.profile-sync-badges span{
  border:1px solid var(--line-2);color:var(--ink-1);font-family:var(--cn);font-size:12px;padding:5px 9px;
}
.community-side-block.sync p{
  font-family:var(--cn);font-size:12.5px;color:var(--ink-2);line-height:1.7;margin-top:12px;
}
.sync-row{
  display:flex;justify-content:space-between;align-items:baseline;padding:9px 0;border-bottom:1px solid var(--line);
}
.sync-row strong{font-family:var(--mono);font-size:18px;color:var(--ink-0);font-weight:600}
.hot-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.hot-list li{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.4}
.hot-list span{font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.12em;margin-right:8px}

.community-composer{
  border:1px solid var(--line-2);background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015));
  padding:18px;display:flex;flex-direction:column;gap:12px;
}
.composer-head,.composer-bottom,.community-toolbar,.post-actions,.post-author,.note-kicker,.question-top,.profile-post-meta{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.composer-head span{
  display:block;font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.2em;text-transform:uppercase;margin-bottom:5px;
}
.composer-head strong{font-family:var(--cn);font-size:18px;color:var(--ink-0);font-weight:500}
.composer-head select{
  background:var(--bg-0);border:1px solid var(--line-2);color:var(--ink-0);font-family:var(--cn);font-size:13px;padding:9px 12px;outline:none;
}
.composer-title,.community-composer textarea{
  width:100%;background:var(--bg-0);border:1px solid var(--line);color:var(--ink-0);outline:none;
  font-family:var(--cn);font-size:14px;padding:12px 14px;
}
.community-composer textarea{min-height:96px;resize:vertical;line-height:1.7}
.composer-title:focus,.community-composer textarea:focus,.composer-head select:focus{border-color:var(--rust)}
.composer-upload{
  width:150px;height:64px;border:1px dashed var(--line-2);display:grid;place-items:center;cursor:pointer;overflow:hidden;background:rgba(255,255,255,.02);
}
.composer-upload input{display:none}
.composer-upload span{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.16em;text-transform:uppercase;
}
.composer-upload img{width:100%;height:100%;object-fit:cover;display:block}
.community-composer .btn::before{display:none}
.community-composer .btn.primary:hover{
  color:#fff;background:var(--rust-2);border-color:var(--rust-3);
}

.community-tabs{margin-top:0}
.community-toolbar{
  margin:18px 0 20px;align-items:flex-start;flex-wrap:wrap;
}
.community-search{
  flex:1 1 260px;border:1px solid var(--line);background:rgba(255,255,255,.02);
  padding:11px 14px;font-family:var(--cn);font-size:13px;color:var(--ink-2);
}
.community-sort{display:flex;gap:6px;flex-wrap:wrap}
.community-sort span{
  border:1px solid var(--line);padding:10px 12px;font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;
}
.community-sort span.on{color:var(--mustard);border-color:var(--mustard);background:rgba(224,184,51,.06)}

.community-feed-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:start;
}
.community-note-card,.community-question,.profile-post-item{
  border:1px solid var(--line);background:var(--bg-1);cursor:pointer;transition:border-color .18s,background .18s,transform .18s;
}
.community-note-card:hover,.community-question:hover,.profile-post-item:hover{
  border-color:var(--line-2);background:var(--bg-2);transform:translateY(-1px);
}
.community-note-card.featured{grid-column:span 2}
.note-media{aspect-ratio:4/3;background:var(--bg-2);overflow:hidden;border-bottom:1px solid var(--line)}
.community-note-card.featured .note-media{aspect-ratio:16/7}
.note-media img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.88) contrast(1.04)}
.note-body{padding:18px 18px 16px;display:flex;flex-direction:column;gap:12px}
.note-kicker,.question-top,.profile-post-meta{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.16em;text-transform:uppercase;
}
.note-kicker span:first-child{color:var(--mustard)}
.community-note-card h3,.community-question h3,.profile-post-item h3{
  font-family:var(--cn);font-weight:500;color:var(--ink-0);line-height:1.35;margin:0;
}
.community-note-card h3{font-size:18px}
.community-note-card.featured h3{font-size:24px}
.community-note-card p,.community-question p,.profile-post-item p{
  font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.7;margin:0;
}
.post-tags{display:flex;flex-wrap:wrap;gap:6px}
.post-tags span{font-size:11px;padding:4px 8px;color:var(--ink-2)}
.post-author{justify-content:flex-start}
.post-author .avatar{width:32px;height:32px;font-size:13px;flex-shrink:0}
.post-author strong{display:block;font-family:var(--cn);font-size:13px;color:var(--ink-0);font-weight:500}
.post-author em{display:block;font-family:var(--mono);font-size:10px;color:var(--ink-2);font-style:normal;margin-top:2px;letter-spacing:.06em}
.post-actions{
  border-top:1px solid var(--line);padding-top:12px;flex-wrap:wrap;justify-content:flex-start;
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.06em;
}
.post-actions span:first-child{color:var(--ink-1)}

.community-question-feed{display:flex;flex-direction:column;gap:12px}
.community-question{display:grid;grid-template-columns:108px minmax(0,1fr);gap:0}
.question-vote{
  border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:16px 10px;
  background:rgba(155,58,43,.05);
}
.question-vote strong{font-family:var(--mono);font-size:22px;color:var(--rust-3);font-weight:600}
.question-vote span{font-family:var(--cn);font-size:12px;color:var(--ink-2)}
.question-main{padding:18px;display:flex;flex-direction:column;gap:11px}
.question-shot{aspect-ratio:16/7;overflow:hidden;background:var(--bg-2);border:1px solid var(--line)}
.question-shot img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.85) contrast(1.05)}
.qid{color:var(--ink-2)}
.qstatus,.qsev{
  border:1px solid currentColor;padding:3px 7px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;
}
.qstatus.wai{color:var(--amber)}
.qstatus.wf,.qstatus.dup{color:var(--ink-2)}
.qstatus.ack{color:var(--blue)}
.qsev{color:var(--rust-3)}
.question-reply{
  border-left:2px solid var(--amber);background:rgba(197,131,45,.05);padding:10px 12px;
  font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.65;
}
.question-reply span{
  display:block;font-family:var(--mono);font-size:10px;color:var(--amber);letter-spacing:.16em;text-transform:uppercase;margin-bottom:4px;
}

/* ─────────── 角色页 · 玩家个人主页同步 ─────────── */
.profile-community-section{background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(155,58,43,.035))}
.profile-sync-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:28px;align-items:start}
.profile-sync-card{
  border:1px solid var(--line-2);background:var(--bg-1);padding:22px;display:flex;flex-direction:column;gap:14px;align-items:flex-start;
}
.profile-sync-avatar{width:64px;height:64px;font-size:24px}
.profile-sync-card p{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.08em;margin:0}
.profile-sync-badges{display:flex;flex-wrap:wrap;gap:7px}
.profile-sync-card .btn{margin-top:6px}
.profile-posts{display:flex;flex-direction:column;gap:12px}
.profile-empty{
  border:1px dashed var(--line-2);background:rgba(255,255,255,.02);padding:28px;
  display:flex;flex-direction:column;align-items:flex-start;gap:12px;
}
.profile-empty strong{font-family:var(--cn);font-size:18px;color:var(--ink-0);font-weight:500}
.profile-empty p{font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.7;margin:0}
.profile-post-item{
  display:grid;grid-template-columns:96px minmax(0,1fr) auto;gap:16px;align-items:start;padding:14px;
}
.profile-post-item img,.profile-post-fallback{
  width:96px;aspect-ratio:1/1;object-fit:cover;background:var(--bg-2);border:1px solid var(--line);display:grid;place-items:center;
}
.profile-post-fallback{font-family:var(--mono);font-size:20px;color:var(--rust-3)}
.profile-post-meta{justify-content:flex-start;margin-bottom:7px}
.profile-post-meta span:first-child{color:var(--mustard)}
.profile-post-item h3{font-size:17px;margin-bottom:7px}
.profile-post-item strong{
  font-family:var(--mono);font-size:13px;color:var(--rust-3);white-space:nowrap;padding-top:8px;
}

@media (max-width:1180px){
  .community-shell{grid-template-columns:190px minmax(0,1fr)}
}
@media (max-width:900px){
  .community-shell,.profile-sync-layout{grid-template-columns:1fr}
  .community-left{position:static}
  .community-feed-grid{grid-template-columns:1fr}
  .community-note-card.featured{grid-column:span 1}
  .community-note-card.featured .note-media{aspect-ratio:4/3}
}
@media (max-width:640px){
  .composer-head,.composer-bottom,.community-toolbar{align-items:stretch;flex-direction:column}
  .composer-upload{width:100%}
  .community-question{grid-template-columns:1fr}
  .question-vote{border-right:0;border-bottom:1px solid var(--line);align-items:flex-start}
  .question-top{align-items:flex-start;flex-wrap:wrap;justify-content:flex-start}
  .profile-post-item{grid-template-columns:72px minmax(0,1fr)}
  .profile-post-item img,.profile-post-fallback{width:72px}
  .profile-post-item strong{grid-column:1/-1;padding-top:0}
}

/* ─────────── Frontend implementation pass · 2026-05-12 ─────────── */
.task-toast{
  position:fixed;left:50%;bottom:24px;z-index:260;transform:translate(-50%,18px);
  max-width:min(560px,calc(100vw - 32px));padding:12px 16px;border:1px solid var(--line-2);
  background:rgba(8,8,10,.94);color:var(--ink-0);font-family:var(--cn);font-size:13px;line-height:1.6;
  box-shadow:0 18px 50px rgba(0,0,0,.38);opacity:0;pointer-events:none;transition:opacity .22s,transform .22s;
}
.task-toast.show{opacity:1;transform:translate(-50%,0)}
.daily-card.is-done,
.goal-card.is-done,
.task-card.is-done{
  border-color:rgba(90,155,106,.45);
  background:linear-gradient(180deg,rgba(90,155,106,.06),rgba(255,255,255,.012));
}
.btn.is-complete,
.btn.is-claimed{
  border-color:var(--green);color:var(--green);background:rgba(90,155,106,.08);
}
.btn.is-complete::before,
.btn.is-claimed::before{background:var(--green)}
.product-card[hidden]{display:none!important}

.profile-home-grid{
  grid-template-columns:minmax(300px,.95fr) minmax(320px,1fr) minmax(260px,.72fr);
}
.profile-history-board{
  border:1px solid var(--line-2);background:var(--bg-1);padding:clamp(22px,3vw,30px);
}
.profile-mini-rows{display:flex;flex-direction:column;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.profile-mini-rows a{
  display:grid;grid-template-columns:96px minmax(0,1fr);gap:12px;align-items:center;
  padding:14px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  transition:background .18s,border-color .18s;
}
.profile-mini-rows a:hover{background:rgba(255,255,255,.025);border-color:var(--line-2)}
.profile-mini-rows span{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;
}
.profile-mini-rows strong{
  font-family:var(--cn);font-size:13px;color:var(--ink-0);font-weight:500;line-height:1.55;overflow-wrap:anywhere;
}
.profile-activity-panel{
  margin-top:22px;border:1px solid var(--line-2);background:linear-gradient(180deg,rgba(255,255,255,.026),rgba(255,255,255,.01));
  padding:clamp(20px,2.4vw,28px);
}
.profile-activity-head{display:flex;align-items:end;justify-content:space-between;gap:18px;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:18px}
.profile-activity-head h3{font-family:var(--cn);font-size:24px;font-weight:600;color:var(--ink-0);letter-spacing:0}
.profile-activity-tabs{display:flex;gap:6px;flex-wrap:wrap}
.profile-activity-tabs button{
  border:1px solid var(--line);padding:9px 13px;font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;
}
.profile-activity-tabs button:hover,
.profile-activity-tabs button.on{color:var(--mustard);border-color:var(--mustard);background:rgba(224,184,51,.06)}
.profile-home-feed{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.profile-home-item{
  border:1px solid var(--line);background:rgba(0,0,0,.16);padding:16px;min-height:142px;
  display:flex;flex-direction:column;gap:10px;transition:background .18s,border-color .18s,transform .18s;
}
.profile-home-item:hover{background:rgba(255,255,255,.026);border-color:var(--line-2);transform:translateY(-1px)}
.profile-home-item span{
  font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.16em;text-transform:uppercase;
}
.profile-home-item strong{font-family:var(--cn);font-size:16px;color:var(--ink-0);font-weight:500;line-height:1.4}
.profile-home-item em{font-family:var(--cn);font-size:12.5px;color:var(--ink-1);font-style:normal;line-height:1.7;margin-top:auto}
.profile-empty.compact{min-height:142px}
.save-r a{color:var(--ink-0);border-bottom:1px solid var(--line-3)}
.save-mask-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

@media (max-width:1180px){
  .profile-home-grid{grid-template-columns:1fr 1fr}
  .profile-history-board{grid-column:1/-1}
  .profile-home-feed{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .profile-home-grid,
  .profile-home-feed{grid-template-columns:1fr}
  .profile-activity-head{align-items:flex-start;flex-direction:column}
  .profile-mini-rows a{grid-template-columns:1fr}
}


/* Frontend community channels and news page */
.community-channel-nav{top:0}
.community-hero-panel.clean{gap:0}
.community-page{display:none;animation:tabFade .22s ease-out}
.community-page.active{display:block}
.community-page-head{
  border:1px solid var(--line-2);background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012));
  padding:clamp(20px,2.4vw,28px);display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:end;position:relative;overflow:hidden;
}
.community-page-head::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--rust)}
.community-page-head.guide::before{background:var(--mustard)}
.community-page-head.log::before{background:var(--green)}
.community-page-head.bug::before{background:var(--rust)}
.community-page-head h2{font-family:var(--cn);font-size:clamp(22px,2.4vw,30px);line-height:1.28;color:var(--ink-0);font-weight:600;letter-spacing:0;margin:8px 0 10px}
.community-page-head p{font-family:var(--cn);font-size:13.5px;line-height:1.75;color:var(--ink-1);max-width:64ch;margin:0}
.community-page-head .btn{min-width:132px;justify-content:center}
.community-log-feed{display:grid;grid-template-columns:1fr;gap:14px}
.community-log-feed .community-note-card{display:grid;grid-template-columns:minmax(0,1fr)}
.community-log-feed .note-body{padding:20px 22px}
.community-log-feed .note-kicker span:first-child{color:var(--green)}
.community-side-block a[href^="#"]{cursor:pointer}
.news-page-hero{background:radial-gradient(ellipse 42% 60% at 84% 50%,rgba(46,91,143,.12),transparent 62%),radial-gradient(ellipse 50% 70% at 16% 40%,rgba(155,58,43,.09),transparent 64%)}
.news-board{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:22px;align-items:stretch}
.news-feature{border:1px solid var(--line-2);background:linear-gradient(135deg,rgba(155,58,43,.18),rgba(255,255,255,.025) 48%,rgba(46,91,143,.08));padding:clamp(24px,3vw,38px);position:relative;overflow:hidden;min-height:260px;display:flex;flex-direction:column;justify-content:flex-end}
.news-feature::after{content:"PATCH";position:absolute;right:-18px;bottom:-34px;font-family:var(--mono);font-size:clamp(86px,13vw,160px);font-weight:700;color:rgba(255,255,255,.035);letter-spacing:0;line-height:1}
.news-feature h2{position:relative;font-family:var(--cn);font-size:clamp(25px,3vw,42px);font-weight:700;line-height:1.18;color:var(--ink-0);letter-spacing:0;margin:10px 0 14px;max-width:820px}
.news-feature p{position:relative;font-family:var(--cn);font-size:14px;line-height:1.85;color:var(--ink-1);max-width:74ch;margin:0}
.news-feature-meta{position:relative;display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.news-feature-meta span{border:1px solid var(--line-2);background:rgba(0,0,0,.16);padding:8px 10px;font-family:var(--mono);font-size:10px;color:var(--ink-1);letter-spacing:.12em;text-transform:uppercase}
.news-alert-panel{border:1px solid var(--line-2);background:var(--bg-1);padding:22px;display:flex;flex-direction:column;gap:16px}
.news-alert-panel h3{font-family:var(--cn);font-size:22px;color:var(--ink-0);font-weight:600;letter-spacing:0}
.news-alert-panel ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.news-alert-panel li{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.65;border-top:1px solid var(--line);padding-top:12px}
.news-alert-panel li span{font-family:var(--mono);font-size:10px;color:var(--mustard);letter-spacing:.16em;margin-right:8px}
.news-timeline{border-top:1px solid var(--line-2)}
.news-timeline-item{display:grid;grid-template-columns:150px minmax(0,1fr);gap:22px;padding:22px 0;border-bottom:1px solid var(--line);position:relative}
.news-timeline-item::before{content:"";position:absolute;left:132px;top:29px;width:9px;height:9px;border:1px solid currentColor;background:var(--bg-0)}
.news-timeline-item.warn{color:var(--mustard)}
.news-timeline-item.info{color:var(--blue)}
.news-timeline-item.ok{color:var(--green)}
.news-date{font-family:var(--mono);font-size:11px;color:currentColor;letter-spacing:.18em;text-transform:uppercase;padding-top:3px}
.news-timeline-item strong{font-family:var(--cn);font-size:18px;color:var(--ink-0);font-weight:600;letter-spacing:0}
.news-timeline-item p{font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.75;margin:7px 0 0;max-width:82ch}
.news-grid-mini{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.news-mini-card{border:1px solid var(--line);background:var(--bg-1);padding:20px;min-height:160px;display:flex;flex-direction:column;gap:10px;color:inherit;transition:background .18s,border-color .18s,transform .18s}
.news-mini-card:hover{background:var(--bg-2);border-color:var(--line-2);transform:translateY(-1px)}
.news-mini-card span{font-family:var(--mono);font-size:10px;color:var(--rust-3);letter-spacing:.18em;text-transform:uppercase}
.news-mini-card strong{font-family:var(--cn);font-size:18px;color:var(--ink-0);font-weight:600;line-height:1.35}
.news-mini-card p{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7;margin:0 auto 0 0}
@media (max-width:980px){
  .news-board{grid-template-columns:1fr}
  .news-grid-mini{grid-template-columns:1fr}
}
@media (max-width:760px){
  .community-page-head{grid-template-columns:1fr;align-items:start}
  .community-page-head .btn{width:100%}
  .news-timeline-item{grid-template-columns:1fr;gap:8px;padding-left:18px}
  .news-timeline-item::before{left:0;top:29px}
}

/* ═══════════════════════════════════════════════════════
   PAGE: contact.html — 联系我们
   ═══════════════════════════════════════════════════════ */
.contact-hero{
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 0%, rgba(8,8,10,.6) 100%),
    radial-gradient(ellipse 60% 50% at 80% 0%, rgba(155,58,43,.10), transparent 70%);
}
.contact-hero-copy{
  font-family:var(--cn);font-weight:300;font-size:15px;color:var(--ink-1);
  line-height:1.75;margin-top:18px;max-width:60ch;
}
.contact-hero-copy strong{color:var(--ink-0);font-weight:500}

/* 频道矩阵 */
.contact-grid{
  display:grid;grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
}
.contact-card{
  position:relative;
  display:flex;flex-direction:column;
  border:1px solid var(--line-2);
  background:rgba(255,255,255,.025);
  padding:20px 20px 18px;
  transition:border-color .25s, background .25s, transform .25s;
}
.contact-card:hover{
  border-color:var(--line-3);
  background:rgba(255,255,255,.045);
  transform:translateY(-2px);
}
.contact-card::before{
  content:"";position:absolute;top:0;left:0;width:32px;height:3px;
  background:var(--rust-3);
}
.contact-card[data-platform="bilibili"]::before{background:#fb7299}
.contact-card[data-platform="douyin"]::before{background:#ff0050}
.contact-card[data-platform="xhs"]::before{background:#ff2442}
.contact-card[data-platform="youtube"]::before{background:#ff0000}
.contact-card[data-platform="qq"]::before{background:var(--green)}

.contact-card .cc-hd{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.contact-card .cc-num{color:var(--ink-0)}
.contact-card .cc-tag{color:var(--ink-1)}

.contact-card .cc-body{
  padding:16px 0 14px;flex:1;
  display:flex;flex-direction:column;gap:10px;min-width:0;
}
.contact-card .cc-name{
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.contact-card .cc-name .zh{
  font-family:var(--cn);font-weight:500;font-size:22px;color:var(--ink-0);
  letter-spacing:.02em;
}
.contact-card .cc-name .cc-en{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.contact-card .cc-desc{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);
  line-height:1.75;margin:0;
}
.contact-card .cc-desc-faint{color:var(--ink-2);font-size:12.5px}
.contact-card .cc-desc strong{color:var(--ink-0);font-weight:500}

.contact-card .cc-meta{
  display:grid;gap:6px;
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;
  padding-top:6px;
}
.contact-card .cc-meta > div{
  display:grid;grid-template-columns:54px minmax(0,1fr);gap:10px;align-items:baseline;
}
.contact-card .cc-meta span{color:var(--ink-2);text-transform:uppercase;letter-spacing:.14em;font-size:9.5px}
.contact-card .cc-meta strong{
  color:var(--ink-0);font-family:var(--cn);font-weight:500;font-size:12.5px;
  letter-spacing:0;
}
.contact-card .cc-meta strong.mono{font-family:var(--mono);letter-spacing:.04em}

/* 二维码框 */
.contact-card .cc-qr{
  display:flex;flex-direction:column;gap:8px;
  padding-top:14px;border-top:1px dashed var(--line-2);
}
.qr-frame{
  position:relative;width:100%;aspect-ratio:1/1;
  background:var(--bone);
  border:1px solid var(--line-3);
  overflow:hidden;
}
.qr-frame .qr-img{
  width:100%;height:100%;object-fit:contain;background:var(--bone);
}
.qr-frame .qr-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;background:var(--bone);color:var(--ink-rev);
  background-image:
    linear-gradient(45deg, var(--bone-2) 25%, transparent 25%),
    linear-gradient(-45deg, var(--bone-2) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, var(--bone-2) 75%),
    linear-gradient(-45deg, transparent 75%, var(--bone-2) 75%);
  background-size:18px 18px;
  background-position:0 0, 0 9px, 9px -9px, -9px 0;
}
.qr-frame .qr-ph-mark{
  font-family:var(--mono);font-weight:700;font-size:34px;
  color:var(--ink-rev);letter-spacing:.16em;
  background:var(--bone);padding:6px 14px;border:2px solid var(--ink-rev);
}
.qr-frame .qr-ph-note{
  font-family:var(--cn);font-size:11px;color:var(--ink-rev);opacity:.6;
  background:var(--bone);padding:2px 8px;text-align:center;line-height:1.4;
}

.cc-qr .qr-foot{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.cc-qr .qr-act{color:var(--rust-3)}

/* QQ 群宽幅卡片：占满整行（4 列），左侧文案/右侧二维码 */
.contact-card-wide{grid-column:1/-1}
.contact-card-wide .cc-body-wide{
  display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:32px;
  align-items:stretch;
}
.contact-card-wide .cc-body-wide > div{
  display:flex;flex-direction:column;gap:12px;
  min-width:0;
}
.contact-card-wide .cc-body-wide .cc-name .zh{font-size:26px}
.contact-card-wide .cc-body-wide .cc-meta{
  margin-top:auto;grid-template-columns:1fr;
}
.contact-card-wide .cc-body-wide .cc-qr{
  padding-top:0;border-top:0;
  border-left:1px dashed var(--line-2);
  padding-left:28px;
  justify-content:center;
}

/* 其他通讯方式 */
.contact-other{
  border:1px solid var(--line-2);
  background:rgba(255,255,255,.02);
}
.co-row{
  display:grid;grid-template-columns:200px minmax(0,1fr) auto;gap:24px;
  align-items:center;
  padding:18px 22px;
  border-bottom:1px solid var(--line);
}
.co-row:last-child{border-bottom:none}
.co-row:hover{background:rgba(255,255,255,.018)}
.co-row .co-lbl{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.16em;text-transform:uppercase;
}
.co-row .co-val{
  font-family:var(--mono);font-size:14px;color:var(--ink-0);font-weight:500;
  letter-spacing:.02em;word-break:break-all;
}
.co-row .co-val:not(.mono){font-family:var(--cn);letter-spacing:0;font-size:14px}
.co-row .co-state{
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 10px;border:1px solid currentColor;white-space:nowrap;
}
.co-state.co-ok{color:var(--green)}
.co-state.co-warn{color:var(--amber)}
.co-state.co-err{color:var(--rust-3)}

@media (max-width:1180px){
  .contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:780px){
  .contact-grid{grid-template-columns:1fr}
  .contact-card-wide .cc-body-wide{grid-template-columns:1fr;gap:18px}
  .contact-card-wide .cc-body-wide .cc-qr{
    border-left:0;padding-left:0;
    border-top:1px dashed var(--line-2);padding-top:14px;
  }
  .co-row{grid-template-columns:1fr;gap:8px;padding:16px 18px}
  .co-row .co-state{justify-self:start}
}

/* ═══════════════════════════════════════════════════════
   PAGE: foundation.html — 基金会（v2 / 完整重做）
   ═══════════════════════════════════════════════════════ */
.foundation-hero{
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 0%, rgba(8,8,10,.6) 100%),
    radial-gradient(ellipse 60% 60% at 100% 0%, rgba(90,155,106,.10), transparent 70%),
    radial-gradient(ellipse 60% 60% at 0% 100%, rgba(155,58,43,.08), transparent 70%);
}
.foundation-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--ink-1);
  letter-spacing:.18em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--line-2);
  margin-bottom:18px;
}
.foundation-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite;
}
.foundation-hero-h{align-items:start}
.foundation-mission{
  font-family:var(--cn);font-weight:300;font-size:16px;color:var(--ink-1);
  line-height:1.85;margin-top:22px;max-width:62ch;
}
.foundation-mission strong{color:var(--ink-0);font-weight:500}

.foundation-hero-stat{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0;border:1px solid var(--line-2);
  background:rgba(255,255,255,.025);
}
.foundation-hero-stat article{
  padding:18px 20px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
  min-width:0;
}
.foundation-hero-stat article:nth-child(2n){border-right:none}
.foundation-hero-stat article:nth-last-child(-n+2){border-bottom:none}
.foundation-hero-stat .lab{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.foundation-hero-stat .v{
  font-family:var(--sans);font-weight:600;font-size:28px;color:var(--ink-0);
  letter-spacing:-.01em;
}
.foundation-hero-stat .v em{font-style:normal;font-size:18px;color:var(--ink-1);margin-left:2px}
.foundation-hero-stat .sub{
  font-family:var(--cn);font-size:11.5px;color:var(--ink-2);line-height:1.5;
}

/* ── 资金池总览 / Command Panel ── */
.foundation-pool-section{padding-top:8px}
.pool-board{
  display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);
  gap:18px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.pool-board-main{
  padding:24px 26px;border-right:1px solid var(--line);
  min-width:0;
}
.pool-board-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}
.pool-board-eyebrow .pip{width:7px;height:7px;background:var(--mustard);display:inline-block}
.pool-board-num{
  font-family:var(--sans);font-weight:700;font-size:clamp(42px, 6vw, 64px);
  color:var(--ink-0);letter-spacing:-.02em;line-height:1.05;
  margin-top:8px;
}
.pool-board-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:0 12px;
  font-family:var(--cn);font-size:13px;color:var(--ink-1);
  margin-top:8px;
}
.pool-board-meta strong{color:var(--ink-0);font-weight:500}
.pool-board-meta .g{color:var(--green)}
.pool-board-meta .sep{color:var(--ink-3)}

.pool-bar{
  display:flex;height:34px;margin:22px 0 14px;
  border:1px solid var(--line-2);background:var(--bg-2);overflow:hidden;
}
.pool-bar .seg{
  display:block;width:var(--w);position:relative;
  border-right:1px solid rgba(0,0,0,.4);
  transition:opacity .2s;
}
.pool-bar .seg:last-child{border-right:none}
.pool-bar .seg:hover{filter:brightness(1.15)}
.pool-bar .seg-aid    { background: linear-gradient(180deg, #ff7a5c, #c95a44) }
.pool-bar .seg-dream  { background: linear-gradient(180deg, #f6c95a, #c5832d) }
.pool-bar .seg-proj   { background: linear-gradient(180deg, #79b48b, #4e8a64) }
.pool-bar .seg-venture{ background: linear-gradient(180deg, #7aa1cf, #4f6b8a) }
.pool-bar .seg-divid  { background: linear-gradient(180deg, #c2a989, #8a7659) }
.pool-bar .seg::after{
  content:attr(data-name);
  position:absolute;left:8px;top:50%;transform:translateY(-50%);
  font-family:var(--mono);font-size:10px;color:rgba(0,0,0,.7);font-weight:600;
  letter-spacing:.04em;white-space:nowrap;
}

.pool-legend{
  list-style:none;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px;margin-top:14px;
}
.pool-legend li{
  display:flex;flex-direction:column;gap:4px;
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  padding:10px 12px;border:1px solid var(--line);background:rgba(255,255,255,.015);
  min-width:0;
}
.pool-legend li .dot{width:10px;height:10px;display:inline-block;align-self:flex-start}
.pool-legend .seg-aid    { background: #c95a44 }
.pool-legend .seg-dream  { background: #c5832d }
.pool-legend .seg-proj   { background: #4e8a64 }
.pool-legend .seg-venture{ background: #4f6b8a }
.pool-legend .seg-divid  { background: #8a7659 }
.pool-legend .name{font-family:var(--cn);font-size:12px;color:var(--ink-0);letter-spacing:0}
.pool-legend .pct{color:var(--ink-2);font-size:10px;letter-spacing:.14em}
.pool-legend .val{color:var(--ink-0);font-weight:500;font-size:12px}

.pool-board-side{
  display:flex;flex-direction:column;
  padding:14px 18px;gap:0;
  min-width:0;
}
.pool-board-side article{
  padding:14px 0;border-bottom:1px dashed var(--line-2);
  display:flex;flex-direction:column;gap:3px;
}
.pool-board-side article:last-of-type{border-bottom:none}
.pool-board-side .lab{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.pool-board-side article strong{
  font-family:var(--sans);font-weight:700;font-size:22px;color:var(--ink-0);
}
.pool-board-side article strong em{font-style:normal;font-size:14px;color:var(--ink-1);margin-left:2px}
.pool-board-side .sub{
  font-family:var(--cn);font-size:11.5px;color:var(--ink-2);
}
.pool-board-side .pool-cta{
  display:flex;flex-direction:column;gap:8px;padding-top:18px;border-top:1px solid var(--line);
}
.pool-board-side .pool-cta .btn{justify-content:space-between}

/* ── 5 大基金 / Bucket Grid ── */
.foundation-principles{
  display:grid;grid-template-columns:repeat(4, minmax(0,1fr));gap:12px;
}
.foundation-principles article{
  padding:18px 18px 16px;
  background:rgba(255,255,255,.025);border:1px solid var(--line);
}

.bucket-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;
}
.bucket-card{
  position:relative;
  display:flex;flex-direction:column;gap:12px;
  padding:22px 22px 22px;
  border:1px solid var(--line-2);
  background:rgba(255,255,255,.025);
  min-width:0;
  transition:border-color .25s, background .25s, transform .25s;
}
.bucket-card:hover{
  border-color:var(--line-3);
  background:rgba(255,255,255,.04);
  transform:translateY(-2px);
}
.bucket-card::before{
  content:"";position:absolute;top:0;left:0;width:42px;height:3px;
}
.bk-aid::before    { background: #c95a44 }
.bk-dream::before  { background: #c5832d }
.bk-proj::before   { background: #4e8a64 }
.bk-venture::before{ background: #4f6b8a }
.bk-divid::before  { background: #8a7659 }

.bucket-card header{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
  padding-bottom:10px;border-bottom:1px solid var(--line);
}
.bk-code{color:var(--ink-0);font-weight:600}
.bk-stat{display:inline-flex;align-items:center;gap:6px;font-size:10px}
.bk-stat .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite}
.bk-stat.beta .dot{background:var(--amber);animation-name:pulseAmber}

.bk-name{
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-top:2px;
}
.bk-name .zh{font-family:var(--cn);font-weight:500;font-size:22px;color:var(--ink-0);letter-spacing:.02em}
.bk-name .en{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase}

.bk-desc{
  font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.8;
  flex:1;
}
.bk-desc strong{color:var(--ink-0);font-weight:500}
.bk-desc a{color:var(--rust-3);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}

.bk-meter{
  width:100%;height:5px;background:var(--bg-2);border:1px solid var(--line);
  overflow:hidden;
}
.bk-meter span{
  display:block;width:var(--p, 0%);height:100%;
  background:linear-gradient(90deg, var(--ink-1), var(--ink-0));
  transition:width .8s ease;
}
.bk-aid    .bk-meter span{background:linear-gradient(90deg, #ff7a5c, #c95a44)}
.bk-dream  .bk-meter span{background:linear-gradient(90deg, #f6c95a, #c5832d)}
.bk-proj   .bk-meter span{background:linear-gradient(90deg, #79b48b, #4e8a64)}
.bk-venture .bk-meter span{background:linear-gradient(90deg, #7aa1cf, #4f6b8a)}
.bk-divid  .bk-meter span{background:linear-gradient(90deg, #c2a989, #8a7659)}

.bk-rows{
  display:grid;gap:7px;
  font-family:var(--mono);font-size:11px;
  padding-top:4px;
}
.bk-rows > div{
  display:grid;grid-template-columns:80px minmax(0,1fr);gap:10px;align-items:baseline;
}
.bk-rows span{color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;font-size:9.5px}
.bk-rows strong{
  color:var(--ink-0);font-family:var(--cn);font-weight:500;font-size:12.5px;letter-spacing:0;
}
.bk-rows strong.g{color:var(--green)}

.bucket-card .btn{align-self:flex-start;margin-top:4px}

/* 砖块红利宽幅卡片 */
.bucket-card.bk-wide{grid-column:1 / -1}
.bk-wide-body{
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
  gap:32px;align-items:center;
}
.bk-divid-bullets{
  display:grid;gap:7px;font-family:var(--cn);font-size:13px;color:var(--ink-1);
  margin-top:8px;
}
.bk-divid-bullets span{display:flex;align-items:baseline;gap:10px}
.bk-divid-bullets i{
  width:6px;height:6px;background:#c2a989;display:inline-block;flex-shrink:0;
  transform:translateY(-2px);
}
.bk-divid-bullets a{color:var(--rust-3);text-decoration:underline;text-underline-offset:3px}

.bk-divid-num{
  padding:22px;
  border:1px solid var(--line-2);background:rgba(194,169,137,.06);
  display:flex;flex-direction:column;gap:8px;
  position:relative;
}
.bk-divid-num::before{
  content:"";position:absolute;top:0;left:0;width:32px;height:3px;background:#c2a989;
}
.bk-divid-num .lab{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.bk-divid-num .num{
  font-family:var(--sans);font-weight:700;font-size:32px;color:var(--ink-0);
  letter-spacing:-.01em;line-height:1.1;
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.bk-divid-num .brick-icon{
  display:inline-grid;place-items:center;width:32px;height:32px;
  background:#c2a989;color:#1a1410;font-size:16px;
  font-family:var(--cn);font-weight:700;letter-spacing:0;
}
.bk-divid-num .sub{font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.7}
.bk-divid-num .sub strong{color:var(--ink-0);font-weight:500}
.bk-divid-num .btn{margin-top:8px;align-self:flex-start}

/* ── 自营项目卡 ── */
.proj-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;
}
.proj-card{
  padding:20px;background:rgba(255,255,255,.025);border:1px solid var(--line-2);
  display:flex;flex-direction:column;gap:12px;min-width:0;
  transition:border-color .25s, background .25s;
}
.proj-card:hover{border-color:var(--line-3);background:rgba(255,255,255,.04)}
.proj-card header{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.proj-tag{color:var(--green);border:1px solid currentColor;padding:3px 8px}
.proj-id{color:var(--ink-1)}
.proj-card h4{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;margin-top:2px;
}
.proj-card p{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.8}
.proj-card p strong{color:var(--ink-0);font-weight:500}
.proj-rows{
  display:grid;gap:6px;font-family:var(--mono);font-size:11px;
  padding-top:4px;border-top:1px dashed var(--line-2);
}
.proj-rows > div{
  display:grid;grid-template-columns:80px minmax(0,1fr);gap:10px;align-items:baseline;
}
.proj-rows span{color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;font-size:9.5px}
.proj-rows strong{color:var(--ink-0);font-family:var(--cn);font-weight:500;font-size:12px;letter-spacing:0}
.proj-bar{
  width:100%;height:4px;background:var(--bg-2);border:1px solid var(--line);overflow:hidden;
}
.proj-bar span{
  display:block;width:var(--p,0%);height:100%;
  background:linear-gradient(90deg, #79b48b, #4e8a64);
}

/* ── Venture / 投资组合 ── */
.venture-board{
  display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:18px;
}
.venture-portfolio{
  padding:22px 24px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
  min-width:0;
}
.vp-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:18px;
  flex-wrap:wrap;margin-bottom:14px;
}
.vp-head h3{font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);letter-spacing:.02em}
.vp-meta{font-family:var(--cn);font-size:12.5px;color:var(--ink-1)}
.vp-meta strong{color:var(--ink-0);font-weight:500}
.vp-meta .g{color:var(--green)}

.vp-table{
  width:100%;border-collapse:collapse;
  font-family:var(--cn);font-size:13px;
}
.vp-table thead th{
  text-align:left;padding:10px 12px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  border-bottom:1px solid var(--line-2);
}
.vp-table tbody td{
  padding:14px 12px;border-bottom:1px solid var(--line);
  color:var(--ink-1);vertical-align:top;
}
.vp-table tbody tr:hover{background:rgba(255,255,255,.018)}
.vp-table strong{color:var(--ink-0);font-weight:500;font-size:13.5px}
.vp-table .sm{font-size:11.5px;color:var(--ink-2);font-family:var(--cn);}
.vp-tag{
  display:inline-block;padding:3px 8px;font-family:var(--mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;border:1px solid currentColor;
}
.vp-tag.g{color:var(--green)}
.vp-tag.a{color:var(--amber)}

.vp-more{
  display:inline-block;margin-top:14px;
  font-family:var(--mono);font-size:11px;color:var(--rust-3);
  letter-spacing:.14em;text-transform:uppercase;
  border-bottom:1px dashed currentColor;padding-bottom:2px;
}
.vp-more:hover{color:var(--bone)}

.venture-pitch{
  padding:24px;border:1px solid var(--line-2);
  background:linear-gradient(180deg, rgba(79,107,138,.10), rgba(255,255,255,.015));
  display:flex;flex-direction:column;gap:14px;
}
.vp-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;color:var(--ink-1);
  letter-spacing:.18em;text-transform:uppercase;
}
.vp-eyebrow .pip{width:7px;height:7px;background:#7aa1cf;display:inline-block}
.venture-pitch h3{
  font-family:var(--cn);font-weight:500;font-size:26px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.3;
}
.venture-pitch p{font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.8}
.vp-list{list-style:none;display:grid;gap:8px;font-family:var(--mono);font-size:11px;padding-top:4px;border-top:1px dashed var(--line-2);margin-top:4px}
.vp-list li{
  display:grid;grid-template-columns:100px minmax(0,1fr);gap:10px;align-items:baseline;
  padding-top:6px;
}
.vp-list span{color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;font-size:9.5px}
.vp-list strong{color:var(--ink-0);font-family:var(--cn);font-weight:500;font-size:13px;letter-spacing:0}
.venture-pitch .btn{align-self:flex-start}
.vp-foot{
  font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;
  padding-top:4px;border-top:1px solid var(--line);margin-top:4px;
}

/* ── 资金流向 / 桑基图 ── */
.flow-board{
  padding:22px 26px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.flow-head{margin-bottom:22px}
.flow-head h3{font-family:var(--cn);font-weight:500;font-size:20px;color:var(--ink-0);letter-spacing:.02em}
.flow-head p{font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.75;margin-top:6px}
.flow-head strong{color:var(--ink-0);font-weight:500}
.flow-head .g{color:var(--green)}

.flow-sankey{
  display:grid;grid-template-columns:1fr 220px 1fr;gap:18px;
  align-items:center;
  padding:18px 0;
  border-top:1px dashed var(--line-2);border-bottom:1px dashed var(--line-2);
}
.flow-col{display:flex;flex-direction:column;gap:8px;min-width:0}
.flow-col-title{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;margin-bottom:4px;
}
.flow-node{
  position:relative;
  padding:12px 14px;border:1px solid var(--line-2);
  background:rgba(255,255,255,.025);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-family:var(--cn);font-size:13px;color:var(--ink-0);
  min-height:calc(46px + var(--h, 20%) * .3);
  transition:border-color .2s, background .2s;
}
.flow-node:hover{border-color:var(--line-3);background:rgba(255,255,255,.05)}
.flow-node::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ink-2);
}
.flow-node .lab{font-weight:500;color:var(--ink-0)}
.flow-node .val{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:13px;color:var(--ink-1)}

.flow-src .flow-node::before{background:var(--green)}
.flow-src .flow-node:nth-child(3)::before{background:#7aa1cf}
.flow-src .flow-node:nth-child(4)::before{background:#c5832d}
.flow-src .flow-node:nth-child(5)::before{background:#c2a989}

.flow-dst .flow-node.f-aid::before    { background:#c95a44 }
.flow-dst .flow-node.f-dream::before  { background:#c5832d }
.flow-dst .flow-node.f-proj::before   { background:#4e8a64 }
.flow-dst .flow-node.f-venture::before{ background:#4f6b8a }
.flow-dst .flow-node.f-divid::before  { background:#8a7659 }

.flow-pool{align-items:center;justify-content:center;align-self:stretch}
.flow-pool-card{
  width:100%;padding:22px 16px;
  background:linear-gradient(180deg, rgba(226,55,37,.10), rgba(255,255,255,.02));
  border:1px solid var(--rev);text-align:center;
  display:flex;flex-direction:column;gap:6px;
  position:relative;
}
.flow-pool-card::before{
  content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:4px;background:var(--rev);
}
.flow-pool-eyebrow{
  font-family:var(--mono);font-size:10px;color:var(--rev);
  letter-spacing:.2em;text-transform:uppercase;
}
.flow-pool-card strong{
  font-family:var(--sans);font-weight:700;font-size:28px;color:var(--ink-0);
  letter-spacing:-.01em;
}
.flow-pool-sub{font-family:var(--cn);font-size:11px;color:var(--ink-2)}

.flow-recent{margin-top:22px}
.flow-recent h4{
  font-family:var(--cn);font-weight:500;font-size:15px;color:var(--ink-0);
  letter-spacing:.02em;margin-bottom:10px;
}
.flow-table{
  width:100%;border-collapse:collapse;font-family:var(--cn);font-size:13px;
}
.flow-table thead th{
  text-align:left;padding:10px 12px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  border-bottom:1px solid var(--line-2);
}
.flow-table tbody td{
  padding:12px;border-bottom:1px solid var(--line);
  color:var(--ink-1);
}
.flow-table tbody tr:hover{background:rgba(255,255,255,.018)}
.flow-table .mono{font-size:11.5px;color:var(--ink-2);letter-spacing:.04em}
.flow-table .tabnum{color:var(--ink-0);font-family:var(--mono);font-weight:500}

/* ── 财报简版 ── */
.report-board{
  padding:24px 26px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.report-stat{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;
  border:1px solid var(--line);
  margin-bottom:24px;
}
.report-stat article{
  padding:18px 20px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
}
.report-stat article:last-child{border-right:none}
.report-stat .lab{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.report-stat .num{
  font-family:var(--sans);font-weight:700;font-size:26px;color:var(--ink-0);
  letter-spacing:-.01em;
}
.report-stat .sub{font-family:var(--cn);font-size:11.5px;color:var(--ink-2)}
.report-stat .sub.g{color:var(--green)}

.report-bars h4{
  font-family:var(--cn);font-weight:500;font-size:15px;color:var(--ink-0);
  letter-spacing:.02em;margin-bottom:14px;
}
.bar-chart{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  height:240px;
  padding:18px 18px 38px;
  border:1px solid var(--line-2);background:rgba(0,0,0,.18);
  position:relative;
}
.bar-chart::before,
.bar-chart::after{
  content:"";position:absolute;left:18px;right:18px;height:1px;background:var(--line);
  bottom:38px;
}
.bar-chart::after{bottom:calc(38px + 50%);background:var(--line)}
.bar-group{
  position:relative;display:flex;flex-direction:column;align-items:center;
  height:100%;
}
.bar-pair{
  display:flex;align-items:flex-end;gap:8px;
  flex:1;width:100%;justify-content:center;
}
.bar{
  width:32px;
  height:var(--h, 30%);
  position:relative;
  transition:filter .2s;
}
.bar:hover{filter:brightness(1.2)}
.bar::after{
  content:attr(data-v);
  position:absolute;left:50%;top:-22px;transform:translateX(-50%);
  font-family:var(--mono);font-size:9.5px;color:var(--ink-1);
  letter-spacing:.04em;white-space:nowrap;
}
.bar.bar-rev   { background:linear-gradient(180deg, #ff7a5c, #c95a44) }
.bar.bar-fund  { background:linear-gradient(180deg, #79b48b, #4e8a64) }
.bar-group.current .bar{box-shadow:0 0 0 1px rgba(232,230,225,.4)}
.bar-label{
  position:absolute;bottom:-30px;left:0;right:0;text-align:center;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.bar-group.current .bar-label{color:var(--ink-0)}

.bar-legend{
  display:flex;gap:24px;margin-top:14px;
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  letter-spacing:.14em;text-transform:uppercase;
}
.bar-legend span{display:inline-flex;align-items:center;gap:8px}
.bar-legend i.dot{width:10px;height:10px;display:inline-block}
.bar-legend i.bar-rev { background:#c95a44 }
.bar-legend i.bar-fund{ background:#4e8a64 }

.report-foot{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  flex-wrap:wrap;
  margin-top:24px;padding-top:18px;
  border-top:1px dashed var(--line-2);
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.report-foot a{color:var(--rust-3);border-bottom:1px dashed currentColor;padding-bottom:2px}
.report-foot a:hover{color:var(--bone)}

/* ── 募捐面板 v2 ── */
.donate-panel-v2{display:grid;gap:16px;grid-template-columns:1fr}
.donate-panel-v2 .donate-options{
  display:flex;gap:8px;flex-wrap:wrap;
}
.donate-panel-v2 .donate-options button{
  padding:11px 18px;border:1px solid var(--line-2);background:transparent;
  font-family:var(--mono);font-size:13px;color:var(--ink-1);
  letter-spacing:.04em;cursor:pointer;transition:all .2s;
}
.donate-panel-v2 .donate-options button:hover{border-color:var(--line-3);color:var(--ink-0)}
.donate-panel-v2 .donate-options button.active{
  border-color:var(--rust-3);color:var(--bone);background:rgba(201,90,68,.12);
}
.donate-targets{
  display:flex;gap:10px;flex-wrap:wrap;
}
.dt-btn{
  flex:1 1 160px;
  padding:14px 16px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
  font-family:var(--cn);font-size:14px;font-weight:500;color:var(--ink-0);
  letter-spacing:.02em;cursor:pointer;transition:all .25s;
  display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  text-align:left;
}
.dt-btn span{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.dt-btn:hover{border-color:var(--line-3);background:rgba(255,255,255,.05)}
.dt-btn.active{
  border-color:var(--green);background:rgba(90,155,106,.08);
}
.dt-btn.active span{color:var(--green)}

/* ── 申请通道 ── */
.apply-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

/* ── 响应式 ── */
@media (max-width:1180px){
  .pool-board{grid-template-columns:1fr}
  .pool-board-main{border-right:none;border-bottom:1px solid var(--line)}
  .pool-legend{grid-template-columns:repeat(2,minmax(0,1fr))}
  .bucket-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .foundation-principles{grid-template-columns:repeat(2,minmax(0,1fr))}
  .proj-grid{grid-template-columns:1fr}
  .venture-board{grid-template-columns:1fr}
  .flow-sankey{grid-template-columns:1fr;gap:14px}
  .report-stat{grid-template-columns:repeat(2,minmax(0,1fr))}
  .report-stat article:nth-child(2n){border-right:none}
  .report-stat article:nth-child(-n+2){border-bottom:1px solid var(--line)}
}
@media (max-width:760px){
  .foundation-hero-stat{grid-template-columns:1fr}
  .foundation-hero-stat article{border-right:none}
  .foundation-hero-stat article:not(:last-child){border-bottom:1px solid var(--line)}
  .bucket-grid{grid-template-columns:1fr}
  .bucket-card.bk-wide{grid-column:auto}
  .bk-wide-body{grid-template-columns:1fr;gap:18px}
  .foundation-principles{grid-template-columns:1fr}
  .bar-chart{height:200px;gap:8px;padding:14px 12px 32px}
  .bar{width:22px}
  .bar::after{font-size:8.5px;top:-18px}
  .report-stat{grid-template-columns:1fr}
  .report-stat article{border-right:none;border-bottom:1px solid var(--line)}
  .report-stat article:last-child{border-bottom:none}
  .pool-bar{height:28px}
  .pool-bar .seg::after{display:none}
  .vp-table{font-size:12px}
  .vp-table thead{display:none}
  .vp-table tbody td{display:block;padding:4px 0;border-bottom:none}
  .vp-table tbody tr{display:block;padding:12px 0;border-bottom:1px solid var(--line)}
  .flow-table{font-size:12px}
}

/* ═══════════════════════════════════════════════════════
   PAGE: news.html — 新闻页（v2 / 完整重做）
   ═══════════════════════════════════════════════════════ */

/* ── HERO（旧紧凑型 · 已弃用，保留兼容） ── */
.news-hero-v2{
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 0%, rgba(8,8,10,.6) 100%),
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(226,55,37,.10), transparent 70%);
}
.news-hero-grid{
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
  gap:36px;align-items:center;
  margin-top:14px;
}
.news-hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--ink-1);
  letter-spacing:.18em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--line-2);
  margin-bottom:18px;
}
.news-hero-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--rev);
  box-shadow:0 0 0 0 rgba(226,55,37,.5);animation:pulse 2.4s ease-in-out infinite;
}
.news-hero-lead h1{
  display:flex;align-items:baseline;flex-wrap:wrap;gap:0 14px;
  font-family:var(--cn);font-weight:500;
  font-size:clamp(28px, 3.6vw, 42px);line-height:1.25;color:var(--ink-0);
  letter-spacing:.02em;
}
.news-hero-lead h1 .zh{font-family:var(--cn)}
.news-hero-lead h1 .accent{color:var(--rev)}
.news-hero-desc{
  font-family:var(--cn);font-weight:300;font-size:15px;color:var(--ink-1);
  line-height:1.8;margin-top:18px;max-width:54ch;
}
.news-hero-desc strong{color:var(--ink-0);font-weight:500}

.news-hero-stat{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
}
.nhs-card{
  display:flex;flex-direction:column;gap:5px;
  padding:18px 20px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  color:inherit;transition:background .25s;cursor:pointer;
  min-width:0;
}
.nhs-card:nth-child(2n){border-right:none}
.nhs-card:nth-last-child(-n+2){border-bottom:none}
.nhs-card:hover{background:rgba(255,255,255,.05)}
.nhs-card .lab{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.nhs-card .v{
  font-family:var(--sans);font-weight:700;font-size:32px;color:var(--ink-0);
  letter-spacing:-.01em;line-height:1.1;
}
.nhs-card .sub{font-family:var(--cn);font-size:11.5px;color:var(--ink-1)}
.nhs-card:hover .v{color:var(--rev)}

/* ── 《核心着陆区》Banner ── */
.lz-section{
  padding: clamp(20px, 3vw, 32px) var(--pad-x);
  position:relative;z-index:5;
}
.lz-banner{
  position:relative;overflow:hidden;
  max-width:var(--maxw);margin:0 auto;
  border:1px solid var(--line-2);
  background:
    linear-gradient(180deg, rgba(8,8,10,.92) 0%, rgba(13,13,16,.88) 100%),
    radial-gradient(ellipse 80% 60% at 20% 50%, rgba(226,55,37,.18), transparent 70%);
  min-height:480px;
}
/* 背景层 */
.lz-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.lz-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(232,230,225,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(232,230,225,.05) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, #000 30%, transparent 90%);
}
.lz-radar{
  position:absolute;right:-180px;top:50%;transform:translateY(-50%);
  width:520px;height:520px;
}
.lz-radar span{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  border:1px dashed rgba(226,55,37,.35);border-radius:50%;
}
.lz-radar span:nth-child(1){width:120px;height:120px;animation:lzPulse 4s ease-in-out infinite}
.lz-radar span:nth-child(2){width:280px;height:280px;animation:lzPulse 4s ease-in-out infinite 1s}
.lz-radar span:nth-child(3){width:480px;height:480px;animation:lzPulse 4s ease-in-out infinite 2s}
@keyframes lzPulse{0%,100%{opacity:.25}50%{opacity:.55}}
.lz-scan{
  position:absolute;left:0;right:0;top:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rev), transparent);
  opacity:.5;animation:lzScan 6s linear infinite;
}
@keyframes lzScan{
  0%{top:0;opacity:0}
  10%{opacity:.6}
  90%{opacity:.6}
  100%{top:100%;opacity:0}
}

.lz-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
  gap:42px;
  padding:42px 44px;
}

.lz-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--rev);
  letter-spacing:.2em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--rev);
  background:rgba(226,55,37,.08);
}
.lz-tag .dot{
  width:6px;height:6px;border-radius:50%;background:var(--rev);
  box-shadow:0 0 0 0 rgba(226,55,37,.5);animation:pulse 2.4s ease-in-out infinite;
}
.lz-codename{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.24em;text-transform:uppercase;margin-top:18px;
}
.lz-title{
  display:flex;align-items:baseline;flex-wrap:wrap;gap:0 16px;
  font-family:var(--cn);font-weight:600;
  font-size:clamp(36px, 5vw, 58px);line-height:1.1;color:var(--ink-0);
  letter-spacing:.02em;margin-top:8px;
}
.lz-title .zh{font-family:var(--cn-serif);font-weight:700;color:var(--ink-1);font-size:.65em}
.lz-title .lz-sep{color:var(--rev);font-weight:300}
.lz-title .lz-sub{
  font-family:var(--cn);font-weight:600;color:var(--ink-0);
  position:relative;
}
.lz-title .lz-sub::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:3px;background:var(--rev);
}
.lz-desc{
  font-family:var(--cn);font-weight:300;font-size:16px;color:var(--ink-1);
  line-height:1.85;margin-top:24px;max-width:54ch;
}
.lz-desc strong{color:var(--ink-0);font-weight:500}

.lz-milestones{
  list-style:none;display:grid;gap:6px;margin-top:24px;padding-top:18px;
  border-top:1px dashed var(--line-2);
}
.lz-milestones li{
  display:grid;grid-template-columns:18px 80px minmax(0,1fr);gap:12px;
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.04em;
  padding:5px 0;align-items:center;
}
.lz-milestones .dot{
  width:8px;height:8px;border-radius:50%;background:var(--ink-3);justify-self:center;
}
.lz-milestones strong{color:var(--ink-1);font-family:var(--mono);font-weight:600;letter-spacing:.1em}
.lz-milestones li span:last-child{
  font-family:var(--cn);font-size:12.5px;color:var(--ink-1);letter-spacing:0;
}
.lz-milestones li.done .dot{background:var(--green)}
.lz-milestones li.done strong{color:var(--ink-0)}
.lz-milestones li.active .dot{
  background:var(--rev);
  box-shadow:0 0 0 0 rgba(226,55,37,.55);
  animation:pulseRev 1.8s ease-in-out infinite;
}
.lz-milestones li.active strong{color:var(--rev)}
.lz-milestones li.active span:last-child{color:var(--ink-0)}
@keyframes pulseRev{0%,100%{box-shadow:0 0 0 0 rgba(226,55,37,.55)}50%{box-shadow:0 0 0 7px rgba(226,55,37,0)}}

.lz-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}

/* 右侧数据 */
.lz-data{
  display:flex;flex-direction:column;gap:14px;min-width:0;
}
.lz-data-card{
  display:flex;flex-direction:column;gap:6px;
  padding:18px 20px;
  background:linear-gradient(180deg, rgba(226,55,37,.10), rgba(255,255,255,.02));
  border:1px solid var(--rev);position:relative;
}
.lz-data-card::before{
  content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:3px;background:var(--rev);
}
.lz-data-card .lab{
  font-family:var(--mono);font-size:10px;color:var(--rev);
  letter-spacing:.18em;text-transform:uppercase;
}
.lz-data-card .v{
  font-family:var(--sans);font-weight:700;font-size:44px;color:var(--ink-0);
  letter-spacing:-.02em;line-height:1;
}
.lz-data-card .v em{font-style:normal;font-size:16px;color:var(--ink-1);margin-left:6px}
.lz-data-card .sub{font-family:var(--cn);font-size:11.5px;color:var(--ink-2)}

.lz-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid var(--line-2);
}
.lz-stats > div{
  padding:14px 12px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:3px;
  background:rgba(255,255,255,.02);
  min-width:0;
}
.lz-stats > div:last-child{border-right:none}
.lz-stats span{
  font-family:var(--mono);font-size:9px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.lz-stats strong{
  font-family:var(--sans);font-weight:700;font-size:18px;color:var(--ink-0);
}
.lz-stats strong.r{color:var(--rev)}

.lz-trailer{
  display:flex;flex-direction:column;gap:6px;cursor:pointer;
  text-decoration:none;color:inherit;
}
.lz-trailer-cover{
  position:relative;aspect-ratio:16/9;
  background:
    linear-gradient(135deg, rgba(226,55,37,.18), rgba(8,8,10,.4)),
    repeating-linear-gradient(90deg, rgba(232,230,225,.04) 0 1px, transparent 1px 12px),
    var(--bg-2);
  border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  transition:border-color .25s;
}
.lz-trailer:hover .lz-trailer-cover{border-color:var(--rev)}
.lz-play{
  position:relative;z-index:2;
  width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;
  font-size:18px;color:#fff;
  background:rgba(226,55,37,.92);
  border:2px solid #fff;
  transition:transform .25s, background .25s;
}
.lz-trailer:hover .lz-play{transform:scale(1.08);background:var(--rev-2)}
.lz-trailer-tag{
  position:absolute;left:10px;bottom:10px;
  font-family:var(--mono);font-size:10px;color:var(--bone);
  letter-spacing:.14em;text-transform:uppercase;
  background:rgba(0,0,0,.6);padding:4px 10px;
}
.lz-trailer-cap{
  font-family:var(--mono);font-size:9.5px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}

/* ── Tab 切换器（旧版 sticky，已被新版替代） ── */
.news-tabs-section{padding-top:6px}
.news-tabs-section .news-tabs-bar{
  position:sticky;top:64px;z-index:20;
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;
  background:rgba(8,8,10,.92);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line-2);
  margin-bottom:28px;
}
.news-tab{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;
  border-right:1px solid var(--line);
  background:transparent;cursor:pointer;
  text-align:left;color:var(--ink-1);
  transition:background .25s, color .25s;
  font-family:inherit;
  position:relative;
}
.news-tab:last-child{border-right:none}
.news-tab:hover{background:rgba(255,255,255,.025);color:var(--ink-0)}
.news-tab.is-active{color:var(--ink-0);background:rgba(226,55,37,.06)}
.news-tab.is-active::before{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--rev);
}
.nt-idx{
  font-family:var(--mono);font-weight:600;font-size:11px;color:var(--ink-2);
  letter-spacing:.14em;
}
.news-tab.is-active .nt-idx{color:var(--rev)}
.nt-name{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.nt-name .zh{font-family:var(--cn);font-weight:500;font-size:16px;color:inherit;letter-spacing:.02em}
.nt-name .en{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase}
.news-tab.is-active .nt-name .en{color:var(--ink-1)}
.nt-count{
  font-family:var(--mono);font-variant-numeric:tabular-nums;
  font-size:14px;font-weight:600;color:var(--ink-0);
  padding:3px 8px;border:1px solid var(--line-2);background:var(--bg-2);
  flex-shrink:0;
}
.news-tab.is-active .nt-count{border-color:var(--rev);color:var(--rev)}

/* Tab Panel */
.news-tab-panel{display:none}
.news-tab-panel.is-active{display:block}
.ntp-head{
  display:flex;align-items:end;justify-content:space-between;gap:18px;
  flex-wrap:wrap;margin-bottom:22px;
}
.ntp-head h2{margin-top:6px}

/* ── 公司动态卡片 ── */
.company-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
.company-card{
  padding:22px 24px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  display:flex;flex-direction:column;gap:10px;min-width:0;
  transition:border-color .25s, background .25s, transform .25s;
  position:relative;
}
.company-card:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.04);transform:translateY(-2px);
}
.company-card.is-feature{
  grid-column:span 2;
  background:linear-gradient(180deg, rgba(226,55,37,.06), rgba(255,255,255,.02));
  border-color:var(--rev-edge, rgba(226,55,37,.4));
}
.company-card.is-feature::before{
  content:"";position:absolute;top:0;left:0;width:48px;height:3px;background:var(--rev);
}
.company-card header{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;
}
.cc-tag{
  color:var(--ink-0);padding:3px 8px;
  border:1px solid var(--line-3);font-weight:500;
}
.cc-lvl{
  padding:3px 8px;border:1px solid currentColor;
}
.cc-lvl.lvl-info{color:var(--blue)}
.cc-lvl.lvl-ok{color:var(--green)}
.cc-lvl.lvl-warn{color:var(--mustard)}
.cc-date{color:var(--ink-2);margin-left:auto}
.company-card h3{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.4;
}
.company-card.is-feature h3{font-size:22px}
.company-card p{font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.8}
.company-card p.cc-body{color:var(--ink-2);font-size:12.5px;border-top:1px dashed var(--line);padding-top:10px;margin-top:4px}
.company-card footer{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:8px;border-top:1px dashed var(--line);
  margin-top:auto;
}
.cc-id{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.14em}

/* ── 游戏内新闻卡片 ── */
.game-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
.game-card{
  display:flex;gap:0;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  transition:border-color .25s, background .25s, transform .25s;
  min-width:0;
}
.game-card:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.04);transform:translateY(-2px);
}
.gc-bar{
  width:4px;flex-shrink:0;background:var(--ink-2);
}
.game-card.lvl-info .gc-bar{background:var(--blue)}
.game-card.lvl-ok   .gc-bar{background:var(--green)}
.game-card.lvl-warn .gc-bar{background:var(--mustard)}
.gc-body{padding:18px 20px;flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}
.gc-body header{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
}
.gc-lvl{
  padding:3px 8px;border:1px solid currentColor;font-weight:600;color:inherit;
}
.game-card.lvl-info .gc-lvl{color:var(--blue)}
.game-card.lvl-ok   .gc-lvl{color:var(--green)}
.game-card.lvl-warn .gc-lvl{color:var(--mustard)}
.gc-tag{color:var(--ink-1);padding:3px 8px;border:1px dashed var(--line-2)}
.gc-date{color:var(--ink-2);margin-left:auto}
.game-card h3{
  font-family:var(--cn);font-weight:500;font-size:16px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.5;
}
.game-card p{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.8}
.gc-body-long{color:var(--ink-2);font-size:12.5px;border-top:1px dashed var(--line);padding-top:8px}

/* ── 视频墙 ── */
.video-chips{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;
}
.video-chips .chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border:1px solid var(--line-2);
  background:transparent;color:var(--ink-1);
  font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  cursor:pointer;transition:all .2s;
}
.video-chips .chip:hover{border-color:var(--line-3);color:var(--ink-0)}
.video-chips .chip.is-active{
  border-color:var(--rev);color:var(--bone);background:rgba(226,55,37,.08);
}
.video-chips .chip .ct{
  font-family:var(--mono);font-variant-numeric:tabular-nums;
  font-size:10px;color:var(--ink-2);padding:1px 6px;
  border:1px solid var(--line-2);
}
.video-chips .chip.is-active .ct{color:var(--rev);border-color:var(--rev)}

.video-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;
}
.video-card{
  display:flex;flex-direction:column;gap:0;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  color:inherit;text-decoration:none;cursor:pointer;
  transition:border-color .25s, background .25s, transform .25s;
  min-width:0;overflow:hidden;
}
.video-card:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.04);transform:translateY(-2px);
}
.vc-cover{
  position:relative;aspect-ratio:16/9;
  overflow:hidden;background:var(--bg-2);
}
.vc-cover img{width:100%;height:100%;object-fit:cover}
.vc-cover-fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:
    linear-gradient(135deg, rgba(232,230,225,.05) 0%, rgba(8,8,10,.4) 100%),
    repeating-linear-gradient(45deg, rgba(232,230,225,.04) 0 1px, transparent 1px 14px);
}
.vc-cover[data-platform="bilibili"] .vc-cover-fallback{background-color:rgba(251,114,153,.08)}
.vc-cover[data-platform="douyin"]   .vc-cover-fallback{background-color:rgba(255,0,80,.08)}
.vc-cover[data-platform="xhs"]      .vc-cover-fallback{background-color:rgba(255,36,66,.08)}
.vc-cover[data-platform="youtube"]  .vc-cover-fallback{background-color:rgba(255,0,0,.08)}
.vc-platform-mark{
  font-family:var(--mono);font-weight:600;font-size:24px;
  color:var(--bone);letter-spacing:.14em;
  padding:6px 14px;border:2px solid var(--bone);
  background:rgba(0,0,0,.4);
}
.vc-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;
  font-size:16px;color:#fff;
  background:rgba(0,0,0,.7);border:2px solid #fff;
  transition:transform .25s, background .25s;
  z-index:2;
}
.video-card:hover .vc-play{transform:translate(-50%,-50%) scale(1.1);background:var(--rev)}
.vc-duration{
  position:absolute;right:10px;bottom:10px;
  font-family:var(--mono);font-size:11px;color:var(--bone);
  letter-spacing:.04em;background:rgba(0,0,0,.7);padding:3px 8px;
}
.vc-info{
  padding:16px 18px;display:flex;flex-direction:column;gap:8px;
  flex:1;
}
.vc-info header{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;
}
.vc-platform{color:var(--col, var(--ink-1));font-weight:600}
.vc-date{color:var(--ink-2)}
.video-card h4{
  font-family:var(--cn);font-weight:500;font-size:15px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.5;
}
.video-card p{
  font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.7;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.video-empty{
  grid-column:1/-1;
  padding:60px 20px;text-align:center;
  font-family:var(--cn);font-size:14px;color:var(--ink-2);
  border:1px dashed var(--line-2);
}

/* ── Hash 跳转闪烁高亮 ── */
.is-flash{
  animation:flashHl 1.8s ease;
}
@keyframes flashHl{
  0%,100%{box-shadow:0 0 0 0 rgba(226,55,37,0)}
  20%{box-shadow:0 0 0 4px rgba(226,55,37,.5)}
  60%{box-shadow:0 0 0 4px rgba(226,55,37,.18)}
}
.news-timeline-item.is-flash{
  background:rgba(226,55,37,.06);
  outline:1px solid rgba(226,55,37,.4);
  outline-offset:4px;
}

/* ── 响应式 ── */
@media (max-width:1180px){
  .news-hero-grid{grid-template-columns:1fr;gap:20px}
  .lz-inner{grid-template-columns:1fr;gap:28px;padding:32px}
  .lz-radar{display:none}
  .company-grid{grid-template-columns:1fr}
  .company-card.is-feature{grid-column:span 1}
  .game-grid{grid-template-columns:1fr}
  .video-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .news-tabs-bar{top:60px}
}
@media (max-width:760px){
  .news-hero-stat{grid-template-columns:1fr}
  .nhs-card{border-right:none}
  .nhs-card:not(:last-child){border-bottom:1px solid var(--line)}
  .lz-inner{padding:24px 20px}
  .lz-title{font-size:32px}
  .lz-milestones li{grid-template-columns:18px minmax(0,1fr);gap:8px}
  .lz-milestones li strong{display:none}
  .lz-stats{grid-template-columns:1fr}
  .lz-stats > div{border-right:none;border-bottom:1px solid var(--line)}
  .lz-stats > div:last-child{border-bottom:none}
  .news-tabs-bar{grid-template-columns:1fr;top:60px}
  .news-tab{border-right:none;border-bottom:1px solid var(--line);padding:14px 18px}
  .news-tab:last-child{border-bottom:none}
  .news-tab.is-active::before{display:none}
  .news-tab.is-active{border-left:3px solid var(--rev)}
  .video-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════
   news.html v3 — Tab 上提 + 横屏轮播 Hero
   ═══════════════════════════════════════════════════════ */

/* ── Tab Bar：顶在 nav 下方 sticky ── */
.news-tabs-bar{
  position:sticky;top:60px;z-index:30;
  background:rgba(8,8,10,.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-2);
}
.news-tabs-inner{
  max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad-x);
  display:flex;align-items:stretch;
  gap:0;
}
.news-tabs-inner .news-tab{
  display:flex;align-items:center;gap:14px;
  padding:18px 26px;
  border:none;border-right:1px solid var(--line);
  background:transparent;cursor:pointer;
  text-align:left;color:var(--ink-1);
  transition:background .25s, color .25s;
  font-family:inherit;
  position:relative;
  min-width:0;
}
.news-tabs-inner .news-tab:first-child{border-left:1px solid var(--line)}
.news-tabs-inner .news-tab:hover{background:rgba(255,255,255,.025);color:var(--ink-0)}
.news-tabs-inner .news-tab.is-active{color:var(--ink-0);background:rgba(226,55,37,.06)}
.news-tabs-inner .news-tab.is-active::before{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--rev);
}
.news-tabs-inner .news-tab .nt-idx{
  font-family:var(--mono);font-weight:600;font-size:11px;color:var(--ink-2);
  letter-spacing:.14em;
}
.news-tabs-inner .news-tab.is-active .nt-idx{color:var(--rev)}
.news-tabs-inner .news-tab .nt-name{display:flex;flex-direction:column;gap:2px;min-width:0}
.news-tabs-inner .news-tab .nt-name .zh{font-family:var(--cn);font-weight:500;font-size:15px;color:inherit;letter-spacing:.02em}
.news-tabs-inner .news-tab .nt-name .en{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase}
.news-tabs-inner .news-tab.is-active .nt-name .en{color:var(--ink-1)}
.news-tabs-inner .news-tab .nt-count{
  font-family:var(--mono);font-variant-numeric:tabular-nums;
  font-size:13px;font-weight:600;color:var(--ink-0);
  padding:3px 8px;border:1px solid var(--line-2);background:var(--bg-2);
  flex-shrink:0;
}
.news-tabs-inner .news-tab.is-active .nt-count{border-color:var(--rev);color:var(--rev)}

.news-tabs-meta{
  margin-left:auto;display:flex;align-items:center;gap:8px;
  padding:0 18px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
  border-right:1px solid var(--line);
}
.news-tabs-meta .dot{
  width:7px;height:7px;border-radius:50%;background:var(--rev);
  box-shadow:0 0 0 0 rgba(226,55,37,.5);animation:pulse 2.4s ease-in-out infinite;
}

/* ── Hero 横屏轮播 ── */
.news-carousel-section{
  padding:0;background:var(--bg-0);
}
.news-carousel{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  height: clamp(380px, 56vh, 580px);
  overflow:hidden;
  background:var(--bg-1);
  border-bottom:1px solid var(--line-2);
}
.nc-track{
  position:absolute;inset:0;
}
.nc-slide{
  position:absolute;inset:0;
  display:block;color:inherit;text-decoration:none;
  opacity:0;visibility:hidden;
  transition:opacity .7s ease, visibility 0s linear .7s;
  cursor:pointer;
  overflow:hidden;
}
.nc-slide.is-active{
  opacity:1;visibility:visible;
  transition:opacity .7s ease, visibility 0s linear 0s;
  z-index:2;
}
.nc-slide.is-active .nc-slide-title{animation:slideUp .8s ease both .1s}
.nc-slide.is-active .nc-slide-sub{animation:slideUp .8s ease both .25s}
.nc-slide.is-active .nc-slide-top{animation:slideDown .8s ease both 0s}
.nc-slide.is-active .nc-slide-cta{animation:slideUp .8s ease both .4s}
.nc-slide.is-active .nc-lz-countdown{animation:slideIn .8s ease both .35s}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* slide 背景 */
.nc-slide-bg{
  position:absolute;inset:0;
  background:var(--bg-2);
  overflow:hidden;
}
.nc-slide-bg .nc-cover-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:.85;
}
.nc-slide-bg[data-pattern="company"]{
  background:
    radial-gradient(ellipse 70% 60% at 25% 50%, rgba(226,55,37,.18), transparent 70%),
    radial-gradient(ellipse 50% 40% at 80% 80%, rgba(155,58,43,.15), transparent 70%),
    linear-gradient(135deg, #14141a 0%, #0a0a0d 100%);
}
.nc-slide-bg[data-pattern="game"]{
  background:
    radial-gradient(ellipse 60% 50% at 30% 40%, rgba(197,131,45,.18), transparent 70%),
    radial-gradient(ellipse 60% 50% at 80% 70%, rgba(79,107,138,.18), transparent 70%),
    linear-gradient(135deg, #15141a 0%, #0a0a0e 100%);
}
.nc-slide-bg[data-pattern="video"]{
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, rgba(232,230,225,.06), transparent 70%),
    linear-gradient(135deg, #0d0d12 0%, #050507 100%);
}
.nc-slide-bg[data-pattern="lz"]{
  background:
    radial-gradient(ellipse 80% 70% at 20% 50%, rgba(226,55,37,.24), transparent 70%),
    radial-gradient(ellipse 50% 40% at 90% 30%, rgba(122,28,16,.4), transparent 70%),
    linear-gradient(135deg, #181014 0%, #08080a 60%);
}
/* 网格背景 */
.nc-slide-bg::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(232,230,225,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(232,230,225,.04) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, #000 30%, transparent 90%);
  pointer-events:none;
}
.nc-slide-vignette{
  position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 0%, rgba(8,8,10,.4) 60%, rgba(8,8,10,.86) 100%),
    linear-gradient(90deg, rgba(8,8,10,.6) 0%, rgba(8,8,10,.1) 50%, rgba(8,8,10,.4) 100%);
}

/* 《核心着陆区》专属雷达圈 + 扫描线 */
.nc-lz-radar{
  position:absolute;right:-120px;top:50%;transform:translateY(-50%);
  width:480px;height:480px;pointer-events:none;
}
.nc-lz-radar span{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  border:1px dashed rgba(226,55,37,.4);border-radius:50%;
}
.nc-lz-radar span:nth-child(1){width:120px;height:120px;animation:lzPulse 4s ease-in-out infinite}
.nc-lz-radar span:nth-child(2){width:260px;height:260px;animation:lzPulse 4s ease-in-out infinite 1s}
.nc-lz-radar span:nth-child(3){width:440px;height:440px;animation:lzPulse 4s ease-in-out infinite 2s}
.nc-lz-scan{
  position:absolute;left:0;right:0;top:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rev), transparent);
  opacity:.6;animation:lzScan 6s linear infinite;pointer-events:none;
}

/* slide 内容层 */
.nc-slide-content{
  position:absolute;inset:0;z-index:2;
  display:grid;grid-template-rows:auto 1fr auto;
  padding: clamp(32px, 5vw, 64px) clamp(32px, 6vw, 88px);
  max-width:var(--maxw);margin:0 auto;
}
.nc-slide-top{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.nc-slide-tag{
  display:inline-flex;align-items:center;
  padding:6px 12px;
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  border:1px solid currentColor;
  color:var(--col, var(--rev));
  background:rgba(0,0,0,.3);
  backdrop-filter:blur(6px);
}
.nc-slide-tag.tag-info{color:var(--blue)}
.nc-slide-tag.tag-ok{color:var(--green)}
.nc-slide-tag.tag-warn{color:var(--mustard)}
.nc-slide-date{
  font-family:var(--mono);font-size:11px;color:var(--bone);
  letter-spacing:.14em;opacity:.7;
}
.nc-slide-duration{
  margin-left:auto;
  font-family:var(--mono);font-size:11px;color:var(--bone);
  letter-spacing:.04em;
  padding:4px 10px;background:rgba(0,0,0,.5);
}

.nc-slide-center{
  display:flex;align-items:center;justify-content:center;
}
.nc-slide-play{
  width:78px;height:78px;border-radius:50%;
  display:grid;place-items:center;
  font-size:26px;color:#fff;
  background:rgba(226,55,37,.92);
  border:3px solid #fff;
  box-shadow:0 8px 28px rgba(0,0,0,.5);
  transition:transform .3s, background .3s;
}
.nc-slide-video:hover .nc-slide-play{
  transform:scale(1.08);
  background:var(--rev-2);
}

.nc-slide-bottom{
  display:flex;flex-direction:column;gap:14px;
  max-width:68%;
}
.nc-slide-title{
  font-family:var(--cn);font-weight:600;
  font-size: clamp(28px, 4.2vw, 48px);
  line-height:1.2;color:var(--bone);
  letter-spacing:.02em;
  text-shadow:0 2px 16px rgba(0,0,0,.55);
}
.nc-slide-sub{
  font-family:var(--cn);font-weight:300;
  font-size: clamp(14px, 1.4vw, 17px);
  color:var(--ink-1);
  line-height:1.75;max-width:54ch;
}
.nc-slide-cta{display:flex;gap:10px;flex-wrap:wrap}
.nc-slide-cta .btn{
  font-family:var(--cn);font-size:14px;font-weight:600;
  letter-spacing:.04em;
  padding:14px 22px;
  background:var(--bone);color:var(--ink-rev);
  border:1px solid var(--bone);
  display:inline-flex;align-items:center;gap:10px;
  transition:background .2s, color .2s;
}
.nc-slide-cta .btn.ghost{
  background:transparent;color:var(--bone);border-color:var(--bone);
}
.nc-slide-cta .btn .arr{
  width:16px;height:10px;display:inline-block;position:relative;vertical-align:middle;
  background:linear-gradient(currentColor,currentColor) center/100% 1px no-repeat;
}
.nc-slide-cta .btn .arr::before,.nc-slide-cta .btn .arr::after{
  content:"";position:absolute;right:0;width:7px;height:1px;background:currentColor
}
.nc-slide-cta .btn .arr::before{top:4px;transform:rotate(35deg);transform-origin:right}
.nc-slide-cta .btn .arr::after{top:6px;transform:rotate(-35deg);transform-origin:right}
.nc-slide:hover .nc-slide-cta .btn:not(.ghost){background:var(--rev);color:#fff;border-color:var(--rev)}
.nc-slide:hover .nc-slide-cta .btn.ghost{background:var(--bone);color:var(--ink-rev)}

/* 《核心着陆区》倒计时浮卡 */
.nc-lz-countdown{
  position:absolute;right: clamp(32px, 6vw, 88px);
  top:50%;transform:translateY(-50%);
  padding:22px 28px;
  background:linear-gradient(180deg, rgba(226,55,37,.12), rgba(8,8,10,.6));
  border:1px solid var(--rev);
  display:flex;flex-direction:column;gap:6px;
  min-width:220px;
  backdrop-filter:blur(6px);
  z-index:3;
}
.nc-lz-countdown::before{
  content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:3px;background:var(--rev);
}
.nc-lz-countdown .lab{
  font-size:10px;color:var(--rev);
  letter-spacing:.2em;text-transform:uppercase;
}
.nc-lz-countdown .v{
  font-family:var(--sans);font-weight:700;font-size:48px;color:var(--bone);
  letter-spacing:-.02em;line-height:1;
}
.nc-lz-countdown .v em{font-style:normal;font-size:18px;color:var(--ink-1);margin-left:6px}
.nc-lz-countdown .sub{font-family:var(--cn);font-size:11.5px;color:var(--ink-1)}

/* 视频幻灯片：把"中央播放按钮"显示出来 */
.nc-slide-video .nc-slide-center{display:flex}
.nc-slide:not(.nc-slide-video) .nc-slide-center{display:none}

/* 左右箭头 */
.nc-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:10;
  width:56px;height:56px;
  display:grid;place-items:center;
  font-size:36px;color:var(--bone);
  background:rgba(8,8,10,.6);
  border:1px solid var(--line-2);
  cursor:pointer;
  transition:background .2s, border-color .2s, transform .2s;
  backdrop-filter:blur(8px);font-family:var(--sans);
  line-height:1;padding-bottom:4px;
}
.nc-arrow:hover{
  background:var(--rev);color:#fff;border-color:var(--rev);
  transform:translateY(-50%) scale(1.05);
}
.nc-prev{left:18px}
.nc-next{right:18px}

/* 底部 dots + 计数 */
.nc-bottom{
  position:absolute;left:0;right:0;bottom:18px;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(32px, 6vw, 88px);
  max-width:var(--maxw);margin:0 auto;
}
.nc-dots{display:flex;gap:8px}
.nc-dot{
  width:42px;height:3px;
  background:rgba(232,230,225,.25);
  border:none;cursor:pointer;padding:0;
  transition:background .2s, transform .2s;
}
.nc-dot:hover{background:rgba(232,230,225,.5)}
.nc-dot.is-active{background:var(--bone);height:4px}
.nc-counter{
  font-family:var(--mono);font-size:12px;color:var(--bone);
  letter-spacing:.18em;
  background:rgba(0,0,0,.4);padding:4px 10px;
}
.nc-counter .sep{color:var(--ink-2);margin:0 4px}

/* 顶部进度条 */
.nc-progress{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:rgba(232,230,225,.08);z-index:11;
}
.nc-progress-bar{
  display:block;height:100%;width:0%;background:var(--rev);
}

/* ── Tab Panel 容器 ── */
.news-list-section{padding-top:32px}
.ntp-eyebrow{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;flex-wrap:wrap;
  padding:0 0 14px;
  margin-bottom:18px;
  border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}
.ntp-eyebrow .mono{color:var(--ink-1)}

/* ── 响应式（覆盖旧响应式） ── */
@media (max-width:1180px){
  .news-tabs-inner{padding-left:0;padding-right:0}
  .news-tabs-inner .news-tab{padding:14px 20px}
  .news-tabs-meta{display:none}
  .news-carousel{height: clamp(420px, 60vh, 540px)}
  .nc-slide-bottom{max-width:78%}
  .nc-lz-countdown{min-width:180px;padding:16px 20px}
  .nc-lz-countdown .v{font-size:36px}
}
@media (max-width:760px){
  .news-tabs-bar{top:60px}
  .news-tabs-inner{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}
  .news-tabs-inner .news-tab{padding:12px 14px;gap:8px;border-left:none}
  .news-tabs-inner .news-tab:first-child{border-left:none}
  .news-tabs-inner .news-tab .nt-name .zh{font-size:13px}
  .news-tabs-inner .news-tab .nt-name .en{display:none}
  .news-tabs-inner .news-tab .nt-idx{display:none}
  .news-carousel{height:auto;min-height:0}
  .nc-slide{position:relative;height:auto;visibility:visible;opacity:0;display:none}
  /* 移动端简化：用 fade，但 fade-out 的不占位 */
  .nc-slide.is-active{display:block;opacity:1}
  .nc-slide-content{padding:24px 22px;min-height:480px}
  .nc-slide-bottom{max-width:100%}
  .nc-slide-title{font-size:26px}
  .nc-lz-radar{display:none}
  .nc-lz-countdown{
    position:relative;top:auto;right:auto;transform:none;
    margin-top:14px;align-self:flex-start;
  }
  .nc-arrow{width:42px;height:42px;font-size:24px}
  .nc-prev{left:10px}
  .nc-next{right:10px}
  .nc-bottom{padding:0 22px}
  .nc-dot{width:28px}
}

/* ═══════════════════════════════════════════════════════
   news.html v4 — 两 Tab + chips 子筛选 + 分页器
   ═══════════════════════════════════════════════════════ */

/* dyn-chips：放在 ntp-eyebrow 右侧 */
.ntp-eyebrow{justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.ntp-eyebrow .ntp-meta{color:var(--ink-1);font-size:11px}
.dyn-chips{display:flex;gap:6px;flex-wrap:wrap}
.dyn-chips .chip{
  display:inline-flex;align-items:center;
  padding:7px 14px;border:1px solid var(--line-2);
  background:transparent;color:var(--ink-1);
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  cursor:pointer;transition:all .2s;
}
.dyn-chips .chip:hover{border-color:var(--line-3);color:var(--ink-0)}
.dyn-chips .chip.is-active{
  border-color:var(--rev);color:var(--bone);background:rgba(226,55,37,.08);
}

/* 动态卡片：统一格式（文字卡 / 视频卡共用） */
.dynamics-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
.dyn-card{
  position:relative;
  display:flex;flex-direction:column;gap:10px;
  padding:20px 22px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  transition:border-color .25s, background .25s, transform .25s;
  min-width:0;color:inherit;text-decoration:none;
}
.dyn-card:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.04);transform:translateY(-2px);
}
.dyn-card::before{
  content:"";position:absolute;top:0;left:0;width:42px;height:3px;
  background:var(--ink-3);
}
.dyn-card.kind-company::before{background:var(--rev)}
.dyn-card.kind-game::before{background:var(--mustard)}
.dyn-card.kind-video::before{background:var(--blue)}
.dyn-card.kind-legacy::before{background:var(--ink-2)}
/* 视频条目（不论归到哪个类）的左色条用平台色 */
.dyn-card.dyn-video.kind-company::before{background:var(--rev)}
.dyn-card.dyn-video.kind-game::before{background:var(--mustard)}
.dyn-card.dyn-video.kind-legacy::before{background:var(--ink-2)}

.dyn-card header{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  padding-bottom:10px;border-bottom:1px solid var(--line);
}
.dc-kind{
  padding:3px 8px;border:1px solid currentColor;font-weight:600;
}
.dc-kind.kind-company{color:var(--rev)}
.dc-kind.kind-game{color:var(--mustard)}
.dc-kind.kind-video{color:var(--col, var(--blue))}
.dc-kind.kind-legacy{color:var(--ink-1)}
/* 视频附加徽章（"▶ B 站"）— 无论归属哪个类都显示 */
.dc-video-badge{
  color:var(--col, var(--blue));
  padding:3px 8px;border:1px solid currentColor;font-weight:600;
  display:inline-flex;align-items:center;gap:4px;
}
.dc-lvl{padding:3px 8px;border:1px solid currentColor;font-weight:600}
.dc-lvl.lvl-info{color:var(--blue)}
.dc-lvl.lvl-ok{color:var(--green)}
.dc-lvl.lvl-warn{color:var(--mustard)}
.dc-tag{color:var(--ink-1);padding:3px 8px;border:1px dashed var(--line-2)}
.dc-date{color:var(--ink-2);margin-left:auto}

.dyn-card h3{
  font-family:var(--cn);font-weight:500;font-size:17px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.45;
}
.dyn-card > p{font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.75}
.dyn-card .dc-body-long{
  color:var(--ink-2);font-size:12.5px;
  border-top:1px dashed var(--line);padding-top:10px;
}

/* 视频卡片：上半小封面 + 下文字（横向布局） */
.dyn-card.dyn-video{
  display:grid;grid-template-columns:160px minmax(0,1fr);gap:18px;
  padding:14px 16px;align-items:start;
}
.dyn-card.dyn-video::before{background:var(--blue)}
.dyn-card.dyn-video .dc-cover{
  position:relative;aspect-ratio:16/9;
  overflow:hidden;background:var(--bg-2);
  border:1px solid var(--line-2);
}
.dyn-card.dyn-video .dc-cover img{
  width:100%;height:100%;object-fit:cover;
}
.dyn-card.dyn-video .dc-cover-fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:
    linear-gradient(135deg, rgba(232,230,225,.04) 0%, rgba(8,8,10,.4) 100%),
    repeating-linear-gradient(45deg, rgba(232,230,225,.03) 0 1px, transparent 1px 12px);
}
.dyn-card.dyn-video .dc-cover[data-platform="bilibili"] .dc-cover-fallback{background-color:rgba(251,114,153,.08)}
.dyn-card.dyn-video .dc-cover[data-platform="douyin"]   .dc-cover-fallback{background-color:rgba(255,0,80,.08)}
.dyn-card.dyn-video .dc-cover[data-platform="xhs"]      .dc-cover-fallback{background-color:rgba(255,36,66,.08)}
.dyn-card.dyn-video .dc-cover[data-platform="youtube"]  .dc-cover-fallback{background-color:rgba(255,0,0,.08)}
.dc-platform-mark{
  font-family:var(--mono);font-weight:600;font-size:13px;
  color:var(--bone);letter-spacing:.14em;
  padding:3px 8px;border:1px solid var(--bone);
  background:rgba(0,0,0,.4);
}
.dc-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:32px;height:32px;border-radius:50%;
  display:grid;place-items:center;
  font-size:11px;color:#fff;
  background:rgba(0,0,0,.7);border:1.5px solid #fff;
  z-index:2;
  transition:transform .25s, background .25s;
}
.dyn-card.dyn-video:hover .dc-play{transform:translate(-50%,-50%) scale(1.12);background:var(--rev)}
.dc-duration{
  position:absolute;right:6px;bottom:6px;
  font-family:var(--mono);font-size:9.5px;color:var(--bone);
  background:rgba(0,0,0,.7);padding:2px 6px;
}
.dyn-card.dyn-video .dc-body{
  display:flex;flex-direction:column;gap:8px;
  min-width:0;padding-top:4px;
}
.dyn-card.dyn-video .dc-body header{padding-bottom:6px;border-bottom:1px solid var(--line)}
.dyn-card.dyn-video h3{font-size:15px;line-height:1.5}
.dyn-card.dyn-video p{font-size:13px;color:var(--ink-1);line-height:1.7}

.dyn-empty{
  grid-column:1/-1;
  padding:60px 20px;text-align:center;
  font-family:var(--cn);font-size:14px;color:var(--ink-2);
  border:1px dashed var(--line-2);
}

/* 分页器 */
.paginator{
  margin-top:28px;
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;flex-wrap:wrap;
  padding-top:18px;border-top:1px solid var(--line);
}
.paginator:empty{display:none}
.paginator .pg-btn{
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-1);background:transparent;
  border:1px solid var(--line-2);
  padding:9px 16px;cursor:pointer;
  transition:all .2s;
}
.paginator .pg-btn:hover:not([disabled]){
  color:var(--bone);border-color:var(--rust-3);
  background:rgba(201,90,68,.08);
}
.paginator .pg-btn[disabled]{
  opacity:.3;cursor:not-allowed;
}
.paginator .pg-pages{
  display:flex;gap:4px;align-items:center;
}
.paginator .pg-num{
  font-family:var(--mono);font-size:13px;font-weight:600;
  font-variant-numeric:tabular-nums;
  color:var(--ink-1);background:transparent;
  border:1px solid var(--line-2);
  width:38px;height:38px;
  display:grid;place-items:center;
  cursor:pointer;transition:all .2s;
}
.paginator .pg-num:hover{color:var(--ink-0);border-color:var(--line-3)}
.paginator .pg-num.is-active{
  color:var(--bone);border-color:var(--rev);
  background:var(--rev);
}
.paginator .pg-gap{
  font-family:var(--mono);color:var(--ink-2);font-size:13px;
  padding:0 4px;
}

/* 轮播切到日志 Tab 时的 transition */
.news-carousel-section{transition: opacity .25s}

/* 响应式：dynamics 区 */
@media (max-width:1180px){
  .dynamics-grid{grid-template-columns:1fr}
  .ntp-eyebrow{flex-direction:column;align-items:flex-start}
}
@media (max-width:760px){
  .dyn-card.dyn-video{
    grid-template-columns:1fr;gap:12px;padding:14px;
  }
  .dyn-card.dyn-video .dc-cover{aspect-ratio:16/9;width:100%}
  .paginator{flex-direction:column;align-items:stretch;gap:10px}
  .paginator .pg-btn{justify-self:stretch;text-align:center}
  .paginator .pg-pages{justify-content:center;flex-wrap:wrap}
  .dyn-chips{width:100%;justify-content:flex-start}
  .dyn-chips .chip{flex:0 0 auto}
}

/* ═══════════════════════════════════════════════════════
   折叠/展开 + 列表数量整理（v3 遗留，已弃用，仅做兼容）
   ═══════════════════════════════════════════════════════ */

/* 完全隐藏：第 threshold+1 起的条目 */
.company-grid.is-collapsed > .is-overflow,
.game-grid.is-collapsed > .is-overflow,
.video-grid.is-collapsed > .is-overflow,
.news-timeline.is-collapsed > .is-overflow{
  display:none;
}

/* 半张卡片：第 threshold 那条，折叠时只露上半 + 渐隐 + 可点击展开 */
.company-grid.is-collapsed > .is-peek,
.game-grid.is-collapsed > .is-peek,
.video-grid.is-collapsed > .is-peek,
.news-timeline.is-collapsed > .is-peek{
  position:relative;
  max-height:88px;
  overflow:hidden;
  cursor:pointer;
  /* 给半张卡片一个柔和的下渐隐，文字渐淡 */
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 35%, transparent 100%);
          mask-image: linear-gradient(180deg, #000 0%, #000 35%, transparent 100%);
  transition: max-height .35s ease;
}
/* 时间线条目高度稍小，给它更高一点 max-height 才能露出标题 */
.news-timeline.is-collapsed > .is-peek{
  max-height:72px;
}
/* 视频卡是以封面为主，露出封面顶部更直观 */
.video-grid.is-collapsed > .is-peek{
  max-height:160px;
}

/* hover 半张卡片：抬高一点、显示更多，给用户"我可以点"的暗示 */
.company-grid.is-collapsed > .is-peek:hover,
.game-grid.is-collapsed > .is-peek:hover,
.news-timeline.is-collapsed > .is-peek:hover{
  max-height:140px;
}
.video-grid.is-collapsed > .is-peek:hover{
  max-height:240px;
}

/* 半张卡片右上角的小提示 "点击展开 ↓" */
.company-grid.is-collapsed > .is-peek::after,
.game-grid.is-collapsed > .is-peek::after,
.video-grid.is-collapsed > .is-peek::after,
.news-timeline.is-collapsed > .is-peek::after{
  content:"点击展开 ↓";
  position:absolute;right:14px;top:12px;
  font-family:var(--mono);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--rust-3);
  padding:3px 8px;
  background:rgba(8,8,10,.7);
  border:1px solid rgba(201,90,68,.5);
  pointer-events:none;
  z-index:2;
  opacity:0;
  transition:opacity .25s;
}
.company-grid.is-collapsed > .is-peek:hover::after,
.game-grid.is-collapsed > .is-peek:hover::after,
.video-grid.is-collapsed > .is-peek:hover::after,
.news-timeline.is-collapsed > .is-peek:hover::after{
  opacity:1;
}

/* 折叠按钮（放在小标题旁边） */
.ntp-eyebrow{justify-content:space-between}
.toggle-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;
  font-family:var(--mono);font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-1);
  background:transparent;
  border:1px solid var(--line-2);
  cursor:pointer;
  transition:color .2s, border-color .2s, background .2s;
}
.toggle-btn:hover{
  color:var(--bone);border-color:var(--rust-3);
  background:rgba(201,90,68,.08);
}
.toggle-btn .tb-icon{
  font-family:var(--sans);font-weight:600;font-size:13px;
  letter-spacing:0;
  transition:transform .25s;
}
.toggle-btn[aria-expanded="true"] .tb-icon{transform:rotate(180deg)}
.toggle-btn .tb-text{font-weight:600}

/* 时间线小标题旁的内联按钮：与 h2 同一行 */
.section-title{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.toggle-btn-inline{
  font-size:10px;padding:5px 11px;
  align-self:center;
}

/* 隐藏旧版的 chip 计数和 nt-count（HTML 已移除，兼容兜底） */
.nt-count,
.video-chips .chip .ct{display:none !important}

/* video-chips 简化（不再有 ct，调整 padding 让 chip 更舒展） */
.video-chips .chip{padding:9px 18px}

@media (max-width:760px){
  .ntp-eyebrow{flex-direction:column;align-items:flex-start;gap:10px}
  .toggle-btn{width:100%;justify-content:center}
  .section-title{flex-direction:column;align-items:flex-start}
  .toggle-btn-inline{margin-top:6px}
  /* 移动端：半张高度收紧 */
  .company-grid.is-collapsed > .is-peek,
  .game-grid.is-collapsed > .is-peek,
  .video-grid.is-collapsed > .is-peek,
  .news-timeline.is-collapsed > .is-peek{
    max-height:72px;
  }
  /* 移动端：hover 不可靠，直接持续显示提示徽章 */
  .company-grid.is-collapsed > .is-peek::after,
  .game-grid.is-collapsed > .is-peek::after,
  .video-grid.is-collapsed > .is-peek::after,
  .news-timeline.is-collapsed > .is-peek::after{
    opacity:1;
  }
}

/* ═══════════════════════════════════════════════════════
   PAGE: foundation.html — 「守护者奖牌」专区 banner
   ═══════════════════════════════════════════════════════ */
.legal-note{
  display:block;margin-top:14px;padding:12px 16px;
  font-family:var(--cn);font-size:12.5px;color:var(--ink-2);line-height:1.7;
  background:rgba(255,255,255,.025);border-left:3px solid var(--green);
}
.legal-note strong{color:var(--ink-1);font-weight:500}
.legal-note a{color:var(--green);text-decoration:underline;text-underline-offset:3px}

.medal-banner{
  position:relative;overflow:hidden;
  border:1px solid var(--line-2);
  background:
    linear-gradient(135deg, rgba(90,155,106,.06), rgba(8,8,10,0)),
    var(--bg-1);
}
.medal-banner-bg{position:absolute;inset:0;pointer-events:none}
.medal-banner-bg .mb-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(232,230,225,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(232,230,225,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 70% 70% at 30% 50%, #000 30%, transparent 90%);
}
.medal-banner-bg .mb-glow{
  position:absolute;right:-200px;top:-100px;width:600px;height:600px;
  background:radial-gradient(circle, rgba(197,131,45,.12), transparent 70%);
  pointer-events:none;
}
.medal-banner-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
  gap:42px;
  padding:42px 44px;
}
.mb-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--green);
  letter-spacing:.2em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--green);
  background:rgba(90,155,106,.08);
}
.mb-tag .dot{
  width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite;
}
.mb-title{
  font-family:var(--cn);font-weight:500;
  font-size:clamp(28px, 3.6vw, 42px);line-height:1.25;color:var(--ink-0);
  letter-spacing:.02em;margin-top:18px;
}
.mb-title .accent{color:var(--green)}
.mb-desc{
  font-family:var(--cn);font-weight:300;font-size:14.5px;color:var(--ink-1);
  line-height:1.85;margin-top:18px;
}
.mb-desc strong{color:var(--ink-0);font-weight:500}
.mb-philosophy{
  display:block;margin-top:10px;font-style:italic;color:var(--green);
  border-left:2px solid var(--green);padding-left:10px;
}
.mb-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}

.mb-cards{
  display:flex;flex-direction:column;gap:14px;
  align-items:stretch;
}
.medal-sku{
  display:grid;grid-template-columns:96px minmax(0,1fr);gap:18px;
  padding:18px;border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  align-items:center;color:inherit;text-decoration:none;
  transition:border-color .25s, background .25s, transform .25s;
}
.medal-sku:hover{
  border-color:var(--green);background:rgba(90,155,106,.06);transform:translateY(-2px);
}
.medal-sku-virtual{color:#c5832d}
.medal-sku-physical{color:#a8a39a}
.medal-sku .msk-vis{
  width:96px;height:96px;display:grid;place-items:center;
  background:rgba(0,0,0,.3);border:1px dashed var(--line-2);
}
.medal-sku .msk-svg{width:80px;height:80px}
.medal-sku .msk-body{display:flex;flex-direction:column;gap:5px;min-width:0}
.msk-tag{
  font-family:var(--mono);font-size:9.5px;color:var(--ink-2);
  letter-spacing:.18em;text-transform:uppercase;
}
.msk-name{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;
}
.msk-desc{font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.6}
.msk-price{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.1em;
}
.msk-price strong{
  font-family:var(--sans);font-weight:700;font-size:18px;color:var(--green);
  margin-right:2px;
}

.mb-footer{
  position:relative;z-index:2;
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;
  border-top:1px solid var(--line);
}
.mb-footer > div{
  padding:14px 22px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:5px;min-width:0;
}
.mb-footer > div:last-child{border-right:none}
.mbf-lab{
  font-family:var(--mono);font-size:10px;color:var(--green);
  letter-spacing:.18em;text-transform:uppercase;
}
.mbf-val{font-family:var(--cn);font-size:12px;color:var(--ink-1);line-height:1.7}

@media (max-width:1180px){
  .medal-banner-inner{grid-template-columns:1fr;gap:28px;padding:32px}
  .mb-footer{grid-template-columns:1fr}
  .mb-footer > div{border-right:none;border-bottom:1px solid var(--line)}
  .mb-footer > div:last-child{border-bottom:none}
}
@media (max-width:760px){
  .medal-banner-inner{padding:24px 20px}
  .medal-sku{grid-template-columns:64px minmax(0,1fr);gap:14px;padding:14px}
  .medal-sku .msk-vis{width:64px;height:64px}
  .medal-sku .msk-svg{width:54px;height:54px}
}

/* ═══════════════════════════════════════════════════════
   PAGE: shop.html — 公益横幅
   ═══════════════════════════════════════════════════════ */
.shop-charity-banner{
  display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:24px;
  align-items:center;
  padding:18px 22px;margin-bottom:18px;
  border:1px solid var(--green);background:rgba(90,155,106,.06);
  color:inherit;text-decoration:none;
  transition:background .25s;
}
.shop-charity-banner:hover{background:rgba(90,155,106,.1)}
.scb-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;color:var(--green);
  letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  padding:6px 12px;border:1px solid var(--green);
  white-space:nowrap;
}
.scb-tag .dot{
  width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite;
}
.scb-body{min-width:0}
.scb-body h3{
  font-family:var(--cn);font-weight:500;font-size:17px;color:var(--ink-0);
  letter-spacing:.02em;
}
.scb-body p{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7;
  margin-top:4px;
}
.scb-body p strong{color:var(--green)}
.scb-cta{flex-shrink:0}
@media (max-width:760px){
  .shop-charity-banner{grid-template-columns:1fr;gap:12px}
  .scb-tag{justify-self:flex-start}
}

.product-card.pc-charity{
  border-color:var(--green);background:rgba(90,155,106,.04);
  position:relative;
}
.product-card.pc-charity::before{
  content:"100%";position:absolute;top:0;right:0;
  font-family:var(--mono);font-weight:700;font-size:9px;
  color:#fff;background:var(--green);
  padding:3px 8px;letter-spacing:.12em;
}
.pc-price-rmb{
  font-family:var(--sans);font-weight:700;font-size:22px;color:var(--green);
  letter-spacing:-.01em;
}
/* ═══════════════════════════════════════════════════════
   PAGE: medal.html — 奖牌详情页
   ═══════════════════════════════════════════════════════ */
.medal-hero{
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 0%, rgba(8,8,10,.6) 100%),
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(90,155,106,.12), transparent 70%);
}
.medal-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--green);
  letter-spacing:.18em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--green);
  margin-bottom:18px;
}
.medal-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite;
}
.medal-hero-sub{
  font-family:var(--cn);font-weight:300;font-size:15px;color:var(--ink-1);
  line-height:1.85;margin-top:18px;max-width:62ch;
}
.medal-hero-sub strong{color:var(--ink-0);font-weight:500}

.medal-tabs{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border:1px solid var(--line-2);
}
.medal-tabs .mt{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;
  border:none;border-right:1px solid var(--line);
  background:transparent;cursor:pointer;
  text-align:left;color:var(--ink-1);
  transition:background .25s, color .25s;
  font-family:inherit;
  position:relative;
}
.medal-tabs .mt:last-child{border-right:none}
.medal-tabs .mt:hover{background:rgba(255,255,255,.025);color:var(--ink-0)}
.medal-tabs .mt.is-active{color:var(--ink-0);background:rgba(90,155,106,.06)}
.medal-tabs .mt.is-active::before{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--green);
}
.medal-tabs .mt-idx{
  font-family:var(--mono);font-weight:600;font-size:11px;color:var(--ink-2);letter-spacing:.14em;
}
.medal-tabs .mt.is-active .mt-idx{color:var(--green)}
.medal-tabs .mt-name{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.medal-tabs .mt-name .zh{font-family:var(--cn);font-weight:500;font-size:16px;color:inherit;letter-spacing:.02em}
.medal-tabs .mt-name .en{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase}
.medal-tabs .mt.is-active .mt-name .en{color:var(--ink-1)}
.medal-tabs .mt-price{
  font-family:var(--mono);font-weight:600;font-size:13px;color:var(--green);
  padding:3px 10px;border:1px solid currentColor;flex-shrink:0;
}

.medal-section{display:none;padding-top:8px}
.medal-section.is-active{display:block}

.medal-builder{
  display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:32px;
  align-items:start;
}

.medal-form{
  padding:28px 30px;border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  display:flex;flex-direction:column;gap:18px;min-width:0;
}
.mf-head{padding-bottom:14px;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
.mf-tag{
  font-family:var(--mono);font-size:10px;color:var(--green);
  letter-spacing:.18em;text-transform:uppercase;align-self:flex-start;
  padding:3px 8px;border:1px solid var(--green);
}
.mf-head h2{font-family:var(--cn);font-weight:500;font-size:22px;color:var(--ink-0);letter-spacing:.02em}
.mf-head p{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7}
.mf-head p strong{color:var(--ink-0);font-weight:500}

.mf-row{display:flex;flex-direction:column;gap:7px;min-width:0}
.mf-row > span{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.mf-row input[type=text],
.mf-row input[type=tel]{
  width:100%;padding:11px 14px;
  border:1px solid var(--line-2);background:rgba(0,0,0,.3);
  color:var(--ink-0);font-family:var(--cn);font-size:14px;
  outline:none;transition:border-color .2s;
}
.mf-row input:focus{border-color:var(--green);box-shadow:0 0 0 2px rgba(90,155,106,.12)}
.mf-row em{
  font-family:var(--cn);font-size:11.5px;color:var(--ink-2);font-style:normal;line-height:1.5;
}
.mf-row em strong{color:var(--green);font-weight:500}

.mf-amounts{display:flex;gap:6px;flex-wrap:wrap}
.mf-amounts button{
  padding:9px 14px;
  border:1px solid var(--line-2);background:transparent;
  font-family:var(--mono);font-size:12px;color:var(--ink-1);
  letter-spacing:.04em;cursor:pointer;transition:all .2s;
}
.mf-amounts button:hover{border-color:var(--line-3);color:var(--ink-0)}
.mf-amounts button.active{
  border-color:var(--green);color:var(--bone);background:rgba(90,155,106,.12);
}

.mf-tier-info{
  padding:10px 14px;background:rgba(255,255,255,.02);
  border:1px dashed var(--line-2);
  font-family:var(--cn);font-size:13px;color:var(--ink-1);
}
.mf-tier-info .tier-name{color:var(--ink-0);font-weight:500}
.mf-tier-info .tier-name[data-tier="bronze"]  {color:#c47a4a}
.mf-tier-info .tier-name[data-tier="silver"]  {color:#c0bcb4}
.mf-tier-info .tier-name[data-tier="gold"]    {color:#d4a040}
.mf-tier-info .tier-name[data-tier="platinum"]{color:#9ec0e8}
.mf-tier-info .tier-name[data-tier="diamond"] {color:#c8a8e8}

.mf-impact{
  display:flex;align-items:flex-start;gap:10px;
  padding:14px 16px;background:rgba(90,155,106,.08);
  border-left:3px solid var(--green);
}
.mfi-icon{font-family:var(--sans);font-size:18px;color:var(--green);line-height:1.2;flex-shrink:0}
.mfi-text{font-family:var(--cn);font-size:13.5px;color:var(--ink-0);line-height:1.7}
.mfi-text strong{color:var(--green);font-weight:600;font-size:16px;font-family:var(--sans);font-variant-numeric:tabular-nums}

.mf-equality-note{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 16px;background:rgba(255,255,255,.02);border:1px dashed var(--green);
  border-left-width:3px;
}
.men-icon{font-family:var(--sans);font-weight:700;font-size:22px;color:var(--green);line-height:1;flex-shrink:0}
.men-text{font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.75}
.men-text strong{color:var(--ink-0);font-weight:500}

.mf-shipping{
  border:1px solid var(--line);padding:14px 16px;display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;
}
.mf-shipping legend{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.16em;text-transform:uppercase;padding:0 8px;
}
.mf-shipping label{display:flex;flex-direction:column;gap:5px}
.mf-shipping label span{font-family:var(--mono);font-size:9.5px;color:var(--ink-2);letter-spacing:.14em}
.mf-shipping input{
  padding:9px 12px;border:1px solid var(--line-2);background:rgba(0,0,0,.3);
  color:var(--ink-0);font-family:var(--cn);font-size:13px;outline:none;
}
.mf-shipping-full{grid-column:1/-1}

.mf-actions{display:flex;gap:10px;flex-wrap:wrap;padding-top:8px;border-top:1px solid var(--line)}
.mf-legal{
  font-family:var(--cn);font-size:11.5px;color:var(--ink-2);line-height:1.7;
}

.medal-preview{
  position:sticky;top:80px;
  display:flex;flex-direction:column;gap:12px;
}
.mp-stage{
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse 80% 60% at 50% 50%, rgba(255,255,255,.05), transparent 80%), var(--bg-1);
  border:1px solid var(--line-2);padding:20px;
  min-height:540px;
}
.medal-svg{
  width:100%;max-width:380px;height:auto;
  filter:drop-shadow(0 12px 32px rgba(0,0,0,.5));
}
.mp-meta{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:0 4px;
}
.mpm-tag{
  font-family:var(--mono);font-size:10px;color:var(--green);
  letter-spacing:.18em;text-transform:uppercase;
  padding:3px 8px;border:1px solid var(--green);
}
.mpm-hint{font-family:var(--cn);font-size:11.5px;color:var(--ink-2)}

.medal-flow{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:14px;
  align-items:stretch;padding:24px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.medal-flow .mf-step{
  display:flex;flex-direction:column;gap:6px;padding:0 6px;min-width:0;
}
.medal-flow .mf-num{
  font-family:var(--mono);font-weight:700;font-size:14px;color:var(--green);
  letter-spacing:.14em;
}
.medal-flow .mf-step strong{
  font-family:var(--cn);font-weight:500;font-size:15px;color:var(--ink-0);
}
.medal-flow .mf-step p{
  font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.7;
}
.medal-flow .mf-step p strong{font-size:inherit;color:var(--green);font-weight:500}
.medal-flow .mf-step a{color:var(--green);text-decoration:underline;text-underline-offset:3px}
.medal-flow .mf-arr{
  font-family:var(--sans);font-size:24px;color:var(--green);
  align-self:center;opacity:.5;
}

@media (max-width:1180px){
  .medal-builder{grid-template-columns:1fr;gap:24px}
  .medal-preview{position:static}
  .medal-flow{grid-template-columns:1fr;gap:8px}
  .medal-flow .mf-arr{display:none}
}
@media (max-width:760px){
  .medal-form{padding:22px}
  .mf-shipping{grid-template-columns:1fr}
  .medal-tabs{grid-template-columns:1fr}
  .medal-tabs .mt{border-right:none;border-bottom:1px solid var(--line)}
  .medal-tabs .mt:last-child{border-bottom:none}
  .medal-tabs .mt.is-active::before{display:none}
  .medal-tabs .mt.is-active{border-left:3px solid var(--green)}
}
/* ═══════════════════════════════════════════════════════
   PAGE: aid.html — 援助基金独立页
   ═══════════════════════════════════════════════════════ */
.aid-hero{
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 0%, rgba(8,8,10,.6) 100%),
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(201,90,68,.10), transparent 70%);
}
.aid-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--rust-3);
  letter-spacing:.18em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--rust-3);
  margin-bottom:18px;
}
.aid-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--rust-3);
  box-shadow:0 0 0 0 rgba(201,90,68,.5);animation:pulse 2.4s ease-in-out infinite;
}
.aid-hero-sub{
  font-family:var(--cn);font-weight:300;font-size:15px;color:var(--ink-1);
  line-height:1.85;margin-top:18px;max-width:62ch;
}
.aid-hero-sub strong{color:var(--ink-0);font-weight:500}
.aid-note{
  display:block;margin-top:10px;padding:10px 14px;
  background:rgba(255,255,255,.025);border-left:3px solid var(--ink-2);
  font-size:12.5px;color:var(--ink-2);line-height:1.7;
}
.aid-note strong{color:var(--ink-1)}

/* 工具栏 */
.aid-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;flex-wrap:wrap;
  padding:14px 16px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.aid-chips{display:flex;gap:6px;flex-wrap:wrap}
.aid-chips .chip{
  display:inline-flex;align-items:center;
  padding:7px 14px;border:1px solid var(--line-2);
  background:transparent;color:var(--ink-1);
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  cursor:pointer;transition:all .2s;
}
.aid-chips .chip:hover{border-color:var(--line-3);color:var(--ink-0)}
.aid-chips .chip.is-active{
  border-color:var(--rust-3);color:var(--bone);background:rgba(201,90,68,.08);
}
.aid-apply-btn{flex-shrink:0}

/* 援助卡片 */
.aid-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
.aid-card{
  position:relative;
  display:flex;flex-direction:column;gap:10px;
  padding:22px 24px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  transition:border-color .25s, background .25s, transform .25s;
  min-width:0;
}
.aid-card:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.04);transform:translateY(-2px);
}
.aid-card::before{
  content:"";position:absolute;top:0;left:0;width:42px;height:3px;
  background:var(--ink-2);
}
.aid-card.urgency-high::before{background:var(--rev)}
.aid-card.urgency-medium::before{background:var(--amber)}
.aid-card.urgency-low::before{background:var(--green)}
.aid-card.status-completed{opacity:.62}
.aid-card.status-completed::before{background:var(--green)}

.aid-card header{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  padding-bottom:10px;border-bottom:1px solid var(--line);
}
.ac-urg{
  padding:3px 8px;border:1px solid currentColor;font-weight:600;
  color:var(--ink-2);
}
.aid-card.urgency-high .ac-urg{color:var(--rev)}
.aid-card.urgency-medium .ac-urg{color:var(--amber)}
.aid-card.urgency-low .ac-urg{color:var(--green)}
.ac-cat{padding:3px 8px;border:1px dashed var(--line-2);color:var(--ink-1)}
.ac-status{color:var(--ink-2)}
.aid-card.status-completed .ac-status{color:var(--green)}
.aid-card.status-reviewing .ac-status{color:var(--amber)}
.ac-date{margin-left:auto;color:var(--ink-3)}

.aid-card h3{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.45;
}
.ac-meta-user{
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
  font-family:var(--cn);font-size:13px;
}
.acm-nick{color:var(--ink-0);font-weight:500}
.acm-uid{color:var(--ink-3);font-size:10.5px;letter-spacing:.1em}
.ac-story{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.85;
}

.ac-progress{margin-top:4px}
.acp-bar{
  width:100%;height:5px;background:var(--bg-2);border:1px solid var(--line);overflow:hidden;
}
.acp-bar span{
  display:block;height:100%;background:linear-gradient(90deg, var(--rust-3), var(--rust));
  transition:width .8s ease;
}
.acp-meta{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-top:6px;font-family:var(--mono);font-size:12px;color:var(--ink-1);
}
.acp-meta strong{color:var(--ink-0);font-weight:600}
.acp-pct strong{color:var(--rust-3);font-size:14px}

.ac-actions{
  display:flex;align-items:center;gap:6px;
  padding-top:10px;border-top:1px dashed var(--line);margin-top:auto;
}
.ac-cheer, .ac-comment{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border:1px solid var(--line-2);background:transparent;
  font-family:var(--mono);font-size:11px;color:var(--ink-1);
  letter-spacing:.08em;cursor:pointer;transition:all .2s;
}
.ac-cheer:hover, .ac-comment:hover{border-color:var(--line-3);color:var(--ink-0)}
.ac-cheer.is-cheered{border-color:var(--rust-3);color:var(--bone);background:rgba(201,90,68,.08)}
.ac-comment.is-commented{border-color:var(--green);color:var(--bone);background:rgba(90,155,106,.08)}
.acc-icon{font-family:var(--sans);font-weight:600;font-size:13px}
.acc-num{font-weight:600;color:var(--ink-0)}
.acc-lab{color:var(--ink-2);font-size:10.5px}
.ac-spacer{flex:1}
.ac-done{color:var(--green);font-size:10px;letter-spacing:.16em}
.ac-pending{color:var(--ink-2);font-size:10px;letter-spacing:.16em}

/* 流程 */
.aid-process{
  padding:24px 26px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.aid-process h3{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;margin-bottom:14px;
}
.aid-steps{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;
}
.aid-steps article{
  padding:14px;background:rgba(255,255,255,.025);border:1px solid var(--line);
  display:flex;flex-direction:column;gap:5px;
}
.aid-steps article span{
  font-family:var(--mono);font-weight:700;font-size:14px;color:var(--rust-3);
  letter-spacing:.14em;
}
.aid-steps article strong{
  font-family:var(--cn);font-weight:500;font-size:14px;color:var(--ink-0);
}
.aid-steps article p{
  font-family:var(--cn);font-size:11.5px;color:var(--ink-1);line-height:1.7;
}

@media (max-width:1180px){
  .aid-grid{grid-template-columns:1fr}
  .aid-steps{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .aid-toolbar{flex-direction:column;align-items:stretch}
  .aid-apply-btn{justify-content:center}
  .aid-steps{grid-template-columns:1fr}
}
/* ═══════════════════════════════════════════════════════
   PAGE: dream.html — 梦想基金股东页
   ═══════════════════════════════════════════════════════ */
.dream-hero{
  background:
    linear-gradient(180deg, rgba(8,8,10,0) 0%, rgba(8,8,10,.6) 100%),
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(79,107,138,.14), transparent 70%);
}
.dream-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;color:var(--blue);
  letter-spacing:.18em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--blue);
  margin-bottom:18px;
}
.dream-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 0 0 rgba(79,107,138,.5);animation:pulse 2.4s ease-in-out infinite;
}
.dream-hero-sub{
  font-family:var(--cn);font-weight:300;font-size:15px;color:var(--ink-1);
  line-height:1.85;margin-top:18px;max-width:62ch;
}
.dream-hero-sub strong{color:var(--ink-0);font-weight:500}

/* 我的持仓 */
.dream-myholding{
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding:20px 24px;
  border:1px solid var(--blue);background:rgba(79,107,138,.06);
}
.mh-lead{display:flex;flex-direction:column;gap:4px;min-width:0}
.mh-tag{
  font-family:var(--mono);font-size:10px;color:var(--blue);
  letter-spacing:.18em;text-transform:uppercase;
}
.mh-lead h3{font-family:var(--cn);font-weight:500;font-size:17px;color:var(--ink-0);letter-spacing:.02em}
.mh-lead h3 .g{color:var(--green)}
.mh-lead p{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7}
.mh-lead p strong{color:var(--green);font-weight:600}

/* 项目卡 */
.dream-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
.dream-card{
  position:relative;
  display:flex;flex-direction:column;gap:10px;
  padding:22px 24px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  transition:border-color .25s, background .25s, transform .25s;
  min-width:0;
}
.dream-card:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.04);transform:translateY(-2px);
}
.dream-card::before{
  content:"";position:absolute;top:0;left:0;width:42px;height:3px;
  background:var(--blue);
}
.dream-card.status-live::before{background:var(--green)}
.dream-card.status-graduated{opacity:.65}

.dream-card header{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  padding-bottom:10px;border-bottom:1px solid var(--line);
}
.dc-cat{padding:3px 8px;border:1px dashed var(--line-2);color:var(--blue)}
.dc-status{padding:3px 8px;border:1px solid currentColor;font-weight:600;color:var(--ink-2)}
.dc-status.status-funding{color:var(--blue)}
.dc-status.status-live{color:var(--green)}
.dc-divd-flag{
  margin-left:auto;color:var(--green);font-weight:700;letter-spacing:.1em;font-size:10px;
}

.dream-card h3{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.45;
}
.dc-desc{font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.85}

.dc-progress{display:flex;flex-direction:column;gap:5px;margin-top:4px}
.dcp-row{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--mono);font-size:11.5px;
}
.dcp-lab{color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;font-size:9.5px}
.dcp-val{color:var(--ink-1)}
.dcp-val strong{color:var(--blue);font-size:13px}
.acp-bar-mile span{background:linear-gradient(90deg, var(--green), #4e8a64)}

.dc-stats{
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-1);
  padding-top:6px;
}
.dc-stats strong{color:var(--ink-0);font-weight:600;font-size:13px}
.dc-stats .sep{color:var(--ink-3)}
.dc-return strong{color:var(--green)}

.dc-actions{
  display:flex;align-items:center;gap:8px;
  padding-top:10px;border-top:1px dashed var(--line);margin-top:auto;
}
.dc-actions .ac-cheer:hover, .dc-actions .ac-comment:hover{border-color:var(--blue);color:var(--bone)}
.dc-actions .ac-cheer.is-cheered{border-color:var(--blue);background:rgba(79,107,138,.12);color:var(--bone)}

/* 股东机制说明 */
.dream-mechanism{
  padding:28px 30px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.dream-mechanism header{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.dm-tag{
  font-family:var(--mono);font-size:10px;color:var(--blue);
  letter-spacing:.18em;text-transform:uppercase;align-self:flex-start;
  padding:3px 8px;border:1px solid var(--blue);
}
.dream-mechanism h3{
  font-family:var(--cn);font-weight:500;font-size:22px;color:var(--ink-0);letter-spacing:.02em;
}
.dream-mechanism > header > p{
  font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.75;
}
.dream-mechanism > header > p strong{color:var(--ink-0);font-weight:500}

.dream-steps{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;
}
.dream-steps article{
  padding:18px;background:rgba(255,255,255,.025);border:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;
}
.dream-steps article span{
  font-family:var(--mono);font-weight:700;font-size:18px;color:var(--blue);
  letter-spacing:.14em;
}
.dream-steps article strong{
  font-family:var(--cn);font-weight:500;font-size:16px;color:var(--ink-0);
}
.dream-steps article p{
  font-family:var(--cn);font-size:12.5px;color:var(--ink-1);line-height:1.7;
}
.dream-steps article p strong{color:var(--blue);font-size:12.5px}

@media (max-width:1180px){
  .dream-grid{grid-template-columns:1fr}
  .dream-steps{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .dream-myholding{flex-direction:column;align-items:flex-start}
  .dream-steps{grid-template-columns:1fr}
}
/* ═══════════════════════════════════════════════════════
   bug.html v2 — Hero 介绍 + 发布按钮（替代原 stat 数字）
   ═══════════════════════════════════════════════════════ */
.community-hero-intro{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px 22px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  flex-wrap:wrap;
}
.community-hero-intro .chi-lead{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1}
.community-hero-intro .section-eyebrow{margin-bottom:0}
.community-hero-intro .chi-title{
  font-family:var(--cn);font-weight:600;font-size:22px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.3;
}
.community-hero-intro .chi-desc{
  font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.75;max-width:62ch;
}
.community-hero-intro .chi-btn{flex-shrink:0}

@media (max-width:760px){
  .community-hero-intro{flex-direction:column;align-items:stretch}
  .community-hero-intro .chi-btn{width:100%;justify-content:center}
}
/* ═══════════════════════════════════════════════════════
   task.html v2 — Hero 今日委托 + 世界任务 banner + 三 Tab
   ═══════════════════════════════════════════════════════ */

/* Hero 今日委托紧凑卡片 */
.hero-daily{
  margin-top:18px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
}
.hero-daily .hd-head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  flex-wrap:wrap;
  padding:11px 18px;
  border-bottom:1px solid var(--line);
  background:rgba(0,0,0,.18);
}
.hero-daily .hd-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10.5px;color:var(--ink-1);
  letter-spacing:.16em;text-transform:uppercase;
}
.hero-daily .hd-tag .dot{
  width:6px;height:6px;border-radius:50%;background:var(--mustard);
  box-shadow:0 0 0 0 rgba(197,131,45,.5);animation:pulseAmber 2.4s ease-in-out infinite;
}
.hero-daily .hd-tag strong{color:var(--mustard);font-weight:700}
.hero-daily .hd-streak{
  font-family:var(--cn);font-size:12px;color:var(--ink-2);
}
.hero-daily .hd-streak strong{color:var(--ink-0);font-weight:500}
.hero-daily .hd-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
}
.hero-daily .hd-card{
  padding:18px 22px;display:flex;flex-direction:column;gap:8px;
  border-right:1px solid var(--line);min-width:0;
}
.hero-daily .hd-card:last-child{border-right:none}
.hero-daily .hdc-meta{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.hero-daily .hdc-num{color:var(--mustard);font-weight:600}
.hero-daily .hdc-time{color:var(--ink-3)}
.hero-daily .hdc-title{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.3;
}
.hero-daily .hdc-sub{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7;
}
.hero-daily .hdc-foot{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-top:auto;padding-top:6px;
}
.hero-daily .hdc-reward{display:inline-flex;align-items:center;gap:6px}
@media (max-width:760px){
  .hero-daily .hd-grid{grid-template-columns:1fr}
  .hero-daily .hd-card{border-right:none;border-bottom:1px solid var(--line)}
  .hero-daily .hd-card:last-child{border-bottom:none}
  .hero-daily .hd-head{flex-direction:column;align-items:flex-start}
}

/* 世界任务 banner */
.world-quest-banner{
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:24px;
  align-items:center;
  padding:20px 26px;
  border:1px solid var(--rev);background:rgba(226,55,37,.06);
  color:inherit;text-decoration:none;
  transition:background .25s, transform .25s;
}
.world-quest-banner:hover{
  background:rgba(226,55,37,.12);
}
.wqb-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 100% 50%, rgba(226,55,37,.18), transparent 60%);
}
.wqb-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10.5px;color:var(--rev);
  letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  padding:6px 12px;border:1px solid var(--rev);
  white-space:nowrap;
  position:relative;z-index:2;
}
.wqb-tag .dot{
  width:6px;height:6px;border-radius:50%;background:var(--rev);
  box-shadow:0 0 0 0 rgba(226,55,37,.5);animation:pulse 2.4s ease-in-out infinite;
}
.wqb-body{position:relative;z-index:2;min-width:0}
.wqb-body h3{
  font-family:var(--cn);font-weight:500;font-size:18px;color:var(--ink-0);
  letter-spacing:.02em;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.wqb-body h3 .wqb-pct{font-family:var(--mono);font-size:14px;color:var(--rev)}
.wqb-body h3 .wqb-pct strong{font-family:var(--sans);font-weight:700;font-size:18px}
.wqb-body h3 .wqb-deadline{font-family:var(--mono);font-size:12px;color:var(--ink-2)}
.wqb-body p{
  font-family:var(--cn);font-size:13px;color:var(--ink-1);line-height:1.7;
  margin-top:4px;
}
.wqb-body p strong{color:var(--ink-0);font-weight:500}
.wqb-progress{
  width:100%;height:5px;background:var(--bg-2);border:1px solid var(--line);
  margin-top:10px;overflow:hidden;
}
.wqb-progress span{
  display:block;height:100%;background:linear-gradient(90deg, var(--rev), var(--rev-deep));
  transition:width .8s ease;
}
.wqb-cta{
  position:relative;z-index:2;
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--cn);font-weight:500;font-size:14px;color:var(--bone);
  padding:12px 20px;border:1px solid var(--bone);background:transparent;
  white-space:nowrap;flex-shrink:0;
  transition:all .2s;
}
.world-quest-banner:hover .wqb-cta{background:var(--bone);color:var(--ink-rev)}
.wqb-arr{font-family:var(--sans);font-weight:600;font-size:16px}
@media (max-width:760px){
  .world-quest-banner{grid-template-columns:1fr;gap:14px;padding:18px}
  .wqb-cta{justify-content:center}
}

/* Tab 内容 panel */
.task-panels-section .task-panel{display:none}
.task-panels-section .task-panel.is-active{display:block}
.task-panels-section .tp-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;
  flex-wrap:wrap;margin-bottom:22px;
}
.task-panels-section .tp-head h2{margin-top:6px}
.task-panels-section .tp-desc{
  font-family:var(--cn);font-size:13.5px;color:var(--ink-1);line-height:1.7;
  margin-top:8px;max-width:62ch;
}
.task-panels-section .tp-desc strong{color:var(--ink-0);font-weight:500}

/* quest-nav 改为 task-tabs-bar 时的 active 样式（增强） */
.quest-nav.task-tabs-bar a.active{
  color:var(--ink-0);background:rgba(226,55,37,.08);
}
.quest-nav.task-tabs-bar a.active::before{
  background:var(--rev);
}
/* ═══════════════════════════════════════════════════════
   character.html — 个人主页 v2（完全重做）
   ═══════════════════════════════════════════════════════ */
.profile-page-v2{
  padding: clamp(28px, 4vw, 56px) var(--pad-x) clamp(40px, 5vw, 64px);
}

/* ── HERO ── */
.profile-page-v2 .pp-hero{
  display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:28px;
  align-items:center;
  padding:28px 32px;
  border:1px solid var(--line-2);
  background:
    radial-gradient(ellipse 70% 80% at 0% 50%, rgba(201,90,68,.08), transparent 70%),
    radial-gradient(ellipse 30% 80% at 100% 0%, rgba(232,230,225,.04), transparent 70%),
    rgba(255,255,255,.02);
  margin-bottom:18px;
}
.profile-page-v2 .pp-avatar-wrap{position:relative;width:96px;height:96px}
.profile-page-v2 .pp-avatar{
  width:96px;height:96px;
  display:grid;place-items:center;
  font-family:var(--cn);font-weight:700;font-size:42px;color:var(--rust-3);
  background:linear-gradient(135deg, rgba(201,90,68,.18), rgba(201,90,68,.06));
  border:2px solid var(--rust-edge);
  box-shadow:0 8px 24px rgba(201,90,68,.18);
}
.profile-page-v2 .pp-online-dot{
  position:absolute;right:2px;bottom:6px;
  width:16px;height:16px;border-radius:50%;
  background:var(--green);border:3px solid var(--bg-0);
  box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite;
}
.profile-page-v2 .pp-id{display:flex;flex-direction:column;gap:4px;min-width:0}
.profile-page-v2 .pp-id-label{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;color:var(--green);
  letter-spacing:.18em;text-transform:uppercase;
  align-self:flex-start;padding:3px 10px;border:1px solid var(--green);
  background:rgba(90,155,106,.06);
  margin-bottom:6px;
}
.profile-page-v2 .pp-id-label .dot{
  width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite;
}
.profile-page-v2 .pp-name{
  font-family:var(--cn);font-weight:600;font-size:clamp(24px, 3vw, 32px);
  color:var(--ink-0);letter-spacing:.02em;line-height:1.2;
}
.profile-page-v2 .pp-uid{
  font-family:var(--mono);font-size:13px;color:var(--ink-2);letter-spacing:.08em;
}
.profile-page-v2 .pp-meta{
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
  margin-top:8px;font-family:var(--cn);font-size:13px;color:var(--ink-2);
}
.profile-page-v2 .pp-meta b{color:var(--ink-0);font-weight:500}
.profile-page-v2 .pp-meta .sep{color:var(--ink-3)}
.profile-page-v2 .pp-quick-actions{
  display:flex;flex-direction:column;gap:8px;align-items:flex-end;
}

/* ── 血条 + 三组小数据 ── */
.profile-page-v2 .pp-vitals{
  display:grid;grid-template-columns:minmax(0,1.6fr) repeat(3,minmax(0,1fr));gap:14px;
  margin-bottom:18px;
}
.profile-page-v2 .pp-blood{
  padding:18px 22px;border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  display:flex;flex-direction:column;gap:10px;min-width:0;
}
.profile-page-v2 .pp-blood header{
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
}
.profile-page-v2 .pp-blood-lab{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.16em;text-transform:uppercase;
}
.profile-page-v2 .pp-blood-num{
  font-family:var(--sans);font-weight:700;font-size:22px;color:var(--ink-0);
  letter-spacing:-.01em;
}
.profile-page-v2 .pp-blood-bar{
  width:100%;height:10px;background:var(--bg-2);border:1px solid var(--line);overflow:hidden;
}
.profile-page-v2 .pp-blood-bar span{
  display:block;height:100%;width:var(--hp, 0%);
  background:linear-gradient(90deg, var(--rust-3), var(--rust));
  transition:width .8s ease;
}
.profile-page-v2 .pp-blood-note{
  font-family:var(--cn);font-size:12px;color:var(--ink-2);line-height:1.7;
}
.profile-page-v2 .pp-blood-note strong{color:var(--ink-1);font-weight:500}

.profile-page-v2 .pp-vital-mini{
  padding:18px 20px;border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  display:flex;flex-direction:column;gap:4px;min-width:0;
}
.profile-page-v2 .ppvm-lab{
  font-family:var(--mono);font-size:10px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;
}
.profile-page-v2 .ppvm-num{
  font-family:var(--sans);font-weight:700;font-size:26px;color:var(--ink-0);
  letter-spacing:-.01em;line-height:1.1;
}
.profile-page-v2 .ppvm-num em{font-style:normal;font-size:14px;color:var(--ink-1);margin-left:3px}
.profile-page-v2 .pp-mood{color:var(--green)}
.profile-page-v2 .ppvm-sub{
  font-family:var(--cn);font-size:11.5px;color:var(--ink-2);margin-top:2px;
}

@media (max-width:1180px){
  .profile-page-v2 .pp-vitals{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .profile-page-v2 .pp-vitals{grid-template-columns:1fr}
  .profile-page-v2 .pp-hero{grid-template-columns:1fr;text-align:center;padding:24px 20px}
  .profile-page-v2 .pp-avatar-wrap{justify-self:center}
  .profile-page-v2 .pp-id-label{align-self:center}
  .profile-page-v2 .pp-meta{justify-content:center}
  .profile-page-v2 .pp-quick-actions{flex-direction:row;justify-content:center}
}

/* ── 主区：左角色卡 + 右六维 ── */
.profile-page-v2 .pp-main-grid{
  display:grid;grid-template-columns:380px minmax(0,1fr);gap:18px;
  margin-bottom:18px;
}

/* 角色卡 */
.profile-page-v2 .pp-charcard{
  position:relative;overflow:hidden;
  padding:28px 26px 22px;
  border:1px solid var(--rust);
  background:linear-gradient(180deg, #0c0c10 0%, #15110f 100%);
  display:flex;flex-direction:column;gap:16px;min-height:480px;
}
.pcc-bg{position:absolute;inset:0;pointer-events:none}
.pcc-bg .pcc-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(232,230,225,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(232,230,225,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, #000 30%, transparent 90%);
}
.pcc-bg .pcc-glow{
  position:absolute;right:-100px;top:-50px;width:300px;height:300px;
  background:radial-gradient(circle, rgba(201,90,68,.14), transparent 70%);
}
.profile-page-v2 .pp-charcard > *{position:relative;z-index:2}
.pcc-head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-family:var(--mono);font-size:10px;color:var(--rust-3);
  letter-spacing:.2em;text-transform:uppercase;
  padding-bottom:12px;border-bottom:1px solid rgba(201,90,68,.2);
}
.pcc-no{color:var(--ink-2)}
.pcc-avatar{display:flex;justify-content:center;padding:8px 0}
.pcc-av{
  width:96px;height:96px;
  display:grid;place-items:center;
  font-family:var(--cn);font-weight:700;font-size:42px;color:var(--bone);
  background:radial-gradient(circle, rgba(201,90,68,.3), rgba(0,0,0,.4));
  border:2px solid var(--rust-3);
}
.pcc-name-block{display:flex;flex-direction:column;gap:6px;text-align:center;align-items:center}
.pcc-name{
  font-family:var(--cn-serif);font-weight:700;font-size:26px;color:var(--bone);
  letter-spacing:.04em;
}
.pcc-uid{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);letter-spacing:.1em}
.pcc-rows{
  display:flex;flex-direction:column;gap:0;
  margin-top:auto;border-top:1px dashed rgba(201,90,68,.25);padding-top:14px;
}
.pcc-row{
  display:grid;grid-template-columns:60px minmax(0,1fr);gap:14px;
  padding:9px 0;border-bottom:1px dashed rgba(232,230,225,.06);
  align-items:baseline;
}
.pcc-row:last-child{border-bottom:none}
.pcc-k{
  font-family:var(--mono);font-size:9.5px;color:var(--ink-2);
  letter-spacing:.16em;text-transform:uppercase;
}
.pcc-v{
  font-family:var(--cn);font-size:14px;color:var(--ink-0);font-weight:500;letter-spacing:.02em;
}
.pcc-foot{
  display:flex;flex-direction:column;gap:4px;text-align:center;
  padding-top:12px;border-top:1px dashed rgba(201,90,68,.25);
}
.pcc-stamp{
  font-family:var(--mono);font-size:9.5px;color:var(--rust-3);letter-spacing:.24em;
}
.pcc-not{
  font-family:var(--cn);font-size:10.5px;color:var(--ink-3);
}

/* 六维 */
.profile-page-v2 .pp-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  padding:24px 26px;border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  align-items:center;
}
.pp-stats-head{
  grid-column:1/-1;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:6px;
}
.pp-stats-lab{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.16em;text-transform:uppercase;
}
.pp-stats-more{
  font-family:var(--mono);font-size:10.5px;color:var(--rust-3);
  letter-spacing:.14em;border-bottom:1px dashed currentColor;
}
.pp-radar-wrap{display:flex;align-items:center;justify-content:center;padding:8px}
.pp-radar-svg{width:100%;max-width:260px;height:auto}
.pp-radar-area{transition:all .8s ease}
.pp-stats-bars{display:flex;flex-direction:column;gap:9px}
.ppsb{display:grid;grid-template-columns:40px minmax(0,1fr) 40px;gap:10px;align-items:center}
.ppsb-lab{font-family:var(--cn);font-size:12px;color:var(--ink-1)}
.ppsb-bar{height:6px;background:var(--bg-2);border:1px solid var(--line);overflow:hidden}
.ppsb-bar span{
  display:block;height:100%;width:0%;
  background:linear-gradient(90deg, var(--ink-1), var(--rust-3));
  transition:width .8s ease;
}
.ppsb strong{
  font-family:var(--mono);font-weight:600;font-size:13px;color:var(--ink-0);
  text-align:right;font-variant-numeric:tabular-nums;
}

@media (max-width:1180px){
  .profile-page-v2 .pp-main-grid{grid-template-columns:1fr}
  .profile-page-v2 .pp-charcard{min-height:auto}
}
@media (max-width:760px){
  .profile-page-v2 .pp-stats{grid-template-columns:1fr;padding:18px}
  .pp-stats-head{flex-direction:column;align-items:flex-start;gap:8px}
}

/* ── 快速入口 ── */
.profile-page-v2 .pp-quicklinks{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;
  margin-bottom:18px;
}
.pp-ql{
  display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;align-items:center;
  padding:16px 18px;border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  color:inherit;text-decoration:none;
  transition:border-color .25s, background .25s, transform .25s;
  min-width:0;
}
.pp-ql:hover{
  border-color:var(--rust-3);background:rgba(201,90,68,.06);transform:translateY(-2px);
}
.pp-ql.pp-ql-medal{
  border-color:var(--green);background:rgba(90,155,106,.06);
}
.pp-ql.pp-ql-medal:hover{
  border-color:var(--green);background:rgba(90,155,106,.12);
}
.pp-ql-icon{
  display:grid;place-items:center;width:36px;height:36px;
  font-family:var(--sans);font-weight:600;font-size:18px;color:var(--rust-3);
  background:rgba(201,90,68,.1);border:1px solid var(--rust-edge);
}
.pp-ql.pp-ql-medal .pp-ql-icon{color:var(--green);background:rgba(90,155,106,.1);border-color:var(--green)}
.pp-ql-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.pp-ql-body strong{
  font-family:var(--cn);font-weight:500;font-size:13.5px;color:var(--ink-0);
  letter-spacing:.02em;line-height:1.4;
}
.pp-ql-body span{font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase}
.pp-ql-arr{font-family:var(--sans);font-size:14px;color:var(--ink-2);flex-shrink:0}
.pp-ql:hover .pp-ql-arr{color:var(--rust-3)}

@media (max-width:1180px){
  .profile-page-v2 .pp-quicklinks{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .profile-page-v2 .pp-quicklinks{grid-template-columns:1fr}
}

/* ── Feed Section ── */
.profile-page-v2 .pp-feed-section{
  padding:28px 30px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);
}
.pp-feed-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:18px;
  flex-wrap:wrap;margin-bottom:20px;
}
.pp-feed-head h2{
  font-family:var(--cn);font-weight:500;font-size:24px;color:var(--ink-0);
  letter-spacing:.02em;margin-top:6px;
}
.pp-feed-sub{
  font-family:var(--cn);font-size:13px;color:var(--ink-2);line-height:1.7;
  margin-top:6px;max-width:54ch;
}
.pp-feed-tabs{display:flex;gap:0;border:1px solid var(--line-2)}
.pp-feed-tabs button{
  padding:9px 16px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-2);
  letter-spacing:.1em;background:transparent;cursor:pointer;
  border:none;border-right:1px solid var(--line);
  display:inline-flex;align-items:center;gap:7px;
  transition:all .2s;
}
.pp-feed-tabs button:last-child{border-right:none}
.pp-feed-tabs button:hover{color:var(--ink-0)}
.pp-feed-tabs button.on{color:var(--bone);background:rgba(201,90,68,.12);border-color:var(--rust-3)}
.pp-feed-tabs button em{
  font-style:normal;font-family:var(--mono);font-weight:600;font-size:11px;
  color:var(--rust-3);padding:1px 6px;border:1px solid currentColor;
}

@media (max-width:760px){
  .profile-page-v2 .pp-feed-section{padding:22px}
  .pp-feed-head{flex-direction:column;align-items:stretch}
  .pp-feed-tabs{justify-content:stretch}
  .pp-feed-tabs button{flex:1;justify-content:center}
}
/* ═══════════════════════════════════════════════════════
   character.html — 个人主页 v3（沉浸式星空 dashboard）
   ═══════════════════════════════════════════════════════ */
.profile-page-v3{
  position:relative;overflow:hidden;
  isolation:isolate;
  --gold: #c95a44;
  --gold-soft: rgba(201,90,68,.12);
  --gold-line: rgba(201,90,68,.28);
  --gold-deep: #7a2a1f;
  --pp-card-bg: rgba(8,10,18,.62);
  --pp-card-bg-hi: rgba(14,18,28,.78);
  --pp-card-line: rgba(232,196,128,.16);
  --pp-card-line-hi: rgba(232,196,128,.35);
  padding: clamp(32px, 5vw, 64px) var(--pad-x) clamp(56px, 6vw, 88px);
  min-height:100vh;
}

/* 全屏背景层：固定在视口，不随 tab 内容高度变化而重排，避免背景突然缩放 */
.ppv3-backdrop{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  overflow:hidden;
}
.ppv3-bg-image{
  position:absolute;inset:-7%;
  background-image:url('profile-bg.webp');
  background-size:cover;background-position:center -300px;
  filter:brightness(.92) saturate(1.08) contrast(1.02);
  will-change:transform;
  /* 慢慢漂移让背景"活"起来 */
  animation:ppv3BgDrift 48s ease-in-out infinite alternate;
}
@keyframes ppv3BgDrift{
  from{ transform: scale(1.06) translate(0,0); }
  to{   transform: scale(1.14) translate(-3.2%, -2.4%); }
}
.ppv3-bg-vignette{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(8,8,10,.05) 0%, rgba(8,8,10,.35) 55%, rgba(8,8,10,.78) 100%),
    radial-gradient(ellipse 80% 70% at 50% 35%, rgba(8,8,10,0) 45%, rgba(8,8,10,.4) 100%);
}
.ppv3-bg-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(232,230,225,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(232,230,225,.025) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, #000 30%, transparent 90%);
}

.ppv3-inner{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-direction:column;gap:18px;
}

/* ── 通用卡片 ── */
.profile-page-v3 .ppv3-card,
.profile-page-v3 .ppv3-id-card,
.profile-page-v3 .ppv3-level-card,
.profile-page-v3 .ppv3-medals{
  background: var(--pp-card-bg);
  border: 1px solid var(--pp-card-line);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  position:relative;
}
.profile-page-v3 .ppv3-card:hover,
.profile-page-v3 .ppv3-id-card:hover,
.profile-page-v3 .ppv3-level-card:hover,
.profile-page-v3 .ppv3-medals:hover{
  border-color: var(--pp-card-line-hi);
  background: var(--pp-card-bg-hi);
}

/* ═══════ 第一行：身份卡 + 等级卡 ═══════ */
.ppv3-row-top{
  display:grid;grid-template-columns:minmax(0, 380px) minmax(0, 1fr);gap:18px;
}

/* 身份卡 */
.ppv3-id-card{
  padding:26px 28px 22px;
  display:flex;flex-direction:column;gap:18px;
}
.ppv3-id-top{display:flex;align-items:center;gap:18px}
.ppv3-avatar-wrap{position:relative;width:84px;height:84px;flex-shrink:0}
.ppv3-av-ring{
  position:absolute;inset:-4px;border-radius:50%;
  border:1.5px solid var(--gold-line);
  background: conic-gradient(from 0deg, var(--gold) 0%, transparent 28%, var(--gold-deep) 50%, transparent 78%, var(--gold) 100%);
  -webkit-mask: radial-gradient(circle, transparent 39px, #000 40px);
          mask: radial-gradient(circle, transparent 39px, #000 40px);
  animation: ppv3RingSpin 8s linear infinite;
}
@keyframes ppv3RingSpin{ to{ transform:rotate(360deg); } }
.ppv3-avatar{
  position:relative;width:84px;height:84px;border-radius:50%;
  display:grid;place-items:center;
  font-family:var(--cn);font-weight:700;font-size:36px;color:var(--gold);
  background:radial-gradient(circle, rgba(201,90,68,.18), rgba(0,0,0,.5));
  border:2px solid var(--gold);
  box-shadow:0 0 24px rgba(201,90,68,.25), inset 0 0 12px rgba(0,0,0,.4);
}
.ppv3-online-dot{
  position:absolute;right:0px;bottom:4px;
  width:14px;height:14px;border-radius:50%;
  background:var(--green);border:2.5px solid #0a0d18;
  box-shadow:0 0 0 0 rgba(90,155,106,.5);animation:pulse 2.4s ease-in-out infinite;
  z-index:2;
}
.ppv3-id-name{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.ppv3-name{
  font-family:var(--cn);font-weight:600;font-size:24px;color:#e8e6e1;
  letter-spacing:.04em;line-height:1.2;
}
.ppv3-uid{
  font-family:var(--mono);font-size:11px;color:rgba(232,196,128,.6);
  letter-spacing:.08em;
}
.ppv3-meta-row{
  display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;
  margin-top:6px;font-family:var(--cn);font-size:12px;color:rgba(232,196,128,.5);
}
.ppv3-tag-job, .ppv3-tag-shard{
  padding:2px 8px;background:rgba(201,90,68,.08);border:1px solid var(--gold-line);
  font-size:11px;
}
.ppv3-tag-job b, .ppv3-tag-shard b{color:#e8e6e1;font-weight:500}
.ppv3-meta-dot{color:rgba(232,196,128,.3)}

/* 身份卡数据 3 列 */
.ppv3-id-stats{
  display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:0;
  border-top:1px solid var(--gold-line);
  border-bottom:1px solid var(--gold-line);
  padding:14px 0;
}
.ppv3-id-stats article{
  display:flex;flex-direction:column;gap:2px;align-items:center;text-align:center;
  border-right:1px solid rgba(201,90,68,.08);min-width:0;
}
.ppv3-id-stats article:last-child{border-right:none}
.ppv3-id-stats .num{
  font-family:var(--sans);font-weight:700;font-size:22px;color:#e8e6e1;
  letter-spacing:-.01em;line-height:1.1;
}
.ppv3-id-stats em{
  font-style:normal;font-family:var(--mono);font-size:9.5px;color:rgba(232,196,128,.55);
  letter-spacing:.16em;text-transform:uppercase;margin-top:2px;
}

.ppv3-id-actions{display:flex;gap:8px}
.ppv3-id-actions .btn{flex:1;justify-content:center;border-color:var(--gold-line);color:#e8e6e1}
.ppv3-id-actions .btn:hover{border-color:var(--gold);background:var(--gold-soft);color:#fff}

/* 等级卡 */
.ppv3-level-card{
  padding:26px 30px 20px;
  display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
}
.ppv3-lvl-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:24px;
}
.ppv3-lvl-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;color:var(--gold);
  letter-spacing:.18em;text-transform:uppercase;
}
.ppv3-lvl-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 8px var(--gold), 0 0 0 0 rgba(201,90,68,.5);animation:pulse 2.4s ease-in-out infinite;
}
.ppv3-lvl-title{
  font-family:var(--cn);font-weight:600;font-size:clamp(22px, 2.8vw, 30px);color:#f0e8da;
  letter-spacing:.04em;line-height:1.2;margin-top:8px;
  text-shadow: 0 2px 12px rgba(201,90,68,.2);
}
.ppv3-lvl-sub{
  font-family:var(--cn);font-size:12.5px;color:rgba(232,196,128,.65);margin-top:6px;
}
.ppv3-lvl-sub strong{color:var(--gold);font-weight:600}
.ppv3-lvl-num{
  display:flex;align-items:baseline;gap:6px;flex-shrink:0;
}
.ppv3-lvl-num .num{
  font-family:var(--sans);font-weight:700;font-size:64px;color:var(--gold);
  letter-spacing:-.03em;line-height:1;
  text-shadow: 0 0 24px rgba(201,90,68,.4);
}
.ppv3-lvl-num em{
  font-style:normal;font-family:var(--mono);font-size:13px;color:rgba(232,196,128,.6);
  letter-spacing:.1em;
}

.ppv3-lvl-bar-wrap{display:flex;flex-direction:column;gap:6px}
.ppv3-lvl-bar{
  width:100%;height:8px;background:rgba(0,0,0,.5);
  border:1px solid var(--gold-line);overflow:hidden;
  box-shadow: inset 0 0 8px rgba(0,0,0,.5);
}
.ppv3-lvl-bar span{
  display:block;height:100%;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold), #ff7a5c);
  box-shadow: 0 0 8px rgba(201,90,68,.6);
  transition:width 1s ease;
}
.ppv3-lvl-bar-meta{
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  font-family:var(--mono);font-size:11px;color:rgba(232,196,128,.5);
  letter-spacing:.1em;
}
.ppv3-lvl-bar-meta strong{color:var(--gold);font-weight:600}

/* 等级卡：血条 + 三块 */
.ppv3-vitals{
  display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr);gap:14px;
  padding-top:14px;border-top:1px solid rgba(201,90,68,.15);
}
.ppv3-blood{display:flex;flex-direction:column;gap:6px;min-width:0}
.ppv3-blood-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
}
.ppv3-blood-row .lab{font-family:var(--mono);font-size:10px;color:rgba(232,196,128,.55);letter-spacing:.16em;text-transform:uppercase}
.ppv3-blood-row strong{font-family:var(--sans);font-weight:700;font-size:18px;color:#e8e6e1}
.ppv3-blood-bar{
  width:100%;height:8px;background:rgba(0,0,0,.5);border:1px solid rgba(232,196,128,.18);
  overflow:hidden;
}
.ppv3-blood-bar span{
  display:block;height:100%;width:var(--hp, 0%);
  background: linear-gradient(90deg, #c95a44, #ff7a5c);
  transition:width 1s ease;
}
.ppv3-blood-note{
  font-family:var(--cn);font-size:11px;color:rgba(232,196,128,.45);line-height:1.5;
}

.ppv3-mini{
  padding:10px 14px;background:rgba(0,0,0,.3);border:1px solid rgba(201,90,68,.1);
  display:flex;flex-direction:column;gap:2px;min-width:0;
}
.ppv3-mini .lab{font-family:var(--mono);font-size:9.5px;color:rgba(232,196,128,.55);letter-spacing:.14em;text-transform:uppercase}
.ppv3-mini strong{font-family:var(--sans);font-weight:700;font-size:18px;color:#e8e6e1;line-height:1.1}
.ppv3-mini strong.g{color:var(--green)}
.ppv3-mini strong em{font-style:normal;font-size:11px;color:rgba(232,196,128,.5);margin-left:3px}
.ppv3-mini .sub{font-family:var(--cn);font-size:11px;color:rgba(232,196,128,.45)}

/* ═══════ 第二行：4 卡 grid ═══════ */
.ppv3-row-mid{
  display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:14px;
}
.profile-page-v3 .ppv3-card{
  padding:18px 20px;display:flex;flex-direction:column;gap:14px;min-width:0;min-height:300px;
}
.ppv3-card header{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding-bottom:10px;border-bottom:1px solid rgba(201,90,68,.12);
}
.ppv3-card header .lab{
  font-family:var(--mono);font-size:10px;color:var(--gold);
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;
}
.ppv3-card header .more{
  font-family:var(--mono);font-size:10px;color:rgba(232,196,128,.6);
  letter-spacing:.14em;
}
.ppv3-card header .more:hover{color:var(--gold)}

/* feed-tabs */
.ppv3-feed-tabs{display:flex;gap:4px;flex-wrap:wrap}
.ppv3-feed-tabs button{
  font-family:var(--mono);font-size:10.5px;color:rgba(232,196,128,.55);
  letter-spacing:.1em;padding:5px 10px;border:1px solid rgba(232,230,225,.15);
  background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;gap:5px;
}
.ppv3-feed-tabs button:hover{color:#e8e6e1;border-color:var(--gold-line)}
.ppv3-feed-tabs button.on{color:#1a1410;background:var(--gold);border-color:var(--gold)}
.ppv3-feed-tabs button em{font-style:normal;font-family:var(--mono);font-weight:600;font-size:10px;opacity:.7}
/* 固定高度：切换 tab 时内容多寡不再撑高整行，超出部分内部滚动 */
.ppv3-feed{height:300px;overflow-y:auto}

/* 雷达卡 */
.ppv3-radar-wrap{display:flex;align-items:center;justify-content:center;padding:0}
.ppv3-radar{width:100%;max-width:200px;height:auto}
.ppv3-radar-area{transition:all .8s ease;filter: drop-shadow(0 0 6px rgba(201,90,68,.3))}
.ppv3-stats-bars{display:flex;flex-direction:column;gap:6px}
.ppsb{display:grid;grid-template-columns:18px minmax(0,1fr) 26px;gap:8px;align-items:center}
.ppsb-lab{font-family:var(--cn);font-weight:500;font-size:11px;color:rgba(232,196,128,.65)}
.ppsb-bar{height:5px;background:rgba(0,0,0,.4);border:1px solid rgba(201,90,68,.1);overflow:hidden}
.ppsb-bar span{
  display:block;height:100%;width:0%;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold));
  transition:width .8s ease;
}
.ppsb strong{
  font-family:var(--mono);font-weight:600;font-size:11.5px;color:#e8e6e1;
  text-align:right;font-variant-numeric:tabular-nums;
}

/* talent 卡 */
.ppv3-talent-body{display:flex;flex-direction:column;gap:0;flex:1}
.ppv3-talent-row{
  display:grid;grid-template-columns:60px minmax(0,1fr);gap:10px;
  padding:10px 0;border-bottom:1px dashed rgba(201,90,68,.12);
  align-items:baseline;
}
.ppv3-talent-row:last-child{border-bottom:none}
.ppv3-talent-row .k{
  font-family:var(--mono);font-size:9.5px;color:rgba(232,196,128,.55);
  letter-spacing:.14em;text-transform:uppercase;
}
.ppv3-talent-row strong{
  font-family:var(--cn);font-weight:500;font-size:13.5px;color:#e8e6e1;letter-spacing:.02em;
}
.ppv3-talent-foot{
  display:flex;flex-direction:column;gap:3px;align-items:center;text-align:center;
  padding-top:10px;border-top:1px dashed rgba(201,90,68,.15);
}
.ppv3-talent-foot .mono{font-family:var(--mono);font-size:9.5px;color:var(--gold);letter-spacing:.24em}
.ppv3-talent-foot span:last-child{font-family:var(--cn);font-size:10.5px;color:rgba(232,196,128,.4)}

/* wallet 卡 */
.ppv3-wallet-coins{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}
.ppvw-coin{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:10px 6px;border:1px solid rgba(201,90,68,.12);background:rgba(0,0,0,.3);
}
.ppvw-coin .ic{
  display:grid;place-items:center;width:26px;height:26px;border-radius:50%;
  font-family:var(--cn);font-weight:600;font-size:11px;color:#1a1410;
  background: #c2a989;
}
.ppvw-coin.stone .ic{background:#a8a8a8}
.ppvw-coin.brick .ic{background:#c95a44;color:#fff}
.ppvw-coin strong{font-family:var(--sans);font-weight:700;font-size:18px;color:#e8e6e1;line-height:1}
.ppvw-coin em{font-style:normal;font-family:var(--mono);font-size:9px;color:rgba(232,196,128,.5);letter-spacing:.1em;text-transform:uppercase}

.ppv3-wallet-rows{display:flex;flex-direction:column;gap:0;flex:1}
.ppvw-row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 0;border-bottom:1px dashed rgba(201,90,68,.1);
  color:inherit;text-decoration:none;transition:background .15s;
  margin: 0 -8px;padding: 9px 8px;
}
.ppvw-row:hover{background:rgba(201,90,68,.05)}
.ppvw-row span{font-family:var(--mono);font-size:9.5px;color:rgba(232,196,128,.55);letter-spacing:.14em;text-transform:uppercase}
.ppvw-row strong{font-family:var(--cn);font-weight:500;font-size:12px;color:#e8e6e1;text-align:right}

/* ═══════ 第三行：守护者奖牌墙 ═══════ */
.ppv3-medals{
  padding:24px 28px 20px;
  display:flex;flex-direction:column;gap:18px;
}
.ppv3-medals header{
  display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding-bottom:14px;border-bottom:1px solid rgba(201,90,68,.15);
}
.ppv3-medals header .lab{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10.5px;color:var(--gold);
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;
}
.ppv3-medals header .lab .dot{
  width:6px;height:6px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 8px var(--gold);animation:pulse 2.4s ease-in-out infinite;
}
.ppv3-medals header h3{
  font-family:var(--cn);font-weight:500;font-size:20px;color:#e8e6e1;
  letter-spacing:.02em;margin-top:6px;
}
.ppv3-medals header h3 .mono{font-family:var(--mono);font-size:12px;color:rgba(232,196,128,.55);font-weight:400}
.ppv3-medals header h3 strong{color:var(--gold);font-family:var(--sans);font-weight:700}
.ppv3-medals header .btn{border-color:var(--gold-line);color:#e8e6e1}
.ppv3-medals header .btn:hover{border-color:var(--gold);background:var(--gold-soft);color:#fff}

.ppv3-medals-grid{
  display:grid;grid-template-columns:repeat(12, minmax(0, 1fr));gap:10px;
}
.ppv3-medal{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:10px 4px;background:rgba(0,0,0,.3);border:1px solid rgba(201,90,68,.1);
  text-decoration:none;color:inherit;transition:all .25s;
  cursor: default;
}
.ppv3-medal.locked{cursor:pointer}
.ppv3-medal.unlocked{
  background: radial-gradient(ellipse 80% 70% at 50% 30%, rgba(201,90,68,.15), rgba(0,0,0,.4));
  border-color: var(--gold-line);
  box-shadow: 0 4px 14px rgba(201,90,68,.12);
}
.ppv3-medal.locked:hover{
  border-color:var(--gold-line);background:rgba(201,90,68,.06);transform:translateY(-2px);
}
.ppv3-medal.unlocked:hover{
  border-color:var(--gold);transform:translateY(-2px) scale(1.04);
  box-shadow: 0 8px 24px rgba(201,90,68,.3);
}
.ppv3-medal svg{width:100%;max-width:64px;height:auto;display:block}
.ppv3-medal-name{
  font-family:var(--mono);font-size:9.5px;color:rgba(232,196,128,.55);
  letter-spacing:.14em;text-transform:uppercase;text-align:center;
}
.ppv3-medal.unlocked .ppv3-medal-name{color:var(--gold);font-weight:600}

/* ═══════ 底部快速入口 ═══════ */
.ppv3-quicklinks{
  display:grid;grid-template-columns:repeat(6, minmax(0, 1fr));gap:10px;
  margin-top:6px;
}
.ppv3-ql{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:14px 10px;
  background: var(--pp-card-bg);
  border: 1px solid var(--pp-card-line);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color:rgba(232,196,128,.7);text-decoration:none;
  font-family:var(--cn);font-size:12px;letter-spacing:.06em;
  transition: all .25s;
}
.ppv3-ql:hover{
  border-color: var(--gold);color:#fff;background:rgba(201,90,68,.1);
  transform:translateY(-2px);
}
.ppv3-ql.highlight{
  border-color:var(--green);color:#a8e0b0;background:rgba(90,155,106,.08);
}
.ppv3-ql.highlight:hover{
  border-color:var(--green);background:rgba(90,155,106,.18);color:#fff;
}
.ppv3-ql .ic{
  font-family:var(--sans);font-weight:600;font-size:18px;
  width:32px;height:32px;display:grid;place-items:center;
  border:1px solid currentColor;border-radius:50%;
}

/* ═══════ 响应式 ═══════ */
@media (max-width: 1280px){
  .ppv3-row-mid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .ppv3-medals-grid{grid-template-columns:repeat(6, minmax(0, 1fr))}
}
@media (max-width: 980px){
  .ppv3-row-top{grid-template-columns:1fr}
  .ppv3-vitals{grid-template-columns:1fr}
  .ppv3-quicklinks{grid-template-columns:repeat(3, minmax(0, 1fr))}
}
@media (max-width: 640px){
  .ppv3-row-mid{grid-template-columns:1fr}
  .ppv3-medals-grid{grid-template-columns:repeat(4, minmax(0, 1fr))}
  .ppv3-quicklinks{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .ppv3-id-card,
  .ppv3-level-card,
  .ppv3-medals{padding:20px 18px}
  .ppv3-lvl-num .num{font-size:48px}
  .ppv3-lvl-head{flex-direction:column;gap:14px}
}
/* ═══════════════════════════════════════════════════════
   个人主页 v3.1 — 合并角色卡 + 死亡结算上提
   ═══════════════════════════════════════════════════════ */

/* 第二行：角色卡 + 死亡结算 */
.ppv3-row-char{
  display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:14px;
}

/* ── 合并角色卡 ── */
.ppv3-charcard{
  position:relative;
}
.ppv3-charcard .ppv3-cc-grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,260px);gap:24px;
  align-items:start;flex:1;
}
.ppv3-cc-info{display:flex;flex-direction:column;gap:0}
.ppv3-cc-row{
  display:grid;grid-template-columns:78px minmax(0,1fr);gap:14px;
  padding:11px 0;border-bottom:1px dashed rgba(232,230,225,.08);
  align-items:baseline;
}
.ppv3-cc-row .k{
  font-family:var(--mono);font-size:9.5px;color:var(--pp-text-dim);
  letter-spacing:.16em;text-transform:uppercase;
}
.ppv3-cc-row strong{
  font-family:var(--cn);font-weight:500;font-size:14px;color:var(--pp-text-bright);
  letter-spacing:.02em;line-height:1.5;
}
/* 六维数据条紧跟在 info 行下方 */
.ppv3-cc-info .ppv3-stats-bars{
  margin-top:14px;padding-top:14px;
  border-top:1px solid rgba(201,90,68,.15);
  display:flex;flex-direction:column;gap:7px;
}
.ppv3-cc-radar{
  display:flex;align-items:center;justify-content:center;
  align-self:center;padding:4px;
}
.ppv3-cc-radar .ppv3-radar{width:100%;max-width:240px;height:auto}
.ppv3-cc-foot{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  margin-top:16px;padding-top:14px;
  border-top:1px dashed rgba(201,90,68,.2);
  font-family:var(--cn);font-size:10.5px;color:var(--pp-text-dim);
}
.ppv3-cc-foot .mono{
  font-family:var(--mono);font-size:9.5px;color:var(--pp-accent);
  letter-spacing:.22em;
}

/* ── 死亡结算卡 ── */
.ppv3-deathcard{
  border-color:rgba(201,90,68,.3) !important;
}
.ppv3-deathcard header .lab{color:var(--pp-accent)}
.ppv3-deathcard header .lab .dot{
  width:6px;height:6px;border-radius:50%;background:var(--pp-accent);
  box-shadow:0 0 8px var(--pp-accent-glow);animation:pulse 2.4s ease-in-out infinite;
}
.ppv3-death-status{
  padding:14px 16px;
  background:linear-gradient(135deg, rgba(201,90,68,.12), rgba(0,0,0,.2));
  border:1px solid rgba(201,90,68,.25);
}
.ppv3-death-status-main{display:flex;flex-direction:column;gap:4px}
.ppv3-death-tag{
  font-family:var(--mono);font-size:9.5px;color:var(--pp-accent);
  letter-spacing:.16em;text-transform:uppercase;
}
.ppv3-death-status-main strong{
  font-family:var(--cn);font-weight:600;font-size:18px;color:var(--pp-text-bright);
  letter-spacing:.02em;
}
.ppv3-death-status p{
  font-family:var(--cn);font-size:11.5px;color:var(--pp-text-dim);line-height:1.6;
  margin-top:6px;
}
.ppv3-death-rows{display:flex;flex-direction:column;gap:0;flex:1}
.ppv3-death-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding:8px 0;border-bottom:1px dashed rgba(232,230,225,.07);
}
.ppv3-death-row span{
  font-family:var(--mono);font-size:9.5px;color:var(--pp-text-dim);
  letter-spacing:.12em;text-transform:uppercase;flex-shrink:0;
}
.ppv3-death-row strong{
  font-family:var(--cn);font-weight:500;font-size:12px;color:var(--pp-text-bright);
  text-align:right;
}
.ppv3-death-cta{
  display:flex;flex-direction:column;gap:8px;
  padding-top:12px;border-top:1px solid rgba(201,90,68,.18);
}
.ppv3-death-cta .btn{justify-content:center}
.ppv3-death-cta .btn.primary{
  background:var(--pp-accent);border-color:var(--pp-accent);color:#fff;
}
.ppv3-death-cta .btn.ghost{border-color:var(--pp-card-line);color:var(--pp-text-mid)}

/* 第三行：feed + 钱包 */
.ppv3-row-mid2{
  display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:14px;
}

@media (max-width: 980px){
  .ppv3-row-char{grid-template-columns:1fr}
  .ppv3-row-mid2{grid-template-columns:1fr}
  .ppv3-charcard .ppv3-cc-grid{grid-template-columns:1fr}
  .ppv3-cc-radar{order:-1}
}
/* ═══════════════════════════════════════════════════════
   contact.html — Hero 合作邮箱 + 复制按钮（替代原介绍文案）
   ═══════════════════════════════════════════════════════ */
.contact-hero-mail{
  display:flex;flex-direction:column;gap:10px;
  align-items:flex-end;       /* hero 右侧：内容靠右 */
  align-self:center;          /* grid 项垂直居中对齐标题 */
}
.contact-hero-mail .chm-label{
  display:inline-flex;align-items:center;gap:8px;
  align-self:flex-end;
  font-family:var(--cn);font-size:16px;font-weight:600;color:var(--ink-0);
  letter-spacing:.04em;
  padding:5px 14px 5px 12px;
  border-left:3px solid var(--rust-3);
  background:rgba(201,90,68,.08);
}
.contact-hero-mail .chm-row{
  display:inline-flex;align-items:stretch;gap:0;
  border:1px solid var(--line-2);background:rgba(255,255,255,.03);
  align-self:flex-end;max-width:100%;
}
.contact-hero-mail .chm-addr{
  display:flex;align-items:center;
  padding:12px 18px;
  font-family:var(--mono);font-size:15px;color:var(--ink-0);
  letter-spacing:.04em;
  border-right:1px solid var(--line-2);
  transition:color .2s;
  word-break:break-all;
}
.contact-hero-mail .chm-addr:hover{color:var(--rust-3)}
.contact-hero-mail .chm-copy{
  display:inline-flex;align-items:center;gap:7px;
  padding:12px 16px;
  font-family:var(--mono);font-size:12px;color:var(--ink-1);
  letter-spacing:.1em;
  background:transparent;border:none;cursor:pointer;
  transition:color .2s, background .2s;
  white-space:nowrap;
}
.contact-hero-mail .chm-copy:hover{color:var(--ink-0);background:var(--hover-fill)}
.contact-hero-mail .chm-copy .chm-copy-icon{font-size:14px}
.contact-hero-mail .chm-copy.is-copied{
  color:var(--green);background:rgba(90,155,106,.1);
}
/* 窄屏：subpage-h 变单列，邮箱块回到标题下方并靠左 */
@media (max-width:760px){
  .contact-hero-mail{align-items:flex-start;align-self:flex-start;margin-top:6px}
  .contact-hero-mail .chm-label{align-self:flex-start}
  .contact-hero-mail .chm-row{align-self:flex-start}
}
@media (max-width:560px){
  .contact-hero-mail{align-self:stretch}
  .contact-hero-mail .chm-row{flex-direction:column;align-self:stretch}
  .contact-hero-mail .chm-addr{border-right:none;border-bottom:1px solid var(--line-2)}
  .contact-hero-mail .chm-copy{justify-content:center}
}
/* ═══════════════════════════════════════════════════════
   个人主页 v3.2 — 头像上传 + 死亡卡简版
   ═══════════════════════════════════════════════════════ */

/* 头像支持图片显示（applyAvatar 加 has-avatar-img 时） */
.profile-page-v3 .ppv3-avatar{
  cursor:pointer;
  background-size:cover;background-position:center;
  position:relative;overflow:hidden;
  transition:filter .2s;
}
.profile-page-v3 .ppv3-avatar.has-avatar-img{
  font-size:0;  /* 有图时隐藏首字 */
  background-color:#0a0d18;
}
/* hover：浮现"换头像"提示 */
.profile-page-v3 .ppv3-avatar::after{
  content:"换头像";
  position:absolute;left:0;right:0;bottom:0;
  padding:4px 0;
  font-family:var(--cn);font-size:10px;color:#fff;
  background:rgba(201,90,68,.85);
  text-align:center;letter-spacing:.08em;
  opacity:0;transform:translateY(100%);
  transition:opacity .2s, transform .2s;
}
.profile-page-v3 .ppv3-avatar:hover::after{
  opacity:1;transform:translateY(0);
}
.profile-page-v3 .ppv3-avatar:hover{filter:brightness(1.08)}

/* 改昵称按钮（身份卡操作区第一个，主色调强调） */
.profile-page-v3 #ppv3EditNick{
  border-color:var(--pp-accent-line);color:#f0d8c8;
}
.profile-page-v3 #ppv3EditNick:hover{
  border-color:var(--pp-accent);background:var(--pp-accent-soft);color:#fff;
}
.profile-page-v3 #ppv3EditNick:disabled{
  opacity:.5;cursor:wait;
}

/* 死亡卡简版：一段描述 + 一个按钮，垂直居中 */
.ppv3-death-simple{
  display:flex;flex-direction:column;justify-content:center;
  gap:20px;flex:1;padding:8px 4px;
}
.ppv3-death-desc{
  font-family:var(--cn);font-size:14px;line-height:1.9;
  color:var(--pp-text-mid);
}
.ppv3-death-btn{
  align-self:flex-start;
  background:var(--pp-accent);border-color:var(--pp-accent);color:#fff;
}
.ppv3-death-btn:hover{
  background:var(--rust-2);border-color:var(--rust-2);
}
/* ═══════════════════════════════════════════════════════
   个人主页 v3.3 — 第一行合并大横卡（身份 + 大血条）
   ═══════════════════════════════════════════════════════ */
.profile-page-v3 .ppv3-herobar{
  background: var(--pp-card-bg);
  border: 1px solid var(--pp-card-line);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  padding: 24px 28px;
  display:flex;flex-direction:column;gap:20px;
}
.profile-page-v3 .ppv3-herobar:hover{
  border-color: var(--pp-card-line-hi);
  background: var(--pp-card-bg-hi);
}

/* 上半：左身份 + 右三数字 */
.ppv3-hb-top{
  display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
}
.ppv3-hb-id{display:flex;align-items:center;gap:18px;min-width:0}

/* 头像（沿用旧 ppv3-avatar 样式） */
.ppv3-hb-name{display:flex;flex-direction:column;gap:3px;min-width:0}
.ppv3-hb-name .ppv3-name{
  display:flex;align-items:center;gap:8px;
  font-family:var(--cn);font-weight:600;font-size:24px;color:#f0e8da;
  letter-spacing:.04em;line-height:1.2;
}
/* 改昵称小图标 */
.ppv3-nick-edit{
  flex-shrink:0;
  width:26px;height:26px;display:grid;place-items:center;
  font-size:13px;color:var(--pp-text-dim);
  background:rgba(255,255,255,.04);
  border:1px solid var(--pp-card-line);
  border-radius:50%;cursor:pointer;
  transition:all .2s;line-height:1;
}
.ppv3-nick-edit:hover{
  color:#fff;border-color:var(--pp-accent);background:var(--pp-accent-soft);
}
.ppv3-nick-edit:disabled{opacity:.4;cursor:wait}
.ppv3-hb-name .ppv3-uid{
  font-family:var(--mono);font-size:11px;color:rgba(232,196,128,.6);letter-spacing:.08em;
}
.ppv3-hb-name .ppv3-meta-row{
  display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-top:6px;
}
.ppv3-hb-name .ppv3-tag{
  padding:2px 8px;background:rgba(201,90,68,.08);border:1px solid var(--pp-accent-line);
  font-family:var(--cn);font-size:11px;
}
.ppv3-hb-name .ppv3-tag b{color:#e8d4a0;font-weight:500}
.ppv3-hb-name .ppv3-meta-dot{color:rgba(232,196,128,.3)}

/* 右：三个数字 */
.ppv3-hb-stats{
  display:flex;align-items:stretch;gap:0;
  border:1px solid var(--pp-card-line);
}
.ppv3-hb-stats article{
  display:flex;flex-direction:column;gap:3px;align-items:center;text-align:center;
  padding:10px 22px;border-right:1px solid rgba(232,230,225,.06);min-width:0;
}
.ppv3-hb-stats article:last-child{border-right:none}
.ppv3-hb-stats .num{
  font-family:var(--sans);font-weight:700;font-size:24px;color:#f0e8da;
  letter-spacing:-.01em;line-height:1.1;
}
.ppv3-hb-stats em{
  font-style:normal;font-family:var(--mono);font-size:9.5px;color:rgba(232,196,128,.55);
  letter-spacing:.12em;
}

/* 大血条 */
.ppv3-bloodbar-wrap{display:flex;flex-direction:column;gap:8px}
.ppv3-bloodbar{
  width:100%;height:22px;
  background:rgba(0,0,0,.5);
  border:1px solid var(--pp-accent-line);
  overflow:hidden;position:relative;
  box-shadow: inset 0 0 12px rgba(0,0,0,.6);
}
.ppv3-bloodbar span{
  display:block;height:100%;width:0%;
  background: linear-gradient(90deg, var(--rust-deep), var(--rust-3) 60%, #ff7a5c);
  box-shadow: 0 0 12px rgba(201,90,68,.5);
  transition:width 1s ease;
}
/* 血条上斜纹质感 */
.ppv3-bloodbar::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image: repeating-linear-gradient(115deg, transparent 0 8px, rgba(0,0,0,.18) 8px 11px);
}
.ppv3-bloodbar-meta{
  display:flex;align-items:baseline;justify-content:space-between;
  font-family:var(--mono);font-size:12px;color:rgba(232,196,128,.6);letter-spacing:.06em;
}
.ppv3-bloodbar-meta strong{
  color:#f0e8da;font-family:var(--sans);font-weight:700;font-size:15px;margin-left:4px;
}

/* 角色卡导出按钮（header 右上角） */
.ppv3-export-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:5px 12px;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:#e8d4a0;background:transparent;
  border:1px solid var(--pp-accent-line);cursor:pointer;
  transition:all .2s;
}
.ppv3-export-btn:hover{
  color:#fff;border-color:var(--pp-accent);background:var(--pp-accent-soft);
}

@media (max-width: 760px){
  .profile-page-v3 .ppv3-herobar{padding:18px}
  .ppv3-hb-top{flex-direction:column;align-items:stretch;gap:18px}
  .ppv3-hb-id{justify-content:flex-start}
  .ppv3-hb-stats{align-self:stretch}
  .ppv3-hb-stats article{flex:1;padding:10px 8px}
}
/* ═══════════════════════════════════════════════════════
   个人主页 v3.4 — 昵称溢出 / 血条 meta 居中 / 任务卡 / 背包 / 死亡横条
   ═══════════════════════════════════════════════════════ */

/* 1. 昵称过长不顶掉改名按钮：文字省略号，按钮固定不缩 */
.ppv3-hb-name{min-width:0}
.ppv3-hb-name .ppv3-name{min-width:0}
.ppv3-name-text{
  min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.ppv3-nick-edit{flex-shrink:0}

/* 2. 血条下方：等级靠左，通关进度绝对居中 */
.profile-page-v3 .ppv3-bloodbar-meta{
  display:block;position:relative;text-align:center;
  font-family:var(--mono);font-size:12px;color:rgba(232,196,128,.6);letter-spacing:.06em;
}
.ppv3-bb-level{
  position:absolute;left:0;top:0;
}
.ppv3-bb-progress{
  display:inline-block;
  font-variant-numeric:tabular-nums;
}
.ppv3-bb-level strong,
.ppv3-bb-progress strong{
  color:#f0e8da;font-family:var(--sans);font-weight:700;font-size:15px;margin-left:4px;
  font-variant-numeric:tabular-nums;
}

/* 3. 任务卡 */
.ppv3-task-rows{display:flex;flex-direction:column;gap:0;flex:1}
.ppv3-task-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding:11px 8px;margin:0 -8px;
  border-bottom:1px dashed rgba(232,230,225,.07);
  color:inherit;text-decoration:none;transition:background .15s;
}
.ppv3-task-row:hover{background:rgba(201,90,68,.06)}
.ppv3-task-row .ptr-k{
  font-family:var(--mono);font-size:10px;color:var(--pp-text-dim);
  letter-spacing:.14em;text-transform:uppercase;flex-shrink:0;
}
.ppv3-task-row .ptr-v{
  font-family:var(--cn);font-weight:500;font-size:13px;color:var(--pp-text-bright);
  text-align:right;
}
.ppv3-task-btn{
  margin-top:14px;justify-content:center;
  background:var(--pp-accent);border-color:var(--pp-accent);color:#fff;
}
.ppv3-task-btn:hover{background:var(--rust-2);border-color:var(--rust-2)}

/* 4. 我的背包（12 格） */
.profile-page-v3 .ppv3-backpack{
  background: var(--pp-card-bg);
  border: 1px solid var(--pp-card-line);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  padding:22px 26px;
  display:flex;flex-direction:column;gap:16px;
}
.profile-page-v3 .ppv3-backpack:hover{
  border-color: var(--pp-card-line-hi);
  background: var(--pp-card-bg-hi);
}
.ppv3-backpack header{
  display:flex;align-items:center;
  padding-bottom:12px;border-bottom:1px solid rgba(201,90,68,.12);
}
.ppv3-backpack header .lab{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10.5px;color:var(--pp-accent);
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;
}
.ppv3-backpack header .lab .dot{
  width:6px;height:6px;border-radius:50%;background:var(--pp-accent);
  box-shadow:0 0 8px var(--pp-accent-glow);animation:pulse 2.4s ease-in-out infinite;
}
.ppv3-backpack-grid{
  display:grid;grid-template-columns:repeat(12, minmax(0,1fr));gap:10px;
}
.ppv3-slot{
  aspect-ratio:1;
  border:1px solid var(--pp-card-line);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.012) 0 6px, transparent 6px 12px),
    rgba(0,0,0,.25);
  transition:border-color .2s, background .2s;
}
.ppv3-slot:hover{
  border-color:var(--pp-accent-line);
  background:rgba(201,90,68,.05);
}
@media (max-width:1180px){
  .ppv3-backpack-grid{grid-template-columns:repeat(6, minmax(0,1fr))}
}
@media (max-width:560px){
  .ppv3-backpack-grid{grid-template-columns:repeat(4, minmax(0,1fr))}
}

/* 5. 死亡存档（最下方一横条） */
.ppv3-death-bar{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px 28px;
  background: var(--pp-card-bg);
  border:1px solid var(--pp-accent-line);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  color:inherit;text-decoration:none;
  transition:border-color .2s, background .2s;
}
.ppv3-death-bar:hover{
  border-color:var(--pp-accent);
  background: var(--pp-card-bg-hi);
}
.ppv3-death-bar-text{
  font-family:var(--cn);font-size:15px;color:var(--pp-text-mid);letter-spacing:.04em;
}
.ppv3-death-bar-cta{
  display:inline-flex;align-items:center;gap:8px;flex-shrink:0;
  font-family:var(--cn);font-size:13px;font-weight:500;color:#f0d8c8;
  padding:9px 18px;border:1px solid var(--pp-accent-line);
}
.ppv3-death-bar:hover .ppv3-death-bar-cta{
  background:var(--pp-accent);border-color:var(--pp-accent);color:#fff;
}
@media (max-width:560px){
  .ppv3-death-bar{flex-direction:column;align-items:stretch;gap:12px;text-align:center}
  .ppv3-death-bar-cta{justify-content:center}
}
/* ═══════════════════════════════════════════════════════
   个人主页 v3.5 — 进度条动效 / 任务四块 / 死亡横条重做
   ═══════════════════════════════════════════════════════ */

/* 1. 血条填充流光动效 */
.profile-page-v3 .ppv3-bloodbar span{
  position:relative;overflow:hidden;
}
.profile-page-v3 .ppv3-bloodbar span::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(255,228,210,.55) 50%, transparent 100%);
  background-size:80px 100%;background-repeat:no-repeat;
  animation:ppv3BloodFlow 2.4s linear infinite;
}
@keyframes ppv3BloodFlow{
  from{ background-position:-80px 0; }
  to{   background-position:calc(100% + 80px) 0; }
}

/* 2. 任务版面：单行全宽 + 四块网格 */
.ppv3-row-tasks{display:block}
.ppv3-task-grid{
  display:grid;grid-template-columns:repeat(4, minmax(0,1fr));gap:12px;
}
.ppv3-task-block{
  position:relative;
  display:flex;flex-direction:column;gap:5px;
  padding:18px 16px 16px;
  border:1px solid var(--pp-card-line);
  background:rgba(0,0,0,.28);
  color:inherit;text-decoration:none;
  transition:border-color .25s, background .25s, transform .25s;
  min-width:0;
}
.ppv3-task-block::before{
  content:"";position:absolute;top:0;left:0;width:40px;height:3px;
}
.ppv3-task-block.t-main::before{background:var(--rust-3)}
.ppv3-task-block.t-side::before{background:var(--mustard)}
.ppv3-task-block.t-daily::before{background:var(--green)}
.ppv3-task-block.t-world::before{background:var(--blue)}
.ppv3-task-block:hover{
  border-color:var(--pp-card-line-hi);
  background:rgba(201,90,68,.06);
  transform:translateY(-2px);
}
.ppv3-task-block .ptb-ic{
  font-family:var(--sans);font-size:20px;line-height:1;
  color:var(--pp-text-mid);
}
.ppv3-task-block.t-main .ptb-ic{color:var(--rust-3)}
.ppv3-task-block.t-side .ptb-ic{color:var(--mustard)}
.ppv3-task-block.t-daily .ptb-ic{color:var(--green)}
.ppv3-task-block.t-world .ptb-ic{color:var(--blue)}
.ppv3-task-block .ptb-name{
  font-family:var(--mono);font-size:10px;color:var(--pp-text-dim);
  letter-spacing:.16em;text-transform:uppercase;margin-top:4px;
}
.ppv3-task-block .ptb-v{
  font-family:var(--cn);font-weight:600;font-size:17px;color:var(--pp-text-bright);
  letter-spacing:.02em;line-height:1.3;
}
.ppv3-task-block .ptb-sub{
  font-family:var(--cn);font-size:11.5px;color:var(--pp-text-dim);line-height:1.5;
}
@media (max-width:760px){
  .ppv3-task-grid{grid-template-columns:1fr 1fr}
}

/* 3. 死亡存档横条：按钮在上、描述在下，全居中，明显锈红边框 */
.ppv3-death-bar{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:22px 28px;text-align:center;
  background:rgba(26,12,10,.72);
  border:1px solid var(--rust-3);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:inherit;text-decoration:none;
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.ppv3-death-bar:hover{
  border-color:#ff7a5c;
  background:rgba(40,16,12,.82);
  box-shadow:0 0 24px rgba(201,90,68,.22);
}
.ppv3-death-bar-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--cn);font-size:14px;font-weight:600;color:#fff;
  padding:11px 26px;
  background:var(--rust-3);border:1px solid var(--rust-3);
  transition:background .2s;
}
.ppv3-death-bar:hover .ppv3-death-bar-cta{background:var(--rust-2)}
.ppv3-death-bar-text{
  font-family:var(--cn);font-size:12.5px;color:var(--pp-text-dim);letter-spacing:.04em;
}

/* ═══════════════════════════════════════════════════════
   新闻详情页 news-detail.html  +  列表卡"阅读全文"提示
   ═══════════════════════════════════════════════════════ */

/* 列表卡底部的"阅读全文 ›"提示 */
.dc-readmore{
  margin-top:auto;padding-top:8px;
  font-size:10px;letter-spacing:.14em;color:var(--ink-2);
  transition:color .2s,transform .2s;
}
.dyn-card:hover .dc-readmore{color:var(--rev);transform:translateX(2px)}
.dyn-card.kind-game:hover .dc-readmore{color:var(--mustard)}
.dyn-card.kind-legacy:hover .dc-readmore{color:var(--ink-0)}

/* ── 详情页骨架 ── */
.nd-section{padding-top:36px;padding-bottom:80px}
.nd-inner{max-width:920px}

.nd-back{
  display:inline-block;margin-bottom:22px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  color:var(--ink-1);text-decoration:none;transition:color .2s,transform .2s;
}
.nd-back:hover{color:var(--ink-0);transform:translateX(-3px)}

.nd-loading{
  padding:80px 0;text-align:center;color:var(--ink-2);
  font-size:12px;letter-spacing:.3em;
}

/* ── 文章主体 ── */
.nd-article{
  position:relative;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  padding:clamp(28px,4vw,52px) clamp(22px,4vw,56px);
}
.nd-article::before{
  content:"";position:absolute;top:0;left:0;width:64px;height:3px;
  background:var(--ink-3);
}
.nd-article.kind-company::before{background:var(--rev)}
.nd-article.kind-game::before{background:var(--mustard)}
.nd-article.kind-legacy::before{background:var(--ink-2)}

/* 头部 meta */
.nd-head{border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:26px}
.nd-meta{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:18px;
}
.nd-kind{padding:3px 9px;border:1px solid currentColor;font-weight:600}
.nd-kind.kind-company{color:var(--rev)}
.nd-kind.kind-game{color:var(--mustard)}
.nd-kind.kind-legacy{color:var(--ink-1)}
.nd-lvl{padding:3px 8px;border:1px solid currentColor;font-weight:600}
.nd-lvl.lvl-info{color:var(--blue)}
.nd-lvl.lvl-ok{color:var(--green)}
.nd-lvl.lvl-warn{color:var(--mustard)}
.nd-tag{color:var(--ink-1);padding:3px 8px;border:1px dashed var(--line-2)}
.nd-date{color:var(--ink-2);margin-left:auto}

.nd-title{
  font-family:var(--cn);font-weight:700;
  font-size:clamp(24px,3.4vw,38px);line-height:1.32;letter-spacing:.01em;
  color:var(--ink-0);
}
.nd-lead{
  margin-top:16px;
  font-family:var(--cn);font-size:clamp(14px,1.5vw,16px);line-height:1.8;
  color:var(--ink-1);
  padding-left:14px;border-left:2px solid var(--line-3);
}

/* 正文 */
.nd-body{
  font-family:var(--cn);font-size:clamp(14.5px,1.55vw,16.5px);
  line-height:2;color:var(--ink-1);
}
.nd-body p{margin:0 0 1.15em}
.nd-body p:last-child{margin-bottom:0}

.nd-foot{
  margin-top:30px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink-3);
}
.nd-foot-id{color:var(--ink-2)}

/* ── 上一篇 / 下一篇 ── */
.nd-pager{
  margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
.nd-pg-cell{
  display:flex;flex-direction:column;gap:7px;
  padding:16px 18px;min-height:78px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.02);
  text-decoration:none;transition:border-color .2s,background .2s,transform .2s;
}
.nd-pg-cell.is-empty{visibility:hidden}
.nd-pg-next{text-align:right;align-items:flex-end}
.nd-pg-cell:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.045);transform:translateY(-2px);
}
.nd-pg-dir{font-size:10px;letter-spacing:.14em;color:var(--ink-2)}
.nd-pg-cell:hover .nd-pg-dir{color:var(--rev)}
.nd-pg-title{
  font-family:var(--cn);font-size:13.5px;line-height:1.5;color:var(--ink-0);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

/* ── 相关新闻 ── */
.nd-related{margin-top:46px}
.nd-related-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink-1);
  padding-bottom:12px;margin-bottom:16px;border-bottom:1px solid var(--line);
}
.nd-related-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
.nd-rel-card{
  position:relative;display:flex;flex-direction:column;gap:9px;
  padding:18px 18px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.025);
  text-decoration:none;transition:border-color .2s,background .2s,transform .2s;
}
.nd-rel-card::before{
  content:"";position:absolute;top:0;left:0;width:34px;height:3px;background:var(--ink-3);
}
.nd-rel-card.kind-company::before{background:var(--rev)}
.nd-rel-card.kind-game::before{background:var(--mustard)}
.nd-rel-card.kind-legacy::before{background:var(--ink-2)}
.nd-rel-card:hover{
  border-color:var(--line-3);background:rgba(255,255,255,.045);transform:translateY(-2px);
}
.nd-rel-meta{
  display:flex;align-items:center;gap:8px;
  font-size:10px;letter-spacing:.12em;
}
.nd-rel-lvl{padding:2px 7px;border:1px solid currentColor;font-weight:600}
.nd-rel-lvl.lvl-info{color:var(--blue)}
.nd-rel-lvl.lvl-ok{color:var(--green)}
.nd-rel-lvl.lvl-warn{color:var(--mustard)}
.nd-rel-date{color:var(--ink-2);margin-left:auto}
.nd-rel-card h3{
  font-family:var(--cn);font-weight:500;font-size:14.5px;line-height:1.5;color:var(--ink-0);
}
.nd-rel-card p{
  font-family:var(--cn);font-size:12.5px;line-height:1.7;color:var(--ink-2);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}

/* ── 404 / 视频跳转占位 ── */
.nd-notfound{
  text-align:center;padding:56px 20px;
}
.nd-404{
  display:block;font-size:46px;font-weight:600;color:var(--ink-3);
  letter-spacing:.1em;margin-bottom:14px;
}
.nd-notfound h1{
  font-family:var(--cn);font-weight:600;font-size:22px;color:var(--ink-0);margin-bottom:10px;
}
.nd-notfound p{
  font-family:var(--cn);font-size:14px;color:var(--ink-1);line-height:1.8;
  margin-bottom:22px;
}

@media (max-width: 720px){
  .nd-pager{grid-template-columns:1fr}
  .nd-pg-next{text-align:left;align-items:flex-start}
  .nd-related-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════
   世界任务 · 单任务循环版（一条贯穿进度条 + 一次一个锚点）
   ═══════════════════════════════════════════════════════ */
.wq-card.wq-card-v2{display:block}
.wq-card-v2 .wq-desc{max-width:62ch}
.wq-card-v2 .wq-track{margin-top:30px}
/* 进度条推进时平滑过渡 */
.wq-card-v2 .wq-pbar .fill,
.wq-card-v2 .wq-pbar .head{
  transition:width .6s cubic-bezier(.22,1,.36,1), left .6s cubic-bezier(.22,1,.36,1);
}

/* 进度条下：单个任务卡 */
.wq-single{margin-top:22px}
.wq-task{
  border:1px solid var(--line-2);background:var(--bg-3);
  padding:clamp(22px,3vw,34px);
  display:flex;flex-direction:column;gap:18px;
  animation:wqTaskIn .35s cubic-bezier(.22,1,.36,1);
}
@keyframes wqTaskIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.wq-task-top{display:flex;align-items:center;justify-content:space-between;gap:14px}
.wq-task-idx{font-size:11px;letter-spacing:.18em;color:var(--ink-2);text-transform:uppercase}
.wq-task-pts{
  font-family:var(--mono);font-size:13px;color:var(--rust-3);
  letter-spacing:.06em;font-weight:500;white-space:nowrap;
}
.wq-task-pts .rare{color:var(--amber)}
.wq-task-name{
  font-family:var(--cn);font-size:clamp(19px,2.2vw,26px);
  line-height:1.5;color:var(--ink-0);
}
.wq-task-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:4px}
.wq-act{
  font-family:var(--cn);font-size:14px;letter-spacing:.04em;
  padding:14px 16px;cursor:pointer;
  border:1px solid var(--line-2);background:transparent;color:var(--ink-1);
  transition:background .2s,color .2s,border-color .2s;
}
.wq-act-done{border-color:var(--rust);color:var(--rust-3);background:var(--rust-soft)}
.wq-act-done:hover{background:var(--rust);color:var(--bone);border-color:var(--rust)}
.wq-act-fail:hover{border-color:var(--ink-1);color:var(--ink-0)}

/* 通关态 */
.wq-task-end{align-items:center;text-align:center;gap:12px;padding:clamp(30px,4vw,48px)}
.wq-task-end-mark{
  width:54px;height:54px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--green);color:var(--green);font-size:24px;border-radius:50%;
}
.wq-task-end-sub{
  font-family:var(--cn);font-size:14px;color:var(--ink-1);
  line-height:1.8;max-width:46ch;
}

/* 你本期足迹 */
.wq-mine{
  margin-top:20px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.wq-mine-line{font-family:var(--cn);font-size:13px;color:var(--ink-1);letter-spacing:.02em}
.wq-mine-line strong{color:var(--ink-0);font-weight:600;font-family:var(--mono)}
.wq-reset{
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 12px;border:1px solid var(--line-2);background:transparent;color:var(--ink-2);
  cursor:pointer;transition:border-color .2s,color .2s;
}
.wq-reset:hover{border-color:var(--ink-1);color:var(--ink-0)}

.wq-reward{
  margin-top:24px;font-family:var(--mono);font-size:11px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;line-height:1.7;
}
.wq-reward .dim{color:var(--ink-3)}

@media (max-width:560px){
  .wq-task-actions{grid-template-columns:1fr}
  .wq-mine{flex-direction:column;align-items:flex-start}
}
