

:root {
  
  --bg:        #07060f;
  --bg-2:      #0c0a1a;
  --bg-3:      #14112a;     
  --bg-4:      #1c1838;
  --text:      #ece9ff;
  --text-soft: #c4bfe6;
  --text-mute: #8c87b5;
  --line:      rgba(236,233,255,.12);
  --line-2:    rgba(236,233,255,.06);

  --accent:    #a98bff;     
  --accent-2:  #6fe0ff;     
  --gold:      #e9c45a;     
  --glow:      rgba(169,139,255,.55);

  --maxw: 1240px;
  --pad: clamp(1.1rem, 4vw, 2.4rem);
  --radius: 18px;

  --ff-display: "Oswald", "Arial Narrow", system-ui, sans-serif;
  --ff-pixel: "Press Start 2P", "Oswald", monospace;
  --ff-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --ease: cubic-bezier(.16,1,.3,1);
  --ease-out: cubic-bezier(.22,.61,.36,1);
}

body[data-dim="ice"] {
  --bg: #050f1c; --bg-2: #08182b; --bg-3: #0d2236; --bg-4: #123048;
  --text: #eaf6ff; --text-soft: #b8d8ee; --text-mute: #6f93ad;
  --accent: #76d2ff; --accent-2: #c8efff; --gold: #bfe9ff;
  --glow: rgba(118,210,255,.5);
  --line: rgba(200,239,255,.14);
}
body[data-dim="ether"] {
  --bg: #140912; --bg-2: #1d0f1a; --bg-3: #261523; --bg-4: #311b2c;
  --text: #ffeaf6; --text-soft: #e7c3d8; --text-mute: #b083a0;
  --accent: #ff97d3; --accent-2: #8fe39a; --gold: #ffd1ea;
  --glow: rgba(255,151,211,.45);
  --line: rgba(255,200,230,.14);
}
body[data-dim="limbo"] {
  --bg: #040406; --bg-2: #08080c; --bg-3: #101016; --bg-4: #181820;
  --text: #e7e7ef; --text-soft: #adadbf; --text-mute: #6c6c80;
  --accent: #9aa0b8; --accent-2: #cfd2e0; --gold: #b9bdcf;
  --glow: rgba(154,160,184,.4);
  --line: rgba(207,210,224,.12);
}
body[data-dim="mind"] {
  
  --bg: #0a1830; --bg-2: #0f2547; --bg-3: #143764; --bg-4: #1a4a82;
  --text: #f2fbff; --text-soft: #cfeaff; --text-mute: #8fb8d6;
  --accent: #3fd0ff; --accent-2: #7dff9b; --gold: #bfffe0;
  --glow: rgba(63,208,255,.55);
  --line: rgba(190,235,255,.16);
}
body[data-dim="oniric"] {
  
  --bg: #0c0820; --bg-2: #140d33; --bg-3: #1c1444; --bg-4: #261a5c;
  --text: #f1ecff; --text-soft: #cfc4f3; --text-mute: #9286c4;
  --accent: #b69bff; --accent-2: #6fe0d2; --gold: #ffd9f5;
  --glow: rgba(182,155,255,.5);
  --line: rgba(207,196,243,.15);
}
body[data-dim="infierno"] {
  
  --bg: #160806; --bg-2: #20100a; --bg-3: #2c160d; --bg-4: #3a1d12;
  --text: #ffeee2; --text-soft: #f0c4ad; --text-mute: #b8836a;
  --accent: #ff7a3c; --accent-2: #ffd24a; --gold: #ffba5a;
  --glow: rgba(255,122,60,.5);
  --line: rgba(255,196,173,.14);
}
body[data-dim="ender"] {
  
  --bg: #06060d; --bg-2: #0b0a18; --bg-3: #121026; --bg-4: #1a1736;
  --text: #eafaf6; --text-soft: #bfe6dd; --text-mute: #7fa39b;
  --accent: #56e6c8; --accent-2: #b48bff; --gold: #cfeede;
  --glow: rgba(86,230,200,.45);
  --line: rgba(191,230,221,.13);
}
body[data-dim="vacio"] {
  
  --bg: #08040c; --bg-2: #0f0716; --bg-3: #170c22; --bg-4: #221033;
  --text: #fceaff; --text-soft: #e0bdf0; --text-mute: #a079bb;
  --accent: #d56bff; --accent-2: #ff5cc8; --gold: #ffc0f2;
  --glow: rgba(213,107,255,.5);
  --line: rgba(224,189,240,.14);
}
body[data-dim="nexus"] {
  
  --bg: #060912; --bg-2: #0b1120; --bg-3: #121a30; --bg-4: #1b2745;
  --text: #eef4ff; --text-soft: #c2d2ee; --text-mute: #8094b6;
  --accent: #8fb4ff; --accent-2: #d6e4ff; --gold: #ffe6a8;
  --glow: rgba(143,180,255,.5);
  --line: rgba(194,210,238,.14);
}
body[data-dim="borde"] {
  
  --bg: #04100e; --bg-2: #071a16; --bg-3: #0c2620; --bg-4: #11362d;
  --text: #eafff7; --text-soft: #bfead9; --text-mute: #7fae9c;
  --accent: #5effc1; --accent-2: #7fe0ff; --gold: #c8ffe6;
  --glow: rgba(94,255,193,.45);
  --line: rgba(191,234,217,.14);
}
body[data-dim="gobeyond"] {
  
  --bg: #0d0a06; --bg-2: #161106; --bg-3: #201a0e; --bg-4: #2c2414;
  --text: #fff7e8; --text-soft: #ecd9b6; --text-mute: #b89f73;
  --accent: #ffd884; --accent-2: #fff3d0; --gold: #ffe6a0;
  --glow: rgba(255,216,132,.5);
  --line: rgba(236,217,182,.15);
}
body[data-dim="cap5"] {
  
  --bg: #07070f; --bg-2: #0c0c1a; --bg-3: #131330; --bg-4: #1b1b44;
  --text: #eeefff; --text-soft: #c6c8ee; --text-mute: #8688b6;
  --accent: #9aa0ff; --accent-2: #67e8ff; --gold: #d8d0ff;
  --glow: rgba(154,160,255,.45);
  --line: rgba(198,200,238,.13);
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html {
  
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  overflow-x: clip;
  font-family: var(--ff-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: clamp(15px, 1vw + 12px, 17px);
  letter-spacing: .005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; }
.pixel { image-rendering: pixelated; image-rendering: crisp-edges; }

h1, h2, h3, h4 { font-family: var(--ff-display); font-weight: 600; line-height: 1.02; text-transform: uppercase; letter-spacing: .01em; }

.cosmos {
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(60% 50% at 18% 8%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 70%),
    radial-gradient(55% 45% at 85% 18%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 72%),
    radial-gradient(80% 60% at 50% 110%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 70%),
    var(--bg);
}
.cosmos canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.grain {
  position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .045;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap { width: min(100% - 2 * var(--pad), var(--maxw)); margin-inline: auto; }
.section { padding-block: clamp(4rem, 9vw, 8rem); position: relative; }
.eyebrow {
  font-family: var(--ff-body); font-weight: 600; text-transform: uppercase;
  letter-spacing: .28em; font-size: .72rem; color: var(--accent);
  display: inline-flex; align-items: center; gap: .6rem;
}
.eyebrow::before { content: ""; width: 1.6rem; height: 1px; background: currentColor; opacity: .7; }
.section-title { font-size: clamp(2rem, 5.5vw, 4.2rem); text-wrap: balance; max-width: 20ch; }
.lead { color: var(--text-soft); font-size: clamp(1.02rem, 1.4vw, 1.22rem); max-width: 56ch; }

.btn {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .85rem 1.5rem; border-radius: 999px; font-weight: 700;
  font-family: var(--ff-body); letter-spacing: .02em; font-size: .95rem;
  border: 1px solid transparent; transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, border-color .3s;
  will-change: transform;
}
.btn svg { width: 1.15em; height: 1.15em; }
.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #0b0712; box-shadow: 0 10px 30px -10px var(--glow), inset 0 1px 0 rgba(255,255,255,.4);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 18px 45px -12px var(--glow), inset 0 1px 0 rgba(255,255,255,.5); }
.btn-ghost { border-color: var(--line); color: var(--text); background: rgba(255,255,255,.02); }
.btn-ghost:hover { border-color: var(--accent); transform: translateY(-3px); color: var(--text); }
.btn-gold { background: linear-gradient(135deg, #f6d97a, var(--gold)); color: #2a1d00; box-shadow: 0 12px 32px -12px rgba(233,196,90,.6); }
.btn-gold:hover { transform: translateY(-3px); }

.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 80;
  display: flex; align-items: center; justify-content: space-between;
  padding: .9rem var(--pad);
  transition: background .4s var(--ease), backdrop-filter .4s, border-color .4s, padding .4s;
  border-bottom: 1px solid transparent;
}
.nav.is-stuck {
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom-color: var(--line);
  padding-block: .65rem;
}
.nav-brand { display: flex; align-items: center; gap: .6rem; font-family: var(--ff-display); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; font-size: 1rem; }
.nav-brand .mark {
  width: 1.7rem; height: 1.7rem; display: grid; place-items: center; border-radius: 7px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #0b0712; font-weight: 900; font-size: .9rem;
  box-shadow: 0 0 18px -4px var(--glow);
}
.nav-brand b { color: var(--gold); }
.nav-brand .brand-mark { width: 1.9rem; height: 1.9rem; object-fit: contain; image-rendering: pixelated; filter: drop-shadow(0 0 14px var(--glow)); }
.nav-brand .brand-word { height: 1.7rem; width: auto; object-fit: contain; }
@media (max-width: 420px) { .nav-brand .brand-word { display: none; } }
.nav-links { display: flex; align-items: center; gap: 1.6rem; }
.nav-links a { font-size: .85rem; letter-spacing: .04em; color: var(--text-soft); position: relative; padding: .2rem 0; transition: color .25s; }
.nav-links a::after { content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0; background: var(--accent); transition: width .3s var(--ease); }
.nav-links a:hover { color: var(--text); } .nav-links a:hover::after { width: 100%; }
.nav-links a.is-active { color: var(--text); } .nav-links a.is-active::after { width: 100%; }
.nav-cta { display: inline-flex; gap: .6rem; align-items: center; }
.nav-toggle { display: none; width: 2.6rem; height: 2.6rem; border: 1px solid var(--line); border-radius: 10px; }
.nav-toggle span { display: block; width: 18px; height: 2px; background: var(--text); margin: 3px auto; transition: .3s; }

@media (max-width: 860px) {
  .nav-links, .nav-cta .btn-ghost { display: none; }
  .nav-toggle { display: block; }
  .nav.is-open .nav-links {
    display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0;
    background: color-mix(in srgb, var(--bg) 96%, transparent); backdrop-filter: blur(18px);
    padding: 1.4rem var(--pad) 2rem; gap: 1.2rem; border-bottom: 1px solid var(--line);
  }
  .nav.is-open .nav-links a { font-size: 1.1rem; }
}

.scroll-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 90; background: linear-gradient(90deg, var(--accent), var(--accent-2), var(--gold)); box-shadow: 0 0 12px var(--glow); }

.splash {
  position: fixed; inset: 0; z-index: 200; display: grid; place-items: center;
  background: var(--bg);
  animation: splashSafety .01s 4.5s forwards;
}
.splash.is-out { opacity: 0; pointer-events: none; transform: scale(1.04); transition: opacity .8s var(--ease), transform .8s var(--ease); }
@keyframes splashSafety { to { opacity: 0; pointer-events: none; visibility: hidden; } }
.splash-inner { text-align: center; }
.splash-word { font-family: var(--ff-display); text-transform: uppercase; font-weight: 700; letter-spacing: .14em;
  font-size: clamp(1.4rem, 5vw, 2.6rem); color: var(--text); }
.splash-word b { color: var(--gold); display: block; font-size: clamp(2.2rem, 9vw, 5rem); letter-spacing: .04em;
  background: linear-gradient(180deg, #fff6da, var(--gold) 60%, #a9802a); -webkit-background-clip: text; background-clip: text; color: transparent; }
.splash-sub { margin-top: 1rem; font-size: .7rem; letter-spacing: .4em; color: var(--accent); text-transform: uppercase; }
.splash-bar { margin: 1.6rem auto 0; width: 180px; height: 2px; background: var(--line); overflow: hidden; border-radius: 2px; }
.splash-bar i { display: block; height: 100%; width: 40%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); animation: splashLoad 1.6s var(--ease) infinite; }
@keyframes splashLoad { 0% { transform: translateX(-120%); } 100% { transform: translateX(360%); } }

.cursor { --cur: rgba(255,255,255,.92); position: fixed; inset: 0 auto auto 0; z-index: 150; pointer-events: none; opacity: 0; transition: opacity .3s; }
.cursor.is-ready { opacity: 1; }
.cursor-dot, .cursor-ring { position: fixed; top: 0; left: 0; width: 0; height: 0; }
.cursor-dot::before {
  content: ""; position: absolute; left: 0; top: 0; width: 6px; height: 6px;
  background: var(--cur); transform: translate(-50%, -50%) rotate(45deg);
  box-shadow: 0 0 9px var(--glow); transition: background .25s, box-shadow .25s;
}
.cursor-ring::before {
  content: ""; position: absolute; left: 0; top: 0; width: 28px; height: 28px;
  border: 1.5px solid var(--cur); transform: translate(-50%, -50%) rotate(45deg);
  transition: width .28s var(--ease), height .28s var(--ease), border-color .25s, border-radius .28s;
}
.cursor-ring::after {
  content: ""; position: absolute; left: 0; top: 0; width: 30px; height: 30px;
  transform: translate(-50%, -50%);
  background:
    linear-gradient(var(--cur), var(--cur)) 50% 0 / 1.5px 6px no-repeat,
    linear-gradient(var(--cur), var(--cur)) 50% 100% / 1.5px 6px no-repeat,
    linear-gradient(var(--cur), var(--cur)) 0 50% / 6px 1.5px no-repeat,
    linear-gradient(var(--cur), var(--cur)) 100% 50% / 6px 1.5px no-repeat;
  opacity: .85; transition: width .28s var(--ease), height .28s var(--ease), opacity .25s;
  animation: curSpin 7s linear infinite;
}
@keyframes curSpin { to { transform: translate(-50%, -50%) rotate(360deg); } }
.cursor.is-hot .cursor-ring::before { width: 44px; height: 44px; border-color: var(--accent); border-radius: 50%; }
.cursor.is-hot .cursor-ring::after { width: 50px; height: 50px; opacity: 1; }
.cursor.is-hot .cursor-dot::before { width: 8px; height: 8px; background: var(--accent); box-shadow: 0 0 14px var(--accent); }
.cursor.is-down .cursor-ring::after { width: 18px; height: 18px; }
@media (prefers-reduced-motion: reduce) { .cursor-ring::after { animation: none; } }
@media (hover: none), (pointer: coarse) { .cursor { display: none !important; } }

.reveal { opacity: 0; transform: translateY(34px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }

.reveal[data-split] { opacity: 1; transform: none; }
.split-word { display: inline-block; opacity: 0; transform: translateY(0.7em); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.split-word.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .split-word { opacity: 1; transform: none; }
}

.hero { position: relative; min-height: 100svh; display: grid; align-items: center; padding-top: 6rem; overflow: hidden; }
.hero-mesh {
  position: absolute; inset: -20%; z-index: -1; pointer-events: none;
  background:
    radial-gradient(38% 38% at 28% 32%, color-mix(in srgb, var(--accent) 60%, transparent), transparent 70%),
    radial-gradient(34% 34% at 74% 60%, color-mix(in srgb, var(--accent-2) 55%, transparent), transparent 72%),
    radial-gradient(40% 40% at 55% 88%, color-mix(in srgb, var(--gold) 28%, transparent), transparent 70%);
  filter: blur(70px) saturate(135%); opacity: .8;
  animation: meshDrift 26s ease-in-out infinite;
}
@keyframes meshDrift {
  0%,100% { transform: translate3d(0,0,0) scale(1); }
  33% { transform: translate3d(3%, -2%, 0) scale(1.12); }
  66% { transform: translate3d(-3%, 2%, 0) scale(1.06); }
}
.hero-inner { width: min(100% - 2*var(--pad), var(--maxw)); margin-inline: auto; text-align: center; position: relative; z-index: 2; }
.hero-meta { display: inline-flex; align-items: center; gap: .55rem; font-size: .72rem; letter-spacing: .26em; text-transform: uppercase; color: var(--text-soft);
  border: 1px solid var(--line); padding: .45rem 1rem; border-radius: 999px; background: rgba(255,255,255,.03); margin-bottom: 2rem; }
.hero-meta .dot { width: 7px; height: 7px; border-radius: 50%; background: #57e08a; box-shadow: 0 0 10px #57e08a; animation: pulse 2.4s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
@media (prefers-reduced-motion: reduce) { .hero-meta .dot { animation: none; } }

.wordmark { line-height: .92; margin-bottom: 1.4rem; }
.wordmark .mc {
  display: block; font-family: var(--ff-pixel); font-size: clamp(.85rem, 2.6vw, 1.5rem); letter-spacing: .12em;
  color: #dfe6ef; text-transform: uppercase;
  text-shadow: 0 3px 0 #5b6675, 0 4px 6px rgba(0,0,0,.5); margin-bottom: clamp(.7rem,2vw,1.2rem);
}
.wordmark .bte {
  display: block; font-family: var(--ff-pixel); font-size: clamp(1.7rem, 8.2vw, 6.4rem); letter-spacing: .02em;
  text-transform: uppercase; line-height: 1;
  background: linear-gradient(180deg, #fff4cf 0%, #f4cf6a 42%, #e9b53e 60%, #8a601c 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  filter: drop-shadow(0 4px 0 #3a2a08) drop-shadow(0 7px 10px rgba(0,0,0,.55));
}
.wordmark .bte .edge { display: inline-block; }
.hero-logo { width: min(92%, 760px); margin: 0 auto 1.4rem; display:block; filter: drop-shadow(0 12px 34px rgba(0,0,0,.55)); animation: logoIn 1s var(--ease) both; }
@keyframes logoIn { from { opacity:0; transform: translateY(22px) scale(.96); } to { opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .hero-logo { animation: none; } }

.upd-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
@media (max-width:820px){ .upd-grid{ grid-template-columns:1fr; } }
.upd-card { border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background: color-mix(in srgb,var(--bg-3) 55%, transparent); transition: transform .45s var(--ease), border-color .35s, box-shadow .45s; display:flex; flex-direction:column; }
.upd-card:hover { transform:translateY(-6px); border-color:var(--accent); box-shadow:0 30px 60px -28px var(--glow); }
.upd-banner { position:relative; aspect-ratio:16/9; overflow:hidden; background:var(--bg-2); }
.upd-banner img { width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.upd-card:hover .upd-banner img { transform:scale(1.05); }
.upd-badge { position:absolute; top:1rem; left:1rem; z-index:2; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; padding:.42rem .8rem; border-radius:999px; backdrop-filter:blur(6px); display:inline-flex; align-items:center; gap:.45rem; background:rgba(0,0,0,.5); }
.upd-badge::before { content:""; width:7px; height:7px; border-radius:50%; background:currentColor; box-shadow:0 0 8px currentColor; }
.upd-badge.now { color:#6ff0a0; border:1px solid rgba(111,240,160,.4); }
.upd-badge.next { color:var(--gold); border:1px solid color-mix(in srgb,var(--gold) 40%,transparent); }
.upd-badge.now::before { animation: pulse 2s infinite; }
.upd-body { padding:1.4rem 1.5rem 1.6rem; display:flex; flex-direction:column; gap:.5rem; flex:1; }
.upd-body h3 { font-size:1.5rem; }
.upd-body p { color:var(--text-soft); font-size:.92rem; }
.upd-body .btn { align-self:flex-start; margin-top:.6rem; }

.hero-slogan { font-family: var(--ff-display); letter-spacing: .42em; text-transform: uppercase; font-size: clamp(.7rem, 1.8vw, 1.05rem);
  color: var(--accent-2); margin-bottom: 1.6rem; }
.hero-desc { color: var(--text-soft); font-size: clamp(1.02rem, 1.5vw, 1.28rem); max-width: 50ch; margin: 0 auto 2.2rem; }
.hero-actions { display: flex; gap: .9rem; justify-content: center; flex-wrap: wrap; }
.hero-tags { display: flex; gap: 1.4rem; justify-content: center; flex-wrap: wrap; margin-top: 2.6rem; color: var(--text-mute); font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; }
.hero-tags span { display: inline-flex; align-items: center; gap: .5rem; }
.hero-tags span::before { content: "◆"; color: var(--accent); font-size: .6em; }
.scroll-cue { position: absolute; bottom: 1.6rem; left: 50%; transform: translateX(-50%); z-index: 3; color: var(--text-mute); font-size: .68rem; letter-spacing: .28em; text-transform: uppercase; display: grid; justify-items: center; gap: .5rem; }
.scroll-cue i { width: 1px; height: 34px; background: linear-gradient(var(--accent), transparent); animation: cueDrop 2s var(--ease) infinite; }
@keyframes cueDrop { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 51% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

.dhero { position: relative; min-height: 92svh; display: grid; align-items: end; overflow: hidden; }
.dhero-bg { position: absolute; inset: 0; z-index: -1; }
.dhero-bg img { width: 100%; height: 100%; object-fit: cover; }
.dhero-bg::after { content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, color-mix(in srgb,var(--bg) 55%, transparent) 0%, transparent 30%, color-mix(in srgb,var(--bg) 60%, transparent) 65%, var(--bg) 100%); }
.dhero-inner { width: min(100% - 2*var(--pad), var(--maxw)); margin-inline: auto; padding-bottom: clamp(3rem, 7vw, 6rem); position: relative; z-index: 2; }
.dhero-chapter { display: inline-flex; gap: .8rem; align-items: center; font-size: .74rem; letter-spacing: .26em; text-transform: uppercase; color: var(--accent); margin-bottom: 1.2rem; }
.dhero-title { font-size: clamp(2.8rem, 12vw, 9rem); line-height: .9; letter-spacing: .01em;
  text-shadow: 0 8px 40px rgba(0,0,0,.6); }
.dhero-tag { font-family: var(--ff-display); letter-spacing: .3em; text-transform: uppercase; color: var(--accent-2); font-size: clamp(.8rem,2vw,1.1rem); margin-top: .6rem; }
.dhero-sub { color: var(--text-soft); max-width: 52ch; margin-top: 1.4rem; font-size: clamp(1rem,1.4vw,1.2rem); }
.dhero-stats { display: flex; gap: 2.2rem; margin-top: 2rem; flex-wrap: wrap; }
.dhero-stats .st b { font-family: var(--ff-display); font-size: 2rem; color: var(--text); display: block; }
.dhero-stats .st span { font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--text-mute); }

.marquee { overflow: hidden; border-block: 1px solid var(--line); padding-block: 1.2rem; background: color-mix(in srgb, var(--bg-2) 60%, transparent); }
.marquee-track { display: flex; gap: 2.5rem; width: max-content; animation: marquee 28s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-track span { font-family: var(--ff-display); text-transform: uppercase; font-size: clamp(1.2rem, 3vw, 2.2rem); letter-spacing: .04em; color: var(--text-soft); display: inline-flex; align-items: center; gap: 2.5rem; }
.marquee-track span::after { content: "✦"; color: var(--accent); }
@keyframes marquee { to { transform: translateX(-50%); } }

.split2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
@media (max-width: 820px) { .split2 { grid-template-columns: 1fr; } }
.split2.rev .s2-media { order: -1; }
.s2-media { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); box-shadow: 0 30px 60px -30px rgba(0,0,0,.7); }
.s2-media img { width: 100%; aspect-ratio: 16/10; object-fit: cover; transition: transform 1.4s var(--ease); }
.s2-media:hover img { transform: scale(1.06); }
.s2-media .frame-tag { position: absolute; left: 1rem; bottom: 1rem; font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text); background: rgba(0,0,0,.45); backdrop-filter: blur(6px); padding: .4rem .8rem; border-radius: 999px; border: 1px solid var(--line); }

.pain { display: grid; gap: 1rem; margin-top: 2rem; }
.pain li { list-style: none; display: flex; gap: 1rem; align-items: flex-start; color: var(--text-soft); }
.pain li b { color: var(--accent); font-family: var(--ff-display); font-size: 1.2rem; }

.dim-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }
@media (max-width: 720px) { .dim-grid { grid-template-columns: 1fr; } }
.dim-card {
  position: relative; border-radius: var(--radius); overflow: hidden; min-height: 380px;
  display: flex; flex-direction: column; justify-content: flex-end; padding: 1.6rem;
  border: 1px solid var(--line); isolation: isolate; transform-style: preserve-3d; transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .4s;
}
.dim-card img.dim-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; transition: transform 1.2s var(--ease), filter .6s; }
.dim-card::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, transparent 20%, color-mix(in srgb, var(--bg) 35%,transparent) 55%, var(--bg) 100%); }
.dim-card:hover { transform: translateY(-6px); border-color: var(--accent); box-shadow: 0 30px 60px -28px var(--glow); }
.dim-card:hover img.dim-bg { transform: scale(1.08); filter: saturate(1.15); }
.dim-card .dc-chapter { font-size: .68rem; letter-spacing: .22em; text-transform: uppercase; color: var(--accent); margin-bottom: .5rem; }
.dim-card h3 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
.dim-card .dc-tag { font-family: var(--ff-display); letter-spacing: .2em; text-transform: uppercase; color: var(--accent-2); font-size: .8rem; margin: .3rem 0 .7rem; }
.dim-card .dc-blurb { color: var(--text-soft); font-size: .92rem; max-width: 40ch; }
.dim-card .dc-mech { display:inline-flex; align-items:center; gap:.4rem; margin-top:.7rem; font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent-2); border:1px solid var(--line); padding:.3rem .6rem; border-radius:999px; background:rgba(0,0,0,.3); }
.dim-card .dc-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 1.2rem; }
.dim-card .dc-link { font-weight: 700; font-size: .85rem; letter-spacing: .04em; color: var(--text); display: inline-flex; gap: .4rem; align-items: center; }
.dim-card .dc-link svg { transition: transform .3s var(--ease); }
.dim-card:hover .dc-link svg { transform: translateX(5px); }
.state-badge { font-size: .64rem; letter-spacing: .14em; text-transform: uppercase; padding: .35rem .7rem; border-radius: 999px; border: 1px solid var(--line); color: var(--text-soft); background: rgba(0,0,0,.35); }
.state-badge.playable { color: #6ff0a0; border-color: rgba(111,240,160,.4); }
.state-badge.wip { color: var(--gold); border-color: color-mix(in srgb,var(--gold) 40%, transparent); }
.state-badge.soon { color: var(--accent-2); border-color: color-mix(in srgb,var(--accent-2) 40%, transparent); }

.prog { height: 5px; border-radius: 999px; background: var(--line); overflow: hidden; margin-top: .9rem; }
.prog i { display: block; height: 100%; width: 0; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width 1.4s var(--ease); }

.chapters { display: grid; gap: 1.2rem; }
.chap { display: grid; grid-template-columns: auto 1fr auto; gap: 1.4rem; align-items: center; padding: 1.4rem 1.6rem; border: 1px solid var(--line); border-radius: var(--radius); background: color-mix(in srgb, var(--bg-3) 50%, transparent); transition: border-color .3s, transform .3s var(--ease); }
.chap:hover { border-color: var(--accent); transform: translateX(6px); }
.chap .num { font-family: var(--ff-pixel); font-size: 1.4rem; color: var(--accent); }
.chap h4 { font-size: 1.3rem; } .chap p { color: var(--text-soft); font-size: .9rem; }
.chap .chap-state { font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-mute); text-align: right; max-width: 12ch; }
@media (max-width: 640px){ .chap { grid-template-columns: auto 1fr; } .chap .chap-state { grid-column: 2; text-align: left; } }

.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1.2rem; }
.card {
  border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: color-mix(in srgb,var(--bg-3) 55%, transparent);
  transition: transform .4s var(--ease), border-color .35s, box-shadow .4s;
}
.card:hover { transform: translateY(-5px); border-color: var(--accent); box-shadow: 0 24px 48px -26px var(--glow); }
.card-media { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--bg-2); display: grid; place-items: center; }
.card-media img { width: 100%; height: 100%; object-fit: cover; }
.card-media img.is-pixel { width: auto; max-width: 70%; max-height: 70%; object-fit: contain; }
.card-body { padding: 1.1rem 1.2rem 1.4rem; }
.card-body h4 { font-size: 1.05rem; margin-bottom: .4rem; }
.card-body p { color: var(--text-soft); font-size: .86rem; }
.card .tagline { font-size: .64rem; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: .4rem; }

