/* ============================================================
   SUNDAZE FESTIVAL — Digital Poster Site
   Loud, layered, magazine-collage, sun-baked & rebellious
   ============================================================ */

/* ---------- Local fonts (essential weights only) ---------- */
@font-face{
  font-family:"Lemonmilk";
  src:url("assets/Font/LEMONMILK-Regular.otf") format("opentype");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Lemonmilk";
  src:url("assets/Font/LEMONMILK-Medium.otf") format("opentype");
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Lemonmilk";
  src:url("assets/Font/LEMONMILK-Bold.otf") format("opentype");
  font-weight:700;font-style:normal;font-display:swap;
}

@font-face{
  font-family:"Baloo 2";
  src:url("assets/Font/Baloo2-Regular.ttf") format("truetype");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Baloo 2";
  src:url("assets/Font/Baloo2-Medium.ttf") format("truetype");
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Baloo 2";
  src:url("assets/Font/Baloo2-SemiBold.ttf") format("truetype");
  font-weight:600;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Baloo 2";
  src:url("assets/Font/Baloo2-Bold.ttf") format("truetype");
  font-weight:700;font-style:normal;font-display:swap;
}

:root{
  --black:#0b0b0b;
  --white:#ffffff;
  --white-warm:#fffdf6;
  --yellow:#f1ff2c;       /* neon yellow */
  --blue:#1f5cff;          /* electric blue */
  --sky-0:#00a7fc;
  --sky-1:#3cc7fc;
  --sky-deep:#0096e8;
  --skyblue:var(--sky-0);
  --sky-gradient:linear-gradient(180deg,#00a7fc 0%,#18b3fc 18%,#3cc7fc 38%,#2dbefc 62%,#11b0fc 82%,#00a7fc 100%);
  --ocean-gradient:linear-gradient(180deg,#063a5f 0%,#0a2540 45%,#0b0b0b 100%);
  --shadow-soft:0 12px 32px rgba(0,80,140,.28);
  --shadow-card:0 8px 28px rgba(0,0,0,.18);
  --green:#27e36b;         /* bright green */
  --pink:#ff3ea0;          /* hot pink */
  --purple:#9b3cff;        /* purple */
  --orange:#ff6a1f;
  --cream:#fff6dc;
  --ticker-h:40px;
  --menu-clearance:56px;

  --display:"Lemonmilk", sans-serif;
  --headline:"Lemonmilk", sans-serif;
  --body:"Baloo 2", sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;

  /* Type scale — balanced poster sizing */
  --text-section:clamp(44px,7.5vw,140px);
  --text-section-lg:clamp(48px,8.5vw,160px);
  --text-marquee:clamp(36px,5.5vw,88px);
  --text-menu:clamp(32px,6vw,88px);
  --text-footer:clamp(44px,10vw,200px);
  --text-body-lg:18px;
  --text-body-md:16px;
  --text-body-sm:15px;
  --text-price:clamp(44px,5vw,64px);
  --text-card-title:clamp(24px,2.4vw,34px);
  --text-lineup:clamp(18px,3.2vw,40px);
  --text-tile:clamp(20px,2.2vw,36px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
html,body{background:var(--black);color:var(--black);font-family:var(--body);overflow-x:hidden}
body{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
button{font:inherit;border:0;background:none;cursor:pointer}
::selection{background:var(--yellow);color:var(--black)}
:focus-visible{outline:3px solid var(--yellow);outline-offset:3px}
:focus:not(:focus-visible){outline:none}

/* ---------- Halftone overlay (coming-soon poster texture) ---------- */
.halftone{
  position:fixed;inset:0;
  pointer-events:none;z-index:9998;
  background-image:
    radial-gradient(circle at center,rgba(255,255,255,.14) 0%,rgba(255,255,255,0) 60%),
    radial-gradient(rgba(255,255,255,.08) 1px,transparent 1.4px);
  background-size:100% 100%,8px 8px;
  mix-blend-mode:screen;
  opacity:.85;
}
.halftone::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 45%,rgba(0,90,160,.12) 95%);
  pointer-events:none;
}

/* ---------- Page loader ---------- */
body.is-loading{overflow:hidden}
.page-loader{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  background:var(--sky-gradient);
  opacity:1;visibility:visible;
  transition:opacity .55s ease,visibility .55s ease;
}
.page-loader.is-done{opacity:0;visibility:hidden;pointer-events:none}
.page-loader__halftone{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at center,rgba(255,255,255,.18) 0%,rgba(255,255,255,0) 60%),
    radial-gradient(circle,rgba(255,255,255,.14) 1px,transparent 1px);
  background-size:100% 100%,14px 14px;
  opacity:.85;
}
.page-loader__inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  padding:2rem;text-align:center;
}
.page-loader__logo{
  width:clamp(160px,42vw,235px);height:auto;
  filter:drop-shadow(0 8px 24px rgba(0,80,140,.25));
  animation:loader-pulse 1.6s ease-in-out infinite;
}
.page-loader__track{
  width:min(220px,56vw);height:4px;border-radius:999px;
  background:rgba(255,255,255,.28);overflow:hidden;
}
.page-loader__bar{
  display:block;width:40%;height:100%;border-radius:inherit;
  background:linear-gradient(90deg,rgba(255,255,255,.5),#fff);
  box-shadow:0 0 12px rgba(255,255,255,.65);
  animation:loader-bar 1.4s ease-in-out infinite;
}
@keyframes loader-pulse{
  0%,100%{opacity:.88;transform:scale(1)}
  50%{opacity:1;transform:scale(1.03)}
}
@keyframes loader-bar{
  0%{transform:translateX(-120%)}
  100%{transform:translateX(320%)}
}
/* ---------- Top ticker ---------- */
.ticker{
  position:fixed;top:0;left:0;right:0;
  background:rgba(0,120,200,.35);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:var(--white);
  border-bottom:1px solid rgba(255,255,255,.25);
  z-index:90;
  overflow:hidden;
  height:var(--ticker-h);
  display:flex;align-items:center;
}
.ticker__track{
  display:flex;gap:40px;
  white-space:nowrap;
  font-family:var(--headline);
  font-size:13px;letter-spacing:.14em;
  text-transform:uppercase;
  animation:marquee 36s linear infinite;
}
.ticker__track span{display:inline-flex;align-items:center;gap:40px}
.ticker__track em{font-style:normal}
.ticker__track i{
  font-style:normal;display:inline-block;width:6px;height:6px;
  background:var(--white);border-radius:50%;opacity:.7;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ---------- Sticky menu button ---------- */
.menu-btn{
  position:fixed;top:calc(var(--ticker-h) + 10px);right:20px;z-index:95;
  background:var(--black);
  color:var(--white);
  border:2px solid rgba(255,255,255,.2);
  border-radius:999px;
  padding:12px 20px;
  min-height:44px;
  font-family:var(--headline);
  font-size:13px;letter-spacing:.14em;
  text-transform:uppercase;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.menu-btn:hover{
  transform:translateY(-2px);
  background:var(--black);
  border-color:var(--white);
  box-shadow:0 12px 32px rgba(0,0,0,.5);
}
.menu-btn .dot{width:8px;height:8px;border-radius:50%;background:var(--yellow);opacity:1;transition:background .2s ease}
.menu-btn.open{background:var(--white);color:var(--black);border-color:var(--black)}
.menu-btn.open .dot{background:var(--black)}

/* Menu overlay */
.menu-overlay{
  position:fixed;inset:0;z-index:75;
  background:linear-gradient(165deg,#063a5f 0%,var(--black) 55%);
  color:var(--white);
  padding:120px 5vw 5vw;
  display:flex;flex-direction:column;justify-content:space-between;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .35s ease, visibility .35s ease;
}
.menu-overlay.open{opacity:1;visibility:visible;pointer-events:auto}
.menu-overlay[hidden]{display:none}
.menu-overlay.open[hidden]{display:flex}
.menu-overlay ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.menu-overlay li a{
  font-family:var(--display);
  font-size:var(--text-menu);
  line-height:.92;letter-spacing:-.01em;
  color:var(--white);
  display:inline-block;
  transition:color .15s ease, transform .15s ease, -webkit-text-stroke .15s;
  -webkit-text-stroke:0 transparent;
}
.menu-overlay li a:hover{
  color:transparent;
  -webkit-text-stroke:2px var(--sky-1);
  transform:translateX(20px) rotate(-1deg);
}
.menu-overlay__foot{
  display:flex;justify-content:space-between;align-items:flex-end;
  font-family:var(--headline);text-transform:uppercase;font-size:14px;
  letter-spacing:.1em;color:#888;
}

/* ---------- Sections shared ---------- */
section{
  position:relative;padding:80px 5vw;
  content-visibility:auto;contain-intrinsic-size:auto 800px;
}
.is-hidden,[hidden].is-hidden{display:none !important}
.section-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--headline);text-transform:uppercase;
  font-size:14px;letter-spacing:.18em;
  padding:8px 16px;border:2px solid currentColor;border-radius:999px;
  margin-bottom:24px;
}
.section-tag::before{
  content:"";width:8px;height:8px;background:currentColor;border-radius:50%;
}
.section-tag--yellow{color:var(--yellow);border-color:var(--yellow)}
.section-tag--pink{color:var(--pink);border-color:var(--pink)}
.section-tag--glass{
  color:var(--white);border-color:rgba(255,255,255,.55);
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.section-tag--sky{color:var(--sky-deep);border-color:rgba(0,150,232,.4);background:rgba(255,255,255,.65)}

.meta{
  font-family:var(--body);
  letter-spacing:.02em;
  line-height:1.45;
}
.meta--muted{
  font-size:15px;color:#888;max-width:300px;text-align:right;
}
.meta--faq{
  font-size:15px;max-width:260px;text-align:right;
}
.meta--faq a{text-decoration:underline}
.meta--faq a:hover{color:var(--black)}

/* ---------- HERO (coming-soon style) ---------- */
.hero{
  background:var(--sky-gradient);
  padding:calc(var(--ticker-h) + var(--menu-clearance) + 12px) 5vw 80px;
  min-height:100vh;
  min-height:100svh;
  overflow:hidden;
  display:flex;flex-direction:column;
  justify-content:space-between;
  position:relative;
}
.hero__doodles{
  position:absolute;inset:0;pointer-events:none;z-index:1;
}
.hero-doodle{
  position:absolute;display:block;user-select:none;
  transform-origin:center center;
  animation:doodle-wiggle 5.5s ease-in-out infinite;
}
.hero-doodle img{width:100%;height:100%;display:block;object-fit:contain}
.hero-doodle--left-up{top:-2%;left:-40px;width:228px;height:415px;animation-duration:4.7s;animation-delay:-.3s}
.hero-doodle--left-down{bottom:0;left:-40px;width:227px;height:528px;margin:-15px 27px;animation-duration:5.3s;animation-delay:-1.7s}
.hero-doodle--smiley{bottom:0;left:1%;width:144px;height:161px;margin:-17px -15px;animation-duration:4.2s;animation-delay:-2.4s}
.hero-doodle--right-down{bottom:0;right:-40px;width:195px;height:227px;margin:-15px 27px;animation-duration:5s;animation-delay:-3.1s}
.hero-doodle--right-middle{
  top:50%;right:-40px;width:292px;height:557px;margin:-20px -56px;
  animation-name:doodle-wiggle-centered;animation-duration:6.1s;animation-delay:-.8s;
}
.hero-doodle--sunface{
  top:-2%;
  right:-2%;
  width:163px;
  height:163px;
  margin:9px 12px;
  animation-duration:4.5s;
  animation-delay:-1.2s;
  z-index:3;
}
@keyframes doodle-wiggle{
  0%,100%{transform:translate(0,0) rotate(0deg)}
  20%{transform:translate(2px,-2px) rotate(.3deg)}
  40%{transform:translate(-2px,3px) rotate(-.25deg)}
  60%{transform:translate(3px,1px) rotate(.2deg)}
  80%{transform:translate(-1px,-2px) rotate(-.15deg)}
}
@keyframes doodle-wiggle-centered{
  0%,100%{transform:translateY(-50%) translate(0,0) rotate(0deg)}
  20%{transform:translateY(-50%) translate(2px,-2px) rotate(.3deg)}
  40%{transform:translateY(-50%) translate(-2px,3px) rotate(-.25deg)}
  60%{transform:translateY(-50%) translate(3px,1px) rotate(.2deg)}
  80%{transform:translateY(-50%) translate(-1px,-2px) rotate(-.15deg)}
}

.hero__header{
  position:relative;z-index:5;
  display:flex;flex-direction:column;align-items:center;
  gap:14px;
  max-width:720px;margin:0 auto;
}
@media (max-width:680px){
  .hero__header{display:none}
}
.hero__venues{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:8px 10px;
  font-family:var(--headline);text-transform:uppercase;
  font-size:clamp(11px,2.2vw,13px);letter-spacing:.16em;
  color:rgba(255,255,255,.92);
  text-align:center;line-height:1.3;
}
.hero__venues-dot{opacity:.55}
.hero__meta{
  display:flex;align-items:center;justify-content:center;
  gap:10px;
  width:100%;
  flex-wrap:wrap;
}
.hero__chip{
  flex-shrink:0;
  font-family:var(--headline);text-transform:uppercase;
  font-size:11px;letter-spacing:.12em;
  color:var(--white);
  background:rgba(255,255,255,.14);
  border:2px solid rgba(255,255,255,.75);
  border-radius:999px;padding:8px 14px;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  white-space:nowrap;
}
.hero__chip--live{
  display:inline-flex;align-items:center;
  background:rgba(39,227,107,.22);
  border-color:var(--green);
  color:var(--white);
  box-shadow:0 0 0 1px rgba(39,227,107,.35);
}
.hero__chip--live::before{
  content:"";
  display:inline-block;width:7px;height:7px;
  border-radius:50%;background:var(--green);
  margin-right:8px;vertical-align:middle;
  box-shadow:0 0 8px var(--green);
  animation:live-pulse 1.8s ease-in-out infinite;
}
@keyframes live-pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.65;transform:scale(.85)}
}
.hero__title-wrap{
  position:relative;z-index:10;
  text-align:center;padding:40px 0;
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:clamp(1rem,3vh,1.75rem);
}
.hero__title{margin:0;line-height:0}
.hero__logo{
  display:block;width:clamp(200px,42vw,420px);height:auto;margin:0 auto;
  filter:drop-shadow(0 8px 24px rgba(0,80,140,.25));
  opacity:0;transform:translateY(.5em) scale(.94);
}
body.is-hero-revealed .hero__logo{
  animation:hero-logo-in .8s cubic-bezier(.22,1,.36,1) forwards;
}
@keyframes hero-logo-in{
  to{opacity:1;transform:translateY(0) scale(1)}
}
.hero__tagline{
  font-family:var(--body);font-weight:500;
  font-size:clamp(14px,2vw,17px);letter-spacing:.02em;
  color:rgba(255,255,255,.92);max-width:420px;line-height:1.45;
  opacity:0;
}
body.is-hero-revealed .hero__tagline{
  animation:hero-fade-up .65s cubic-bezier(.22,1,.36,1) .25s forwards;
}
.hero__cta{
  display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:center;
  width:min(100%,420px);
  opacity:0;
}
.hero__cta .btn-glass{
  flex:1 1 160px;
  min-height:48px;
}
body.is-hero-revealed .hero__cta{
  animation:hero-fade-up .65s cubic-bezier(.22,1,.36,1) .45s forwards;
}
@keyframes hero-fade-up{
  from{opacity:0;transform:translateY(.75em)}
  to{opacity:1;transform:translateY(0)}
}
.hero__lockup{
  position:relative;z-index:3;text-align:center;
  opacity:0;
}
body.is-hero-revealed .hero__lockup{
  animation:hero-fade-up .65s cubic-bezier(.22,1,.36,1) .6s forwards;
}
.hero__lockup img{
  width:clamp(140px,18vw,220px);height:auto;margin:0 auto;
  filter:drop-shadow(0 4px 16px rgba(0,80,140,.2));
}

/* Glass buttons (coming-soon) */
.btn-glass{
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;
  padding:.85em 1.6em;border:2px solid rgba(255,255,255,.92);
  border-radius:999px;background:rgba(255,255,255,.12);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:var(--white);font-family:var(--headline);
  font-size:clamp(11px,2.4vw,14px);font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;line-height:1.2;
  box-shadow:0 6px 20px rgba(0,80,140,.2);
  transition:background .2s ease,transform .2s ease,box-shadow .2s ease;
}
.btn-glass:hover{
  background:rgba(255,255,255,.22);
  transform:translateY(-2px);
  box-shadow:0 10px 28px rgba(0,80,140,.28);
}
.btn-glass--primary{
  background:rgba(255,255,255,.22);
  border-color:var(--white);
}

.btn-sky{
  display:inline-flex;align-items:center;gap:10px;
  padding:.85em 1.5em;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--sky-deep) 0%,var(--sky-0) 50%,var(--sky-1) 100%);
  color:var(--white);font-family:var(--headline);
  font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  box-shadow:0 8px 22px rgba(0,120,200,.35);
  transition:transform .15s ease,box-shadow .15s ease;
}
.btn-sky:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,120,200,.42)}

