/* ──────────────────────────────────────────────────────────
   VICE DOWNTOWN BRYAN · style.css
   Shared stylesheet for index, /events/, /faq/, and future
   article pages. Edit once, deploys everywhere.
   ────────────────────────────────────────────────────────── */

/* ── DESIGN TOKENS ────────────────────────────────────────── */
:root {
  /* Brand neon palette */
  --cyan:    #00e5ff;          /* primary, signage glow */
  --magenta: #FF2D9B;          /* hookah / hot accent */
  --orange:  #FF8C00;          /* owner / menu accent */
  --purple:  #7B2FBE;          /* dance floor / private events */
  --green:   #00ff88;          /* live status / SMS */

  /* Surfaces */
  --bg:        #000;
  --bg-elev:   #0c0c0c;        /* modals, elevated cards */

  /* Text */
  --text:        rgba(255,255,255,.9);
  --text-muted:  rgba(255,255,255,.62);
  --text-dim:    rgba(255,255,255,.5);
  --text-faint:  rgba(255,255,255,.25);
  --text-ghost:  rgba(255,255,255,.11);

  /* Type */
  --font-display: 'Bebas Neue', sans-serif;
  --font-body:    'Rajdhani', sans-serif;

  /* Common neon shadow recipes */
  --glow-cyan:    0 0 8px var(--cyan), 0 0 20px var(--cyan), 0 0 40px rgba(0,229,255,.27);
  --glow-magenta: 0 0 8px var(--magenta), 0 0 20px var(--magenta);
  --glow-orange:  0 0 6px rgba(255,140,0,.5), 0 0 18px rgba(255,140,0,.2);
}

