/* ============================================================
   LUMIÈRE — shared design system
   Obsidian / Lumière Gold / warm ivory, grounded in stone.
   The page is a walk from the street to the rear of the club:
   luminous and open at the top, quiet and low by the end.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --obsidian:   #0E0D0A;
  --ink:        #14110B;
  --surface:    #1B1710;
  --surface-2:  #241E15;
  --gold:       #C9A96E;
  --gold-soft:  #DAC18D;
  --gold-deep:  #94774A;
  --ivory:      #F0E9DC;
  --stone:      #C7BAA4;   /* travertine — the material the wet zone is clad in */
  --mist:       rgba(240,233,220,0.56);
  --mist-soft:  rgba(240,233,220,0.40);
  --muted:      #9D9384;
  --muted-dim:  #7A7062;
  --border:     rgba(201,169,110,0.16);
  --border-soft:rgba(201,169,110,0.08);
  --hair:       rgba(240,233,220,0.07);

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
  --script:'Italianno', 'Cormorant Garamond', cursive;

  --edge: clamp(24px, 5vw, 56px);   /* page side padding */
}

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; }

body {
  background: var(--obsidian);
  color: var(--ivory);
  font-family: var(--sans);
  font-weight: 300;
  letter-spacing: 0.01em;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  position: relative;
}

