/* ════════════════════════════════════════════════════════════════
   ARCFLAME FRONTIERS  ·  arcflame.gg
   Optimized for desktop & mobile. Mobile-first, fluid tokens.
════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400&family=Bebas+Neue&family=Outfit:wght@300;400;500;600&display=swap');

/* ── Tokens ── */
:root {
  --gold:        #C8A84B;
  --gold-light:  #E8C96A;
  --gold-dim:    #7A6228;
  --ember:       #D45A1A;
  --ember-bright:#F07030;
  --lucentium:   #8B6FD4;
  --luc-bright:  #B090F0;
  --ink:         #080608;
  --ink-2:       #100E12;
  --ink-3:       #18151A;
  --smoke:       #28242C;
  --text-bright: #F2EDE4;
  --text-mid:    #A89E90;
  --text-dim:    #5A5250;

  --f-display:   'Bebas Neue', sans-serif;
  --f-serif:     'Cormorant Garamond', serif;
  --f-body:      'Outfit', sans-serif;

  --nav-h: 64px;
  --max:   1520px;

  /* Fluid type helpers */
  --gap-section: clamp(72px, 10vw, 140px);
}
@media (min-width: 768px) {
  :root { --nav-h: 72px; }
}
@media (min-width: 1024px) {
  :root { --nav-h: 80px; }
}

/* ── Shared keyframes (used by logo) ── */
@keyframes markPulse {
  0%,100% { opacity:1 }
  40%     { opacity:1 }
  50%     { opacity:.82 }
  60%     { opacity:1 }
}
@keyframes octBreathe {
  0%,100% { stroke-opacity:1 }
  45%,55% { stroke-opacity:.55 }
}
@keyframes shimSweep {
  0%,5%   { transform:translateX(-16px); opacity:0 }
  20%,44% { opacity:1 }
  54%     { transform:translateX(16px);  opacity:0 }
  100%    { transform:translateX(16px);  opacity:0 }
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html {
  font-size:16px;
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
  -webkit-text-size-adjust:100%;
}
body {
  background:var(--ink);
  color:var(--text-bright);
  font-family:var(--f-body);
  overflow-x:hidden;
  line-height:1.6;
  min-height:100vh;
}
img,video,svg { display:block; max-width:100% }
img { height:auto }
a { color:inherit; text-decoration:none }
button { cursor:pointer; border:none; background:none; font:inherit; color:inherit }
ul,ol { list-style:none }
::selection { background:var(--gold); color:var(--ink) }
::-webkit-scrollbar { width:6px; height:6px }
::-webkit-scrollbar-track { background:var(--ink) }
::-webkit-scrollbar-thumb { background:var(--gold-dim); border-radius:3px }
.sr-only {
  position:absolute; width:1px; height:1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap;
}

/* ── Container ── */
.wrap {
  width:100%; max-width:var(--max);
  margin:0 auto;
  padding:0 clamp(20px, 5vw, 80px);
}

/* ══════════════════════════ LOADER ══════════════════════════ */
.loader {
  position:fixed; inset:0; z-index:9999;
  background:var(--ink);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:24px;
  transition:opacity .7s ease, visibility .7s ease;
}
.loader.out { opacity:0; visibility:hidden }
.loader__title {
  font-family:var(--f-display);
  font-size:clamp(36px, 6vw, 64px);
  letter-spacing:.15em; color:var(--text-bright);
}
.loader__title em { color:var(--gold); font-style:normal }
.loader__bar {
  width:min(220px, 60vw); height:1px;
  background:rgba(200,168,75,.2); position:relative; overflow:hidden;
}
.loader__fill {
  position:absolute; top:0; left:0; height:100%;
  background:var(--gold); width:0;
  animation:lfill 1s ease forwards;
}
@keyframes lfill { 0%{width:0} 70%{width:85%} 100%{width:100%} }
.loader__label {
  font-size:9px; font-weight:400; letter-spacing:.28em;
  text-transform:uppercase; color:var(--text-dim);
}

/* ══════════════════════════ NOISE ══════════════════════════ */
body::before {
  content:'';
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  opacity:1;
  mix-blend-mode:overlay;
}
@media (max-width: 768px) {
  body::before { opacity:.5 }
}

/* ══════════════════════════ NAVIGATION ══════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  height:var(--nav-h);
  transition:background .4s ease, border-color .4s ease, backdrop-filter .4s ease;
  border-bottom:1px solid transparent;
}
.nav.solid {
  background:rgba(8,6,8,.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom-color:rgba(200,168,75,.12);
}
.nav__inner {
  height:100%;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(16px, 4vw, 64px);
  gap:16px;
}
.nav__logo {
  display:flex; align-items:center; gap:12px;
  font-family:var(--f-display); letter-spacing:.08em;
  color:var(--text-bright);
  font-size:clamp(17px, 2vw, 22px);
  min-width:0;
}
.nav__logo-icon {
  width:clamp(30px, 4vw, 38px);
  height:clamp(30px, 4vw, 38px);
  flex-shrink:0;
}
.nav__logo > div { line-height:1.1 }
.nav__logo-sub {
  display:block;
  font-family:var(--f-body); font-size:9px; font-weight:500;
  letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold); margin-top:3px;
  white-space:nowrap;
}
@media (max-width: 520px) {
  .nav__logo-sub { display:none }
}
.nav__links {
  display:flex; align-items:center; gap:clamp(20px, 3vw, 40px);
}
.nav__link {
  font-family:var(--f-body); font-size:11px; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--text-mid); transition:color .2s;
  position:relative;
  padding:8px 0;
}
.nav__link:hover { color:var(--text-bright) }
.nav__link::after {
  content:''; position:absolute; left:0; right:0; bottom:2px;
  height:1px; background:var(--gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s ease;
}
.nav__link:hover::after { transform:scaleX(1) }
.nav__cta {
  font-family:var(--f-body); font-size:11px; font-weight:600;
  letter-spacing:.15em; text-transform:uppercase;
  padding:11px 24px;
  border:1px solid var(--gold); color:var(--gold);
  transition:all .3s;
  white-space:nowrap;
}
.nav__cta:hover { background:var(--gold); color:var(--ink) }

.nav__burger {
  display:none;
  flex-direction:column; gap:5px;
  padding:10px;
  margin-right:-10px; /* extend hit area */
}
.nav__burger span {
  display:block; width:24px; height:1.5px;
  background:var(--text-bright); transition:.3s;
  transform-origin:center;
}

