/* ============================================================================
   Guanabanas Island Restaurant & Bar — v1
   Concept: "A Taste of Paradise — the open-air dock at golden hour"
   Palette IS the sunset over the Intracoastal: aqua -> gold -> pink on
   charcoal + cream. Fraunces (display) + Nunito Sans (body).
   LOOK is concept-driven; MECHANICS (nav/gallery/order/menu/reviews/connect/
   scroll-reveal base contracts) are the frozen skill contracts, copied here.
   ============================================================================ */

:root {
  /* ---- color (all pairs contrast-verified, web-ui-kit/contrast.py) ---- */
  --paper:      #F3F1E6;   /* cream page ground */
  --paper-2:    #EAE6D5;   /* raised cream (panels, raised grounds) */
  --paper-3:    #FBFAF3;   /* lightest card paper */
  --ink:        #2D2A24;   /* charcoal body text — 12.6:1 on cream */
  --ink-soft:   #4A4438;   /* softened body — 8.5:1 */
  --muted:      #6A6354;   /* captions/meta — 5.3:1 on cream */
  --muted-dark: #A59E8D;   /* meta on charcoal — 5.4:1 */

  --aqua:   #A9E2D4;       /* sunset-water aqua */
  --aqua-deep: #5BB7A2;    /* deeper aqua for rims/strokes on cream */
  --gold:   #E7D06B;       /* sunset gold */
  --gold-deep: #C9A93B;    /* deeper gold rim on cream */
  --pink:   #D24E7C;       /* sunset pink (brand wash) */

  --accent:     #A82D5C;   /* links / prices / eyebrows — 5.8:1 on cream */
  --cta:        #B23463;   /* primary action fill — white text 5.89:1, pops */
  --cta-ink:    #ffffff;
  --cta-hover:  #8E2750;

  --line:       rgba(45,42,36,.14);
  --line-soft:  rgba(45,42,36,.07);
  --line-on-dark: rgba(243,241,230,.16);
  --shadow:     0 20px 46px -26px rgba(45,42,36,.45);
  --shadow-lg:  0 30px 70px -34px rgba(45,42,36,.55);

  /* ---- type ramp (fluid, declared once) ---- */
  --display: 'Fraunces', Georgia, serif;
  --sans:    'Nunito Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --fs-hero: clamp(2.9rem, 7.4vw, 5.6rem);
  --fs-h2:   clamp(2rem, 4.6vw, 3.1rem);
  --fs-h3:   clamp(1.25rem, 2.4vw, 1.55rem);
  --fs-lede: clamp(1.06rem, 2vw, 1.3rem);
  --fs-body: 1.06rem;

  /* ---- rhythm ---- */
  --section-y: clamp(3.6rem, 8vw, 6.4rem);
  --gap:       clamp(1rem, 3vw, 1.5rem);
  --wrap:      1180px;
  --pad-x:     1.25rem;

  /* ---- mechanics tokens ---- */
  --header-h:  76px;
  --order-radius: 18px;
  --marquee-speed: 64s;
  --ph-ease: .3s ease;
  --review-card: clamp(280px, 80vw, 460px);
  --review-lines: 6;
  --star: #C9A93B;

  /* ---- motion (golden-hour-reveal) ---- */
  --reveal-rise: 24px;
  --reveal-dur: .8s;
  --reveal-ease: cubic-bezier(.16,1,.3,1);
  --reveal-stagger: .09s;
}

/* breakpoints used as raw numbers in @media (one set): nav 720, stack 860 */

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

img { max-width: 100%; }
h1, h2, h3, h4 { font-family: var(--display); line-height: 1.06; font-weight: 600; margin: 0; }
p { margin: 0 0 1rem; }
a { color: var(--accent); }

.wrap { width: min(var(--wrap), 100% - 2.5rem); margin-inline: auto; }
.eyebrow {
  display: inline-block; font-family: var(--sans); text-transform: uppercase;
  letter-spacing: .3em; font-size: .72rem; font-weight: 800; color: var(--accent);
}
.section { padding: var(--section-y) 0; position: relative; }
.section--cream2 { background: var(--paper-2); }
.section--dusk {
  /* charcoal dusk band — the sunset deepening into night over the water */
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(210,78,124,.22), transparent 60%),
    radial-gradient(90% 80% at 8% 0%, rgba(231,208,107,.14), transparent 55%),
    var(--ink);
  color: var(--paper);
}
.section--dusk h2 { color: var(--paper); }
.section--dusk .eyebrow { color: var(--gold); }

.section-head { max-width: 62ch; margin-bottom: clamp(1.8rem, 4vw, 2.8rem); }
.section-head h2 { font-size: var(--fs-h2); margin: .5rem 0 0; }
.section-head p { font-size: var(--fs-lede); color: var(--ink-soft); margin: .7rem 0 0; max-width: 60ch; }
.section--dusk .section-head p { color: var(--muted-dark); }

/* skip link */
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--ink); color: var(--paper);
  padding: .6rem 1rem; z-index: 200; border-radius: 0 0 8px 0; }
.skip-link:focus { left: 0; }

/* ===========================================================================
   DOCK-DIVIDER — the woven-rope / dock-piling motif (NEVER a plain <hr>)
   A repeating SVG band: rope twist + piling caps. Decorative (aria-hidden).
   =========================================================================== */
