/* ==========================================================================
   Midtown Bowl — Atlanta · Est. 1960
   Full brand system stylesheet.
   ========================================================================== */

/* ---------- Big Tickle — 15 cuts ---------- */
@font-face { font-family: 'BigTickle'; src: url('../assets/fonts/VVDS_Big-Tickle-Light.otf') format('opentype'); font-weight: 300; font-style: normal; font-display: swap; }
@font-face { font-family: 'BigTickle'; src: url('../assets/fonts/VVDS_Big-Tickle-Normal.otf') format('opentype'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'BigTickle'; src: url('../assets/fonts/VVDS_Big-Tickle-Medium.otf') format('opentype'); font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: 'BigTickle'; src: url('../assets/fonts/VVDS_Big-Tickle-Black.otf') format('opentype'); font-weight: 900; font-style: normal; font-display: swap; }

@font-face { font-family: 'BigTickleScript'; src: url('../assets/fonts/VVDS_Big-Tickle-Script.otf') format('opentype'); font-weight: 400; font-style: normal; font-display: swap; }

@font-face { font-family: 'BigTickleHatched'; src: url('../assets/fonts/VVDS_Big-Tickle-Hatched-Light.otf') format('opentype'); font-weight: 300; font-display: swap; }
@font-face { font-family: 'BigTickleHatched'; src: url('../assets/fonts/VVDS_Big-Tickle-Hatched-Normal.otf') format('opentype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'BigTickleHatched'; src: url('../assets/fonts/VVDS_Big-Tickle-Hatched-Medium.otf') format('opentype'); font-weight: 500; font-display: swap; }
@font-face { font-family: 'BigTickleHatched'; src: url('../assets/fonts/VVDS_Big-Tickle-Hatched-Black.otf') format('opentype'); font-weight: 900; font-display: swap; }

@font-face { font-family: 'BigTickleShadow'; src: url('../assets/fonts/VVDS_Big-Tickle-Shadow-Light.otf') format('opentype'); font-weight: 300; font-display: swap; }
@font-face { font-family: 'BigTickleShadow'; src: url('../assets/fonts/VVDS_Big-Tickle-Shadow-Normal.otf') format('opentype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'BigTickleShadow'; src: url('../assets/fonts/VVDS_Big-Tickle-Shadow-Medium.otf') format('opentype'); font-weight: 500; font-display: swap; }
@font-face { font-family: 'BigTickleShadow'; src: url('../assets/fonts/VVDS_Big-Tickle-Shadow-Black.otf') format('opentype'); font-weight: 900; font-display: swap; }

@font-face { font-family: 'BigTickleGraphicOne'; src: url('../assets/fonts/VVDS_Big-Tickle-Graphic-One.otf') format('opentype'); font-display: swap; }
@font-face { font-family: 'BigTickleGraphicTwo'; src: url('../assets/fonts/VVDS_Big-Tickle-Graphic-Two.otf') format('opentype'); font-display: swap; }

/* ---------- Futura Cyrillic — 7 cuts ---------- */
@font-face { font-family: 'Futura'; src: url('../assets/fonts/FuturaCyrillicLight.ttf') format('truetype'); font-weight: 300; font-display: swap; }
@font-face { font-family: 'Futura'; src: url('../assets/fonts/FuturaCyrillicBook.ttf') format('truetype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Futura'; src: url('../assets/fonts/FuturaCyrillicMedium.ttf') format('truetype'); font-weight: 500; font-display: swap; }
@font-face { font-family: 'Futura'; src: url('../assets/fonts/FuturaCyrillicDemi.ttf') format('truetype'); font-weight: 600; font-display: swap; }
@font-face { font-family: 'Futura'; src: url('../assets/fonts/FuturaCyrillicBold.ttf') format('truetype'); font-weight: 700; font-display: swap; }
@font-face { font-family: 'Futura'; src: url('../assets/fonts/FuturaCyrillicExtraBold.ttf') format('truetype'); font-weight: 800; font-display: swap; }
@font-face { font-family: 'Futura'; src: url('../assets/fonts/FuturaCyrillicHeavy.ttf') format('truetype'); font-weight: 900; font-display: swap; }

/* ---------- Tokens ---------- */
:root {
  --red:        #E63027;
  --yellow:     #F5C518;
  --navy:       #1E2A6B;
  --light-blue: #A9D6E5;
  --cream:      #FAF6EC;
  --black:      #0E0E0E;
  --ink:        #1a1a1a;

  --container:  min(1280px, 92vw);
  --section-y:  clamp(64px, 8vw, 120px);

  --shadow-sm: 0 2px 4px rgba(14,14,14,.08);
  --shadow-md: 0 6px 20px rgba(14,14,14,.14);
  --shadow-lg: 0 14px 40px rgba(14,14,14,.18);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Futura', system-ui, sans-serif;
  font-weight: 400;
  color: var(--ink);
  background: var(--cream);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ---------- Typography ---------- */
.script    { font-family: 'BigTickleScript', cursive; font-weight: 400; line-height: .95; letter-spacing: -.01em; }
.display   { font-family: 'BigTickle', serif; font-weight: 900; line-height: .95; letter-spacing: .005em; text-transform: uppercase; }
.display-m { font-family: 'BigTickle', serif; font-weight: 500; line-height: 1; text-transform: uppercase; }
.hatched   { font-family: 'BigTickleHatched', serif; font-weight: 500; line-height: 1; text-transform: uppercase; }
.shadow-text { font-family: 'BigTickleShadow', serif; font-weight: 500; line-height: 1; text-transform: uppercase; }
.graphic-one { font-family: 'BigTickleGraphicOne', serif; line-height: 1; text-transform: uppercase; }

h1, h2, h3, h4 { margin: 0 0 .4em; }
h1 { font-size: clamp(2.4rem, 6vw, 4.6rem); }
h2 { font-size: clamp(1.9rem, 4.5vw, 3.4rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.9rem); }
p  { margin: 0 0 1em; }
.eyebrow {
  font-family: 'Futura'; font-weight: 700; font-size: .82rem;
  letter-spacing: .22em; text-transform: uppercase; color: var(--red);
  margin-bottom: .8em; display: inline-block;
}
.eyebrow--on-photo {
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  letter-spacing: .26em;
}
.eyebrow--cream { color: var(--cream); }
.eyebrow--yellow { color: var(--yellow); }
.eyebrow--navy { color: var(--navy); }

/* ---------- Layout ---------- */
.container { width: var(--container); margin: 0 auto; }
.section { padding: var(--section-y) 0; }
.section--cream { background: var(--cream); }
.section--red { background: var(--red); color: var(--cream); }
.section--navy { background: var(--navy); color: var(--cream); }
.section--lightblue { background: var(--light-blue); color: var(--ink); }
.section--yellow { background: var(--yellow); color: var(--ink); }
.section--black { background: var(--black); color: var(--cream); }

.grid { display: grid; gap: clamp(20px, 3vw, 40px); }
.grid-2 { grid-template-columns: 1fr 1fr; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 860px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* ---------- Pattern backgrounds ---------- */
.bg-argyle-red { background-color: var(--red); background-image: url('../assets/posters/argyle_red_yellow.png'); background-size: 120px 120px; }
.bg-argyle-blue { background-color: var(--light-blue); background-image: url('../assets/posters/argyle_blue_navy.png'); background-size: 120px 120px; }
.bg-newsprint {
  background: var(--cream) url('../assets/illustrations/04-Low-Grade-Newsprint-copy.jpg') center/cover;
  background-blend-mode: multiply;
}

/* ---------- Header / Nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--cream);
  border-bottom: 4px solid var(--red);
}
.site-header .container {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 0; gap: 24px;
}
.brand-logo { display: block; line-height: 0; }
.brand-logo img { height: 72px; width: auto; display: block; }
@media (max-width: 700px) { .brand-logo img { height: 64px; } }

.nav {
  display: flex; gap: clamp(14px, 2vw, 30px); align-items: center;
}
.nav a {
  font-family: 'Futura'; font-weight: 700; font-size: .92rem;
  letter-spacing: .15em; text-transform: uppercase; color: var(--ink);
  padding: 6px 0; transition: color .2s, transform .2s;
  border-bottom: 2px solid transparent;
}
.nav a:hover, .nav a.active { color: var(--red); border-bottom-color: var(--red); }

.nav-cta {
  background: var(--red); color: var(--cream) !important;
  padding: 10px 18px !important; border: 2px solid var(--red);
  border-bottom: 2px solid var(--red) !important;
  transition: background .2s, color .2s;
}
.nav-cta:hover { background: var(--yellow); color: var(--ink) !important; border-color: var(--yellow); }

.hamburger {
  display: none; background: none; border: none; cursor: pointer;
  padding: 8px; color: var(--ink);
}
.hamburger svg { width: 28px; height: 28px; }
.nav-close { display: none; }

@media (max-width: 860px) {
  .hamburger { display: block; }
  .nav {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: var(--cream);
    flex-direction: column; justify-content: center; align-items: center;
    gap: 28px; z-index: 200;
    transform: translateX(100%); transition: transform .3s;
  }
  .nav.open { transform: translateX(0); }
  .nav a { font-size: 1.3rem; }
  .nav-close {
    display: block;
    position: absolute; top: 20px; right: 20px;
    background: none; border: none; color: var(--ink); cursor: pointer;
  }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-block;
  font-family: 'Futura'; font-weight: 700; font-size: 1rem;
  letter-spacing: .15em; text-transform: uppercase;
  padding: 16px 32px; border: 3px solid transparent;
  transition: all .2s; cursor: pointer;
  text-align: center;
  border-radius: 999px;
}
.btn--red    { background: var(--red); color: var(--cream); border-color: var(--red); }
.btn--red:hover { background: var(--cream); color: var(--red); }
.btn--yellow { background: var(--yellow); color: var(--ink); border-color: var(--yellow); }
.btn--yellow:hover { background: var(--ink); color: var(--yellow); border-color: var(--yellow); }
.btn--navy   { background: var(--navy); color: var(--cream); border-color: var(--navy); }
.btn--navy:hover { background: var(--cream); color: var(--navy); }
.btn--outline-cream { background: transparent; color: var(--cream); border-color: var(--cream); }
.btn--outline-cream:hover { background: var(--cream); color: var(--ink); }
.btn--outline-navy { background: transparent; color: var(--navy); border-color: var(--navy); }
.btn--outline-navy:hover { background: var(--navy); color: var(--cream); }

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden;
  background: var(--light-blue);
  padding: clamp(40px, 6vw, 90px) 0 clamp(60px, 9vw, 140px);
}
.hero--red { background: var(--red); color: var(--cream); }
.hero--navy { background: var(--navy); color: var(--cream); }
.hero--cream { background: var(--cream); }
.hero--yellow { background: var(--yellow); color: var(--ink); }

.hero-inner {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(30px, 5vw, 80px);
  align-items: center;
}
@media (max-width: 900px) { .hero-inner { grid-template-columns: 1fr; } }

.hero-title {
  font-family: 'BigTickle'; font-weight: 900; line-height: .9;
  font-size: clamp(2.8rem, 7.5vw, 6rem); text-transform: uppercase;
  letter-spacing: .01em; margin: 0 0 .3em;
}
/* Single-line hero title variant: shrinks so the line fits without wrapping */
.hero-title--single {
  font-size: clamp(2rem, 9vw, 6rem);
  white-space: nowrap;
  letter-spacing: -.005em;
}
.hero-title--single .script { white-space: normal; }

/* Inline hero title — Bowl script sits on the same line as Your Cares Away. */
.hero-title--inline {
  font-size: clamp(1.75rem, 7.2vw, 5.25rem);
  white-space: nowrap;
  letter-spacing: -.005em;
  display: flex;
  align-items: baseline;
  gap: .18em;
  line-height: 1;
}
.script--inline {
  display: inline-block;
  font-size: 1.35em;
  color: var(--red);
  text-transform: none;
  line-height: 1;
  transform: translateY(.04em);
  margin-right: -.04em;
}
.hero-title__rest { display: inline-block; }

/* Eyebrow stays on one line at all sizes */
.eyebrow { white-space: nowrap; }

/* Single-line hero sub — scales down so it doesn't wrap */
.hero-sub--single {
  white-space: normal;
  font-size: clamp(.95rem, 1.85vw, 1.5rem);
  max-width: 50ch;
}
@media (max-width: 700px) {
  .hero-sub--single { white-space: normal; font-size: 1.15rem; }
}
.hero-title .script {
  display: block; font-size: 1.4em; margin-bottom: -.18em; margin-left: -.06em;
  color: var(--red); text-transform: none; line-height: 1;
}
.hero-title.on-red .script,
.hero-title.on-navy .script { color: var(--yellow); }
.hero-sub {
  font-family: 'Futura'; font-weight: 400; font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  max-width: 50ch; margin: 0 0 32px;
}

.hero-art {
  position: relative;
  display: flex; justify-content: center; align-items: center;
}
.hero-art img { max-height: 520px; width: auto; }

/* Hero two-mode block: floats on the blue background, no boxes */
.hero-modes {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 22px;
  max-width: 60ch;
  margin: 0;
  align-items: start;
}
.hero-mode { padding: 0; }
.hero-mode--day { color: var(--ink); }
.hero-mode--night { color: var(--ink); }
.hero-mode__divider {
  width: 3px; align-self: stretch;
  background: var(--ink);
  min-height: 100%;
}
.hero-mode__tag {
  display: inline-block;
  font-family: 'Futura'; font-weight: 800; font-size: .72rem;
  text-transform: uppercase; letter-spacing: .18em;
  padding: 4px 9px; border: 2px solid currentColor; margin-bottom: 10px;
  background: transparent;
}
.hero-mode--day .hero-mode__tag { color: var(--red); }
.hero-mode--night .hero-mode__tag { color: var(--navy); }
.hero-mode__title {
  font-family: 'BigTickleBlack'; font-weight: 400;
  font-size: 2rem; line-height: 1; margin: 0 0 10px;
  text-transform: uppercase; letter-spacing: .01em;
}
.hero-mode--day .hero-mode__title { color: var(--red); }
.hero-mode--night .hero-mode__title { color: var(--navy); }
.hero-mode p { font-size: .95rem; line-height: 1.5; margin: 0; color: var(--ink); }
@media (max-width: 700px) {
  .hero-modes { grid-template-columns: 1fr; gap: 18px; }
  .hero-mode__divider { width: auto; height: 3px; min-height: 0; }
}

/* Hero art: floating illustration, no box/frame */
.hero-art--float img {
  max-height: 460px; width: 100%; height: auto;
  background: transparent; border: 0; box-shadow: none;
  filter: drop-shadow(0 6px 14px rgba(14,14,14,.18));
}
@media (max-width: 900px) {
  .hero-art--float { display: none; }
}

/* Hero with illustrated building + light blue background */
.hero--photo {
  position: relative;
  overflow: hidden;
  background: var(--light-blue);
  padding: clamp(20px, 3vw, 40px) 0 clamp(48px, 6vw, 90px);
}
.hero__bg {
  position: absolute;
  top: 0; bottom: 0; right: 0;
  width: 40%;
  background-image: url('../assets/illustrations/MTB_BRAND_ASSETS__BLDG_FULL_COLOR_brandbg.png');
  background-size: contain;
  background-position: center right;
  background-repeat: no-repeat;
  z-index: 0;
}
.hero__scrim {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--light-blue) 0%, var(--light-blue) 38%, rgba(169,214,229,.9) 48%, rgba(169,214,229,0) 62%);
  z-index: 1;
}
.hero__inner { position: relative; z-index: 2; padding-right: 2rem; }
.hero__inner > *,
.hero__inner .hero-modes--on-photo { max-width: min(56%, 720px) !important; }
.hero__inner .hero-title { font-size: clamp(2rem, 4.5vw, 4rem); line-height: 1.05; }
.hero__inner .hero-title--inline { flex-wrap: wrap; align-items: flex-start; }
.hero__inner .hero-title--inline .script--inline { flex-basis: 100%; display: block; line-height: 1; margin-bottom: -.05em; }
.hero__inner .hero-title--inline .hero-title__rest { display: block; }
.hero__inner .hero-modes { max-width: 100%; }
@media (max-width: 900px) {
  .hero__inner { padding-left: 0; padding-right: 0; max-width: 100%; }
  .hero__inner > *,
  .hero__inner .hero-modes--on-photo { max-width: 100% !important; }
  .hero__inner .hero-title { font-size: clamp(2rem, 9vw, 3.4rem); }
  .hero__inner .eyebrow { white-space: normal; font-size: .95rem; letter-spacing: .2em; }
}

.eyebrow--on-photo { color: var(--navy); }
.hero-title--on-photo {
  color: var(--navy);
  text-shadow: none;
}
.hero-title--on-photo .script--inline { color: var(--red); }
.hero-sub--on-photo {
  color: var(--ink);
  text-shadow: none;
  max-width: 60ch;
}

/* Two-mode block on light blue */
.hero-modes--on-photo {
  max-width: 68ch;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.hero-modes--on-photo .hero-mode {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  padding: 0 0 0 14px;
  border-left: 3px solid var(--navy);
}
.hero-modes--on-photo .hero-mode--night { border-left-color: var(--red); }
.hero-modes--on-photo .hero-mode__divider { display: none; }
.hero-modes--on-photo .hero-mode--day .hero-mode__tag,
.hero-modes--on-photo .hero-mode--day .hero-mode__title { color: var(--navy); }
.hero-modes--on-photo .hero-mode--night .hero-mode__tag,
.hero-modes--on-photo .hero-mode--night .hero-mode__title { color: var(--red); }
.hero-modes--on-photo .hero-mode p { color: var(--ink); }

@media (max-width: 900px) {
  .hero--photo { min-height: 0; padding: 14px 0 48px; }
  .hero__bg {
    position: relative;
    width: 100%;
    height: 240px;
    margin: 18px 0 24px;
    background-position: center;
  }
  .hero__scrim { display: none; }
  .hero-modes--on-photo { grid-template-columns: 1fr; }
  .hero-modes--on-photo .hero-mode__divider { display: none; }
}

/* ---------- Stat row (deck-inspired) ---------- */
.stat-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
  border-top: 3px solid var(--ink);
  border-bottom: 3px solid var(--ink);
  padding: 28px 0;
}
.stat { text-align: left; padding: 0 6px; }
.stat__num {
  font-family: 'BigTickleBlack';
  font-weight: 400;
  color: var(--red);
  font-size: clamp(2.8rem, 6.5vw, 5.5rem);
  line-height: .95;
  letter-spacing: -.01em;
  margin-bottom: 6px;
}
.stat__num-suffix { font-size: .55em; vertical-align: baseline; }
.stat__cap {
  font-family: 'Futura';
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: clamp(.72rem, .95vw, .92rem);
}
@media (max-width: 700px) {
  .stat-row { grid-template-columns: 1fr; gap: 22px; padding: 22px 0; }
  .stat { text-align: left; }
}

/* ---------- Marquee / divider ---------- */
.marquee {
  background: var(--red); color: var(--cream);
  padding: 18px 0; overflow: hidden; white-space: nowrap;
  border-top: 4px solid var(--yellow); border-bottom: 4px solid var(--yellow);
}
.marquee-track {
  display: inline-block; animation: scroll 38s linear infinite;
  font-family: 'BigTickle'; font-weight: 900; font-size: 1.6rem;
  text-transform: uppercase; letter-spacing: .04em;
}
.marquee-track span { display: inline-block; padding: 0 38px; }
.marquee-track span::after { content: ' ✦'; color: var(--yellow); padding-left: 38px; }
@keyframes scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* Bottles marquee — image-only variant */
.marquee--bottles {
  background: var(--navy); padding: 0; overflow: hidden; white-space: nowrap;
  border-top: 4px solid var(--yellow); border-bottom: 4px solid var(--yellow);
  height: 120px;
}
.marquee--bottles .marquee-track {
  display: flex; align-items: center; animation: scroll 38s linear infinite;
  height: 100%;
}
.marquee--bottles .marquee-track img {
  height: 120px; width: auto; display: block; flex-shrink: 0;
}

/* ---------- Cards / Tiles ---------- */
.card {
  background: var(--cream); padding: clamp(24px, 3vw, 36px);
  border: 3px solid var(--ink);
  box-shadow: 8px 8px 0 var(--ink);
  transition: transform .2s, box-shadow .2s;
  border-radius: 18px;
}
.card:hover { transform: translate(-2px, -2px); box-shadow: 10px 10px 0 var(--ink); }
.card--red    { background: var(--red); color: var(--cream); border-color: var(--cream); box-shadow: 8px 8px 0 var(--cream); }
.card--navy   { background: var(--navy); color: var(--cream); border-color: var(--yellow); box-shadow: 8px 8px 0 var(--yellow); }
.card--yellow { background: var(--yellow); color: var(--ink); border-color: var(--ink); box-shadow: 8px 8px 0 var(--ink); }
.card--lightblue { background: var(--light-blue); color: var(--ink); border-color: var(--navy); box-shadow: 8px 8px 0 var(--navy); }

.tile-title {
  font-family: 'BigTickle'; font-weight: 900; text-transform: uppercase;
  font-size: 1.5rem; line-height: 1; margin: 0 0 12px;
}
.price {
  font-family: 'Futura'; font-weight: 800; font-size: 1.15rem;
  color: var(--red); float: right;
}

/* ---------- Menu list ---------- */
.menu-item {
  padding: 14px 0; border-bottom: 1px dashed rgba(14,14,14,.18);
}
.menu-item:last-child { border-bottom: none; }
.menu-item-head {
  display: flex; justify-content: space-between; align-items: baseline; gap: 14px;
  margin-bottom: 4px;
}
.menu-item-name {
  font-family: 'Futura'; font-weight: 700; font-size: 1.05rem;
  text-transform: uppercase; letter-spacing: .04em;
}
.menu-item-price {
  font-family: 'Futura'; font-weight: 700; color: var(--red); font-size: 1rem;
}
.menu-item-desc {
  font-size: .92rem; color: rgba(14,14,14,.7); line-height: 1.45; margin: 0;
}

.menu-section-title {
  font-family: 'BigTickle'; font-weight: 900; text-transform: uppercase;
  color: var(--red); font-size: clamp(1.8rem, 3vw, 2.6rem);
  margin: 0 0 6px;
}
.menu-section-sub {
  font-family: 'BigTickleScript'; font-size: 1.2rem; color: var(--navy);
  margin: 0 0 24px;
}

/* ---------- Footer ---------- */
.site-footer {
  background: var(--cream); color: var(--ink);
  padding: 70px 0 24px;
  border-top: 4px solid var(--red);
}
.site-footer .grid-4 { gap: 40px; }
.site-footer h4 {
  font-family: 'BigTickle'; font-weight: 900; text-transform: uppercase;
  color: var(--red); font-size: 1.1rem; letter-spacing: .04em;
}
.site-footer a { color: var(--ink); transition: color .15s; text-decoration: underline; text-decoration-color: rgba(14,14,14,.25); text-underline-offset: 3px; }
.site-footer a:hover { color: var(--red); text-decoration-color: var(--red); }
.site-footer .footer-logo img { height: 80px; margin-bottom: 14px; }
.site-footer-bottom {
  margin-top: 50px; padding-top: 22px; border-top: 1px solid rgba(14,14,14,.2);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px;
  font-size: .85rem; color: rgba(14,14,14,.6);
}

/* ---------- Modal ---------- */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(14,14,14,.75);
  display: none; align-items: center; justify-content: center; z-index: 1000;
  padding: 24px;
}
.modal-backdrop.open { display: flex; }
.modal {
  background: var(--cream); color: var(--ink);
  max-width: 520px; width: 100%; padding: 40px;
  border: 4px solid var(--red);
  box-shadow: 14px 14px 0 var(--navy);
  position: relative;
}
.modal-close {
  position: absolute; top: 14px; right: 18px;
  background: none; border: none; cursor: pointer;
  font-size: 1.5rem; color: var(--ink);
}
.modal h3 {
  font-family: 'BigTickle'; font-weight: 900; text-transform: uppercase;
  font-size: 2rem; color: var(--red); margin: 0 0 8px;
}
.modal .script {
  color: var(--navy); font-size: 1.4rem; margin: 0 0 14px;
}
.modal-form { display: flex; flex-direction: column; gap: 14px; margin-top: 18px; }
.modal-form input, .modal-form select, .modal-form textarea, .form input, .form select, .form textarea {
  font-family: 'Futura'; font-size: 1rem;
  padding: 12px 14px; border: 2px solid var(--ink); background: var(--cream);
}
.modal-form input:focus, .form input:focus { outline: none; border-color: var(--red); }

/* ---------- Forms ---------- */
.form { display: grid; gap: 14px; }
.form label {
  font-family: 'Futura'; font-weight: 700; font-size: .82rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--navy);
}
.form .row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 600px) { .form .row-2 { grid-template-columns: 1fr; } }
.form textarea { min-height: 130px; resize: vertical; }

/* ---------- Utilities ---------- */
.text-center { text-align: center; }
.mt-0 { margin-top: 0; } .mb-0 { margin-bottom: 0; }
.mt-4 { margin-top: 1.5rem; } .mt-8 { margin-top: 3rem; }
.divider-stars {
  text-align: center; font-family: 'BigTickle'; color: var(--yellow);
  letter-spacing: 1em; padding: 24px 0; font-size: 1.5rem;
}
.divider-stars::before { content: '✦ ✦ ✦'; }

/* Hours table */
.hours-list { list-style: none; padding: 0; margin: 0; }
.hours-list li {
  display: flex; justify-content: space-between;
  padding: 10px 0; border-bottom: 1px dashed rgba(250,246,236,.2);
  font-family: 'Futura'; font-weight: 500; font-size: 1.05rem;
}
.hours-list li.closed { color: rgba(250,246,236,.55); }
.hours-list .day { font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }

/* ---------- Global rounded corners for boxed elements ---------- */
/* Any element with the brand offset-shadow + thick-border pattern gets a soft radius */
[style*="box-shadow:14px 14px 0"],
[style*="box-shadow: 14px 14px 0"],
[style*="box-shadow:8px 8px 0"],
[style*="box-shadow: 8px 8px 0"],
[style*="box-shadow:10px 10px 0"],
[style*="box-shadow: 10px 10px 0"],
[style*="box-shadow:3px 3px 0"],
[style*="box-shadow: 3px 3px 0"] {
  border-radius: 18px;
}
/* Images inside those boxed wrappers also need rounding */
[style*="box-shadow:14px 14px 0"] > img,
[style*="box-shadow: 14px 14px 0"] > img {
  border-radius: 14px;
}
/* Tighter radius for small inline badges */
[style*="transform:rotate"][style*="box-shadow:3px 3px 0"],
[style*="transform: rotate"][style*="box-shadow: 3px 3px 0"] {
  border-radius: 10px;
}
/* Inputs in forms */
input, textarea, select { border-radius: 8px; }
input[type="submit"], button[type="submit"] { border-radius: 999px; }

/* Hero CTA row — fits three buttons on one row on desktop, wraps on mobile */
.hero-cta-row {
  display: flex;
  gap: 10px;
  flex-wrap: nowrap;
  align-items: center;
}
.hero-cta-row .btn {
  white-space: nowrap;
  padding: 14px 20px;
  font-size: .85rem;
}
@media (max-width: 900px) {
  .hero-cta-row { flex-wrap: wrap; gap: 12px; }
  .hero-cta-row .btn { padding: 14px 22px; font-size: .9rem; }
}
