:root{
  --planit-dark:#020617;
  --planit-blue:#0ea5e9;
  --planit-gold:#fbbf24;
  --planit-silver:#94a3b8;

  --slate-50:#f8fafc;
  --slate-100:#f1f5f9;
  --slate-200:#e2e8f0;
  --slate-300:#cbd5e1;
  --slate-400:#94a3b8;
  --slate-500:#64748b;
  --slate-600:#475569;
  --slate-700:#334155;
  --slate-800:#1e293b;
  --slate-900:#0f172a;
  --slate-950:#020617;

  --radius-xl: 1.25rem;
  --radius-2xl: 1.5rem;
  --radius-3xl: 1.875rem;

  --shadow-neon: 0 0 15px rgba(14,165,233,.4);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Outfit', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--planit-dark);
  color: var(--slate-100);
  overflow-x:hidden;
}

::selection{ background: var(--planit-blue); color:#fff; }

/* Custom scrollbar */
::-webkit-scrollbar{ width:8px; }
::-webkit-scrollbar-track{ background: var(--planit-dark); }
::-webkit-scrollbar-thumb{ background: var(--slate-700); border-radius:4px; }
::-webkit-scrollbar-thumb:hover{ background: var(--slate-600); }

.bg-texture{
  position:fixed;
  inset:0;
  background-image:url('https://www.transparenttextures.com/patterns/stardust.png');
  opacity:.2;
  pointer-events:none;
  z-index:0;
}

.container{
  width:min(1100px, calc(100% - 3rem));
  margin:0 auto;
}

/* Header */
.header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  transition: all .3s ease;
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 1.25rem 0;
}
.header--scrolled{
  background: rgba(2,6,23,.9);
  backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.header--scrolled .header__inner{ padding: .75rem 0; }

.brand{
  display:flex;
  align-items:center;
  gap:.6rem;
  text-decoration:none;
  color:#fff;
}
.brand__logo{
  position:relative;
  width:2.5rem;
  height:2.5rem;
  border-radius:999px;
  overflow:hidden;
  border:2px solid var(--planit-blue);
  box-shadow: 0 0 15px rgba(14,165,233,.5);
  transition: box-shadow .3s ease;
}
.brand__logo img{ width:100%; height:100%; object-fit:cover; display:block; }
.brand__logoOverlay{
  position:absolute; inset:0;
  background: linear-gradient(to top right, rgba(14,165,233,.4), transparent);
  mix-blend-mode: overlay;
}
.group:hover .brand__logo{ box-shadow: 0 0 25px rgba(14,165,233,.8); }
.brand__wordmark{ font-weight:900; letter-spacing:-.04em; font-size:1.6rem; }
.brand__dot{ color: var(--planit-blue); }

.nav{ display:flex; gap:2rem; align-items:center; }
.nav__link{
  position:relative;
  text-decoration:none;
  color: var(--slate-300);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  transition: color .2s ease;
}
.nav__link:hover{ color:#fff; }
.nav__link::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:0;
  height:2px;
  background: var(--planit-blue);
  transition: width .2s ease;
}
.nav__link:hover::after{ width:100%; }

.iconBtn{
  background:transparent;
  border:0;
  color:#fff;
  padding:.35rem;
  cursor:pointer;
}
.icon{ width:1.25rem; height:1.25rem; }
.icon--menu{ display:block; }
.icon--close{ display:none; }

.mobileNav{
  position:absolute;
  top:100%; left:0;
  width:100%;
  background: rgba(2,6,23,.95);
  backdrop-filter: blur(18px);
  border-bottom:1px solid rgba(255,255,255,.1);
  overflow:hidden;
  max-height:0;
  opacity:0;
  transition: all .3s ease;
}
.mobileNav__inner{ display:flex; flex-direction:column; gap:1rem; padding:1.5rem; }
.mobileNav__link{
  text-decoration:none;
  color: var(--slate-200);
  font-size:1.125rem;
  font-weight:800;
  transition: color .2s ease;
}
.mobileNav__link:hover{ color: var(--planit-blue); }

.header--menuOpen .mobileNav{ max-height:24rem; opacity:1; }
.header--menuOpen .icon--menu{ display:none; }
.header--menuOpen .icon--close{ display:block; }

/* Hero */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  padding-top: 5rem;
  padding-bottom: 3rem;
  overflow:hidden;
  z-index:1;
}
.hero__glow{
  position:absolute;
  width:24rem; height:24rem;
  border-radius:999px;
  filter: blur(100px);
  pointer-events:none;
}
.hero__glow--left{
  top:25%;
  left:-8rem;
  background: rgba(14,165,233,.2);
}
.hero__glow--right{
  bottom:0;
  right:-8rem;
  background: rgba(251,191,36,.1);
}