@media (max-width: 960px) {
  .nav__links, .nav__cta { display:none }
  .nav__burger { display:flex }
}

/* Mobile overlay */
.nav__mobile {
  position:fixed; inset:0; z-index:800;
  background:rgba(8,6,8,.98);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:24px;
  opacity:0; pointer-events:none; transition:opacity .35s ease;
  padding:var(--nav-h) 24px 40px;
}
.nav__mobile.open { opacity:1; pointer-events:all }
.nav__mobile .nav__link {
  font-size:22px; letter-spacing:.12em;
  color:var(--text-bright);
  padding:10px 0;
}
.nav__mobile .nav__link::after { display:none }
.nav__mobile .btn { margin-top:16px }

/* ══════════════════════════ HERO ══════════════════════════ */
.hero {
  position:relative; width:100%;
  min-height:100svh; min-height:100vh;
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden;
  padding-top:var(--nav-h);
}

.hero__bg {
  position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(8,6,8,.85) 0%, rgba(8,6,8,.4) 55%, rgba(8,6,8,.15) 100%),
    linear-gradient(to top,   rgba(8,6,8,.95) 0%, rgba(8,6,8,.35) 45%, transparent 75%),
    url('../Assets/hero-keyart.jpg') center top / cover no-repeat;
  will-change:transform;
}
@media (max-width: 768px) {
  .hero__bg {
    background:
      linear-gradient(to bottom, rgba(8,6,8,.5) 0%, rgba(8,6,8,.35) 40%, rgba(8,6,8,.95) 100%),
      url('../Assets/hero-keyart.jpg') center top / cover no-repeat;
  }
}

/* Cinematic grain (lightweight) */
.hero__bg::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg, transparent, transparent 4px, rgba(0,0,0,.035) 4px, rgba(0,0,0,.035) 5px);
  mix-blend-mode:multiply;
}

.hero__content {
  position:relative; z-index:2;
  padding:clamp(32px, 6vw, 100px) clamp(20px, 6vw, 100px) clamp(80px, 10vh, 140px);
  max-width:980px;
  width:100%;
}

.hero__eyebrow {
  font-family:var(--f-body); font-size:clamp(9px, 1.2vw, 11px);
  font-weight:500; letter-spacing:.32em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:20px;
  display:flex; align-items:center; gap:14px;
}
.hero__eyebrow::before {
  content:''; width:clamp(20px, 4vw, 36px); height:1px;
  background:var(--gold); flex-shrink:0;
}

.hero__logo-wrap { margin:0 0 12px; padding:0; font-size:0 }
.hero__logo-shimmer-wrap { position:relative; display:inline-block }
.hero__logo-img {
  display:block;
  width:clamp(260px, 55vw, 720px);
  height:auto;
  opacity:0; transform:translateY(20px);
  animation:
    logoReveal .9s cubic-bezier(.16,1,.3,1) .3s forwards,
    logoShimmer 12s ease-in-out 1.8s infinite;
}
@keyframes logoReveal { to { opacity:1; transform:translateY(0) } }
@keyframes logoShimmer {
  0%,3%    { filter:brightness(1) drop-shadow(0 0 0 rgba(255,248,200,0)) }
  8%       { filter:brightness(1.35) drop-shadow(0 0 8px rgba(255,248,200,.35)) }
  14%,20%  { filter:brightness(1) drop-shadow(0 0 0 rgba(255,248,200,0)) }
  25%      { filter:brightness(1.3) drop-shadow(0 0 6px rgba(255,248,200,.25)) }
  31%,100% { filter:brightness(1) drop-shadow(0 0 0 rgba(255,248,200,0)) }
}
@media (prefers-reduced-motion:reduce) {
  .hero__logo-img { animation:none; opacity:1; transform:none; filter:none }
}

.hero__sub {
  font-family:var(--f-serif);
  font-size:clamp(15px, 2vw, 24px);
  font-weight:300; font-style:italic;
  color:var(--text-mid); letter-spacing:.06em;
  margin-bottom:clamp(20px, 3vh, 32px);
}
.hero__desc {
  font-size:clamp(14px, 1.4vw, 17px);
  font-weight:300; color:var(--text-mid);
  line-height:1.8;
  max-width:540px;
  margin-bottom:clamp(28px, 4vh, 48px);
}
.hero__actions {
  display:flex; align-items:center;
  gap:12px; flex-wrap:wrap;
}

/* Scroll indicator — hide on mobile */
.hero__scroll {
  position:absolute; bottom:24px; left:50%;
  transform:translateX(-50%);
  z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  opacity:.55;
}
.hero__scroll span {
  font-size:9px; font-weight:500; letter-spacing:.28em;
  text-transform:uppercase; color:var(--text-dim);
}
.hero__scroll-line {
  width:1px; height:40px;
  background:linear-gradient(to bottom, var(--gold), transparent);
  animation:scrollpulse 2s ease infinite;
}
@keyframes scrollpulse { 0%,100%{opacity:.5} 50%{opacity:1} }
@media (max-width: 768px) { .hero__scroll { display:none } }

/* Stats — kept on mobile as horizontal strip */
.hero__stats {
  position:absolute; right:clamp(20px, 5vw, 80px);
  bottom:clamp(80px, 10vh, 140px);
  z-index:2;
  display:flex; flex-direction:column; gap:1px; align-items:flex-end;
}
.hero__stat {
  display:flex; align-items:baseline; gap:10px;
  padding:14px 20px;
  background:rgba(8,6,8,.72);
  border-left:2px solid var(--gold);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.hero__stat-num {
  font-family:var(--f-display);
  font-size:clamp(28px, 4vw, 52px);
  color:var(--gold); line-height:1;
}
.hero__stat-label {
  font-size:10px; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--text-dim);
}

/* Mobile: stats become a horizontal strip below the content */
@media (max-width: 900px) {
  .hero__stats {
    position:relative; right:auto; bottom:auto;
    flex-direction:row;
    width:100%;
    margin-top:0;
    border-top:1px solid rgba(200,168,75,.15);
    border-bottom:1px solid rgba(200,168,75,.15);
    gap:0;
  }
  .hero__stat {
    flex:1; justify-content:center;
    padding:16px 8px;
    background:rgba(8,6,8,.5);
    border-left:none;
    border-right:1px solid rgba(200,168,75,.1);
    flex-direction:column; align-items:center; gap:4px;
    text-align:center;
  }
  .hero__stat:last-child { border-right:none }
  .hero__stat-num { font-size:clamp(26px, 7vw, 36px) }
  .hero__stat-label { font-size:8.5px; letter-spacing:.18em }
}