.item-row { display: flex; flex-wrap: wrap; gap: .8rem; }
.chip { display: inline-flex; align-items: center; gap: .55rem; padding: .55rem .9rem; border: 1px solid var(--line); border-radius: 999px; background: color-mix(in srgb,var(--bg-3) 60%, transparent); font-size: .82rem; color: var(--text-soft); }
.chip b { color: var(--text); }
.chip .ord { font-family: var(--ff-pixel); font-size: .6rem; color: var(--accent); }

.boss { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
@media (max-width: 760px){ .boss { grid-template-columns: 1fr; } }
.boss-media { position: relative; min-height: 340px; }
.boss-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.boss-body { padding: clamp(1.6rem, 3vw, 2.8rem); display: flex; flex-direction: column; justify-content: center; background: color-mix(in srgb,var(--bg-3) 60%, transparent); }
.boss-body .b-kicker { font-size: .7rem; letter-spacing: .26em; text-transform: uppercase; color: #ff6b6b; margin-bottom: .8rem; display:inline-flex; gap:.5rem; align-items:center; }
.boss-body .b-kicker::before { content:"☠"; }
.boss-body h3 { font-size: clamp(1.8rem, 4vw, 3rem); margin-bottom: .8rem; }
.boss-body p { color: var(--text-soft); }
.boss-bar { margin-top: 1.4rem; }
.boss-bar .bb-label { font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-mute); display:flex; justify-content:space-between; margin-bottom: .4rem; }
.boss-bar .bb-track { height: 10px; border-radius: 4px; background: #2a0d0d; border: 1px solid rgba(255,80,80,.3); overflow: hidden; }
.boss-bar .bb-track i { display:block; height: 100%; width: 0; background: linear-gradient(90deg,#ff4d4d,#ff8a5b); transition: width 1.6s var(--ease); }

.callout { border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: 12px; padding: 1.2rem 1.4rem; background: color-mix(in srgb,var(--bg-3) 50%, transparent); color: var(--text-soft); }
.callout b { color: var(--accent); }
.callout.warn { border-left-color: #ff8a5b; } .callout.warn b { color: #ff8a5b; }

.steps { display: grid; gap: 1.1rem; counter-reset: step; }
.step { display: grid; grid-template-columns: auto 1fr; gap: 1.2rem; align-items: start; padding: 1.2rem 1.4rem; border: 1px solid var(--line); border-radius: var(--radius); background: color-mix(in srgb,var(--bg-3) 45%, transparent); transition: border-color .3s, transform .3s var(--ease); }
.step:hover { border-color: var(--accent); transform: translateY(-3px); }
.step::before { counter-increment: step; content: counter(step,decimal-leading-zero); font-family: var(--ff-pixel); font-size: 1.1rem; color: var(--accent); }
.step h4 { font-size: 1.1rem; margin-bottom: .35rem; } .step p { color: var(--text-soft); font-size: .9rem; }

.lore { text-align: center; max-width: 30ch; margin-inline: auto; }
.lore q { font-family: var(--ff-display); text-transform: uppercase; font-size: clamp(1.6rem, 5vw, 3.4rem); line-height: 1.05; quotes: none; }
.lore q::before, .lore q::after { content: ""; }
.lore .who { display: block; margin-top: 1.4rem; font-size: .74rem; letter-spacing: .24em; text-transform: uppercase; color: var(--accent); }

.gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: .8rem; }
.gallery a, .gallery figure { position: relative; overflow: hidden; border-radius: 12px; border: 1px solid var(--line); aspect-ratio: 4/3; }
.gallery img { width:100%; height:100%; object-fit: cover; transition: transform 1s var(--ease); }
.gallery figure:hover img { transform: scale(1.1); }

.next-dim { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 300px; display: grid; place-items: center; text-align: center; border: 1px solid var(--line); padding: 3rem var(--pad); }
.next-dim img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; }
.next-dim::after { content:""; position: absolute; inset: 0; z-index: -1; background: color-mix(in srgb,var(--bg) 70%, transparent); }
.next-dim h3 { font-size: clamp(1.6rem, 5vw, 3.2rem); }
.next-dim p { color: var(--text-soft); margin: .8rem auto 1.6rem; max-width: 44ch; }

.install { position: relative; border-radius: var(--radius); border: 1px solid var(--line); overflow: hidden; padding: clamp(2.2rem, 5vw, 4.5rem); text-align: center;
  background: radial-gradient(70% 120% at 50% 0%, color-mix(in srgb,var(--accent) 18%, transparent), transparent 70%), color-mix(in srgb,var(--bg-2) 70%, transparent); }
.install h2 { font-size: clamp(2rem, 6vw, 4rem); margin-bottom: 1rem; }
.install p { color: var(--text-soft); max-width: 46ch; margin: 0 auto 2rem; }
.dl-grid { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.dl-card { flex: 1 1 220px; max-width: 280px; border: 1px solid var(--line); border-radius: 14px; padding: 1.4rem; background: color-mix(in srgb,var(--bg-3) 55%, transparent); transition: transform .4s var(--ease), border-color .3s, box-shadow .4s; text-align: left; }
.dl-card:hover { transform: translateY(-5px); border-color: var(--accent); box-shadow: 0 24px 48px -26px var(--glow); }
.dl-card .dl-name { font-family: var(--ff-display); text-transform: uppercase; letter-spacing: .08em; font-size: 1.2rem; margin-bottom: .3rem; }
.dl-card .dl-meta { font-size: .8rem; color: var(--text-mute); margin-bottom: 1rem; }
.dl-card .btn { width: 100%; justify-content: center; }
.deps { margin-top: 2rem; font-size: .82rem; color: var(--text-mute); }
.deps b { color: var(--text-soft); }

.footer { border-top: 1px solid var(--line); padding: clamp(2.5rem,5vw,4rem) var(--pad) 2.5rem; margin-top: 3rem; }
.footer-grid { width: min(100% - 0px, var(--maxw)); margin-inline: auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 2rem; }
@media (max-width: 720px){ .footer-grid { grid-template-columns: 1fr; gap: 2.4rem; } }
.footer h5 { font-size: .74rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-mute); margin-bottom: 1rem; font-family: var(--ff-body); }
.footer a { color: var(--text-soft); display: block; padding: .25rem 0; transition: color .25s; }
.footer a:hover { color: var(--accent); }
.footer-brand .wm { font-family: var(--ff-display); text-transform: uppercase; letter-spacing: .06em; font-size: 1.3rem; }
.footer-brand .wm b { color: var(--gold); }
.footer-brand p { color: var(--text-mute); font-size: .86rem; max-width: 34ch; margin-top: .8rem; }
.footer-bottom { width: min(100%, var(--maxw)); margin: 2.5rem auto 0; padding-top: 1.5rem; border-top: 1px solid var(--line-2); display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; color: var(--text-mute); font-size: .78rem; }
.slogan-foot { color: var(--accent-2); letter-spacing: .3em; text-transform: uppercase; font-size: .72rem; }

.center { text-align: center; }
.mt-s { margin-top: 1rem; } .mt-m { margin-top: 2rem; } .mt-l { margin-top: 3.5rem; }
.muted { color: var(--text-mute); }
.tac { text-align: center; }
.maxw-prose { max-width: 60ch; }
.grid-2 { display:grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
@media (max-width:720px){ .grid-2 { grid-template-columns: 1fr; } }
.divider { height:1px; background: var(--line); border:0; margin-block: clamp(3rem,7vw,6rem); }

.beta-note { display:inline-flex; gap:.5rem; align-items:center; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); border:1px solid color-mix(in srgb,var(--gold) 35%,transparent); padding:.4rem .9rem; border-radius:999px; }
.beta-note::before{ content:"⚠"; }

.mech {
  position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line);
  padding: clamp(1.8rem, 4vw, 3.2rem); display: grid; grid-template-columns: auto 1fr; gap: clamp(1.4rem,3vw,2.4rem); align-items: center;
  background:
    radial-gradient(120% 140% at 0% 0%, color-mix(in srgb,var(--accent) 16%, transparent), transparent 60%),
    color-mix(in srgb,var(--bg-3) 60%, transparent);
}
@media (max-width: 680px){ .mech { grid-template-columns: 1fr; } }
.mech-glyph { width: clamp(64px,10vw,104px); height: clamp(64px,10vw,104px); border-radius: 20px; display:grid; place-items:center;
  background: linear-gradient(135deg, color-mix(in srgb,var(--accent) 30%, transparent), color-mix(in srgb,var(--accent-2) 18%, transparent));
  border: 1px solid var(--line); font-size: clamp(2rem,5vw,3rem); box-shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 0 30px -10px var(--glow); }
.mech-body .mk { font-size:.7rem; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); display:block; margin-bottom:.5rem; }
.mech-body h3 { font-size: clamp(1.5rem,3.6vw,2.4rem); margin-bottom:.6rem; }
.mech-body p { color: var(--text-soft); max-width: 62ch; }

.meter { margin-top: 1.2rem; max-width: 460px; }
.meter .ml { display:flex; justify-content:space-between; font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-mute); margin-bottom:.4rem; }
.meter .mt { height: 12px; border-radius: 6px; background: color-mix(in srgb,var(--bg) 60%, #000); border:1px solid var(--line); overflow:hidden; position:relative; }
.meter .mt i { display:block; height:100%; width:0; border-radius:6px; transition: width 1.8s var(--ease); background: linear-gradient(90deg, var(--accent), var(--accent-2)); }
.meter.sanity .mt i { background: linear-gradient(90deg,#7a2bd6,#ff4d6d); }
.meter.lucid .mt i  { background: linear-gradient(90deg,#3fd0ff,#7dff9b); }
.meter .stages { display:flex; gap:.4rem; flex-wrap:wrap; margin-top:.7rem; }
.meter .stages span { font-size:.6rem; letter-spacing:.06em; text-transform:uppercase; padding:.3rem .55rem; border:1px solid var(--line); border-radius:999px; color:var(--text-mute); }

.vid { position: relative; aspect-ratio: 16/9; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); background:#000; box-shadow: 0 30px 60px -30px rgba(0,0,0,.7); }
.vid video, .vid iframe.vid-frame { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; background:#000; border:0; }
.vid iframe.vid-frame { z-index:5; }
.vid-poster { position:absolute; inset:0; cursor:pointer; border:0; padding:0; width:100%; display:block; background:#000; }
.vid-poster img { width:100%; height:100%; object-fit:cover; aspect-ratio:16/9; transition: transform 1s var(--ease), filter .4s; }
.vid-poster::after { content:""; position:absolute; inset:0; background: radial-gradient(60% 60% at 50% 50%, transparent, rgba(0,0,0,.4)); }
.vid-poster:hover img { transform: scale(1.05); filter: brightness(1.08); }
.vid-play { position:absolute; inset:0; display:grid; place-items:center; z-index:2; pointer-events:none; }
.vid-play span { width:74px; height:74px; border-radius:50%; display:grid; place-items:center; color:#0b0712;
  background: linear-gradient(135deg, var(--accent), var(--accent-2)); box-shadow:0 12px 40px -8px var(--glow), inset 0 1px 0 rgba(255,255,255,.5); transition: transform .35s var(--ease); }
.vid-poster:hover + .vid-play span, .vid-play:hover span { transform: scale(1.1); }
.vid-play svg { width:26px; height:26px; margin-left:4px; }
.vid-label { position:absolute; left:1rem; bottom:1rem; z-index:3; pointer-events:none; }
.vid-label b { display:block; font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.06em; font-size:1.05rem; }
.vid-label small { font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); }
.vid.is-playing .vid-poster, .vid.is-playing .vid-play { opacity:0; pointer-events:none; transition:opacity .4s; }

.ost-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap:1.2rem; }

.boss-rail { display:grid; grid-template-columns: repeat(5, 1fr); gap:1rem; }
@media (max-width: 1000px){ .boss-rail { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .boss-rail { grid-template-columns: 1fr; } }
.boss-cell { position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); min-height:330px; display:flex; flex-direction:column; justify-content:flex-end; padding:1.2rem; transition: transform .4s var(--ease), border-color .35s, box-shadow .4s; }
.boss-cell img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition: transform 1s var(--ease); }
.boss-cell::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, transparent 25%, rgba(8,5,12,.55) 60%, rgba(8,5,12,.95) 100%); }
.boss-cell:hover { transform: translateY(-6px); border-color: var(--accent); box-shadow:0 28px 56px -28px var(--glow); }
.boss-cell:hover img { transform: scale(1.08); }
.boss-cell .bo-n { font-family:var(--ff-pixel); font-size:1rem; color:var(--accent); }
.boss-cell h4 { font-size:1.25rem; margin:.4rem 0 .2rem; }
.boss-cell .bo-dim { font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-mute); }
.boss-cell p { color:var(--text-soft); font-size:.82rem; margin-top:.5rem; }
.boss-cell .bo-ost { margin-top:.8rem; display:inline-flex; align-items:center; gap:.45rem; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.boss-cell .bo-ost svg { width:1em; height:1em; }

.lore-hero { min-height: 80svh; display:grid; place-items:center; text-align:center; padding: 7rem var(--pad) 4rem; position:relative; }
.lore-hero h1 { font-size: clamp(2.6rem, 9vw, 7rem); line-height:.95; }
.lore-hero .ls { font-family:var(--ff-display); letter-spacing:.4em; text-transform:uppercase; color:var(--accent-2); font-size:clamp(.7rem,1.8vw,1rem); margin-top:1rem; }
.prose { max-width: 70ch; margin-inline:auto; }
.prose p { margin-bottom: 1.15rem; color: var(--text-soft); font-size: clamp(1rem,1.25vw,1.16rem); }
.prose p.first::first-letter { font-family:var(--ff-display); font-size: 3.4em; line-height:.8; float:left; padding:.05em .12em 0 0; color: var(--accent); }
.lore-kicker { font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--accent); display:block; margin:3rem 0 1rem; text-align:center; }
.lore-chapter-title { text-align:center; font-size:clamp(1.8rem,5vw,3.2rem); margin-bottom:2rem; }

.fragment { border-left:2px solid var(--accent); padding:.2rem 0 .2rem 1.4rem; margin:1.4rem auto; max-width:60ch; }
.fragment p { font-style:italic; color:var(--text); font-family:var(--ff-display); text-transform:none; font-weight:400; letter-spacing:.01em; font-size:clamp(1.05rem,1.5vw,1.3rem); line-height:1.4; margin-bottom:.5rem; }
.fragment p::before { content:"“"; } .fragment p::after { content:"”"; }

.spoiler { border:1px dashed color-mix(in srgb,var(--accent) 45%, transparent); border-radius:14px; margin:1.6rem auto; max-width:72ch; overflow:hidden; background: color-mix(in srgb,var(--bg-2) 55%, transparent); }
.spoiler > summary { list-style:none; cursor:pointer; padding:1rem 1.3rem; display:flex; align-items:center; gap:.7rem; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); user-select:none; }
.spoiler > summary::-webkit-details-marker { display:none; }
.spoiler > summary::before { content:"🔒"; }
.spoiler[open] > summary::before { content:"🔓"; }
.spoiler > summary .sp-hint { margin-left:auto; color:var(--text-mute); font-size:.68rem; letter-spacing:.06em; text-transform:none; }
.spoiler .spoiler-body { padding: 0 1.4rem 1.4rem; animation: spOpen .5s var(--ease); }
.spoiler:not([open]) .spoiler-body { display:none; }
@keyframes spOpen { from { opacity:0; transform:translateY(8px);} to{opacity:1;transform:none;} }

.obf { font-family: var(--ff-pixel); color: var(--accent-2); letter-spacing:.05em; }
.pname { font-family: var(--ff-pixel); font-size:.82em; color: var(--gold); letter-spacing:.02em; padding:0 .15em; }

.dlg { margin: 1.4rem auto; max-width: 60ch; }
.dlg p { margin: 0 0 .35rem; color: var(--text); font-size: clamp(1rem,1.3vw,1.18rem); }
.dlg p.a { color: var(--text-soft); }
.dlg p.b { color: var(--accent-2); }
.poem-dialogue p { margin-bottom: .55rem; }

body[data-page="lore"] .cosmos { transition: background 1.1s var(--ease); }
body[data-page="lore"] .btn, body[data-page="lore"] .lore-kicker, body[data-page="lore"] .eyebrow { transition: color .9s var(--ease), background .9s var(--ease); }

.lore-fig { margin: clamp(2.4rem, 6vw, 5rem) auto; max-width: 1000px; }
.lore-fig figure { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); box-shadow: 0 30px 70px -34px rgba(0,0,0,.8); margin: 0; }
.lore-fig img { width: 100%; aspect-ratio: 16/8; object-fit: cover; display: block; transition: transform 1.4s var(--ease); }
.lore-fig figure:hover img { transform: scale(1.05); }
.lore-fig figcaption { margin-top: .9rem; text-align: center; font-size: .82rem; letter-spacing: .04em; color: var(--text-mute); font-style: italic; }

