/* ============================================================
   FUEGO STEAKHOUSE — design system
   Dark cinematic luxury · gold accents · editorial spacing
   ============================================================ */

:root{
  /* surfaces */
  --bg:        #100c0a;
  --bg-soft:   #16110e;
  --bg-deep:   #0a0706;
  --bg-card:   #1b1512;

  /* brand */
  --gold:      #c89a52;   /* tweakable */
  --gold-deep: #a67c39;
  --gold-soft: #e3c489;
  --fire-1:    #ffb43a;
  --fire-2:    #ef6a1c;
  --fire-3:    #b3220c;

  /* ink */
  --text:      #f3ece1;
  --text-dim:  #b1a594;
  --text-mute: #847a6c;
  --line:      rgba(244,236,225,.12);
  --line-soft: rgba(244,236,225,.07);

  /* type */
  --font-display: "DM Serif Display", Georgia, serif;  /* tweakable */
  --font-body:    "Mulish", system-ui, sans-serif;

  /* rhythm */
  --pad-section: 132px;   /* tweakable density */
  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

::selection{ background:var(--gold); color:#1a1207; }

/* ---------- shared atoms ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

.eyebrow{
  font-family:var(--font-body);
  font-size:12.5px;
  font-weight:700;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 22px;
  display:flex; align-items:center; gap:14px;
}
.eyebrow.center{ justify-content:center; }

h1,h2,h3{ font-family:var(--font-display); font-weight:400; line-height:1.04; margin:0; letter-spacing:.005em; }
h1{ font-size:clamp(42px, 5.2vw, 84px); }
h2{ font-size:clamp(36px, 4.4vw, 60px); }
.accent-italic{ font-style:italic; color:var(--gold); }
.lead{ color:var(--text-dim); font-size:clamp(17px,1.15vw,19px); line-height:1.75; max-width:54ch; }

/* buttons */
.btn{
  --bh:#c89a52;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-body); font-weight:700;
  font-size:12.5px; letter-spacing:.18em; text-transform:uppercase;
  padding:17px 30px; border-radius:var(--radius);
  border:1px solid var(--gold);
  transition:all .35s var(--ease);
  white-space:nowrap;
}
.btn:focus-visible{ outline:2px solid var(--gold-soft); outline-offset:3px; }
.btn-gold{ background:var(--gold); color:#1a1207; border-color:var(--gold); }
.btn-gold:hover{ background:var(--gold-soft); border-color:var(--gold-soft); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--text); }
.btn-ghost:hover{ background:rgba(200,154,82,.12); border-color:var(--gold-soft); color:#fff; transform:translateY(-2px); }
.btn-row{ display:flex; flex-wrap:wrap; gap:16px; }

.text-link{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-body); font-weight:700;
  font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold);
}
.text-link svg{ transition:transform .3s var(--ease); }
.text-link:hover svg{ transform:translateX(5px); }

/* hairline divider used in eyebrows / section heads */
.hair{ height:1px; width:46px; background:var(--gold); opacity:.7; flex:none; }

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   IMAGE SLOTS — cinematic empty state
   ============================================================ */
image-slot{
  background:
    radial-gradient(120% 90% at 70% 10%, rgba(239,106,28,.16), transparent 55%),
    linear-gradient(160deg,#241813,#0c0907 70%);
  border:1px solid var(--line);
  color:var(--text-mute);
  --slot-label-color:var(--text-dim);
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(12,9,7,.82);
  backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line-soft);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; height:84px; position:relative; z-index:2; }

/* live ember flames along the sticky header's bottom edge (desktop only) */
.header-fire{
  position:absolute; left:0; right:0; bottom:0; width:100%; height:36px;
  z-index:0; pointer-events:none;
  opacity:0; transition:opacity .6s var(--ease);
  -webkit-mask-image:linear-gradient(to top, #000 0%, rgba(0,0,0,.65) 42%, transparent 100%);
          mask-image:linear-gradient(to top, #000 0%, rgba(0,0,0,.65) 42%, transparent 100%);
}
.header-fire.lit{ opacity:.5; }
@media (max-width:1040px){ .header-fire{ display:none !important; } }

.brand{ display:flex; align-items:center; gap:12px; }
.brand-logo{ height:66px; width:auto; display:block; transition:transform .4s var(--ease); }
.brand:hover .brand-logo{ transform:scale(1.04); }
.brand-foot .brand-logo{ height:120px; margin:-18px 0 4px -10px; }
.brand .flame{ width:34px; height:42px; flex:none; }
.brand .word{ line-height:1; }
.brand .word b{ font-family:var(--font-display); font-size:25px; letter-spacing:.04em; display:block; }
.brand .word span{ font-family:var(--font-body); font-weight:700; font-size:10.5px; letter-spacing:.42em; color:var(--gold); display:block; margin-top:3px; }

.nav{ display:flex; align-items:center; gap:34px; }
.nav a{
  font-size:12.5px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--text-dim); position:relative; padding:6px 0; transition:color .25s;
}
.nav a:hover, .nav a.active{ color:var(--text); }
.nav a.active::after{ content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--gold); }
.nav .has-caret{ display:inline-flex; align-items:center; gap:6px; }
.nav .has-caret svg{ transition:transform .28s var(--ease); }

/* dropdown */
.nav-item{ position:relative; display:flex; align-items:center; }
.dropdown{
  position:absolute; top:100%; left:50%;
  transform:translateX(-50%) translateY(4px);
  min-width:188px; padding:9px; margin-top:14px;
  background:rgba(14,10,8,.97); backdrop-filter:blur(16px) saturate(120%);
  border:1px solid var(--line-soft); border-radius:6px;
  box-shadow:0 26px 54px rgba(0,0,0,.5);
  display:flex; flex-direction:column; gap:2px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .26s var(--ease), transform .26s var(--ease), visibility .26s;
  z-index:70;
}
.dropdown::before{ content:""; position:absolute; top:-28px; left:-16px; right:-16px; height:30px; }
.nav-item.has-dropdown:hover .dropdown,
.nav-item.has-dropdown:focus-within .dropdown{
  opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(8px);
}
.nav-item.has-dropdown:hover .has-caret svg,
.nav-item.has-dropdown:focus-within .has-caret svg{ transform:rotate(180deg); }
.dropdown a{
  font-size:11.5px; letter-spacing:.15em; text-transform:uppercase; font-weight:700;
  color:var(--text-dim); padding:12px 14px; border-radius:4px; white-space:nowrap;
  transition:background .2s, color .2s, padding-left .2s;
}
.dropdown a:hover{ color:var(--text); background:rgba(200,154,82,.13); padding-left:18px; }
.dropdown a::after{ display:none; }

.header-cta{ display:flex; align-items:center; gap:14px; }
.burger{ display:none; background:none; border:1px solid var(--line); border-radius:var(--radius); width:46px; height:46px; padding:0; align-items:center; justify-content:center; }
.burger span{ display:block; width:20px; height:2px; background:var(--text); position:relative; transition:.3s; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:var(--text); transition:.3s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }
body.menu-open .burger span{ background:transparent; }
body.menu-open .burger span::before{ top:0; transform:rotate(45deg); }
body.menu-open .burger span::after{ top:0; transform:rotate(-45deg); }

/* mobile drawer */
.mobile-nav{
  position:fixed; inset:0; z-index:55; background:rgba(8,6,5,.97);
  backdrop-filter:blur(8px);
  display:flex; flex-direction:column; justify-content:center; gap:8px;
  padding:0 var(--gutter);
  opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s;
}
body.menu-open .mobile-nav{ opacity:1; visibility:visible; }
.mobile-nav a{ font-family:var(--font-display); font-size:34px; padding:12px 0; border-bottom:1px solid var(--line-soft); }
.mobile-sub{ display:flex; flex-direction:column; }
.mobile-sub a{ font-family:var(--font-body); font-size:15px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); padding:11px 0 11px 22px; border-bottom:1px solid var(--line-soft); }
.mobile-sub a:last-child{ border-bottom:1px solid var(--line-soft); }
.mobile-nav .btn{ margin-top:28px; align-self:flex-start; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.hero-media{ position:absolute; inset:0; z-index:0; background:linear-gradient(160deg,#241813,#0c0907 70%); }
.hero-media image-slot{ width:100%; height:100%; }
.hero-video{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, var(--bg) 18%, rgba(16,12,10,.72) 46%, rgba(16,12,10,.12) 72%, transparent),
             linear-gradient(0deg, var(--bg) 2%, transparent 30%);
}
.hero-inner{ position:relative; z-index:2; padding-top:140px; padding-bottom:90px; }
.hero .eyebrow{ margin-bottom:26px; }
.hero h1{ max-width:13ch; margin-bottom:34px; }
.hero .lead{ margin-bottom:38px; max-width:42ch; }
.scroll-cue{ position:absolute; left:50%; bottom:30px; transform:translateX(-50%); z-index:3; color:var(--text-mute); font-size:10.5px; letter-spacing:.3em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:10px; }
.scroll-cue .line{ width:1px; height:46px; background:linear-gradient(var(--gold),transparent); animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%{transform:scaleY(.2);transform-origin:top;opacity:.3} 50%{transform:scaleY(1);opacity:1} 100%{transform:scaleY(.2);transform-origin:bottom;opacity:.3} }

/* ============================================================
   SIGNATURE (split)
   ============================================================ */
.signature{ display:grid; grid-template-columns:1.05fr 1fr; align-items:stretch; background:var(--bg-deep); }
.signature .media{ position:relative; min-height:560px; }
.signature .media image-slot, .signature .media img{ width:100%; height:100%; object-fit:cover; }
.signature .copy{ padding:var(--pad-section) clamp(40px,6vw,96px); display:flex; flex-direction:column; justify-content:center; }
.signature h2{ max-width:13ch; margin-bottom:26px; }
.signature .lead{ margin-bottom:36px; }

/* ============================================================
   ENTERTAINMENT
   ============================================================ */
.entertain{ position:relative; background:var(--bg-soft); display:grid; grid-template-columns:1fr 1fr; align-items:stretch; }
.entertain .copy{ padding:var(--pad-section) clamp(40px,6vw,96px); display:flex; flex-direction:column; justify-content:center; }
.entertain h2{ margin-bottom:48px; max-width:11ch; }
.entertain .media{ position:relative; min-height:560px; overflow:hidden; }
.entertain .media image-slot{ width:100%; height:100%; }
.entertain .media .media-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 38%; }
.entertain .media::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,var(--bg-soft),transparent 30%); }