/* ══════════════════════════ BUTTONS ══════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--f-body);
  font-size:clamp(10px, 1.2vw, 11px);
  font-weight:600; letter-spacing:.18em;
  text-transform:uppercase;
  padding:14px 30px;
  transition:all .3s;
  border:none;
  position:relative; overflow:hidden;
  min-height:44px;
  white-space:nowrap;
}
.btn-gold { background:var(--gold); color:var(--ink) }
.btn-gold:hover {
  background:var(--gold-light);
  box-shadow:0 0 40px rgba(200,168,75,.4);
  transform:translateY(-1px);
}
.btn-outline {
  background:transparent; color:var(--text-bright);
  border:1px solid rgba(242,237,228,.28);
}
.btn-outline:hover { border-color:var(--gold); color:var(--gold) }
.btn-ghost {
  background:transparent; color:var(--gold);
  border:1px solid rgba(200,168,75,.4);
}
.btn-ghost:hover { background:rgba(200,168,75,.1); border-color:var(--gold) }

/* ══════════════════════════ DIVIDERS + LABELS ══════════════════════════ */
.divider {
  display:flex; align-items:center; gap:20px;
  padding:0 clamp(20px, 6vw, 100px); margin:0;
}
.divider__line {
  flex:1; height:1px;
  background:linear-gradient(to right, transparent, rgba(200,168,75,.25), transparent);
}
.divider__icon {
  color:var(--gold-dim); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase;
  font-family:var(--f-body); font-weight:500;
  white-space:nowrap;
}
.eyebrow {
  font-family:var(--f-body); font-size:10px; font-weight:500;
  letter-spacing:.3em; text-transform:uppercase;
  color:var(--gold);
  display:flex; align-items:center; gap:14px; margin-bottom:16px;
}
.eyebrow::before {
  content:''; width:28px; height:1px;
  background:var(--gold); flex-shrink:0;
}

/* ══════════════════════════ THE GAME ══════════════════════════ */
.about {
  position:relative; overflow:hidden;
  padding:var(--gap-section) 0;
}
.about__bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 100% 50%, rgba(139,111,212,.06) 0%, transparent 60%),
    radial-gradient(ellipse 80% 60% at 0% 50%, rgba(200,168,75,.04) 0%, transparent 60%),
    var(--ink-2);
}
.about__inner {
  position:relative; z-index:1;
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:center;
}
@media (min-width: 1024px) {
  .about__inner { grid-template-columns:1fr 1.1fr }
}

.about__heading {
  font-family:var(--f-display);
  font-size:clamp(40px, 7vw, 80px);
  line-height:.95; letter-spacing:.04em; text-transform:uppercase;
  color:var(--text-bright); margin-bottom:24px;
}
.about__heading .accent {
  display:block;
  background:linear-gradient(135deg, var(--gold-light), var(--gold), var(--gold-dim));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.about__body {
  font-size:clamp(14px, 1.4vw, 17px);
  font-weight:300; color:var(--text-mid);
  line-height:1.85; margin-bottom:18px;
  text-wrap:pretty;
}
.about__quote {
  font-family:var(--f-serif);
  font-size:clamp(17px, 2vw, 24px);
  font-style:italic; color:var(--text-mid);
  border-left:2px solid var(--gold);
  padding-left:20px;
  margin:24px 0;
  line-height:1.6;
}
.about__tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:24px }
.tag {
  font-size:9px; font-weight:500; letter-spacing:.18em;
  text-transform:uppercase; color:var(--text-dim);
  border:1px solid rgba(200,168,75,.2);
  padding:7px 13px;
  transition:all .3s;
}
.tag:hover { border-color:var(--gold); color:var(--gold) }

.about__visual { position:relative }
.about__frame {
  position:relative;
  aspect-ratio:4/3; overflow:hidden;
  background:var(--ink-3);
  border:1px solid rgba(200,168,75,.12);
}
.about__img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:contain;
  transition:opacity .5s ease;
}
video.about__img { background:var(--ink-3); outline:none }
.about__img--base { opacity:1; z-index:1 }
.about__img--hover { opacity:0; z-index:2 }
.about__img--hover.active { opacity:1 }
.about__frame-label {
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  padding:14px 18px;
  background:linear-gradient(to top, rgba(8,6,8,.92), transparent);
  font-size:clamp(9px, 1.1vw, 10px);
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); font-family:var(--f-body); font-weight:500;
  transition:opacity .3s ease;
}
.about__frame::before, .about__frame::after {
  content:''; position:absolute; z-index:4;
  width:24px; height:24px;
  border-color:var(--gold); border-style:solid;
  pointer-events:none;
}
.about__frame::before { top:12px; left:12px; border-width:1px 0 0 1px }
.about__frame::after  { bottom:12px; right:12px; border-width:0 1px 1px 0 }

/* Pillars */
.about__pillars {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  margin-top:1px;
  background:rgba(200,168,75,.1);
}
@media (max-width: 560px) {
  .about__pillars { grid-template-columns:1fr }
}
.pillar {
  background:rgba(8,6,8,.8);
  padding:20px 18px;
  cursor:pointer;
  transition:background .3s, border-color .3s;
  -webkit-tap-highlight-color:transparent;
  user-select:none;
  min-height:108px;
}
.pillar:hover, .pillar.active { background:rgba(200,168,75,.08) }
.pillar__num {
  font-family:var(--f-display);
  font-size:clamp(30px, 3.5vw, 40px);
  color:var(--gold); opacity:.55; line-height:1;
  margin-bottom:8px; transition:opacity .3s;
}
.pillar:hover .pillar__num, .pillar.active .pillar__num { opacity:1 }
.pillar__title {
  font-family:var(--f-body);
  font-size:clamp(11px, 1.2vw, 12px);
  font-weight:600; letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-bright);
  margin-bottom:6px;
}
.pillar__desc {
  font-size:clamp(12px, 1.2vw, 13px);
  font-weight:300; color:var(--text-mid);
  line-height:1.6; transition:color .3s;
}
.pillar:hover .pillar__desc, .pillar.active .pillar__desc { color:var(--text-bright) }