.btn-bold{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--black);color:var(--white);
  border:3px solid var(--black);
  font-family:var(--headline);text-transform:uppercase;
  font-size:16px;letter-spacing:.06em;
  padding:16px 24px;border-radius:999px;
  box-shadow:8px 8px 0 var(--pink);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn-bold:hover{
  transform:translate(-3px,-3px);
  box-shadow:14px 14px 0 var(--yellow);
}
.btn-bold .arrow{
  width:32px;height:32px;border-radius:50%;
  background:var(--yellow);color:var(--black);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--headline);font-size:18px;
  transition:transform .2s ease;
}
.btn-bold:hover .arrow{transform:rotate(45deg)}

.btn-outline{
  display:inline-flex;align-items:center;gap:10px;
  border:3px solid var(--black);background:transparent;color:var(--black);
  border-radius:999px;padding:16px 24px;
  font-family:var(--headline);text-transform:uppercase;letter-spacing:.08em;font-size:16px;
  transition:background .2s, color .2s, transform .2s;
}
.btn-outline:hover{background:var(--black);color:var(--white);transform:translate(-2px,-2px)}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes wobble{
  0%,100%{transform:rotate(-8deg) scale(1)}
  50%{transform:rotate(10deg) scale(1.1)}
}

/* ---------- DATE STRIP ---------- */
.date-strip{
  background:var(--sky-gradient);
  border-top:1px solid rgba(255,255,255,.2);
  border-bottom:1px solid rgba(255,255,255,.2);
  padding:20px 0;
  overflow:hidden;
}
.date-strip__track{
  display:flex;gap:40px;white-space:nowrap;
  font-family:var(--display);
  font-size:var(--text-marquee);
  line-height:1;color:var(--white);
  text-transform:uppercase;letter-spacing:-.01em;
  text-shadow:0 2px 12px rgba(0,80,140,.2);
  animation:marquee 22s linear infinite;
}
.date-strip__track span{display:inline-flex;align-items:center;gap:48px}
.date-strip__track .star{
  display:inline-flex;width:.75em;height:.75em;align-items:center;justify-content:center;opacity:.85;
}
.date-strip__track .star svg{width:100%;height:100%}
.date-strip--alt{
  background:linear-gradient(90deg,var(--sky-deep) 0%,var(--sky-0) 50%,var(--sky-1) 100%);
}
.date-strip--alt .date-strip__track{color:var(--white)}