.events{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-bottom:46px; }
.event{ display:flex; flex-direction:column; gap:9px; }
.event .ico{ width:30px; height:30px; color:var(--gold); margin-bottom:10px; }
.event .day{ font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--text-mute); }
.event .name{ font-family:var(--font-display); font-size:23px; line-height:1.12; }
.event .desc{ font-size:14.5px; color:var(--text-dim); line-height:1.5; }
.event .time{ font-size:13px; font-weight:700; letter-spacing:.08em; color:var(--gold); margin-top:4px; }

/* ============================================================
   BRUNCH (image | text | image)
   ============================================================ */
.brunch{ display:grid; grid-template-columns:1.1fr 1.15fr .95fr; align-items:stretch; background:var(--bg); min-height:560px; }
.brunch image-slot, .brunch img{ width:100%; height:100%; min-height:560px; object-fit:cover; }
.brunch .copy{ padding:var(--pad-section) clamp(34px,4vw,64px); display:flex; flex-direction:column; justify-content:center; }
.brunch h2{ line-height:1.02; margin-bottom:26px; }
.brunch .lead{ margin-bottom:34px; font-size:17px; }

/* ============================================================
   PRIVATE EVENTS + MENU PREVIEW (combined row)
   ============================================================ */
.events-menus{ background:var(--bg-deep); padding-block:var(--pad-section); }
.em-grid{ display:grid; grid-template-columns:.86fr 1.14fr; gap:clamp(40px,6vw,90px); align-items:center; }
.private h2{ margin-bottom:24px; }
.private .lead{ margin-bottom:34px; max-width:40ch; }
.cat-list{ display:grid; grid-template-columns:1fr 1fr; gap:16px 30px; margin-bottom:40px; list-style:none; padding:0; }
.cat-list li{ display:flex; align-items:center; gap:13px; font-size:15.5px; color:var(--text); }
.cat-list svg{ width:19px; height:19px; color:var(--gold); flex:none; }