.dock-divider {
  height: 26px; margin: 0; border: 0; width: 100%;
  background-repeat: repeat-x; background-position: center; background-size: 46px 26px;
  /* rope twist: alternating diagonal strands in aqua/gold over transparent */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='46' height='26' viewBox='0 0 46 26'><g fill='none' stroke-width='3.4' stroke-linecap='round'><path d='M-2 8 Q 9 0 20 8 T 42 8' stroke='%23C9A93B'/><path d='M-2 18 Q 9 26 20 18 T 42 18' stroke='%235BB7A2'/><path d='M4 8 L 4 18 M 27 8 L 27 18' stroke='%23D24E7C' stroke-width='2.2' opacity='.55'/></g></svg>");
  opacity: .9;
}
.dock-divider--on-dark {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='46' height='26' viewBox='0 0 46 26'><g fill='none' stroke-width='3.4' stroke-linecap='round'><path d='M-2 8 Q 9 0 20 8 T 42 8' stroke='%23E7D06B'/><path d='M-2 18 Q 9 26 20 18 T 42 18' stroke='%23A9E2D4'/><path d='M4 8 L 4 18 M 27 8 L 27 18' stroke='%23D24E7C' stroke-width='2.2' opacity='.7'/></g></svg>");
}
/* a thinner inline rope rule used inside section heads */
.rope-rule { height: 14px; flex: 1; min-width: 40px; opacity: .8;
  background-repeat: repeat-x; background-position: center; background-size: 40px 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='14' viewBox='0 0 40 14'><g fill='none' stroke-width='2.6' stroke-linecap='round'><path d='M-2 4 Q 8 -1 18 4 T 38 4' stroke='%23C9A93B'/><path d='M-2 10 Q 8 15 18 10 T 38 10' stroke='%235BB7A2'/></g></svg>"); }

/* ===========================================================================
   BUTTONS
   =========================================================================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5em;
  font-family: var(--sans); font-weight: 800; font-size: .96rem; letter-spacing: .01em;
  padding: .85em 1.65em; border-radius: 999px; text-decoration: none;
  border: 2px solid transparent; cursor: pointer; min-height: 48px;
  transition: background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.btn--primary { background: var(--cta); color: var(--cta-ink); box-shadow: 0 12px 26px -14px rgba(178,52,99,.8); }
.btn--primary:hover { background: var(--cta-hover); color: #fff; }
.btn--ghost { border-color: rgba(243,241,230,.7); color: #fff; background: rgba(45,42,36,.18); }
.btn--ghost:hover { border-color: #fff; background: rgba(45,42,36,.35); }
.btn--dark { background: var(--ink); color: var(--paper); }
.btn--dark:hover { background: #1f1d18; color: #fff; }
.btn--outline { border-color: var(--accent); color: var(--accent); background: transparent; }
.btn--outline:hover { background: var(--accent); color: #fff; }
.btn .icon { width: 1.15em; height: 1.15em; }

/* ===========================================================================
   SITE HEADER / NAV  (site-nav base contract + concept skin)
   =========================================================================== */
.site-header { position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line); }
.header__inner { display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; min-height: var(--header-h); }

.wordmark { display: inline-flex; align-items: center; gap: .6rem; text-decoration: none; color: var(--ink); }
.wordmark__logo { height: clamp(40px, 7vw, 54px); width: auto; display: block; }

:where(section[id], [id].menu-section) { scroll-margin-top: calc(var(--header-h) + 12px); }

.nav-toggle { display: none; appearance: none; background: none; border: 0; padding: 0;
  cursor: pointer; color: var(--ink); line-height: 0; }
.nav-toggle .icon { width: 1.7rem; height: 1.7rem; }
.nav-toggle__close { display: none; }
.nav-close { display: none; }
.site-header[data-open] .nav-toggle__open  { display: none; }
.site-header[data-open] .nav-toggle__close { display: inline-block; }

[data-nav-panel]:focus { outline: none; }
.nav a, .nav-toggle, .nav .btn { -webkit-tap-highlight-color: transparent; }
.nav a:focus:not(:focus-visible), .nav .btn:focus:not(:focus-visible),
.nav-toggle:focus:not(:focus-visible) { outline: none; }

html.nav-locked, html.nav-locked body { overflow: hidden; }
.site-header[data-nav-lock][data-open] { -webkit-backdrop-filter: none; backdrop-filter: none; filter: none; }

.nav a:not(.btn) { font-family: var(--sans); font-weight: 700; font-size: .96rem;
  color: var(--ink); text-decoration: none; position: relative; }
.nav a:not(.btn):hover { color: var(--accent); }

@media (min-width: 721px) {
  .nav { display: flex; align-items: center; gap: 1.7rem; }
  /* concept: a quiet aqua-gold rope underline on hover */
  .nav a:not(.btn)::after { content: ""; position: absolute; left: 0; right: 0; bottom: -6px;
    height: 3px; border-radius: 3px; background: linear-gradient(90deg, var(--aqua-deep), var(--gold-deep));
    transform: scaleX(0); transform-origin: left; transition: transform .25s ease; }
  .nav a:not(.btn):hover::after, .nav a:not(.btn).is-current::after { transform: scaleX(1); }
}