/* ---------- ABOUT ---------- */
.about{
  background:var(--pink);color:var(--black);
  padding:96px 5vw;
  position:relative;overflow:hidden;
}
.about__grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:start;
}
.about h2{
  font-family:var(--display);
  font-size:var(--text-section);line-height:.88;
  letter-spacing:-.02em;
  color:var(--black);
}
.about h2 em{
  font-style:normal;color:var(--yellow);
  -webkit-text-stroke:2px var(--black);
}
.about__copy{
  font-family:var(--body);
  font-size:var(--text-body-lg);line-height:1.5;font-weight:500;max-width:560px;
}
.about__copy--spaced{margin-top:32px}
.about__copy p+p{margin-top:18px}
.about__stats{
  display:flex;gap:32px;margin-top:48px;flex-wrap:wrap;
}
.about__stat{
  background:rgba(255,255,255,.92);color:var(--sky-deep);
  border:2px solid rgba(255,255,255,.8);border-radius:20px;padding:22px 26px;
  min-width:150px;
  transform:rotate(-2deg);
  box-shadow:var(--shadow-card);
  transition:transform .2s ease,box-shadow .2s ease;
}
.about__stat:nth-child(2){transform:rotate(2deg);background:rgba(255,255,255,.95)}
.about__stat:nth-child(3){transform:rotate(-1deg);background:linear-gradient(135deg,var(--sky-0),var(--sky-1));color:var(--white);border-color:rgba(255,255,255,.35)}
.about__stat:hover{transform:rotate(0) scale(1.03);box-shadow:var(--shadow-soft)}
.about__stat:nth-child(3) .n,.about__stat:nth-child(3) .l{color:var(--white)}
.about__stat .n{font-family:var(--display);font-size:48px;line-height:1}
.about__stat .l{font-family:var(--headline);text-transform:uppercase;font-size:13px;letter-spacing:.15em;margin-top:6px}

.about__art{
  position:relative;height:480px;
}
.about__art .poster{
  position:absolute;top:0;right:0;width:75%;
  border:3px solid rgba(255,255,255,.6);border-radius:20px;overflow:hidden;
  transform:rotate(3deg);
  box-shadow:var(--shadow-soft);
  transition:transform .35s ease,box-shadow .35s ease;
}
.about__art .poster:hover{transform:rotate(0) scale(1.03);box-shadow:0 18px 44px rgba(0,80,140,.35)}
.about__art .poster img{aspect-ratio:4/5;object-fit:cover;width:100%}
.about__art .sticker{
  position:absolute;background:var(--yellow);color:var(--black);
  font-family:var(--headline);text-transform:uppercase;
  border:3px solid var(--black);border-radius:999px;
  padding:10px 18px;font-size:14px;letter-spacing:.12em;
  z-index:3;
}
.about__art .sticker--1{top:-10px;left:-10px;transform:rotate(-8deg);background:var(--green)}
.about__art .sticker--2{bottom:40px;left:0;transform:rotate(6deg);background:var(--white)}

