/* ════════════════════════════════════════════
   DJ MO BLVD — cinematic 3D scroll site
   ════════════════════════════════════════════ */
:root{
  --bg:#ffffff;
  --bg-2:#f4f5f2;
  --ink:#10241a;
  --ink-dim:#51635a;
  --accent:#006747;
  --accent-2:#0b7a4e;
  --line:rgba(16,36,26,.14);
  --on-accent:#ffffff;
  --section-y:clamp(5.1rem,11.5vh,8.5rem); /* vertical rhythm between sections (editable in admin) */
  --section-x:clamp(1.2rem,5vw,4.5rem);     /* horizontal page gutter */
  --font-d:'Fraunces',serif;
  --font-b:'Inter',sans-serif;
  --font-i:'Fraunces',serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-b);
  font-weight:400;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}

html.sans-display .hero-title,html.sans-display .section-title,html.sans-display .hero-end-text,
html.sans-display .cinema-caption p,html.sans-display .loader-logo,html.sans-display .nav-brand,
html.sans-display .footer-brand,html.sans-display .service-body h3,html.sans-display .pkg h3,
html.sans-display .pkg-price,html.sans-display .step h3,html.sans-display .venues-title,
html.sans-display .inquire-title,html.sans-display .djep-title,html.sans-display .cal-head h3,
html.sans-display .portal-card h2,html.sans-display .pkg-hero h1,html.sans-display .portal-hero h1,
html.sans-display .mobile-menu a,html.sans-display .stat strong,html.sans-display .menu-price{
  font-weight:800;font-variation-settings:normal;letter-spacing:-.02em;
}

/* display serif tuning */
.hero-title,.section-title,.hero-end-text,.cinema-caption p,.loader-logo,.nav-brand,.footer-brand,
.service-body h3,.pkg h3,.pkg-price,.step h3,.vibe-name,.venues-title,.inquire-title,.djep-title,
.cal-head h3,.portal-card h2,.pkg-hero h1,.portal-hero h1,.mobile-menu a,.stat strong,.menu-price{
  font-weight:600;font-variation-settings:"opsz" 144;
}

/* ── loader ── */
.loader{
  position:fixed;inset:0;z-index:300;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s;
}
.loader.done{opacity:0;visibility:hidden}
.loader-inner{text-align:center}
.loader-logo{
  font-family:var(--font-d);font-size:clamp(2.4rem,6vw,4rem);letter-spacing:.04em;
  margin-bottom:1.6rem;
}
.loader-logo span{color:var(--accent);margin-left:.35em}
.loader-bar{width:min(320px,60vw);height:1px;background:var(--line);margin:0 auto}
.loader-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.loader-pct{margin-top:.8rem;font-size:.78rem;letter-spacing:.3em;color:var(--ink-dim)}

/* ── nav ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(1.35rem + var(--nav-down,0px)) clamp(1.2rem,4vw,3rem) 1.35rem;
  transition:background .4s,backdrop-filter .4s,transform .45s ease;
}
.nav.solid{background:color-mix(in srgb, var(--bg) 78%, transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav.hide{transform:translateY(-110%)}
.nav-brand{font-family:var(--font-d);font-size:1.15rem;letter-spacing:.06em}
.nav-brand em,.footer-brand em{font-style:normal;color:var(--accent)}
.nav-links{display:flex;gap:2rem}
.nav-links a{
  position:relative;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);
  transition:color .3s;padding-bottom:.2em;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--accent-2);transform:scaleX(0);transform-origin:right;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:hover{color:var(--accent-2)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid var(--accent);color:var(--ink);
  padding:.6em 1.5em;border-radius:4px;
  transition:background .3s,color .3s,box-shadow .3s;
}
.nav-cta:hover{background:var(--accent);box-shadow:none}

/* ── cinema (scroll-scrub) sections ── */
.cinema{position:relative}
.cinema-hero{height:var(--hd-h-index,240vh)}
.cinema-mid{height:300vh}
.cinema-sticky{
  position:sticky;top:0;height:100vh;overflow:hidden;
  perspective:1000px;background:#0a0f0c; /* footage backing — stays dark in every theme */
}
.cinema-canvas{position:absolute;inset:0;width:100%;height:100%}
.cinema-vignette{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at center,transparent 45%,rgba(4,5,9,.55) 100%),
    linear-gradient(180deg,rgba(4,5,9,.5) 0%,transparent 18%,transparent 78%,rgba(4,5,9,.7) 100%);
}

