/* ============================================================
   HOOKED SEAFOOD BISTRO — Frontend Stylesheet
   Palette: #fdfdfd · #c1cfce · #abbebc · #6c9e9d · #679b9c · #3d6569
   NO brown. Admin-matched feel.
   ============================================================ */

:root {
  --w:    #fdfdfd;
  --s1:   #c1cfce;
  --s2:   #abbebc;
  --t1:   #6c9e9d;
  --t2:   #679b9c;
  --dk:   #3d6569;
  --text: #2c1f1a;        /* warm dark brown for body text */
  --muted:#5a4a44;        /* muted warm brown for secondary text */
  --r:    #c0392b;        /* accent red — kept only for price/cta */
  --g:    #c9a035;        /* gold — kept for featured labels */
  --brown:#1e4a4d;        /* deep teal — footer */
  --nav-h:70px;
  --font-display: 'Bebas Neue', cursive;
  --font-serif:   'Playfair Display', serif;
  --font-body:    'Montserrat', sans-serif;
  --shadow-sm: 0 2px 8px rgba(61,101,105,.1);
  --shadow-md: 0 4px 20px rgba(61,101,105,.16);
  --shadow-lg: 0 8px 40px rgba(61,101,105,.22);
  --ease: 0.22s ease;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body { font-family:var(--font-body); color:var(--text); overflow-x:hidden; background:var(--w); margin:0; padding:0; width:100%; }
img  { display:block; max-width:100%; }
a    { color:inherit; }

/* ── SEAFOOD BG TEXTURE — fixed so it shows through all sections ── */
.seafood-bg {
  position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.18;
  background-image:url('/assets/img/seafood-sketches.svg');
  background-size:100vw auto;
  background-repeat:repeat-y;
}
/* Section-level seafood bg adjustments — match reference */
.bg-white  .seafood-bg-section { opacity:.18; }
.bg-sage1  .seafood-bg-section { opacity:.16; }
.bg-sage2  .seafood-bg-section { opacity:.16; }
.bg-teal1  .seafood-bg-section { opacity:.25; filter:invert(1) brightness(2); }
.bg-teal2  .seafood-bg-section { opacity:.25; filter:invert(1) brightness(2); }
.bg-dark   .seafood-bg-section { opacity:.25; filter:invert(1) brightness(2); }

/* ── NAV ── */
#site-nav {
  position:fixed; top:0; left:0; right:0; z-index:800;
  height:var(--nav-h); display:flex; align-items:center;
  justify-content:space-between; padding:0 2rem;
  background:var(--dk); border-bottom:2px solid rgba(193,207,206,.25);
  transition:box-shadow var(--ease);
}
#site-nav.scrolled { box-shadow:0 4px 24px rgba(61,101,105,.4); }

.n-brand { display:flex; align-items:center; gap:11px; text-decoration:none; }
.n-logo  { width:44px; height:44px; object-fit:cover; border-radius:50%;
           background:var(--w); filter:drop-shadow(0 2px 6px rgba(0,0,0,.3));
           transition:transform .3s ease; }
.n-logo:hover { animation:waveBob .6s ease; }
.n-text b    { font-family:var(--font-display); font-size:1.22rem; color:var(--w);
               letter-spacing:.08em; display:block; line-height:1; }
.n-text span { font-size:.48rem; font-weight:700; letter-spacing:.2em;
               text-transform:uppercase; color:var(--s2); display:block; }

.n-links { display:flex; align-items:center; list-style:none; }
.n-links > li > a {
  display:flex; align-items:center; gap:5px; height:var(--nav-h); padding:0 11px;
  font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(253,253,253,.68); text-decoration:none;
  transition:color var(--ease), background var(--ease); white-space:nowrap;
}
.n-links > li > a:hover,
.n-links > li > a.active { color:var(--s1); background:rgba(193,207,206,.1); }

/* Cart nav item */
.n-cart {
  position:relative; display:flex; align-items:center;
  height:var(--nav-h); padding:0 11px; cursor:pointer;
  color:rgba(253,253,253,.68); text-decoration:none;
  font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  transition:color var(--ease);
}
.n-cart:hover { color:var(--s1); }
.cart-bubble {
  background:var(--r); color:#fff; font-size:.52rem; font-weight:700;
  min-width:16px; height:16px; border-radius:8px; padding:0 4px;
  display:inline-flex; align-items:center; justify-content:center;
  margin-left:4px; line-height:1;
}