.menu-head{ text-align:center; margin-bottom:26px; }
.menu-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.menu-cards-3{ grid-template-columns:repeat(3,1fr); }
.menu-card{ position:relative; aspect-ratio:3/4.1; border-radius:var(--radius); overflow:hidden; }
.menu-card image-slot, .menu-card img{ width:100%; height:100%; object-fit:cover; }
.menu-card .overlay{ position:absolute; inset:0; background:linear-gradient(0deg,rgba(7,5,4,.92) 6%,rgba(7,5,4,.25) 48%,transparent); pointer-events:none; }
.menu-card .label{ position:absolute; left:18px; right:18px; bottom:18px; }
.menu-card .label h3{ font-family:var(--font-display); font-size:22px; margin-bottom:6px; }
.menu-card .label .text-link{ font-size:10.5px; }
.menu-card:hover image-slot, .menu-card:hover img{ filter:brightness(1.08); }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{ position:relative; background:var(--bg-soft); padding-block:var(--pad-section); overflow:hidden; }
.reviews::before{ content:""; position:absolute; inset:0; opacity:.5;
  background:radial-gradient(80% 60% at 50% 0%, rgba(200,154,82,.08), transparent 60%); }
.reviews .inner{ position:relative; z-index:2; }
.reviews-head{ text-align:center; margin-bottom:54px; }
.review-rail{ display:flex; align-items:stretch; gap:30px; }
.google-card{ flex:none; width:210px; display:flex; flex-direction:column; justify-content:center; align-items:center; gap:8px; text-align:center; padding-right:30px; border-right:1px solid var(--line-soft); }
.google-card .glogo{ font-size:30px; font-weight:700; letter-spacing:-.01em; }
.google-card .glogo .b{color:#4285F4}.glogo .r{color:#EA4335}.glogo .y{color:#FBBC05}.glogo .g{color:#34A853}
.google-card .rating{ font-size:30px; font-family:var(--font-display); color:var(--gold); }
.google-card .count{ font-size:13px; color:var(--text-dim); }
.stars{ display:inline-flex; gap:3px; color:var(--gold); }
.stars svg{ width:17px; height:17px; }

.review-track{ display:grid; grid-auto-flow:column; grid-auto-columns:minmax(260px,1fr); gap:30px; flex:1; overflow:hidden; }
.review{ display:flex; flex-direction:column; gap:14px; padding-left:6px; }
.review .quote{ font-family:var(--font-display); font-size:40px; line-height:.4; color:var(--gold); opacity:.6; }
.review .body{ font-size:15.5px; color:var(--text-dim); line-height:1.6; }
.review .who{ font-size:13px; font-weight:700; letter-spacing:.05em; color:var(--text); margin-top:auto; }
.review-nav{ position:absolute; top:50%; z-index:3; width:46px; height:46px; border-radius:50%; border:1px solid var(--line); background:rgba(16,12,10,.7); color:var(--text); display:flex; align-items:center; justify-content:center; }
.review-nav:hover{ border-color:var(--gold); color:var(--gold); }
.review-nav.prev{ left:6px; } .review-nav.next{ right:6px; }

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{ position:relative; min-height:62vh; display:flex; align-items:center; overflow:hidden; }
.final .media{ position:absolute; inset:0; z-index:0; }
.final .media image-slot{ width:100%; height:100%; }
.final .media img{ width:100%; height:100%; object-fit:cover; }
.final .media::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(8,6,5,.92),rgba(8,6,5,.55) 60%,rgba(8,6,5,.35)); }
.final .inner{ position:relative; z-index:2; display:flex; align-items:center; justify-content:space-between; gap:50px; flex-wrap:wrap; padding-block:90px; }
.final h2{ font-size:clamp(40px,5.4vw,76px); max-width:11ch; }
.final .lead{ margin-top:18px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--bg-deep); padding-block:78px 30px; border-top:1px solid var(--line-soft); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.3fr 1.4fr; gap:46px; }
.footer .brand{ margin-bottom:24px; }
.foot-contact{ display:flex; flex-direction:column; gap:13px; color:var(--text-dim); font-size:14.5px; }
.foot-contact .row{ display:flex; align-items:flex-start; gap:11px; }
.foot-contact svg{ width:17px; height:17px; color:var(--gold); flex:none; margin-top:3px; }
.socials{ display:flex; gap:12px; margin-top:24px; }
.socials a{ width:40px; height:40px; border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--text-dim); transition:.3s; }
.socials a:hover{ border-color:var(--gold); color:var(--gold); }
.socials svg{ width:17px; height:17px; }

