:root {
  --bg: #081018;
  --bg-2: #0d1622;
  --surface: #121b29;
  --surface-2: #182233;
  --surface-3: #1d293d;
  --line: rgba(255, 255, 255, 0.1);
  --line-strong: rgba(212, 175, 55, 0.32);
  --text: #f5f7fb;
  --muted: #b8c2d3;
  --faint: #7e8aa1;
  --gold: #d4af37;
  --gold-soft: #f0d67a;
  --green: #2fb36f;
  --shadow-lg: 0 30px 90px rgba(0, 0, 0, 0.42);
  --radius-xl: 32px;
  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --ease: 220ms cubic-bezier(0.16, 1, 0.3, 1);
  --max: 1260px;
}

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

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(212,175,55,0.07), transparent 32%),
    linear-gradient(180deg, #071018 0%, #0c1320 48%, #101827 100%);
}

button,
a {
  font: inherit;
}

.dynasty-shell {
  min-height: 100vh;
}

.stadium-hero {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background:
    radial-gradient(circle at top center, rgba(212,175,55,0.08), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0)),
    linear-gradient(160deg, #09111a 0%, #0b1220 45%, #11192a 100%);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8,12,18,0.16), rgba(8,12,18,0.4)),
    radial-gradient(circle at 80% 20%, rgba(212,175,55,0.06), transparent 24%);
  pointer-events: none;
}

.hero-inner,
.hero-inner {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 48px;
  max-width: var(--max);
  margin: 0 auto;
  padding: 80px 40px 80px;
  position: relative;
}

.hero-copy {
  flex: 1;
  max-width: 560px;
}

.hero-kicker {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 14px;
}

.hero-inner h1 {
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  line-height: 1.1;
  margin: 0 0 20px;
  color: var(--text);
}

.hero-inner h1 span {
  color: var(--gold);
}

.hero-lede {
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--muted);
  margin: 0 0 32px;
  max-width: 480px;
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.hero-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--gold);
  color: #111;
  font-size: 0.9rem;
  font-weight: 600;
  padding: 13px 26px;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  transition: background var(--ease), transform var(--ease), box-shadow var(--ease);
  box-shadow: 0 0 0 0 rgba(212,175,55,0);
}

.hero-cta:hover {
  background: var(--gold-soft);
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(212,175,55,0.28);
}

.hero-secondary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--muted);
  text-decoration: none;
  padding: 12px 22px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  transition: color var(--ease), border-color var(--ease), background var(--ease);
}

.hero-secondary:hover {
  color: var(--text);
  border-color: rgba(255,255,255,0.22);
  background: rgba(255,255,255,0.04);
}

.hero-trust {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.hero-trust span {
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--faint);
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.02);
}

.hero-visual {
  flex: 0 0 440px;
  width: 440px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.stadium-frame {
  position: relative;
  width: 400px;
  height: 400px;
}

.stadium-rings {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(212,175,55,0.14);
  box-shadow:
    inset 0 0 0 28px rgba(212,175,55,0.03),
    inset 0 0 0 70px rgba(212,175,55,0.02),
    0 0 60px rgba(212,175,55,0.06);
}

.stadium-core {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 230px;
  height: 230px;
  border-radius: 50%;
  border: 1px solid rgba(212,175,55,0.12);
  background:
    radial-gradient(circle at center, rgba(212,175,55,0.06), transparent 72%),
    rgba(8,16,24,0.9);
  box-shadow:
    0 0 40px rgba(212,175,55,0.06),
    inset 0 0 30px rgba(8,16,24,0.8);
}

.stadium-entry-glow {
  position: absolute;
  bottom: 15%;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 150px;
  background: radial-gradient(circle at 50% 70%, rgba(212,175,55,0.34), transparent 65%);
  filter: blur(8px);
  animation: breatheGlow 3.4s ease-in-out infinite;
}

.stadium-path {
  position: absolute;
  left: 12%;
  right: 12%;
  bottom: 16%;
  display: flex;
  align-items: center;
}

.path-line {
  flex: 1;
  height: 2px;
  background: linear-gradient(90deg, rgba(255,255,255,0.14), rgba(212,175,55,0.26));
}

.path-node {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgba(255,255,255,0.22);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.03);
}