/* dawn (top) → dusk (lower), the light walking through the day */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 90% 48% at 12% -8%, rgba(201,169,110,0.085), transparent 60%),
    radial-gradient(ellipse 60% 45% at 96% 4%, rgba(148,119,74,0.05), transparent 55%);
}
/* fine grain */
body::after {
  content: '';
  position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: 0.045;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
nav, section, footer, .band, .map-grid, .quiet-block, .page-hero { position: relative; z-index: 2; }

::selection { background: rgba(201,169,110,0.26); color: var(--ivory); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
img, svg, video, iframe { display: block; max-width: 100%; }
a { color: inherit; }

/* ── NAV ─────────────────────────────────────────────── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 26px var(--edge);
  display: flex; justify-content: space-between; align-items: center;
  background: var(--obsidian);
  transition: padding .4s ease, border-color .4s ease;
  border-bottom: 1px solid var(--border-soft);
}
nav.scrolled { padding: 16px var(--edge); background: var(--obsidian); border-bottom-color: var(--border); }
.nav-logo { display: inline-flex; align-items: center; text-decoration: none; }
.nav-logo img { height: 36px; width: auto; transition: height .4s ease; }
nav.scrolled .nav-logo img { height: 28px; }
.nav-right { display: flex; align-items: center; gap: 28px; }
.nav-links { display: flex; align-items: center; gap: 26px; }
.nav-links a {
  color: var(--mist-soft); text-decoration: none; font-size: 10px;
  letter-spacing: 0.24em; text-transform: uppercase; transition: color .4s;
}
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--gold); }
.nav-divider { width: 1px; height: 14px; background: var(--border); }
.nav-cta {
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ivory);
  text-decoration: none; border-bottom: 1px solid var(--gold-deep); padding-bottom: 3px;
  transition: color .4s, border-color .4s; white-space: nowrap;
}
.nav-cta:hover { color: var(--gold); border-color: var(--gold); }

/* luxury icon-only trigger (no label) — tapered lines */
.menu-trigger { background: none; border: none; cursor: pointer; padding: 8px 2px; display: inline-flex; align-items: center; }
.menu-icon { display: flex; flex-direction: column; gap: 6px; width: 28px; }
.menu-icon span { display: block; height: 1px; background: var(--ivory); transition: background .4s, width .45s cubic-bezier(.2,.7,.2,1); }
.menu-icon span:nth-child(1) { width: 28px; }
.menu-icon span:nth-child(2) { width: 19px; margin-left: auto; }
.menu-icon span:nth-child(3) { width: 28px; }
.menu-trigger:hover .menu-icon span { background: var(--gold); width: 28px; }
.menu-trigger:hover .menu-icon span:nth-child(2) { margin-left: auto; }

/* MENU OVERLAY — sweeps in from the right; Apply pinned to the bottom */
.menu-overlay {
  position: fixed; inset: 0; z-index: 200;
  transform: translateX(100%); visibility: hidden;
  transition: transform .5s cubic-bezier(.16,.84,.34,1), visibility .5s;
  background:
    radial-gradient(ellipse 130% 50% at 50% 0%, rgba(201,169,110,0.08), transparent 60%),
    #0B0A07;
  display: flex; flex-direction: column;
  overscroll-behavior: contain;
}
body.menu-open { position: fixed; left: 0; right: 0; width: 100%; overflow: hidden; }
body.menu-open .menu-overlay { transform: translateX(0); visibility: visible; }

/* top bar: wordmark + close */
.menu-bar {
  flex: 0 0 auto;
  position: relative; z-index: 2; background: #0B0A07;
  display: flex; justify-content: space-between; align-items: center;
  padding: max(20px, env(safe-area-inset-top)) var(--edge) 16px;
  border-bottom: 1px solid var(--border-soft);
}
.menu-bar .nav-logo img { height: 34px; }
.menu-close { display: inline-flex; align-items: center; gap: 11px; background: none; border: none; cursor: pointer;
  font-family: var(--sans); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--ivory);
  padding: 8px 0; line-height: 1; transition: color .35s; }
.menu-close .mc-x { font-size: 22px; line-height: 1; }
.menu-close:hover { color: var(--gold); }

/* logo text fallback (only shown if the wordmark image fails to load) */
.logo-fallback { font-family: var(--script); font-size: 32px; line-height: 1; color: var(--gold); white-space: nowrap; }
.menu-bar .logo-fallback { font-size: 30px; }
.footer-logo .logo-fallback { font-size: 36px; }
nav.scrolled .logo-fallback { font-size: 26px; }

/* scrolling nav zone (top-aligned list) */
.menu-body {
  flex: 1 1 auto; min-height: 0; overflow-y: auto; -webkit-overflow-scrolling: touch;
  display: flex; flex-direction: column; justify-content: flex-start;
  width: 100%; max-width: 1100px; margin: 0 auto;
  padding: 8px var(--edge);
}
/* reset properties leaking from the global `nav` rule onto this in-overlay nav */
.menu-nav { position: static; z-index: auto; background: none; border: 0; padding: 0;
  display: flex; flex-direction: column; align-items: center; width: 100%; margin: auto 0; }
.menu-link {
  font-family: var(--serif); font-weight: 300; line-height: 1;
  font-size: clamp(32px, 7vw, 56px); letter-spacing: -0.01em;
  color: var(--ivory); text-decoration: none;
  padding: clamp(16px, 2.4vw, 22px) 0;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: baseline; justify-content: space-between;
  opacity: 0; transform: translateX(26px);
  transition: color .4s, opacity .55s cubic-bezier(.2,.7,.2,1), transform .55s cubic-bezier(.2,.7,.2,1);
}
.menu-nav .menu-link:first-child { border-top: 1px solid var(--border); }
.menu-link::after { content: '\2192'; font-family: var(--sans); font-size: 0.34em; color: var(--gold-deep);
  opacity: 0; transform: translateX(-8px); transition: opacity .4s, transform .4s, color .4s; align-self: center; }
.menu-link:hover { color: var(--gold); }
.menu-link:hover::after { opacity: 1; transform: translateX(0); color: var(--gold); }
body.menu-open .menu-link { opacity: 1; transform: translateX(0); }
body.menu-open .menu-link:nth-child(1) { transition-delay: .20s; }
body.menu-open .menu-link:nth-child(2) { transition-delay: .27s; }
body.menu-open .menu-link:nth-child(3) { transition-delay: .34s; }
body.menu-open .menu-link:nth-child(4) { transition-delay: .41s; }

/* pinned bottom: Apply + contact */
.menu-bottom {
  flex: 0 0 auto;
  position: relative; z-index: 2; background: #0B0A07;
  border-top: 1px solid var(--border);
  padding: 22px var(--edge) calc(26px + env(safe-area-inset-bottom));
  display: flex; flex-direction: column; gap: 16px;
  opacity: 0; transition: opacity .5s ease .34s;
}
body.menu-open .menu-bottom { opacity: 1; }
.menu-apply { display: block; text-align: center; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--obsidian); background: var(--gold); text-decoration: none; padding: 19px 38px; transition: background .4s, transform .3s; }
.menu-apply:hover { background: var(--gold-soft); transform: translateY(-2px); }
.menu-contact { font-size: 11px; color: var(--muted); letter-spacing: 0.08em; line-height: 1.9; text-align: center; }
.menu-contact a { color: var(--gold-deep); text-decoration: none; transition: color .4s; }
.menu-contact a:hover { color: var(--gold); }
@media (prefers-reduced-motion: reduce) {
  .menu-overlay { transition: visibility .2s; }
  .menu-link, .menu-bottom { transition: color .3s; opacity: 1; transform: none; }
}