/* ══════════════════════════ WORLD ══════════════════════════ */
.world {
  position:relative; overflow:hidden;
  padding:var(--gap-section) 0;
}
.world__bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 50% 70% at 20% 50%, rgba(139,111,212,.12) 0%, transparent 60%),
    radial-gradient(ellipse 70% 100% at 80% 100%, rgba(200,168,75,.06) 0%, transparent 50%),
    var(--ink-2);
}
.world__inner {
  position:relative; z-index:1;
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(40px, 6vw, 120px);
  align-items:start;
}
@media (min-width: 1024px) {
  .world__inner { grid-template-columns:1.2fr 1fr }
}
.world__heading {
  font-family:var(--f-display);
  font-size:clamp(40px, 7vw, 80px);
  line-height:.95; letter-spacing:.04em; text-transform:uppercase;
  margin-bottom:28px; color:var(--text-bright);
}
.world__heading .luc { color:var(--luc-bright) }
.world__body {
  font-size:clamp(14px, 1.4vw, 17px);
  font-weight:300; color:var(--text-mid);
  line-height:1.85; margin-bottom:18px;
  text-wrap:pretty;
}
.world__pull {
  font-family:var(--f-serif);
  font-size:clamp(18px, 2.2vw, 30px);
  font-weight:300; font-style:italic;
  color:var(--text-bright); line-height:1.5;
  margin:32px 0;
  padding:24px 0;
  border-top:1px solid rgba(200,168,75,.2);
  border-bottom:1px solid rgba(200,168,75,.2);
}

.world__crystal {
  display:flex; flex-direction:column; gap:1px;
}
@media (min-width: 1024px) {
  .world__crystal { position:sticky; top:calc(var(--nav-h) + 32px) }
}
.world__crystal-main {
  aspect-ratio:3/4;
  background:var(--ink-3);
  border:1px solid rgba(139,111,212,.25);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; position:relative;
  background-image:url('../Assets/lucentium.jpg');
  background-size:cover;
  background-position:center;
  cursor:pointer;
  transition:border-color .3s;
}
.world__crystal-main:hover { border-color:rgba(176,144,240,.5) }
@media (max-width: 640px) {
  .world__crystal-main { aspect-ratio:4/5 }
}
.world__crystal-caption {
  padding:14px 18px;
  background:rgba(139,111,212,.08);
  border:1px solid rgba(139,111,212,.15);
  font-size:clamp(10px, 1.2vw, 11px);
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--luc-bright); font-family:var(--f-body); font-weight:500;
  text-align:center;
}
.world__crystal-zoom-hint {
  position:absolute; top:12px; right:12px; z-index:3;
  width:32px; height:32px;
  background:rgba(8,6,8,.75);
  border:1px solid rgba(200,168,75,.4);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .3s;
}
.world__crystal-main:hover .world__crystal-zoom-hint { opacity:1 }
@media (hover: none) {
  .world__crystal-zoom-hint { opacity:.85 }
}

/* ══════════════════════════ FACTIONS ══════════════════════════ */
.factions { position:relative; overflow:hidden }

.factions__header {
  padding:var(--gap-section) clamp(20px, 5vw, 80px) clamp(48px, 6vw, 80px);
  text-align:center;
  max-width:var(--max);
  margin:0 auto;
}
.factions__title {
  font-family:var(--f-display);
  font-size:clamp(44px, 9vw, 112px);
  line-height:.9; letter-spacing:.06em; text-transform:uppercase;
  color:var(--text-bright);
}

.faction {
  position:relative; overflow:hidden;
}

/* DESKTOP: full-bleed background, content overlaid */
@media (min-width: 900px) {
  .faction {
    min-height:clamp(480px, 60vh, 700px);
    display:flex; align-items:center;
  }
}

/* Backgrounds */
.faction--kingdom .faction__bg {
  background:
    linear-gradient(to right, rgba(8,6,8,.9) 0%, rgba(8,6,8,.55) 55%, rgba(8,6,8,.1) 100%),
    url('../Assets/faction-kingdom.webp') center / cover no-repeat;
}
.faction--outcasts .faction__bg {
  background:
    linear-gradient(to left, rgba(8,6,8,.9) 0%, rgba(8,6,8,.55) 55%, rgba(8,6,8,.1) 100%),
    url('../Assets/faction-outcasts.webp') center / cover no-repeat;
}
.faction--dwellers .faction__bg {
  background:
    linear-gradient(to right, rgba(8,6,8,.9) 0%, rgba(8,6,8,.55) 55%, rgba(8,6,8,.1) 100%),
    url('../Assets/faction-dwellers.webp') center / cover no-repeat;
}

/* Mobile: gradient FROM BOTTOM so text (below) has dark bg */
@media (max-width: 899px) {
  .faction { display:flex; flex-direction:column }
  .faction__bg {
    position:relative !important;
    aspect-ratio:16/10;
    width:100%; height:auto;
  }
  .faction--kingdom .faction__bg {
    background:
      linear-gradient(to bottom, rgba(8,6,8,.3) 0%, rgba(8,6,8,.65) 75%, rgba(8,6,8,.98) 100%),
      url('../Assets/faction-kingdom.webp') center / cover no-repeat;
  }
  .faction--outcasts .faction__bg {
    background:
      linear-gradient(to bottom, rgba(8,6,8,.3) 0%, rgba(8,6,8,.65) 75%, rgba(8,6,8,.98) 100%),
      url('../Assets/faction-outcasts.webp') center / cover no-repeat;
  }
  .faction--dwellers .faction__bg {
    background:
      linear-gradient(to bottom, rgba(8,6,8,.3) 0%, rgba(8,6,8,.65) 75%, rgba(8,6,8,.98) 100%),
      url('../Assets/faction-dwellers.webp') center / cover no-repeat;
  }
}

.faction__bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform 6s ease;
}
.faction:hover .faction__bg { transform:scale(1.03) }

.faction__content {
  position:relative; z-index:2;
  padding:clamp(40px, 6vh, 80px) clamp(20px, 6vw, 100px);
  max-width:620px;
}
@media (max-width: 899px) {
  .faction__content {
    margin-top:-60px; /* overlap into image gradient for cinematic seam */
    padding-top:0;
  }
}

/* Outcasts: right-aligned on desktop */
@media (min-width: 900px) {
  .faction--outcasts .faction__content {
    margin-left:auto; text-align:right;
  }
  .faction--outcasts .faction__eyebrow { flex-direction:row-reverse }
  .faction--outcasts .faction__eyebrow::before { display:none }
  .faction--outcasts .faction__eyebrow::after {
    content:''; width:28px; height:1px;
    background:currentColor; flex-shrink:0;
  }
  .faction--outcasts .faction__desc { margin-left:auto }
  .faction--outcasts .faction__traits { justify-content:flex-end }
  .faction--outcasts .faction__previews { justify-content:flex-end }
}

