/* ============================================================================
   VEYLITH: BREACHLINE — static site styles (no build step)
   ========================================================================== */
:root {
  --void: #05030a;
  --void-2: #0a0612;
  --panel: #120a20;
  --panel-2: #1a1030;
  --bone: #b8a9d0;
  --bone-dim: #6b5d85;
  --veil: #7b2fff;
  --veil-bright: #a874ff;
  --veil-glow: #c9a6ff;
  --veil-deep: #4a1a99;
  --breach: #ff2d3d;
  --breach-bright: #ff6470;
  --uv: #2f8fff;
  --uv-bright: #6cc0ff;
  --f-title: "Cinzel", Georgia, serif;
  --f-disp: "Chakra Petch", system-ui, sans-serif;
  --f-ui: "Chakra Petch", system-ui, sans-serif;
  --f-mono: "Share Tech Mono", ui-monospace, monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--void);
  color: var(--bone);
  font-family: var(--f-ui);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}
@media (hover: hover) and (pointer: fine) { body { cursor: none; } }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: rgba(123,47,255,.4); color: #fff; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--void); }
::-webkit-scrollbar-thumb { background: linear-gradient(var(--veil-deep), var(--breach)); }

/* ---- overlays ---- */
#bg { position: fixed; inset: 0; z-index: 0; display: block; }
.grain {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}
body::before { /* scanlines */
  content: ""; position: fixed; inset: 0; z-index: 60; pointer-events: none; opacity: .6;
  background: repeating-linear-gradient(to bottom, rgba(123,47,255,.03) 0 1px, transparent 1px 3px);
}
body::after { /* vignette */
  content: ""; position: fixed; inset: 0; z-index: 55; pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 48%, rgba(0,0,0,.7) 100%);
}

/* ---- custom cursor ---- */
#cursorDot, #cursorRing { position: fixed; left: 0; top: 0; z-index: 100; pointer-events: none; }
#cursorDot { width: 6px; height: 6px; margin: -3px 0 0 -3px; border-radius: 50%; background: var(--veil-bright); }
#cursorRing { width: 32px; height: 32px; margin: -16px 0 0 -16px; border: 1px solid var(--veil-bright); opacity: .7;
  transition: width .2s, height .2s, margin .2s, border-color .2s, transform .2s; }
#cursorRing i { position: absolute; background: var(--veil-bright); }
#cursorRing i:nth-child(1){ width:1px;height:5px;left:50%;top:-6px;}
#cursorRing i:nth-child(2){ width:1px;height:5px;left:50%;bottom:-6px;}
#cursorRing i:nth-child(3){ height:1px;width:5px;top:50%;left:-6px;}
#cursorRing i:nth-child(4){ height:1px;width:5px;top:50%;right:-6px;}
#cursorRing.active { width:46px;height:46px;margin:-23px 0 0 -23px; border-color: var(--breach); transform: rotate(45deg); }
#cursorRing.active i { background: var(--breach); }
@media (hover: none), (pointer: coarse) { #cursorDot,#cursorRing{ display:none; } }

/* ---- loader ---- */
#loader { position: fixed; inset: 0; z-index: 200; display: grid; place-items: center;
  background: var(--void); transition: opacity .7s ease; }
#loader.done { opacity: 0; pointer-events: none; }
.loader__in { width: min(90vw, 480px); display: flex; flex-direction: column; align-items: center; gap: 32px; }
.loader__logo { width: 176px; height: 176px; object-fit: contain; animation: veilPulse 3.4s ease-in-out infinite; }
.loader__bar-wrap { width: 100%; }
.loader__line { display: flex; justify-content: space-between; font-family: var(--f-mono);
  font-size: 11px; text-transform: uppercase; letter-spacing: .12em; margin-bottom: 8px; }
#bootText { color: var(--veil-bright); animation: breachFlicker 5s linear infinite; }
#bootText.last { color: var(--breach); }
#bootPct { color: var(--bone-dim); }
.loader__track { height: 3px; width: 100%; background: var(--panel-2); overflow: hidden; }
.loader__fill { height: 100%; width: 0; background: linear-gradient(90deg, var(--veil-deep), var(--veil), var(--breach)); transition: width .1s linear; }
.loader__audio { background: none; border: 0; cursor: pointer; font-family: var(--f-mono); font-size: 10px;
  letter-spacing: .3em; text-transform: uppercase; color: var(--bone-dim); transition: color .2s; }
