/* ===========================================================
   KLAM — black & neon / rave brutalist
   =========================================================== */
:root{
  --black:#000000;
  --ink:#0a0a0a;
  --panel:#0e0d10;
  --white:#f2efe6;
  --dim:#8c8a85;
  /* neon: vermilion primario, magenta secondario */
  --neon:#ff2a14;
  --neon-2:#ff1e6f;
  --glow:rgba(255,42,20,.55);

  --maxw:1280px;
  --pad:clamp(18px,4vw,64px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--white);
  font-family:"Space Grotesk",system-ui,sans-serif;
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.mono{font-family:"Space Mono",ui-monospace,monospace;letter-spacing:.04em}

/* ---------- ambient / grain ---------- */
.ambient{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60vw 60vw at 78% -10%, rgba(255,42,20,.20), transparent 60%),
    radial-gradient(50vw 50vw at 5% 110%, rgba(255,30,111,.16), transparent 60%);
}
.grain{
  position:fixed;inset:-200%;z-index:1;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 1.2s steps(4) infinite;
}
@keyframes grain{to{transform:translate(8%,6%)}}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:14px var(--pad);
  background:linear-gradient(180deg,rgba(0,0,0,.85),transparent);
  backdrop-filter:blur(2px);
}
.nav__logo{font-family:"Anton",sans-serif;font-size:24px;letter-spacing:.06em}
.nav__links{display:flex;gap:clamp(12px,2vw,30px);font-size:13px;text-transform:uppercase;letter-spacing:.12em}
.nav__links a{color:var(--dim);transition:color .2s}
.nav__links a:hover{color:var(--neon)}
.nav__ig{font-family:"Space Mono",monospace;font-size:12px;color:var(--dim)}
.nav__ig:hover{color:var(--neon-2)}
@media(max-width:760px){.nav__links{display:none}}

/* ---------- hero ---------- */
.hero{
  position:relative;z-index:2;min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:90px var(--pad) 40px;
}
.hero__tag{font-size:clamp(10px,1.4vw,13px);color:var(--neon);letter-spacing:.28em;margin-bottom:clamp(10px,3vh,28px)}
.hero__title{font-family:"Anton",sans-serif;line-height:.82;letter-spacing:.02em;
  font-size:clamp(98px,30vw,360px);text-transform:uppercase}
.flicker{
  color:var(--white);
  text-shadow:0 0 8px var(--glow),0 0 28px var(--glow),0 0 64px rgba(255,42,20,.35);
  animation:flicker 6s infinite;
}
@keyframes flicker{
  0%,18%,22%,25%,53%,57%,100%{opacity:1;text-shadow:0 0 8px var(--glow),0 0 28px var(--glow),0 0 64px rgba(255,42,20,.35)}
  20%,24%,55%{opacity:.72;text-shadow:none}
}

.hero__next{margin-top:clamp(20px,5vh,46px);max-width:720px}
.eyebrow{font-size:12px;letter-spacing:.3em;color:var(--neon-2)}
.hero__date{font-family:"Anton",sans-serif;font-size:clamp(34px,6vw,68px);letter-spacing:.05em;margin:6px 0 2px}
.hero__place{font-family:"Space Grotesk",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:clamp(15px,2.2vw,22px);color:var(--dim)}
.hero__meta{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:14px;font-size:12px;color:var(--white)}
.hero__meta i{color:var(--neon);font-style:normal}

.countdown{display:flex;gap:clamp(14px,4vw,40px);justify-content:center;margin-top:clamp(20px,4vh,38px)}
.countdown div{display:flex;flex-direction:column;align-items:center}
.countdown b{font-family:"Anton",sans-serif;font-size:clamp(30px,5vw,56px);line-height:1;color:var(--neon)}
.countdown small{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-top:6px}

.scroll-cue{position:absolute;bottom:22px;font-size:11px;letter-spacing:.3em;color:var(--dim);animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(6px)}}