@media (max-width: 720px) {
  .nav-enhanced .nav-toggle { display: inline-flex; align-items: center; justify-content: center;
    min-width: 48px; min-height: 48px; }
  /* curtain panel (data-nav-anim="curtain", needs data-nav-lock) */
  .nav-enhanced .nav { position: fixed; inset: 0; z-index: 60;
    background: var(--ink);
    background-image:
      radial-gradient(120% 80% at 80% 0%, rgba(210,78,124,.30), transparent 55%),
      radial-gradient(90% 70% at 0% 100%, rgba(91,183,162,.26), transparent 55%);
    display: flex; flex-direction: column; align-items: stretch; justify-content: center;
    gap: .2rem; padding: clamp(4.5rem, 14vw, 6rem) 1.5rem 2rem;
    transform: translateY(-100%); transition: transform .4s cubic-bezier(.4,0,.2,1);
    overflow-y: auto; }
  .site-header[data-open] .nav-enhanced .nav,
  .nav-enhanced .site-header[data-open] .nav { transform: translateY(0); }
  .site-header[data-open] .nav { transform: translateY(0); }
  .nav-enhanced .nav a { display: flex; align-items: center; min-height: 52px; width: 100%;
    color: var(--paper); font-size: 1.35rem; font-weight: 700; border-bottom: 1px solid var(--line-on-dark); }
  .nav-enhanced .nav a:not(.btn):hover { color: var(--gold); }
  .nav-enhanced .nav .btn { justify-content: center; margin-top: 1.1rem; min-height: 52px; }
  .nav-enhanced .nav .btn--ghost { border-color: rgba(243,241,230,.65); color: #fff; }
  /* in-panel close lives INSIDE the panel (mobile-safari layering) */
  .nav-enhanced .nav-close { display: inline-flex; position: absolute; top: 1.1rem; right: 1.1rem;
    width: 48px; height: 48px; align-items: center; justify-content: center; border-radius: 999px;
    border: 1px solid var(--line-on-dark); background: rgba(243,241,230,.08); color: var(--paper); }
  .nav-enhanced .nav-close .icon { width: 1.5rem; height: 1.5rem; }
}
@media (prefers-reduced-motion: reduce) {
  .nav-enhanced .nav { transition: none; }
}

/* ===========================================================================
   HERO — full-bleed dock at golden hour, sunset-gradient scrim
   =========================================================================== */
.hero { position: relative; min-height: 90vh; display: flex; align-items: flex-end;
  color: #fff; background: var(--ink); overflow: hidden; }
.hero__img { position: absolute; inset: 0; display: block; width: 100%; height: 100%;
  min-height: 100%; object-fit: cover; object-position: center 42%; }
/* sunset scrim: gold->pink->charcoal, dark top (header) + dark bottom (text) */
.hero__scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(31,21,28,.62) 0%, rgba(31,21,28,.12) 26%,
      rgba(120,40,70,.14) 52%, rgba(45,30,30,.66) 80%, rgba(28,22,22,.92) 100%); }
.hero__inner { position: relative; z-index: 2; padding: clamp(2.6rem, 6vw, 5rem) 0 clamp(3rem,7vw,5.5rem);
  max-width: 820px; }
.hero__eyebrow { color: var(--gold); text-shadow: 0 1px 12px rgba(0,0,0,.5); }
.hero h1 { font-size: var(--fs-hero); line-height: 1.0; margin: .5rem 0 .3rem;
  text-shadow: 0 3px 36px rgba(0,0,0,.5); letter-spacing: -.01em; }
.hero h1 .hero__sun { color: var(--gold); }
.hero__lede { font-size: var(--fs-lede); color: rgba(255,255,255,.95); max-width: 50ch;
  margin: 1rem 0 1.8rem; text-shadow: 0 2px 18px rgba(0,0,0,.55); }
.hero__cta { display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; }
.hero__meta { margin-top: 1.6rem; display: flex; flex-wrap: wrap; gap: .6rem 1.4rem;
  font-family: var(--sans); font-weight: 700; font-size: .85rem; color: rgba(255,255,255,.92);
  text-shadow: 0 1px 10px rgba(0,0,0,.6); }
.hero__meta span { display: inline-flex; align-items: center; gap: .45rem; }
.hero__meta .icon { width: 1.05em; height: 1.05em; color: var(--aqua); }

/* ===========================================================================
   COLORED-PLATE CARDS — the bright serving-plate motif (known-for + signatures)
   Rounded "plate" frames with rotating aqua / gold / pink color rims.
   =========================================================================== */
.plates { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.plates > * { min-width: 0; }
.plate-card { position: relative; background: var(--paper-3);
  border-radius: 22px; padding: .55rem .55rem 1.25rem; box-shadow: var(--shadow);
  border: 1px solid var(--line); overflow: hidden; }
.plate-card__media { position: relative; border-radius: 18px; overflow: hidden;
  /* the color "plate" rim */
  box-shadow: inset 0 0 0 6px var(--plate-rim, var(--aqua));
  aspect-ratio: 4/3; }
.plate-card__media img { display: block; width: 100%; height: 100%; min-height: 100%;
  object-fit: cover; object-position: center 45%; transition: transform .55s ease; }
.plate-card:hover .plate-card__media img { transform: scale(1.05); }
.plate-card__body { padding: 1rem .9rem 0; }
.plate-card__body h3 { font-size: var(--fs-h3); color: var(--ink); }
.plate-card__body p { margin: .4rem 0 0; color: var(--ink-soft); font-size: .97rem; }
.plate-card__kicker { font-family: var(--sans); font-weight: 800; font-size: .68rem;
  letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
/* rotate the rim color so the row reads like a stack of bright plates */
.plate-card:nth-child(3n+1) { --plate-rim: var(--aqua); }
.plate-card:nth-child(3n+2) { --plate-rim: var(--gold); }
.plate-card:nth-child(3n+3) { --plate-rim: var(--pink); }

/* ===========================================================================
   STORY — two-column photo + narrative
   =========================================================================== */
.story { display: grid; grid-template-columns: 1.02fr .98fr; gap: clamp(2rem, 5vw, 4.2rem); align-items: center; }
.story > * { min-width: 0; }
.story__media { position: relative; margin: 0; }
.story__media img { display: block; width: 100%; height: 100%; min-height: 100%;
  border-radius: 20px; aspect-ratio: 5/4; object-fit: cover; object-position: center 50%;
  box-shadow: var(--shadow-lg); }
.story__media::after { /* a thin aqua "tide-line" edge under the photo */
  content: ""; position: absolute; left: 14px; right: 14px; bottom: -10px; height: 8px; border-radius: 8px;
  background: linear-gradient(90deg, var(--aqua), var(--gold)); opacity: .85; }
.story__tag { position: absolute; top: 14px; left: 14px; background: var(--ink); color: var(--paper);
  font-family: var(--sans); font-weight: 800; font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
  padding: .55em 1em; border-radius: 999px; }
.story__body h2 { font-size: var(--fs-h2); margin: .5rem 0 0; }
.story__body p { font-size: 1.12rem; color: var(--ink-soft); margin: 1rem 0 0; }
.story__since { display: inline-flex; align-items: baseline; gap: .5rem; margin-top: 1.3rem;
  font-family: var(--display); font-style: italic; font-size: 1.35rem; color: var(--accent); }

/* ===========================================================================
   MENU TEASER — a dockside "what to eat" board (no hardcoded prices)
   =========================================================================== */
.teaser__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.6rem, 4vw, 3rem); align-items: stretch; }
.teaser__grid > * { min-width: 0; }
.teaser__photo { position: relative; margin: 0; border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-lg);
  min-height: clamp(280px, 40vw, 440px); }