/* Order CTA button in nav */
.n-cta {
  background:var(--t1) !important; color:var(--w) !important;
  height:36px !important; padding:0 20px !important; margin-left:8px;
  border-radius:2px; font-size:.64rem !important; letter-spacing:.14em !important;
  transition:filter var(--ease), transform var(--ease) !important;
}
.n-cta:hover { filter:brightness(1.1) !important; transform:translateY(-1px) !important; }

.hbg-btn { display:none; flex-direction:column; gap:5px;
           background:none; border:none; cursor:pointer; padding:4px; }
.hbg-btn span { display:block; width:24px; height:2px; background:var(--w);
               border-radius:1px; transition:all .3s; }

/* ── LAYOUT ── */
.sec  { padding:90px 2rem; position:relative; z-index:1; }
.wrap { max-width:1140px; margin:0 auto; }

/* ── BACKGROUNDS — teal/sage palette only ── */
.bg-w     { background:var(--w); }
.bg-white { background:rgba(253,253,253,.92); }
.bg-light { background:#f0f5f5; }
.bg-sage1 { background:rgba(193,207,206,.88); } /* #c1cfce */
.bg-sage2 { background:rgba(171,190,188,.88); } /* #abbebc */
.bg-teal1 { background:rgba(108,158,157,.92); } /* #6c9e9d */
.bg-teal2 { background:rgba(103,155,156,.92); } /* #679b9c */
.bg-dark  { background:rgba(61,101,105,.96);  } /* #3d6569 */
.bg-dk    { background:var(--dk); }
.bg-ink   { background:rgba(55,44,41,.97);    } /* keep for footer */

/* ── LABELS ── */
.lbl {
  display:flex; align-items:center; gap:12px;
  font-size:.58rem; font-weight:700; letter-spacing:.28em; text-transform:uppercase;
  margin-bottom:.5rem;
}
.lbl::before { content:''; width:24px; height:1px; flex-shrink:0; }
.lbl::after  { content:''; flex:1; height:1px; }
.lbl-dk   { color:var(--dk); }
.lbl-dk::before, .lbl-dk::after { background:var(--dk); opacity:.35; }
.lbl-w    { color:var(--s1); }
.lbl-w::before, .lbl-w::after { background:var(--s1); opacity:.5; }
.lbl-t1   { color:var(--t1); }
.lbl-t1::before, .lbl-t1::after { background:var(--t1); opacity:.5; }
.lbl-c { justify-content:center; }
.lbl-c::before, .lbl-c::after { flex:1; }

/* ── HEADINGS ── */
.h2 { font-family:var(--font-display); font-size:clamp(2.2rem,5vw,3.6rem);
      line-height:.95; letter-spacing:.03em; }
.h2-dk  { color:var(--dk); }
.h2-dk em { font-family:var(--font-serif); font-style:italic;
            color:var(--t2); font-size:.85em; }
.h2-w   { color:var(--w); }
.h2-w em { font-family:var(--font-serif); font-style:italic;
           color:var(--s1); font-size:.85em; }

/* ── BUTTONS ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  background:var(--dk); color:var(--w); padding:13px 32px;
  font-family:var(--font-display); font-size:.95rem; letter-spacing:.13em;
  border:none; cursor:pointer; border-radius:2px;
  clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%);
  transition:filter var(--ease), transform var(--ease);
  box-shadow:var(--shadow-sm);
}
.btn-primary:hover { filter:brightness(1.12); transform:translateY(-2px); }

.btn-teal {
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  background:var(--t1); color:var(--w); padding:13px 32px;
  font-family:var(--font-display); font-size:.95rem; letter-spacing:.13em;
  border:none; cursor:pointer; border-radius:2px;
  clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%);
  transition:filter var(--ease), transform var(--ease);
}
.btn-teal:hover { filter:brightness(1.1); transform:translateY(-2px); }

.btn-outline {
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  border:2px solid var(--dk); color:var(--dk); padding:11px 30px;
  font-family:var(--font-display); font-size:.9rem; letter-spacing:.12em;
  background:transparent; cursor:pointer; border-radius:2px;
  clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
  transition:all var(--ease);
}
.btn-outline:hover { background:var(--dk); color:var(--w); }

.btn-outline-w {
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  border:2px solid rgba(255,255,255,.5); color:var(--w); padding:11px 30px;
  font-family:var(--font-display); font-size:.9rem; letter-spacing:.12em;
  background:transparent; cursor:pointer; border-radius:2px;
  clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
  transition:all var(--ease);
}
.btn-outline-w:hover { border-color:var(--s1); color:var(--s1); transform:translateY(-2px); }

/* ── TICKER ── */
.ticker {
  border-top:2px solid var(--t1); border-bottom:2px solid var(--t1);
  padding:10px 0; overflow:hidden; position:relative; z-index:1;
  background:var(--brown);
}
.t-track { display:inline-flex; white-space:nowrap; animation:tick 36s linear infinite; }
.ti { display:inline-flex; align-items:center; gap:12px; padding:0 24px;
      font-family:var(--font-display); font-size:.84rem; letter-spacing:.13em;
      color:rgba(255,255,255,.88); }
.td { width:5px; height:5px; background:var(--t1); border-radius:50%; flex-shrink:0; }

/* ── FORMS ── */
.fg { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.fg label { font-size:.58rem; font-weight:700; letter-spacing:.16em;
            text-transform:uppercase; color:var(--dk); }
.fg input, .fg select, .fg textarea {
  border:1.5px solid var(--s2); background:var(--w);
  border-radius:3px; padding:11px 13px; font-family:var(--font-body);
  font-size:.84rem; color:var(--text); outline:none;
  transition:border-color var(--ease), box-shadow var(--ease);
}
.fg input:focus, .fg select:focus, .fg textarea:focus {
  border-color:var(--t1); box-shadow:0 0 0 3px rgba(108,158,157,.15);
}
.fg textarea { resize:vertical; min-height:90px; }
.fg-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

.form-submit {
  width:100%; border:none; cursor:pointer;
  background:linear-gradient(110deg, var(--dk) 0%, var(--t1) 100%);
  color:var(--w); padding:15px; font-family:var(--font-display);
  font-size:1rem; letter-spacing:.14em; border-radius:2px;
  clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
  transition:filter var(--ease), transform var(--ease);
  box-shadow:0 4px 16px rgba(61,101,105,.3);
}
.form-submit:hover   { filter:brightness(1.1); transform:translateY(-2px); }
.form-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }

/* ── ALERTS ── */
.alert { padding:12px 16px; border-radius:3px; font-size:.82rem; font-weight:600; margin-bottom:16px; }
.alert-success { background:rgba(61,101,105,.1);  border-left:4px solid var(--dk); color:var(--dk); }
.alert-error   { background:rgba(192,57,43,.08);  border-left:4px solid var(--r);  color:#7f1c14; }
.alert-info    { background:rgba(108,158,157,.12); border-left:4px solid var(--t1); color:var(--dk); }

/* ── TOAST ── */
.toast {
  position:fixed; bottom:2rem; right:2rem; z-index:9000;
  background:var(--dk); color:var(--w); padding:14px 20px;
  font-size:.8rem; font-weight:600; max-width:320px; border-radius:3px;
  box-shadow:var(--shadow-lg); display:none;
  border-left:3px solid var(--t1);
}
.toast.show { display:block; animation:riseUp .3s ease; }
.toast.toast-error { border-left-color:var(--r); }

/* ── REVEAL ── */
.rv { opacity:0; transform:translateY(22px); transition:opacity .65s ease, transform .65s ease; }
.rv.vis { opacity:1; transform:none; }

/* ── PAGE HERO (inner pages) ── */
.page-hero {
  min-height:300px; display:flex; align-items:flex-end;
  position:relative; overflow:hidden;
  padding:calc(var(--nav-h) + 48px) 2rem 48px;
}
.page-hero-bg {
  position:absolute; inset:0; background-size:cover; background-position:center;
  filter:brightness(.38) saturate(1.1);
}
.page-hero-ov {
  position:absolute; inset:0;
  background:linear-gradient(160deg, rgba(61,101,105,.75) 0%, rgba(42,74,77,.9) 100%);
}
.page-hero-inner { position:relative; z-index:2; }

.breadcrumb {
  display:flex; align-items:center; gap:7px; margin-bottom:1rem;
  font-size:.58rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.38);
}
.breadcrumb a { color:rgba(255,255,255,.38); text-decoration:none; transition:color var(--ease); }
.breadcrumb a:hover { color:var(--s1); }
.breadcrumb span { color:rgba(255,255,255,.2); }

/* ── MENU ITEM CARD ── */
.menu-item {
  background:var(--w); border:1px solid rgba(171,190,188,.3);
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:12px; padding:16px 18px;
  transition:background var(--ease), border-color var(--ease);
}
.menu-item:hover { background:#f0f5f5; border-color:var(--s2); }
.menu-item-name  { font-size:.84rem; font-weight:600; color:var(--dk); line-height:1.3; }
.menu-item-desc  { font-size:.72rem; color:var(--muted); margin-top:3px; line-height:1.5; }
.menu-item-price { font-family:var(--font-display); font-size:1rem; color:var(--dk);
                   white-space:nowrap; flex-shrink:0; }
.menu-item-price.sold-out { color:var(--muted); text-decoration:line-through; }

/* ── ADD TO CART BUTTON (menu items) ── */
.btn-add {
  background:var(--t1); color:var(--w); border:none; padding:6px 14px;
  font-family:var(--font-display); font-size:.7rem; letter-spacing:.08em;
  cursor:pointer; border-radius:2px; transition:filter var(--ease), transform var(--ease);
  white-space:nowrap;
}
.btn-add:hover { filter:brightness(1.1); transform:translateY(-1px); }

/* ── CART SIDEBAR ── */
#cartSidebar {
  position:fixed; top:0; right:0; bottom:0; width:min(380px,100vw);
  background:var(--w); border-left:2px solid var(--s2);
  z-index:900; transform:translateX(100%);
  transition:transform .35s ease; box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column;
}
#cartSidebar.open { transform:translateX(0); }
.cart-header {
  background:var(--dk); color:var(--w); padding:18px 20px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:2px solid var(--t1);
}
.cart-header h3 { font-family:var(--font-display); font-size:1.2rem; letter-spacing:.08em; }
.cart-body  { flex:1; overflow-y:auto; padding:16px 20px; background:var(--w); }
.cart-footer { padding:16px 20px; border-top:1px solid var(--s2); background:#f0f5f5; }
.cart-item {
  display:flex; align-items:center; gap:10px; padding:10px 0;
  border-bottom:1px solid rgba(171,190,188,.3); font-size:.8rem;
}
.cart-item-name  { flex:1; color:var(--dk); font-weight:600; }
.cart-item-qty   { display:flex; align-items:center; gap:6px; }
.cart-qty-btn    { background:var(--s2); border:none; width:22px; height:22px;
                   border-radius:50%; cursor:pointer; font-size:.8rem; font-weight:700;
                   color:var(--dk); transition:background var(--ease); }
.cart-qty-btn:hover { background:var(--t1); color:var(--w); }
.cart-item-price { color:var(--t1); font-family:var(--font-display); font-size:.95rem; }
.cart-remove     { background:none; border:none; color:var(--muted); cursor:pointer;
                   font-size:.8rem; transition:color var(--ease); }
.cart-remove:hover { color:var(--r); }
.cart-overlay {
  display:none; position:fixed; inset:0; background:rgba(61,101,105,.4);
  z-index:899; backdrop-filter:blur(2px);
}
.cart-overlay.show { display:block; }

/* ── FOOTER ── */
footer {
  background:var(--dk); padding:0;
  position:relative; z-index:1;
}
.ft-logo { width:88px; height:88px; object-fit:cover; border-radius:50%;
           margin:0 auto 1rem; display:block;
           filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));
           background:rgba(255,255,255,.12); }