/* hero content */
.hero-content{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:flex-start;justify-content:flex-end;text-align:left;
  max-width:var(--hd-w-index,100%);
  padding:0 clamp(1.2rem,5vw,4.5rem) calc(clamp(5rem,13vh,9rem) + var(--hd-shift-index,0px));
  transform-style:preserve-3d;will-change:transform,opacity;
}
.hero-eyebrow{
  font-size:clamp(.62rem,1.1vw,.8rem);letter-spacing:.42em;text-transform:uppercase;
  color:var(--accent-2);margin-bottom:1.4rem;text-shadow:0 2px 18px rgba(0,0,0,.8);
}
.hero-title{
  font-family:var(--font-d);
  font-size:clamp(3.4rem,13vw,11.5rem);
  line-height:.95;letter-spacing:-.01em;
  text-shadow:0 8px 60px rgba(0,0,0,.55);
}
.hero-line{display:block;overflow:hidden}
.hero-line span{display:inline-block;transform:translateY(110%)}
.hero-line-2 span{
  font-style:italic;font-weight:400;color:var(--accent-2);
  letter-spacing:.02em;
}
.hero-tag{
  margin-top:1.4rem;max-width:34ch;font-family:var(--font-i);font-style:italic;
  font-size:clamp(1rem,2.2vw,1.5rem);color:var(--ink);
  opacity:0;text-shadow:0 2px 24px rgba(0,0,0,.9);
}
.hero-end{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
}
.hero-end-text{
  font-family:var(--font-d);font-size:clamp(2rem,6vw,5rem);text-align:center;
  text-shadow:0 6px 50px rgba(0,0,0,.7);line-height:1.05;
}
.hero-end-text em{
  font-style:italic;font-weight:400;display:block;color:var(--accent-2);
}
.scroll-cue{
  position:absolute;bottom:2.6rem;right:clamp(1.2rem,5vw,4.5rem);
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  font-size:.68rem;letter-spacing:.4em;text-transform:uppercase;color:var(--ink-dim);
}
.scroll-cue-line{width:1px;height:54px;background:linear-gradient(180deg,var(--accent-2),transparent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* cinema captions */
.cinema-caption{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  opacity:0;will-change:transform,opacity;
}
.cinema-caption p{
  font-family:var(--font-d);font-size:clamp(2.4rem,8vw,7rem);
  text-shadow:0 8px 60px rgba(0,0,0,.75);text-align:center;padding:0 1rem;
}
.cinema-quote{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  padding:0 clamp(1.5rem,8vw,10rem);text-align:center;
}
.cinema-quote p{
  font-family:var(--font-i);font-style:italic;
  font-size:clamp(1.5rem,4.2vw,3.4rem);line-height:1.35;
  text-shadow:0 4px 40px rgba(0,0,0,.85);
}
.qw{opacity:.12;display:inline-block;transition:none}

/* ── marquee ── */
.marquee{
  overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.1rem 0;background:var(--bg-2);
}
.marquee-track{display:flex;white-space:nowrap;width:max-content;animation:marquee 36s linear infinite}
.marquee-track span{
  font-family:var(--font-d);font-size:clamp(1.1rem,2.4vw,1.8rem);
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);
}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ── sections common ── */
section{position:relative}
.about,.services,.gallery,.packages,.reviews{padding:var(--section-y) var(--section-x)}
.section-head{
  display:block;border-top:1px solid var(--line);
  padding-top:1.1rem;margin-bottom:calc(var(--section-y)*0.5);
}
.section-no{
  display:block;font-size:.72rem;letter-spacing:.3em;color:var(--accent);
  margin-bottom:1.2rem;font-family:var(--font-b);
}
.section-no::before{content:"( "}
.section-no::after{content:" )"}
.section-title{
  font-family:var(--font-d);
  font-size:clamp(2.2rem,6vw,4.8rem);line-height:1.04;text-transform:uppercase;letter-spacing:-.01em;
}
.st-line{display:inline-block}
.st-em{
  font-style:italic;font-weight:400;text-transform:lowercase;
  color:var(--accent-2);letter-spacing:.01em;
}

/* ── about ── */
.about{background:var(--bg)}
.about-grid{
  display:grid;grid-template-columns:minmax(280px,460px) 1fr;
  gap:clamp(2rem,6vw,5rem);align-items:start;
}
.about-media{position:relative;transform-style:preserve-3d}
.about-img-wrap{overflow:hidden;border-radius:6px;aspect-ratio:4/5}
.about-img-wrap img{width:100%;height:115%;object-fit:cover;will-change:transform}
.about-img-badge{
  position:absolute;bottom:-1rem;right:-1rem;background:var(--accent);color:#fff;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.8em 1.4em;border-radius:3px;transform:translateZ(40px);
  box-shadow:0 14px 40px color-mix(in srgb, var(--accent) 35%, transparent);
}
.about-copy p{margin-bottom:1.3rem;color:var(--ink-dim);max-width:58ch}
.about-lede{
  font-size:clamp(1.25rem,2.4vw,1.7rem);color:var(--ink)!important;
  font-weight:400;line-height:1.4;
}
.about-stats{display:flex;gap:clamp(1.5rem,4vw,3.5rem);margin-top:2.4rem;flex-wrap:wrap}
.stat strong{
  display:block;font-family:var(--font-d);font-weight:400;
  font-size:2rem;color:var(--accent-2);
}
.stat span{font-size:.78rem;letter-spacing:.06em;color:var(--ink-dim);max-width:15ch;display:block}
.about-quote{margin-top:clamp(4rem,9vh,6.5rem);text-align:center}
.about-quote blockquote{
  font-family:var(--font-i);font-style:italic;
  font-size:clamp(1.4rem,3.4vw,2.6rem);line-height:1.4;
  max-width:24ch;margin:0 auto;
}
.about-quote em{color:var(--accent-2)}
.about-quote figcaption{margin-top:1.4rem;font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim)}

