/* ── VARIABLES ── */
:root{
  --bg:#1e1035;
  --surface:#180c2e;
  --surface-raised:#261848;
  --border:rgba(255,255,255,.08);
  --border-bright:rgba(255,255,255,.16);
  --purple:#6D28D9;
  --purple-mid:#7C3AED;
  --purple-lite:#C4B5FD;
  --purple-dim:rgba(109,40,217,.2);
  --purple-glow:rgba(109,40,217,.4);
  --gold:#C8973A;
  --gold-warm:#9B7328;
  --green:#2DD36F;
  --green-dim:rgba(0,224,84,.14);
  --text:#FFFFFF;
  --muted:rgba(255,255,255,.84);
  --faint:rgba(255,255,255,.60);
  --transition:.18s ease;
  --font-display:'Bebas Neue',sans-serif;
  --font-body:'Inter',sans-serif;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── NAV ── */
.site-nav{
  position:sticky;top:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;height:56px;
  background:rgba(22,10,40,.92);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.nav-brand{
  font-family:var(--font-display);
  font-size:1.15rem;letter-spacing:.1em;
  color:var(--text);white-space:nowrap;
}
.nav-brand .accent{color:var(--gold)}
.nav-links{
  display:flex;list-style:none;gap:0;
}
.nav-links a{
  display:block;padding:0 16px;
  font-family:var(--font-body);font-size:.8rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  line-height:56px;
  transition:color var(--transition);
}
.nav-links a:hover{color:#fff}
.nav-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 16px;border-radius:2px;
  background:var(--purple);color:#fff;
  font-family:var(--font-body);font-size:.78rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  transition:filter var(--transition);
  white-space:nowrap;
}
.nav-pill:hover{filter:brightness(1.15)}
@media(max-width:680px){.nav-links{display:none}}

/* ── CITY HERO ── */
.city-hero-wrap{
  position:relative;
  background:linear-gradient(135deg,#0f0620 0%,#1a0d3a 50%,#0d051e 100%);
  overflow:hidden;
  padding:60px 40px 64px;
  border-bottom:1px solid var(--border);
}
.city-hero-wrap::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 70% 50%, rgba(109,40,217,.25) 0%, transparent 70%);
  pointer-events:none;
}
.city-hero{
  position:relative;z-index:1;
  max-width:1100px;margin:0 auto;
  display:grid;
  grid-template-columns:260px 1fr;
  gap:52px;
  align-items:center;
}
.city-poster{
  position:relative;flex-shrink:0;
}
.city-poster img{
  width:100%;border-radius:6px;
  box-shadow:0 24px 64px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.08);
}
.city-info{
  display:flex;flex-direction:column;
  gap:14px;
}
.city-breadcrumb{
  font-family:var(--font-body);
  font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.45);
}
.city-breadcrumb a{color:rgba(255,255,255,.45);transition:color var(--transition)}
.city-breadcrumb a:hover{color:rgba(255,255,255,.75)}
.city-eyebrow{
  font-family:var(--font-body);
  font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);
}
.city-title{
  font-family:var(--font-display);
  font-size:clamp(2.8rem,5vw,5rem);
  line-height:.93;letter-spacing:.03em;
  color:var(--text);
}
.city-date-venue{
  display:flex;flex-direction:column;gap:6px;
  padding:14px 18px;
  border-left:3px solid var(--purple-mid);
  background:rgba(109,40,217,.1);
  border-radius:0 4px 4px 0;
}
.city-date{
  font-family:var(--font-display);
  font-size:1.5rem;letter-spacing:.06em;
  color:#fff;
}
.city-venue{
  font-family:var(--font-body);
  font-size:.88rem;color:rgba(255,255,255,.7);
}
.city-in-person{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-body);font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--green);
}
.city-in-person::before{
  content:'';
  display:inline-block;width:7px;height:7px;
  background:var(--green);border-radius:50%;
  flex-shrink:0;
}
.city-actions{
  display:flex;gap:12px;flex-wrap:wrap;
  margin-top:4px;
}