.ft-tag  { font-family:var(--font-serif); font-style:italic;
           color:rgba(193,207,206,.7); font-size:.92rem; margin-bottom:0;
           text-align:center; }
.ft-cols { display:grid; grid-template-columns:repeat(3,1fr); gap:40px;
           max-width:900px; margin:0 auto 1.4rem; }
.ft-col h4 { font-family:var(--font-display); font-size:.9rem; letter-spacing:.12em;
             color:rgba(255,255,255,.88); margin-bottom:1rem; }
.ft-col a, .ft-col p {
  display:block; color:rgba(255,255,255,.6); text-decoration:none;
  font-size:.78rem; line-height:2.2; transition:color var(--ease);
}
.ft-col a:hover { color:var(--s1); }
.ft-bottom {
  border-top:1px solid rgba(255,255,255,.07); padding-top:1rem;
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:10px; max-width:1140px; margin:0 auto;
}
.ft-copy   { color:rgba(255,255,255,.5); font-size:.72rem; letter-spacing:.06em; }
.ft-social { display:flex; gap:10px; }
.ft-social a { color:rgba(255,255,255,.35); text-decoration:none; font-size:.72rem;
               font-weight:700; letter-spacing:.08em;
               transition:color var(--ease); }
.ft-social a:hover { color:var(--s1); }