/* ── services ── */
.services{background:var(--bg-2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,2rem)}
.service-card{
  background:var(--bg);border:1px solid var(--line);border-radius:4px;overflow:hidden;
  transform-style:preserve-3d;will-change:transform;
  transition:border-color .4s,box-shadow .4s;
}
.service-card:hover{border-color:color-mix(in srgb, var(--accent) 50%, transparent);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.service-img{aspect-ratio:4/3;overflow:hidden}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.service-card:hover .service-img img{transform:scale(1.07)}
.service-body{padding:1.8rem 1.6rem 2rem;transform:translateZ(30px)}
.service-no{font-size:.7rem;letter-spacing:.3em;color:var(--accent)}
.service-body h3{
  font-family:var(--font-d);font-weight:400;font-size:1.9rem;
  text-transform:uppercase;margin:.5rem 0 .8rem;
}
.service-body p{color:var(--ink-dim);font-size:.92rem;margin-bottom:1.2rem}
.service-body ul{list-style:none}
.service-body li{
  font-size:.82rem;color:var(--ink-dim);padding:.45em 0;border-top:1px solid var(--line);
}
.service-body li::before{content:"✦";color:var(--accent-2);margin-right:.7em;font-size:.7em}

/* ── gallery ── */
.gallery{background:var(--bg);overflow:hidden}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.8rem,2vw,1.6rem);align-items:start}
.g-col{display:flex;flex-direction:column;gap:clamp(.8rem,2vw,1.6rem);will-change:transform}
.g-col:nth-child(2){margin-top:clamp(2rem,6vh,5rem)}
.g-item{overflow:hidden;border-radius:6px;opacity:0;transform:translateY(60px) rotateX(8deg);perspective:600px}
.g-item img{width:100%;height:auto;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.g-item:hover img{transform:scale(1.05)}
.gallery-cta{margin-top:3rem;text-align:center;font-size:.85rem;letter-spacing:.12em;color:var(--ink-dim)}
.gallery-cta a{color:var(--accent-2);border-bottom:1px solid currentColor}

/* ── packages ── */
.packages{background:var(--bg-2)}
.packages-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.6rem)}
.pkg{
  position:relative;background:var(--bg);border:1px solid var(--line);border-radius:4px;
  padding:2rem 1.6rem;display:flex;flex-direction:column;
  transform-style:preserve-3d;transition:border-color .4s,box-shadow .4s;
}
.pkg:hover{border-color:color-mix(in srgb, var(--accent-2) 40%, transparent);box-shadow:0 24px 70px rgba(0,0,0,.45)}
.pkg-featured{border-color:var(--accent);background:linear-gradient(170deg,color-mix(in srgb, var(--accent) 12%, transparent),rgba(6,7,11,.4) 55%)}
.pkg-flag{
  position:absolute;top:-0.75em;left:1.4rem;background:var(--accent);color:#fff;
  font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;
  padding:.5em 1.2em;border-radius:99px;
}
.pkg h3{font-family:var(--font-d);font-weight:400;font-size:1.6rem;text-transform:uppercase}
.pkg-price{margin:.6rem 0 1.4rem;font-family:var(--font-d);font-size:2rem;color:var(--accent-2)}
.pkg-price span{font-family:var(--font-b);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim);display:block}
.pkg ul{list-style:none;flex:1}
.pkg li{font-size:.82rem;color:var(--ink-dim);padding:.5em 0;border-top:1px solid var(--line)}
.pkg-btn{
  margin-top:1.6rem;text-align:center;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  border:1px solid var(--accent);border-radius:4px;padding:.85em 0;
  transition:background .3s,box-shadow .3s;
}
.pkg-btn:hover{background:var(--accent);box-shadow:none}