.loader__audio:hover { color: var(--veil-bright); }

/* ---- nav ---- */
.nav { position: fixed; inset: 0 0 auto 0; z-index: 50; border-bottom: 1px solid transparent; transition: all .5s; }
.nav.scrolled { background: rgba(5,3,10,.85); backdrop-filter: blur(10px); border-bottom-color: rgba(123,47,255,.15); }
.nav__in { max-width: 1200px; margin: 0 auto; padding: 12px 20px; display: flex; align-items: center; justify-content: space-between; }
.nav__brand { display: flex; align-items: center; gap: 12px; }
.nav__brand img { width: 36px; height: 36px; object-fit: contain; animation: veilPulse 3.4s ease-in-out infinite; }
.nav__brand span { font-family: var(--f-title); font-weight: 700; font-size: 16px; letter-spacing: .16em; text-transform: uppercase; color: #fff; }
.nav__brand em { color: var(--veil-bright); font-style: normal; }
.nav__links { display: flex; align-items: center; gap: 4px; }
.nav__links > a { padding: 8px 16px; font-size: 14px; font-weight: 500; text-transform: uppercase; letter-spacing: .14em; color: var(--bone); transition: color .2s; position: relative; }
.nav__links > a:hover { color: #fff; }
.nav__links > a.active { color: var(--veil-glow); }
.nav__links > a.active::after { content: ""; position: absolute; left: 50%; bottom: -2px; width: 5px; height: 5px; transform: translateX(-50%) rotate(45deg); background: var(--veil); }
.audio-toggle { display: flex; align-items: center; gap: 8px; margin-left: 12px; padding-left: 16px; border: 0; border-left: 1px solid rgba(107,93,133,.3);
  background: none; cursor: pointer; font-family: var(--f-mono); font-size: 10px; letter-spacing: .25em; text-transform: uppercase; color: var(--bone-dim); transition: color .2s; }
.audio-toggle:hover { color: var(--veil-bright); }
.audio-toggle .bars { display: flex; align-items: flex-end; gap: 2px; height: 16px; }
.audio-toggle .bars i { width: 2px; height: 3px; background: currentColor; opacity: .3; transform-origin: bottom; }
.audio-toggle.on .bars i { opacity: 1; }
.audio-toggle.on .bars i:nth-child(1){ animation: bar .7s ease-in-out infinite; }
.audio-toggle.on .bars i:nth-child(2){ animation: bar .9s ease-in-out infinite; }
.audio-toggle.on .bars i:nth-child(3){ animation: bar .6s ease-in-out infinite; }
.audio-toggle.on .bars i:nth-child(4){ animation: bar 1s ease-in-out infinite; }
.nav__burger { display: none; flex-direction: column; gap: 5px; width: 36px; height: 36px; align-items: center; justify-content: center;
  background: none; border: 1px solid rgba(123,47,255,.4); cursor: pointer; clip-path: polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px); }
.nav__burger i { width: 18px; height: 1px; background: var(--veil-bright); transition: .3s; }

/* ---- buttons ---- */
.btn { position: relative; display: inline-flex; align-items: center; gap: 8px; padding: 13px 28px 13px 30px;
  border: 1px solid; font-family: var(--f-disp); font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: .18em;
  cursor: pointer; background: transparent; transition: all .3s;
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.btn::before { content: ""; position: absolute; left: 10px; top: 50%; width: 6px; height: 6px; transform: translateY(-50%) rotate(45deg); background: currentColor; opacity: .7; }
.btn--veil { border-color: rgba(123,47,255,.6); color: var(--veil-glow); background: rgba(123,47,255,.1); }
.btn--veil:hover { background: rgba(123,47,255,.2); border-color: var(--veil-bright); box-shadow: 0 0 26px rgba(123,47,255,.5); }
.btn--breach { border-color: rgba(255,45,61,.6); color: var(--breach-bright); background: rgba(255,45,61,.1); }
.btn--breach:hover { background: rgba(255,45,61,.2); border-color: var(--breach); box-shadow: 0 0 26px rgba(255,45,61,.5); }
.btn--disabled { border-color: rgba(107,93,133,.4); color: var(--bone-dim); cursor: not-allowed; }

/* ---- generic section heads ---- */
main { position: relative; z-index: 10; }
.section { max-width: 1200px; margin: 0 auto; padding: 112px 20px; }
.head { display: flex; flex-direction: column; align-items: center; text-align: center; margin-bottom: 56px; }
.eyebrow { font-family: var(--f-mono); font-size: 12px; text-transform: uppercase; letter-spacing: .4em; }
.eyebrow.veil { color: var(--veil-bright); } .eyebrow.breach { color: var(--breach); } .eyebrow.uv { color: var(--uv-bright); }
.head h2 { font-family: var(--f-title); font-size: clamp(30px, 5vw, 52px); font-weight: 700; text-transform: uppercase; color: #fff; margin-top: 12px; letter-spacing: .02em; }
.rule { display: flex; align-items: center; gap: 12px; margin-top: 20px; }
.rule i { width: 64px; height: 1px; background: linear-gradient(90deg, transparent, var(--veil)); }
.rule i:last-child { background: linear-gradient(90deg, var(--veil), transparent); }
.rule b { width: 6px; height: 6px; transform: rotate(45deg); background: var(--veil); }
.head p { max-width: 640px; margin-top: 20px; font-weight: 300; color: var(--bone); }
.glow-veil { text-shadow: 0 0 10px rgba(168,116,255,.7), 0 0 34px rgba(123,47,255,.45); }

/* ---- hero ---- */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 96px 20px 0; }
.hero__emblem { position: absolute; top: 50%; left: 50%; width: min(86vw, 620px); transform: translate(-50%, -54%); opacity: .18; animation: creep 6s ease-in-out infinite; pointer-events: none; }
.hero__in { position: relative; z-index: 2; max-width: 880px; display: flex; flex-direction: column; align-items: center; text-align: center; }
.hero__eyebrow { display: flex; align-items: center; gap: 12px; font-family: var(--f-mono); font-size: 11px; text-transform: uppercase; letter-spacing: .35em; color: var(--breach); margin-bottom: 24px; }
.pulse-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--breach); box-shadow: 0 0 10px rgba(255,45,61,.9); animation: pulse 1.6s ease-in-out infinite; }
.hero__title { font-family: var(--f-title); font-weight: 900; text-transform: uppercase; line-height: .9; color: #fff; }
.hero__title .t1 { display: block; font-size: clamp(56px, 13vw, 150px); text-shadow: 0 0 10px rgba(168,116,255,.7), 0 0 40px rgba(123,47,255,.5); }
.hero__title .t2 { display: block; font-size: clamp(22px, 5vw, 52px); letter-spacing: .3em;
  background: linear-gradient(180deg, #fff, var(--bone) 50%, var(--veil)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero__lede { max-width: 640px; margin-top: 26px; font-size: clamp(16px, 2vw, 20px); font-weight: 300; color: var(--bone); }
.hero__cta { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-top: 38px; }
.hero__telemetry { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; width: min(100%, 440px); margin-top: 60px;
  border: 1px solid rgba(255,255,255,.05); background: rgba(255,255,255,.05); font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .12em; }
.hero__telemetry > div { background: rgba(5,3,10,.6); padding: 12px; }
.hero__telemetry .k { display: block; color: var(--bone-dim); }
.hero__telemetry .v { display: block; margin-top: 4px; }
.hero__telemetry .uv { color: var(--uv-bright); } .hero__telemetry .veil { color: var(--veil-bright); } .hero__telemetry .breach { color: var(--breach-bright); }
.hero__scroll { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 8px; z-index: 2; }
.hero__scroll span { font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .3em; color: var(--bone-dim); }
.hero__scroll i { width: 1px; height: 32px; background: linear-gradient(180deg, var(--veil), transparent); animation: pulse 2s ease-in-out infinite; }

/* ---- story ---- */
.story { max-width: 1200px; margin: 0 auto; padding: 112px 20px; }
.story__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.story__poster { display: flex; justify-content: center; }
.poster-frame { position: relative; border: 1px solid rgba(123,47,255,.3); background: var(--void); padding: 8px; box-shadow: 0 0 60px -15px rgba(123,47,255,.5);
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.poster-frame img { width: min(80vw, 440px); }
.poster-frame::after { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .4;
  background: repeating-linear-gradient(to bottom, rgba(123,47,255,.05) 0 1px, transparent 1px 3px); }
.story__text .eyebrow { display: block; }
.story__text h2 { font-family: var(--f-title); font-size: clamp(26px, 4vw, 38px); color: #fff; margin-top: 12px; line-height: 1.1; }
.story__text p { margin-top: 20px; font-weight: 300; color: var(--bone); }
.story__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 40px; }
.story__stats > div { text-align: center; border: 1px solid rgba(123,47,255,.2); background: rgba(18,10,32,.6); padding: 20px 12px;
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.story__stats b { display: block; font-family: var(--f-title); font-size: clamp(22px, 3vw, 30px); color: var(--veil-glow); text-shadow: 0 0 10px rgba(168,116,255,.7); }
.story__stats span { display: block; margin-top: 4px; font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .12em; color: var(--bone-dim); }

/* ---- hierarchy / bestiary ---- */
.tier-tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; margin-bottom: 40px; }
.tier-tab { border: 1px solid rgba(255,255,255,.1); background: transparent; cursor: pointer; padding: 10px 16px;
  font-family: var(--f-disp); font-size: 12px; text-transform: uppercase; letter-spacing: .14em; color: var(--bone-dim); transition: all .3s;
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.tier-tab small { display: block; font-family: var(--f-mono); font-size: 9px; letter-spacing: .18em; opacity: .7; margin-bottom: 2px; }
.tier-tab:hover { color: var(--bone); border-color: rgba(255,255,255,.25); }
.tier-tab.active.veil { border-color: var(--veil); color: var(--veil-glow); background: rgba(255,255,255,.06); }
.tier-tab.active.breach { border-color: var(--breach); color: var(--breach-bright); background: rgba(255,255,255,.06); }
.tier-tab.active.uv { border-color: var(--uv); color: var(--uv-bright); background: rgba(255,255,255,.06); }
.tier-intro { max-width: 760px; margin: 0 auto 40px; text-align: center; }
.tier-intro .cls { font-family: var(--f-mono); font-size: 12px; text-transform: uppercase; letter-spacing: .3em; }
.tier-intro.veil .cls { color: var(--veil-bright); } .tier-intro.breach .cls { color: var(--breach-bright); } .tier-intro.uv .cls { color: var(--uv-bright); }
.tier-intro h3 { font-family: var(--f-title); font-size: clamp(26px, 4vw, 36px); text-transform: uppercase; color: #fff; margin-top: 8px; }
.tier-intro p { margin-top: 16px; font-weight: 300; color: var(--bone); }
.tier-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.beast { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; padding: 16px;
  border: 1px solid rgba(255,255,255,.1); background: rgba(18,10,32,.4); transition: all .3s; opacity: 0; transform: translateY(18px);
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.beast.in { opacity: 1; transform: translateY(0); }
.beast:hover { background: rgba(18,10,32,.7); }
.beast.veil:hover { border-color: var(--veil); } .beast.breach:hover { border-color: var(--breach); } .beast.uv:hover { border-color: var(--uv); }
.beast__img { height: 112px; width: 100%; display: grid; place-items: center; }
.beast__img img { max-height: 112px; object-fit: contain; transition: transform .5s; }
.beast:hover .beast__img img { transform: scale(1.1); }
.beast h4 { margin-top: 12px; font-family: var(--f-disp); font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.beast.veil h4 { color: var(--veil-glow); } .beast.breach h4 { color: var(--breach-bright); } .beast.uv h4 { color: var(--uv-bright); }
.beast p { margin-top: 4px; font-size: 11px; font-weight: 300; line-height: 1.35; color: var(--bone-dim); }

/* ---- arsenal ---- */
.grid-towers { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.tower { position: relative; display: flex; flex-direction: column; padding: 20px; border: 1px solid rgba(255,255,255,.1); background: rgba(18,10,32,.4); transition: all .3s;
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.tower:hover { border-color: rgba(47,143,255,.5); background: rgba(18,10,32,.7); box-shadow: 0 0 34px -10px rgba(47,143,255,.5); }
.tower__top { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; margin-bottom: 12px; }
.tower__cls { padding: 4px 8px; border: 1px solid; font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .12em;
  clip-path: polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px); }
.cls-Kinetic, .cls-Energy { color: var(--uv-bright); border-color: rgba(47,143,255,.4); }
.cls-Control { color: var(--veil-glow); border-color: rgba(123,47,255,.4); }
.cls-Support { color: var(--bone); border-color: rgba(107,93,133,.4); }
.cls-Alien { color: var(--breach-bright); border-color: rgba(255,45,61,.4); }
.tower__range { font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .12em; color: var(--bone-dim); }
.tower__img { width: 96px; height: 96px; margin: 0 auto; }
.tower__img img { width: 96px; height: 96px; object-fit: contain; filter: drop-shadow(0 6px 14px rgba(47,143,255,.35)); transition: transform .5s; }
.tower:hover .tower__img img { transform: translateY(-4px) scale(1.05); }
.tower h3 { margin-top: 12px; text-align: center; font-family: var(--f-disp); font-size: 14px; font-weight: 600; text-transform: uppercase; color: #fff; }
.tower p { margin-top: 8px; text-align: center; font-size: 11px; font-weight: 300; line-height: 1.35; color: var(--bone-dim); }

/* ---- doctrine ---- */
.grid-doctrine { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.doc { position: relative; padding: 24px; border: 1px solid rgba(255,255,255,.1); background: rgba(18,10,32,.4); transition: all .3s;
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.doc:hover { border-color: rgba(123,47,255,.5); background: rgba(18,10,32,.7); }
.doc__n { font-family: var(--f-mono); font-size: 30px; font-weight: 700; color: rgba(123,47,255,.4); transition: color .3s; }
.doc:hover .doc__n { color: var(--veil); }
.doc h3 { margin-top: 8px; font-family: var(--f-disp); font-size: 18px; font-weight: 700; text-transform: uppercase; color: #fff; }
.doc p { margin-top: 8px; font-weight: 300; font-size: 14px; color: var(--bone); }

.subhead { display: flex; align-items: center; gap: 12px; margin: 80px 0 24px; flex-wrap: wrap; }
.subhead .diamond { width: 6px; height: 6px; transform: rotate(45deg); }
.subhead .diamond.uv { background: var(--uv); } .subhead .diamond.veil { background: var(--veil); }
.subhead h3 { font-family: var(--f-disp); font-size: 18px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: #fff; }
.subhead em { font-family: var(--f-mono); font-size: 11px; font-style: normal; text-transform: uppercase; letter-spacing: .12em; color: var(--bone-dim); }

.wall-rail { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 16px; }
.wallcard { flex: 0 0 auto; width: 112px; display: flex; flex-direction: column; align-items: center; text-align: center; padding: 12px;
  border: 1px solid rgba(255,255,255,.1); background: rgba(18,10,32,.4); transition: all .3s;
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.wallcard:hover { border-color: rgba(47,143,255,.5); background: rgba(18,10,32,.7); }
.wallcard .t { font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .12em; color: var(--uv-bright); }
.wallcard img { width: 64px; height: 64px; object-fit: contain; margin: 8px 0; transition: transform .5s; }
.wallcard:hover img { transform: scale(1.1); }
.wallcard span { font-size: 10px; font-weight: 300; line-height: 1.2; color: var(--bone-dim); }

.grid-res { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.res { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 20px;
  border: 1px solid rgba(255,255,255,.1); background: rgba(18,10,32,.4); transition: all .3s;
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.res:hover { border-color: rgba(123,47,255,.5); background: rgba(18,10,32,.7); }
.res img { width: 64px; height: 64px; object-fit: contain; filter: drop-shadow(0 6px 12px rgba(123,47,255,.4)); transition: transform .5s; }
.res:hover img { transform: translateY(-4px) scale(1.1); }
.res b { margin-top: 12px; font-family: var(--f-disp); font-size: 12px; font-weight: 600; text-transform: uppercase; color: var(--veil-glow); }
.res span { margin-top: 4px; font-size: 10px; font-weight: 300; line-height: 1.3; color: var(--bone-dim); }

/* ---- enlist ---- */
.enlist { position: relative; text-align: center; padding: 64px 24px; border: 1px solid rgba(123,47,255,.25);
  background: linear-gradient(180deg, rgba(18,10,32,.7), rgba(5,3,10,.4));
  clip-path: polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px); }
.enlist__logo { width: 96px; height: 96px; object-fit: contain; margin: 0 auto; animation: veilPulse 3.4s ease-in-out infinite; }
.enlist h2 { margin-top: 24px; font-family: var(--f-title); font-size: clamp(34px, 6vw, 60px); font-weight: 900; text-transform: uppercase; color: #fff; }
.enlist p { max-width: 560px; margin: 20px auto 0; font-size: 18px; font-weight: 300; color: var(--bone); }
.enlist__cta { display: flex; flex-wrap: wrap; justify-content: center; gap: 16px; margin-top: 36px; }
.enlist__channels { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; max-width: 760px; margin: 48px auto 0; }
.enlist__channels > * { display: flex; flex-direction: column; align-items: center; padding: 16px; border: 1px solid rgba(255,255,255,.1); background: rgba(18,10,32,.4); transition: all .3s;
  clip-path: polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px); }
.enlist__channels a:hover { border-color: rgba(123,47,255,.5); background: rgba(18,10,32,.7); }
.enlist__channels .dead { opacity: .55; }
.enlist__channels b { font-family: var(--f-disp); font-size: 14px; font-weight: 600; text-transform: uppercase; color: #fff; }
.enlist__channels span { margin-top: 4px; font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .12em; color: var(--bone-dim); }

/* ---- footer ---- */
.footer { border-top: 1px solid rgba(255,255,255,.05); padding: 48px 20px; }
.footer__in { max-width: 1200px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 20px; text-align: center; }
.footer__brand { display: flex; align-items: center; gap: 12px; }
.footer__brand img { width: 36px; height: 36px; object-fit: contain; }
.footer__brand span { font-family: var(--f-title); font-weight: 700; font-size: 16px; letter-spacing: .16em; text-transform: uppercase; color: #fff; }
.footer__brand em { color: var(--veil-bright); font-style: normal; }
.footer__tag { font-weight: 300; font-size: 14px; color: var(--bone-dim); }
.footer__legal { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .12em; color: rgba(107,93,133,.7); }
.footer__legal a { color: rgba(168,116,255,.8); }
.footer__legal a:hover { color: var(--veil-bright); }

/* ---- reveal ---- */
.reveal { opacity: 0; transform: translateY(40px); filter: blur(6px); transition: opacity .9s ease, transform .9s ease, filter .9s ease; }
.reveal.in { opacity: 1; transform: none; filter: none; }

/* ---- keyframes ---- */
@keyframes veilPulse { 0%,100%{ opacity:.6; filter: drop-shadow(0 0 14px rgba(123,47,255,.5)); } 50%{ opacity:1; filter: drop-shadow(0 0 30px rgba(168,116,255,.9)); } }
@keyframes breachFlicker { 0%,44%,49%,92%,100%{opacity:1;} 47%{opacity:.25;} 94%{opacity:.4;} }
@keyframes creep { 0%,100%{ transform: translate(-50%, calc(-54% - 6px)); } 50%{ transform: translate(-50%, calc(-54% + 6px)); } }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.35;} }
@keyframes bar { 0%,100%{ transform: scaleY(.5);} 50%{ transform: scaleY(1.4);} }

/* ---- responsive ---- */
@media (max-width: 900px) {
  .tier-grid { grid-template-columns: repeat(3, 1fr); }
  .grid-towers, .grid-doctrine { grid-template-columns: repeat(2, 1fr); }
  .grid-res { grid-template-columns: repeat(3, 1fr); }
  .story__grid { grid-template-columns: 1fr; }
  .enlist__channels { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .nav__links { position: absolute; top: 60px; left: 0; right: 0; flex-direction: column; align-items: stretch; gap: 0;
    background: rgba(5,3,10,.97); backdrop-filter: blur(10px); border-bottom: 1px solid rgba(123,47,255,.15);
    max-height: 0; overflow: hidden; transition: max-height .4s ease; }
  .nav__links.open { max-height: 420px; }
  .nav__links > a { padding: 14px 22px; border-bottom: 1px solid rgba(255,255,255,.05); }
  .audio-toggle { margin: 0; padding: 14px 22px; border-left: 0; }
  .nav__burger { display: flex; }
}
@media (max-width: 560px) {
  .tier-grid { grid-template-columns: repeat(2, 1fr); }
  .grid-res { grid-template-columns: repeat(2, 1fr); }
  .hero__telemetry { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; filter: none; }
}