/* ── GLOBAL RESET & TYPE ──────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--bg);
  font-family: var(--font-body);
  color: #fff;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}
::selection { background: #00e5ff33; color: var(--cyan); }

/* ── ANIMATIONS ───────────────────────────────────────────── */
@keyframes flicker {
  0%,19%,21%,23%,25%,54%,56%,100% { opacity:1; }
  20%,24%,55% { opacity:0.4; }
}
@keyframes pulseCyan {
  0%,100% { text-shadow: 0 0 8px #00e5ff,0 0 20px #00e5ff,0 0 40px #00e5ff44; }
  50%      { text-shadow: 0 0 4px #00e5ff,0 0 10px #00e5ff; }
}
@keyframes float {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}
@keyframes borderGlow {
  0%,100% { box-shadow: 0 0 8px #00e5ff, 0 0 20px #00e5ff44, inset 0 0 8px #00e5ff22; }
  50%      { box-shadow: 0 0 16px #00e5ff, 0 0 40px #00e5ff66, inset 0 0 16px #00e5ff33; }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes slideUp {
  from { opacity:0; transform:translateY(40px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes dotPulse {
  0%,100% { box-shadow: 0 0 6px #00ff88, 0 0 14px #00ff88; }
  50%      { box-shadow: 0 0 10px #00ff88, 0 0 24px #00ff88; }
}
@keyframes stickyIn {
  from { transform: translateY(100%); opacity:0; }
  to   { transform: translateY(0); opacity:1; }
}
@keyframes revealUp {
  from { opacity:0; transform:translateY(32px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── UTILITIES ────────────────────────────────────────────── */
.flicker    { animation: flicker 8s infinite; }
.float      { animation: float 6s ease-in-out infinite; }
.pulse-cyan { animation: pulseCyan 4s ease-in-out infinite; }
.neon-border-cyan { border:1px solid #00e5ff66; animation: borderGlow 3s ease-in-out infinite; }

/* Scroll-triggered reveal */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }

/* Grid background overlay */
.grid-bg {
  background-image:
    linear-gradient(rgba(0,229,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,229,255,.05) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* Scroll offset for fixed nav */
section[id] { scroll-margin-top: 64px; }

/* ── NAV ──────────────────────────────────────────────────── */
#nav {
  position: fixed; top:0; left:0; right:0; z-index:200;
  padding: 15px 20px;
  display: flex; align-items: center; justify-content: space-between;
  transition: background .4s, border .4s;
}
#nav.scrolled {
  background: rgba(0,0,0,.96);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(0,229,255,.1);
}
#nav.menu-open {
  background: rgba(0,0,0,.96);
  backdrop-filter: blur(20px);
}
.nav-logo {
  font-family: var(--font-display);
  font-size: 25px; letter-spacing: 6px;
  color: var(--cyan);
  text-shadow: var(--glow-cyan);
  text-decoration: none;
}

/* Nav location pin */
#nav-pin {
  background: none; border: none; cursor: pointer;
  padding: 6px 8px;
  display: flex; align-items: center; gap: 6px;
  color: rgba(255,255,255,.5);
  font-family: var(--font-body); font-weight: 600;
  font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  transition: color .2s;
}
#nav-pin:hover, #nav-pin:active { color: var(--magenta); }
#nav-pin svg { flex-shrink: 0; }

/* Hamburger */
#hamburger {
  background: none; border: none; cursor: pointer;
  padding: 8px; display: flex; flex-direction: column;
  gap: 5px; align-items: flex-end;
}
.ham-line {
  display: block; height: 1.5px;
  background: var(--cyan);
  box-shadow: 0 0 8px #00e5ff,0 0 20px #00e5ff;
  transition: all .3s ease;
}
.ham-line:nth-child(1) { width:24px; }
.ham-line:nth-child(2) { width:16px; }
.ham-line:nth-child(3) { width:24px; }
#hamburger.open .ham-line:nth-child(1) { transform: rotate(45deg) translate(4.5px,4.5px); }
#hamburger.open .ham-line:nth-child(2) { opacity:0; width:0; }
#hamburger.open .ham-line:nth-child(3) { transform: rotate(-45deg) translate(4.5px,-4.5px); }

/* Desktop nav links */
#nav-links { display:none; gap:32px; align-items:center; }
.nav-link {
  color: rgba(255,255,255,.75);
  text-decoration: none;
  font-family: var(--font-body); font-weight:600;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  transition: color .3s, text-shadow .3s;
}
.nav-link:hover { color:var(--cyan); text-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff; }
.nav-cta {
  font-family:var(--font-body); font-weight:700;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  color:#000; background:var(--cyan); padding:9px 22px;
  text-decoration:none;
  box-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff;
}

/* Mobile fullscreen menu */
#mobile-menu {
  position: fixed; inset:0; z-index:190;
  background: rgba(0,0,0,.97); backdrop-filter: blur(24px);
  display: flex; flex-direction:column;
  align-items:center; justify-content:center; gap:4px;
  transform: translateY(-100%);
  transition: transform .4s cubic-bezier(.77,0,.175,1);
  pointer-events: none;
}
#mobile-menu.open { transform: translateY(0); pointer-events:auto; }
.mob-nav-link {
  color: rgba(255,255,255,.75);
  text-decoration:none;
  font-family:var(--font-body); font-weight:600;
  font-size:30px; letter-spacing:6px; text-transform:uppercase;
  padding:12px 0; text-align:center;
  transition: color .3s, text-shadow .3s;
}
.mob-nav-link:hover { color:var(--cyan); text-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff; }
.mob-cta {
  margin-top:24px;
  font-family:var(--font-body); font-weight:700;
  font-size:14px; letter-spacing:3px; text-transform:uppercase;
  color:#000; background:var(--cyan); padding:14px 44px;
  text-decoration:none;
  box-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff;
}

/* ── HERO (home) ──────────────────────────────────────────── */
#hero {
  position:relative; min-height:100svh;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  overflow:hidden; background:#000;
  padding: 90px 20px 80px;
}
.hero-overlay-1 {
  position:absolute; inset:0;
  background: radial-gradient(ellipse 100% 60% at 50% 40%, rgba(0,229,255,.07), transparent 70%);
}
.hero-fade-bottom {
  position:absolute; bottom:0; left:0; right:0; height:35%;
  background: linear-gradient(to top, #000, transparent);
}
.hero-scanlines {
  position:absolute; inset:0; pointer-events:none;
  background: repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.07) 2px,rgba(0,0,0,.07) 4px);
}
.hero-blob-1 {
  position:absolute; top:15%; left:-5%; width:220px; height:220px;
  background: radial-gradient(circle,rgba(255,45,155,.1),transparent 70%);
  filter:blur(40px);
}
.hero-blob-2 {
  position:absolute; bottom:15%; right:-5%; width:260px; height:260px;
  background: radial-gradient(circle,rgba(123,47,190,.12),transparent 70%);
  filter:blur(50px);
}
.hero-inner {
  position:relative; text-align:center; z-index:2; width:100%;
  animation: float 6s ease-in-out infinite;
}
.hero-sub {
  font-family:var(--font-body); font-weight:600;
  font-size:11px; letter-spacing:6px; text-transform:uppercase;
  color:var(--magenta); text-shadow:0 0 8px #FF2D9B,0 0 20px #FF2D9B;
  margin-bottom:14px;
  animation: fadeUp .6s .2s ease both;
}
.hero-title {
  font-family:var(--font-display);
  font-size:38vw; line-height:.88;
  color:transparent;
  -webkit-text-stroke:1.5px var(--cyan);
  letter-spacing:6px;
  animation: fadeUp .8s .4s ease both, pulseCyan 4s ease-in-out infinite;
}
.hero-tagline {
  font-family:var(--font-body); font-weight:300;
  font-size:12px; letter-spacing:4px; text-transform:uppercase;
  color:rgba(255,255,255,.42);
  margin-top:14px; line-height:1.9;
  animation: fadeUp .8s .7s ease both;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  margin-top:26px; padding:12px 22px;
  border:1px solid rgba(0,229,255,.3);
  background:rgba(0,229,255,.05);
  color:var(--cyan); font-family:var(--font-body);
  font-weight:600; font-size:13px; letter-spacing:3px; text-transform:uppercase;
  animation: fadeUp .8s 1s ease both;
}
.hero-dot {
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
  background:var(--green);
  animation: dotPulse 2s ease-in-out infinite;
}
.hero-reserve-btn {
  display:inline-flex; align-items:center; gap:10px;
  margin-top:18px; padding:14px 34px;
  background:rgba(255,45,155,.1);
  border:1px solid rgba(255,45,155,.5);
  color:var(--magenta); font-family:var(--font-body);
  font-weight:700; font-size:13px; letter-spacing:4px; text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 0 16px rgba(255,45,155,.15);
  transition: background .2s, box-shadow .2s;
  animation: fadeUp .8s 1.2s ease both;
}
.hero-reserve-btn:active { background:rgba(255,45,155,.2); }
.hero-menu-btn {
  display:inline-flex; align-items:center; gap:10px;
  margin-top:14px; padding:14px 34px;
  background:rgba(255,140,0,.1);
  border:1px solid rgba(255,140,0,.5);
  color:var(--orange); font-family:var(--font-body);
  font-weight:700; font-size:13px; letter-spacing:4px; text-transform:uppercase;
  cursor:pointer; text-decoration:none;
  box-shadow:0 0 16px rgba(255,140,0,.15);
  transition: background .2s, box-shadow .2s;
  animation: fadeUp .8s 1.4s ease both;
}
.hero-menu-btn:active { background:rgba(255,140,0,.2); }
.scroll-cue {
  position:absolute; bottom:18px;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:rgba(255,255,255,.45); font-family:var(--font-body);
  font-size:11px; letter-spacing:5px; text-transform:uppercase;
  text-shadow:0 0 8px rgba(255,255,255,.15);
}
.scroll-line {
  width:1px; height:32px;
  background:linear-gradient(to bottom,rgba(0,229,255,.7),transparent);
  box-shadow:0 0 4px rgba(0,229,255,.3);
}

/* ── PAGE HERO (sub-pages: events, faq, articles) ─────────── */
.page-hero {
  position:relative;
  padding: 130px 20px 56px;
  text-align:center;
  border-bottom:1px solid rgba(255,255,255,.04);
  overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(ellipse 80% 50% at 50% 30%, rgba(0,229,255,.06), transparent 70%);
}
.page-hero .grid-bg {
  position:absolute; inset:0; opacity:.4; pointer-events:none;
}
.page-hero-inner { position:relative; z-index:2; max-width:900px; margin:0 auto; }
.page-hero-eyebrow {
  font-family:var(--font-body); font-weight:600;
  font-size:11px; letter-spacing:6px; text-transform:uppercase;
  margin-bottom:14px;
}
.page-hero-title {
  font-family:var(--font-display);
  font-size:clamp(48px,12vw,96px); line-height:.95;
  letter-spacing:6px;
  color:#fff;
  text-shadow: 0 0 24px rgba(255,255,255,.08);
  margin-bottom:18px;
}
.page-hero-sub {
  font-family:var(--font-body); font-weight:400;
  font-size:16px; line-height:1.6;
  color:var(--text-muted); max-width:620px; margin:0 auto;
}

/* ── ABOUT (home) ─────────────────────────────────────────── */
#about { padding:64px 20px; max-width:1200px; margin:0 auto; }
.about-bar { width:32px; height:2px; background:var(--magenta); box-shadow:0 0 8px #FF2D9B,0 0 20px #FF2D9B; margin-bottom:22px; }
.about-title {
  font-family:var(--font-display);
  font-size:clamp(38px,11vw,64px); line-height:1; letter-spacing:3px;
  color:#fff; margin-bottom:18px;
}
.about-title span { color:var(--cyan); text-shadow:0 0 8px rgba(0,229,255,.5), 0 0 22px rgba(0,229,255,.2); }
.about-body {
  font-family:var(--font-body); font-weight:400;
  font-size:17px; line-height:1.7; color:var(--text-muted);
  margin-bottom:16px;
}
.about-body strong { color:var(--orange); font-weight:700; }
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:32px; }
.stat-card {
  padding:18px 16px;
  background:rgba(255,255,255,.02);
  transition:transform .2s ease;
}
.stat-card:active { transform:scale(.97); }
.stat-num {
  font-family:var(--font-display); font-size:30px; line-height:1; margin-bottom:5px;
}
.stat-label {
  font-family:var(--font-body); font-size:11px; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.5); line-height:1.3;
}

/* ── EXPERIENCE (home) ────────────────────────────────────── */
#experience {
  padding:64px 20px;
  background:rgba(255,255,255,.01);
  border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.section-eyebrow {
  font-family:var(--font-body); font-weight:600;
  font-size:11px; letter-spacing:7px; text-transform:uppercase;
  margin-bottom:10px;
}
.section-title {
  font-family:var(--font-display);
  font-size:clamp(44px,13vw,64px); letter-spacing:4px; color:#fff;
  text-shadow: 0 0 20px rgba(255,255,255,.05);
  margin-bottom:36px;
}
.exp-grid { display:grid; grid-template-columns:1fr; gap:14px; }
.exp-card {
  padding:24px 20px;
  background:rgba(0,0,0,.6);
  position:relative; overflow:hidden;
  transition:transform .2s ease;
}
.exp-card:active { transform:scale(.98); }
.exp-card-glow {
  position:absolute; top:-10px; right:-10px;
  width:100px; height:100px;
  filter:blur(14px); pointer-events:none;
}
.exp-icon {
  font-family:var(--font-display); font-size:26px; margin-bottom:8px;
}
.exp-name {
  font-family:var(--font-display); font-size:28px; letter-spacing:3px;
  color:#fff; line-height:1;
  text-shadow: 0 0 14px rgba(255,255,255,.06);
}
.exp-sub {
  font-family:var(--font-body); font-weight:600; font-size:11px;
  letter-spacing:4px; text-transform:uppercase;
  margin-bottom:12px; margin-top:4px;
}
.exp-desc {
  font-family:var(--font-body); font-size:15px;
  line-height:1.6; color:rgba(255,255,255,.52);
}

/* ── HOURS (home) ─────────────────────────────────────────── */
#hours { padding:64px 20px; max-width:900px; margin:0 auto; }
.hours-table { overflow:hidden; }
.hours-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:15px 16px; position:relative;
}
.hours-row + .hours-row { border-top:1px solid rgba(255,255,255,.06); }
.hours-today-bar {
  position:absolute; left:0; top:0; bottom:0;
  width:3px; background:var(--cyan);
  box-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff;
}
.hours-day {
  font-family:var(--font-body); font-weight:700;
  font-size:15px; letter-spacing:2px; text-transform:uppercase;
}
.hours-note {
  font-family:var(--font-body); font-size:11px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--magenta); text-shadow:0 0 8px #FF2D9B,0 0 20px #FF2D9B;
  margin-top:2px;
}
.hours-time {
  font-family:var(--font-body); font-weight:600;
  font-size:14px; letter-spacing:1.5px; flex-shrink:0;
}
.hours-footnote {
  margin-top:16px; padding:13px 16px;
  border:1px solid rgba(255,45,155,.2);
  background:rgba(255,45,155,.04);
  display:flex; gap:10px; align-items:flex-start;
}
.hours-footnote-icon { color:var(--magenta); font-size:14px; flex-shrink:0; margin-top:2px; }
.hours-footnote p {
  font-family:var(--font-body); font-size:13px;
  line-height:1.55; color:rgba(255,255,255,.4); letter-spacing:.5px;
}

/* ── CONTACT (home) ───────────────────────────────────────── */
#contact {
  padding:64px 20px 80px;
  border-top:1px solid rgba(255,255,255,.04);
  position:relative; overflow:hidden;
}
.contact-glow {
  position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:400px; height:200px;
  background:radial-gradient(ellipse,rgba(0,229,255,.05),transparent 70%);
  filter:blur(40px); pointer-events:none;
}
.address-btn {
  display:block; width:100%; text-align:left;
  background:rgba(0,229,255,.04);
  padding:16px 18px;
  border:1px solid rgba(0,229,255,.25);
  margin-bottom:10px; cursor:pointer;
}
.address-inner { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.address-label {
  font-family:var(--font-body); font-weight:600; font-size:10px;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--cyan); text-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff; margin-bottom:6px;
}
.address-text {
  font-family:var(--font-body); font-size:17px;
  font-weight:600; color:rgba(255,255,255,.9); letter-spacing:.5px; line-height:1.4;
}
.address-cta {
  flex-shrink:0; display:flex; align-items:center; gap:6px;
  font-family:var(--font-body); font-weight:700; font-size:11px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--cyan); text-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff;
  border:1px solid rgba(0,229,255,.3);
  padding:8px 14px; white-space:nowrap;
}
.info-grid { display:grid; grid-template-columns:1fr; gap:10px; margin-bottom:20px; }
.info-card { padding:14px 16px; background:rgba(255,255,255,.015); }
.info-label {
  font-family:var(--font-body); font-weight:600; font-size:10px;
  letter-spacing:4px; text-transform:uppercase; margin-bottom:5px;
}
.info-val {
  font-family:var(--font-body); font-size:16px;
  font-weight:500; color:rgba(255,255,255,.75);
}
.info-val a {
  color:rgba(255,255,255,.75); text-decoration:none;
}
.info-val a:hover { color:var(--cyan); }

.contact-actions { display:grid; grid-template-columns:1fr; gap:10px; margin-bottom:20px; }
.contact-action-btn {
  display:flex; align-items:center; gap:14px;
  padding:17px 18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  text-decoration:none; cursor:pointer;
  transition: background .2s;
}
.contact-action-btn:active { background:rgba(255,255,255,.07); }
.contact-action-icon {
  font-size:20px; width:28px; text-align:center; flex-shrink:0;
}
.contact-action-label {
  font-family:var(--font-body); font-weight:700;
  font-size:16px; letter-spacing:3px; text-transform:uppercase;
}
.contact-action-sub {
  font-family:var(--font-body); font-size:12px;
  letter-spacing:1px; color:rgba(255,255,255,.35); margin-top:2px;
}
.contact-action-arrow { margin-left:auto; font-size:16px; opacity:.4; }

.owner-block { padding:22px 18px; border:1px solid rgba(255,255,255,.06); background:rgba(255,255,255,.02); margin-top:20px; }
.owner-label {
  font-family:var(--font-body); font-size:11px; font-weight:600;
  color:rgba(255,255,255,.3); letter-spacing:3px; text-transform:uppercase; margin-bottom:5px;
}
.owner-name {
  font-family:var(--font-display); font-size:30px; letter-spacing:4px;
  color:var(--orange); text-shadow:var(--glow-orange); margin-bottom:5px;
}
.owner-venues {
  font-family:var(--font-body); font-size:12px;
  color:rgba(255,255,255,.25); letter-spacing:1.5px;
  text-transform:uppercase; line-height:1.8;
}

/* ── FOOTER ───────────────────────────────────────────────── */
footer {
  border-top:1px solid rgba(0,229,255,.08);
  padding:20px 20px 40px;
  display:flex; flex-direction:column; gap:8px;
}
.footer-logo {
  font-family:var(--font-display); font-size:20px; letter-spacing:6px;
  color:var(--cyan); text-shadow:0 0 8px #00e5ff,0 0 20px #00e5ff; opacity:.45;
}
.footer-copy, .footer-21 {
  font-family:var(--font-body); font-size:11px; letter-spacing:2px; text-transform:uppercase;
}
.footer-copy { color:rgba(255,255,255,.17); }
.footer-21   { color:rgba(255,255,255,.11); }

/* ── MODAL SHEETS (shared) ────────────────────────────────── */
.modal-overlay {
  display:none;
  position:fixed; inset:0; z-index:500;
  background:rgba(0,0,0,.82); backdrop-filter:blur(14px);
  align-items:flex-end; justify-content:center;
  padding:0 16px 40px;
}
.modal-overlay.open { display:flex; animation:fadeUp .2s ease both; }
.modal-sheet {
  width:100%; max-width:420px;
  background:var(--bg-elev);
  border:1px solid rgba(0,229,255,.2);
  box-shadow:0 0 40px rgba(0,229,255,.1), 0 -4px 60px rgba(0,0,0,.9);
  padding:20px 18px 18px;
  animation:slideUp .3s cubic-bezier(.23,1,.32,1) both;
}
.sheet-handle { width:36px; height:3px; background:rgba(255,255,255,.12); border-radius:2px; margin:0 auto 22px; }
.sheet-eyebrow {
  font-family:var(--font-body); font-weight:600; font-size:11px;
  letter-spacing:5px; text-transform:uppercase;
  color:rgba(255,255,255,.3); text-align:center; margin-bottom:5px;
}
.sheet-title {
  font-family:var(--font-display); font-size:21px; letter-spacing:4px;
  color:#fff; text-align:center; margin-bottom:20px;
}
.sheet-options { display:flex; flex-direction:column; gap:10px; }
.sheet-option {
  display:flex; align-items:center; gap:14px;
  padding:17px 18px; background:rgba(255,255,255,.03);
  text-decoration:none; cursor:pointer; border:none; width:100%; text-align:left;
  transition: background .15s;
}
.sheet-option:active { background:rgba(255,255,255,.08); }
.sheet-option-label {
  font-family:var(--font-body); font-weight:700;
  font-size:17px; letter-spacing:3px; text-transform:uppercase;
}
.sheet-option-sub {
  font-family:var(--font-body); font-size:12px; letter-spacing:1px;
  color:rgba(255,255,255,.35); margin-top:2px;
}
.sheet-option-arrow { margin-left:auto; font-size:18px; }
.sheet-cancel {
  width:100%; margin-top:10px; padding:13px;
  background:none; border:1px solid rgba(255,255,255,.07);
  color:rgba(255,255,255,.28);
  font-family:var(--font-body); font-weight:600;
  font-size:12px; letter-spacing:4px; text-transform:uppercase;
  cursor:pointer;
}

@media (max-width: 380px) {
  #nav-pin span.pin-label { display: none; }
}

/* ── DESKTOP overrides (768px+) ───────────────────────────── */
@media (min-width: 768px) {
  #nav { padding:17px 48px; }
  #nav-pin { display: none; }
  .nav-logo { font-size:27px; }
  #hamburger { display:none; }
  #nav-links { display:flex; }
  #mobile-menu { display:none !important; }
  footer { padding-bottom:26px; }

  #hero { padding:0 48px; }
  .hero-sub { font-size:13px; letter-spacing:8px; margin-bottom:22px; }
  .hero-title { font-size:clamp(100px,18vw,220px); -webkit-text-stroke:2px #00e5ff; letter-spacing:16px; }
  .hero-tagline { font-size:17px; letter-spacing:6px; line-height:1; margin-top:18px; }
  .hero-tagline br { display:none; }
  .hero-badge { margin-top:34px; padding:10px 28px; font-size:14px; letter-spacing:4px; }
  .scroll-cue { bottom:32px; font-size:12px; }
  .scroll-line { height:44px; }

  .page-hero { padding: 160px 48px 80px; }

  #about { padding:120px 48px; }
  .about-bar { width:48px; margin-bottom:32px; }
  .about-title { font-size:clamp(48px,6vw,80px); margin-bottom:28px; }
  .about-body { font-size:18px; }
  .about-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
  .stat-grid { grid-template-columns:1fr; margin-top:0; gap:14px; }
  .stat-card { display:flex; align-items:center; gap:22px; padding:20px 26px; }
  .stat-num { font-size:36px; min-width:76px; margin-bottom:0; }
  .stat-label { font-size:14px; }

  #experience { padding:100px 48px; }
  .section-title { font-size:clamp(44px,6vw,72px); margin-bottom:60px; }
  .exp-grid { grid-template-columns:1fr 1fr; gap:18px; }
  .exp-card { padding:38px 34px; }
  .exp-name { font-size:32px; }
  .exp-desc { font-size:16px; }

  #hours { padding:100px 48px; }
  .section-title-hours { font-size:clamp(44px,6vw,72px); }
  .hours-row { padding:18px 32px; }
  .hours-day { font-size:17px; }
  .hours-time { font-size:16px; }

  #contact { padding:80px 48px 120px; }
  .contact-card-grid { grid-template-columns:1fr 1fr !important; }
  .address-btn { padding:20px 24px; margin-bottom:14px; }
  .address-text { font-size:19px; }
  .info-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .contact-actions { grid-template-columns:repeat(2,1fr); }
  .info-card { padding:18px 22px; }
  .owner-block { padding:22px 32px; }
  .owner-name { font-size:34px; }
  .owner-venues { line-height:1; }

  footer { flex-direction:row; justify-content:space-between; align-items:center; padding:26px 48px; gap:0; }
}

/* ── GOOGLE REVIEW BANNER (home) ──────────────────────────── */
#review-banner {
  padding:32px 20px;
  background: linear-gradient(135deg, rgba(255,45,155,.06), rgba(0,229,255,.06));
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
  text-align:center;
}
.review-inner { max-width:600px; margin:0 auto; }
.review-eyebrow {
  font-family:var(--font-body); font-weight:600;
  font-size:11px; letter-spacing:5px; text-transform:uppercase;
  color:rgba(255,255,255,.3); margin-bottom:8px;
}
.review-headline {
  font-family:var(--font-display); font-size:clamp(26px,7vw,40px);
  letter-spacing:4px; color:#fff;
  text-shadow: 0 0 20px rgba(255,255,255,.1);
  margin-bottom:8px;
}
.review-sub {
  font-family:var(--font-body); font-size:14px; font-weight:500;
  color:rgba(255,255,255,.35); letter-spacing:1px;
  margin-bottom:22px; line-height:1.5;
}
.review-stars {
  font-size:24px; letter-spacing:4px; margin-bottom:18px;
  filter: drop-shadow(0 0 8px rgba(255,200,0,.6));
}
.review-btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.2);
  color:#fff; font-family:var(--font-body);
  font-weight:700; font-size:13px; letter-spacing:4px; text-transform:uppercase;
  text-decoration:none;
  transition: background .2s, border-color .2s;
  box-shadow: 0 0 20px rgba(255,255,255,.05);
}
.review-btn:active { background:rgba(255,255,255,.1); }
.review-btn-icon { font-size:18px; }
@media (min-width:768px) {
  #review-banner { padding:48px 48px; }
}