/* ── venues ── */
.venues{
  padding:var(--section-y) 0;text-align:center;
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;
}
.venues-kicker{font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;color:var(--accent-2);margin-bottom:.8rem}
.venues-title{
  font-family:var(--font-d);font-weight:400;text-transform:uppercase;
  font-size:clamp(1.6rem,4vw,2.8rem);margin-bottom:clamp(2rem,5vh,3.2rem);
}
.venue-rows{display:flex;flex-direction:column;gap:1.6rem}
.venue-row{overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
}
.venue-track{display:flex;gap:clamp(2.4rem,6vw,5rem);width:max-content;align-items:center}
.venue-row-a .venue-track{animation:marquee 42s linear infinite}
.venue-row-b .venue-track{animation:marquee 42s linear infinite reverse}
.venue-track span{
  font-family:var(--font-i);font-style:italic;white-space:nowrap;
  font-size:clamp(1.3rem,3vw,2.1rem);color:var(--ink-dim);
  transition:color .3s;
}
.venue-track span:hover{color:var(--accent-2)}
.venues-note{margin-top:clamp(2rem,5vh,3rem);font-size:.85rem;color:var(--ink-dim);letter-spacing:.04em;padding:0 1.5rem;max-width:60ch;margin-left:auto;margin-right:auto}

/* ── reel ── */
.reel{padding:var(--section-y) var(--section-x);background:var(--bg)}
.reel-frame{
  position:relative;border-radius:4px;overflow:hidden;border:1px solid var(--line);
  aspect-ratio:16/9;max-width:1080px;margin:0 auto;
  box-shadow:0 40px 120px rgba(0,0,0,.6);
  transform-style:preserve-3d;
}
.reel-frame video{width:100%;height:100%;object-fit:cover;display:block}
.reel-play{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;
  background:linear-gradient(180deg,rgba(4,5,9,.25),rgba(4,5,9,.55));
  border:0;cursor:pointer;color:var(--ink);font-family:var(--font-b);
  transition:opacity .5s,visibility .5s;
}
.reel-play.hidden{opacity:0;visibility:hidden}
.reel-play-ring{
  position:absolute;width:108px;height:108px;border-radius:50%;
  border:1px solid color-mix(in srgb, var(--accent-2) 60%, transparent);
  animation:ringpulse 2.2s ease-out infinite;
}
@keyframes ringpulse{0%{transform:scale(.85);opacity:1}100%{transform:scale(1.5);opacity:0}}
.reel-play-icon{
  width:92px;height:92px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb, var(--accent) 18%, transparent);border:1px solid var(--accent);backdrop-filter:blur(8px);
  font-size:1.6rem;padding-left:6px;color:var(--accent-2);
  transition:background .3s,transform .3s;
}
.reel-play:hover .reel-play-icon{background:var(--accent);color:#fff;transform:scale(1.06)}
.reel-play-label{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink);text-shadow:0 2px 12px rgba(0,0,0,.8)}
.reel-more{margin-top:1.8rem;text-align:center;font-size:.85rem;color:var(--ink-dim)}
.reel-more a{color:var(--accent-2)}

