/* =========================================================
   Community Organisation — communityorg.co.uk  (v2)
   Navy #0B1F3A · Gold #C9A84C · Discord blurple #5865F2
   ========================================================= */

:root {
  --navy:        #0B1F3A;
  --navy-deep:   #060F23;
  --navy-darker: #03081A;
  --navy-card:   #0d172e;
  --gold:        #C9A84C;
  --gold-bright: #E8D38A;
  --gold-hot:    #FFD86B;
  --ink:         #ECF1FB;
  --ink-soft:    #B8C3DA;
  --ink-dim:     #6C7B96;
  --blurple:     #5865F2;
  --blurple-2:   #7C8BFF;
  --green:       #43B581;
  --line:        rgba(201,168,76,.18);
  --line-strong: rgba(201,168,76,.34);
  --bg-card:     rgba(255,255,255,.035);
  --bg-card-h:   rgba(255,255,255,.07);
  --shadow-xl:   0 30px 80px -20px rgba(0,0,0,.7), 0 12px 40px -10px rgba(88,101,242,.18);
  --shadow-glow: 0 0 0 1px rgba(201,168,76,.18), 0 20px 60px -16px rgba(88,101,242,.35);
  --radius:      18px;
  --radius-lg:   28px;
  --easing:      cubic-bezier(.2,.7,.2,1);
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--navy-darker);
  color: var(--ink);
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  scroll-behavior: smooth;
}
body {
  background:
    radial-gradient(1200px 800px at 80% -10%, rgba(88,101,242,.22), transparent 60%),
    radial-gradient(900px 700px at -10% 30%, rgba(201,168,76,.12), transparent 65%),
    linear-gradient(180deg, var(--navy-darker) 0%, var(--navy-deep) 60%, var(--navy-darker) 100%);
  min-height: 100vh;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--gold); color: var(--navy); }

a:focus-visible, button:focus-visible, summary:focus-visible {
  outline: 2px solid var(--gold-hot);
  outline-offset: 4px;
  border-radius: 10px;
}

/* =========================================================
   Scroll-progress bar
   ========================================================= */
.scroll-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  z-index: 100; pointer-events: none;
  background: rgba(201,168,76,.08);
}
.scroll-progress i {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--blurple), var(--gold), var(--gold-hot));
  width: 0%;
  transition: width 60ms linear;
  box-shadow: 0 0 14px rgba(255,216,107,.5);
}

/* =========================================================
   Cursor halo
   ========================================================= */
.cursor-halo {
  position: fixed; top: 0; left: 0;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(201,168,76,.16) 0%, rgba(88,101,242,.10) 30%, transparent 65%);
  pointer-events: none;
  z-index: 1;
  transform: translate3d(-9999px, -9999px, 0);
  transition: opacity .4s ease;
  mix-blend-mode: screen;
}
@media (hover: none) { .cursor-halo { display: none; } }

/* =========================================================
   Aurora + constellation + vignette
   ========================================================= */