/* ── FLOOR SPLIT (home Step Inside) ───────────────────────── */
.floor-split { display:grid; grid-template-columns:1fr; gap:14px; margin-bottom:14px; }
.floor-card {
  padding:28px 22px; position:relative; overflow:hidden;
  background:rgba(0,0,0,.6);
  transition:transform .2s ease;
}
.floor-card:active { transform:scale(.98); }
.floor-accent { position:absolute; top:0; left:0; width:3px; height:100%; }
.floor-badge {
  font-family:var(--font-body); font-weight:700;
  font-size:11px; letter-spacing:5px; text-transform:uppercase;
  margin-bottom:8px;
}
.floor-name {
  font-family:var(--font-display); font-size:32px; letter-spacing:3px;
  color:#fff; line-height:1; margin-bottom:10px;
  text-shadow:0 0 14px rgba(255,255,255,.06);
}
.floor-desc {
  font-family:var(--font-body); font-size:15px;
  line-height:1.65; color:rgba(255,255,255,.5);
  margin-bottom:16px;
}
.floor-tags { display:flex; flex-wrap:wrap; gap:8px; }
.floor-tag {
  font-family:var(--font-body); font-weight:700;
  font-size:10px; letter-spacing:3px; text-transform:uppercase;
  padding:5px 12px; border:1px solid currentColor;
}