/* ── process: hairline timeline, no boxes ── */
.process{padding:var(--section-y) var(--section-x);background:var(--bg-2)}
.process-grid{
  list-style:none;display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;position:relative;max-width:1240px;margin:0 auto;
}
.process-grid::before{
  content:"";position:absolute;top:9px;left:calc(12.5% );right:calc(12.5%);
  height:1px;background:linear-gradient(90deg,transparent,var(--line) 12%,var(--line) 88%,transparent);
}
.step{position:relative;padding:0 clamp(.8rem,2vw,1.8rem);text-align:center;background:none;border:0}
.step::before{
  content:"";position:absolute;top:4px;left:50%;transform:translateX(-50%);
  width:11px;height:11px;border-radius:50%;
  border:1px solid var(--accent);background:var(--bg-2);
  box-shadow:0 0 0 5px var(--bg-2),0 0 18px color-mix(in srgb, var(--accent) 55%, transparent);
}
.step-no{
  display:block;margin:2.2rem 0 .2rem;
  font-family:var(--font-i);font-style:italic;font-size:1rem;color:var(--accent-2);
  background:none;-webkit-text-fill-color:currentColor;
}
.step h3{
  font-family:var(--font-d);font-weight:400;font-size:clamp(1.05rem,1.6vw,1.3rem);
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem;
}
.step p{font-size:.85rem;color:var(--ink-dim);max-width:26ch;margin:0 auto}
@media (max-width:900px){
  .process-grid{grid-template-columns:1fr;gap:0;max-width:480px}
  .process-grid::before{top:0;bottom:0;left:5px;right:auto;width:1px;height:auto;
    background:linear-gradient(180deg,transparent,var(--line) 8%,var(--line) 92%,transparent)}
  .step{text-align:left;padding:0 0 2.6rem 2.2rem}
  .step:last-child{padding-bottom:0}
  .step::before{left:0;top:6px;transform:none;box-shadow:0 0 0 5px var(--bg-2),0 0 18px color-mix(in srgb, var(--accent) 55%, transparent)}
  .step-no{margin:0 0 .2rem}
  .step p{margin:0;max-width:42ch}
}

/* ── faq ── */
.faq{padding:var(--section-y) var(--section-x);background:var(--bg-2)}
.faq-list{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;
  padding:1.5rem .2rem;font-size:clamp(1rem,2vw,1.25rem);font-weight:400;color:var(--ink);
  transition:color .3s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--accent-2)}
.faq-x{
  font-family:var(--font-b);font-weight:300;font-size:1.5rem;color:var(--accent);
  transition:transform .35s ease;flex-shrink:0;
}
.faq-item[open] .faq-x{transform:rotate(45deg)}
.faq-item p{padding:0 .2rem 1.6rem;color:var(--ink-dim);max-width:62ch}

/* ── reviews ── */
.reviews-trust{margin:-1.5rem 0 2.4rem;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2)}
.reviews-trust a{color:var(--ink-dim);border-bottom:1px solid var(--line);transition:color .3s}
.reviews-trust a:hover{color:var(--accent-2)}
.review-stars{color:var(--accent-2);letter-spacing:.2em;font-size:.8rem;margin-bottom:.9rem}

/* ── vibes ── */
.vibes{padding:var(--section-y) var(--section-x);background:var(--bg-2)}
.vibes-sub{margin:-1.6rem 0 2.4rem;color:var(--ink-dim);font-size:.92rem}
.vibes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.6rem)}
.vibe{
  position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;
  background:var(--bg);border:1px solid var(--line);border-radius:4px;
  padding:1.8rem 1.6rem;cursor:pointer;color:var(--ink);font-family:var(--font-b);text-align:left;
  transition:border-color .35s,box-shadow .35s,transform .35s;
}
.vibe:hover{border-color:color-mix(in srgb, var(--accent) 50%, transparent);transform:translateY(-3px)}
.vibe.playing{border-color:var(--accent-2);box-shadow:0 0 40px color-mix(in srgb, var(--accent-2) 18%, transparent)}
.vibe-eq{display:flex;align-items:flex-end;gap:3px;height:26px;margin-bottom:.4rem}
.vibe-eq i{width:4px;height:30%;background:var(--accent);border-radius:4px;transition:height .3s}
.vibe.playing .vibe-eq i{background:var(--accent-2);animation:eq .7s ease-in-out infinite alternate}
.vibe.playing .vibe-eq i:nth-child(1){animation-delay:0s}
.vibe.playing .vibe-eq i:nth-child(2){animation-delay:.12s}
.vibe.playing .vibe-eq i:nth-child(3){animation-delay:.24s}
.vibe.playing .vibe-eq i:nth-child(4){animation-delay:.06s}
.vibe.playing .vibe-eq i:nth-child(5){animation-delay:.18s}
@keyframes eq{from{height:18%}to{height:100%}}
.vibe-name{font-family:var(--font-d);font-size:1.35rem;text-transform:uppercase;letter-spacing:.03em}
.vibe-desc{font-size:.82rem;color:var(--ink-dim)}
.vibe-time{
  position:absolute;top:1.4rem;right:1.4rem;font-size:.72rem;letter-spacing:.18em;color:var(--ink-dim);
}
.vibe-progress{
  position:absolute;left:0;bottom:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:0 2px 2px 0;
}

.reels-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(1rem,2vw,1.6rem);justify-items:center;align-items:start;
}
.reels-grid .instagram-media{border-radius:4px;overflow:hidden}
@media (max-width:900px){.reels-grid{grid-template-columns:1fr}}