.hero__grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr;
  gap:3rem;
  align-items:center;
}
.hero__copy{ text-align:center; }

.pill{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.4rem 1rem;
  border-radius:999px;
  background: rgba(14,165,233,.10);
  border:1px solid rgba(14,165,233,.30);
  color: var(--planit-blue);
  font-size:.70rem;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.pill__dot{ width:.5rem; height:.5rem; border-radius:999px; background: var(--planit-blue); display:inline-block; }

.hero__h1{
  margin:0;
  font-weight:900;
  letter-spacing:-.04em;
  line-height: .95;
  font-size: clamp(3rem, 7vw, 5.5rem);
  background: linear-gradient(to right, #fff, var(--slate-200), var(--slate-400));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  filter: drop-shadow(0 0 30px rgba(255,255,255,.1));
}
.hero__h1Accent{
  background: linear-gradient(to right, var(--planit-blue), #a855f7);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero__h2{
  margin:.65rem 0 0;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size: clamp(1.5rem, 3.2vw, 2.25rem);
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.4));
}

.neon-text{ text-shadow: 0 0 10px rgba(14,165,233,.7); }

.heroMeta{
  margin-top: 1.25rem;
  display:flex;
  flex-direction:column;
  gap:.9rem;
  color: var(--slate-300);
  font-weight:600;
}
.heroMeta__item{ display:flex; align-items:center; justify-content:center; gap:.55rem; }
.icon--blue{ color: var(--planit-blue); }
.icon--gold{ color: var(--planit-gold); }
.icon--purple{ color: #c084fc; }

/* Countdown */
.countdown{ padding: .5rem 0 0; }
.countdown__titleRow{ display:flex; align-items:center; gap:.6rem; justify-content:center; margin: 1.1rem 0 1rem; }
.countdown__line{ height:1px; width:2rem; background: rgba(14,165,233,.5); }
.countdown__title{
  margin:0;
  font-size:.70rem;
  font-weight:900;
  letter-spacing:.2em;
  text-transform:uppercase;
  color: var(--planit-blue);
}
.countdown__grid{ display:flex; justify-content:center; gap:.75rem; }

.timeUnit{ display:flex; flex-direction:column; align-items:center; }
.timeUnit__box{
  position:relative;
  width:4rem; height:4rem;
  display:flex; align-items:center; justify-content:center;
  border-radius: .85rem;
  background: rgba(2,6,23,.65);
  border:1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
  box-shadow: 0 0 20px rgba(0,0,0,.5);
  transition: all .3s ease;
}
.group:hover .timeUnit__box{
  border-color: rgba(14,165,233,.5);
  box-shadow: 0 0 15px rgba(14,165,233,.3);
}
.timeUnit__value{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-weight:900;
  font-size:1.6rem;
  color:#fff;
  position:relative;
  z-index:1;
}
.timeUnit__shine{
  position:absolute; inset:0;
  border-radius: .85rem;
  background: linear-gradient(to bottom, rgba(255,255,255,.06), transparent);
}
.timeUnit__label{
  margin-top:.5rem;
  font-size:.65rem;
  font-weight:900;
  letter-spacing:.12em;
  color: var(--slate-500);
  transition: color .2s ease;
}
.group:hover .timeUnit__label{ color: var(--planit-blue); }

/* CTA */
.hero__cta{ padding-top:.5rem; }
.btnPrimary{
  position:relative;
  display:inline-flex;
  width:100%;
  align-items:center;
  justify-content:center;
  gap:.7rem;
  padding: 1rem 2rem;
  border-radius: 999px;
  border:0;
  background:#fff;
  color: var(--planit-dark);
  font-weight:900;
  font-size:1.05rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  transition: transform .3s ease, background .3s ease, color .3s ease, box-shadow .3s ease;
}
.btnPrimary:hover{
  background: var(--planit-blue);
  color:#fff;
  transform: scale(1.05);
  box-shadow: 0 0 30px rgba(14,165,233,.6);
}
.icon--arrow{ width:1.2rem; height:1.2rem; transition: transform .2s ease; }
.btnPrimary:hover .icon--arrow{ transform: translateX(4px); }
.btnPrimary__ring{
  position:absolute; inset:0;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.2);
  opacity:.3;
  pointer-events:none;
}
.btnPrimary:hover .btnPrimary__ring{ border-color: rgba(14,165,233,.5); }

/* Poster */
.hero__visual{ position:relative; display:flex; justify-content:center; align-items:center; }
.posterWrap{ width: min(420px, 100%); }
.poster{
  position:relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-3xl);
  overflow:hidden;
  background: var(--slate-800);
  border:1px solid rgba(255,255,255,.1);
  box-shadow: 0 25px 60px rgba(0,0,0,.45);
  transform: rotate(3deg);
  transition: transform .5s ease;
}
.poster:hover{ transform: rotate(0deg); }
.poster__shade{ position:absolute; inset:0; background: linear-gradient(to bottom, transparent, rgba(0,0,0,.8)); z-index:2; }
.poster__img{ width:100%; height:100%; object-fit:cover; transition: transform .7s ease; display:block; }
.poster:hover .poster__img{ transform: scale(1.10); }
.poster__text{ position:absolute; left:0; bottom:0; padding:2rem; z-index:3; }
.poster__tag{ font-size:.65rem; font-weight:900; letter-spacing:.18em; text-transform:uppercase; color: var(--planit-gold); margin-bottom:.5rem; }
.poster__title{ margin:0 0 .5rem; font-weight:900; font-size:1.75rem; line-height:1; }
.poster__desc{ margin:0; color: var(--slate-300); font-size:.9rem; }
.poster__glare{
  position:absolute; inset:0;
  background: linear-gradient(to top right, rgba(255,255,255,0), rgba(255,255,255,.05), rgba(255,255,255,0));
  opacity:0;
  transition: opacity .5s ease;
  z-index:4;
  pointer-events:none;
}
.poster:hover .poster__glare{ opacity:1; }