.scene-rule { width: 100%; max-width: 60ch; margin: clamp(2.4rem,5vw,4rem) auto; display: flex; align-items: center; justify-content: center; gap: 1rem; color: var(--accent); }
.scene-rule::before, .scene-rule::after { content: ""; height: 1px; flex: 1; background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 60%, transparent) 50%, transparent); background-size: 200% 100%; animation: ruleShimmer 5s linear infinite; }
.scene-rule::after { animation-direction: reverse; }
.scene-rule span { position: relative; font-size: .7rem; letter-spacing: .3em; text-transform: uppercase; text-align: center; }
.scene-rule span::before { content: "◆"; display: inline-block; margin-right: .6em; font-size: .8em; animation: diamondBreathe 3.4s ease-in-out infinite; }
@keyframes ruleShimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
@keyframes diamondBreathe { 0%,100% { opacity:.5; transform: rotate(0deg) scale(.85); filter: drop-shadow(0 0 0 transparent); } 50% { opacity:1; transform: rotate(180deg) scale(1.1); filter: drop-shadow(0 0 8px var(--glow)); } }

.pull { max-width: 24ch; margin: clamp(2rem,5vw,3.5rem) auto; text-align: center; font-family: var(--ff-display); text-transform: uppercase; line-height: 1.05; font-size: clamp(1.6rem, 4.5vw, 3rem); color: var(--text); text-wrap: balance; }
.pull b { color: var(--accent); }