/* ── TICKET BUTTONS ── */
.tix-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:13px 26px;border-radius:2px;
  font-family:var(--font-display);font-size:.95rem;letter-spacing:.05em;text-transform:uppercase;
  text-decoration:none;transition:filter .15s ease;
  white-space:nowrap;cursor:pointer;border:none;
}
.tix-btn-primary{background:var(--purple);color:#fff}
.tix-btn-primary:hover{filter:brightness(1.15)}
.tix-btn-vip{background:var(--gold);color:#fff}
.tix-btn-vip:hover{filter:brightness(.88)}

/* ── VIP SECTION (Boston) ── */
.vip-section{
  background:rgba(200,151,58,.07);
  border:1px solid rgba(200,151,58,.3);
  border-left:4px solid var(--gold);
  border-radius:4px;
  padding:28px 32px;
  max-width:1100px;margin:40px auto 0;
}
.vip-eyebrow{
  font-family:var(--font-body);font-size:.62rem;font-weight:800;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin-bottom:10px;
}
.vip-title{
  font-family:var(--font-display);font-size:1.8rem;letter-spacing:.06em;
  color:var(--gold);margin-bottom:10px;
}
.vip-desc{
  font-family:var(--font-body);font-size:.92rem;line-height:1.7;
  color:rgba(255,255,255,.8);margin-bottom:16px;
}
.vip-perks{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;
}
.vip-perk{
  font-family:var(--font-body);font-size:.75rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  padding:4px 12px;border-radius:2px;
  background:rgba(200,151,58,.15);
  border:1px solid rgba(200,151,58,.3);
  color:var(--gold);
}

/* ── CASTLE SECTION (Beloit) ── */
.castle-section{
  background:linear-gradient(135deg,rgba(32,16,58,.9),rgba(55,22,90,.9));
  border:1px solid rgba(255,209,102,.35);
  border-radius:4px;
  padding:28px 32px;
  max-width:1100px;margin:40px auto 0;
  text-align:center;
  position:relative;overflow:hidden;
}
.castle-section::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),#fff8e1,var(--gold));
}
.castle-emoji{font-size:2.5rem;margin-bottom:10px;display:block}
.castle-title{
  font-family:var(--font-display);font-size:2.2rem;letter-spacing:.08em;
  color:var(--gold);margin-bottom:10px;
}
.castle-desc{
  font-family:var(--font-body);font-size:.92rem;line-height:1.7;
  color:rgba(255,255,255,.8);max-width:560px;margin:0 auto;
}

/* ── TWO-NIGHT SECTION (Oakland) ── */
.two-night-section{
  background:rgba(109,40,217,.08);
  border:1px solid var(--purple-dim);
  border-radius:4px;
  padding:28px 32px;
  max-width:1100px;margin:40px auto 0;
}
.two-night-eyebrow{
  font-family:var(--font-body);font-size:.62rem;font-weight:800;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--purple-lite);margin-bottom:10px;
}
.two-night-title{
  font-family:var(--font-display);font-size:1.8rem;letter-spacing:.06em;
  color:#fff;margin-bottom:10px;
}
.two-night-desc{
  font-family:var(--font-body);font-size:.92rem;line-height:1.7;
  color:rgba(255,255,255,.8);margin-bottom:18px;
}
.two-night-buttons{
  display:flex;gap:12px;flex-wrap:wrap;
}

/* ── PAGE BODY ── */
.city-body{
  max-width:1100px;margin:0 auto;
  padding:48px 40px 0;
  display:flex;flex-direction:column;gap:56px;
}

/* ── DESCRIPTION ── */
.city-description-wrap{}
.city-desc-label{
  font-family:var(--font-body);font-size:.65rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-bottom:14px;
}
.city-desc-text{
  font-family:var(--font-body);
  font-size:1.08rem;line-height:1.75;
  color:rgba(255,255,255,.82);
  max-width:680px;
}

/* ── MOVIE STRIP ── */
.movie-strip{
  display:flex;flex-wrap:wrap;
  gap:0;
  border:1px solid var(--border);
  border-radius:2px;
  overflow:hidden;
}
.movie-strip-item{
  flex:1;min-width:160px;
  padding:16px 22px;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:4px;
}
.movie-strip-item:last-child{border-right:none}
.strip-label{
  font-family:var(--font-body);font-size:.6rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.4);
}
.strip-value{
  font-family:var(--font-display);font-size:1.3rem;letter-spacing:.04em;
  color:#fff;
}
.strip-value.gold{color:var(--gold)}
.strip-value.green{color:var(--green)}

/* ── TRAILER ── */
.trailer-wrap-outer{}
.trailer-label{
  font-family:var(--font-body);font-size:.65rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-bottom:14px;
}
.trailer-ratio{
  position:relative;padding-bottom:56.25%;height:0;overflow:hidden;
  border-radius:3px;
  box-shadow:0 2px 10px rgba(0,0,0,.4);
}
.trailer-ratio iframe{
  position:absolute;top:0;left:0;width:100%;height:100%;border:0;
}
.trailer-thumb{
  position:absolute;top:0;left:0;width:100%;height:100%;
  cursor:pointer;z-index:2;background:#000;
}
.trailer-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.trailer-thumb:hover img{transform:scale(1.02)}
.trailer-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:72px;height:72px;background:rgba(0,0,0,.6);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;
}
.trailer-thumb:hover .trailer-play{
  background:rgba(124,58,237,.92);
  transform:translate(-50%,-58%) scale(1.1);
}
.trailer-play::after{
  content:'';display:block;width:0;height:0;
  border-style:solid;border-width:13px 0 13px 24px;
  border-color:transparent transparent transparent #fff;
  margin-left:5px;
}