/* VIP STRIP */
.vip-strip {
  padding:22px 20px;
  border:1px solid rgba(0,229,255,.2);
  background:rgba(0,229,255,.03);
  margin-bottom:14px;
}
.vip-strip-inner {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  flex-wrap:wrap;
}
.vip-strip-label {
  font-family:var(--font-display); font-size:22px; letter-spacing:3px;
  color:var(--cyan); line-height:1; margin-bottom:4px;
}
.vip-strip-desc {
  font-family:var(--font-body); font-size:14px;
  color:rgba(255,255,255,.4); line-height:1.5; max-width:500px;
}
.vip-strip-btn {
  font-family:var(--font-body); font-weight:700;
  font-size:12px; letter-spacing:4px; text-transform:uppercase;
  color:var(--cyan); background:rgba(0,229,255,.08);
  border:1px solid rgba(0,229,255,.35);
  padding:12px 26px; cursor:pointer; white-space:nowrap;
  transition:background .2s;
}
.vip-strip-btn:active { background:rgba(0,229,255,.15); }

/* PRIVATE EVENTS CALLOUT */
.private-callout {
  padding:22px 20px;
  border:1px solid rgba(123,47,190,.2);
  background:rgba(123,47,190,.03);
}
.private-inner { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.private-icon { font-size:24px; flex-shrink:0; }
.private-title {
  font-family:var(--font-display); font-size:20px; letter-spacing:3px;
  color:#fff; line-height:1; margin-bottom:3px;
}
.private-desc {
  font-family:var(--font-body); font-size:13px;
  color:rgba(255,255,255,.38); line-height:1.5;
}
.private-btn {
  font-family:var(--font-body); font-weight:700;
  font-size:12px; letter-spacing:4px; text-transform:uppercase;
  color:var(--purple); background:rgba(123,47,190,.08);
  border:1px solid rgba(123,47,190,.35);
  padding:12px 26px; cursor:pointer; margin-left:auto; white-space:nowrap;
  transition:background .2s;
}
.private-btn:active { background:rgba(123,47,190,.15); }

@media (min-width:768px) {
  .floor-split { grid-template-columns:1fr 1fr; gap:18px; }
  .floor-card { padding:38px 34px; }
  .floor-name { font-size:38px; }
  .floor-desc { font-size:16px; }
  .vip-strip { padding:26px 32px; }
  .vip-strip-label { font-size:26px; }
  .private-callout { padding:22px 32px; }
}

/* ── EVENTS section (home) ────────────────────────────────── */
#private-events, #events {
  padding:64px 20px;
  background:rgba(255,45,155,.02);
  border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.events-grid { display:grid; grid-template-columns:1fr; gap:14px; }
.event-card {
  padding:20px 18px;
  background:rgba(0,0,0,.6);
  border:1px solid rgba(255,255,255,.06);
  position:relative; overflow:hidden;
  transition:transform .2s ease;
}
.event-card:active { transform:scale(.98); }
.event-card.private { border-color:rgba(123,47,190,.3); background:rgba(123,47,190,.04); }
.event-card.dj      { border-color:rgba(0,229,255,.3);  background:rgba(0,229,255,.04); }
.event-card.special { border-color:rgba(255,140,0,.3);  background:rgba(255,140,0,.04); }
.event-card.closed  { border-color:rgba(255,45,155,.25); background:rgba(255,45,155,.03); }
.event-date {
  font-family:var(--font-body); font-weight:700;
  font-size:11px; letter-spacing:4px; text-transform:uppercase;
  margin-bottom:6px;
}
.event-title {
  font-family:var(--font-display); font-size:26px; letter-spacing:3px;
  color:#fff; line-height:1; margin-bottom:4px;
  text-shadow: 0 0 20px rgba(255,255,255,.1);
}
.event-type {
  font-family:var(--font-body); font-weight:600; font-size:11px;
  letter-spacing:4px; text-transform:uppercase; margin-bottom:10px;
}
.event-desc {
  font-family:var(--font-body); font-size:14px;
  line-height:1.6; color:rgba(255,255,255,.45);
}
.event-tag {
  display:inline-block; margin-top:12px;
  font-family:var(--font-body); font-weight:700;
  font-size:10px; letter-spacing:3px; text-transform:uppercase;
  padding:5px 12px; border:1px solid currentColor;
}
.event-cta-btn {
  display:block; width:100%; margin-top:22px;
  padding:14px; text-align:center;
  background:rgba(255,45,155,.1);
  border:1px solid rgba(255,45,155,.4);
  color:var(--magenta); font-family:var(--font-body);
  font-weight:700; font-size:12px; letter-spacing:4px; text-transform:uppercase;
  cursor:pointer;
  transition: background .2s;
}
.event-cta-btn:active { background:rgba(255,45,155,.2); }
@media (min-width: 768px) {
  #private-events, #events { padding:100px 48px; }
  .events-grid { grid-template-columns:1fr 1fr; gap:18px; }
  .event-card { padding:30px 28px; }
  .event-title { font-size:30px; }
}

/* ════════════════════════════════════════════════════════════
   SUB-PAGE COMPONENTS — events, faq, future articles
   ════════════════════════════════════════════════════════════ */

/* ── FEATURED EVENT (Latin Night, etc.) ───────────────────── */
.feature-event {
  max-width: 1100px; margin: 0 auto; padding: 56px 20px;
}
.feature-event-card {
  position: relative; overflow: hidden;
  border: 1px solid rgba(255,140,0,.25);
  background: linear-gradient(135deg, rgba(255,140,0,.05), rgba(255,45,155,.04));
  padding: 32px 24px;
}
.feature-event-card::before {
  content:''; position:absolute; top:-60px; right:-60px;
  width:240px; height:240px;
  background:radial-gradient(circle, rgba(255,140,0,.18), transparent 70%);
  filter:blur(40px); pointer-events:none;
}
.feature-event-eyebrow {
  position: relative;
  font-family:var(--font-body); font-weight:700;
  font-size:11px; letter-spacing:5px; text-transform:uppercase;
  color:var(--orange); text-shadow:var(--glow-orange);
  margin-bottom:10px;
}
.feature-event-title {
  position: relative;
  font-family:var(--font-display);
  font-size:clamp(40px,9vw,72px); line-height:.95;
  letter-spacing:5px; color:#fff;
  text-shadow:0 0 18px rgba(255,140,0,.18), 0 0 4px rgba(255,255,255,.1);
  margin-bottom:6px;
}
.feature-event-when {
  position: relative;
  font-family:var(--font-body); font-weight:600;
  font-size:14px; letter-spacing:3px; text-transform:uppercase;
  color:var(--magenta); text-shadow:0 0 8px #FF2D9B,0 0 20px #FF2D9B;
  margin-bottom:18px;
}
.feature-event-body {
  position: relative;
  font-family:var(--font-body); font-size:16px;
  line-height:1.7; color:var(--text-muted);
  max-width:680px; margin-bottom:18px;
}
.feature-event-perks {
  position: relative;
  display:grid; grid-template-columns:1fr; gap:10px;
  margin-bottom:22px;
}
.feature-event-perk {
  display:flex; gap:14px; align-items:center;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.02);
}
.feature-event-perk-icon {
  font-size:20px; flex-shrink:0; width:28px; text-align:center;
}
.feature-event-perk-text {
  font-family:var(--font-body); font-size:14px;
  letter-spacing:1px; color:rgba(255,255,255,.7); line-height:1.45;
}
.feature-event-cta {
  position: relative;
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 28px;
  background:rgba(255,45,155,.1);
  border:1px solid rgba(255,45,155,.4);
  color:var(--magenta); font-family:var(--font-body);
  font-weight:700; font-size:13px; letter-spacing:4px; text-transform:uppercase;
  text-decoration:none; cursor:pointer;
  transition: background .2s;
}
.feature-event-cta:hover, .feature-event-cta:active { background:rgba(255,45,155,.2); }