.aurora {
  position: fixed; inset: 0;
  z-index: 0; pointer-events: none;
  overflow: hidden;
}
.blob {
  position: absolute; border-radius: 50%;
  filter: blur(80px);
  opacity: .55;
  mix-blend-mode: screen;
  animation: float 22s ease-in-out infinite alternate;
  will-change: transform;
}
.blob-1 { width: 540px; height: 540px; background: radial-gradient(circle, #5865F2 0%, transparent 70%); top: -120px; left: -120px; animation-duration: 24s; }
.blob-2 { width: 600px; height: 600px; background: radial-gradient(circle, #C9A84C 0%, transparent 70%); top: 28%; right: -180px; animation-duration: 28s; opacity:.32; }
.blob-3 { width: 460px; height: 460px; background: radial-gradient(circle, #7C8BFF 0%, transparent 70%); bottom: 8%; left: 12%; animation-duration: 30s; }
.blob-4 { width: 380px; height: 380px; background: radial-gradient(circle, #E8D38A 0%, transparent 70%); bottom: -120px; right: 18%; animation-duration: 32s; opacity:.28; }
@keyframes float {
  from { transform: translate3d(0,0,0) scale(1); }
  to   { transform: translate3d(70px,-50px,0) scale(1.18); }
}
.constellation {
  position: absolute; inset: 0; width: 100%; height: 100%;
  opacity: .55;
  mix-blend-mode: screen;
}
.grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: .22; mix-blend-mode: overlay;
}
.vignette {
  position: absolute; inset: 0;
  background: radial-gradient(circle at center, transparent 0%, transparent 55%, rgba(3,8,26,.4) 100%);
}
@media (prefers-reduced-motion: reduce) {
  .blob { animation: none; }
  .constellation { display: none; }
}

/* =========================================================
   Top nav
   ========================================================= */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 32px;
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  background: linear-gradient(180deg, rgba(6,15,35,.78), rgba(6,15,35,.35));
  border-bottom: 1px solid var(--line);
  transition: padding .3s var(--easing), background .3s;
}
.topbar.tight { padding: 10px 32px; background: rgba(6,15,35,.92); }
.brand {
  display: inline-flex; align-items: center; gap: 14px;
  font-weight: 800; letter-spacing: -.01em; font-size: 17px;
}
.brand-mark {
  display: inline-grid; place-items: center;
  width: 42px; height: 42px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(201,168,76,.16), rgba(88,101,242,.16));
  border: 1px solid var(--line-strong);
  transition: transform .4s var(--easing);
}
.brand:hover .brand-mark { transform: rotate(-6deg) scale(1.06); }
.ring-spin { transform-origin: 20px 20px; animation: ring-spin 18s linear infinite; }
@keyframes ring-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .ring-spin { animation: none; } }

.brand-text-dim { color: var(--ink-soft); font-weight: 500; margin-left: 4px; }
.nav-right { display: flex; align-items: center; gap: 26px; }
.nav-link {
  color: var(--ink-soft); font-size: 14px; font-weight: 500;
  position: relative; padding: 4px 0;
  transition: color .2s;
}
.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 .35s var(--easing);
}
.nav-link:hover { color: var(--gold-bright); }
.nav-link:hover::after { transform: scaleX(1); }
.nav-cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px; border-radius: 999px;
  background: var(--blurple);
  color: white; font-weight: 600; font-size: 14px;
  border: 1px solid rgba(255,255,255,.1);
  transition: transform .2s var(--easing), box-shadow .2s, background .2s;
  box-shadow: 0 8px 24px -8px rgba(88,101,242,.6);
}
.nav-cta:hover { transform: translateY(-1px); background: var(--blurple-2); box-shadow: 0 12px 30px -8px rgba(88,101,242,.7); }
@media (max-width: 760px) {
  .topbar { padding: 14px 18px; }
  .nav-right .nav-link { display: none; }
}

/* =========================================================
   Hero
   ========================================================= */
main { position: relative; z-index: 2; }
.hero {
  position: relative;
  max-width: 1240px;
  margin: 0 auto;
  padding: 90px 32px 120px;
  display: grid;
  grid-template-columns: 1.3fr .85fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 980px) {
  .hero { grid-template-columns: 1fr; padding: 60px 22px 70px; gap: 44px; }
}

.kicker {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(201,168,76,.08);
  border: 1px solid var(--line-strong);
  color: var(--gold-bright);
  font-size: 12.5px; font-weight: 600;
  letter-spacing: .02em;
  margin-bottom: 28px;
  font-variant-numeric: tabular-nums;
}
.kicker-mute { color: var(--ink-dim); }
.kicker-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(67,181,129,.22);
  animation: pulse-green 2.2s infinite;
}
@keyframes pulse-green {
  0%,100% { box-shadow: 0 0 0 4px rgba(67,181,129,.22); }
  50%     { box-shadow: 0 0 0 10px rgba(67,181,129,0); }
}

/* Letter-reveal title */
.title {
  font-family: 'Instrument Serif', 'Inter', serif;
  font-weight: 400;
  font-size: clamp(52px, 8.5vw, 104px);
  line-height: 1.0;
  letter-spacing: -.025em;
  margin: 0 0 26px;
  color: var(--ink);
}
.title .line { display: block; overflow: hidden; padding-bottom: .12em; margin-bottom: -.12em; }
.title .word {
  display: inline-block;
  transform: translateY(110%);
  opacity: 0;
  animation: word-up .9s var(--easing) forwards;
  margin-right: .22em;
}
.title .word:nth-child(1) { animation-delay: 80ms; }
.title .word:nth-child(2) { animation-delay: 200ms; }
.title .line:nth-child(2) .word:nth-child(1) { animation-delay: 340ms; }
.title .line:nth-child(2) .word:nth-child(2) { animation-delay: 460ms; }
.title .line:nth-child(2) .word:nth-child(3) { animation-delay: 580ms; }
@keyframes word-up { to { transform: translateY(0); opacity: 1; } }
.title-period {
  display: inline-block;
  color: var(--gold-hot);
  opacity: 0;
  animation: word-up .6s 760ms var(--easing) forwards;
}
.title-shimmer {
  font-style: italic;
  background: linear-gradient(90deg, var(--gold) 0%, var(--gold-bright) 35%, var(--gold-hot) 50%, var(--gold-bright) 65%, var(--gold) 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: word-up .9s 580ms var(--easing) forwards, shimmer 6s 1.6s ease-in-out infinite;
}
@keyframes shimmer {
  0%,100% { background-position: 0% 50%; }
  50%     { background-position: 100% 50%; }
}
@media (prefers-reduced-motion: reduce) {
  .title .word, .title-period { opacity: 1; transform: none; animation: none; }
  .title-shimmer { animation: none; }
}

.reveal {
  opacity: 0; transform: translateY(20px);
  transition: opacity .9s var(--easing) 200ms, transform .9s var(--easing) 200ms;
}
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

.lede {
  font-size: clamp(16px, 1.4vw, 19.5px);
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 580px;
  margin: 0 0 40px;
  transition-delay: 350ms !important;
}
.lede strong { color: var(--ink); font-weight: 600; }
.lede em { font-style: normal; color: var(--gold-bright); font-weight: 500; }
.lede-em {
  font-weight: 700;
  color: var(--ink);
  background: linear-gradient(120deg, transparent 0%, transparent 8%, rgba(88,101,242,.28) 8%, rgba(88,101,242,.28) 92%, transparent 92%);
  padding: 0 4px;
}

.cta-row {
  display: flex; flex-wrap: wrap; gap: 14px;
  margin-bottom: 56px;
  transition-delay: 500ms !important;
}

/* Magnet effect — JS adds inline transform to .magnet-inner on mouse move */
.magnet { display: inline-flex; }
.magnet-inner {
  display: inline-flex; align-items: center; gap: 10px;
  transition: transform .25s var(--easing);
  will-change: transform;
}

.cta-primary {
  position: relative;
  border-radius: 999px;
  font-weight: 700; font-size: 15.5px;
  background: var(--blurple);
  color: white;
  border: none;
  isolation: isolate;
  transition: transform .25s var(--easing), box-shadow .25s;
  box-shadow: 0 14px 38px -10px rgba(88,101,242,.6), inset 0 1px 0 rgba(255,255,255,.18);
}
.cta-primary::before {
  content: ""; position: absolute; inset: -2px;
  border-radius: 999px;
  background: conic-gradient(from 0deg, #5865F2, #C9A84C, #FFD86B, #5865F2);
  z-index: -1; opacity: 0;
  animation: spin 7s linear infinite;
  transition: opacity .3s var(--easing);
}
.cta-primary:hover { transform: translateY(-2px); box-shadow: 0 20px 55px -10px rgba(88,101,242,.75); }
.cta-primary:hover::before { opacity: 1; }
@keyframes spin { to { transform: rotate(360deg); } }
.cta-primary-inner {
  padding: 15px 24px;
  border-radius: 999px;
  background: var(--blurple);
}
.cta-primary-lg .cta-primary-inner { padding: 19px 34px; font-size: 17px; }
.cta-primary:hover .cta-arrow { transform: translateX(5px); }
.cta-arrow { transition: transform .25s var(--easing); display: inline-block; }

.cta-secondary {
  padding: 15px 22px;
  border-radius: 999px;
  font-weight: 600; font-size: 15px;
  color: var(--ink);
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,.02);
  transition: all .2s;
}
.cta-secondary:hover {
  background: rgba(201,168,76,.08);
  border-color: var(--gold);
  color: var(--gold-bright);
}

.hero-meta {
  display: grid; grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px; max-width: 500px;
  transition-delay: 650ms !important;
}
.meta-card {
  position: relative;
  display: flex; flex-direction: column; gap: 6px;
  padding: 18px 20px;
  border-radius: var(--radius);
  background: var(--bg-card);
  border: 1px solid var(--line);
  transition: transform .25s var(--easing), border-color .25s;
  overflow: hidden;
}
.meta-card::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(201,168,76,.05), transparent 60%);
  opacity: 0; transition: opacity .25s;
}
.meta-card:hover { transform: translateY(-3px); border-color: var(--line-strong); }
.meta-card:hover::before { opacity: 1; }
.meta-num {
  font-family: 'Instrument Serif', serif;
  font-size: 34px;
  line-height: 1;
  color: var(--gold-bright);
  font-weight: 400;
  font-variant-numeric: tabular-nums;
}
.meta-lbl {
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--ink-dim);
  font-weight: 600;
}
.meta-pulse {
  position: absolute; top: 14px; right: 14px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(67,181,129,.22);
  animation: pulse-green 2.2s infinite;
}