/* ── availability ── */
.avail{padding:var(--section-y) var(--section-x);background:var(--bg)}
.avail-wrap{display:grid;grid-template-columns:minmax(300px,460px) 1fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.avail-cal{background:var(--bg-2);border:1px solid var(--line);border-radius:4px;padding:1.6rem}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.cal-head h3{font-family:var(--font-d);font-weight:400;font-size:1.15rem;text-transform:uppercase;letter-spacing:.06em}
.cal-nav{
  background:none;border:1px solid var(--line);border-radius:50%;width:36px;height:36px;
  color:var(--ink);cursor:pointer;font-size:.9rem;transition:border-color .3s,background .3s;
}
.cal-nav:hover{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent)}
.cal-nav:disabled{opacity:.3;cursor:default}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-dow span{text-align:center;font-size:.66rem;letter-spacing:.15em;color:var(--ink-dim);padding:.4em 0}
.cal-day{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:.8rem;border-radius:6px;border:1px solid transparent;color:var(--ink);
  background:color-mix(in srgb, var(--ink) 5%, transparent);cursor:pointer;transition:border-color .25s,background .25s;
}
.cal-day:hover{border-color:var(--accent-2)}
.cal-day.empty{background:none;cursor:default}
.cal-day.empty:hover{border-color:transparent}
.cal-day.past{opacity:.25;cursor:default;background:none}
.cal-day.past:hover{border-color:transparent}
.cal-day.booked{
  background:color-mix(in srgb, var(--accent) 16%, transparent);color:var(--ink-dim);cursor:default;
  text-decoration:line-through;text-decoration-color:color-mix(in srgb, var(--accent-2) 60%, transparent);
}
.cal-day.booked:hover{border-color:transparent}
.cal-day.selected{border-color:var(--accent-2);background:color-mix(in srgb, var(--accent-2) 15%, transparent)}
.cal-legend{display:flex;gap:1.4rem;margin-top:1.1rem;font-size:.72rem;color:var(--ink-dim);letter-spacing:.08em}
.cal-legend .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:.45em}
.dot-open{background:color-mix(in srgb, var(--ink) 35%, transparent)}
.dot-booked{background:var(--accent)}
.avail-lede{font-size:clamp(1.25rem,2.4vw,1.7rem);margin-bottom:1rem}
.avail-copy p{color:var(--ink-dim);max-width:48ch;margin-bottom:1.2rem}
.avail-copy .avail-lede{color:var(--ink)}
.avail-note{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;margin-top:1.6rem;opacity:.65}

/* ── instagram ── */
.insta{padding:var(--section-y) var(--section-x);background:var(--bg)}
.insta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.6rem,1.5vw,1.2rem)}
.insta-item{position:relative;display:block;overflow:hidden;border-radius:6px;aspect-ratio:1}
.insta-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.insta-item:hover img{transform:scale(1.06)}
.insta-ov{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,color-mix(in srgb, var(--accent) 25%, transparent),rgba(4,5,9,.65));
  color:#fff;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;
  opacity:0;transition:opacity .4s;
}
.insta-item:hover .insta-ov{opacity:1}
.insta-cta{margin-top:2.4rem;text-align:center}


/* ── nav right / mode toggle ── */
.nav-right{display:flex;align-items:center;gap:.8rem}
.mode-toggle{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:none;color:var(--ink);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .3s,color .3s,transform .4s;
}
.mode-toggle:hover{border-color:var(--accent);color:var(--accent-2);transform:rotate(40deg)}

/* ── reel cards (drop the needle) ── */
.reel-card{
  position:relative;margin:0;border-radius:4px;overflow:hidden;cursor:pointer;
  aspect-ratio:9/16;max-width:340px;width:100%;justify-self:center;
  border:1px solid var(--line);background:#000;
  transition:border-color .35s,box-shadow .35s,transform .35s;
}
.reel-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb, var(--accent) 55%, transparent);box-shadow:0 24px 70px rgba(0,0,0,.5)}
.reel-card.sound-on{border-color:var(--accent);box-shadow:0 18px 50px rgba(0,0,0,.45)}
.reel-card video{width:100%;height:100%;object-fit:cover;display:block}
.reel-card-ui{
  position:absolute;left:0;right:0;bottom:0;padding:2.2rem 1rem .9rem;
  display:flex;justify-content:space-between;align-items:flex-end;gap:.6rem;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.72));
  pointer-events:none;
}
.reel-card-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.8)}
.reel-card-sound{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.75);white-space:nowrap}
.reel-card.sound-on .reel-card-sound{color:var(--accent-2)}
.reel-card.sound-on .reel-card-sound::after{content:" · on"}
.reel-card-ig{
  position:absolute;top:.7rem;right:.7rem;width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.45);color:#fff;font-size:.95rem;backdrop-filter:blur(6px);
  transition:background .3s;
}
.reel-card-ig:hover{background:var(--accent)}