/* ── KEYFRAMES ── */
@keyframes tick    { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes riseUp  { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }
@keyframes popIn   { from{opacity:0;transform:scale(.84) translateY(-16px)} to{opacity:1;transform:none} }
@keyframes fadeDown{ from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:none} }
@keyframes spinIn  {
  0%   { opacity:0; transform:scale(.6) rotate(-180deg); }
  60%  { transform:scale(1.08) rotate(8deg); }
  80%  { transform:scale(.97) rotate(-3deg); }
  100% { opacity:1; transform:scale(1) rotate(0deg); }
}
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
@keyframes waveBob {
  0%, 100% { transform:translateY(0); }
  50%       { transform:translateY(-6px); }
}
@keyframes floatLogo {
  0%, 100% { transform:translateY(0px) rotate(0deg); }
  25%       { transform:translateY(-8px) rotate(1deg); }
  75%       { transform:translateY(-4px) rotate(-1deg); }
}

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .ft-cols { grid-template-columns:1fr 1fr; }
}
@media(max-width:640px) {
  .sec { padding:64px 1.2rem; }
  .fg-row { grid-template-columns:1fr; }
  .ft-cols { grid-template-columns:1fr; gap:20px; }
  .ft-col { text-align:center; }
  .ft-col a, .ft-col p { justify-content:center; }
  .ft-bottom { justify-content:center; flex-direction:column; align-items:center; text-align:center; gap:6px; }
  #cartSidebar { width:100vw; }
  .n-cta { display:none !important; }

  /* ── Mobile nav: hamburger left | logo center | cart right ── */
  #site-nav {
    display:grid;
    grid-template-columns:48px 1fr auto;
    align-items:center;
    padding:0 1rem;
  }
  .hbg-btn {
    grid-column:1; grid-row:1;
    display:flex !important;
    align-items:center;
    justify-content:flex-start;
  }
  .n-brand {
    grid-column:2; grid-row:1;
    display:flex !important;
    align-items:center;
    justify-content:center;
  }
  .n-logo { width:52px !important; height:52px !important; }
  .n-text { display:none !important; }
  .n-cart {
    grid-column:3; grid-row:1;
    display:flex !important;
    align-items:center;
    justify-content:flex-end;
    height:auto !important;
    padding:0 !important;
    color:rgba(253,253,253,.68);
  }
  .n-cart svg { stroke:rgba(253,253,253,.68); }

  /* Nav links — hidden by default, full dropdown when open */
  .n-links {
    display:none;
    flex-direction:column;
    position:absolute;
    top:var(--nav-h); left:0; right:0;
    background:var(--dk);
    padding:.8rem 1.4rem;
    border-top:1px solid rgba(193,207,206,.15);
    z-index:900;
    list-style:none;
    margin:0;
  }
  .n-links.open { display:flex; }
  .n-links > li > a { height:auto; padding:11px 0; display:block; }
}
/* ============================================================
   MOBILE OPTIMIZATION  — Batch 3
   Breakpoints: 960px | 768px | 480px
   ============================================================ */

