:root {
  --bg: #0b1020;
  --ink: #e8ecf4;
  --muted: #b8c0d0;
  --primary: #22c55e;
  --primary-ink: #0b1020;
  --accent: #7c3aed;
  --danger: #ef4444;
  --card: #131a33;
  --stroke: #243159;
  --glow1: #22c55e;
  --glow2: #7c3aed;
  --glow3: #38bdf8;
  --stickybar-h: 46px;
  --nav-h: 50px;
}
* { box-sizing: border-box }
html, body { margin: 0; padding: 0; height: 100%; background: var(--bg); color: var(--ink); font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial, "Apple Color Emoji", "Segoe UI Emoji"; }
body { scroll-padding-top: calc(var(--nav-h) + var(--stickybar-h) + 10px) }
a { color: inherit }
img { max-width: 100%; height: auto; border: 0; display: block }
.container { width: 100%; max-width: 1100px; margin-left: auto; margin-right: auto; padding-left: 16px; padding-right: 16px }
.container.wide { max-width: 1240px }
.centered { text-align: center }
.section-narrow { max-width: 860px; margin: 0 auto }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; text-decoration: none; border-radius: 12px; padding: 14px 20px; font-weight: 700; transition: transform .08s ease, opacity .2s ease, box-shadow .2s ease, background .2s ease; will-change: transform, box-shadow }
.btn:active { transform: translateY(1px) }
.btn-primary { background: var(--primary); color: var(--primary-ink); box-shadow: 0 0 0 rgba(0,0,0,0) }
.btn-primary:hover { box-shadow: 0 10px 24px rgba(34,197,94,.25) }
.btn-primary:focus-visible { outline: 2px solid var(--glow3) }
.btn-outline { background: transparent; color: var(--ink); border: 1px solid var(--stroke) }
.eyebrow { color: var(--accent); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; font-size: 12px }
.muted { color: var(--muted) }
.card { background: linear-gradient(180deg, rgba(19,26,51,.9), rgba(19,26,51,.7)); border: 1px solid var(--stroke); border-radius: 16px; padding: 16px; position: relative; overflow: hidden }
.card::before { content:""; position:absolute; inset:-2px; border-radius:18px; background: conic-gradient(from 0deg, var(--glow1), var(--glow2), var(--glow3), var(--glow1)); filter: blur(16px); opacity:.2; z-index:0; animation: spinGlow 16s linear infinite }
.card:hover::before { opacity:.28 }
.card > * { position: relative; z-index: 1 }
.chip { border: 1px solid var(--stroke); color: var(--muted); padding: 6px 10px; border-radius: 999px; font-size: 12px }

/* Sticky bar */
.stickybar { position: sticky; top: var(--nav-h); z-index: 10001; backdrop-filter: blur(8px); background: linear-gradient(90deg, rgba(11,16,32,.88), rgba(17,28,55,.85)); border-bottom: 1px solid var(--stroke); transform: translateY(-100%); animation: slideDown .6s ease .2s forwards; min-height: var(--stickybar-h) }
.stickybar-inner { display: flex; gap: 12px; align-items: center; justify-content: space-between; padding: 10px 16px }
.stickybar-title { font-weight: 700; font-size: 14px }
.countdown { font-variant-numeric: tabular-nums; font-weight: 700; white-space: nowrap; color: var(--glow3) }

/* Top navigation */
.site-nav { position: sticky; top: 0; z-index: 10002; background: linear-gradient(90deg, rgba(12,19,40,.7), rgba(19,31,62,.7)); backdrop-filter: blur(8px); border-bottom: 1px solid var(--stroke) }
.site-nav .nav-inner { display:flex; gap:12px; align-items:center; justify-content:center; padding: 8px 12px; flex-wrap:wrap }
.site-nav a { color: var(--ink); text-decoration:none; font-weight:700; padding:8px 12px; border-radius:999px; border:1px solid transparent; background: rgba(124,58,237,.08) }
.site-nav a:hover { border-color: var(--stroke); background: rgba(34,197,94,.12) }