body[data-page="lore"] .lore-hero h1 { animation: loreHeroFloat 7s ease-in-out infinite; }
@keyframes loreHeroFloat { 0%,100% { transform: translateY(0); text-shadow: 0 8px 40px rgba(0,0,0,.6); } 50% { transform: translateY(-12px); text-shadow: 0 18px 60px rgba(0,0,0,.7), 0 0 40px var(--glow); } }
body[data-page="lore"] .lore-hero .ls { animation: lsPulse 4s ease-in-out infinite; }
@keyframes lsPulse { 0%,100% { opacity:.6; letter-spacing:.4em; } 50% { opacity:1; letter-spacing:.5em; } }

body[data-page="lore"] .lore-kicker { animation: kickerGlow 3.4s ease-in-out infinite; }
@keyframes kickerGlow { 0%,100% { opacity:.55; text-shadow:none; } 50% { opacity:1; text-shadow: 0 0 16px var(--glow); } }

body[data-page="lore"] .lore-chapter-title { background-image: linear-gradient(100deg, var(--text) 30%, var(--accent) 50%, var(--accent-2) 60%, var(--text) 75%); background-size: 250% auto; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; animation: titleSheen 9s linear infinite; }
@keyframes titleSheen { 0% { background-position: 0% center; } 100% { background-position: 250% center; } }