/* ── TYPE PRIMITIVES ─────────────────────────────────── */
.eyebrow {
  font-size: 10px; letter-spacing: 0.4em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 20px;
}
.rule { width: 50px; height: 1px; background: var(--gold-deep); margin-bottom: 28px; }
.rule.center { margin-left: auto; margin-right: auto; }
.title {
  font-family: var(--serif); font-weight: 300; line-height: 1.06;
  font-size: clamp(36px, 4.2vw, 60px); letter-spacing: -0.012em; color: var(--ivory);
}
.title em { font-style: italic; color: var(--gold); }
.lead { font-size: 15px; color: var(--mist); line-height: 1.95; max-width: 52ch; }
.prose p { font-size: 15px; color: var(--mist); line-height: 2; margin-bottom: 22px; max-width: 60ch; }
.prose p:last-child { margin-bottom: 0; }
.prose em { color: var(--gold); font-style: italic; }

/* ── SECTIONS / LAYOUT ───────────────────────────────── */
section { padding: clamp(80px, 11vw, 132px) var(--edge); }
.wrap { max-width: 1180px; margin: 0 auto; }
.split {
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 88px); align-items: center;
}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn {
  background: var(--gold); color: var(--obsidian); font-family: var(--sans);
  font-size: 11px; font-weight: 400; letter-spacing: 0.22em; text-transform: uppercase;
  text-decoration: none; padding: 17px 40px; display: inline-block; border: none; cursor: pointer;
  transition: background .4s, transform .3s, box-shadow .4s;
}
.btn:hover { background: var(--gold-soft); transform: translateY(-2px); box-shadow: 0 16px 42px rgba(201,169,110,0.16); }
.btn-ghost {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mist);
  text-decoration: none; border-bottom: 1px solid rgba(240,233,220,0.2); padding-bottom: 3px;
  transition: color .4s, border-color .4s;
}
.btn-ghost:hover { color: var(--ivory); border-color: var(--gold); }
.btn-full {
  display: block; width: 100%; text-align: center; background: var(--gold); color: var(--obsidian);
  font-family: var(--sans); font-size: 11px; font-weight: 400; letter-spacing: 0.22em;
  text-transform: uppercase; text-decoration: none; padding: 19px 24px; border: none; cursor: pointer;
  transition: background .4s, transform .3s;
}
.btn-full:hover { background: var(--gold-soft); transform: translateY(-2px); }

/* ── PAGE HERO (interior pages) ──────────────────────── */
.page-hero { padding: clamp(150px, 20vh, 220px) var(--edge) clamp(70px, 9vw, 110px); }
.page-hero-inner { max-width: 1180px; margin: 0 auto; }
.page-hero .title { font-size: clamp(42px, 6vw, 84px); }
.page-hero-sub { font-size: 16px; color: var(--mist); line-height: 1.9; max-width: 48ch; margin-top: 26px; }

/* ── QUIET BLOCK (the "light / meaning" pause) ───────── */
.quiet-block {
  text-align: center; padding: clamp(96px, 14vw, 168px) var(--edge);
  background:
    radial-gradient(ellipse 70% 120% at 50% 50%, rgba(201,169,110,0.06), transparent 70%),
    var(--ink);
  border-top: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft);
}
.q-script {
  font-family: var(--script); font-size: clamp(64px, 12vw, 150px); line-height: 0.9;
  color: var(--gold); font-weight: 400;
}
.q-script img { height: clamp(64px, 11vw, 120px); width: auto; margin: 0 auto; }
.q-word img { height: clamp(50px, 8vw, 84px); width: auto; margin: 0 auto; }
.q-phon { font-size: 12px; letter-spacing: 0.34em; text-transform: lowercase; color: var(--stone); margin-top: 8px; }
.q-rule { width: 44px; height: 1px; background: var(--gold-deep); margin: 30px auto; }
.q-mean { font-family: var(--serif); font-size: clamp(20px, 2.6vw, 30px); font-weight: 300; font-style: italic;
  color: rgba(240,233,220,0.84); line-height: 1.5; max-width: 22ch; margin: 0 auto; }
.q-word { font-family: var(--serif); font-size: clamp(28px, 4vw, 46px); font-weight: 300; color: var(--ivory); letter-spacing: 0.06em; }

/* ── INTEREST CAPTURE (soft lead) ────────────────────── */
.interest { padding: clamp(72px, 10vw, 120px) var(--edge); border-top: 1px solid var(--border-soft);
  background: radial-gradient(ellipse 70% 120% at 50% 50%, rgba(201,169,110,0.05), transparent 70%), var(--ink); text-align: center; }