.teaser__photo img { position: absolute; inset: 0; display: block; width: 100%; height: 100%; min-height: 100%;
  object-fit: cover; object-position: center 45%; }
.teaser__photo figcaption { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  padding: 1.6rem 1.4rem .9rem; color: #fff; font-family: var(--sans); font-weight: 700; font-size: .9rem;
  background: linear-gradient(transparent, rgba(28,20,18,.86)); }
.teaser__board { background: var(--ink); color: var(--paper); border-radius: 20px;
  padding: clamp(1.4rem, 3.5vw, 2.2rem); display: flex; flex-direction: column;
  background-image: radial-gradient(110% 80% at 100% 0%, rgba(231,208,107,.16), transparent 55%); }
.teaser__board h3 { color: var(--paper); font-size: clamp(1.5rem,3.5vw,2.1rem); }
.teaser__board p { color: var(--muted-dark); margin: .6rem 0 1.1rem; }
.teaser__list { list-style: none; margin: 0 0 1.4rem; padding: 0; }
.teaser__list li { display: flex; align-items: baseline; gap: .6rem; padding: .65rem 0;
  border-bottom: 1px dashed var(--line-on-dark); }
.teaser__list .t-name { font-family: var(--display); font-weight: 600; font-size: 1.12rem; color: var(--paper); }
.teaser__list .t-tag { font-family: var(--sans); font-size: .76rem; font-weight: 700; letter-spacing: .04em;
  color: var(--gold); }
.teaser__list .t-dots { flex: 1; border-bottom: 1px dotted var(--muted-dark); transform: translateY(-3px); opacity: .6; }
.teaser__board .btn { align-self: flex-start; }

/* ===========================================================================
   LIVE MUSIC — "Tonight on the deck" lineup board
   ─ CANVAS band (.live-band: section head + feature photo) sits ABOVE the
     editable LIVE SLOT (section.live-music + .live-music__* frozen classes,
     ADR 0056). Both share the dusk ground so they read as one band; the slot
     re-renders on an owner edit, so all its look lives here on frozen classes.
   =========================================================================== */
/* canvas band wrappers — abut the slot (no seam) */
.live-band--head { padding-bottom: clamp(1.6rem,4vw,2.4rem); }
.live-band--note { padding-top: 0; padding-bottom: var(--section-y); }
.live__feature { position: relative; border-radius: 20px; overflow: hidden; min-height: clamp(240px, 36vw, 380px);
  display: flex; align-items: flex-end; box-shadow: var(--shadow-lg); margin: 0; }
.live__feature img { position: absolute; inset: 0; display: block; width: 100%; height: 100%; min-height: 100%;
  object-fit: cover; object-position: center 40%; }
