/* TOKENS */
:root{
  --bg:#F8F7F4;
  --white:#FFFFFF;
  --ink:#0E0D0B;
  --text:#1A1916;
  --muted:#6B6760;
  --border:#E4E2DC;
  --surface:#F2F0EB;
  --gold:#9A7A2C;
  --gold2:rgba(154,122,44,.12);
  --gold3:rgba(154,122,44,.06);
  --gold-light:#FBF5E4;
  --gold-mid:#C4963E;
  --dark:#0C0B09;
  --dark2:#141310;
}

/* BASE */
*{margin:0;padding:0;box-sizing:border-box}
html{
  background:var(--bg);
  color:var(--text);
  font-family:'DM Sans',sans-serif;
  -webkit-font-smoothing:antialiased;
  scroll-behavior:smooth;
  overflow-x:clip;
  max-width:100%;
}
body{
  background:var(--bg);
  overflow-x:clip;
  max-width:100%;
}
main [id]{scroll-margin-top:132px}
a{color:inherit}
.sec-pre{font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.sec-h2{font-family:'Playfair Display',serif;font-size:clamp(34px,4vw,54px);font-weight:300;color:var(--ink);line-height:1;letter-spacing:-.02em;margin-bottom:16px}
.sec-h2 em{font-style:italic;color:var(--gold-mid)}
.sec-h2 b{font-weight:700}
.sec-rule{width:40px;height:1px;background:var(--gold);margin-bottom:20px}
.sec-p{font-size:16px;font-weight:300;color:var(--muted);line-height:1.8;max-width:540px}
.btn-primary{background:var(--gold-mid);color:#fff;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:16px 36px;border-radius:2px;text-decoration:none;display:inline-block;transition:.15s}
.btn-primary:hover{opacity:.85}
.btn-secondary{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.2);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:14px 28px;border-radius:2px;text-decoration:none;display:inline-block;backdrop-filter:blur(8px);transition:.15s}
.btn-secondary:hover{background:rgba(255,255,255,.15)}
.btn-secondary.dark{background:var(--ink);color:#fff;border:1px solid var(--ink)}
.btn-secondary.dark:hover{opacity:.86}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:64px;padding:0 52px;display:flex;align-items:center;justify-content:space-between;transition:all .35s}
nav.light{background:rgba(248,247,244,.95);backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}
.nav-brand{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;font-style:italic;color:#fff;letter-spacing:.01em;transition:.35s;text-decoration:none}
nav.light .nav-brand{color:var(--ink)}
.nav-links{display:flex;gap:32px;align-items:center}
.nl{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);text-decoration:none;transition:.2s}
nav.light .nl{color:var(--muted)}
.nl:hover{color:#fff}
nav.light .nl:hover{color:var(--ink)}

/* VENUE TABS (all microsites) */
.venue-tabs{
  position:fixed;
  top:64px;
  left:0;
  right:0;
  z-index:180;
  background:rgba(12,11,9,.72);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.venue-tabs-scroll{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:10px 18px;
  -webkit-overflow-scrolling:touch;
}
.venue-tab{
  font-size:10px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.65);
  text-decoration:none;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  padding:7px 11px;
  border-radius:999px;
  white-space:nowrap;
  transition:.15s;
}
.venue-tab:hover{color:#fff;border-color:rgba(255,255,255,.32)}
.venue-tab.active{background:var(--gold-mid);border-color:var(--gold-mid);color:#fff}

/* HERO */
.hero{position:relative;height:100vh;min-height:720px;overflow:hidden;display:flex;align-items:flex-end;padding-top:38px}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 25%}
.hero-ov{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(12,11,9,.35) 0%,rgba(12,11,9,.05) 35%,rgba(12,11,9,.5) 65%,rgba(12,11,9,.95) 100%)}
.hero-content{position:relative;z-index:2;padding:0 80px 80px;width:100%;display:grid;grid-template-columns:1fr auto;align-items:flex-end;gap:60px}
.hero-kicker{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);padding:7px 16px;border-radius:2px;margin-bottom:28px}
.hk-dot{width:5px;height:5px;border-radius:50%;background:var(--gold-mid);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hk-txt{font-size:10px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.9)}
.hero-h1{font-family:'Playfair Display',serif;font-size:clamp(48px,5.5vw,80px);font-weight:300;color:#fff;line-height:.95;letter-spacing:-.025em;max-width:680px;margin-bottom:24px}
.hero-h1 em{font-style:italic;color:#F0D898;display:block}
.hero-h1 b{font-weight:700;display:block}
.hero-p{font-size:16px;font-weight:300;color:rgba(255,255,255,.6);line-height:1.75;max-width:460px;margin-bottom:36px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* COUNTDOWN */
.countdown-box{background:rgba(12,11,9,.55);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(16px);border-radius:4px;padding:28px 24px;text-align:center;min-width:200px;flex-shrink:0}
.cd-pre{font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.cd-nums{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.cd-unit{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:3px;padding:10px 6px}
.cd-n{font-family:'Playfair Display',serif;font-size:34px;font-weight:700;color:var(--gold-mid);line-height:1;display:block}
.cd-l{font-size:8px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:2px}
.cd-event{font-size:11px;font-weight:500;color:rgba(255,255,255,.7);margin-bottom:3px}
.cd-dates{font-size:10px;color:rgba(255,255,255,.35);letter-spacing:.06em}

/* TICKER */
.ticker{background:var(--dark);overflow:hidden;padding:13px 0;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}
.ticker-track{display:flex;white-space:nowrap;animation:scroll 30s linear infinite}
.tick{font-size:10px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-mid);padding:0 28px}
.tick-sep{color:rgba(255,255,255,.12)}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* SECTIONS */
.section{padding:120px 80px}
.section.white{background:var(--white)}
.section.surface{background:var(--surface)}

/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center}
.info-list{margin-top:32px;display:flex;flex-direction:column}
.il-item{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--border)}
.il-item:last-child{border-bottom:none}
.il-label{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.il-val{font-size:14px;color:var(--ink);text-align:right;max-width:220px}

/* PHOTO GRID 5 */
.grid5{display:grid;grid-template-columns:1.3fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:600px}
.g5i{position:relative;overflow:hidden;border-radius:3px}
.g5i.span2{grid-row:span 2}
.g5i img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.g5i:hover img{transform:scale(1.04)}
.g5-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,11,9,.8) 0%,transparent 55%)}
.g5-lbl{position:absolute;bottom:0;left:0;right:0;padding:18px 20px}
.g5-cat{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-mid);margin-bottom:4px}
.g5-txt{font-size:14px;font-weight:500;color:#fff;line-height:1.3}

/* FULL WIDTH PHOTO */
.fw{position:relative;overflow:hidden}
.fw img{width:100%;height:100%;object-fit:cover;display:block}
.fw-ov{position:absolute;inset:0}
.fw-lbl{position:absolute;z-index:2}
.fw-fans{height:58vh;min-height:420px}
.fw-dj{height:52vh;min-height:380px}
.fw-fans img{object-position:center 40%}
.fw-dj img{object-position:center 30%}
.fw-fans .fw-ov{background:linear-gradient(to right,rgba(12,11,9,.75) 0%,rgba(12,11,9,.2) 55%,transparent 100%)}
.fw-dj .fw-ov{background:linear-gradient(to right,rgba(12,11,9,.7),rgba(12,11,9,.15) 60%,transparent)}
.fw-fans .fw-lbl,.fw-dj .fw-lbl{left:80px;top:50%;transform:translateY(-50%);max-width:500px}
.fw-dj .fw-lbl{max-width:420px}
.fw-eyebrow{font-size:10px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-mid);margin-bottom:14px}
.fw-title{font-family:'Playfair Display',serif;font-size:clamp(32px,4vw,54px);font-weight:300;color:#fff;line-height:1.05;letter-spacing:-.02em}
.fw-title em{font-style:italic;color:#F0D898}
.fw-dj .fw-title{font-size:clamp(28px,3.5vw,46px)}

/* VENUE PHOTOS — 4 grid */
.venue-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:680px;margin-top:56px}
.venue-actions{display:flex;gap:10px;margin:16px 0 0}
.vg-item{position:relative;overflow:hidden;border-radius:3px}
.vg-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.vg-item:hover img{transform:scale(1.03)}
.vg-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,11,9,.65) 0%,transparent 50%)}
.vg-lbl{position:absolute;bottom:0;left:0;right:0;padding:20px 22px}
.vg-cat{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-mid);margin-bottom:4px}
.vg-txt{font-size:15px;font-weight:500;color:#fff}

/* CULTURE STRIP — dark */
.culture-strip{background:var(--dark);padding:100px 80px}
.culture-pre{color:var(--gold-mid)}
.culture-title{color:#fff;max-width:520px}
.culture-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;height:480px;margin-top:48px}
.ci{position:relative;overflow:hidden;border-radius:3px}
.ci img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.ci:hover img{transform:scale(1.05)}
.ci-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,11,9,.85) 0%,transparent 50%)}
.ci-lbl{position:absolute;bottom:0;left:0;right:0;padding:22px}
.ci-cat{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-mid);margin-bottom:5px}
.ci-txt{font-size:15px;font-weight:500;color:#fff;line-height:1.3}

/* STATUS */
.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-top:56px}
.status-list{border:1px solid var(--border);border-radius:4px;overflow:hidden}
.sl-item{display:flex;align-items:center;gap:14px;padding:16px 22px;border-bottom:1px solid var(--border);background:var(--white)}
.sl-item:last-child{border-bottom:none}
.sl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-g{background:#2E8B57}.dot-a{background:var(--gold-mid)}.dot-r{background:#B22222}
.sl-match{flex:1;font-size:13px;font-weight:500;color:var(--ink)}
.sl-date{font-size:11px;color:var(--muted);margin-top:1px}
.sl-status{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.s-open{color:#2E8B57}.s-fast{color:var(--gold-mid)}.s-ltd{color:#B22222}
.access-card{background:var(--ink);border-radius:4px;padding:44px;display:flex;flex-direction:column;gap:20px}
.ac-pre{font-size:10px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-mid)}
.ac-h{font-family:'Playfair Display',serif;font-size:32px;font-weight:300;color:#fff;line-height:1.1}
.ac-h em{font-style:italic;color:#F0D898}
.ac-p{font-size:14px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.75}
.ac-list{display:flex;flex-direction:column;gap:10px}
.ac-item{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(255,255,255,.7)}
.ac-dot{width:4px;height:4px;border-radius:50%;background:var(--gold-mid);flex-shrink:0}
.ac-btn{background:var(--gold-mid);color:#fff;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:16px 32px;border-radius:2px;text-decoration:none;display:inline-block;transition:.15s;text-align:center}
.ac-btn:hover{opacity:.85}
.ac-btn2{background:transparent;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.15);font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:14px 28px;border-radius:2px;text-decoration:none;display:inline-block;transition:.15s;text-align:center}
.ac-btn2:hover{border-color:rgba(255,255,255,.4);color:#fff}

/* INQUIRY + FOOTER */
.inquiry{padding:110px 80px;background:var(--white)}
.inquiry-card{background:linear-gradient(160deg,#12110f 0%,#1d1a14 100%);border-radius:4px;padding:52px 56px;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:end}
.inquiry-copy .sec-pre{color:var(--gold-mid)}
.inquiry-copy .sec-h2{color:#fff;margin-bottom:14px}
.inquiry-copy .sec-p{color:rgba(255,255,255,.68);max-width:640px}
.inquiry-actions{display:flex;gap:12px;flex-wrap:wrap}
.inquiry-actions .btn-secondary{color:rgba(255,255,255,.88)}
footer{background:var(--dark2);border-top:1px solid rgba(255,255,255,.06);padding:34px 80px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;font-size:11px;color:rgba(255,255,255,.3);letter-spacing:.06em;text-align:center}
.footer-disclaimer{max-width:860px;color:rgba(255,255,255,.42);line-height:1.6}

/* HARBOR GALLERY */
.hg-modal{position:fixed;inset:0;background:rgba(12,11,9,.68);backdrop-filter:blur(6px);z-index:240;display:none;padding:42px 20px;overflow:auto}
.hg-modal.open{display:block}
.hg-panel{max-width:1120px;margin:0 auto;background:#fff;border-radius:8px;border:1px solid var(--border);box-shadow:0 24px 72px rgba(0,0,0,.28);padding:18px}
.hg-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.hg-title{font-family:'Playfair Display',serif;font-size:30px;line-height:1;color:var(--ink)}
.hg-state{font-size:12px;color:var(--muted);margin-top:6px}
.hg-close{width:36px;height:36px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-size:20px;color:var(--ink);cursor:pointer}
.hg-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.hg-card{border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#fff}
.hg-card img{width:100%;height:220px;object-fit:cover;display:block}
.hg-meta{font-size:11px;color:var(--muted);padding:8px 10px;line-height:1.5}
.hg-meta a{color:inherit}
body.hg-open{overflow:hidden}

@media(max-width:960px){
  nav{padding:0 24px}
  .venue-tabs{top:64px}
  .venue-tabs-scroll{padding:9px 12px}
  .hero-content{grid-template-columns:1fr;padding:0 28px 60px}
  .countdown-box{display:none}
  .section,.culture-strip,.inquiry{padding:80px 28px}
  .two-col,.status-grid,.inquiry-card{grid-template-columns:1fr}
  .grid5{grid-template-columns:1fr 1fr;height:auto}
  .g5i.span2{grid-row:span 1}
  .g5i img{height:220px}
  .culture-grid,.venue-grid{grid-template-columns:1fr;height:auto}
  .venue-actions{flex-direction:column}
  .ci img,.vg-item img{height:240px}
  .fw-fans,.fw-dj{height:auto;min-height:0}
  .fw-fans img,.fw-dj img{height:400px}
  .fw-fans .fw-lbl,.fw-dj .fw-lbl{left:24px;right:24px;top:auto;bottom:24px;transform:none;max-width:none}
  .inquiry-card{padding:38px 30px}
  .hg-grid{grid-template-columns:1fr}
  .hg-card img{height:210px}
  footer{padding:28px 24px}
}

@media(max-width:768px){
  .hero{min-height:min(100svh, 720px)}
  .hero-h1{font-size:clamp(40px,13vw,56px)}
  .hero-p{font-size:15px}
  .ticker{padding:10px 0}
}

@media(max-width:640px){
  nav{padding:0 14px;gap:10px;min-height:56px;height:auto;flex-wrap:nowrap}
  .nav-brand{font-size:15px;flex-shrink:0;max-width:42vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .nav-links{flex:1;min-width:0;display:flex;gap:14px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding:4px 0;justify-content:flex-end}
  .nl{flex-shrink:0;font-size:10px;letter-spacing:.08em}
  .venue-tabs-scroll{padding:8px 12px}
  .hero-content{padding:0 20px 48px}
}
@media(max-width:480px){
  html{-webkit-text-size-adjust:100%}
  nav{padding:0 12px}
  .hero-content{padding:0 16px 40px}
  .section,.culture-strip,.inquiry{padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right));}
}

@media (prefers-reduced-motion: reduce){
  .ticker-track{animation:none}
}