.path-node.is-gate,
.path-node.is-elevator,
.path-node.is-rooms {
  background: var(--gold);
}

.path-node.is-scoreboard {
  background: var(--green);
}

.stadium-label {
  position: absolute;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(7, 12, 20, 0.74);
}

.stadium-label-a {
  left: 8%;
  bottom: 24%;
}

.stadium-label-b {
  left: 32%;
  bottom: 30%;
}

.stadium-label-c {
  right: 10%;
  top: 18%;
}

.stadium-main {
  padding: 0 0 64px;
}

.section-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 40px;
}

.stadium-section {
  padding: 64px 0;
}

.intro-strip {
  border-bottom: 1px solid var(--line);
}

.intro-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.intro-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 32px;
}

.card-kicker {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 10px;
}

.intro-card h2 {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1.35rem;
  line-height: 1.3;
  margin: 0 0 12px;
  color: var(--text);
}

.intro-card p {
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--muted);
  margin: 0;
}

.launch-strip {
  background: var(--surface);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.launch-panel {
  display: flex;
  align-items: center;
  gap: 48px;
}

.launch-copy {
  flex: 1;
}

.launch-copy h2 {
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.2;
  margin: 0 0 16px;
}

.launch-copy p:not(.card-kicker) {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--muted);
  margin: 0 0 28px;
}

.launch-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--gold);
  color: #111;
  font-size: 0.9rem;
  font-weight: 600;
  padding: 13px 26px;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--ease), transform var(--ease);
}

.launch-btn:hover {
  background: var(--gold-soft);
  transform: translateY(-1px);
}

@keyframes breatheGlow {
  0%, 100% { opacity: 0.6; transform: translateX(-50%) scale(0.95); }
  50% { opacity: 1; transform: translateX(-50%) scale(1.05); }
}

@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(212,175,55,0.3); }
  50% { box-shadow: 0 0 0 8px rgba(212,175,55,0); }
}

.parking-lot {
  position: relative;
  width: min(480px, 100%);
  height: 300px;
  border-radius: 18px;
  overflow: hidden;
  background: var(--surface-2);
  border: 1px solid var(--line);
}