@media (min-width:768px) {
  .feature-event { padding: 80px 48px; }
  .feature-event-card { padding: 56px 48px; }
  .feature-event-perks { grid-template-columns: 1fr 1fr; gap:12px; }
}

/* ── ARTICLE INDEX (events page → blog stack) ─────────────── */
.article-index {
  max-width: 1200px; margin: 0 auto; padding: 24px 20px 80px;
}
.article-index-head {
  display:flex; align-items:flex-end; justify-content:space-between;
  flex-wrap:wrap; gap:12px;
  margin-bottom:24px; padding-bottom:18px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.article-index-title {
  font-family:var(--font-display); font-size:clamp(28px,5vw,44px);
  letter-spacing:4px; color:#fff;
}
.article-index-meta {
  font-family:var(--font-body); font-size:11px; font-weight:600;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--text-faint);
}
.article-grid {
  display:grid; grid-template-columns:1fr; gap:14px;
}
.article-card {
  display:flex; flex-direction:column;
  padding:22px 20px;
  background:rgba(0,0,0,.5);
  border:1px solid rgba(255,255,255,.06);
  text-decoration:none;
  transition: border-color .2s, background .2s, transform .2s;
}
.article-card:hover {
  border-color: rgba(0,229,255,.35);
  background: rgba(0,229,255,.03);
  transform: translateY(-2px);
}
.article-card-tag {
  font-family:var(--font-body); font-weight:700;
  font-size:10px; letter-spacing:4px; text-transform:uppercase;
  color: var(--cyan);
  text-shadow: 0 0 6px rgba(0,229,255,.6);
  margin-bottom:10px;
}
.article-card-title {
  font-family:var(--font-display);
  font-size:22px; line-height:1.05; letter-spacing:2px;
  color:#fff;
  margin-bottom:10px;
  text-shadow: 0 0 12px rgba(255,255,255,.06);
}
.article-card-summary {
  font-family:var(--font-body); font-size:14px;
  line-height:1.55; color:var(--text-muted);
  margin-bottom:14px; flex:1;
}
.article-card-foot {
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--font-body); font-weight:600;
  font-size:11px; letter-spacing:2px; text-transform:uppercase;
  color: var(--text-faint);
}
.article-card-foot .article-card-cta { color: var(--magenta); }
.article-card.placeholder { opacity:.55; pointer-events:none; }
.article-card.placeholder .article-card-cta::after { content:' · soon'; color:var(--text-faint); }