/* ---------- LINEUP ---------- */
.lineup{
  background:var(--ocean-gradient);color:var(--white);
  padding:96px 5vw;
  position:relative;overflow:hidden;
}
.lineup__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:40px;flex-wrap:wrap;margin-bottom:56px;
}
.lineup h2{
  font-family:var(--display);
  font-size:var(--text-section-lg);line-height:.88;
  color:var(--white);letter-spacing:-.02em;
}
.lineup h2 em{
  font-style:normal;color:transparent;
  -webkit-text-stroke:2px var(--yellow);
}
.lineup__meta{
  color:rgba(255,255,255,.75);
  max-width:280px;text-align:right;
  font-size:16px;
}

.lineup__stage{
  position:relative;
  background:var(--sky-gradient);
  border:4px solid rgba(255,255,255,.35);
  border-radius:24px;
  padding:clamp(12px,2.5vw,20px);
  max-width:960px;margin:0 auto;
  transform:rotate(-1deg);
  box-shadow:0 16px 40px rgba(0,80,140,.35);
  overflow:hidden;
  transition:transform .35s ease, box-shadow .35s ease;
}
.lineup__stage:hover{
  transform:rotate(0) translateY(-4px);
  box-shadow:0 22px 50px rgba(0,80,140,.45);
}
.lineup__poster{
  margin:0;
  padding:0;
  border:none;
  display:block;
  width:100%;
  position:relative;
  z-index:2;
  border-radius:12px;
  overflow:hidden;
  background:rgba(0,80,140,.12);
  box-shadow:0 8px 28px rgba(0,0,0,.12);
  cursor:pointer;
}
.lineup__poster::after{
  content:"";
  position:absolute;inset:0;
  background:rgba(0,0,0,.3);
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
}
.lineup__poster:hover::after{opacity:1}
.lineup__poster picture,
.lineup__poster img{
  display:block;
  width:100%;
  height:auto;
}
.lineup__poster img{
  object-fit:contain;
  vertical-align:middle;
}
.lineup__expand{
  position:absolute;bottom:20px;right:20px;z-index:3;
  background:rgba(0,0,0,.75);color:var(--white);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:10px 20px;border-radius:999px;
  font-family:var(--headline);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;
  opacity:0;transform:translateY(10px);
  transition:opacity .25s ease, transform .25s ease;
  pointer-events:none;
}
.lineup__expand svg{width:16px;height:16px}
.lineup__poster:hover .lineup__expand{opacity:1;transform:translateY(0)}
.lineup__sticker{
  position:absolute;top:-14px;right:32px;z-index:3;
  background:rgba(255,255,255,.92);color:var(--sky-deep);
  font-family:var(--headline);text-transform:uppercase;
  border:2px solid rgba(255,255,255,.8);border-radius:999px;
  padding:10px 18px;font-size:12px;letter-spacing:.14em;
  transform:rotate(6deg);box-shadow:var(--shadow-card);
}

.lineup__doodle{
  position:absolute;pointer-events:none;z-index:1;
}
.lineup__doodle--star{
  top:14%;left:6%;width:32px;color:var(--white);
  animation:spin 22s linear infinite;
}
.lineup__doodle--star-outline{
  bottom:18%;left:8%;width:44px;color:var(--white);
}
.lineup__doodle--star-yellow{
  top:38%;right:10%;width:40px;color:var(--yellow);
  animation:wobble 4s ease-in-out infinite;
}
.lineup__doodle--zigzag{
  top:8%;right:6%;width:100px;color:var(--pink);
  transform:rotate(8deg);
}

.lineup__names{
  list-style:none;
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  align-items:center;gap:clamp(6px,1.2vw,14px);
}
.lineup__line{
  display:flex;flex-wrap:wrap;
  align-items:center;justify-content:center;
  gap:clamp(10px,2vw,22px);
  font-family:var(--body);
  font-size:var(--text-lineup);
  font-weight:700;
  line-height:1.15;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:var(--white);
  cursor:pointer;
  transition:transform .2s ease, color .2s ease;
}
.lineup__line:hover{transform:scale(1.02)}
.lineup__line:hover .lineup__artist{color:var(--yellow)}
.lineup__line:nth-child(3n+1):hover .lineup__artist{color:var(--pink)}
.lineup__line:nth-child(3n+2):hover .lineup__artist{color:var(--green)}
.lineup__artist{
  white-space:nowrap;
  transition:color .2s ease;
  text-shadow:
    -2px 0 0 var(--black),
    2px 0 0 var(--black),
    0 -2px 0 var(--black),
    0 2px 0 var(--black);
}
.lineup__sep{
  font-size:.5em;line-height:1;
  opacity:.85;
  transform:translateY(-.04em);
  color:var(--white);
}
.lineup__b2b{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--white);color:var(--sky-0);
  border:2px solid var(--black);
  border-radius:999px;
  padding:clamp(5px,0.8vw,8px) clamp(4px,0.6vw,6px);
  min-width:clamp(22px,3vw,30px);
  font-family:var(--headline);
  font-size:clamp(9px,1.1vw,12px);
  font-weight:700;
  letter-spacing:.06em;
  line-height:1;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  transform:rotate(180deg);
  vertical-align:middle;
  flex-shrink:0;
  box-shadow:3px 3px 0 var(--black);
}
.lineup__live{
  font-weight:600;
  letter-spacing:.04em;
}
.lineup.in .lineup__line{
  animation:lineup-in .55s ease both;
  animation-delay:calc(var(--i, 0) * 45ms);
}
@keyframes lineup-in{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

/* ---------- EXPERIENCE ZONES ---------- */
.zones{
  background:var(--green);color:var(--black);
  padding:96px 5vw;position:relative;overflow:hidden;
}
.zones__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:40px;flex-wrap:wrap;margin-bottom:60px;
}
.zones h2{
  font-family:var(--display);
  font-size:var(--text-section);line-height:.88;
  letter-spacing:-.02em;color:var(--black);
}
.zones h2 em{font-style:normal;color:var(--white);-webkit-text-stroke:2px var(--black)}
.zones__intro{max-width:380px;font-family:var(--body);font-size:var(--text-body-md);font-weight:500;line-height:1.45}

.zones__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.zone-card{
  background:var(--white);border:2px solid rgba(11,11,11,.12);
  border-radius:20px;padding:28px;
  display:flex;flex-direction:column;
  min-height:340px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-card);
  transition:transform .25s ease,box-shadow .25s;
  cursor:pointer;
}
.zone-card:nth-child(1){background:var(--yellow);transform:rotate(-2deg)}
.zone-card:nth-child(2){background:linear-gradient(160deg,var(--sky-deep),var(--sky-0));color:var(--white);transform:rotate(1deg)}
.zone-card:nth-child(3){background:var(--purple);color:var(--white);transform:rotate(-1deg)}
.zone-card:nth-child(4){background:var(--pink);transform:rotate(2deg)}
.zone-card:hover{transform:rotate(0) translateY(-8px);box-shadow:var(--shadow-soft)}
.zone-card .num{
  font-family:var(--mono);font-size:14px;letter-spacing:.1em;
  opacity:.6;
}
.zone-card .title{
  font-family:var(--display);font-size:var(--text-card-title);line-height:.95;
  margin-top:auto;letter-spacing:-.01em;
}
.zone-card .desc{margin-top:14px;font-family:var(--body);font-size:var(--text-body-sm);line-height:1.45;font-weight:500}
.zone-card .icon{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:120px;height:120px;opacity:.85;
  transition:transform .3s ease;
}
.zone-card:hover .icon{transform:translate(-50%,-50%) scale(1.15) rotate(12deg)}