.parking-lot .car {
  position: absolute;
  bottom: 16%;
  width: 86px;
  height: 28px;
  border-radius: 999px 999px 16px 16px;
  background: linear-gradient(180deg, #2a3447 0%, #151d2b 100%);
  border: 1px solid rgba(255,255,255,0.08);
}

.parking-lot .car::before,
.parking-lot .car::after {
  content: "";
  position: absolute;
  top: 9px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(241, 206, 101, 0.5);
  filter: blur(1px);
}

.parking-lot .car::before { left: 8px; }
.parking-lot .car::after { right: 8px; }
.parking-lot .car-a { left: 14%; }
.parking-lot .car-b { left: 34%; bottom: 22%; }
.parking-lot .car-c { right: 19%; bottom: 20%; }

.parking-lot .stadium-shell {
  position: absolute;
  top: 13%;
  left: 50%;
  transform: translateX(-50%);
  width: min(72%, 560px);
  height: 160px;
  border-radius: 120px 120px 30px 30px;
  border: 1px solid rgba(212,175,55,0.18);
  background:
    radial-gradient(circle at 50% 10%, rgba(212,175,55,0.16), transparent 55%),
    linear-gradient(180deg, #1c2638 0%, #0f1623 100%);
  box-shadow:
    0 0 0 10px rgba(255,255,255,0.02),
    0 24px 70px rgba(0,0,0,0.35);
}

/* ===== Victoria's Nickel Tour — Modal ===== */
.nickel-tour-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;visibility:hidden;opacity:0;transition:opacity .22s ease, visibility 0s linear .22s;}
.nickel-tour-modal[aria-hidden="false"]{visibility:visible;opacity:1;transition:opacity .22s ease;}
.tour-backdrop{position:absolute;inset:0;background:radial-gradient(circle at 50% 30%, rgba(212,175,55,.08), rgba(8,16,24,.92) 60%);backdrop-filter:blur(6px);}
.tour-container{position:relative;width:min(720px,100%);max-height:90vh;overflow:auto;background:var(--surface-2,#182233);border:1px solid var(--line-strong,rgba(212,175,55,.32));border-radius:18px;padding:32px 32px 24px;color:var(--text,#f5f7fb);box-shadow:0 30px 80px rgba(0,0,0,.55);transform:translateY(8px);transition:transform .22s ease;}
.nickel-tour-modal[aria-hidden="false"] .tour-container{transform:translateY(0);}
.tour-container.stepping{opacity:.6;transition:opacity .12s ease;}
.tour-close{position:absolute;top:12px;right:14px;background:transparent;border:0;color:var(--muted,#b8c2d3);font-size:28px;line-height:1;cursor:pointer;}
.tour-close:hover{color:var(--gold,#d4af37);}
.tour-eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold,#d4af37);margin:0 0 8px;}
.tour-title{font-family:"Playfair Display",Georgia,serif;font-size:28px;line-height:1.15;margin:0 0 10px;}
.tour-desc{color:var(--muted,#b8c2d3);margin:0 0 18px;font-size:15px;}
.tour-detail{background:var(--bg-2,#0d1622);border:1px solid var(--line, rgba(255,255,255,.1));border-radius:12px;padding:16px 18px;margin:0 0 18px;font-size:14px;color:var(--text,#f5f7fb);}
.tour-detail ul{margin:0;padding-left:18px;}
.tour-detail li{margin:4px 0;}
.tour-victoria{border-left:3px solid var(--gold,#d4af37);padding:6px 0 6px 14px;}
.tour-victoria-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint,#7e8aa1);margin:0 0 6px;}
.tour-victoria-line{margin:0 0 6px;font-style:italic;font-size:15px;color:var(--text,#f5f7fb);}
.tour-victoria-notes{margin:0;color:var(--muted,#b8c2d3);font-size:13px;}
.tour-progress{display:flex;gap:10px;justify-content:center;margin:0 0 18px;}
.tour-dot{width:10px;height:10px;border-radius:50%;border:1px solid var(--line-strong,rgba(212,175,55,.32));background:transparent;padding:0;cursor:pointer;transition:background .18s ease, transform .18s ease;}
.tour-dot.active{background:var(--gold,#d4af37);transform:scale(1.15);}
.tour-dot:last-child.active{background:#6ad48a;}
.tour-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:8px;border-top:1px solid var(--line, rgba(255,255,255,.08));}
.tour-foot-right{display:flex;gap:8px;}
.tour-btn{font:inherit;font-weight:600;font-size:14px;padding:10px 16px;border-radius:999px;cursor:pointer;border:1px solid var(--line-strong,rgba(212,175,55,.32));background:transparent;color:var(--text,#f5f7fb);transition:background .15s ease, color .15s ease, border-color .15s ease;}
.tour-btn:hover{background:rgba(212,175,55,.08);}
.tour-btn[disabled]{opacity:.35;cursor:not-allowed;}
.tour-btn-ghost{background:transparent;}
.tour-btn-gold{background:var(--gold,#d4af37);color:#111;border-color:var(--gold,#d4af37);}
.tour-btn-gold:hover{background:#e8c75a;color:#111;border-color:#e8c75a;}
.tour-btn[hidden]{display:none;}
@media (max-width:640px){.tour-container{padding:22px 18px 16px;border-radius:14px;} .tour-title{font-size:22px;} .tour-foot{flex-wrap:wrap;}}