body[data-page="lore"] .prose p.first::first-letter { animation: dropcapGlow 5s ease-in-out infinite; }
@keyframes dropcapGlow { 0%,100% { text-shadow: none; } 50% { text-shadow: 0 0 22px var(--glow); } }

body[data-page="lore"] .fragment { position: relative; }
body[data-page="lore"] .fragment::before { content:""; position:absolute; left:-2px; top:0; bottom:0; width:2px; background: var(--accent); box-shadow: 0 0 12px var(--glow); animation: edgePulse 3.2s ease-in-out infinite; }
@keyframes edgePulse { 0%,100% { opacity:.4; box-shadow: 0 0 6px transparent; } 50% { opacity:1; box-shadow: 0 0 16px var(--glow); } }

body[data-page="lore"] .dlg.is-visible p, body[data-page="lore"] .poem-dialogue.is-visible p { animation: lineIn .6s var(--ease) backwards; }
body[data-page="lore"] .dlg.is-visible p:nth-child(2) { animation-delay:.1s; }
body[data-page="lore"] .dlg.is-visible p:nth-child(3) { animation-delay:.2s; }
body[data-page="lore"] .dlg.is-visible p:nth-child(4) { animation-delay:.3s; }
@keyframes lineIn { from { opacity:0; transform: translateX(-14px); } to { opacity:1; transform:none; } }

body[data-page="lore"] .spoiler { transition: border-color .4s var(--ease), box-shadow .4s var(--ease); }
body[data-page="lore"] .spoiler:hover { border-color: var(--accent); box-shadow: 0 0 26px -6px var(--glow); }
body[data-page="lore"] .spoiler > summary::before { transition: transform .4s var(--ease); }
body[data-page="lore"] .spoiler[open] > summary::before { animation: keyTurn .5s var(--ease); }
@keyframes keyTurn { from { transform: rotate(-25deg) scale(.8); } to { transform: none; } }

body[data-page="lore"] .pull b { animation: kickerGlow 2.6s ease-in-out infinite; }

@media (prefers-reduced-motion: reduce) {
  body[data-page="lore"] .lore-hero h1,
  body[data-page="lore"] .lore-hero .ls,
  body[data-page="lore"] .lore-kicker,
  body[data-page="lore"] .lore-chapter-title,
  body[data-page="lore"] .prose p.first::first-letter,
  body[data-page="lore"] .fragment::before,
  body[data-page="lore"] .dlg.is-visible p,
  body[data-page="lore"] .poem-dialogue.is-visible p,
  body[data-page="lore"] .pull b,
  .scene-rule::before, .scene-rule::after, .scene-rule span::before { animation: none; }
  body[data-page="lore"] .lore-chapter-title { -webkit-text-fill-color: var(--text); color: var(--text); }
}