/* ---------- GALLERY ---------- */
.gallery{
  background:var(--ocean-gradient);color:var(--white);
  padding:96px 5vw 72px;
  position:relative;
}
.gallery__head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:40px;flex-wrap:wrap}
.gallery h2{
  font-family:var(--display);font-size:var(--text-section);line-height:.88;
  color:var(--white);letter-spacing:-.02em;
}
.gallery h2 em{font-style:normal;color:var(--pink)}
.gallery__grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:120px;
  gap:14px;
}
.tile{
  position:relative;overflow:hidden;border-radius:16px;
  background:#1a2a3a;border:2px solid rgba(255,255,255,.25);
  box-shadow:var(--shadow-card);
  cursor:pointer;
  transition:transform .25s ease,box-shadow .25s;
}
.tile:hover{transform:scale(1.03) rotate(-1deg);z-index:2}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease, filter .3s}
.tile:hover img{transform:scale(1.1);filter:saturate(1.4)}
.tile .label{
  position:absolute;left:14px;bottom:14px;
  background:var(--yellow);color:var(--black);
  font-family:var(--headline);text-transform:uppercase;letter-spacing:.1em;
  font-size:12px;padding:6px 12px;border-radius:999px;border:2px solid var(--black);
  opacity:0;transform:translateY(8px);transition:all .25s ease;
}
.tile:hover .label{opacity:1;transform:translateY(0)}

.tile.t1{grid-column:span 5;grid-row:span 3}
.tile.t2{grid-column:span 4;grid-row:span 2}
.tile.t3{grid-column:span 3;grid-row:span 2}
.tile.t4{grid-column:span 4;grid-row:span 2;background:var(--blue)}
.tile.t5{grid-column:span 3;grid-row:span 3}
.tile.t6{grid-column:span 5;grid-row:span 2;background:var(--pink)}
.tile.t7{grid-column:span 4;grid-row:span 2;background:var(--green)}
.tile.t8{grid-column:span 3;grid-row:span 2;background:var(--purple)}
.tile.t9{grid-column:span 5;grid-row:span 2;background:var(--yellow)}

.tile--text{
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:24px;border-color:transparent;
}
.tile--text .big{
  font-family:var(--display);font-size:var(--text-tile);line-height:.95;
  color:var(--black);
}
.tile.t4 .big,.tile.t8 .big{color:var(--white)}
.tile--yellow{background:var(--yellow)}
.tile--gradient{
  background:linear-gradient(135deg,var(--pink),var(--orange));
  position:relative;
}
.tile__illus{position:absolute;inset:0;width:100%;height:100%}

/* ---------- TICKETS ---------- */
.tickets{
  background:var(--purple);
  color:var(--white);
  padding:96px 5vw;position:relative;overflow:hidden;
}
.tickets__head{
  text-align:center;margin-bottom:48px;
}
.tickets h2{
  font-family:var(--display);font-size:var(--text-section-lg);line-height:.88;
  color:var(--white);letter-spacing:-.02em;
}
.tickets h2 em{
  font-style:normal;color:var(--green);
  -webkit-text-stroke:2px var(--black);
}
.tickets__status{
  font-family:var(--headline);text-transform:uppercase;
  letter-spacing:.12em;font-size:13px;
  color:var(--yellow);margin-top:16px;
}
.tickets__sub{
  font-family:var(--body);
  letter-spacing:.02em;
  font-size:var(--text-body-md);margin-top:10px;opacity:.9;
}
.tickets__soldout{
  display:flex;flex-wrap:wrap;justify-content:center;gap:12px;
  max-width:760px;margin:0 auto 28px;
}
.soldout-row{
  display:inline-flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  padding:10px 18px;
}
.soldout-row__name{
  font-family:var(--headline);text-transform:uppercase;
  letter-spacing:.1em;font-size:13px;color:var(--white);
}
.soldout-row__tag{
  font-family:var(--headline);text-transform:uppercase;
  letter-spacing:.1em;font-size:11px;
  color:rgba(255,255,255,.6);
  border:1px solid rgba(255,255,255,.3);
  border-radius:999px;padding:4px 10px;
}
.tickets__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.tickets__grid--two{
  grid-template-columns:repeat(2,1fr);
  max-width:760px;margin:0 auto;
}
.ticket{
  background:rgba(255,255,255,.96);color:var(--sky-deep);
  border:2px solid rgba(255,255,255,.5);border-radius:20px;
  padding:32px 28px;position:relative;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:var(--shadow-card);
  transition:transform .25s ease,box-shadow .25s;
  cursor:pointer;
}
.ticket:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft)}
.ticket .tier{
  font-family:var(--headline);text-transform:uppercase;letter-spacing:.15em;
  font-size:13px;
}
.ticket .price{
  font-family:var(--display);font-size:var(--text-price);line-height:.9;letter-spacing:-.02em;
}
.ticket .price small{font-size:18px;display:block;letter-spacing:.05em;font-family:var(--headline);text-transform:uppercase;margin-top:6px}
.ticket ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:8px;font-family:var(--body);font-size:var(--text-body-sm);font-weight:500}
.ticket ul li{display:flex;gap:10px;align-items:flex-start}
.ticket ul li::before{content:"";display:inline-block;width:16px;height:16px;background:var(--sky-0);border-radius:50%;flex-shrink:0;margin-top:3px}
.ticket .btn-sky,.ticket .btn-bold{margin-top:auto;align-self:flex-start}