/* Hero */
.hero { position: relative; overflow: hidden; }
.hero-media { position: absolute; inset: 0; pointer-events: none; }
.hero-media::before { content: ""; position: absolute; inset: 0; background: radial-gradient(1200px 500px at 50% -20%, rgba(124,58,237,.4), rgba(34,197,94,.18) 40%, rgba(56,189,248,.12) 60%, transparent 75%); animation: gradientShift 12s ease-in-out infinite alternate }
.hero-bg { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 100%; height: 100%; opacity: .36; object-fit: cover; filter: saturate(1.2) brightness(1.08) contrast(1.08); will-change: transform }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,16,32,.45), rgba(11,16,32,.95) 65%); will-change: transform }
.hero-inner { position: relative; padding: 56px 0 28px; text-align: center }
.hero h1 { margin: 6px 0 10px; font-size: 36px; line-height: 1.1 }
.hero p.lede { font-size: 16px; color: var(--muted); margin: 0 0 16px }
.hero-ctas { display: grid; grid-template-columns: 1fr; gap: 10px; max-width: 460px; will-change: transform }
.hero-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px }
.dates { color: var(--muted); font-weight: 600 }

/* Value stack */
.values { display: grid; grid-template-columns: 1fr; gap: 10px; margin: 20px 0; justify-items: center }
.values .item { display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: center; text-align: center }
.values .item strong { font-size: 14px; color: #fff }
.values .item span { font-size: 13px; color: var(--muted) }

/* Ticket card */
.tickets { margin: 24px 0; text-align: center }
.price { font-size: 40px; font-weight: 800 }
.list { margin: 10px 0 0; padding: 0; list-style: none; color: var(--muted); text-align: center }
.list li { margin: 6px 0 }
/* Center the ticket card “frame” */
#tickets .card { max-width: 820px; margin: 0 auto }
/* Ensure the entire tickets card and its contents are perfectly centered */
#tickets { display: flex; justify-content: center; align-items: stretch }
#tickets .card { margin-left: auto; margin-right: auto; place-items: center; text-align: center }
#tickets .card .list { margin-left: auto; margin-right: auto }
#tickets .card .price { justify-self: center }
#tickets .card .eyebrow, #tickets .card h2 { justify-self: center }

/* Headliners grid */
.grid { display: grid; gap: 12px; justify-items: center }
.venue-grid { display:grid; gap:12px; grid-template-columns: 1fr }
.venue { border: 1px solid var(--stroke); border-radius: 12px; overflow: hidden; background: rgba(19,26,51,.5); transform: translateY(8px); opacity: 0; transition: transform .6s cubic-bezier(.22,.61,.36,1), opacity .6s ease; will-change: transform, opacity; position: relative }
.venue::before { content:""; position:absolute; inset:-2px; border-radius:14px; background: conic-gradient(from 0deg, rgba(34,197,94,.45), rgba(124,58,237,.45), rgba(56,189,248,.45), rgba(34,197,94,.45)); filter: blur(14px); opacity:.18; z-index:0; pointer-events:none; animation: spinGlow 20s linear infinite reverse }
.venue:hover::before { opacity:.26 }
.venue.is-visible { transform: none; opacity: 1 }
.venue figcaption { padding: 8px; font-size: 12px; text-align: center }
.venue img { width: 100%; height: auto; object-fit: cover; display:block }
/* Socials */
.socials { display:flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: center; margin-top: 12px }
.social-btn { display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:999px; border:1px solid var(--stroke); background: rgba(19,26,51,.6); transition: transform .08s ease, box-shadow .2s ease; }
.social-btn:active { transform: translateY(1px) }
.social-btn:hover { box-shadow: 0 10px 24px rgba(124,58,237,.25) }
.social-btn img { width:24px; height:24px; }
.grid.two { grid-template-columns: repeat(2, 1fr) }
.grid.three { grid-template-columns: repeat(3, 1fr) }
.artist { border: 1px solid var(--stroke); border-radius: 12px; overflow: hidden; background: linear-gradient(180deg, rgba(19,26,51,.55), rgba(19,26,51,.4)); transform: translateY(8px); opacity: 0; transition: transform .6s cubic-bezier(.22,.61,.36,1), opacity .6s ease; will-change: transform, opacity; position: relative }
.artist::before { content:""; position:absolute; inset:-2px; border-radius:14px; background: conic-gradient(from 90deg, rgba(124,58,237,.55), rgba(56,189,248,.45), rgba(34,197,94,.45), rgba(124,58,237,.55)); filter: blur(14px); opacity:.18; z-index:0; pointer-events:none; animation: spinGlow 22s linear infinite }
.artist:hover::before { opacity:.26 }
.artist.is-visible { transform: none; opacity: 1 }
.artist figcaption { padding: 8px; font-size: 12px; text-align: center }
.artist img { width: 100%; height: 120px; object-fit: cover }

/* Livestream capture */
.capture { display: grid; gap: 10px; }
.input { background: transparent; border: 1px solid var(--stroke); border-radius: 10px; color: var(--ink); padding: 12px 14px; width: 100% }

/* FAQ */
details { border: 1px solid var(--stroke); border-radius: 12px; padding: 12px 14px; background: rgba(19,26,51,.6); transform: translateY(8px); opacity: 0; transition: transform .6s cubic-bezier(.22,.61,.36,1), opacity .6s ease; will-change: transform, opacity; position: relative }
details::before { content:""; position:absolute; inset:-2px; border-radius:14px; background: conic-gradient(from 270deg, rgba(124,58,237,.4), rgba(56,189,248,.4), rgba(34,197,94,.4), rgba(124,58,237,.4)); filter: blur(12px); opacity:.16; z-index:0; pointer-events:none; animation: spinGlow 26s linear infinite }
details:hover::before { opacity:.22 }
details.is-visible { transform: none; opacity: 1 }
details + details { margin-top: 10px }
summary { cursor: pointer; font-weight: 700 }
summary::-webkit-details-marker { display: none }

/* Footer */
footer { color: var(--muted); font-size: 13px; padding: 48px 0 36px; margin-top: 28px; position: relative; overflow: hidden; border-top: 1px solid var(--stroke); background: radial-gradient(700px 300px at 0% 120%, rgba(34,197,94,.08), transparent 60%) }
footer::before { content:""; position:absolute; inset:0; background: radial-gradient(700px 300px at 10% -20%, rgba(124,58,237,.18), transparent 60%), radial-gradient(700px 300px at 90% 120%, rgba(34,197,94,.14), transparent 60%); opacity: .8; pointer-events:none }
.footer-inner { display:grid; gap:18px }
.footer-columns { display:grid; gap:18px; grid-template-columns: 1fr; }
.footer-col h4 { margin:0 0 8px; color:#fff; font-size:14px; letter-spacing:.02em }
.footer-col a { color: var(--ink); opacity:.9; text-decoration:none }
.footer-col a:hover { text-decoration:underline }
.footer-brand { display:flex; align-items:flex-start; gap:12px }
.footer-brand img { width:36px; height:36px; border-radius:8px }
.footer-note { color: var(--muted); margin: 6px 0 0; font-size: 13px }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; gap:10px; flex-wrap:wrap; margin-top:12px; color: var(--muted) }
@media (min-width: 720px) { .footer-columns { grid-template-columns: 2fr 1fr 1fr } }

/* Larger screens */
@media (min-width: 720px) {
  .hero-inner { padding: 84px 0 48px }
  .hero h1 { font-size: 48px }
  .values { grid-template-columns: repeat(3, 1fr) }
  .grid.three { grid-template-columns: repeat(6, 1fr) }
  .artist img { height: 140px }
  .venue-grid { grid-template-columns: repeat(2, 1fr) }
}

/* Animations */
@keyframes gradientShift {
  0% { transform: translateY(0) scale(1); opacity:.9 }
  100% { transform: translateY(-6%) scale(1.05); opacity:1 }
}
@keyframes slideDown {
  from { transform: translateY(-100%) }
  to { transform: translateY(0) }
}
@keyframes spinGlow {
  from { transform: rotate(0deg) }
  to { transform: rotate(360deg) }
}

.reveal { opacity: 0; transform: translateY(12px); transition: transform .7s cubic-bezier(.22,.61,.36,1), opacity .7s ease; will-change: transform, opacity }
.reveal.is-visible { opacity: 1; transform: none }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hero-media::before { animation: none }
  .card::before { animation: none }
  .stickybar { animation: none; transform: none }
  .reveal, .artist, details { transition: none; transform: none; opacity: 1 }
}