.aero { position:relative; min-height:70svh; display:grid; place-items:center; text-align:center; overflow:hidden; border-radius:var(--radius); padding:4rem var(--pad);
  background: linear-gradient(180deg,#9fe6ff 0%, #c8f5ff 35%, #e9fff2 70%, #ffffff 100%); color:#0a2a3a; }
.aero h2 { color:#063a52; font-size:clamp(1.8rem,5vw,3.4rem); text-shadow:0 1px 0 rgba(255,255,255,.6); }
.aero p { color:#0d5170; max-width:46ch; margin:1rem auto 0; }
.aero .aero-note { margin-top:1.6rem; display:inline-flex; gap:.5rem; align-items:center; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:#0a6e8c; background:rgba(255,255,255,.5); border:1px solid rgba(255,255,255,.8); padding:.5rem 1rem; border-radius:999px; backdrop-filter: blur(6px); }
.bubbles { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.bubbles i { position:absolute; bottom:-60px; border-radius:50%;
  background: radial-gradient(circle at 32% 28%, rgba(255,255,255,.95), rgba(255,255,255,.25) 45%, rgba(140,220,255,.12) 70%);
  box-shadow: inset 0 0 14px rgba(255,255,255,.7), 0 4px 18px rgba(70,170,220,.25);
  animation: rise linear infinite; }
@keyframes rise { 0%{ transform: translateY(0) scale(1); opacity:0; } 10%{opacity:.9;} 100%{ transform: translateY(-90svh) scale(1.1); opacity:0; } }
@media (prefers-reduced-motion: reduce){ .bubbles i { animation: none; opacity:.5; } }

.void { position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); min-height:60svh; display:grid; place-items:center; text-align:center; padding:4rem var(--pad); }
.void img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; opacity:.7; }
.void::after { content:""; position:absolute; inset:0; z-index:-1; background: radial-gradient(70% 70% at 50% 50%, transparent, rgba(6,6,13,.6) 70%, rgba(6,6,13,.92)); }
.void h2 { font-size:clamp(2rem,6vw,4rem); }
.void p { color:var(--text-soft); max-width:48ch; margin:1rem auto 0; }
.void .vtag { font-family:var(--ff-pixel); font-size:.7rem; color:var(--accent); letter-spacing:.1em; }

.zoomable { cursor: zoom-in; }
.lightbox { position: fixed; inset: 0; z-index: 300; display: none; align-items: center; justify-content: center;
  background: rgba(4,3,9,.92); backdrop-filter: blur(8px); padding: 4vmin; opacity: 0; transition: opacity .3s var(--ease); cursor: zoom-out; }
.lightbox.is-open { display: flex; opacity: 1; }
.lightbox img { max-width: 96vw; max-height: 86vh; border-radius: 10px; border: 1px solid var(--line);
  box-shadow: 0 40px 100px -20px rgba(0,0,0,.8); transform: scale(.96); transition: transform .35s var(--ease); }
.lightbox.is-open img { transform: scale(1); }
.lightbox.pix img { image-rendering: pixelated; }
.lightbox .lb-cap { position: absolute; bottom: 2.4vmin; left: 0; right: 0; text-align: center; color: var(--text-soft); font-size: .82rem; letter-spacing: .04em; padding-inline: 1rem; }
.lightbox .lb-close { position: absolute; top: 2.4vmin; right: 3vmin; width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid var(--line); background: rgba(255,255,255,.06); color: #fff; font-size: 1.4rem; line-height: 1; display: grid; place-items: center; cursor: pointer; }
.lightbox .lb-close:hover { background: rgba(255,255,255,.14); }

.fx { position: absolute; inset: 0; z-index: -1; pointer-events: none; overflow: hidden; }

.fx-void::before { content:""; position:absolute; inset:-20%; background: radial-gradient(40% 40% at 50% 50%, color-mix(in srgb,var(--accent) 45%, transparent), transparent 70%); filter: blur(50px); animation: voidPulse 7s ease-in-out infinite; }
@keyframes voidPulse { 0%,100%{ transform:scale(.85); opacity:.5; } 50%{ transform:scale(1.15); opacity:.95; } }

.fx-nexus::before { content:""; position:absolute; left:50%; top:50%; width:120vmin; height:120vmin; transform:translate(-50%,-50%); border-radius:50%;
  background: conic-gradient(from 0deg, transparent, color-mix(in srgb,var(--accent) 35%, transparent), transparent 30%, color-mix(in srgb,var(--accent-2) 30%, transparent), transparent 60%);
  filter: blur(40px); opacity:.55; animation: nexusSpin 28s linear infinite; }
@keyframes nexusSpin { to { transform: translate(-50%,-50%) rotate(360deg); } }

.fx-aurora::before, .fx-aurora::after { content:""; position:absolute; inset:-30% -10%; background: linear-gradient(120deg, transparent, color-mix(in srgb,var(--accent) 32%, transparent), transparent 60%); filter: blur(60px); animation: auroraDrift 16s ease-in-out infinite; }
.fx-aurora::after { background: linear-gradient(60deg, transparent, color-mix(in srgb,var(--accent-2) 28%, transparent), transparent 55%); animation-duration: 22s; animation-direction: reverse; }
@keyframes auroraDrift { 0%,100%{ transform: translateX(-6%) skewX(-6deg);} 50%{ transform: translateX(6%) skewX(6deg);} }

.fx-rays::before { content:""; position:absolute; left:50%; top:50%; width:160vmax; height:160vmax; transform:translate(-50%,-50%);
  background: repeating-conic-gradient(from 0deg, transparent 0deg, color-mix(in srgb,var(--accent) 14%, transparent) 2deg, transparent 6deg); animation: nexusSpin 60s linear infinite; opacity:.5; }

.fx-grid { background-image: linear-gradient(color-mix(in srgb,var(--accent) 12%, transparent) 1px, transparent 1px), linear-gradient(90deg, color-mix(in srgb,var(--accent) 12%, transparent) 1px, transparent 1px); background-size: 44px 44px; opacity:.5; }
.fx-grid::after { content:""; position:absolute; left:0; right:0; height:40%; top:-40%; background: linear-gradient(180deg, transparent, color-mix(in srgb,var(--accent) 22%, transparent), transparent); animation: scan 6s linear infinite; }
@keyframes scan { to { top:120%; } }
@media (prefers-reduced-motion: reduce){ .fx-void::before,.fx-nexus::before,.fx-aurora::before,.fx-aurora::after,.fx-rays::before,.fx-grid::after { animation:none; } }

.secret-portal {
  position: absolute; left: 50%; bottom: .5rem; transform: translateX(-50%);
  font-size: 1rem; line-height: 1; color: var(--accent);
  opacity: .07; text-decoration: none; cursor: default;
  transition: opacity .6s var(--ease), text-shadow .6s var(--ease), transform .6s var(--ease), letter-spacing .6s var(--ease);
  user-select: none; padding: .4rem;
}
.secret-portal:hover, .secret-portal:focus-visible {
  opacity: 1; cursor: pointer; outline: none;
  color: var(--accent-2); letter-spacing: .3em;
  text-shadow: 0 0 10px var(--glow), 0 0 26px var(--glow), 0 0 50px var(--accent);
  animation: secretWake 1.6s ease-in-out infinite;
}
@keyframes secretWake { 0%,100% { transform: translateX(-50%) scale(1) rotate(0deg); } 50% { transform: translateX(-50%) scale(1.25) rotate(180deg); } }
.footer { position: relative; }

.trail-star { position: fixed; left: 0; top: 0; z-index: 149; pointer-events: none;
  border-radius: 50%; transform: translate(-50%, -50%);
  background: radial-gradient(circle at 35% 35%, #ffffff, var(--accent) 55%, rgba(111,224,255,0) 72%);
  box-shadow: 0 0 10px var(--glow); will-change: transform, opacity;
  animation: trailFade .72s linear forwards; }
@keyframes trailFade { 0% { opacity: .95; } 100% { opacity: 0; transform: translate(-50%, -50%) scale(.25); } }
@media (hover: none), (pointer: coarse) { .trail-star { display: none !important; } }

.fx-dock { position: fixed; right: 1rem; bottom: 1rem; z-index: 200; display: flex; flex-direction: column; gap: .5rem; }
.fx-btn { display: inline-flex; align-items: center; gap: .5rem; padding: .5rem .85rem; border-radius: 999px;
  border: 1px solid var(--line); background: color-mix(in srgb, var(--bg-2) 82%, transparent); color: var(--text-soft);
  font-family: var(--ff-body); font-size: .74rem; letter-spacing: .03em; cursor: pointer; backdrop-filter: blur(8px);
  box-shadow: 0 10px 30px -16px #000; transition: border-color .25s, color .25s, transform .25s, background .25s; }
.fx-btn:hover { border-color: var(--accent); color: var(--text); transform: translateY(-2px); }
.fx-btn:focus-visible { outline: 2px solid var(--accent-2); outline-offset: 2px; }
.fx-btn .ico { font-size: 1rem; line-height: 1; }
.fx-btn.is-off { opacity: .68; }
@media (max-width: 640px) { .fx-btn .lbl { display: none; } .fx-btn { padding: .6rem; } }
.fx-vol-row { display: flex; align-items: center; gap: .45rem; padding: .4rem .7rem;
  background: color-mix(in srgb, var(--bg-2) 82%, transparent); border: 1px solid var(--line);
  border-radius: 999px; backdrop-filter: blur(8px); box-shadow: 0 10px 30px -16px #000; }
.fx-vol-ico { font-size: .95rem; line-height: 1; flex-shrink: 0; }
.fx-vol-slider { -webkit-appearance: none; appearance: none; width: 80px; height: 4px;
  border-radius: 2px; background: var(--line); outline: none; cursor: pointer; transition: background .2s; }
.fx-vol-slider::-webkit-slider-thumb { -webkit-appearance: none; width: 14px; height: 14px;
  border-radius: 50%; background: var(--accent); cursor: pointer; border: none;
  box-shadow: 0 0 6px color-mix(in srgb, var(--accent) 60%, transparent); }
.fx-vol-slider::-moz-range-thumb { width: 14px; height: 14px; border-radius: 50%;
  background: var(--accent); cursor: pointer; border: none; }
.fx-vol-slider:hover { background: color-mix(in srgb, var(--accent) 30%, var(--line)); }
@media (max-width: 640px) { .fx-vol-slider { width: 60px; } }

.dim-tip { position: fixed; z-index: 210; pointer-events: none; transform: translate(-50%, -125%);
  background: color-mix(in srgb, var(--bg-3) 94%, transparent); border: 1px solid var(--accent);
  color: var(--text); padding: .5rem .75rem; border-radius: 10px; font-size: .76rem; letter-spacing: .02em;
  box-shadow: 0 14px 34px -14px var(--glow); opacity: 0; transition: opacity .16s var(--ease); white-space: nowrap; }
.dim-tip.is-on { opacity: 1; }
.dim-tip b { color: var(--accent-2); font-family: var(--ff-display); font-size: 1rem; }
@media (hover: none), (pointer: coarse) { .dim-tip { display: none !important; } }

.global-prog { max-width: 680px; margin: 1.8rem auto 0; }
.global-prog .gp-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: .55rem; }
.global-prog .gp-head span { font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-soft); }
.global-prog .gp-head b { font-family: var(--ff-display); font-size: 1.6rem; color: var(--accent-2); text-shadow: 0 0 18px var(--glow); }
.global-prog .gp-bar { height: 10px; border-radius: 999px; background: var(--bg-3); border: 1px solid var(--line); overflow: hidden; }
.global-prog .gp-fill { height: 100%; width: 0; border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2)); box-shadow: 0 0 18px var(--glow);
  transition: width 1.6s var(--ease); }

body.reduce-anim *, body.reduce-anim *::before, body.reduce-anim *::after {
  animation-duration: .001ms !important; animation-iteration-count: 1 !important;
  transition-duration: .001ms !important; }
body.reduce-anim .trail-star { display: none !important; }
body.reduce-anim html { scroll-behavior: auto !important; }

.bit-cipher{
  font-family: var(--ff-pixel, monospace); font-size:.5rem; letter-spacing:.22em;
  color: color-mix(in srgb, var(--accent) 70%, #fff 10%);
  opacity:.16; user-select:all; -webkit-user-select:all; white-space:nowrap;
  transition: opacity .4s ease; pointer-events:auto;
}
.bit-cipher:hover{ opacity:.55; }
.bit-cipher.bc-fixed{ position:fixed; z-index:5; }
.bit-cipher.bc-top{ top:.5rem; left:50%; transform:translateX(-50%); }
.bit-cipher.bc-bl{ bottom:.45rem; left:.6rem; }
.bit-cipher.bc-br{ bottom:.45rem; right:.6rem; }
.bit-cipher.bc-foot{ display:block; text-align:center; margin-top:.9rem; opacity:.2; }
@media (max-width:640px){ .bit-cipher.bc-fixed{ display:none; } }

.emp-card{
  position:relative; width:min(90vw,380px); isolation:isolate; overflow:hidden;
  padding:1.5rem 1.4rem 1.2rem; border-radius:3px;
  font-family:"Old Standard TT", Georgia, "Times New Roman", serif; color:#2a2114; user-select:none;
  background:
    radial-gradient(70% 50% at 20% 8%, rgba(255,250,232,.8), transparent 60%),
    radial-gradient(60% 50% at 90% 95%, rgba(120,96,52,.16), transparent 60%),
    linear-gradient(160deg,#efe6cd,#e2d5b4);
  border:1px solid #b9a877;
  box-shadow:0 22px 55px -26px #000, 0 0 0 1px rgba(120,96,52,.35), 0 0 0 6px rgba(255,255,255,.18) inset;
}
.emp-card::before{ content:""; position:absolute; inset:7px; border:1.5px double #8a7448; border-radius:2px; pointer-events:none; }
.emp-card::after{ content:""; position:absolute; inset:0; pointer-events:none; mix-blend-mode:multiply; opacity:.4;
  background:
    radial-gradient(40px 30px at 14% 22%, rgba(110,80,30,.4), transparent 70%),
    radial-gradient(50px 36px at 86% 80%, rgba(90,60,20,.35), transparent 70%); }
.emp-watermark{ position:absolute; inset:0; z-index:0; display:grid; place-items:center; font-size:13rem; line-height:1;
  color:rgba(120,96,52,.08); pointer-events:none; }
.emp-card > *{ position:relative; z-index:1; }
.emp-head{ text-align:center; }
.emp-org{ font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; color:#6f5d3e; }
.emp-title{ font-family:"Playfair Display","Old Standard TT",Georgia,serif; font-weight:900; font-size:1.18rem;
  line-height:1.12; margin:.3rem 0 .2rem; color:#241c12; text-wrap:balance; }
.emp-rule{ display:block; width:60%; height:0; margin:.55rem auto .2rem; border-top:2px solid #8a7448; position:relative; }
.emp-rule::after{ content:"◈"; position:absolute; top:50%; left:50%; transform:translate(-50%,-55%); background:#e9dcbd;
  padding:0 .4rem; color:#8a7448; font-size:.7rem; }
.emp-body{ font-size:.82rem; line-height:1.5; text-align:justify; hyphens:auto; margin:.7rem 0 .6rem; color:#3a3020; }
.emp-body b{ color:#241c12; }
.emp-role{ font-size:.74rem; letter-spacing:.02em; color:#4a3c27; border-top:1px solid rgba(120,96,52,.4);
  border-bottom:1px solid rgba(120,96,52,.4); padding:.4rem 0; text-align:center; }
.emp-sign{ position:relative; margin:1.1rem auto .3rem; width:80%; min-height:64px; }
.emp-sign-img{ display:block; width:100%; max-height:80px; object-fit:contain; mix-blend-mode:multiply; margin-bottom:-6px; }
.emp-sign-line{ display:block; border-top:1.5px solid #2a2114; }
.emp-sign-label{ display:block; text-align:center; font-size:.58rem; letter-spacing:.16em; text-transform:uppercase;
  color:#6f5d3e; margin-top:.25rem; }
.emp-foot{ display:flex; justify-content:space-between; align-items:center; font-size:.58rem; letter-spacing:.08em;
  text-transform:uppercase; color:#6f5d3e; margin-top:.6rem; }
.emp-stamp{ position:absolute; right:14px; bottom:48px; z-index:2; transform:rotate(-16deg);
  font-family:"Playfair Display",Georgia,serif; font-weight:900; font-size:1.15rem; letter-spacing:.12em;
  color:#7a1f14; border:3px double #7a1f14; border-radius:6px; padding:.18rem .6rem; opacity:.82;
  text-shadow:0 0 2px rgba(122,31,20,.3); box-shadow:0 0 0 1px rgba(122,31,20,.15); }

.collect-wrap{ max-width:1100px; margin-inline:auto; padding:6.5rem var(--pad) 4rem; }
.collect-head{ text-align:center; margin-bottom:2.5rem; }
.collect-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(340px,1fr)); gap:3rem 2rem; justify-items:center; perspective:1200px; }
.collect-cell{ display:flex; flex-direction:column; align-items:center; gap:.6rem; width:100%; max-width:420px; }
.collect-date{ font-family:var(--ff-pixel); font-size:.46rem; letter-spacing:.12em; color:var(--text-mute); }
.collect-empty{ text-align:center; max-width:46ch; margin:2rem auto; color:var(--text-soft); }

.postcard{ width:min(92vw,380px); aspect-ratio:3/2; perspective:1200px; cursor:pointer; user-select:none;
  font-family:"Old Standard TT", Georgia, "Times New Roman", serif; }
.postcard:focus-visible{ outline:2px solid var(--accent-2); outline-offset:4px; }
.pc-inner{ position:relative; width:100%; height:100%; transition:transform .75s var(--ease); transform-style:preserve-3d; }
.postcard.is-flipped .pc-inner{ transform:rotateY(180deg); }
.pc-face{ position:absolute; inset:0; -webkit-backface-visibility:hidden; backface-visibility:hidden; border-radius:7px;
  overflow:hidden; color:#2a2114; border:1px solid #b9a877;
  background:linear-gradient(160deg,#efe6cd,#ddcfae);
  box-shadow:0 20px 48px -22px #000, 0 0 0 1px rgba(120,96,52,.3); }
.pc-face::after{ content:""; position:absolute; inset:0; pointer-events:none; mix-blend-mode:multiply; opacity:.35;
  background:radial-gradient(50px 36px at 12% 18%, rgba(110,80,30,.4), transparent 70%),
            radial-gradient(60px 44px at 88% 86%, rgba(90,60,20,.36), transparent 70%); }

.pc-front{ display:flex; }
.pc-photo{ width:42%; position:relative; border-right:1px solid rgba(120,96,52,.55); overflow:hidden;
  background:
    radial-gradient(circle at 30% 22%, rgba(255,250,232,.65), transparent 45%),
    radial-gradient(2px 2px at 60% 30%, #fff8, transparent 60%),
    radial-gradient(1.5px 1.5px at 30% 55%, #fff7, transparent 60%),
    radial-gradient(1.5px 1.5px at 75% 65%, #fff7, transparent 60%),
    linear-gradient(165deg, #6a5a86 0%, #8a7448 55%, #c9b58a 100%); }
.pc-photo-label{ position:absolute; left:0; right:0; bottom:0; text-align:center; font-size:.56rem; letter-spacing:.2em;
  text-transform:uppercase; background:rgba(0,0,0,.45); color:#f3ead7; padding:2px 0; }
.pc-side{ flex:1; position:relative; padding:.7rem .8rem .6rem; display:flex; flex-direction:column; }
.pc-stamp{ position:absolute; top:.5rem; right:.6rem; width:42px; height:50px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; border:2px dashed #7a1f14; color:#7a1f14; border-radius:3px;
  background:rgba(122,31,20,.06); line-height:1; }
.pc-stamp span{ font-family:"Playfair Display",serif; font-weight:900; font-size:1.05rem; }
.pc-stamp small{ font-size:.4rem; letter-spacing:.1em; margin-top:2px; }
.pc-postmark{ position:absolute; top:1.6rem; right:3.6rem; font-size:.62rem; letter-spacing:.15em; color:#5a4a2e;
  opacity:.7; transform:rotate(-8deg); border:1px solid #5a4a2e7a; border-radius:50%; padding:.25rem .35rem; }
.pc-note{ font-style:italic; font-size:.74rem; line-height:1.4; color:#3a3020; margin:.2rem 2.6rem .4rem 0; }
.pc-addr{ margin-top:auto; display:flex; flex-direction:column; gap:.5rem; width:70%; }
.pc-addr span{ border-bottom:1px solid rgba(60,48,32,.45); height:.5rem; }
.pc-sign{ position:absolute; bottom:.55rem; right:.7rem; font-style:italic; font-weight:700; font-size:.85rem; color:#241c12; }
.pc-flip-hint{ position:absolute; bottom:.45rem; left:.7rem; font-family:var(--ff-pixel); font-size:.42rem;
  letter-spacing:.12em; color:#7a6a48; opacity:.7; }

.pc-back{ transform:rotateY(180deg); display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:1.3rem 1.4rem; gap:.7rem; }
.pc-back-msg{ font-family:"Playfair Display",Georgia,serif; font-style:italic; font-size:clamp(1.05rem,3.6vw,1.45rem);
  line-height:1.3; color:#241c12; margin:0; }
.pc-back-sign{ font-style:italic; font-size:.9rem; color:#5a4a2e; margin:0; }
.pc-back-sign b{ color:#7a1f14; }
.pc-back-meta{ position:absolute; bottom:.5rem; left:0; right:0; text-align:center; font-family:var(--ff-pixel);
  font-size:.42rem; letter-spacing:.1em; color:#7a6a48; }

.cmd-collect{
  width:min(92vw,300px);
  aspect-ratio:3/4;           
  perspective:1200px;
  cursor:pointer;
  user-select:none;
  border-radius:14px;
  box-shadow:0 28px 70px -20px #000, 0 0 0 1px rgba(255,255,255,.05);
}
.cmd-collect:focus-visible{ outline:2px solid var(--accent-2); outline-offset:4px; }

.cmd-collect-inner{
  position:relative;
  width:100%; height:100%;
  transform-style:preserve-3d;
  transition:transform .8s cubic-bezier(.4,0,.2,1);
}
.cmd-collect.is-flipped .cmd-collect-inner{ transform:rotateY(180deg); }

.cmd-collect-face{
  position:absolute; inset:0;
  -webkit-backface-visibility:hidden; backface-visibility:hidden;
  border-radius:14px; overflow:hidden;
}

.cmd-collect-front{ background:#0a0a12; }
.cmd-collect-front img{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  display:block; border-radius:14px;
}

.cmd-collect-front img[src="assets/img/command.webp"]:not([complete]){
  background:radial-gradient(circle at 40% 40%, #1a1530, #07070e);
}
.cmd-collect-overlay{
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent,rgba(0,0,0,.82));
  padding:1.2rem .9rem .7rem;
  display:flex; justify-content:space-between; align-items:flex-end;
}
.cmd-collect-tag{
  font-family:var(--ff-pixel); font-size:.48rem; letter-spacing:.14em;
  color:#ff7591; background:rgba(0,0,0,.55); padding:.22rem .5rem;
  border-radius:4px; border:1px solid rgba(255,117,145,.45);
}
.cmd-collect-id{
  font-family:var(--ff-pixel); font-size:.4rem; letter-spacing:.1em;
  color:rgba(255,255,255,.4);
}
.cmd-collect-hint{
  position:absolute; top:.6rem; right:.7rem;
  font-family:var(--ff-pixel); font-size:.42rem; letter-spacing:.1em;
  color:rgba(255,255,255,.4); z-index:2;
}

.cmd-collect-back{
  transform:rotateY(180deg);
  background:linear-gradient(155deg,#0e1120,#1a1030,#0b0e1a);
  border:1px solid rgba(255,117,145,.22);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:1.5rem 1.2rem; text-align:center; color:#ece9ff; gap:.7rem;
  box-shadow:0 0 60px -12px rgba(255,117,145,.25) inset;
}
.cmd-collect-back .cmd-collect-hint{
  position:static; color:rgba(255,255,255,.28);
  font-size:.42rem; margin-top:.4rem;
}
.cmd-cb-classify{
  font-family:var(--ff-pixel); font-size:.44rem; letter-spacing:.16em; text-transform:uppercase;
  color:#ff7591; border:1px solid rgba(255,117,145,.38); padding:.22rem .7rem; border-radius:4px;
}
.cmd-cb-glyph{
  font-size:2.2rem; color:#ff7591; line-height:1;
  text-shadow:0 0 28px rgba(255,117,145,.65);
  animation:cmdGlyphPulse 2.8s ease-in-out infinite;
}
@keyframes cmdGlyphPulse{
  0%,100%{ opacity:.55; text-shadow:0 0 16px rgba(255,117,145,.35); }
  50%    { opacity:1;   text-shadow:0 0 36px rgba(255,117,145,.85); }
}
.cmd-cb-desc{
  font-family:var(--ff-body); font-size:.85rem; line-height:1.65; color:#c4bfe6; margin:0;
}
.cmd-cb-desc b{ color:#fff; }
.cmd-cb-sub{
  font-family:var(--ff-pixel); font-size:.38rem; letter-spacing:.08em;
  color:rgba(255,255,255,.28); margin:0; line-height:1.8;
}

.tcg-card{
  position:relative;
  width:min(92vw,300px);
  aspect-ratio:5/7;
  border-radius:16px;
  padding:10px;
  user-select:none;
  background:
    linear-gradient(160deg,#ff2bd6,#7a2bff 45%,#16e0ff 100%);
  box-shadow:0 26px 70px -20px #000, 0 0 0 1px rgba(255,255,255,.18),
    0 0 34px -6px rgba(255,43,214,.5);
  overflow:hidden;
  font-family:var(--ff-pixel);
}
.tcg-card:focus-visible{ outline:2px solid #16e0ff; outline-offset:4px; }

.tcg-holo{
  position:absolute; inset:0; z-index:3; pointer-events:none; border-radius:16px;
  background:linear-gradient(115deg, transparent 30%, rgba(255,255,255,.28) 45%, rgba(22,224,255,.18) 50%, transparent 62%);
  background-size:280% 280%;
  mix-blend-mode:screen; opacity:.7;
  animation:tcgHolo 5s linear infinite;
}
@keyframes tcgHolo{ 0%{ background-position:0% 0%; } 100%{ background-position:280% 280%; } }
.tcg-card:hover{ transform:translateY(-4px); }
.tcg-card:hover .tcg-holo{ animation-duration:2.2s; opacity:.95; }

.tcg-inner{
  position:relative; z-index:2;
  height:100%; display:flex; flex-direction:column; gap:7px;
  border-radius:11px; padding:9px;
  background:linear-gradient(180deg,#16121f,#241133 60%,#120a22);
  border:1px solid rgba(255,255,255,.14);
}
.tcg-head{ display:flex; align-items:center; justify-content:space-between; gap:.4rem; }
.tcg-name{
  font-family:"Press Start 2P", var(--ff-pixel);
  font-size:.52rem; line-height:1.25; color:#fff;
  text-shadow:0 0 8px #ff2bd6, 0 0 16px rgba(255,43,214,.6);
}
.tcg-hp{
  flex:none; display:inline-flex; align-items:center; gap:.3rem;
  font-size:.5rem; letter-spacing:.06em; color:#16e0ff; text-shadow:0 0 10px rgba(22,224,255,.7);
}
.tcg-hp b{ color:#fff; font-size:.75rem; }
.tcg-type{ color:#ffe14a; text-shadow:0 0 10px rgba(255,225,74,.7); font-size:.8rem; }

.tcg-art{
  position:relative; border-radius:8px; overflow:hidden;
  border:2px solid; border-image:linear-gradient(120deg,#16e0ff,#ff2bd6,#ffe14a) 1;
  background:#05060f; aspect-ratio:4/3;
  box-shadow:0 0 22px -6px rgba(22,224,255,.6) inset;
}
.tcg-art img{ width:100%; height:100%; object-fit:cover; display:block; }
.tcg-stage{
  position:absolute; left:0; bottom:0; right:0;
  font-size:.36rem; letter-spacing:.08em; color:#cfeaff;
  background:linear-gradient(transparent,rgba(0,0,0,.8)); padding:.5rem .4rem .25rem;
}
.tcg-info{ display:flex; flex-direction:column; gap:5px; }
.tcg-move{ display:flex; align-items:center; gap:.45rem; }
.tcg-move-cost{ color:#ff2bd6; font-size:.6rem; letter-spacing:.05em; text-shadow:0 0 8px rgba(255,43,214,.7); }
.tcg-move-name{ flex:1; font-size:.46rem; letter-spacing:.04em; color:#fff; }
.tcg-move-dmg{ font-family:"Press Start 2P", var(--ff-pixel); font-size:.7rem; color:#ffe14a; text-shadow:0 0 10px rgba(255,225,74,.7); }
.tcg-move-text{ margin:0; font-size:.4rem; line-height:1.6; color:#bdb4e0; letter-spacing:.02em; }
.tcg-stats{
  display:flex; justify-content:space-between; gap:.3rem; margin-top:2px;
  border-top:1px solid rgba(255,255,255,.12); padding-top:5px;
  font-size:.36rem; letter-spacing:.04em; color:#8f86b8;
}
.tcg-stats b{ color:#16e0ff; }
.tcg-foot{ margin-top:auto; display:flex; flex-direction:column; gap:3px; }
.tcg-flavor{ font-family:var(--ff-body); font-style:italic; font-size:.5rem; line-height:1.45; color:#d9d2ff; }
.tcg-meta{ font-size:.34rem; letter-spacing:.08em; color:#ff8fe6; text-shadow:0 0 8px rgba(255,43,214,.5); }

@media (prefers-reduced-motion: reduce){ .tcg-holo{ animation:none; } }

.fx-btn-reset{
  border-color: rgba(239,68,68,.5);
  color: #fca5a5;
}
.fx-btn-reset:hover{
  border-color: #ef4444;
  color: #fff;
  background: rgba(239,68,68,.18);
  transform: translateY(-2px);
}
.fx-btn-reset .ico{ font-size:1.1rem; display:inline-block; }
.fx-btn-reset:hover .ico{ animation: resetSpin .55s ease; }
@keyframes resetSpin{ to{ transform:rotate(-360deg); } }

.reset-overlay{
  position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(4px);
  display:grid; place-items:center;
  padding:1rem;
  opacity:0; transition:opacity .25s ease;
  pointer-events:none;
}
.reset-overlay.is-open{ opacity:1; pointer-events:all; }
.reset-modal{
  background: linear-gradient(145deg,#1a1a2e,#12121c);
  border:1px solid rgba(239,68,68,.4);
  border-radius:16px;
  padding:2rem 2.2rem;
  max-width:380px; width:100%;
  text-align:left;
  box-shadow:0 0 60px rgba(239,68,68,.12), 0 24px 64px rgba(0,0,0,.7);
  transform:scale(.94) translateY(12px);
  transition:transform .28s cubic-bezier(.34,1.56,.64,1);
}
.reset-overlay.is-open .reset-modal{ transform:scale(1) translateY(0); }
.reset-modal-warn{
  font-size:2.8rem; line-height:1; margin-bottom:.7rem;
  color:#f59e0b;
}
.reset-modal-title{
  font-family:var(--ff-title); font-size:1.1rem; letter-spacing:.04em;
  color:#fff; margin:0 0 .75rem;
}
.reset-modal-desc{
  font-family:var(--ff-body); font-size:.9rem; line-height:1.65;
  color:rgba(255,255,255,.65); margin:0 0 1.4rem;
}
.reset-modal-desc strong{ color:#fca5a5; font-weight:600; }
.reset-modal-btns{ display:flex; gap:.75rem; justify-content:flex-end; flex-wrap:wrap; }
.reset-btn-cancel,.reset-btn-confirm{
  border:none; border-radius:8px; padding:.55rem 1.15rem;
  font-family:var(--ff-body); font-size:.88rem; font-weight:600;
  cursor:pointer; transition:all .18s ease;
}
.reset-btn-cancel{
  background:rgba(255,255,255,.08); color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.15);
}
.reset-btn-cancel:hover{ background:rgba(255,255,255,.14); color:#fff; }
.reset-btn-confirm{
  background:#ef4444; color:#fff;
  border:1px solid transparent;
}
.reset-btn-confirm:hover{ background:#dc2626; transform:translateY(-1px); box-shadow:0 4px 16px rgba(239,68,68,.45); }
.reset-btn-confirm:active{ transform:translateY(0); }
@media(max-width:480px){
  .reset-modal{ padding:1.4rem 1.2rem; }
  .reset-modal-btns{ flex-direction:column-reverse; }
  .reset-btn-cancel,.reset-btn-confirm{ width:100%; text-align:center; }
}

.gem-collect{
  width:min(92vw,300px);
  aspect-ratio:3/4;
  perspective:1200px;
  cursor:pointer;
  user-select:none;
  border-radius:14px;
  box-shadow:0 28px 70px -20px #000, 0 0 0 1px rgba(255,255,255,.05);
}
.gem-collect:focus-visible{ outline:2px solid #bcd2ff; outline-offset:4px; }
.gem-collect-inner{
  position:relative;
  width:100%; height:100%;
  transform-style:preserve-3d;
  transition:transform .8s cubic-bezier(.4,0,.2,1);
}
.gem-collect.is-flipped .gem-collect-inner{ transform:rotateY(180deg); }
.gem-collect-face{
  position:absolute; inset:0;
  -webkit-backface-visibility:hidden; backface-visibility:hidden;
  border-radius:14px; overflow:hidden;
}
.gem-collect-front{
  background:radial-gradient(120% 100% at 50% 18%, #1b2547 0%, #0b1024 55%, #05060f 100%);
  display:flex; align-items:center; justify-content:center;
}
.gem-collect-front::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(40% 30% at 50% 30%, rgba(150,180,255,.20), transparent 70%),
    repeating-linear-gradient(0deg, transparent 0 26px, rgba(255,255,255,.012) 26px 27px);
  pointer-events:none;
}
.gem-trophy{
  position:relative; width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  perspective:760px;
}
.gem-rays{
  position:absolute; inset:0; pointer-events:none;
  background:conic-gradient(from 0deg at 50% 42%,
    rgba(180,205,255,0) 0deg, rgba(190,215,255,.16) 22deg, rgba(180,205,255,0) 44deg,
    rgba(190,215,255,.13) 90deg, rgba(180,205,255,0) 130deg,
    rgba(190,215,255,.16) 200deg, rgba(180,205,255,0) 240deg,
    rgba(190,215,255,.13) 310deg, rgba(180,205,255,0) 360deg);
  mix-blend-mode:screen; opacity:.7;
  animation:gemRays 18s linear infinite;
}
@keyframes gemRays{ to{ transform:rotate(360deg); } }
.gem-trophy-stage{
  position:relative; width:62%;
  transform-style:preserve-3d;
  animation:gemSpin 9s linear infinite;
}
@keyframes gemSpin{
  from{ transform:rotateY(0deg); }
  to{ transform:rotateY(360deg); }
}
.gem-3d{ position:relative; transform-style:preserve-3d; }
.gem-svg{
  display:block; width:100%; height:auto;
  filter:drop-shadow(0 6px 14px rgba(40,70,160,.55)) drop-shadow(0 0 22px rgba(150,190,255,.65));
  animation:gemBob 4.6s ease-in-out infinite;
}
@keyframes gemBob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
.gem-shape{ transform-origin:80px 96px; }
.gem-spark{ animation:gemSparkle 3.2s ease-in-out infinite; }
@keyframes gemSparkle{ 0%,100%{ opacity:.35; } 50%{ opacity:.9; } }
.gem-base{
  position:absolute; left:50%; bottom:-2%; transform:translateX(-50%);
  width:54%; height:11%;
  background:linear-gradient(180deg,#e9d8a0,#9c7f3e 55%,#6b521f);
  border-radius:50% 50% 22% 22%/70% 70% 30% 30%;
  box-shadow:0 5px 14px rgba(0,0,0,.5), inset 0 2px 4px rgba(255,255,255,.5);
}
.gem-shadow{
  position:absolute; left:50%; bottom:-9%; transform:translateX(-50%);
  width:60%; height:7%;
  background:radial-gradient(50% 50% at 50% 50%, rgba(0,0,0,.55), transparent 70%);
  filter:blur(3px);
  animation:gemShadow 4.6s ease-in-out infinite;
}
@keyframes gemShadow{ 0%,100%{ opacity:.6; width:60%; } 50%{ opacity:.4; width:52%; } }
.gem-collect-overlay{
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  background:linear-gradient(transparent,rgba(0,0,0,.82));
  padding:1.2rem .9rem .7rem;
  display:flex; justify-content:space-between; align-items:flex-end;
}
.gem-collect-tag{
  font-family:var(--ff-pixel); font-size:.48rem; letter-spacing:.14em;
  color:#dbe7ff; background:rgba(0,0,0,.55); padding:.22rem .5rem;
  border-radius:4px; border:1px solid rgba(190,210,255,.55);
}
.gem-collect-id{
  font-family:var(--ff-pixel); font-size:.4rem; letter-spacing:.1em;
  color:rgba(255,255,255,.42);
}
.gem-collect-hint{
  position:absolute; top:.6rem; right:.7rem; z-index:3;
  font-family:var(--ff-pixel); font-size:.42rem; letter-spacing:.1em;
  color:rgba(255,255,255,.4);
}
.gem-collect-back{
  transform:rotateY(180deg);
  background:linear-gradient(155deg,#0c1124,#161d3a,#0a0e1e);
  border:1px solid rgba(190,210,255,.22);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:1.5rem 1.2rem; text-align:center; color:#eaf0ff; gap:.7rem;
  box-shadow:0 0 60px -12px rgba(150,190,255,.3) inset;
}
.gem-collect-back .gem-collect-hint{
  position:static; color:rgba(255,255,255,.28); font-size:.42rem; margin-top:.4rem;
}
.gem-cb-classify{
  font-family:var(--ff-pixel); font-size:.44rem; letter-spacing:.16em; text-transform:uppercase;
  color:#bcd2ff;
}
.gem-cb-glyph{ font-size:1.7rem; color:#cfe0ff; text-shadow:0 0 18px rgba(160,200,255,.8); }
.gem-cb-desc{ font-size:.85rem; line-height:1.55; color:#dfe6ff; margin:0; }
.gem-cb-desc b{ color:#fff; }
.gem-cb-sub{ font-size:.64rem; letter-spacing:.04em; color:rgba(220,228,255,.55); margin:0; line-height:1.5; }
@media (prefers-reduced-motion:reduce){
  .gem-trophy-stage,.gem-svg,.gem-rays,.gem-spark,.gem-shadow{ animation:none; }
}
body.reduce-anim .gem-trophy-stage,
body.reduce-anim .gem-svg,
body.reduce-anim .gem-rays,
body.reduce-anim .gem-spark,
body.reduce-anim .gem-shadow{ animation:none; }