.faction__eyebrow {
  font-family:var(--f-body); font-size:10px; font-weight:500;
  letter-spacing:.3em; text-transform:uppercase;
  display:flex; align-items:center; gap:14px;
  margin-bottom:12px;
}
.faction__eyebrow::before {
  content:''; width:28px; height:1px;
  background:currentColor; flex-shrink:0;
}
.faction--kingdom  .faction__eyebrow { color:var(--lucentium) }
.faction--outcasts .faction__eyebrow { color:var(--ember-bright) }
.faction--dwellers .faction__eyebrow { color:#6AAA60 }

.faction__name {
  font-family:var(--f-display);
  font-size:clamp(48px, 8vw, 96px);
  line-height:.9; letter-spacing:.04em; text-transform:uppercase;
  color:var(--text-bright); margin-bottom:8px;
}
.faction__motto {
  font-family:var(--f-serif);
  font-size:clamp(15px, 1.6vw, 20px);
  font-weight:300; font-style:italic;
  color:var(--text-mid); margin-bottom:18px;
}
.faction__desc {
  font-size:clamp(14px, 1.3vw, 16px);
  font-weight:300; color:var(--text-mid);
  line-height:1.8;
  max-width:520px; margin-bottom:22px;
  text-wrap:pretty;
}
.faction__traits { display:flex; flex-wrap:wrap; gap:8px }
.ftrait {
  font-size:9px; font-weight:500; letter-spacing:.18em;
  text-transform:uppercase;
  padding:6px 12px; border:1px solid;
  transition:all .3s;
}
.faction--kingdom  .ftrait { color:rgba(176,144,240,.75); border-color:rgba(139,111,212,.3) }
.faction--kingdom  .ftrait:hover { color:var(--luc-bright); border-color:var(--luc-bright) }
.faction--outcasts .ftrait { color:rgba(240,112,48,.8); border-color:rgba(212,90,26,.3) }
.faction--outcasts .ftrait:hover { color:var(--ember-bright); border-color:var(--ember-bright) }
.faction--dwellers .ftrait { color:rgba(138,204,120,.75); border-color:rgba(100,160,80,.3) }
.faction--dwellers .ftrait:hover { color:#8ACC78; border-color:#8ACC78 }

/* Preview buttons */
.faction__previews {
  display:flex; gap:8px; margin-top:22px; flex-wrap:wrap;
  position:relative; z-index:4;
}
.faction__preview-btn {
  font-family:var(--f-body); font-size:10px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  padding:10px 18px;
  border:1px solid rgba(242,237,228,.25);
  color:var(--text-mid);
  background:rgba(8,6,8,.6);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  cursor:pointer; transition:all .3s;
  -webkit-tap-highlight-color:transparent;
  min-height:40px;
}
.faction__preview-btn:hover,
.faction__preview-btn.active {
  color:var(--text-bright);
  border-color:var(--gold);
  background:rgba(200,168,75,.15);
}

/* Preview box — DESKTOP: centered overlay on faction banner */
.faction__preview-box {
  display:none;
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%, -50%);
  z-index:5;
  height:calc(clamp(480px, 60vh, 700px) * 0.8);
  width:auto; max-width:min(90vw, 680px);
  aspect-ratio:4/3;
}
.faction__preview-box.visible { display:block }

/* MOBILE: preview appears INLINE below the content, not overlaid */
@media (max-width: 899px) {
  .faction__preview-box {
    position:relative;
    top:auto; left:auto;
    transform:none;
    height:auto; width:100%;
    max-width:100%;
    aspect-ratio:16/10;
    margin:0 0 clamp(20px, 5vw, 32px);
    padding:0 clamp(20px, 6vw, 100px);
  }
  /* Move preview BEFORE content via flex order on the faction */
  .faction {
    display:flex; flex-direction:column;
  }
}

.faction__preview-frame {
  position:relative;
  width:100%; height:100%;
  background:var(--ink-3);
  border:1px solid rgba(200,168,75,.3);
  overflow:hidden;
  cursor:pointer;
}
.faction__preview-frame::before,
.faction__preview-frame::after {
  content:''; position:absolute; z-index:2;
  width:16px; height:16px;
  border-color:var(--gold); border-style:solid;
  pointer-events:none;
}
.faction__preview-frame::before { top:8px; left:8px; border-width:1px 0 0 1px }
.faction__preview-frame::after  { bottom:8px; right:8px; border-width:0 1px 1px 0 }

.faction__preview-img {
  width:100%; height:100%;
  object-fit:cover; display:block;
}
.faction__preview-label {
  position:absolute; bottom:0; left:0; right:0;
  padding:14px 16px 12px;
  background:linear-gradient(to top, rgba(8,6,8,.95) 60%, transparent);
  font-family:var(--f-body); font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
}
.faction__preview-label .label-title {
  font-size:10px; display:block; margin-bottom:4px;
}
.faction__preview-label .label-desc {
  font-size:11px; font-weight:300;
  letter-spacing:.06em; color:var(--text-mid);
  text-transform:none; display:block; line-height:1.4;
}
.faction__preview-expand, .about__expand {
  position:absolute; top:8px; right:8px; z-index:3;
  width:32px; height:32px;
  background:rgba(8,6,8,.75);
  border:1px solid rgba(200,168,75,.4);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s;
}
.faction__preview-expand:hover, .about__expand:hover {
  background:rgba(200,168,75,.2);
  border-color:var(--gold);
}
.about__expand { top:12px; right:12px }


/* ── Carousel dots ── */
.carousel__dots {
  position: absolute;
  bottom: 48px;
  right: 12px;
  display: flex;
  gap: 6px;
  z-index: 4;
  align-items: center;
}
.carousel__dot {
  width: 8px;
  height: 8px;
  border-radius: 0;
  background: rgba(200,168,75,.25);
  border: 1px solid rgba(200,168,75,.5);
  cursor: pointer;
  transition: background .25s, transform .25s, border-color .25s;
  padding: 0;
  flex-shrink: 0;
}
.carousel__dot.active {
  background: var(--gold);
  border-color: var(--gold);
  transform: scale(1.3);
}
.carousel__dot:hover:not(.active) {
  background: rgba(200,168,75,.55);
  border-color: var(--gold);
}

.faction-rule {
  height:1px;
  background:linear-gradient(to right, transparent, rgba(200,168,75,.18), transparent);
}

/* ══════════════════════════ GAME MODES ══════════════════════════ */
.modes {
  position:relative; overflow:hidden;
  padding:var(--gap-section) 0;
}
.modes__bg {
  position:absolute; inset:0;
  background:var(--ink-2);
}
.modes__bg::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 60% at 50% 100%, rgba(200,168,75,.05) 0%, transparent 70%);
}
.modes__header {
  text-align:center;
  margin-bottom:clamp(40px, 6vw, 80px);
}
.modes__heading {
  font-family:var(--f-display);
  font-size:clamp(42px, 8vw, 96px);
  line-height:.9; letter-spacing:.06em; text-transform:uppercase;
  color:var(--text-bright);
  margin-bottom:18px;
}
.modes__body {
  font-size:clamp(14px, 1.4vw, 17px);
  font-weight:300; color:var(--text-mid);
  max-width:600px; margin:0 auto;
  line-height:1.8;
  text-wrap:pretty;
}
.modes__grid {
  display:grid;
  grid-template-columns:1fr;
  gap:1px;
  background:rgba(200,168,75,.08);
}
@media (min-width: 768px) {
  .modes__grid { grid-template-columns:repeat(2, 1fr) }
}
.mode {
  background:var(--ink-2);
  padding:clamp(28px, 4vw, 52px) clamp(24px, 3.5vw, 48px);
  position:relative; overflow:hidden;
  transition:background .4s; cursor:default;
}
.mode::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s ease;
}
.mode:hover { background:rgba(200,168,75,.04) }
.mode:hover::before { transform:scaleX(1) }
.mode__roman {
  font-family:var(--f-display);
  font-size:clamp(56px, 8vw, 112px);
  color:rgba(200,168,75,.08); line-height:1;
  position:absolute; bottom:-10px; right:24px;
  transition:color .4s; pointer-events:none;
}
.mode:hover .mode__roman { color:rgba(200,168,75,.13) }
.mode__title {
  font-family:var(--f-display);
  font-size:clamp(28px, 4vw, 44px);
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--text-bright);
  margin-bottom:14px;
}
.mode__desc {
  font-size:clamp(14px, 1.3vw, 16px);
  font-weight:300; color:var(--text-mid);
  line-height:1.8; max-width:500px;
  text-wrap:pretty;
}
.mode__tag {
  display:inline-block;
  font-size:9px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
  border:1px solid rgba(200,168,75,.3);
  padding:5px 12px; margin-top:18px;
}

