:root {
  --black: #050505;
  --cream: #fff4d7;
  --olive: #7fa538;
  --gold: #ffc857;
  --magenta: #ee3f8c;
  --aqua: #23c7b7;
  --line: rgba(255, 244, 215, .16);
  font-family: Arial, Helvetica, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--cream);
  background:
    radial-gradient(circle at 74% 24%, rgba(238, 63, 140, .2), transparent 24%),
    radial-gradient(circle at 18% 12%, rgba(127, 165, 56, .18), transparent 22%),
    #050505;
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .1;
  background: repeating-linear-gradient(0deg, #fff 0 1px, transparent 1px 5px);
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 10;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 22px;
  padding: 12px clamp(18px, 4vw, 52px);
  background: rgba(5, 5, 5, .72);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.brand {
  width: auto;
  display: grid;
  gap: 2px;
  padding: 8px 0;
  color: var(--cream);
  text-transform: uppercase;
  line-height: .9;
}

.brand span,
.footer-brand span {
  font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  font-size: clamp(1.4rem, 2.3vw, 2rem);
  letter-spacing: 0;
  text-shadow: 3px 3px 0 rgba(238, 63, 140, .55), 6px 6px 0 rgba(35, 199, 183, .28);
}

.brand small,
.footer-brand small {
  width: max-content;
  padding: 3px 8px;
  color: #071006;
  background: var(--olive);
  border-radius: 999px;
  font-size: .7rem;
  font-weight: 950;
  letter-spacing: 0;
}
nav {
  justify-self: center;
  display: flex;
  gap: 6px;
  padding: 7px;
  background: rgba(255, 244, 215, .06);
  border: 1px solid var(--line);
}
nav a, .reserve-link, .button, .tab {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border: 1px solid transparent;
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
}
nav a:hover { color: var(--gold); }
.reserve-link, .button.primary {
  background: var(--olive);
  color: #071006;
}
.button.secondary {
  background: rgba(255, 244, 215, .08);
  border-color: var(--line);
}
section { padding: clamp(58px, 7vw, 92px) clamp(18px, 5vw, 72px); }
.hero {
  position: relative;
  min-height: 88vh;
  display: grid;
  align-items: end;
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(127, 165, 56, .18), transparent 34%),
    linear-gradient(120deg, transparent 0 48%, rgba(238, 63, 140, .18) 48.5% 72%, transparent 72.5%);
}
.hero-copy { position: relative; z-index: 2; max-width: 660px; }
.eyebrow {
  margin: 0 0 12px;
  color: var(--gold);
  font-size: .78rem;
  font-weight: 950;
  text-transform: uppercase;
}
h1, h2, h3, p { margin-top: 0; }
h1, h2 {
  font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  line-height: .9;
  letter-spacing: 0;
  text-transform: uppercase;
}
h1 {
  margin-bottom: 20px;
  max-width: 720px;
  font-size: clamp(3.4rem, 8.8vw, 7.6rem);
  line-height: .88;
  text-shadow: 0 0 28px rgba(238, 63, 140, .24), 0 10px 0 rgba(0, 0, 0, .44);
}
h2 { max-width: 980px; font-size: clamp(2rem, 4.8vw, 3.9rem); }
p { color: rgba(255, 244, 215, .78); line-height: 1.62; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.hero-art {
  position: absolute;
  right: clamp(38px, 8vw, 118px);
  top: 29%;
  width: min(30vw, 390px);
  aspect-ratio: 1;
  opacity: .82;
}
.slice {
  position: absolute;
  inset: 0 16% 24% 6%;
  clip-path: polygon(7% 0, 100% 0, 52% 100%);
  background:
    radial-gradient(circle at 45% 35%, #ef4a38 0 7%, transparent 7.5%),
    radial-gradient(circle at 62% 50%, #ef4a38 0 7%, transparent 7.5%),
    radial-gradient(circle at 67% 25%, #111 0 4%, var(--olive) 4.5% 7%, transparent 7.5%),
    linear-gradient(#c97826 0 18%, #ffe26f 18%);
  border: 1px solid rgba(255, 244, 215, .24);
  border-radius: 16px;
  animation: float 5s ease-in-out infinite;
}
.record {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 46%;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, var(--gold) 0 10%, #050505 10.5% 100%),
    repeating-radial-gradient(circle, #171717 0 5px, #050505 6px 10px);
  box-shadow: 0 0 70px rgba(35, 199, 183, .2);
  animation: spin 8s linear infinite;
}
.bars {
  position: absolute;
  right: -4%;
  bottom: -2%;
  display: flex;
  align-items: end;
  gap: 8px;
  height: 90px;
}
.bars span {
  width: 10px;
  border-radius: 99px;
  background: linear-gradient(var(--gold), var(--magenta));
  animation: bars .8s ease-in-out infinite alternate;
}
.bars span:nth-child(1) { height: 42%; }
.bars span:nth-child(2) { height: 74%; animation-delay: .15s; }
.bars span:nth-child(3) { height: 92%; animation-delay: .3s; }
.bars span:nth-child(4) { height: 58%; animation-delay: .45s; }
.intro, .visit-section {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(320px, 1fr);
  gap: clamp(26px, 4vw, 56px);
  align-items: center;
  background: rgba(255, 244, 215, .035);
  border-block: 1px solid var(--line);
}
.feature-grid, .menu-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
article, .card {
  padding: 24px;
  background: rgba(255, 244, 215, .07);
  border: 1px solid var(--line);
  border-radius: 8px;
}
article span { color: var(--magenta); font-weight: 950; }

article h3,
.card h3 {
  margin-bottom: 10px;
}

.feature-grid article {
  min-height: 190px;
}

.menu-section > h2,
.events-section > h2 {
  margin-bottom: 22px;
}

.menu-tabs { display: flex; flex-wrap: wrap; gap: 10px; margin: 24px 0; }
.tab { cursor: pointer; color: var(--cream); background: rgba(255,244,215,.08); border-color: var(--line); }
.tab.active, .tab:hover { background: rgba(238, 63, 140, .72); }
.menu-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.menu-item { min-height: 184px; display: flex; flex-direction: column; justify-content: space-between; }
.topline { display: flex; justify-content: space-between; gap: 18px; }
.price { color: #050505; background: var(--gold); border-radius: 999px; padding: 4px 8px; font-weight: 950; }
.hours-section .wide { width: 100%; max-width: 1180px; margin-inline: auto; }
.hours-section h2 { max-width: 920px; }
.hours-row { display: flex; justify-content: space-between; gap: 18px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.events-section { background: #070707; }
.address-heading { font-size: clamp(1.6rem, 3vw, 2.65rem); line-height: 1.05; }
.address-heading span { display: block; }
footer {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 38px 18px;
  border-top: 1px solid var(--line);
}

.footer-brand {
  display: grid;
  justify-items: center;
  gap: 4px;
  color: var(--cream);
  text-align: center;
  text-transform: uppercase;
  line-height: .9;
}

.footer-brand span {
  font-size: clamp(2rem, 6vw, 4rem);
}

.footer-brand small {
  justify-self: center;
  font-size: .85rem;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes float { 50% { transform: translateY(-16px) rotate(5deg); } }
@keyframes bars { from { transform: scaleY(.45); } to { transform: scaleY(1); } }
@media (max-width: 900px) {
  .site-header { grid-template-columns: auto 1fr; }
  nav { display: none; }
  .reserve-link { justify-self: end; }
  .intro, .visit-section, .feature-grid, .menu-grid { grid-template-columns: 1fr; }
  .hero {
    min-height: 86vh;
    padding-top: 120px;
  }
  .hero-art { right: -116px; top: 22%; width: 360px; opacity: .28; }
  h1 { font-size: clamp(3rem, 14vw, 5.2rem); }
  h2 { font-size: clamp(2rem, 10vw, 3.1rem); }
  .actions, .button { width: 100%; }
}