.live__feature .live__fscrim { position: absolute; inset: 0; background: linear-gradient(transparent 30%, rgba(20,14,18,.9)); }
.live__feature .live__fcap { position: relative; z-index: 2; padding: 1.6rem 1.5rem 1.4rem; color: #fff; }
.live__feature .live__fcap h3 { color: #fff; font-size: clamp(1.4rem,3vw,2rem); }
.live__feature .live__fcap p { color: rgba(255,255,255,.9); margin: .35rem 0 0; max-width: 48ch; }
.live__note { margin: 0; font-size: .95rem; color: var(--muted-dark); }
.live__note a { color: var(--gold); font-weight: 700; }

/* the LIVE SLOT — full dusk section, themed entirely via the frozen classes */
.live-music { position: relative; padding: 0 0 clamp(1.6rem,4vw,2.4rem);
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(210,78,124,.22), transparent 60%),
    radial-gradient(90% 80% at 8% 0%, rgba(231,208,107,.14), transparent 55%),
    var(--ink);
  color: var(--paper); }
.live-music > * { width: min(var(--wrap), 100% - 2.5rem); margin-inline: auto; }
.live-music__intro { display: none; }  /* the canvas band carries the heading; the slot's intro is a redundant twin */
.live-music__shows { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.live-music__shows > * { min-width: 0; }
.live-music__show { background: var(--paper-3); border: 1px solid var(--line); border-radius: 18px;
  box-shadow: var(--shadow); display: flex; flex-direction: column; padding: 1rem 1.1rem 1.2rem;
  border-top: 4px solid var(--plate-rim, var(--gold)); }
.live-music__show:nth-child(3n+1) { --plate-rim: var(--aqua-deep); }
.live-music__show:nth-child(3n+2) { --plate-rim: var(--gold-deep); }
.live-music__show:nth-child(3n+3) { --plate-rim: var(--pink); }
.live-music__head { display: flex; align-items: baseline; flex-wrap: wrap; gap: .5rem .7rem; }
.live-music__act { font-family: var(--display); font-weight: 600; font-size: 1.18rem; color: var(--ink); }
.live-music__when { margin: .55rem 0 0; font-family: var(--sans); font-weight: 700; font-size: .82rem;
  color: var(--muted); display: flex; align-items: baseline; gap: .35rem; }
.live-music__cover { color: var(--accent); }
.live-music__desc { color: var(--ink-soft); font-size: .92rem; margin: .5rem 0 0; }
.live-music__links { margin-top: .7rem; display: flex; flex-wrap: wrap; gap: .5rem; }
.live-music__link { font-weight: 700; font-size: .82rem; color: var(--accent); }

/* ===========================================================================
   SPECIALS — tiki / chalk board (editable LIVE SLOT, frozen specials__* / ADR 0056)
   ─ section.specials re-renders on an owner edit, so EVERY bit of the look lives
     here on the frozen classes; each .specials__item is a tiki/chalk board card.
   =========================================================================== */
.specials { padding: var(--section-y) 0; position: relative; }
.specials > * { width: min(var(--wrap), 100% - 2.5rem); margin-inline: auto; }
.specials__intro { max-width: 62ch; margin-bottom: clamp(1.8rem, 4vw, 2.8rem); }
.specials__intro h2 { font-size: var(--fs-h2); margin: 0; }
.specials__lede { font-size: var(--fs-lede); color: var(--ink-soft); margin: .7rem 0 0; max-width: 60ch; }
.specials__list { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.specials__list > * { min-width: 0; }
/* each special is a chalk/tiki board card */
.specials__item { position: relative; border-radius: 18px; padding: clamp(1.3rem,3vw,1.8rem);
  background:
    repeating-linear-gradient(135deg, rgba(243,241,230,.018) 0 8px, transparent 8px 16px),
    #20211C;
  color: var(--paper); border: 2px solid rgba(231,208,107,.35); box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column; }
.specials__item::before { /* a thin tiki-bamboo top edge */
  content: ""; position: absolute; inset: 8px 8px auto 8px; height: 4px; border-radius: 4px;
  background: linear-gradient(90deg, var(--aqua), var(--gold), var(--pink)); opacity: .9; }
.specials__top { display: flex; align-items: baseline; gap: .7rem; margin-top: .35rem; }
.specials__name { font-family: var(--display); font-weight: 600; font-size: 1.32rem; color: #fff; }
.specials__dots { flex: 1; border-bottom: 1px dashed rgba(243,241,230,.22); transform: translateY(-4px); }
.specials__deal { font-family: var(--display); font-weight: 600; font-size: 1.5rem; color: var(--gold); white-space: nowrap; }
.specials__when { display: flex; align-items: center; flex-wrap: wrap; gap: .5rem;
  font-family: var(--sans); font-weight: 700; font-size: .82rem; color: var(--aqua); margin: .5rem 0 0; }
.specials__desc { color: rgba(243,241,230,.82); font-size: .92rem; margin: .7rem 0 0; }
/* Margarita Monday — the feature board (targeted by its STABLE renderer id, not a bespoke class).
   Equal-size card (6 = two tidy rows of 3) but visually the feature via the pink wash + bigger deal. */
#margarita-monday.specials__item {
  background:
    repeating-linear-gradient(135deg, rgba(243,241,230,.02) 0 8px, transparent 8px 16px),
    linear-gradient(160deg, #6E2546, #20211C 70%);
  border-color: rgba(210,78,124,.5); }
#margarita-monday .specials__deal { font-size: clamp(1.5rem,4vw,1.9rem); }
.specials__disclaimer { margin: clamp(1.4rem,3vw,2rem) 0 0; font-size: .82rem; color: var(--muted); }

/* shared chip — the frozen category/genre tag on specials + live-music (and the
   menu's diet tags). Default reads on LIGHT cards (the cream live-music cards);
   overridden inside the dark .specials__item below. */
.tag { display: inline-flex; align-items: center; font-family: var(--sans); font-weight: 800;
  font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; line-height: 1;
  padding: .32em .6em; border-radius: 999px; white-space: nowrap; }
.tag-other { background: color-mix(in srgb, var(--accent) 12%, transparent); color: var(--accent); }
.live-music__genre.tag { margin-left: .1rem; }
.specials__category.tag-other { background: rgba(231,208,107,.16); color: var(--gold); }

/* ===========================================================================
   ORDER — sheet (order.js) base contract + concept skin
   =========================================================================== */
.order-band { text-align: center; }
.order-band .section-head { margin-inline: auto; }
.order-band__cta { display: flex; flex-wrap: wrap; gap: .9rem; justify-content: center; margin-top: 1.6rem; }
.order-band__channels { margin-top: 1.4rem; font-size: .95rem; color: var(--muted-dark); }

html.order-locked { overflow: hidden; }
.order-sheet { position: fixed; inset: 0; z-index: 80; display: flex; align-items: flex-end; justify-content: center; visibility: hidden; }
.order-sheet[data-open] { visibility: visible; }
.order-sheet__scrim { position: absolute; inset: 0; background: rgba(20,14,12,.55); opacity: 0; transition: opacity .22s ease; }
.order-sheet[data-open] .order-sheet__scrim { opacity: 1; }
.order-sheet__panel { position: relative; width: min(34rem, 100%); max-height: 86vh;
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--paper-3); color: var(--ink);
  border-radius: var(--order-radius) var(--order-radius) 0 0;
  border-top: 5px solid var(--cta);
  transform: translateY(100%); transition: transform .24s cubic-bezier(.4,0,.2,1); }
.order-sheet[data-open] .order-sheet__panel { transform: translateY(0); }
@media (min-width: 640px) {
  .order-sheet { align-items: center; }
  .order-sheet__panel { border-radius: var(--order-radius); border-top: 5px solid var(--cta);
    transform: translateY(12px) scale(.98); transition: transform .2s ease, opacity .2s ease; opacity: 0; }
  .order-sheet[data-open] .order-sheet__panel { transform: none; opacity: 1; }
}
.order-sheet__head { flex: 0 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: clamp(1.2rem,4vw,1.6rem) clamp(1.2rem,4vw,1.6rem) .8rem; }
.order-sheet__title { font-family: var(--display); font-size: 1.4rem; margin: 0; color: var(--ink); }
.order-sheet__close { width: 42px; height: 42px; border: 0; border-radius: 999px; background: var(--line-soft);
  color: var(--ink); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.order-sheet__close:hover { background: var(--line); }
.order-list { flex: 1 1 auto; overflow-y: auto; -webkit-overflow-scrolling: touch; list-style: none; margin: 0;
  padding: .25rem clamp(1.2rem,4vw,1.6rem) calc(1.4rem + env(safe-area-inset-bottom));
  display: flex; flex-direction: column; gap: .55rem; }
.order-row__link { display: flex; align-items: center; gap: .85rem; padding: .8rem .85rem;
  border: 1px solid var(--line); border-radius: 14px; text-decoration: none; color: inherit; background: #fff; }
.order-row__link:hover { border-color: var(--cta); background: var(--line-soft); }
.order-row__icon { flex: 0 0 auto; width: 44px; height: 44px; border-radius: 12px; background: #fff;
  color: var(--brand, var(--accent)); border: 1px solid var(--line);
  display: inline-flex; align-items: center; justify-content: center; overflow: hidden; }
.order-row__icon svg { width: auto; height: auto; max-width: 60%; max-height: 60%; }
.order-row__body { display: flex; flex-direction: column; gap: .12rem; min-width: 0; }
.order-row__name { font-weight: 800; font-family: var(--sans); }
.order-row__meta { font-size: .85rem; color: var(--muted); }
@media (prefers-reduced-motion: reduce) { .order-sheet__panel, .order-sheet__scrim { transition: none; } }

/* ===========================================================================
   GALLERY — dockside lineup marquee + lightbox (gallery.js base contract)
   =========================================================================== */
.marquee { position: relative; overflow: hidden; }
.marquee--static { overflow-x: auto; scrollbar-width: thin; }
.marquee__track { display: flex; gap: 0; margin: 0; padding: 0; list-style: none; width: max-content; }
.marquee--animated .marquee__track { animation: ph-marquee var(--marquee-speed, 64s) linear infinite; }
.marquee--animated:hover .marquee__track,
.marquee--animated:focus-within .marquee__track { animation-play-state: paused; }
.marquee__item { flex: 0 0 auto; padding: 0 calc(var(--gap, 1rem) / 2); }
.ph-btn { display: block; padding: 0; border: 0; background: none; cursor: zoom-in; border-radius: 16px; }
/* concept: each photo is a bright "deck plank" frame with a rotating color rim */
.gallery .ph-btn img { width: clamp(240px, 30vw, 360px); aspect-ratio: 4/3; object-fit: cover; border-radius: 16px;
  box-shadow: var(--shadow), inset 0 0 0 5px var(--plate-rim, var(--aqua)); transition: box-shadow var(--ph-ease); }
.gallery .marquee__item:nth-child(3n+1) .ph-btn img { --plate-rim: var(--aqua); }
.gallery .marquee__item:nth-child(3n+2) .ph-btn img { --plate-rim: var(--gold); }
.gallery .marquee__item:nth-child(3n+3) .ph-btn img { --plate-rim: var(--pink); }
.marquee--animated .ph-btn:hover img { box-shadow: var(--shadow-lg), inset 0 0 0 5px #fff; }
@keyframes ph-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee--animated .marquee__track { animation: none; } }
.gallery__hint { margin-top: 1.1rem; font-size: .9rem; color: var(--muted); }

html.ph-lock, html.ph-lock body { overflow: hidden; }
.ph-lightbox[aria-hidden="true"] { display: none; }
.ph-lightbox { position: fixed; inset: 0; z-index: 100; display: flex; align-items: center; justify-content: center; }
.ph-lightbox__backdrop { position: absolute; inset: 0; background: rgba(18,13,14,.92); }
.ph-lightbox__dialog { position: relative; display: flex; align-items: center; justify-content: center; gap: .5rem; max-width: min(94vw, 1100px); }
.ph-lightbox__figure { margin: 0; }
.ph-lightbox__prev, .ph-lightbox__next { position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; }
.ph-lightbox__prev { left: .5rem; }
.ph-lightbox__next { right: .5rem; }
.ph-lightbox__img { max-width: 84vw; max-height: 80vh; width: auto; height: auto; border-radius: 12px; display: block; }
.ph-lightbox__cap { color: #fff; font-family: var(--sans); font-size: .92rem; text-align: center; margin-top: .7rem; opacity: .92; }
.ph-lightbox__btn { background: rgba(255,255,255,.14); color: #fff; border: 0; cursor: pointer; width: 46px; height: 46px;
  border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; }
.ph-lightbox__btn:hover { background: rgba(255,255,255,.28); }
.ph-lightbox__btn svg { width: 1.4rem; height: 1.4rem; }
.ph-lightbox__close { position: absolute; top: -3.2rem; right: 0; }
@media (max-width: 600px) { .ph-lightbox__close { top: -2.8rem; } .ph-lightbox__img { max-width: 92vw; } }

/* ===========================================================================
   "FROM THE DOCK" reputation band (honest social proof — NO fabricated reviews)
   =========================================================================== */
.rep { position: relative; overflow: hidden; }
.rep__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.rep__grid > * { min-width: 0; }
.rep__media { position: relative; margin: 0; border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-lg);
  min-height: clamp(260px, 38vw, 400px); }
.rep__media img { position: absolute; inset: 0; display: block; width: 100%; height: 100%; min-height: 100%;
  object-fit: cover; object-position: center 40%; }
.rep__quote { font-family: var(--display); font-size: clamp(1.5rem, 3vw, 2.05rem); line-height: 1.3; color: var(--paper);
  margin: .6rem 0 0; }
.rep__quote .q-mark { color: var(--gold); }
.rep__sub { color: var(--muted-dark); margin: 1.1rem 0 0; }
.rep__facts { display: flex; flex-wrap: wrap; gap: 1.4rem 2.2rem; margin: 1.6rem 0 0; list-style: none; padding: 0; }
.rep__facts li { min-width: 0; }
.rep__facts .n { display: block; font-family: var(--display); font-size: clamp(1.6rem,3.5vw,2.2rem); color: var(--gold); line-height: 1; }
.rep__facts .l { display: block; font-family: var(--sans); font-weight: 700; font-size: .82rem; color: var(--paper);
  margin-top: .35rem; }

/* ===========================================================================
   CONNECT — stay connected (connect.js base contract)
   =========================================================================== */
.connect__inner { display: flex; flex-wrap: wrap; gap: clamp(1rem,4vw,2.5rem); align-items: center; justify-content: space-between; }
.connect__copy { max-width: 36rem; }
.connect__copy h2 { font-family: var(--display); font-size: clamp(1.7rem,5vw,2.5rem); margin: .4rem 0 .5rem; }
.connect__copy p { color: var(--ink-soft); margin: 0; }
.connect__actions { display: flex; flex-wrap: wrap; gap: .7rem; align-items: center; }
.connect__follow { display: flex; flex-wrap: wrap; gap: .7rem; }
/* follow buttons are the frozen .social-link (single-sourced); the share button keeps .connect__btn */
.connect__actions .social-link,
.connect__btn { display: inline-flex; align-items: center; gap: .55rem; padding: .85rem 1.25rem; min-height: 48px;
  border: 2px solid var(--line); border-radius: 999px; background: var(--paper-3); color: var(--ink);
  font: inherit; font-weight: 800; text-decoration: none; cursor: pointer; }
.connect__actions .social-link:hover,
.connect__btn:hover { border-color: var(--cta); color: var(--cta); }
.connect__actions .social-link .icon,
.connect__btn .icon { width: 1.25em; height: 1.25em; }
.connect__done { font-size: .8rem; color: var(--muted); }

/* ===========================================================================
   VISIT / HOURS — hours table + contact + map link
   =========================================================================== */
.visit__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: start; }
.visit__grid > * { min-width: 0; }
.hours-table { width: 100%; border-collapse: collapse; font-size: 1.06rem; }
.hours-table td { padding: .6rem 0; border-bottom: 1px solid var(--line-on-dark); }
.hours-table td:first-child { font-family: var(--sans); font-weight: 700; letter-spacing: .03em; color: var(--paper); }
.hours-table td:last-child { text-align: right; color: var(--muted-dark); font-variant-numeric: tabular-nums; }
.hours-table tr.today td:first-child { color: var(--gold); }
.hours-table tr.today td:last-child { color: var(--gold); }
.hours-table tr.today td:first-child::after { content: " · today"; font-size: .7rem; color: var(--gold); letter-spacing: .08em; }
.visit h3 { color: var(--paper); font-size: var(--fs-h3); margin-bottom: 1rem; }
.contact-lines { list-style: none; padding: 0; margin: 0 0 1.5rem; font-size: 1.06rem; }
.contact-lines li { padding: .55rem 0; border-bottom: 1px solid var(--line-on-dark); display: flex; gap: .8rem; }
.contact-lines .k { font-family: var(--sans); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--gold); min-width: 80px; padding-top: .35em; }
.contact-lines a, .contact-lines span.v { text-decoration: none; color: var(--paper); }
.contact-lines a:hover { color: var(--aqua); text-decoration: underline; }
.visit__cta { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: .4rem; }
.visit .btn--outline { border-color: var(--aqua); color: var(--aqua); }
.visit .btn--outline:hover { background: var(--aqua); color: var(--ink); }
.visit__noresv { margin-top: 1.4rem; font-size: .92rem; color: var(--muted-dark); }

/* ===========================================================================
   FOOTER
   =========================================================================== */
.site-footer { background: #20211C; color: rgba(243,241,230,.8); padding: clamp(3rem,7vw,4.5rem) 0 2rem; position: relative; }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 2.2rem; }
.footer__grid > * { min-width: 0; }
.f-brand { display: flex; align-items: center; gap: .7rem; margin-bottom: .8rem; }
.f-brand img { height: 52px; width: auto; }
.site-footer p { color: rgba(243,241,230,.72); }
.site-footer h4 { font-family: var(--sans); text-transform: uppercase; letter-spacing: .16em; font-size: .72rem;
  color: var(--gold); margin: 0 0 1rem; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin-bottom: .5rem; }
.site-footer a { color: rgba(243,241,230,.8); text-decoration: none; }
.site-footer a:hover { color: var(--aqua); }
.f-social { display: flex; gap: .6rem; margin-top: 1rem; }
.f-social .social-link { width: 44px; height: 44px; border-radius: 999px; border: 1px solid var(--line-on-dark);
  display: inline-flex; align-items: center; justify-content: center; color: var(--paper); }
.f-social .social-link:hover { border-color: var(--gold); color: var(--gold); }
.f-social .icon { width: 1.25rem; height: 1.25rem; }
.f-bottom { border-top: 1px solid var(--line-on-dark); margin-top: 2.6rem; padding-top: 1.4rem;
  font-size: .78rem; color: rgba(243,241,230,.5); display: flex; justify-content: space-between; flex-wrap: wrap; gap: .5rem; }

/* ===========================================================================
   SCROLL-REVEAL (motion.md §scroll-reveal contract — golden-hour-reveal)
   =========================================================================== */
[data-reveal] { opacity: 1; transform: none; }
[data-reveal].reveal-armed { opacity: 0; transform: translateY(var(--reveal-rise, 24px)); }
[data-reveal].is-revealed { opacity: 1; transform: none;
  transition: opacity var(--reveal-dur, .8s) var(--reveal-ease, ease),
              transform var(--reveal-dur, .8s) var(--reveal-ease, ease); }
[data-reveal-stagger] [data-reveal].is-revealed { transition-delay: calc(var(--reveal-i, 0) * var(--reveal-stagger, .09s)); }
@media (prefers-reduced-motion: reduce) {
  [data-reveal], [data-reveal].reveal-armed, [data-reveal].is-revealed {
    opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ===========================================================================
   MENU PAGE (menu-page base contract + concept skin) — dockside menu board
   =========================================================================== */
.menu-hero { background: var(--ink); color: var(--paper); padding: clamp(2.4rem,6vw,4rem) 0 clamp(2rem,5vw,3rem);
  position: relative; overflow: hidden;
  background-image:
    radial-gradient(120% 80% at 85% 0%, rgba(210,78,124,.28), transparent 55%),
    radial-gradient(90% 70% at 0% 100%, rgba(91,183,162,.22), transparent 55%); }
.menu-hero .eyebrow { color: var(--gold); }
.menu-hero h1 { font-size: clamp(2.4rem,6vw,4rem); margin: .4rem 0 .3rem; color: var(--paper); }
.menu-hero p { color: var(--muted-dark); max-width: 60ch; margin: 0; }
.menu-hero__actions { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 1.4rem; }
.menu-hero .btn--ghost { border-color: rgba(243,241,230,.6); }

.menu-nav { position: sticky; top: var(--header-h); z-index: 40;
  background: color-mix(in srgb, var(--paper) 95%, transparent);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line); padding: .6rem 0; }
.menu-section, [id].menu-section {
  scroll-margin-top: calc(var(--header-h) + var(--menu-nav-h, 56px) + .6rem); }
.menu-nav .wrap { display: flex; gap: .4rem; overflow-x: auto; scrollbar-width: none; }
.menu-nav .wrap::-webkit-scrollbar { display: none; }
.menu-nav a { flex: 0 0 auto; white-space: nowrap; padding: .4em .9em; border-radius: 999px; text-decoration: none;
  font-family: var(--sans); font-size: .82rem; font-weight: 700; color: var(--muted);
  min-height: 44px; display: inline-flex; align-items: center; }
.menu-nav a:hover { background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--accent); }
.menu-nav a:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; }
.menu-nav a.is-active { background: var(--cta); color: #fff; }

.menu-nav__arrow { flex: 0 0 auto; width: 44px; height: 44px; display: none;
  align-items: center; justify-content: center; align-self: center; margin: 0 var(--pad-x);
  border: 1px solid var(--line); border-radius: 999px;
  background: color-mix(in srgb, var(--paper) 80%, transparent); color: var(--accent);
  cursor: pointer; -webkit-tap-highlight-color: transparent; }
.menu-nav--scrollable { display: flex; align-items: stretch; }
.menu-nav--scrollable .wrap { flex: 1 1 auto; min-width: 0; order: 0; }
.menu-nav--scrollable .menu-nav__arrow { display: inline-flex; }
.menu-nav__arrow--prev { order: -1; margin-right: .35rem; }
.menu-nav__arrow--next { order: 1; margin-left: .35rem; }
.menu-nav__arrow svg { width: 22px; height: 22px; }
.menu-nav__arrow:hover:not(:disabled) { background: color-mix(in srgb, var(--accent) 12%, var(--paper)); }
.menu-nav__arrow:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; }
.menu-nav__arrow:disabled { opacity: .3; cursor: default; }
@media (prefers-reduced-motion: reduce) { .menu-nav .wrap { scroll-behavior: auto; } }

.menu-body { padding: clamp(2.4rem,5vw,4rem) 0 clamp(3rem,7vw,5rem); }
.menu-intro-note { max-width: 70ch; margin: 0 auto clamp(2rem,4vw,3rem); color: var(--muted);
  font-size: .95rem; text-align: center; }
.menu-section { margin-bottom: clamp(2.6rem,5vw,3.6rem); padding-inline: clamp(1.5rem,5vw,2.5rem); }
.menu-section__head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; max-width: var(--menu-measure, 860px); }
.menu-section__head h2 { font-size: var(--fs-h2); color: var(--accent); white-space: nowrap; margin: 0; min-width: 0; }
.menu-section__note { font-size: .88rem; color: var(--muted); margin: -.6rem 0 1.2rem; max-width: var(--menu-measure,860px); }
.menu-list { display: grid; grid-template-columns: 1fr 1fr; gap: .3rem 3rem; max-width: 1100px; }
.menu-row { padding: .75rem 0; border-bottom: 1px dotted var(--line); }
.menu-row__top { display: flex; align-items: baseline; gap: .6rem; }
.menu-row__name { font-family: var(--display); font-weight: 600; color: var(--ink); }
.menu-row__dots { flex: 1; border-bottom: 1px dotted var(--muted); transform: translateY(-3px); opacity: .5; }
.menu-row__price { font-family: var(--sans); font-weight: 800; color: var(--accent);
  font-variant-numeric: tabular-nums; white-space: nowrap; }
.menu-row__price--mp { color: var(--muted); font-weight: 700; font-style: italic; font-size: .92rem; }
.menu-row__desc { margin: .25rem 0 0; font-size: .94rem; color: var(--ink-soft); max-width: 62ch; }

.menu-cta-band { background: var(--paper-2); padding: clamp(2.4rem,5vw,3.6rem) 0; text-align: center; }
.menu-cta-band .connect__inner { justify-content: center; text-align: center; }
.menu-cta-band .connect__copy { max-width: 40rem; }

/* ===========================================================================
   RESPONSIVE
   =========================================================================== */
@media (max-width: 860px) {
  .story { grid-template-columns: 1fr; }
  .story__media { max-width: 520px; }
  .teaser__grid { grid-template-columns: 1fr; }
  .specials__list { grid-template-columns: repeat(2, 1fr); }
  .live-music__shows { grid-template-columns: repeat(2, 1fr); }
  .rep__grid { grid-template-columns: 1fr; }
  .visit__grid { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .menu-list { grid-template-columns: 1fr; gap: 0; }
}
@media (max-width: 640px) {
  /* image grids STAY multi-column (operator rule): plates/lineup/gallery -> 2-up, never 1 */
  .plates { grid-template-columns: repeat(2, 1fr); }
  .live-music__shows { grid-template-columns: repeat(2, 1fr); }
  /* specials: the chalk-board cards carry a price + when-line, so single-column reads
     cleaner than a cramped 2-up on a phone. */
  .specials__list { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .menu-section__head h2 { font-size: clamp(1.35rem,5.2vw,1.9rem); white-space: normal; }
}