@media (min-width:768px) {
  .article-index { padding: 24px 48px 120px; }
  .article-grid { grid-template-columns: repeat(3, 1fr); gap:18px; }
  .article-card { padding:26px 24px; }
  .article-card-title { font-size:24px; }
}

/* ── FAQ ──────────────────────────────────────────────────── */
.faq-section {
  max-width: 880px; margin: 0 auto; padding: 56px 20px 100px;
}
.faq-list {
  display:flex; flex-direction:column; gap:0;
  border-top:1px solid rgba(255,255,255,.06);
}
.faq-item {
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:22px 4px;
}
.faq-question {
  font-family:var(--font-display);
  font-size:clamp(22px,4.5vw,30px); line-height:1.15;
  letter-spacing:2px; color:#fff;
  margin-bottom:12px;
  text-shadow: 0 0 12px rgba(255,255,255,.05);
}
.faq-answer {
  font-family:var(--font-body); font-size:16px;
  line-height:1.7; color:var(--text-muted);
}
.faq-answer p + p { margin-top:12px; }
.faq-answer a { color:var(--cyan); text-decoration:underline; text-decoration-color: rgba(0,229,255,.35); }
.faq-answer a:hover { text-decoration-color: var(--cyan); }

@media (min-width:768px) {
  .faq-section { padding: 80px 48px 140px; }
  .faq-item { padding:28px 4px; }
}