.ticket--featured{
  background:var(--white);
  border-color:rgba(255,255,255,.85);
  transform:rotate(-1deg) scale(1.02);
  box-shadow:0 16px 40px rgba(0,0,0,.28);
}
.ticket--featured::before{
  content:"LIVE NOW";
  position:absolute;top:-14px;right:24px;
  background:var(--green);color:var(--black);
  font-family:var(--headline);font-size:12px;letter-spacing:.14em;
  padding:8px 16px;border-radius:999px;border:3px solid var(--black);
  transform:rotate(4deg);box-shadow:6px 6px 0 var(--black);
}
.ticket--sold-out{
  opacity:.72;
  background:#f0f0f0;color:#666;
  border-color:rgba(0,0,0,.15);
  pointer-events:none;
}
.ticket--sold-out ul li::before{background:#999}
.ticket--sold-out .price{text-decoration:line-through;text-decoration-color:rgba(0,0,0,.25)}
.ticket--soon{
  background:rgba(255,255,255,.12);color:var(--white);
  border:2px dashed rgba(255,255,255,.45);
  box-shadow:none;
}
.ticket--soon:hover,.ticket--sold-out:hover{transform:none;box-shadow:none}
.ticket--soon ul li::before{background:var(--yellow)}
.ticket--soon .btn-sky--muted{
  background:rgba(255,255,255,.15);color:var(--white);
  border:2px solid rgba(255,255,255,.5);box-shadow:none;
}
.ticket__badge{
  margin-top:auto;align-self:flex-start;
  font-family:var(--headline);text-transform:uppercase;
  font-size:12px;letter-spacing:.12em;
  padding:10px 16px;border-radius:999px;
  border:2px solid var(--black);
}
.ticket__badge--sold{background:var(--black);color:var(--white)}
.tickets__gate{
  text-align:center;margin-top:32px;
  font-family:var(--headline);text-transform:uppercase;
  letter-spacing:.14em;font-size:13px;
  color:var(--yellow);
}
.tickets__partner{
  text-align:center;margin-top:16px;
  font-family:var(--body);letter-spacing:.02em;
  font-size:14px;opacity:.85;
}
.tickets__partner a{color:inherit;text-decoration:underline;text-underline-offset:3px}
.tickets__partner a:hover{color:var(--yellow)}
.section-tag--yellow{color:var(--yellow);border-color:var(--yellow)}

/* ---------- MERCH ---------- */
.merch{
  background:var(--yellow);
  color:var(--black);
  padding:96px 5vw;
  position:relative;
  overflow:hidden;
}
.merch__head{
  text-align:center;
  max-width:820px;
  margin:0 auto 48px;
}
.merch h2{
  font-family:var(--display);
  font-size:var(--text-section);
  line-height:.88;
  letter-spacing:-.02em;
  margin-top:12px;
}
.merch h2 em{
  font-style:normal;
  color:var(--purple);
  -webkit-text-stroke:2px var(--black);
}
.merch__lead{
  font-family:var(--body);
  font-size:var(--text-body-lg);
  font-weight:600;
  margin-top:18px;
  line-height:1.45;
}
.merch__status{
  font-family:var(--headline);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:13px;
  margin-top:12px;
  color:var(--black);
}
.merch__status strong{
  color:var(--purple);
}
.merch__grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
  max-width:920px;
  margin:0 auto;
}
.merch__item{
  position:relative;
  background:var(--white);
  border:3px solid var(--black);
  border-radius:20px;
  padding:20px;
  box-shadow:8px 8px 0 var(--black);
  transition:transform .25s ease, box-shadow .25s ease;
  cursor:pointer;
}
.merch__item:hover{
  transform:translateY(-6px) rotate(-1deg);
  box-shadow:12px 14px 0 var(--black);
}
.merch__badge{
  position:absolute;
  top:-14px;
  left:20px;
  z-index:2;
  background:var(--green);
  color:var(--black);
  font-family:var(--headline);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:11px;
  padding:8px 14px;
  border-radius:999px;
  border:2px solid var(--black);
  transform:rotate(-3deg);
  box-shadow:4px 4px 0 var(--black);
}
.merch__figure{
  margin:0;
  border-radius:12px;
  overflow:hidden;
  background:var(--cream);
}
.merch__figure img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}
.merch__cta{
  text-align:center;
  margin-top:40px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
}
.merch__how{
  font-family:var(--body);
  font-size:var(--text-body-md);
  font-weight:600;
  max-width:36ch;
  line-height:1.5;
}
.btn-merch{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:14px 28px;
  border-radius:999px;
  border:3px solid var(--black);
  background:var(--purple);
  color:var(--white);
  font-family:var(--headline);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:13px;
  box-shadow:6px 6px 0 var(--black);
  transition:transform .2s ease, box-shadow .2s ease;
}
.btn-merch:hover{
  transform:translateY(-2px);
  box-shadow:8px 10px 0 var(--black);
}

/* ---------- SPECIAL PACKAGES ---------- */
.packages{
  background:var(--black);
  color:var(--white);
  padding:96px 5vw;
  position:relative;
  overflow:hidden;
}
.packages__head{
  text-align:center;
  margin-bottom:48px;
}
.packages h2{
  font-family:var(--display);
  font-size:var(--text-section);
  line-height:.88;
  letter-spacing:-.02em;
  margin-top:12px;
}
.packages h2 em{
  font-style:normal;
  color:var(--yellow);
  -webkit-text-stroke:2px var(--black);
}
.packages__sub{
  font-family:var(--body);
  font-size:var(--text-body-md);
  margin-top:14px;
  opacity:.85;
  letter-spacing:.02em;
}
.packages__slider{
  max-width:1240px;
  margin:0 auto;
}
.packages__hint,
.packages__dots{display:none}
.packages__track{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.pass{
  --pass-top:#3cc7fc;
  --pass-bottom:#9b3cff;
  --pass-perk-bg:#9b3cff;
  --pass-perk-text:var(--white);
  --pass-title:var(--white);
  --pass-shadow:#6a1fd4;
  --pass-label-bg:var(--yellow);
  --pass-label-text:var(--purple);
  --pass-tagline:var(--white);
  --pass-cta-bg:var(--white);
  --pass-cta-text:var(--purple);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow-card);
  display:flex;
  flex-direction:column;
  transition:transform .25s ease,box-shadow .25s;
  cursor:pointer;
}
.pass:hover{
  transform:translateY(-8px) rotate(-1deg);
  box-shadow:0 20px 48px rgba(0,0,0,.35);
}
.pass--goodtimes{
  --pass-top:#ff6a1f;
  --pass-bottom:var(--yellow);
  --pass-perk-bg:var(--yellow);
  --pass-perk-text:var(--purple);
  --pass-title:var(--purple);
  --pass-shadow:#d4a800;
  --pass-label-bg:var(--orange);
  --pass-label-text:var(--white);
  --pass-tagline:var(--purple);
  --pass-cta-bg:var(--purple);
  --pass-cta-text:var(--white);
}
.pass--fullcircle{
  --pass-top:#ffb8d9;
  --pass-bottom:#d4007a;
  --pass-perk-bg:#ff4da6;
  --pass-perk-text:var(--white);
  --pass-title:var(--white);
  --pass-shadow:#8f0050;
  --pass-label-bg:#ffc4e0;
  --pass-label-text:#b00062;
  --pass-tagline:var(--white);
  --pass-cta-bg:var(--white);
  --pass-cta-text:#b00062;
}
.pass__top{
  background:var(--pass-top);
  padding:28px 22px 18px;
  flex:1;
}
.pass--lovebird .pass__top{background:linear-gradient(180deg,#5ed4ff 0%,var(--pass-top) 100%)}
.pass--fullcircle .pass__top{background:linear-gradient(180deg,#ffd0e8 0%,var(--pass-top) 100%)}
.pass__brands{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom:22px;
}
.pass__brands img{
  filter:brightness(0) invert(1);
  width:clamp(72px,8vw,96px);
  height:auto;
}
.pass--goodtimes .pass__brands img,
.pass--goodtimes .pass__x,
.pass--goodtimes .pass__partner{color:var(--white)}
.pass__x{
  font-family:var(--display);
  font-size:18px;
  opacity:.85;
}
.pass__partner{
  font-family:var(--headline);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:13px;
}
.pass__perks{
  list-style:none;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.pass__perks li{
  background:var(--pass-perk-bg);
  color:var(--pass-perk-text);
  border-radius:14px;
  padding:12px 10px;
  font-family:var(--body);
  font-size:12px;
  font-weight:600;
  line-height:1.35;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:8px;
  min-height:108px;
  justify-content:center;
}
.pass__icon{
  width:28px;
  height:28px;
  flex-shrink:0;
}
.pass__icon svg{width:100%;height:100%}
.pass__tear{
  height:14px;
  background:var(--pass-bottom);
  clip-path:polygon(
    0% 0%,4% 100%,8% 0%,12% 100%,16% 0%,20% 100%,24% 0%,28% 100%,32% 0%,36% 100%,
    40% 0%,44% 100%,48% 0%,52% 100%,56% 0%,60% 100%,64% 0%,68% 100%,72% 0%,76% 100%,
    80% 0%,84% 100%,88% 0%,92% 100%,96% 0%,100% 100%,100% 0%
  );
  margin-top:-1px;
}
.pass__bottom{
  background:var(--pass-bottom);
  color:var(--pass-tagline);
  padding:28px 22px 32px;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}
.pass__price{
  background:var(--yellow);
  color:var(--purple);
  font-family:var(--display);
  font-size:clamp(18px,2vw,22px);
  letter-spacing:.04em;
  padding:10px 22px;
  border-radius:8px;
  transform:rotate(-3deg);
  box-shadow:4px 4px 0 rgba(0,0,0,.2);
  margin-bottom:6px;
}
.pass__name{
  font-family:var(--display);
  font-size:clamp(26px,2.8vw,36px);
  line-height:.95;
  letter-spacing:-.02em;
  color:var(--pass-title);
  text-transform:uppercase;
  text-shadow:
    3px 3px 0 var(--pass-shadow),
    6px 6px 0 var(--pass-shadow);
}
.pass__label{
  font-family:var(--headline);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:12px;
  background:var(--pass-label-bg);
  color:var(--pass-label-text);
  padding:8px 18px;
  border-radius:999px;
  border:2px solid rgba(0,0,0,.12);
}
.pass__tagline{
  font-family:var(--body);
  font-size:var(--text-body-sm);
  font-weight:600;
  max-width:22ch;
  line-height:1.45;
  margin-top:4px;
}
.pass__cta{
  margin-top:10px;
  font-family:var(--headline);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:13px;
  background:var(--pass-cta-bg);
  color:var(--pass-cta-text);
  padding:12px 24px;
  border-radius:999px;
  border:2px solid rgba(0,0,0,.15);
  box-shadow:0 8px 20px rgba(0,0,0,.18);
  transition:transform .2s ease,box-shadow .2s;
}
.pass__cta:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(0,0,0,.25);
}
@keyframes packages-swipe-hint{
  0%,100%{transform:translateX(0)}
  50%{transform:translateX(7px)}
}

/* ---------- FAQ ---------- */
.faq{
  background:linear-gradient(180deg,#e8f7ff 0%,#fff6dc 100%);
  color:var(--sky-deep);
  padding:96px 5vw;
}
.faq__head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-bottom:40px}
.faq h2{
  font-family:var(--display);font-size:var(--text-section);line-height:.88;
  color:var(--sky-deep);letter-spacing:-.02em;
}
.faq h2 em{font-style:normal;color:var(--sky-0)}
.faq__list{display:flex;flex-direction:column;gap:14px;max-width:1100px}
.faq-item{
  background:rgba(255,255,255,.85);border:2px solid rgba(0,150,232,.25);border-radius:16px;
  padding:24px 28px;
  box-shadow:var(--shadow-card);
  cursor:pointer;
  transition:background .2s,transform .2s,box-shadow .2s;
}
.faq-item:hover{transform:translateX(4px);box-shadow:var(--shadow-soft)}
.faq-item summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--headline);text-transform:uppercase;letter-spacing:.05em;
  font-size:clamp(16px,1.6vw,20px);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .plus{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--sky-deep),var(--sky-0));color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:24px;flex-shrink:0;
  transition:transform .25s ease;
}
.faq-item[open] summary .plus{transform:rotate(45deg);background:var(--sky-1);color:var(--white)}
.faq-item .answer{
  margin-top:16px;font-family:var(--body);font-size:var(--text-body-md);line-height:1.5;font-weight:500;max-width:760px;color:rgba(6,58,95,.9);
}
.faq-item[open]{background:var(--white)}

/* ---------- FOOTER ---------- */
.footer{
  background:linear-gradient(180deg,var(--sky-deep) 0%,#063a5f 18%,var(--black) 42%);
  color:var(--white);
  padding:80px 5vw 40px;position:relative;overflow:hidden;
}
.footer__brand{
  text-align:center;margin-bottom:48px;
}
.footer__logo{
  width:clamp(160px,22vw,240px);height:auto;margin:0 auto;
  filter:drop-shadow(0 4px 20px rgba(255,255,255,.08));
}
.footer__row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px;
  border-top:2px solid #2a2a2a;border-bottom:2px solid #2a2a2a;
  padding:40px 0;
}
.footer__col h4{
  font-family:var(--headline);text-transform:uppercase;letter-spacing:.12em;
  font-size:13px;color:rgba(255,255,255,.85);margin-bottom:18px;
}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-family:var(--body);font-size:var(--text-body-md);font-weight:500}
.footer__col a:hover{color:var(--sky-1)}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  margin-top:32px;font-family:var(--mono);font-size:12px;color:#888;
  letter-spacing:.08em;text-transform:uppercase;
}
.footer__socials{display:flex;gap:10px}
.footer__socials a{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.15);color:var(--white);
  border:2px solid rgba(255,255,255,.35);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,color .2s,transform .2s;
}
.footer__socials a:hover{background:rgba(255,255,255,.28);transform:rotate(-8deg) scale(1.08)}
.footer__socials svg{width:22px;height:22px}
.footer__submit{margin-top:8px}