.footer h4{ font-family:var(--font-body); font-size:12px; font-weight:800; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin:6px 0 22px; }
.foot-links{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:13px; }
.foot-links a{ font-size:14.5px; color:var(--text-dim); transition:color .25s; }
.foot-links a:hover{ color:var(--text); }
.hours .row{ display:flex; flex-direction:column; gap:1px; margin-bottom:14px; font-size:14px; }
.hours .row b{ color:var(--text); font-weight:600; }
.hours .row span{ color:var(--text-dim); }

.newsletter p{ color:var(--text-dim); font-size:14.5px; margin:0 0 18px; }
.news-form{ display:flex; flex-direction:column; gap:12px; max-width:300px; }
.news-form label{ font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); }
.news-form input{ background:var(--bg-card); border:1px solid var(--line); color:var(--text); padding:14px 16px; border-radius:var(--radius); font-family:inherit; font-size:15px; }
.news-form input:focus{ outline:none; border-color:var(--gold); }
.news-form .msg{ font-size:13px; min-height:16px; }
.news-form .msg.ok{ color:var(--gold-soft); } .news-form .msg.err{ color:#e98b5a; }
.news-form button{ background:var(--gold); color:#1a1207; border:none; font-weight:800; letter-spacing:.16em; text-transform:uppercase; font-size:12.5px; padding:15px; border-radius:var(--radius); transition:.3s; }
.news-form button:hover{ background:var(--gold-soft); }

.footer-bottom{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  margin-top:60px; padding-top:26px; border-top:1px solid var(--line-soft); }
.footer-bottom .copy{ font-size:13px; color:var(--text-mute); }
.footer-bottom .legal{ display:flex; gap:24px; }
.footer-bottom .legal a{ font-size:13px; color:var(--text-mute); } .footer-bottom .legal a:hover{ color:var(--text-dim); }

/* ============================================================
   RESERVE MODAL
   ============================================================ */
.modal-scrim{ position:fixed; inset:0; z-index:90; background:rgba(6,4,3,.78); backdrop-filter:blur(6px);
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s; display:flex; align-items:center; justify-content:center; padding:24px; }
.modal-scrim.open{ opacity:1; visibility:visible; }
.modal{ width:100%; max-width:560px; background:var(--bg-card); border:1px solid var(--line); border-radius:6px; overflow:hidden;
  transform:translateY(20px) scale(.98); transition:transform .4s var(--ease); max-height:92vh; overflow-y:auto; }
.modal-scrim.open .modal{ transform:none; }
.modal-top{ position:relative; padding:34px 38px 26px; border-bottom:1px solid var(--line-soft);
  background:radial-gradient(120% 100% at 80% 0,rgba(239,106,28,.14),transparent 60%); }
.modal-top .eyebrow{ margin-bottom:14px; }
.modal-top h3{ font-family:var(--font-display); font-size:32px; }
.modal-top p{ color:var(--text-dim); font-size:14.5px; margin:8px 0 0; }
.modal-close{ position:absolute; top:20px; right:20px; width:38px; height:38px; border-radius:50%; background:rgba(0,0,0,.3); border:1px solid var(--line); color:var(--text); font-size:18px; display:flex; align-items:center; justify-content:center; }
.modal-close:hover{ border-color:var(--gold); color:var(--gold); }
.modal-body{ padding:30px 38px 38px; display:flex; flex-direction:column; gap:20px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-size:11.5px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.field input,.field select{ background:var(--bg-deep); border:1px solid var(--line); color:var(--text); padding:14px 15px; border-radius:var(--radius); font-family:inherit; font-size:15.5px; }
.field input:focus,.field select:focus{ outline:none; border-color:var(--gold); }
.field-2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.party-pills{ display:flex; flex-wrap:wrap; gap:8px; }
.party-pills button{ background:var(--bg-deep); border:1px solid var(--line); color:var(--text-dim); border-radius:var(--radius); padding:11px 0; flex:1; min-width:42px; font-weight:700; font-size:14px; transition:.2s; }
.party-pills button.sel{ background:var(--gold); color:#1a1207; border-color:var(--gold); }
.modal .btn-gold{ width:100%; padding:18px; }
.modal-success{ text-align:center; padding:18px 0 6px; }
.modal-success .check{ width:62px; height:62px; border-radius:50%; border:2px solid var(--gold); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; color:var(--gold); }
.modal-success .check svg{ width:28px; height:28px; }
.modal-success h3{ font-family:var(--font-display); font-size:28px; margin-bottom:10px; }
.modal-success p{ color:var(--text-dim); font-size:15px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .nav, .header-cta .btn{ display:none; }
  .burger{ display:flex; }
  .hero{ min-height:auto; }
  .hero-inner{ padding-top:128px; padding-bottom:96px; }
  .hero h1{ font-size:clamp(40px,6.4vw,58px); }
  .signature, .entertain{ grid-template-columns:1fr; }
  .signature .media, .entertain .media{ min-height:380px; order:-1; }
  .brunch{ grid-template-columns:1fr; }
  .brunch image-slot, .brunch img{ min-height:340px; }
  .em-grid{ grid-template-columns:1fr; }
  .menu-cards{ grid-template-columns:1fr 1fr; }
  .menu-cards-3{ grid-template-columns:repeat(3,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:40px; }
  .review-rail{ flex-direction:column; }
  .google-card{ width:100%; border-right:none; border-bottom:1px solid var(--line-soft); padding:0 0 26px; flex-direction:row; justify-content:flex-start; gap:24px; text-align:left; }
  .review-track{ grid-auto-columns:minmax(80%,1fr); }
}
@media (max-width:560px){
  body{ font-size:16px; }
  :root{ --pad-section:84px; }
  .events{ grid-template-columns:1fr; gap:26px; }
  .menu-cards{ grid-template-columns:1fr 1fr; gap:12px; }
  .menu-cards-3{ grid-template-columns:1fr; gap:14px; }
  .cat-list{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .final .inner{ flex-direction:column; align-items:flex-start; }
  .hero h1{ font-size:46px; }
}