.floatBlob{
  position:absolute;
  width:6rem; height:6rem;
  border-radius:999px;
  filter: blur(18px);
  opacity:.7;
  mix-blend-mode:multiply;
  pointer-events:none;
}
.floatBlob--a{ top:-2.5rem; right:-2.5rem; background: var(--planit-blue); }
.floatBlob--b{ bottom:5rem; left:-2.5rem; width:4rem; height:4rem; background:#a855f7; }

/* Community */
.community{ padding:5rem 0; background: linear-gradient(to bottom, transparent, rgba(15,23,42,.5)); }
.communityCard{
  position:relative;
  border-radius: 2.5rem;
  overflow:hidden;
  background: var(--slate-900);
  border:1px solid rgba(255,255,255,.1);
  padding: clamp(2rem, 4vw, 4rem);
  text-align:center;
}
.communityCard__glowA{
  position:absolute; inset:0;
  left:50%; transform: translateX(-50%);
  width:66%;
  background: rgba(14,165,233,.05);
  filter: blur(48px);
  pointer-events:none;
}
.communityCard__glowB{
  position:absolute;
  right:-6rem; bottom:-6rem;
  width:16rem; height:16rem;
  background: rgba(34,197,94,.2);
  filter: blur(80px);
  pointer-events:none;
}
.communityCard__inner{ position:relative; z-index:1; max-width: 42rem; margin: 0 auto; }
.communityBadge{
  width:4rem; height:4rem;
  border-radius:999px;
  margin:0 auto 1rem;
  background: rgba(34,197,94,.2);
  color: rgba(74,222,128,1);
  display:flex; align-items:center; justify-content:center;
}
.communityCard__h2{ margin:0; font-size: clamp(2rem, 4vw, 3rem); font-weight:900; }
.text-green{ color: rgba(74,222,128,1); }
.communityCard__p{ margin:1rem 0 2rem; color: var(--slate-400); font-size:1.1rem; }
.btnWhatsApp{
  display:inline-flex;
  align-items:center;
  gap:.75rem;
  background: rgba(34,197,94,1);
  color:#fff;
  text-decoration:none;
  padding: 1rem 2rem;
  border-radius:999px;
  font-weight:900;
  font-size:1.05rem;
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
  box-shadow: 0 0 20px rgba(34,197,94,.4);
}
.btnWhatsApp:hover{ background: rgba(74,222,128,1); transform: scale(1.05); }

/* About */
.about{ padding:6rem 0; position:relative; overflow:hidden; }
.aboutGrid{ display:grid; grid-template-columns:1fr; gap:4rem; align-items:center; }
.aboutKicker{ display:flex; align-items:center; gap:.6rem; font-size:.8rem; font-weight:900; letter-spacing:.18em; text-transform:uppercase; color: var(--planit-gold); }
.aboutTitle{ margin:.75rem 0 0; font-weight:900; font-size: clamp(2.2rem, 4.6vw, 3.2rem); line-height:1.05; }
.text-blue{ color: var(--planit-blue); }
.aboutText{ margin:1.4rem 0 0; color: var(--slate-400); font-size:1.125rem; line-height:1.7; }
.strong{ color:#fff; font-weight:900; }
.aboutCards{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-top:1.5rem; }
.miniCard{
  padding:1rem;
  border-radius: 1.1rem;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(10px);
}
.miniCard h4{ margin:.65rem 0 0; font-weight:900; font-size:1.05rem; color:#fff; }
.miniCard p{ margin:.3rem 0 0; font-size:.75rem; color: var(--slate-400); }

.aboutVisual{ position:relative; }
.aboutVisual__glow{ position:absolute; inset:0; background: rgba(14,165,233,1); filter: blur(100px); opacity:.2; }
.videoCard{
  position:relative;
  border-radius: var(--radius-3xl);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.2);
  box-shadow: 0 25px 60px rgba(0,0,0,.5);
  aspect-ratio: 16/9;
  cursor:pointer;
}
.videoCard__img{ width:100%; height:100%; object-fit:cover; display:block; transition: transform .7s ease; }
.videoCard:hover .videoCard__img{ transform: scale(1.05); }
.videoCard__overlay{
  position:absolute; inset:0;
  background: rgba(0,0,0,.4);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1;
  transition: background .25s ease;
}
.videoCard:hover .videoCard__overlay{ background: rgba(0,0,0,.2); }
.playBtn{
  width:5rem; height:5rem;
  border-radius:999px;
  background: rgba(255,255,255,.2);
  border:1px solid rgba(255,255,255,.3);
  backdrop-filter: blur(10px);
  display:flex; align-items:center; justify-content:center;
  transition: transform .25s ease;
}
.videoCard:hover .playBtn{ transform: scale(1.1); }
.playTriangle{
  width:0; height:0;
  border-top:12px solid transparent;
  border-bottom:12px solid transparent;
  border-left:24px solid #fff;
  margin-left:6px;
}
.planet{ position:absolute; right:-2.5rem; bottom:-2.5rem; width:8rem; height:8rem; opacity:.5; pointer-events:none; }
.planet__ringA{ width:100%; height:100%; border-radius:999px; border:4px solid rgba(251,191,36,.3); transform: rotate(12deg); }
.planet__ringB{ position:absolute; inset:.5rem; border-radius:999px; border:2px solid rgba(251,191,36,.2); transform: rotate(-12deg); }

/* Gallery */
.gallery{ padding:6rem 0; background: rgba(0,0,0,.3); }
.galleryHead{ display:flex; align-items:flex-end; justify-content:space-between; gap:1.5rem; margin-bottom:3rem; }
.galleryTitle{ margin:0; font-weight:900; font-size:2.5rem; color:#fff; }
.gallerySub{ margin:.5rem 0 0; color: var(--slate-400); }
.galleryBtns{ display:flex; gap:.5rem; }
.circleBtn{
  width:3rem; height:3rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.2);
  background:transparent;
  color:#fff;
  cursor:pointer;
  transition: background .2s ease, color .2s ease;
}
.circleBtn:hover{ background:#fff; color:#000; }

.galleryStripWrap{ padding: 0 1.5rem; }
.galleryStrip{
  display:flex;
  gap:1.5rem;
  overflow-x:auto;
  padding: 0 0 2rem;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.galleryStrip__spacer{ flex: 0 0 1.5rem; }

.galleryCard{
  flex: 0 0 auto;
  width: 18rem;
  aspect-ratio: 3/4;
  border-radius: var(--radius-2xl);
  overflow:hidden;
  position:relative;
  scroll-snap-align:center;
}
.galleryCard img{ width:100%; height:100%; object-fit:cover; display:block; filter: grayscale(1); transition: transform .7s ease, filter .7s ease; }
.galleryCard:hover img{ transform: scale(1.10); filter: grayscale(0); }
.galleryCard__fade{ position:absolute; inset:0; background: linear-gradient(to top, rgba(0,0,0,.8), transparent, transparent); opacity:.6; z-index:1; }
.galleryCard__label{
  position:absolute;
  left:1rem;
  bottom:1rem;
  z-index:2;
  font-weight:900;
  font-size:1.125rem;
  color:#fff;
  transform: translateY(16px);
  opacity:0;
  transition: transform .3s ease, opacity .3s ease;
}
.galleryCard:hover .galleryCard__label{ transform: translateY(0); opacity:1; }

/* Footer */
.footer{ background: var(--slate-950); padding:5rem 0 2.5rem; border-top:1px solid rgba(255,255,255,.05); }
.footerInner{ display:flex; flex-direction:column; align-items:center; gap:2rem; text-align:center; }
.footerBrand h2{ margin:0; font-size:2rem; font-weight:900; letter-spacing:-.04em; }
.footerBrand p{ margin:.6rem 0 0; color: var(--slate-500); font-size:.9rem; }
.footerSocial{ display:flex; gap:1.25rem; }
.socialBtn{
  width:3rem; height:3rem;
  border-radius:999px;
  background: rgba(255,255,255,.05);
  display:flex; align-items:center; justify-content:center;
  color:#fff;
  text-decoration:none;
  transition: transform .3s ease, background .3s ease, border .3s ease;
}
.socialBtn:hover{ transform: scale(1.10); }
.socialBtn--ig:hover{ background:#db2777; }
.socialBtn--wa:hover{ background:#22c55e; }
.socialBtn--tt:hover{ background:#000; border:1px solid #fff; }
.socialBtn--mail:hover{ background:#3b82f6; }

.footerLinks{ display:flex; gap:1.5rem; flex-wrap:wrap; justify-content:center; }
.footerLinks a{ color: var(--slate-400); text-decoration:none; font-size:.9rem; transition: color .2s ease; }
.footerLinks a:hover{ color:#fff; }
.footerCopy{ font-size:.75rem; color: var(--slate-600); }

/* Modal */
.modal{ position:fixed; inset:0; z-index:100; display:none; align-items:center; justify-content:center; padding:1rem; }
.modal.is-open{ display:flex; }
.modal__backdrop{ position:absolute; inset:0; background: rgba(0,0,0,.8); backdrop-filter: blur(6px); }

.modalCard{
  position:relative;
  width: min(420px, 100%);
  background: var(--slate-900);
  border:1px solid var(--slate-700);
  border-radius: var(--radius-3xl);
  box-shadow: 0 0 50px rgba(0,0,0,.8);
  overflow:hidden;
  z-index:1;
}
.modalHead{ position:relative; background: linear-gradient(to right, var(--planit-dark), var(--slate-900)); padding:1.5rem; border-bottom:1px solid rgba(255,255,255,.05); }
.modalClose{ position:absolute; right:1rem; top:1rem; background:transparent; border:0; color: var(--slate-400); cursor:pointer; padding:.35rem; }
.modalClose:hover{ color:#fff; }
.modalHead__center{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:.35rem; }
.modalBadge{ width:3rem; height:3rem; border-radius:999px; display:flex; align-items:center; justify-content:center; background: rgba(14,165,233,.10); border:1px solid rgba(14,165,233,.2); color: var(--planit-blue); margin-bottom:.4rem; }
.modalHead h2{ margin:.2rem 0 0; font-size:1.35rem; font-weight:900; }
.modalHead p{ margin:0; color: var(--slate-400); font-size:.9rem; }

.modalForm{ padding:1.5rem; display:flex; flex-direction:column; gap:1.25rem; }
.formGroup label{ display:block; font-size:.72rem; font-weight:900; letter-spacing:.14em; text-transform:uppercase; color: var(--slate-400); margin-bottom:.55rem; }
.inputWrap{ position:relative; }
.inputIcon{ position:absolute; left:1rem; top:50%; transform: translateY(-50%); width:1.25rem; height:1.25rem; color: var(--slate-500); }
.inputWrap input{
  width:100%;
  background: #020617;
  border:1px solid #1f2937;
  border-radius: 1rem;
  padding: .95rem 1rem .95rem 3rem;
  color:#fff;
  outline:none;
  transition: border .2s ease, box-shadow .2s ease;
}
.inputWrap input::placeholder{ color: var(--slate-600); }
.inputWrap input:focus{ border-color: var(--planit-blue); box-shadow: 0 0 0 1px var(--planit-blue); }

.btnCheckout{
  width:100%;
  padding:1rem;
  border-radius: 1rem;
  border:0;
  background:#fff;
  color: var(--planit-dark);
  font-weight:900;
  font-size:1.05rem;
  cursor:pointer;
  transition: background .3s ease, color .3s ease, transform .2s ease, opacity .2s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
}
.btnCheckout:hover{ background: var(--planit-blue); color:#fff; }
.btnCheckout:disabled{ opacity:.7; cursor:not-allowed; }
.btnCheckout__spinner{ display:none; }
.btnCheckout.is-loading .btnCheckout__spinner{ display:inline-flex; }

.modalFineprint{ margin:0; text-align:center; font-size:.75rem; color: var(--slate-500); }

/* Helpers */
.lineClamp2{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.scrollbar-hide::-webkit-scrollbar{ display:none; }
.scrollbar-hide{ scrollbar-width:none; -ms-overflow-style:none; }

/* Animations */
@keyframes pulse{ 0%,100%{ opacity:1 } 50%{ opacity:.5 } }
@keyframes ping{ 75%,100%{ transform: scale(2); opacity:0 } }
@keyframes bounce{ 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-12px) } }
@keyframes fadeInUp{ from{ opacity:0; transform: translateY(14px) } to{ opacity:1; transform: translateY(0) } }
@keyframes spin{ to{ transform: rotate(360deg) } }

.animate-pulse{ animation: pulse 2s cubic-bezier(.4,0,.6,1) infinite; }
.animate-ping{ animation: ping 1.4s cubic-bezier(0,0,.2,1) infinite; }
.animate-bounce{ animation: bounce 1.4s infinite; }
.animate-fade-in-up{ animation: fadeInUp .6s ease both; }
.animate-spin{ animation: spin 1s linear infinite; }

.delay-700{ animation-delay:.7s; }
.delay-1000{ animation-delay:1s; }

/* Responsive */
@media (min-width: 768px){
  .nav--desktop{ display:flex; }
  .nav__toggle{ display:none; }
  .hero__grid{ grid-template-columns: 1fr 1fr; }
  .hero__copy{ text-align:left; }
  .heroMeta{ flex-direction:row; justify-content:flex-start; gap:2rem; }
  .heroMeta__item{ justify-content:flex-start; }
  .countdown__titleRow{ justify-content:flex-start; }
  .countdown__grid{ justify-content:flex-start; gap:1.25rem; }
  .btnPrimary{ width:auto; }
  .timeUnit__box{ width:5rem; height:5rem; }
  .timeUnit__value{ font-size:2rem; }
  .galleryCard{ width:24rem; }
  .aboutGrid{ grid-template-columns: 1.05fr .95fr; }
}

@media (max-width: 767px){
  .nav--desktop{ display:none; }
}


/* Signup counter next to CTA */
.heroCtaRow{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1rem;
  flex-wrap:wrap;
}
.signupCounter{
  display:flex;
  align-items:baseline;
  gap:.5rem;
  padding:.75rem 1rem;
  border-radius:999px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
}
.signupCounter__label{
  font-size:.70rem;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color: var(--slate-400);
}
.signupCounter__value{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-weight:900;
  font-size:1.05rem;
  color:#fff;
}

/* Align left on desktop like existing CTA */
@media (min-width: 768px){
  .heroCtaRow{ justify-content:flex-start; }
}


/* Video card */
.videoCard__video{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius: inherit;
}


/* Video: click-to-play without showing a thumbnail frame */
.videoCard--clickToPlay{
  position:relative;
}
.videoCard--clickToPlay .videoCard__video{
  opacity:0;
  pointer-events:none;
}
.videoCard--clickToPlay.is-playing .videoCard__video{
  opacity:1;
  pointer-events:auto;
}
\.videoCard--clickToPlay .videoCard__overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:2;
  transition: opacity .25s ease;
}
.videoCard--clickToPlay.is-playing .videoCard__overlay{
  opacity:0;
  pointer-events:none;
}
.videoCard--clickToPlay .videoCard__video{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius: inherit;
  transition: opacity .25s ease;
}


/* Promo (48-hour discount) */
.promoCard{
  margin-top: 1.25rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem 1.1rem;
  border-radius: 1.25rem;
  background: linear-gradient(135deg, rgba(236,72,153,.14), rgba(14,165,233,.10));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  position:relative;
  overflow:hidden;
}
.promoCard::before{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 20% 30%, rgba(236,72,153,.22), transparent 55%),
              radial-gradient(circle at 70% 60%, rgba(14,165,233,.18), transparent 60%);
  filter: blur(12px);
  opacity:.9;
  pointer-events:none;
}
.promoCard__left, .promoCard__right{ position:relative; z-index:1; }
.promoCard__left{ min-width: 14rem; }

.promoBadge{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.35rem .65rem;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  margin-bottom:.6rem;
}
.promoBadge__dot{
  width:.5rem;height:.5rem;border-radius:999px;
  background: rgba(236,72,153,1);
  box-shadow: 0 0 0 6px rgba(236,72,153,.15);
  animation: promoPulse 1.6s ease-in-out infinite;
}
@keyframes promoPulse{ 0%,100%{transform:scale(1);opacity:1;} 50%{transform:scale(1.2);opacity:.85;} }
.promoBadge__text{
  font-size:.72rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
  color: rgba(255,255,255,.9);
}
.promoTitle{ font-size: 1rem; font-weight: 900; margin: 0 0 .5rem 0; }

.promoTimer{ display:flex; align-items:center; gap:.55rem; }
.promoTimer__seg{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:.55rem .7rem;
  border-radius: 1rem;
  background: rgba(2,6,23,.55);
  border: 1px solid rgba(255,255,255,.10);
  min-width: 4.2rem;
}
.promoTimer__num{ font-size: 1.25rem; font-weight: 900; letter-spacing: .04em; }
.promoTimer__lbl{
  margin-top:.1rem;
  font-size:.65rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;
  color: rgba(148,163,184,1);
}
.promoTimer__sep{ font-weight:900; opacity:.7; }

.promoBtn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.9rem 1.05rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-weight: 900;
  cursor: pointer;
  transition: transform .15s ease, background .15s ease;
  white-space: nowrap;
}
.promoBtn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.12); }
.promoBtn:active{ transform: translateY(0); }

.discountWrap{
  margin-top:.7rem;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:.4rem;
}
.discountLabel{
  font-size:.7rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;
  color: rgba(255,255,255,.85);
}
.discountCode{
  width:100%;
  max-width: 18rem;
  text-align:left;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  padding:.85rem 1rem;
  border-radius: 1rem;
  background: rgba(2,6,23,.6);
  border: 1px solid rgba(255,255,255,.14);
  color:#fff;
  cursor:pointer;
}
.discountCode__hint{ font-size:.72rem; font-weight:800; color: rgba(148,163,184,1); }
.discountCode.copied .discountCode__hint{ color: rgba(34,197,94,1); }

@media (max-width: 720px){
  .promoCard{ flex-direction:column; align-items:stretch; }
  .promoCard__right{ display:flex; flex-direction:column; align-items:stretch; }
  .discountWrap{ align-items:stretch; }
  .discountCode{ max-width:none; }
}


/* Event meta stacked lines (age group + dress code) */
.eventMeta__item--stack{ align-items:flex-start; }
.eventMeta__line{ display:flex; align-items:center; gap:.5rem; }
.eventMeta__line + .eventMeta__line{ margin-top:.35rem; opacity:.88; }


/* Promo card: when reveal button is removed, keep code block aligned nicely */
.promoCard__right{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:center;
}
@media (max-width: 720px){
  .promoCard__right{ align-items:stretch; }
}


/* Event meta emoji lines */
.eventMeta__emoji{
  display:inline-flex;
  width: 1.25rem;
  justify-content:center;
}


/* Extra event info under meta */
.eventExtraInfo {
  margin-top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.eventExtraInfo__line {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.9);
}

.eventExtraInfo__emoji {
  width: 1.2rem;
  text-align: center;
}