/* ── mobile burger + menu ── */
.nav-burger{
  display:none;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:none;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px;
}
.nav-burger span{display:block;width:16px;height:1.5px;background:var(--ink);transition:transform .3s,opacity .3s}
.nav-burger.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:color-mix(in srgb, var(--bg) 96%, transparent);
  backdrop-filter:blur(16px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;
  opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{
  font-family:var(--font-d);font-size:clamp(1.6rem,7vw,2.4rem);text-transform:uppercase;
  color:var(--ink);padding:.25em .6em;letter-spacing:.04em;transition:color .25s;
}
.mobile-menu a:hover{color:var(--accent-2)}
@media (max-width:900px){
  .nav-burger{display:flex}
}

/* ── DJ Event Planner embedded form ── */
.djep{
  max-width:760px;margin:3.5rem auto 0;text-align:left;
  background:var(--bg);border:1px solid var(--line);border-radius:4px;
  padding:clamp(1.4rem,4vw,2.5rem);
}
.djep-title{font-family:var(--font-d);font-weight:400;font-size:1.5rem;text-transform:uppercase;margin-bottom:.3rem}
.djep-sub{font-size:.85rem;color:var(--ink-dim);margin-bottom:1.5rem}
.djep form{margin:0}
.djep table{width:100%;border-collapse:collapse}
.djep td{padding:.3em 0;font-size:.9rem}
.djep p,.djep div,.djep span,.djep label,.djep td,.djep b,.djep strong{color:var(--ink);font-family:var(--font-b)}
.djep input[type=text],.djep input[type=tel],.djep input[type=email],.djep textarea,.djep select{
  width:100%;background:color-mix(in srgb, var(--ink) 4%, transparent);
  border:1px solid var(--line);border-radius:4px;color:var(--ink);
  padding:.75em .9em;font-family:var(--font-b);font-size:16px; /* 16px stops iOS zoom */
  margin:.25em 0 .9em;appearance:none;-webkit-appearance:none;
}
.djep select{
  background-image:linear-gradient(45deg,transparent 50%,var(--ink-dim) 50%),linear-gradient(135deg,var(--ink-dim) 50%,transparent 50%);
  background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px;background-repeat:no-repeat;
}
.djep select.monthselect,.djep select.dayselect,.djep select.yearselect{
  width:auto;min-width:96px;display:inline-block;margin-right:.5em;
}
.djep input:focus,.djep select:focus,.djep textarea:focus{outline:none;border-color:var(--accent)}
.djep input[type=submit],.djep .formbutton{
  display:block;width:100%;margin-top:1rem;cursor:pointer;
  font-family:var(--font-b);font-size:.9rem;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid var(--accent);background:var(--accent);color:var(--on-accent,#fff);font-weight:600;
  border-radius:4px;padding:1em 0;transition:box-shadow .3s;
}
.djep input[type=submit]:hover{box-shadow:none}
.djep img{display:none} /* DJEP spacer gifs */
.djep td[bgcolor],.djep table[bgcolor],.djep [bgcolor]{background:transparent!important}
.djep td[bgcolor]{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-dim);font-size:.8rem;padding-bottom:1em}
@media (max-width:640px){
  .djep td{display:block;width:100%}
  .djep table,.djep tbody,.djep tr{display:block;width:100%}
}

/* ── footer socials ── */
.footer-socials{display:flex;justify-content:center;gap:1.6rem;margin-bottom:1.2rem;flex-wrap:wrap}
.footer-socials a{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);
  transition:color .3s;
}
.footer-socials a:hover{color:var(--accent-2)}