/* ── ALL DATES CTA ── */
.all-dates-cta{
  text-align:center;
  padding:40px 24px 56px;
  border-top:1px solid var(--border);
}
.all-dates-label{
  font-family:var(--font-body);font-size:.72rem;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin-bottom:16px;
}
.all-dates-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;border-radius:2px;
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.85);
  font-family:var(--font-display);font-size:1.1rem;letter-spacing:.08em;text-transform:uppercase;
  transition:border-color var(--transition),color var(--transition),background var(--transition);
}
.all-dates-btn:hover{
  border-color:rgba(255,255,255,.5);
  color:#fff;
  background:rgba(255,255,255,.05);
}

/* ── FOOTER ── */
.site-footer{
  border-top:1px solid var(--border);
  padding:40px 28px 32px;
  text-align:center;
}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-conversion{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
  padding-bottom:28px;
  border-bottom:1px solid var(--border);
  margin-bottom:28px;
}
.footer-conversion-text{
  font-family:var(--font-display);
  font-size:clamp(1.4rem,3vw,2rem);
  letter-spacing:.05em;color:var(--text);
  text-align:left;
}
.footer-conversion-text em{color:var(--gold);font-style:normal}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
}
.footer-brand{
  font-family:var(--font-display);
  font-size:1rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}
.footer-brand span{color:var(--gold)}
.footer-nav{
  display:flex;flex-wrap:wrap;justify-content:center;gap:0;
}
.footer-nav a{
  font-family:var(--font-body);font-size:.75rem;
  font-weight:500;letter-spacing:.05em;
  color:rgba(255,255,255,.5);
  padding:4px 12px;
  border-right:1px solid rgba(255,255,255,.1);
  transition:color var(--transition);
}
.footer-nav a:last-child{border-right:none}
.footer-nav a:hover{color:rgba(255,255,255,.9)}
.footer-social{
  display:flex;gap:16px;
}
.footer-social a{
  font-family:var(--font-body);font-size:.75rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
  transition:color var(--transition);
}
.footer-social a:hover{color:#fff}
.footer-tix-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 24px;border-radius:2px;
  background:var(--purple);color:#fff;
  font-family:var(--font-display);font-size:.95rem;letter-spacing:.06em;text-transform:uppercase;
  transition:filter var(--transition);
  white-space:nowrap;
}
.footer-tix-btn:hover{filter:brightness(1.15)}

/* ── FAQ ── */
.city-faq{padding-bottom:8px}
.faq-list{display:flex;flex-direction:column;max-width:680px;margin-top:14px}
.faq-item{padding:16px 0;border-bottom:1px solid var(--border)}
.faq-item:first-child{padding-top:0}
.faq-item:last-child{border-bottom:none;padding-bottom:0}
.faq-q{font-family:var(--font-body);font-weight:700;font-size:.95rem;color:#fff;margin-bottom:6px}
.faq-a{font-family:var(--font-body);font-size:.92rem;line-height:1.75;color:rgba(255,255,255,.78);margin:0}

/* ── NEXT STOP ── */
.next-stop{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px}
.next-stop span{font-family:var(--font-body);font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.next-stop a{font-family:var(--font-body);font-size:.8rem;font-weight:600;color:var(--purple-lite);transition:color var(--transition)}
.next-stop a:hover{color:#fff}
.city-share{margin-top:28px;padding-top:24px;border-top:1px solid var(--border)}
.city-share-label{font-family:var(--font-body);font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:12px}
.city-share-btns{display:flex;gap:8px;flex-wrap:wrap}
.share-btn{font-family:var(--font-body);font-size:.78rem;font-weight:600;padding:8px 14px;border-radius:6px;text-decoration:none;transition:opacity var(--transition);line-height:1}
.share-btn:hover{opacity:.75}
.share-x{background:#000;color:#fff}
.share-fb{background:#1877F2;color:#fff}
.share-reddit{background:#FF4500;color:#fff}

/* ── MOBILE ── */
@media(max-width:860px){
  .city-hero{grid-template-columns:200px 1fr;gap:32px}
  .city-hero-wrap{padding:48px 28px 52px}
}
@media(max-width:640px){
  .city-hero{grid-template-columns:1fr;gap:0}
  .city-hero-wrap{padding:32px 20px 40px}
  .city-poster{max-width:200px;margin:0 auto 24px}
  .city-title{font-size:2.6rem}
  .city-actions{flex-direction:column}
  .tix-btn{width:100%;justify-content:center}
  .city-body{padding:32px 20px 0;gap:40px}
  .vip-section,.castle-section,.two-night-section{margin:24px 20px 0;padding:20px}
  .movie-strip{flex-direction:column}
  .movie-strip-item{border-right:none;border-bottom:1px solid var(--border)}
  .movie-strip-item:last-child{border-bottom:none}
  .footer-conversion{flex-direction:column;text-align:center}
  .footer-conversion-text{text-align:center}
  .footer-bottom{flex-direction:column;gap:12px}
  .two-night-buttons{flex-direction:column}
  .two-night-buttons .tix-btn{width:100%;justify-content:center}
}
@media(max-width:400px){
  .city-title{font-size:2.2rem}
}