/* ---------- marquee ---------- */
.marquee{position:relative;z-index:2;border-top:1px solid #1c1c1c;border-bottom:1px solid #1c1c1c;
  background:var(--neon);color:#000;overflow:hidden;padding:10px 0}
.marquee__track{display:inline-flex;gap:26px;align-items:center;white-space:nowrap;
  font-family:"Anton",sans-serif;font-size:20px;letter-spacing:.08em;text-transform:uppercase;
  animation:scroll 26s linear infinite;will-change:transform}
.marquee .dot{font-size:10px;transform:translateY(-3px)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
.section{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(64px,12vh,140px) var(--pad)}
.section--alt{background:linear-gradient(180deg,#060606,#000);max-width:none}
.section--alt > *{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.section__head{margin-bottom:clamp(28px,5vh,56px)}
.section__title{font-family:"Anton",sans-serif;font-size:clamp(46px,11vw,140px);line-height:.9;letter-spacing:.01em;text-transform:uppercase}
.section__sub{color:var(--dim);font-size:13px;letter-spacing:.16em;margin-top:8px;text-transform:uppercase}
.note{color:#5e5c57;font-size:12px;margin-top:24px}
.note code{color:var(--neon-2)}

/* ---------- events ---------- */
.events{display:grid;gap:1px;background:#161616;border:1px solid #161616}
.event{
  display:grid;grid-template-columns:170px 1fr auto;gap:24px;align-items:center;
  background:var(--black);padding:22px clamp(16px,3vw,34px);transition:background .2s}
.event:hover{background:#0c0a0b}
.event__date{font-family:"Anton",sans-serif;font-size:clamp(22px,3vw,34px);letter-spacing:.03em;color:var(--neon)}
.event__date small{display:block;font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.18em;color:var(--dim);margin-top:4px}
.event__place{font-family:"Space Grotesk",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:clamp(16px,2.4vw,24px)}
.event__line{color:var(--dim);font-size:13px;margin-top:6px}
.event__line b{color:var(--white);font-weight:500}
.event__badge{font-family:"Space Mono",monospace;font-size:11px;border:1px solid #2a2a2a;border-radius:0;
  padding:6px 10px;color:var(--dim);white-space:nowrap}
.event--upcoming .event__badge{color:#000;background:var(--neon-2);border-color:var(--neon-2)}
@media(max-width:680px){
  .event{grid-template-columns:1fr;gap:8px}
  .event__badge{justify-self:start}
}

/* ---------- residents ---------- */
.residents{list-style:none;display:flex;flex-wrap:wrap;gap:0;border-top:1px solid #161616}
.residents li{
  flex:1 1 220px;border-bottom:1px solid #161616;border-right:1px solid #161616;
  padding:clamp(20px,4vw,40px);font-family:"Anton",sans-serif;
  font-size:clamp(26px,4vw,52px);text-transform:uppercase;letter-spacing:.02em;
  color:var(--white);position:relative;transition:color .2s,background .2s;cursor:default}
.residents li:hover{color:var(--neon);background:#0c0a0b}
.residents li small{display:block;font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.2em;color:var(--dim);margin-top:8px;font-weight:400}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.gallery .ph{
  aspect-ratio:3/4;background:linear-gradient(150deg,#15100f,#0a0a0a);
  border:1px solid #1a1a1a;display:flex;align-items:center;justify-content:center;
  font-family:"Space Mono",monospace;font-size:11px;color:#4a4a4a;position:relative;overflow:hidden}
.gallery .ph::after{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 60% at 50% 120%,var(--glow),transparent 70%);opacity:.5}
.gallery .ph:nth-child(3n)::after{background:radial-gradient(80% 60% at 50% 120%,rgba(255,30,111,.5),transparent 70%)}
.gallery .ph img{width:100%;height:100%;object-fit:cover}
@media(max-width:880px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* ---------- booking ---------- */
.booking{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,60px);align-items:center}
.booking__title{font-family:"Anton",sans-serif;font-size:clamp(56px,11vw,150px);line-height:.86;text-transform:uppercase;
  text-shadow:0 0 30px rgba(255,30,111,.25)}
.booking__body p{color:var(--dim);max-width:42ch;margin-bottom:26px;font-size:clamp(15px,1.6vw,18px)}
.cta{display:inline-block;font-family:"Space Mono",monospace;font-weight:700;letter-spacing:.08em;
  background:var(--neon);color:#000;padding:16px 26px;margin:0 12px 12px 0;transition:transform .15s,background .2s}
.cta:hover{transform:translate(-2px,-2px);background:var(--neon-2)}
.cta--ghost{background:transparent;color:var(--white);border:1px solid #2a2a2a}
.cta--ghost:hover{background:#0c0a0b;border-color:var(--neon-2)}
@media(max-width:760px){.booking{grid-template-columns:1fr}}

/* ---------- footer ---------- */
.footer{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;
  padding:30px var(--pad);border-top:1px solid #1a1a1a;font-size:12px;color:var(--dim)}
.footer__logo{font-family:"Anton",sans-serif;font-size:28px;color:var(--white);letter-spacing:.06em}
.footer__links{display:flex;gap:20px;flex-wrap:wrap}
.footer a:hover{color:var(--neon-2)}

/* ---------- a11y / motion ---------- */
:focus-visible{outline:2px solid var(--neon-2);outline-offset:3px}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
}