/* ══════════════════════════ ENLIST ══════════════════════════ */
.enlist {
  position:relative; overflow:hidden;
  padding:var(--gap-section) 0;
  text-align:center;
}
.enlist__bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 80% at 50% 100%, rgba(200,168,75,.08) 0%, transparent 60%),
    var(--ink);
}
.enlist__inner {
  position:relative; z-index:1;
  max-width:680px; margin:0 auto;
}
.enlist__heading {
  font-family:var(--f-display);
  font-size:clamp(44px, 9vw, 112px);
  line-height:.9; letter-spacing:.06em; text-transform:uppercase;
  color:var(--text-bright);
  margin-bottom:18px;
}
.enlist__sub {
  font-family:var(--f-serif);
  font-size:clamp(17px, 2vw, 24px);
  font-style:italic; color:var(--text-mid);
  margin-bottom:14px;
}
.enlist__body {
  font-size:clamp(14px, 1.3vw, 16px);
  font-weight:300; color:var(--text-dim);
  line-height:1.8;
  margin-bottom:36px;
  text-wrap:pretty;
}
.enlist__ctas {
  display:flex; justify-content:center; gap:12px;
  flex-wrap:wrap; margin-bottom:36px;
}
.enlist__form {
  display:flex;
  max-width:460px; margin:0 auto 14px;
  gap:0;
}
.enlist__input {
  flex:1; min-width:0;
  background:rgba(242,237,228,.05);
  border:1px solid rgba(200,168,75,.2);
  border-right:none;
  color:var(--text-bright);
  font-family:var(--f-body);
  font-size:13px;
  padding:14px 18px;
  outline:none; transition:border-color .3s;
}
.enlist__input:focus { border-color:rgba(200,168,75,.6) }
.enlist__input::placeholder { color:var(--text-dim) }
.enlist__submit {
  background:var(--gold); color:var(--ink);
  font-family:var(--f-body); font-size:11px; font-weight:600;
  letter-spacing:.15em; text-transform:uppercase;
  padding:14px 24px;
  border:none; cursor:pointer;
  transition:background .3s;
  white-space:nowrap;
}
.enlist__submit:hover { background:var(--gold-light) }
@media (max-width: 480px) {
  .enlist__form { flex-direction:column; gap:8px }
  .enlist__input { border-right:1px solid rgba(200,168,75,.2); padding:14px 16px }
  .enlist__submit { padding:14px }
}
.enlist__note {
  font-size:10px; font-weight:400;
  letter-spacing:.15em; color:var(--text-dim);
  text-transform:uppercase;
}

/* ══════════════════════════ STUDIO ══════════════════════════ */
.studio {
  position:relative; overflow:hidden;
  padding:var(--gap-section) 0;
  border-top:1px solid rgba(200,168,75,.1);
}
.studio__bg {
  position:absolute; inset:0;
  background:var(--ink-2);
}
.studio__inner {
  position:relative; z-index:1;
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:start;
}
@media (min-width: 1024px) {
  .studio__inner { grid-template-columns:1fr 1fr }
}
.studio__heading {
  font-family:var(--f-display);
  font-size:clamp(42px, 8vw, 88px);
  line-height:.9; letter-spacing:.04em; text-transform:uppercase;
  color:var(--text-bright);
  margin-bottom:22px;
}
.studio__heading .red {
  color:#C8211A;
  -webkit-text-fill-color:#C8211A;
}
.studio__body {
  font-size:clamp(14px, 1.3vw, 16px);
  font-weight:300; color:var(--text-mid);
  line-height:1.85; margin-bottom:18px;
  text-wrap:pretty;
}
.studio__mantra {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  margin:32px 0;
  border-top:1px solid rgba(200,168,75,.15);
}
.studio__mantra-item {
  padding:20px 16px 20px 20px;
  border-right:1px solid rgba(200,168,75,.1);
}
.studio__mantra-item:first-child { padding-left:0 }
.studio__mantra-item:last-child { border-right:none; padding-right:0 }
.studio__mantra-title {
  font-family:var(--f-display);
  font-size:clamp(16px, 2vw, 20px);
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--gold); margin-bottom:4px;
}
.studio__mantra-desc {
  font-size:clamp(10px, 1.2vw, 12px);
  font-weight:300; color:var(--text-mid);
  line-height:1.5;
}
@media (max-width: 600px) {
  .studio__mantra { grid-template-columns:1fr }
  .studio__mantra-item {
    border-right:none;
    border-bottom:1px solid rgba(200,168,75,.1);
    padding:16px 0;
  }
  .studio__mantra-item:last-child { border-bottom:none }
}
.studio__credits-label {
  font-size:9px; font-weight:500;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:14px;
}
.studio__credits { display:flex; flex-wrap:wrap; gap:6px }
.studio__credit {
  font-size:11px; font-weight:400;
  letter-spacing:.08em; color:var(--text-mid);
  background:rgba(242,237,228,.04);
  border:1px solid rgba(242,237,228,.08);
  padding:6px 12px;
  transition:all .2s;
}
.studio__credit:hover {
  border-color:rgba(200,168,75,.3);
  color:var(--text-bright);
}