/* ── 960px — tablets ── */
@media(max-width:960px) {
  /* Checkout */
  .checkout-layout { grid-template-columns:1fr !important; }
  .co-summary { padding:24px 20px !important; }
  .co-form-panel { padding:24px 20px !important; }

  /* Confirmation */
  .conf-grid { grid-template-columns:1fr !important; }

  /* Contact & Gift Cards */
  .contact-grid { grid-template-columns:1fr !important; gap:32px !important; }
  .gc-grid { grid-template-columns:1fr !important; gap:32px !important; }
  .how-grid { grid-template-columns:1fr 1fr !important; }

  /* Order layout */
  .order-layout { grid-template-columns:1fr !important; }

  /* Photo strips — collapse to 2 cols */
  [style*="grid-template-columns:repeat(4,1fr)"][style*="height:"] {
    grid-template-columns: repeat(2,1fr) !important;
    height: auto !important;
  }
  [style*="grid-template-columns:repeat(4,1fr)"][style*="height:"] > div {
    height: 180px !important;
  }
}

/* ── 768px — large phones ── */
@media(max-width:768px) {
  /* Nav */
  .n-links {
    display:none; flex-direction:column; position:fixed;
    top:var(--nav-h); left:0; right:0; bottom:0;
    background:var(--dk); padding:1.4rem;
    border-top:1px solid rgba(193,207,206,.15);
    overflow-y:auto; z-index:799;
  }
  .n-links.open { display:flex; }
  .n-links > li > a { height:auto; padding:14px 0; font-size:.72rem;
    border-bottom:1px solid rgba(193,207,206,.08); width:100%; }
  .n-links > li:last-child > a { border-bottom:none; }
  .n-cart { height:auto !important; padding:14px 0 !important; }
  .hbg-btn { display:flex !important; }

  /* Hero */
  .hero-bar { grid-template-columns:1fr 1fr !important; }

  /* Sections */
  .sec { padding:52px 1.2rem !important; }

  /* Story */
  .story-grid { grid-template-columns:1fr !important; gap:28px !important; }
  .story-img-wrap { display:none !important; }

  /* Stats band */
  .stats-band { grid-template-columns:1fr 1fr !important; }

  /* Experience grid */
  .experience-grid { grid-template-columns:1fr 1fr !important; }

  /* Menu */
  .menu-grid { grid-template-columns:1fr !important; }
  .menu-showcase { grid-template-columns:1fr !important; }
  .tab-bar { gap:6px !important; }
  .tab-btn { padding:7px 14px !important; font-size:.72rem !important; }

  /* Events */
  .events-grid { grid-template-columns:1fr 1fr !important; }
  .weekly-grid { grid-template-columns:1fr !important; }

  /* Gallery */
  .photo-grid { columns:2 !important; }

  /* Reviews */
  .review-grid { grid-template-columns:1fr !important; }

  /* Vibes */
  .vibes-grid { grid-template-columns:1fr !important; }
  .vibe-large { grid-row:auto !important; }
  .vibe-item:not(.vibe-large) { height:200px !important; }

  /* Footer */
  .ft-cols { grid-template-columns:1fr !important; gap:20px !important; }
  .ft-col { text-align:center !important; }

  /* Photo mosaics — 2 cols */
  [style*="grid-template-columns:2fr 1fr 1fr"] {
    grid-template-columns:1fr 1fr !important;
    grid-template-rows:auto !important;
  }
  [style*="grid-template-columns:2fr 1fr 1fr"] > div:first-child {
    grid-row:auto !important;
    height:220px !important;
  }
  [style*="grid-template-columns:2fr 1fr 1fr"] > div { height:180px !important; }

  [style*="grid-template-columns:1fr 1fr 1fr"][style*="height:320px"] {
    grid-template-columns:1fr !important;
    height:auto !important;
  }
  [style*="grid-template-columns:1fr 1fr 1fr"][style*="height:320px"] > div { height:200px !important; }

  [style*="grid-template-columns:repeat(3,1fr)"][style*="height:"] {
    grid-template-columns:1fr 1fr !important;
    height:auto !important;
  }
  [style*="grid-template-columns:repeat(3,1fr)"][style*="height:"] > div { height:160px !important; }

  /* Specials grid */
  [style*="grid-template-columns:repeat(4,1fr)"][style*="gap:16px"] {
    grid-template-columns:1fr 1fr !important;
  }

  /* Order confirmation */
  .ref-code { font-size:1.4rem !important; letter-spacing:.06em !important; }

  /* Gift card amount options */
  .amount-options { grid-template-columns:repeat(3,1fr) !important; }

  /* How-to grid */
  .how-grid { grid-template-columns:1fr !important; }

  /* Values */
  .values-grid { grid-template-columns:1fr 1fr !important; }
}