.interest-inner { max-width: 640px; margin: 0 auto; }
.interest-title { font-family: var(--serif); font-weight: 300; font-size: clamp(32px, 4.5vw, 50px); color: var(--ivory); line-height: 1.05; margin: 6px 0 0; }
.interest-sub { font-size: 14px; color: var(--muted); line-height: 1.8; margin: 18px auto 30px; max-width: 48ch; }
.interest-form { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.interest-form input { flex: 1 1 220px; min-width: 0; background: rgba(0,0,0,0.25); border: 1px solid var(--border);
  color: var(--ivory); font-family: var(--sans); font-size: 14px; padding: 15px 18px; outline: none; transition: border-color .3s; }
.interest-form input:focus { border-color: var(--gold-deep); }
.interest-form input::placeholder { color: var(--muted-dim); }
.interest-submit { flex: 0 0 auto; background: var(--gold); color: var(--obsidian); border: none; cursor: pointer;
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; padding: 16px 34px; transition: background .3s, transform .3s; }
.interest-submit:hover { background: var(--gold-soft); transform: translateY(-2px); }
.interest-note { font-size: 11px; color: var(--muted-dim); letter-spacing: 0.04em; margin-top: 16px; }
.interest-success, .interest-error { font-size: 13px; margin-top: 18px; }
.interest-success { color: var(--gold); display: none; }
.interest-success.visible { display: block; }
.interest-error { color: #C98A6E; display: none; }
.interest-error.visible { display: block; }
@media (max-width: 520px) { .interest-submit { flex-basis: 100%; } }

/* ── MEDIA BAND (subpage imagery) ────────────────────── */
.media-band { width: 100%; height: clamp(280px, 48vh, 540px); overflow: hidden; position: relative; background: var(--ink); }
.media-band img, .media-band video { width: 100%; height: 100%; object-fit: cover; display: block; }
.media-band::after { content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(to top, rgba(14,13,10,0.55), transparent 55%); }
.media-band .band-caption { position: absolute; left: 0; right: 0; bottom: 0; padding: clamp(22px, 4vw, 44px) var(--edge);
  font-family: var(--serif); font-style: italic; font-weight: 300; font-size: clamp(18px, 2.4vw, 26px); color: var(--ivory); max-width: 1180px; margin: 0 auto; }

/* ── FOUNDING CLOSED (scarcity signal) ───────────────── */
.founding-closed {
  max-width: 1180px; margin: 0 auto 20px;
  display: flex; align-items: center; gap: 16px 20px; flex-wrap: wrap;
  padding: 16px 22px; border: 1px solid var(--border-soft); background: rgba(0,0,0,0.2);
}
.fc-tier { font-family: var(--serif); font-size: 18px; color: var(--mist); }
.fc-status { font-size: 9.5px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--muted);
  border: 1px solid var(--border); padding: 5px 13px; border-radius: 100px; }
.fc-note { font-size: 13px; color: var(--muted); letter-spacing: 0.02em; margin-left: auto; }
@media (max-width: 640px) { .fc-note { margin-left: 0; flex-basis: 100%; } }

/* ── CHARTER SHOWCASE ────────────────────────────────── */
.charter { max-width: 1180px; margin: 0 auto; }
.charter-card {
  position: relative; overflow: hidden;
  background: linear-gradient(158deg, rgba(201,169,110,0.11), rgba(201,169,110,0.025) 58%, rgba(0,0,0,0.10));
  border: 1px solid var(--border);
  padding: clamp(30px, 5vw, 58px);
}
.charter-card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--gold); }
.charter-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; flex-wrap: wrap; }
.charter-badge { font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold); border: 1px solid var(--gold-deep); padding: 7px 15px; border-radius: 100px; }
.charter-name { font-family: var(--serif); font-size: clamp(32px, 4.4vw, 50px); font-weight: 300; color: var(--ivory); line-height: 1; margin-top: 18px; }
.charter-price { font-family: var(--serif); font-size: clamp(30px, 4vw, 46px); color: var(--gold); font-weight: 300; white-space: nowrap; line-height: 1; }
.charter-price small { font-family: var(--sans); font-size: 13px; color: var(--muted); letter-spacing: 0.04em; }
.charter-hero-perk { margin: 28px 0 6px; padding: 18px 22px; background: rgba(201,169,110,0.09); border: 1px solid var(--border); display: flex; gap: 14px; align-items: center; }
.charter-hero-perk .gp { color: var(--gold); font-size: 16px; flex: 0 0 auto; }
.charter-hero-perk span.t { font-size: 15px; color: rgba(240,233,220,0.82); line-height: 1.5; }
.charter-hero-perk b { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: clamp(18px, 2.2vw, 23px); color: var(--ivory); }
.charter-incl { list-style: none; margin: 28px 0 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 13px 32px; }
.charter-incl li { position: relative; padding-left: 24px; font-size: 14px; color: rgba(240,233,220,0.82); line-height: 1.5; }
.charter-incl li::before { content: '\2726'; position: absolute; left: 0; top: 1px; color: var(--gold); font-size: 11px; }
.charter-foot { margin-top: 34px; display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.charter-foot .note { font-size: 12px; color: var(--muted); letter-spacing: 0.04em; }
.charter-alts { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 18px; }
.charter-alt { border: 1px solid var(--border-soft); padding: 24px 26px; background: rgba(0,0,0,0.16); }
.charter-alt .an { font-family: var(--serif); font-size: 23px; color: var(--ivory); font-weight: 400; }
.charter-alt .ap { color: var(--gold); font-size: 16px; margin-top: 2px; }
.charter-alt .ax { display: block; font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-top: 9px; }
.charter-alt small { display: block; font-size: 13px; color: rgba(240,233,220,0.7); margin-top: 10px; line-height: 1.55; }
@media (max-width: 720px) { .charter-incl, .charter-alts { grid-template-columns: 1fr; } }

/* ── VALUE ROWS (about) ──────────────────────────────── */
.value-row { display: grid; gap: 6px; padding: 26px 0; border-bottom: 1px solid var(--border-soft); }
.value-row:last-child { border-bottom: none; }
.value-label { font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); }
.value-title { font-family: var(--serif); font-size: 22px; font-weight: 400; color: var(--ivory); }
.value-text { font-size: 13.5px; color: var(--mist); line-height: 1.8; }