.studio__links {
  display:flex; flex-direction:column; gap:1px;
  margin-bottom:28px;
}

/* Studio link icons */
.studio__link-icon {
  display:flex;
  align-items:center;
  flex-shrink:0;
  color:var(--text-dim);
  transition:color .3s;
}
.studio__link-item:hover .studio__link-icon { color:var(--gold); }

.studio__link-item {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  padding:18px 22px;
  background:rgba(242,237,228,.03);
  border:1px solid rgba(200,168,75,.08);
  transition:all .3s;
}
.studio__link-item:hover {
  background:rgba(200,168,75,.06);
  border-color:rgba(200,168,75,.2);
}
.studio__link-item span {
  font-size:12px; font-weight:400;
  letter-spacing:.1em; color:var(--text-mid);
}
.studio__link-item strong {
  font-size:13px; font-weight:500;
  letter-spacing:.06em; color:var(--text-bright);
  transition:color .3s;
  flex:1;
}
.studio__link-item:hover strong { color:var(--gold) }
.studio__link-arrow {
  font-size:14px; color:var(--gold);
  opacity:0; transition:opacity .3s, transform .3s;
  transform:translateX(-8px);
}
.studio__link-item:hover .studio__link-arrow {
  opacity:1; transform:translateX(0);
}

.studio__contact {
  padding:26px 22px;
  border:1px solid rgba(200,168,75,.15);
  border-left:2px solid var(--gold);
  text-align:left;
}
.studio__contact-title {
  font-family:var(--f-display);
  font-size:clamp(16px, 2vw, 20px);
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-bright); margin-bottom:8px;
}
.studio__contact-body {
  font-size:13px; font-weight:300;
  color:var(--text-mid);
  line-height:1.6; margin-bottom:18px;
}

/* ══════════════════════════ FOOTER ══════════════════════════ */
.footer {
  background:var(--ink);
  border-top:1px solid rgba(200,168,75,.1);
  padding:clamp(48px, 6vw, 80px) 0 28px;
}
.footer__top {
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  padding-bottom:clamp(32px, 5vw, 56px);
  border-bottom:1px solid rgba(200,168,75,.08);
  margin-bottom:24px;
}
@media (min-width: 640px) {
  .footer__top { grid-template-columns:1fr 1fr; gap:36px }
}
@media (min-width: 1024px) {
  .footer__top { grid-template-columns:2fr 1fr 1fr 1fr; gap:44px }
}
.footer__brand-logo {
  display:flex; align-items:center; gap:12px;
  font-family:var(--f-display);
  font-size:clamp(17px, 2vw, 20px);
  letter-spacing:.08em;
  margin-bottom:14px;
}
.footer__brand p {
  font-size:12px; font-weight:300;
  color:var(--text-dim);
  line-height:1.7; max-width:340px;
}
.footer__social { display:flex; gap:8px; margin-top:18px }
.footer__soc {
  width:36px; height:36px;
  border:1px solid rgba(200,168,75,.15);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-dim); transition:all .3s;
}
.footer__soc:hover { border-color:var(--gold); color:var(--gold) }

.footer__col-title {
  font-size:9px; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:16px;
}
.footer__links {
  display:flex; flex-direction:column; gap:10px;
}
.footer__lnk {
  font-size:13px; font-weight:300;
  color:var(--text-mid); transition:color .2s;
}
.footer__lnk:hover { color:var(--gold) }

.footer__bottom {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px;
}
.footer__copy {
  font-size:11px; font-weight:300;
  color:var(--text-dim);
}
.footer__legal { display:flex; gap:20px }

/* ══════════════════════════ REVEAL ANIMATIONS ══════════════════════════ */
.reveal, .reveal-l, .reveal-r {
  opacity:0;
  transition:opacity .8s ease, transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal   { transform:translateY(40px) }
.reveal-l { transform:translateX(-48px) }
.reveal-r { transform:translateX(48px) }
.reveal.in, .reveal-l.in, .reveal-r.in {
  opacity:1; transform:none;
}
.d1 { transition-delay:.08s }
.d2 { transition-delay:.16s }
.d3 { transition-delay:.24s }
.d4 { transition-delay:.32s }
.d5 { transition-delay:.4s  }
.d6 { transition-delay:.48s }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-l, .reveal-r {
    opacity:1; transform:none; transition:none;
  }
}

/* ══════════════════════════ LIGHTBOX ══════════════════════════ */
.lightbox {
  position:fixed; inset:0; z-index:99000;
  display:none;
  align-items:center; justify-content:center;
  padding:20px;
}
.lightbox.open { display:flex }
.lightbox__overlay {
  position:absolute; inset:0;
  background:rgba(4,2,6,.95);
  cursor:pointer;
}
.lightbox__content {
  position:relative; z-index:1;
  max-width:min(92vw, 1100px);
  max-height:92vh;
  display:flex; align-items:center; justify-content:center;
}
.lightbox__content::before, .lightbox__content::after {
  content:''; position:absolute;
  width:28px; height:28px;
  border-color:var(--gold); border-style:solid;
  pointer-events:none;
}
.lightbox__content::before { top:0; left:0; border-width:1px 0 0 1px }
.lightbox__content::after  { bottom:0; right:0; border-width:0 1px 1px 0 }
.lightbox__img {
  display:block;
  max-width:100%; max-height:90vh;
  object-fit:contain;
}
.lightbox__close {
  position:absolute; top:-20px; right:-20px;
  width:44px; height:44px;
  background:rgba(8,6,8,.9);
  border:1px solid rgba(200,168,75,.3);
  color:var(--gold);
  font-size:24px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s;
  z-index:2;
}
.lightbox__close:hover {
  background:var(--gold); color:var(--ink);
}
@media (max-width: 600px) {
  .lightbox__close { top:0; right:0 }
}