/* ── 480px — small phones ── */
@media(max-width:480px) {
  /* Hero text */
  .hero-bar { grid-template-columns:1fr 1fr !important; }
  .hero-bar-item { padding:10px 12px !important; }
  .hero-bar-value { font-size:.68rem !important; }

  /* Nav brand */
  .n-text b { font-size:1rem !important; }
  .n-text span { font-size:.4rem !important; }

  /* Sections */
  .sec { padding:40px 1rem !important; }

  /* Headings */
  .h2 { font-size:clamp(1.8rem,8vw,2.8rem) !important; }

  /* Experience — single col */
  .experience-grid { grid-template-columns:1fr !important; }

  /* Events */
  .events-grid { grid-template-columns:1fr !important; }

  /* Gallery */
  .photo-grid { columns:1 !important; }

  /* Footer */
  .ft-cols { grid-template-columns:1fr !important; }
  .ft-bottom { flex-direction:column !important; text-align:center !important; }

  /* Stats */
  .stats-band { grid-template-columns:1fr 1fr !important; }
  .sband-num { font-size:2.2rem !important; }

  /* Values */
  .values-grid { grid-template-columns:1fr !important; }

  /* Photo strips — single col on very small screens */
  [style*="grid-template-columns:repeat(4,1fr)"][style*="height:"] {
    grid-template-columns:1fr 1fr !important;
  }
  [style*="grid-template-columns:repeat(3,1fr)"][style*="height:"] {
    grid-template-columns:1fr 1fr !important;
    height:auto !important;
  }
  [style*="grid-template-columns:repeat(3,1fr)"][style*="height:"] > div { height:140px !important; }

  /* Checkout form */
  .fg-row { grid-template-columns:1fr !important; }
  .co-type-toggle { grid-template-columns:1fr 1fr !important; }
  .co-summary { padding:20px 16px !important; }
  .co-form-panel { padding:20px 16px !important; }

  /* Gift card */
  .amount-options { grid-template-columns:1fr 1fr 1fr !important; }
  .gc-card-preview { padding:28px 20px !important; }
  .gc-amount-display { font-size:2.4rem !important; }

  /* Contact form */
  .contact-form { padding:24px 18px !important; }

  /* Ticker */
  .ti { font-size:.7rem !important; padding:0 14px !important; }

  /* Buttons */
  .btn-primary, .btn-teal, .btn-outline, .btn-outline-w {
    padding:11px 22px !important; font-size:.82rem !important;
  }

  /* Order confirmation */
  .conf-panel { padding:20px 16px !important; }
  .bank-detail { padding:10px 12px !important; }
}