/* Global animated background with musical accent */
.bg-visual { position: fixed; inset: 0; z-index: -1; pointer-events: none; overflow: hidden }
.bg-visual::before { content:""; position:absolute; inset:-10%; background: radial-gradient(1200px 700px at 20% -10%, rgba(124,58,237,.25), transparent 60%), radial-gradient(1200px 700px at 80% 110%, rgba(34,197,94,.18), transparent 60%), radial-gradient(900px 500px at -10% 60%, rgba(56,189,248,.15), transparent 60%); filter: blur(2px); animation: bgPulse 18s ease-in-out infinite alternate }
.bg-visual::after { content:""; position:absolute; inset:0; background: repeating-linear-gradient( 135deg, rgba(124,58,237,.06) 0 40px, rgba(34,197,94,.04) 40px 80px, rgba(56,189,248,.04) 80px 120px ); mix-blend-mode: overlay; opacity:.5 }
@keyframes bgPulse { from { transform: scale(1) } to { transform: scale(1.05) } }

/* Floating musical notes */
.note { position: absolute; width: 28px; height: 28px; opacity: .18; filter: drop-shadow(0 6px 18px rgba(124,58,237,.25)); animation: floatUp 22s linear infinite; will-change: transform }
.note:nth-child(1){ left: 8%; bottom: -10%; animation-duration: 26s }
.note:nth-child(2){ left: 22%; bottom: -15%; animation-duration: 24s }
.note:nth-child(3){ left: 48%; bottom: -12%; animation-duration: 28s }
.note:nth-child(4){ left: 70%; bottom: -18%; animation-duration: 25s }
.note:nth-child(5){ left: 90%; bottom: -14%; animation-duration: 27s }
@keyframes floatUp { 0% { transform: translateY(0) rotate(0deg) } 100% { transform: translateY(-140vh) rotate(180deg) } }

@media (prefers-reduced-motion: reduce) {
  .bg-visual::before { animation: none }
  .note { animation: none }
}

/* Video embed */
.video-card { max-width: 960px; margin: 0 auto }
.video-embed { position: relative; width: 100%; padding-top: 56.25%; border-radius: 12px; overflow: hidden; border: 1px solid var(--stroke); background: #000 }
.video-card::before { content:""; position:absolute; inset:-2px; border-radius:16px; background: conic-gradient(from 180deg, rgba(56,189,248,.5), rgba(124,58,237,.5), rgba(34,197,94,.5), rgba(56,189,248,.5)); filter: blur(14px); opacity:.18; z-index:-1; animation: spinGlow 24s linear infinite }
.video-card:hover::before { opacity:.26 }
.video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0 }
.link-buttons { display:flex; flex-wrap:wrap; gap:10px; align-items:center; justify-content:center; }
.link-buttons .btn { padding: 10px 14px; border-radius: 10px }