/* ── FAQ ACCORDION ───────────────────────────────────── */
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-cat { font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); margin: 54px 0 6px; }
.faq-cat:first-of-type { margin-top: 0; }
details.faq-item { border-bottom: 1px solid var(--border-soft); }
details.faq-item summary {
  list-style: none; cursor: pointer; padding: 26px 0; gap: 24px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--serif); font-size: clamp(19px, 2.2vw, 24px); font-weight: 400; color: var(--ivory);
  transition: color .35s;
}
details.faq-item summary::-webkit-details-marker { display: none; }
details.faq-item summary:hover { color: var(--gold); }
.faq-mark { position: relative; width: 14px; height: 14px; flex-shrink: 0; }
.faq-mark::before, .faq-mark::after { content: ''; position: absolute; background: var(--gold); transition: transform .35s; }
.faq-mark::before { top: 6px; left: 0; width: 14px; height: 1px; }
.faq-mark::after  { top: 0; left: 6px; width: 1px; height: 14px; }
details[open] .faq-mark::after { transform: scaleY(0); }
details[open] summary { color: var(--gold); }
.faq-a { padding: 0 0 28px; }
.faq-a p { font-size: 14px; color: var(--mist); line-height: 1.9; max-width: 70ch; }
.faq-a a { color: var(--gold); text-decoration: none; border-bottom: 1px solid var(--gold-deep); }

/* ── FOOTER ──────────────────────────────────────────── */
footer {
  padding: clamp(44px, 6vw, 60px) var(--edge);
  border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: flex-start; gap: 36px; flex-wrap: wrap;
}
.footer-left { display: flex; flex-direction: column; gap: 18px; }
.footer-logo img { height: 46px; width: auto; }
.footer-links { display: flex; flex-wrap: wrap; gap: 22px; }
.footer-links a { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); text-decoration: none; transition: color .4s; }
.footer-links a:hover { color: var(--gold); }
.footer-meta { font-size: 11px; color: var(--muted); letter-spacing: 0.1em; text-align: right; line-height: 1.95; }
.footer-meta .gold { color: var(--gold-deep); }
.footer-social { display: flex; gap: 22px; }
.footer-social a { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted);
  text-decoration: none; transition: color .4s; display: flex; align-items: center; gap: 8px; }
.footer-social a svg { width: 15px; height: 15px; fill: currentColor; }
.footer-social a:hover { color: var(--gold); }
.footer-right { display: flex; flex-direction: column; gap: 16px; align-items: flex-end; }
@media (max-width: 860px) { .footer-right { align-items: flex-start; } }

/* ── REVEAL ANIMATION ────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* ── RESPONSIVE ──────────────────────────────────────── */
@media (max-width: 860px) {
  .nav-links { display: none; }
  .split { grid-template-columns: 1fr; }
  .footer-meta { text-align: left; }
  footer { flex-direction: column; gap: 28px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