/* ── Touch-friendly tap targets ── */
@media(hover:none) {
  .btn-primary:hover, .btn-teal:hover, .btn-outline:hover { transform:none !important; }
  .menu-row:hover { background:rgba(255,255,255,.7) !important; }
  .exp-card:hover { transform:none !important; }
}

/* ── Image display on mobile ── */
@media(max-width:768px) {
  /* Ensure all images show on mobile — override any hide rules */
  .story-img-wrap { display:block !important; }
  .story-img { height:260px !important; }
  /* Food photo strips scale down gracefully */
  [style*="height:420px"] { height:240px !important; }
  [style*="height:380px"] { height:220px !important; }
  [style*="height:320px"] { height:200px !important; }
  [style*="height:280px"] { height:180px !important; }
  [style*="height:260px"] { height:160px !important; }
}


/* ── HERO TEXT MOBILE CENTERING ── */
@media(max-width:768px) {
  /* Homepage hero SVG text */
  #site-nav ~ section svg[viewBox] {
    width:100vw !important;
  }
  /* Hero section full width centering */
  section[style*="min-height:100vh"] > div[style*="text-align:center"] {
    padding-left:1rem !important;
    padding-right:1rem !important;
  }
  /* SVG text viewbox fix for mobile */
  svg[viewBox="0 0 960 140"],
  svg[viewBox="0 0 960 130"] {
    width:100vw !important;
    max-width:100vw !important;
  }
}

/* ── GIFT CARD MOBILE CENTERING ── */
@media(max-width:768px) {
  .gc-hero-content { text-align:center !important; }
  .gc-amounts-section { text-align:center !important; }
  .gc-amounts-section .wrap { text-align:center !important; }
  .denom-grid { max-width:100% !important; }
  .gc-form-wrap { text-align:left !important; }
  .gc-steps { text-align:center !important; }
  .gc-balance-section { text-align:center !important; }
  .gc-float-wrap { display:block !important; text-align:center !important; }
  .gc-card-3d { margin:0 auto !important; transform:none !important; }
  /* Fix breadcrumb on mobile */
  .breadcrumb { justify-content:center !important; flex-wrap:wrap !important; }
}

/* ── HERO MOBILE CENTERING ── */
@media(max-width:640px) {
  /* Hero inner wrapper */
  section[style*="min-height:100vh"] > div[style*="z-index:2"] {
    text-align:center !important;
    padding-left:1.2rem !important;
    padding-right:1.2rem !important;
  }
  /* SVG text full width */
  section[style*="min-height:100vh"] svg {
    width:100vw !important;
    max-width:100vw !important;
  }
  /* Buttons stack nicely */
  section[style*="min-height:100vh"] .btn-primary,
  section[style*="min-height:100vh"] .btn-outline-w {
    width:100% !important;
    justify-content:center !important;
  }
}
/* ══ NAV — main styles ══════════════════════════════════════ */
#main-nav {
  position:fixed; top:0; left:0; right:0; z-index:800;
  height:var(--nav-h); display:flex; align-items:center;
  justify-content:space-between; padding:0 2rem;
  background:var(--dk); border-bottom:2px solid rgba(193,207,206,.25);
  transition:box-shadow var(--ease);
}
#main-nav.scrolled { box-shadow:0 4px 24px rgba(61,101,105,.4); }

/* Brand */
.nav-brand { display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0; }
.nav-logo   { width:46px; height:46px; object-fit:cover; border-radius:50%;
              filter:drop-shadow(0 2px 6px rgba(0,0,0,.3)); transition:transform .3s ease; }