/* ── CROSS-LINK CALLOUT (used on sub-pages) ───────────────── */
.cross-callout {
  max-width: 1100px; margin: 0 auto;
  padding: 32px 22px;
  border:1px solid rgba(0,229,255,.18);
  background:linear-gradient(135deg, rgba(0,229,255,.05), rgba(255,45,155,.04));
  display:flex; flex-direction:column; gap:14px;
  align-items:flex-start;
}
.cross-callout-eyebrow {
  font-family:var(--font-body); font-weight:600;
  font-size:11px; letter-spacing:5px; text-transform:uppercase;
  color: var(--cyan); text-shadow: 0 0 8px #00e5ff,0 0 20px #00e5ff;
}
.cross-callout-title {
  font-family:var(--font-display); font-size:clamp(26px,5vw,38px);
  line-height:1.1; letter-spacing:3px; color:#fff;
}
.cross-callout-body {
  font-family:var(--font-body); font-size:15px;
  line-height:1.6; color:var(--text-muted); max-width:620px;
}
.cross-callout-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 26px;
  background:rgba(0,229,255,.08);
  border:1px solid rgba(0,229,255,.4);
  color:var(--cyan); font-family:var(--font-body);
  font-weight:700; font-size:12px; letter-spacing:3px; text-transform:uppercase;
  text-decoration:none; cursor:pointer;
  transition:background .2s;
}
.cross-callout-btn:hover, .cross-callout-btn:active { background:rgba(0,229,255,.16); }

@media (min-width:768px) {
  .cross-callout {
    flex-direction:row; align-items:center; justify-content:space-between;
    padding: 40px 48px;
  }
  .cross-callout-btn { flex-shrink:0; margin-left:auto; }
}