/* ---------- Image Lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
}
.lightbox.is-open{opacity:1;pointer-events:auto}
.lightbox__backdrop{
  position:absolute;inset:0;
  background:rgba(0,0,0,.85);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.lightbox__content{
  position:relative;z-index:2;
  max-width:100%;max-height:100%;
  display:flex;align-items:center;justify-content:center;
}
.lightbox__content img{
  max-width:100%;max-height:92vh;
  object-fit:contain;border-radius:12px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.lightbox__close{
  position:absolute;top:-40px;right:0;
  color:var(--white);background:none;border:none;
  font-size:32px;line-height:1;cursor:pointer;
  opacity:.7;transition:opacity .2s;
  padding:4px;
}
.lightbox__close:hover{opacity:1}

/* ---------- Signup modal (coming-soon) ---------- */
body.signup-modal-open{overflow:hidden}
.signup-modal{
  position:fixed;inset:0;z-index:150;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,32px);
  pointer-events:none;opacity:0;
  transition:opacity .22s ease;
}
.signup-modal.is-open{pointer-events:auto;opacity:1}
.signup-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(0,60,110,.45);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.signup-modal__dialog{
  position:relative;width:min(100%,420px);max-height:min(90vh,560px);overflow:auto;
  padding:clamp(1.5rem,5vw,2rem);border-radius:20px;
  border:2px solid rgba(255,255,255,.55);
  background:linear-gradient(165deg,rgba(255,255,255,.97) 0%,rgba(230,248,255,.98) 100%);
  color:#0a4d7a;
  box-shadow:0 20px 50px rgba(0,70,130,.35);
  transform:translateY(12px) scale(.98);
  transition:transform .22s cubic-bezier(.22,1,.36,1);
}
.signup-modal.is-open .signup-modal__dialog{transform:translateY(0) scale(1)}
.signup-modal__close{
  position:absolute;top:.65rem;right:.75rem;width:2.25rem;height:2.25rem;
  padding:0;border:none;border-radius:50%;background:transparent;
  color:#0a4d7a;font-size:1.65rem;line-height:1;cursor:pointer;opacity:.65;
  transition:opacity .15s ease,background .15s ease;
}
.signup-modal__close:hover{opacity:1;background:rgba(0,120,200,.1)}
.signup-modal__eyebrow{
  margin:0 0 .35rem;font-size:clamp(10px,2vw,12px);font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--sky-deep);
}
.signup-modal__title{
  margin:0 0 .5rem;font-family:var(--headline);
  font-size:clamp(1.35rem,5vw,1.75rem);font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;line-height:1.1;color:#063a5f;
}
.signup-modal__desc{
  margin:0 0 1.25rem;font-size:clamp(.85rem,2.5vw,.95rem);
  line-height:1.45;color:rgba(6,58,95,.85);
}
.signup-form{display:flex;flex-direction:column;gap:.5rem}
.signup-form__label{
  font-size:.75rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:#063a5f;
}
.signup-form__input{
  width:100%;padding:.85em 1em;
  border:2px solid rgba(0,150,232,.35);border-radius:12px;
  background:var(--white);color:#063a5f;font:inherit;font-size:1rem;
  transition:border-color .15s ease,box-shadow .15s ease;
}
.signup-form__input::placeholder{color:rgba(6,58,95,.4)}
.signup-form__input:focus{
  outline:none;border-color:var(--sky-deep);
  box-shadow:0 0 0 3px rgba(0,167,252,.25);
}
.signup-form__error{margin:0;font-size:.85rem;color:#c42b2b}
.signup-form__submit{
  margin-top:.35rem;padding:.9em 1.25em;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--sky-deep) 0%,var(--sky-0) 50%,var(--sky-1) 100%);
  color:var(--white);font-family:var(--headline);
  font-size:clamp(12px,2.5vw,14px);font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;box-shadow:0 8px 22px rgba(0,120,200,.35);
  transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease;
}
.signup-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,120,200,.4)}
.signup-form__submit:disabled{opacity:.7;cursor:wait}
.signup-form__fine{margin:.5rem 0 0;font-size:.75rem;line-height:1.4;color:rgba(6,58,95,.65);text-align:center}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .halftone{opacity:.5}
  .page-loader,.page-loader__logo,.page-loader__bar{animation:none}
  .hero-doodle{animation:none}
  .hero-doodle--right-middle{transform:translateY(-50%)}
  .hero__chip--live::before{animation:none}
  body.is-hero-revealed .hero__logo,
  body.is-hero-revealed .hero__tagline,
  body.is-hero-revealed .hero__cta,
  body.is-hero-revealed .hero__lockup{animation:none;opacity:1;transform:none}
  .reveal{opacity:1;transform:none;transition:none}
  .lineup.in .lineup__line{animation:none}
  .packages__hint-arrow{animation:none}
}