.nav-brand-text b,
.nav-brand-name { font-family:var(--font-display); font-size:1.22rem; color:var(--w);
                  letter-spacing:.08em; display:block; line-height:1; }
.nav-brand-sub  { font-size:.48rem; font-weight:700; letter-spacing:.2em;
                  text-transform:uppercase; color:var(--s2); display:block; }

/* Desktop links */
.nav-links { display:flex; align-items:center; list-style:none; margin:0; padding:0; }
.nav-links > li > a {
  display:flex; align-items:center; height:var(--nav-h); padding:0 11px;
  font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(253,253,253,.68); text-decoration:none;
  transition:color var(--ease), background var(--ease); white-space:nowrap;
}
.nav-links > li > a:hover,
.nav-links > li > a.active { color:var(--s1); background:rgba(193,207,206,.1); }

/* CTA button */
.nav-cta {
  background:var(--t1) !important; color:var(--w) !important;
  height:36px !important; padding:0 20px !important; margin-left:8px;
  border-radius:2px; font-size:.64rem !important; letter-spacing:.14em !important;
  white-space:nowrap; text-decoration:none; display:inline-flex; align-items:center;
  transition:filter var(--ease), transform var(--ease) !important;
}
.nav-cta:hover { filter:brightness(1.1) !important; transform:translateY(-1px) !important; }

/* Cart */
.nav-cart {
  display:flex; align-items:center; gap:5px; padding:0 8px;
  color:rgba(253,253,253,.75); text-decoration:none; position:relative;
  font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  transition:color var(--ease);
}
.nav-cart:hover { color:var(--s1); }
.nav-cart-label { display:inline; }
.cart-bubble {
  background:var(--r); color:#fff; font-size:.52rem; font-weight:700;
  min-width:16px; height:16px; border-radius:8px; padding:0 4px;
  display:inline-flex; align-items:center; justify-content:center; line-height:1;
}

/* Hamburger */
.nav-hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:6px;
}
.nav-hamburger span {
  display:block; width:24px; height:2px; background:var(--w);
  border-radius:1px; transition:all .3s;
}

/* Dropdown */
.nav-dropdown { position:relative; }
.nav-btn {
  display:flex; align-items:center; gap:5px; height:var(--nav-h); padding:0 11px;
  font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(253,253,253,.68); background:none; border:none; cursor:pointer;
  transition:color var(--ease);
}
.nav-btn:hover { color:var(--s1); }
.nav-drop {
  display:none; position:absolute; top:100%; left:0; min-width:180px;
  background:var(--dk); border:1px solid rgba(193,207,206,.2);
  border-top:2px solid var(--t1); z-index:900; padding:.4rem 0;
}
.nav-dropdown:hover .nav-drop,
.nav-dropdown:focus-within .nav-drop { display:block; }
.nav-drop a {
  display:block; padding:10px 16px; color:rgba(253,253,253,.75);
  text-decoration:none; font-size:.62rem; letter-spacing:.08em;
  transition:background var(--ease), color var(--ease);
}
.nav-drop a:hover { background:rgba(193,207,206,.1); color:var(--s1); }

/* ── CLOSURE NOTICE ── */
.closure-notice {
  display:flex; align-items:flex-start; gap:14px;
  background:#1e4a4d; color:#f4f0ec;
  padding:14px 20px; font-size:.85rem; line-height:1.6;
  margin-top:var(--nav-h); position:relative; z-index:800;
}
.closure-notice-hours { background:#5a3e1b; }
.closure-icon { font-size:1.4rem; flex-shrink:0; margin-top:2px; }

/* ── MOBILE NAV (≤640px) ── */
@media(max-width:640px) {
  #main-nav {
    padding:0 1rem;
    display:grid;
    grid-template-columns:44px 1fr 44px;
    align-items:center;
  }
  /* Hamburger — left column */
  .nav-hamburger { display:flex; grid-column:1; justify-self:start; }
  /* Brand — center column */
  .nav-brand { grid-column:2; justify-self:center; gap:0; }
  .nav-brand-text { display:none; }
  .nav-logo { width:52px; height:52px; }
  /* Hide desktop links and CTA */
  .nav-links, .nav-cta-wrap, .nav-cta { display:none !important; }
  /* Cart — right column */
  .nav-cart { grid-column:3; justify-self:end; padding:0; }
  .nav-cart-label { display:none; }
  /* Closure notice — compact on mobile */
  .closure-notice { font-size:.75rem; padding:10px 14px; gap:10px; }
  .closure-icon { font-size:1.1rem; }
}