/* ── reviews ── */
.reviews{background:var(--bg);overflow:hidden}
.reviews-track-wrap{
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.reviews-track{display:flex;gap:1.4rem;width:max-content;animation:marquee 48s linear infinite}
.reviews-track:hover{animation-play-state:paused}
.review{
  width:min(380px,78vw);flex-shrink:0;
  background:var(--bg-2);border:1px solid var(--line);border-radius:4px;padding:1.8rem;
}
.review p{font-family:var(--font-i);font-style:italic;font-size:1.05rem;line-height:1.55;margin-bottom:1.2rem}
.review span{font-size:.75rem;letter-spacing:.25em;text-transform:uppercase;color:var(--accent-2)}

/* ── inquire ── */
.inquire{
  padding:calc(var(--section-y)*1.3) 1.5rem;text-align:center;
  background:
    radial-gradient(60% 70% at 50% 110%,color-mix(in srgb, var(--accent) 22%, transparent),transparent 70%),
    var(--bg-2);
}
.inquire-kicker{font-size:.75rem;letter-spacing:.42em;text-transform:uppercase;color:var(--accent-2);margin-bottom:1.2rem}
.inquire-title{
  font-family:var(--font-d);font-weight:400;text-transform:uppercase;
  font-size:clamp(2.6rem,8.5vw,7rem);line-height:1.02;margin-bottom:2.6rem;
}
.inquire-title .st-line{display:block}
.inquire-btn{
  display:inline-block;font-size:.95rem;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid var(--accent);border-radius:4px;padding:1.1em 2.6em;
  transition:background .35s,box-shadow .35s,transform .2s;
}
.inquire-btn:hover{background:var(--accent);box-shadow:none}
.inquire-socials{margin-top:3.2rem;display:flex;justify-content:center;gap:clamp(1.2rem,4vw,2.6rem);flex-wrap:wrap}
.inquire-socials a{
  font-size:.78rem;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-dim);
  transition:color .3s;
}
.inquire-socials a:hover{color:var(--accent-2)}

/* ── footer ── */
.footer{
  padding:4rem 1.5rem 2.4rem;text-align:center;border-top:1px solid var(--line);background:var(--bg);
  overflow:hidden;
}
.footer-brand{
  font-family:var(--font-d);font-weight:600;font-variation-settings:"opsz" 144;
  font-size:clamp(3rem,13.5vw,12rem);line-height:.95;letter-spacing:-.01em;
  margin-bottom:2rem;white-space:nowrap;
}
.footer-brand em{font-style:italic;font-weight:400}
.footer p{font-size:.8rem;color:var(--ink-dim);letter-spacing:.06em}
.footer-fine{margin-top:.5rem;opacity:.6}

/* ── responsive ── */
@media (max-width:980px){
  .services-grid{grid-template-columns:1fr 1fr}
  .packages-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr}
  .about-media{max-width:420px}
  .avail-wrap{grid-template-columns:1fr}
}
@media (max-width:900px){
  .nav-links{display:none}
}
@media (max-width:480px){
  .nav-cta{display:none}
}
@media (max-width:640px){
  .cinema-hero{height:180vh}
  .services-grid{grid-template-columns:1fr}
  .packages-grid{grid-template-columns:1fr}
  .vibes-grid{grid-template-columns:1fr}
  .insta-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .g-col:nth-child(3){display:none}
  .cinema-mid{height:240vh}
}
@media (prefers-reduced-motion:reduce){
  .marquee-track,.reviews-track,.scroll-cue-line{animation:none}
}

/* ── à la carte: menu card elegance ── */
.menu-list li{padding:1.05em .2rem;align-items:center}
.menu-name{display:flex;align-items:baseline;gap:.7em;flex-wrap:wrap}
.menu-name em{font-family:var(--font-i);font-style:italic;font-size:1.12em;color:var(--ink);font-weight:400}
.menu-tag{
  font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent-2);border:1px solid color-mix(in srgb, var(--accent) 45%, transparent);
  border-radius:99px;padding:.25em .8em;white-space:nowrap;
}

/* hide scroll cue on short viewports (collides with tagline) */
@media (max-height:620px){.scroll-cue{display:none}}

/* cinema sections sit on dark footage — keep their text light in every theme */
.cinema-sticky{
  --ink:#f6f8f6;
  --ink-dim:rgba(246,248,246,.78);
  --accent-2:#9fe3bd;
  color:var(--ink);
}
/* transparent nav floats over the hero video — light links until it goes solid */
.nav:not(.solid){
  --ink:#f6f8f6;
  --ink-dim:rgba(246,248,246,.85);
  --accent:#9fe3bd;
  --accent-2:#c9f3dc;
  --line:rgba(255,255,255,.3);
  color:var(--ink);
}

/* ── footer logo ── */
.footer-logo{width:min(220px,55vw);height:auto;margin:0 auto 1.6rem;display:block}

/* clickable service cards */
a.service-card{display:block;color:inherit;text-decoration:none;cursor:pointer}
.service-arrow{display:inline-block;color:var(--accent);transition:transform .3s;margin-left:.15em}
.service-card:hover .service-arrow{transform:translateX(5px)}