/* ---------- Responsive ---------- */
@media (max-width:1100px){
  .about__grid{grid-template-columns:1fr}
  .about__art{height:480px;margin-top:32px}
  .zones__grid{grid-template-columns:repeat(2,1fr)}
  .tickets__grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .ticket--featured{transform:none}
  .footer__row{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(6,1fr)}
  .tile{grid-column:span 3 !important;grid-row:span 2 !important}
}

/* ---------- PACKAGES: swipe carousel (tablet + mobile) ---------- */
@media (max-width:1000px){
  .packages__slider{
    position:relative;
    margin:0 -5vw;
    max-width:none;
  }
  .packages__slider::before,
  .packages__slider::after{
    content:"";
    position:absolute;
    top:8px;
    bottom:56px;
    width:5vw;
    z-index:2;
    pointer-events:none;
    transition:opacity .45s ease;
  }
  .packages__slider::before{
    left:0;
    background:linear-gradient(90deg,var(--black) 0%,transparent 100%);
  }
  .packages__slider::after{
    right:0;
    background:linear-gradient(-90deg,var(--black) 0%,transparent 100%);
  }
  .packages__slider--engaged::before,
  .packages__slider--engaged::after{opacity:0}
  .packages__hint{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    font-family:var(--headline);
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:11px;
    color:var(--yellow);
    margin:0 5vw 16px;
    transition:opacity .4s ease,max-height .4s ease,margin .4s ease;
  }
  .packages__hint-arrow{
    display:inline-block;
    animation:packages-swipe-hint 1.3s ease-in-out infinite;
  }
  .packages__slider--engaged .packages__hint{
    opacity:0;
    max-height:0;
    margin-bottom:0;
    overflow:hidden;
  }
  .packages__track{
    display:flex;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    scroll-snap-type:x mandatory;
    gap:16px;
    padding:8px max(5vw,calc((100% - 360px) / 2)) 28px;
    scroll-padding-inline:max(5vw,calc((100% - 360px) / 2));
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .packages__track::-webkit-scrollbar{display:none}
  .packages__track:focus-visible{outline:3px solid var(--yellow);outline-offset:4px}
  .pass{
    flex:0 0 min(82vw,360px);
    scroll-snap-align:center;
    scroll-snap-stop:always;
  }
  .pass:hover{transform:none;box-shadow:var(--shadow-card)}
  .packages__dots{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
    margin-top:20px;
    padding:0 5vw;
  }
  .packages__dot{
    width:9px;
    height:9px;
    border-radius:50%;
    background:rgba(255,255,255,.3);
    border:0;
    padding:0;
    cursor:pointer;
    transition:transform .25s ease,background .25s ease;
  }
  .packages__dot.is-active{
    background:var(--yellow);
    transform:scale(1.4);
  }
  /* tighter card internals so cards aren't overly tall */
  .pass__top{padding:22px 18px 16px}
  .pass__perks{gap:8px}
  .pass__perks li{min-height:96px;padding:11px 8px;font-size:11.5px}
  .pass__bottom{padding:24px 18px 28px;gap:9px}
  .pass__name{font-size:clamp(24px,7vw,32px)}
}
@media (max-width:680px){
  .menu-btn{top:calc(var(--ticker-h) + 8px);right:12px;padding:10px 16px;font-size:12px;min-height:42px}
  /* Hero: header hidden on mobile, so center the logo + CTA block */
  .hero{
    padding:calc(var(--ticker-h) + 36px) 5vw 56px;
    justify-content:center;
  }
  .hero__title-wrap{
    padding:24px 0;
    gap:clamp(1.1rem,4vh,1.6rem);
  }
  .hero__logo{width:clamp(200px,62vw,320px)}
  .hero__tagline{
    font-size:14px;
    max-width:300px;
    line-height:1.5;
  }
  /* Doodles: corner-anchored exactly like the coming-soon reference */
  .hero-doodle--left-up{top:-2%;width:170px;height:310px;left:-28px}
  .hero-doodle--left-down{width:191px;height:444px;left:-32px}
  .hero-doodle--right-down{right:-32px;width:164px;height:191px}
  .hero-doodle--smiley{bottom:0;left:-2%;width:clamp(135px,36vw,225px);height:clamp(135px,36vw,225px);margin:-17px -15px}
  .hero-doodle--right-middle{right:-24px;width:clamp(70px,18vw,292px);height:auto;aspect-ratio:292/557}
  .hero-doodle--sunface{
    top:-2%;
    right:-2%;
    width:clamp(120px,32vw,163px);
    height:auto;
    aspect-ratio:215/191;
    margin:9px 12px;
  }
  .hero__lockup{margin-top:8px}
  .hero__lockup img{width:clamp(116px,34vw,170px)}
  .hero__cta{
    width:100%;
    max-width:300px;
    margin:0 auto;
    flex-direction:column;
  }
  .hero__cta .btn-glass{
    width:100%;
    flex:1 1 auto;
    min-height:52px;
    font-size:13px;
  }
  .zones__grid{grid-template-columns:1fr}
  .tickets__grid{grid-template-columns:1fr;gap:32px}
  .footer__row{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .tile{grid-column:span 1 !important;grid-row:span 2 !important}
  .about,.lineup,.zones,.tickets,.merch,.packages,.faq{padding:72px 5vw}
  .merch__grid{grid-template-columns:1fr;gap:32px;max-width:420px}
  .lineup__head{flex-direction:column;align-items:flex-start}
  .lineup__meta{text-align:left;max-width:none}
  .lineup__stage{transform:none;box-shadow:0 12px 32px rgba(0,80,140,.3)}
  .lineup__sticker{top:-12px;right:16px;font-size:11px;padding:8px 14px}
  .lineup__poster{border-radius:12px}
  .lineup__expand{
    opacity:1;transform:translateY(0);
    bottom:12px;right:12px;padding:6px 12px;font-size:10px;
    background:rgba(0,0,0,.65);
  }
  .lineup__expand svg{width:12px;height:12px}
  .lightbox{padding:16px}
  .lightbox__close{top:-36px;font-size:28px}
}