/* =========================================================
   3D-tilt Discord card
   ========================================================= */
.tilt {
  position: relative;
  border-radius: var(--radius-lg);
  padding: 1.5px;
  background: linear-gradient(140deg, rgba(88,101,242,.7), rgba(201,168,76,.5));
  box-shadow: var(--shadow-xl);
  transform-style: preserve-3d;
  transition: transform .5s var(--easing), box-shadow .5s;
  will-change: transform;
  animation: card-rise 1s 200ms var(--easing) both;
}
@keyframes card-rise {
  from { opacity: 0; transform: translateY(40px) rotateX(8deg); }
  to   { opacity: 1; transform: translateY(0) rotateX(0); }
}
.tilt:hover { box-shadow: 0 40px 100px -20px rgba(0,0,0,.7), 0 20px 60px -10px rgba(88,101,242,.4); }

.tilt-shine {
  position: absolute; inset: 1.5px;
  border-radius: calc(var(--radius-lg) - 1.5px);
  pointer-events: none;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.15) 0%, transparent 30%);
  opacity: 0;
  transition: opacity .3s var(--easing);
  z-index: 3;
  mix-blend-mode: overlay;
}
.tilt:hover .tilt-shine { opacity: 1; }

.discord-card-glow {
  position: absolute; inset: -30px;
  border-radius: 40px;
  background: radial-gradient(circle at 50% 30%, rgba(88,101,242,.55), transparent 70%);
  filter: blur(40px);
  z-index: -1;
  opacity: .65;
}
.discord-card-body {
  position: relative;
  padding: 24px 24px 20px;
  border-radius: calc(var(--radius-lg) - 1.5px);
  background:
    linear-gradient(160deg, #1a2547 0%, #0d172e 70%, #0a142a 100%);
  display: flex; flex-direction: column; gap: 18px;
}

.discord-card-top {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center; gap: 16px;
}
.discord-card-icon {
  width: 64px; height: 64px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: #fff;
  box-shadow: 0 8px 22px -6px rgba(0,0,0,.5);
}
.discord-card-meta { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.discord-card-eyebrow {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10.5px; font-weight: 500;
  letter-spacing: .18em;
  color: var(--blurple-2);
}
.discord-card-title {
  font-size: 20px; font-weight: 800; color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  letter-spacing: -.01em;
}
.discord-card-presence {
  font-size: 13px; color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 8px;
  font-variant-numeric: tabular-nums;
}
.discord-card-presence strong { color: var(--ink); font-weight: 700; }
.dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.dot-online {
  background: var(--green);
  box-shadow: 0 0 0 3px rgba(67,181,129,.25);
  animation: pulse-green 2.2s infinite;
}

.discord-card-divider {
  height: 1px; background: linear-gradient(90deg, transparent, rgba(201,168,76,.2), transparent);
}

.discord-card-members {
  display: flex; flex-wrap: wrap; gap: 8px;
  min-height: 44px;
}
.discord-card-members .av {
  position: relative;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: #1a2547;
  border: 2px solid var(--navy-card);
  background-size: cover; background-position: center;
  transition: transform .2s var(--easing);
}
.discord-card-members .av:hover { transform: translateY(-2px) scale(1.06); z-index: 2; }
.discord-card-members .av .av-status {
  position: absolute; bottom: -1px; right: -1px;
  width: 12px; height: 12px;
  border-radius: 50%;
  border: 2px solid var(--navy-card);
}
.av-status.s-online { background: var(--green); }
.av-status.s-idle   { background: #faa61a; }
.av-status.s-dnd    { background: #f04747; }
.av-status.s-offline{ background: #747f8d; }
.av-more {
  width: 36px; height: 36px; border-radius: 50%;
  display: grid; place-items: center;
  background: rgba(201,168,76,.1);
  color: var(--gold-bright);
  border: 2px solid var(--navy-card);
  font-size: 11px; font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.avatar-skeleton {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.10), rgba(255,255,255,.04));
  background-size: 200% 100%;
  animation: shimmer-skel 1.4s infinite;
}
@keyframes shimmer-skel {
  to { background-position: -200% 0; }
}

.discord-card-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
.invite-code {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 12.5px; color: var(--ink-dim);
}
.invite-code strong { color: var(--gold-bright); font-weight: 600; }
.discord-card-action {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 16px;
  border-radius: 999px;
  background: var(--blurple);
  color: white; font-weight: 700; font-size: 14px;
  transition: background .2s, transform .2s;
}
.tilt:hover .discord-card-action { background: var(--blurple-2); transform: translateX(2px); }
.discord-card-arrow { font-weight: 800; }

@media (max-width: 540px) {
  .discord-card-top { grid-template-columns: auto 1fr; }
}

/* =========================================================
   Marquee
   ========================================================= */
.marquee {
  position: relative;
  margin: 32px 0 0;
  padding: 22px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(6,15,35,.5);
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
}
.marquee-track {
  display: inline-flex; gap: 28px;
  white-space: nowrap;
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: clamp(20px, 2.6vw, 30px);
  color: var(--gold-bright);
  animation: scroll-x 38s linear infinite;
}
.marquee-track span { padding: 0 6px; }
.marquee-dot { color: var(--blurple-2); opacity: .7; font-style: normal; font-size: 0.7em; }
@keyframes scroll-x { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
}

/* =========================================================
   Sections
   ========================================================= */
.section { position: relative; padding: 120px 32px; }
.section-alt {
  background:
    linear-gradient(180deg, transparent 0%, rgba(6,15,35,.55) 30%, rgba(6,15,35,.55) 70%, transparent 100%);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section-final { padding: 80px 32px 140px; }
.section-inner { max-width: 1140px; margin: 0 auto; }

.eyebrow {
  display: inline-block;
  font-size: 11.5px; font-weight: 700;
  letter-spacing: .24em; text-transform: uppercase;
  color: var(--gold);
  padding: 0 0 14px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 26px;
}
.eyebrow-light { color: var(--gold-bright); border-bottom-color: rgba(201,168,76,.3); }
.section-title {
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(36px, 5.5vw, 64px);
  line-height: 1.04;
  letter-spacing: -.022em;
  margin: 0 0 22px;
  max-width: 22ch;
  color: var(--ink);
}
.section-title em { font-style: italic; color: var(--gold-bright); }
.section-lede {
  font-size: clamp(15px, 1.2vw, 17.5px);
  line-height: 1.7;
  color: var(--ink-soft);
  max-width: 680px;
  margin: 0 0 60px;
}

/* About */
.about-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 22px;
}
@media (max-width: 820px) { .about-grid { grid-template-columns: 1fr; } }

.about-card {
  position: relative;
  padding: 34px 28px 30px;
  border-radius: var(--radius);
  background: var(--bg-card);
  border: 1px solid var(--line);
  transition: transform .4s var(--easing), border-color .4s, background .4s;
  overflow: hidden;
}
.about-card::before {
  content: ""; position: absolute; inset: -1px;
  border-radius: var(--radius);
  background: linear-gradient(140deg, transparent, rgba(201,168,76,.5), transparent);
  opacity: 0; transition: opacity .4s var(--easing);
  -webkit-mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 1px;
  pointer-events: none;
}
.about-card:hover { transform: translateY(-5px); background: var(--bg-card-h); }
.about-card:hover::before { opacity: 1; }
.about-card-icon {
  margin-bottom: 22px;
  display: inline-grid; place-items: center;
  width: 56px; height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(201,168,76,.18), rgba(88,101,242,.18));
  border: 1px solid var(--line-strong);
  color: var(--gold-bright);
}
.about-card h3 {
  margin: 0 0 10px; font-size: 19px; font-weight: 700;
  color: var(--ink); letter-spacing: -.01em;
}
.about-card p { margin: 0; line-height: 1.65; color: var(--ink-soft); font-size: 15px; }

/* Pillars */
.pillars {
  display: grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 14px;
}
@media (max-width: 1100px) { .pillars { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .pillars { grid-template-columns: 1fr; } }

.pillar {
  position: relative;
  padding: 26px 22px 60px;
  border-radius: var(--radius);
  background: rgba(11,31,58,.65);
  border: 1px solid var(--line);
  transition: transform .35s var(--easing), border-color .35s, background .35s;
  display: block;
}
.pillar:hover { transform: translateY(-5px); border-color: var(--gold); background: rgba(11,31,58,.92); }
.pillar-num {
  font-family: 'Instrument Serif', serif;
  font-size: 38px;
  color: var(--gold);
  font-style: italic;
  display: block; margin-bottom: 14px;
  line-height: 1;
}
.pillar h3 { margin: 0 0 8px; font-size: 17px; font-weight: 700; color: var(--ink); }
.pillar p { margin: 0; font-size: 14px; line-height: 1.55; color: var(--ink-soft); }
.pillar-link {
  position: absolute; left: 22px; right: 22px; bottom: 20px;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12.5px; font-weight: 600;
  color: var(--gold-bright);
  letter-spacing: .02em;
}
.pillar-link i { font-style: normal; transition: transform .25s var(--easing); display: inline-block; }
.pillar:hover .pillar-link i { transform: translateX(3px); }
.pillar-link-mute { color: var(--ink-dim); }

/* =========================================================
   Live now
   ========================================================= */
.live-wrap {
  position: relative;
  padding: 1px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(88,101,242,.5), rgba(201,168,76,.4));
  box-shadow: var(--shadow-glow);
}
.live-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
  padding: 28px;
  background: linear-gradient(155deg, #0e1732 0%, #07122a 100%);
  border-radius: calc(var(--radius-lg) - 1px);
  min-height: 200px;
}
.live-empty {
  padding: 60px 28px; text-align: center;
  color: var(--ink-soft); font-size: 16px;
  background: linear-gradient(155deg, #0e1732 0%, #07122a 100%);
  border-radius: calc(var(--radius-lg) - 1px);
}
.live-card {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.05);
  transition: transform .25s var(--easing), border-color .25s, background .25s;
  overflow: hidden;
  min-width: 0;
}
.live-card:hover { transform: translateY(-2px); border-color: var(--line-strong); background: rgba(255,255,255,.05); }
.live-card .lc-av {
  position: relative;
  width: 38px; height: 38px;
  border-radius: 50%;
  background-size: cover; background-position: center;
  background-color: #1a2547;
  flex-shrink: 0;
}
.live-card .lc-av .av-status {
  position: absolute; bottom: -1px; right: -1px;
  width: 12px; height: 12px;
  border-radius: 50%;
  border: 2px solid #0e1732;
}
.lc-meta { min-width: 0; display: flex; flex-direction: column; }
.lc-name { color: var(--ink); font-weight: 600; font-size: 13.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lc-act  { color: var(--ink-dim); font-size: 11.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lc-act strong { color: var(--gold-bright); font-weight: 500; }

.live-foot {
  position: absolute; top: 12px; right: 16px;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; color: var(--ink-dim);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.live-foot-bar {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 3px rgba(67,181,129,.22);
  animation: pulse-green 2.2s infinite;
}

/* =========================================================
   FAQ
   ========================================================= */
.faq {
  display: grid;
  gap: 10px;
  max-width: 820px;
}
.faq-item {
  position: relative;
  border-radius: var(--radius);
  background: var(--bg-card);
  border: 1px solid var(--line);
  overflow: hidden;
  transition: border-color .25s, background .25s;
}
.faq-item[open] { background: var(--bg-card-h); border-color: var(--line-strong); }
.faq-item summary {
  cursor: pointer;
  padding: 20px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  font-size: 16px; font-weight: 600; color: var(--ink);
  list-style: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-plus {
  position: relative;
  width: 22px; height: 22px;
  flex-shrink: 0;
}
.faq-plus::before, .faq-plus::after {
  content: ""; position: absolute; inset: 0; margin: auto;
  background: var(--gold-bright);
  transition: transform .3s var(--easing), opacity .3s;
}
.faq-plus::before { width: 14px; height: 2px; top: 10px; }
.faq-plus::after  { width: 2px; height: 14px; left: 10px; }
.faq-item[open] .faq-plus::after { transform: rotate(90deg); opacity: 0; }
.faq-body {
  padding: 0 24px 22px;
  color: var(--ink-soft);
  font-size: 15px; line-height: 1.65;
}
.faq-body a { color: var(--gold-bright); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.faq-body em { color: var(--gold-bright); font-style: normal; font-weight: 500; }
.faq-body strong { color: var(--ink); }

/* =========================================================
   Final join
   ========================================================= */
.join {
  position: relative;
  border-radius: 36px;
  padding: 1.5px;
  background: linear-gradient(135deg, var(--blurple) 0%, var(--gold) 100%);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
}
.join-glow {
  position: absolute; inset: -50px;
  background:
    radial-gradient(circle at 20% 30%, rgba(88,101,242,.5), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(201,168,76,.4), transparent 50%);
  filter: blur(50px);
  pointer-events: none;
}
.join-content {
  position: relative;
  border-radius: 34.5px;
  background: linear-gradient(155deg, #0e1732 0%, #060f23 100%);
  padding: 72px 56px;
  text-align: center;
}
@media (max-width: 720px) { .join-content { padding: 48px 24px; } }

.join-title {
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(40px, 6.5vw, 78px);
  line-height: 1.05;
  letter-spacing: -.022em;
  margin: 0 0 22px;
  color: var(--ink);
}
.join-title em { font-style: italic; color: var(--gold-bright); }
.join-lede {
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.7;
  color: var(--ink-soft);
  max-width: 640px;
  margin: 0 auto 38px;
}
.join-lede strong { color: var(--ink); font-weight: 600; }
.join-invite {
  margin: 26px 0 0;
  font-size: 13px;
  color: var(--ink-dim);
  letter-spacing: .04em;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.join-invite strong { color: var(--gold-bright); font-weight: 600; }

/* =========================================================
   Footer
   ========================================================= */
.foot {
  position: relative; z-index: 2;
  border-top: 1px solid var(--line);
  padding: 36px 32px;
  background: rgba(3,8,26,.7);
}
.foot-inner {
  max-width: 1240px; margin: 0 auto;
  display: flex; flex-wrap: wrap; gap: 22px;
  align-items: center; justify-content: space-between;
  font-size: 13.5px;
}
.foot-brand { display: flex; flex-direction: column; gap: 4px; }
.foot-brand-row { display: inline-flex; align-items: center; gap: 10px; }
.foot-mark {
  display: inline-grid; place-items: center;
  width: 26px; height: 26px; border-radius: 7px;
  background: linear-gradient(135deg, var(--gold), var(--gold-bright));
  color: var(--navy); font-weight: 900; font-size: 11px;
}
.foot-brand strong { color: var(--ink); font-weight: 700; font-size: 14.5px; }
.foot-brand span { color: var(--ink-dim); font-size: 12.5px; }
.foot-links { display: flex; gap: 22px; flex-wrap: wrap; }
.foot-links a { color: var(--ink-soft); transition: color .2s; }
.foot-links a:hover { color: var(--gold-bright); }
.foot-meta { color: var(--ink-dim); display: flex; gap: 10px; }
.foot-dot { opacity: .5; }

/* =========================================================
   Stagger reveal
   ========================================================= */
.stagger {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s var(--easing), transform .7s var(--easing);
  transition-delay: calc(var(--stagger, 1) * 80ms);
}
.stagger.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .stagger { opacity: 1; transform: none; transition: none; }
}