/* ══════════════════════════
   PARTNERS SECTION
══════════════════════════ */
.partners {
  position:relative; overflow:hidden;
  /* Match other sections — explicit padding-top so it clears studio cleanly */
  padding:clamp(80px,10vw,140px) 0;
  /* Subtle separator from studio section above */
  border-top:1px solid rgba(200,168,75,.08);
}
.partners__bg {
  position:absolute; inset:0;
  background:var(--ink-2);
}
.partners__bg::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 60% at 50% 100%, rgba(200,168,75,.05) 0%, transparent 70%);
}
/* 6-box grid overriding the default 2-col modes__grid */
.partners__grid--six {
  grid-template-columns:repeat(3,1fr) !important;
}
@media(max-width:1100px) {
  .partners__grid--six { grid-template-columns:repeat(2,1fr) !important; }
}
@media(max-width:600px) {
  .partners__grid--six { grid-template-columns:1fr !important; }
}

/* Partner header: logo icon + name side by side */
.partner__header {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
  min-height:0;
}
/* Logo constrained — never resizes the box */
.partner__logo {
  width:28px;
  height:28px;
  max-width:28px;
  max-height:28px;
  object-fit:contain;
  flex-shrink:0;
  /* Render any colour logo as white on dark bg */
  filter:brightness(0) invert(1);
  opacity:.75;
  transition:opacity .3s;
}
.mode:hover .partner__logo { opacity:1; }
.partner__header .mode__title { margin-bottom:0; }

/* Open / CTA box — dashed to feel different */
.partner__open {
  border-style:dashed !important;
  border-color:rgba(200,168,75,.2) !important;
}
.partner__open:hover {
  border-style:solid !important;
  border-color:rgba(200,168,75,.35) !important;
}

/* Partners boxes — compact, 3-per-row always, subdued scale */
.partners__grid--six {
  grid-template-columns:repeat(3,1fr) !important;
}
@media(max-width:700px) {
  .partners__grid--six { grid-template-columns:repeat(2,1fr) !important; }
}
@media(max-width:440px) {
  .partners__grid--six { grid-template-columns:1fr !important; }
}
/* Override the .mode padding for partner boxes only */
.partners__grid--six .mode {
  padding:clamp(18px,2.5vw,28px) clamp(16px,2vw,24px);
}
.partners__grid--six .mode__roman {
  font-size:clamp(36px,5vw,64px);
  bottom:-6px; right:14px;
}
.partners__grid--six .mode__title {
  font-size:clamp(14px,1.6vw,18px);
  margin-bottom:0;
  letter-spacing:.04em;
}
.partners__grid--six .mode__desc {
  font-size:clamp(11px,1vw,13px);
  line-height:1.65;
  margin-top:10px;
  max-width:100%;
}
.partners__grid--six .mode__tag {
  font-size:8px;
  padding:4px 10px;
  margin-top:12px;
}
/* Also shrink section padding since it's a supporting segment */
.partners {
  padding:clamp(48px,6vw,80px) 0 !important;
}
.partners .modes__header {
  margin-bottom:clamp(28px,4vw,48px);
}
.partners .modes__heading {
  font-size:clamp(28px,4vw,52px);
}
.partners .modes__body {
  font-size:clamp(13px,1.2vw,15px);
}

/* ── Audio mute toggle button ── */
.nav__audio-btn {
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px; height:36px;
  border:1px solid rgba(200,168,75,.3);
  background:transparent;
  color:var(--gold);
  cursor:pointer;
  transition:all .25s;
  flex-shrink:0;
  position:relative;
  z-index:1;
}
.nav__audio-btn:hover {
  border-color:var(--gold);
  background:rgba(200,168,75,.1);
}
.nav__audio-btn.muted {
  color:var(--text-dim);
  border-color:rgba(242,237,228,.15);
}
.nav__audio-btn.muted:hover {
  color:var(--text-mid);
  border-color:rgba(242,237,228,.3);
}
/* Pulse ring when music is playing */
.nav__audio-btn::after {
  content:'';
  position:absolute;
  inset:-4px;
  border:1px solid rgba(200,168,75,.2);
  animation:audioPulse 3s ease-in-out infinite;
  pointer-events:none;
}
.nav__audio-btn.muted::after { display:none; }
@keyframes audioPulse {
  0%,100% { opacity:0; transform:scale(1); }
  50%      { opacity:1; transform:scale(1.08); }
}
@media(prefers-reduced-motion:reduce) {
  .nav__audio-btn::after { animation:none; display:none; }
}

/* Partners — pure black background to alternate with Studio (ink-2) */
.partners__bg {
  background:var(--ink) !important;
}
.partners__bg::before {
  background:radial-gradient(ellipse 50% 50% at 50% 100%, rgba(200,168,75,.04) 0%, transparent 60%) !important;
}
/* Remove logos entirely */
.partner__logo { display:none !important; }
/* Without logo, reduce gap in header */
.partner__header { gap:0; }

/* Footer — dark grey (ink-2) to alternate with Partners (black) */
.footer { background:var(--ink-2) !important; }

/* Audio + CTA sit flush together on the right */
.nav__cta-group {
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
}
/* On mobile hide CTA but keep audio button accessible */
@media(max-width:768px) {
  .nav__cta-group .nav__cta { display:none; }
}

/* ── Carousel nav arrows ── */
.carousel__arrow {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:36px; height:52px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(8,6,8,.6);
  border:1px solid rgba(200,168,75,.35);
  color:var(--gold);
  cursor:pointer;
  /* Always visible when box is open — no hover needed */
  opacity:1;
  transition:background .2s, border-color .2s, color .2s;
  -webkit-tap-highlight-color:transparent;
}
.carousel__arrow--prev { left:0;  border-left:none;  border-radius:0 3px 3px 0; }
.carousel__arrow--next { right:0; border-right:none; border-radius:3px 0 0 3px; }
.carousel__arrow:hover {
  background:rgba(200,168,75,.25);
  border-color:var(--gold);
  color:#fff;
}
/* Hide arrows when only one image */
.carousel__arrow.hidden { display:none; }

/* Enlist Discord button */
.enlist__discord {
  margin-top:20px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  max-width:100%;
  box-sizing:border-box;
  white-space:nowrap;
}
@media(max-width:480px) {
  .enlist__discord {
    width:100%;
    justify-content:center;
    white-space:normal;
    text-align:center;
  }
}
