﻿/* =========================================================
   Pecan Nuts & Coffee — Styles (desktop + mobile heroes split)
   ========================================================= */

/* ---------- Design tokens ---------- */
:root{
  --bg:#f3ece3;
  --bg-deep:#e5d5c7;
  --paper:#fffdfa;
  --ink:#1f120b;
  --muted:#6e5643;
  --brand:#8c5f36;
  --brand-soft:rgba(140,95,54,.12);
  --accent:#d59a66;
  --accent-soft:rgba(213,154,102,.16);
  --shadow-soft:0 18px 40px rgba(31,18,11,.14);
  --shadow-strong:0 30px 60px rgba(31,18,11,.22);
  --radius:18px;
  --radius-lg:26px;

  /* desktop/tablet container */
  --container:min(1140px, calc(100% - 48px));
}

/* ---------- Base ---------- */
*{ box-sizing:border-box; }
html,body{ height:100%; }
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%; /* iOS: prevent font auto-zoom */
}
body{
  margin:0;
  background:
    radial-gradient(1200px 520px at 50% -260px, rgba(213,154,102,.16), transparent 60%),
    linear-gradient(180deg, var(--bg-top, #f3ece3) 0%, var(--bg-mid, #fffdfa) 45%, var(--bg-bottom, #e5d5c7) 100%);
  color:var(--ink);
  font:16px/1.6 "Inter","Segoe UI",system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden; /* safety on small phones */
}
img{ max-width:100%; height:auto; display:block; border-radius:inherit; }
a{ color:inherit; text-decoration:none; }
a:hover{ opacity:.92; }

.container{ width:var(--container); margin-inline:auto; }
.eyebrow{ letter-spacing:.28em; text-transform:uppercase; font-size:12px; font-weight:600; color:var(--brand); margin:0 0 16px; }
.muted{ color:var(--muted); }

.skip-link{ position:absolute; left:-999px; top:auto; background:var(--paper); padding:8px 14px; border-radius:10px; box-shadow:var(--shadow-soft); }
.skip-link:focus{ left:16px; top:16px; }

/* =========================================================
   GLASS HEADER
   ========================================================= */
.glass-header{
  position:fixed; top:24px; left:0; width:100%; z-index:100;
  display:grid; place-items:center; pointer-events:none; transition:top .22s ease;
}
.glass-container{
  pointer-events:auto;
  width:min(1180px, calc(100% - 28px));
  min-height:70px;
  padding:0 12px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:14px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.35);
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
  border-radius:22px;
  box-shadow:0 14px 40px rgba(31,18,11,.18);
  transition:min-height .22s ease, background .22s ease, border-color .22s ease;
  overflow:hidden;
}
.glass-header.scrolled .glass-container{ background:rgba(255,255,255,.32); border-color:rgba(255,255,255,.45); }
.glass-header.docked{ top:0; }
.glass-header.docked .glass-container{ min-height:64px; border-radius:20px; }

/* Logo */
.brand-circle{
  width:56px; height:56px; border-radius:999px;
  display:grid; place-items:center; align-self:center;
  background:#fffdfa;
  box-shadow:0 6px 16px rgba(31,18,11,.16), inset 0 0 0 1px rgba(140,95,54,.16);
  transition: transform .28s ease, width .2s ease, height .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.brand-circle img{ width:44px; height:44px; object-fit:contain; }
.glass-header.docked .brand-circle{
  width:48px; height:48px;
  box-shadow:0 4px 12px rgba(31,18,11,.14), inset 0 0 0 1px rgba(140,95,54,.14);
  background:#fffdf9;
}

/* Desktop nav */
.glass-nav{ justify-self:end; }
.glass-nav ul{ margin:0; padding:0; list-style:none; display:flex; gap:6px; }
.glass-nav a{
  display:inline-flex; align-items:center; padding:10px 14px; border-radius:999px; font-weight:600; color:var(--ink);
  transition: background .2s ease, color .2s ease, transform .15s ease;
}
.glass-nav a:hover{ background:rgba(213,154,102,.12); }
.glass-nav a[aria-current="page"], .glass-nav a.is-active{ background:rgba(213,154,102,.16); color:var(--brand); }

/* Focus ring */
:where(.glass-nav a, .brand-circle, .hamburger):focus-visible{ outline:0; box-shadow:0 0 0 4px rgba(213,154,102,.28); }

/* ---------- Mobile hamburger + overlay ---------- */
.hamburger{
  display:none; order:3; justify-self:end;
  width:44px; height:44px; border:0; background:transparent; border-radius:10px; cursor:pointer;
  position:relative; z-index:130; align-self:center;
}
.hamburger span{
  position:absolute; left:10px; right:10px; height:2px; background:var(--ink); border-radius:2px;
  transition: transform .22s ease, opacity .22s ease, top .22s ease;
}
.hamburger span:nth-child(1){ top:calc(50% - 8px); transform:translateY(-50%); }
.hamburger span:nth-child(2){ top:50%; transform:translateY(-50%); }
.hamburger span:nth-child(3){ top:calc(50% + 8px); transform:translateY(-50%); }
.hamburger[aria-expanded="true"] span:nth-child(1){ top:50%; transform:translateY(-50%) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.hamburger[aria-expanded="true"] span:nth-child(3){ top:50%; transform:translateY(-50%) rotate(-45deg); }

/* Full-screen overlay nav */
.overlay-nav{
  position:fixed; inset:0; z-index:120;
  display:grid; place-items:center;
  background:
    radial-gradient(900px 500px at 50% -120px, rgba(255,255,255,.35), transparent 60%),
    rgba(31,18,11,.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity:0; pointer-events:none; transform:translateY(8px);
  transition: opacity .22s ease, transform .22s ease;
}
.overlay-nav.open{ opacity:1; pointer-events:auto; transform:translateY(0); }
.overlay-nav ul{ list-style:none; margin:0; padding:0; display:grid; gap:18px; text-align:center; }
.overlay-nav a{
  display:inline-block; padding:14px 22px; border-radius:999px;
  background:rgba(255,255,255,.9); color:var(--ink); font-weight:800; font-size:1.25rem; letter-spacing:.02em;
  box-shadow:var(--shadow-soft);
}
.overlay-close{
  position:absolute; top:18px; right:18px;
  width:44px; height:44px; border-radius:12px; border:0;
  background:rgba(255,255,255,.9); color:var(--ink);
  font-size:28px; line-height:1; cursor:pointer; box-shadow:var(--shadow-soft);
}

/* Mobile layout triggers */
@media (max-width:900px){
  .glass-container{ grid-template-columns:auto 1fr auto; }
  .hamburger{ display:inline-block; }
  .glass-nav{ display:none; }
  .glass-header.docked .brand-circle{ width:44px; height:44px; }
}

/* prevent page scroll when the overlay is open */
.no-scroll{ overflow:hidden; }

/* =========================================================
   Sections & seams
   ========================================================= */
main{ display:block; }
.section{ padding:92px 0; position:relative; background:transparent; isolation:isolate; }
.section-head{ margin-bottom:36px; max-width:680px; }
.section-head h2{ margin:0; font-size:clamp(2rem,4vw,2.8rem); }
.section:not(:first-of-type)::before{
  content:""; position:absolute; left:0; right:0; top:-44px; height:88px; pointer-events:none; z-index:-1;
  background:radial-gradient(60% 80px at 50% 44px, rgba(31,18,11,.08), transparent 70%);
}

/* alt panel feather */
.section-alt{ background:transparent; }
.section-alt::after{
  content:""; position:absolute; inset:-24px 0 -24px 0; z-index:-1; pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(229,213,199,.38));
  -webkit-mask:linear-gradient(to bottom, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
          mask:linear-gradient(to bottom, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
}

/* Push the "Δες retail μενού" button further down */
.retail .btn-primary{
  display:inline-flex;
  margin-top:0.5px; /* tweak to 36–40px if you want more space */
}
/* Optional: add a gap under the badges so both spaces add up */
.retail .badge-row{ margin-bottom:18px; }

/* =========================================================
   Hero (desktop)
   ========================================================= */
.hero{ position:relative; overflow:hidden; }
.hero-home{ padding:140px 0 120px; }
.hero-image{ position:absolute; inset:0; overflow:hidden; }
.hero-image img{ width:100%; height:100%; object-fit:cover; filter:saturate(88%) contrast(.96); }
.hero-overlay{ position:absolute; inset:0; background:linear-gradient(110deg, rgba(31,18,11,.66) 0%, rgba(31,18,11,.52) 45%, rgba(31,18,11,.35) 100%); mix-blend-mode:multiply; }
.hero-body{ position:relative; display:grid; gap:24px; color:#fff; max-width:620px; }
.hero-body p{ margin:0; font-size:1.08rem; color:rgba(255,255,255,.84); }
.hero-body h1{ margin:0; font-size:clamp(2.6rem,6vw,3.8rem); line-height:1.05; }

/* HERO actions + STAT PILLS (glassy) */
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; }
.hero-actions .btn{ box-shadow:none; }
.hero-home .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.4); background:rgba(255,255,255,.08); }
.hero-home .btn-link{ color:#fff; }

.hero-stats{ display:flex; flex-wrap:wrap; gap:12px; margin-top:10px; }
.stat-pill{
  display:grid; gap:4px; padding:14px 20px;
  background:rgba(255,255,255,.08);
  border-radius:14px; border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
  min-width:120px; text-align:left; color:#fff;
}
.stat-pill strong{ font-size:1.4rem; }
.stat-pill span{ font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; }

/* =========================================================
   Buttons
   ========================================================= */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; border-radius:999px; border:1px solid transparent; padding:12px 22px; font-weight:600; cursor:pointer; transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease; }
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--brand); color:#fff; box-shadow:var(--shadow-soft); }
.btn-ghost{ border-color:rgba(140,95,54,.26); background:rgba(255,255,255,.78); color:var(--brand); }
.btn-link{ padding:0; border:none; border-radius:0; background:none; color:var(--brand); font-weight:600; position:relative; }
.btn-link::after{ content:"›"; margin-left:8px; transition:transform .2s ease; }
.btn-link:hover{ transform:none; }
.btn-link:hover::after{ transform:translateX(4px); }

/* =========================================================
   Cards / Highlights
   ========================================================= */
.highlight-grid{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:26px; }
.card{ background:var(--paper); border-radius:var(--radius); border:1px solid rgba(140,95,54,.16); padding:28px; box-shadow:var(--shadow-soft); }
.card h3{ margin:0 0 12px; font-size:1.2rem; }
.card ul{ margin:18px 0; padding-left:18px; color:var(--muted); display:grid; gap:6px; }
.card-link{ display:inline-flex; align-items:center; gap:6px; font-weight:600; color:var(--brand); }
.card-link::after{ content:"›"; transition:transform .2s ease; }
.card-link:hover::after{ transform:translateX(4px); }
.card-head{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; }
.tag{ background:var(--brand-soft); color:var(--brand); padding:6px 12px; border-radius:999px; font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; }

/* =========================================================
   Story
   ========================================================= */
.story{ background:rgba(255,255,255,.75); }
.split{ display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:54px; align-items:center; }
.story-media{ position:relative; display:grid; gap:20px; }
.story-main{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-strong); }
.story-accent{ position:absolute; width:45%; bottom:-14%; right:-6%; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); }
.feature-list{ list-style:none; margin:28px 0; padding:0; display:grid; gap:12px; color:var(--muted); }
.cta-row{ display:flex; flex-wrap:wrap; gap:12px; }

/* =========================================================
   Menu preview
   ========================================================= */
.menu-preview-grid{ display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:24px; }
.menu-preview-card{ padding:26px; background:rgba(255,255,255,.9); box-shadow:var(--shadow-soft); }
.menu-preview-card p{ margin:0 0 18px; color:var(--muted); }

/* =========================================================
   Visit
   ========================================================= */
.visit .info-list{ list-style:none; margin:26px 0; padding:0; display:grid; gap:10px; color:var(--muted); }
.badge-row{ display:flex; flex-wrap:wrap; gap:10px; }
.badge{ background:rgba(255,255,255,.82); border:1px solid rgba(140,95,54,.24); border-radius:999px; padding:6px 14px; font-size:.82rem; color:var(--brand); box-shadow:var(--shadow-soft); }
.map{ background:rgba(255,255,255,.82); border-radius:var(--radius); min-height:280px; display:grid; place-items:center; color:var(--muted); font-weight:600; border:1px dashed rgba(140,95,54,.36); }
.map iframe,.map .map-placeholder{ width:100%; height:380px; border:0; border-radius:18px; box-shadow:var(--shadow-soft); }

/* =========================================================
   Showcase / Βιτρίνα
   ========================================================= */
.showcase{ position:relative; }
.showcase .section-head p.muted{ max-width:680px; }
.showcase-grid{ display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:28px; }
@media (max-width:1080px){ .showcase-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); } }
@media (max-width:700px){ .showcase-grid{ grid-template-columns:1fr; } }

.showcase-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(140,95,54,.16);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
  padding:22px;
  display:grid; grid-template-rows:1fr auto;
  min-height:320px;
  transition:transform .18s ease, box-shadow .18s ease;
}
.showcase-card:hover{ transform:translateY(-3px); box-shadow:0 24px 60px rgba(31,18,11,.18); }
.showcase-media{ width:100%; aspect-ratio:1/1; border-radius:18px; overflow:hidden; margin-bottom:14px; background:#fff; }
.showcase-card h4{ margin:0 0 6px; font-size:1.1rem; }
.showcase-card p{ margin:0; color:var(--muted); }

.showcase-cta{ display:grid; place-items:center; min-height:320px; text-align:center; background:rgba(255,255,255,.96); border:1px solid rgba(140,95,54,.16); border-radius:var(--radius-lg); box-shadow:var(--shadow-soft); }
.showcase-cta .btn{ padding:14px 22px; border-radius:999px; font-weight:700; }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{ background:#1d130c; color:rgba(255,246,234,.86); padding:34px 0; }
.footer-inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; font-size:.95rem; }
.social{ list-style:none; display:flex; gap:14px; margin:0; padding:0; }
.social a{ opacity:.85; }
.social a:hover{ opacity:1; text-decoration:underline; }

/* =========================================================
   MENU PAGE — Desktop (old layout preserved)
   ========================================================= */
body.page-menu{ background:transparent; }

/* Desktop hero */
.menu-hero{ position:relative; overflow:hidden; padding:130px 0 72px; }
.menu-hero-inner{ display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:54px; align-items:center; }
.menu-hero-inner>div:first-child{ max-width:560px; }
.menu-hero p{ color:var(--muted); }
.menu-hero-media{ position:relative; }
.menu-hero-media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-strong); }
.menu-hero-media .hero-glow{ position:absolute; inset:auto; top:12%; left:10%; width:70%; height:70%; background:radial-gradient(circle, rgba(213,154,102,.28), transparent 70%); filter:blur(12px); z-index:-1; }

/* Desktop content */
.menu-sections{ display:grid; grid-template-columns:1fr; gap:48px; margin-bottom:130px; }
.menu-content{ display:grid; gap:72px; }
.menu-group header{ margin-bottom:30px; }
.menu-group h2{ margin:0; font-size:clamp(1.9rem, 4vw, 2.6rem); }
.item-grid{ display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:24px; }
.item-grid article{ background:rgba(255,255,255,.92); border-radius:var(--radius); border:1px solid rgba(140,95,54,.18); box-shadow:var(--shadow-soft); padding:24px; display:grid; gap:10px; }
.item-grid h3{ margin:0; font-size:1.08rem; }
.item-grid p{ margin:0; color:var(--muted); }
.tags{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; }
.tags li{ background:rgba(140,95,54,.12); color:var(--brand); border-radius:999px; padding:5px 12px; font-size:.78rem; font-weight:600; }
.item-notes{ font-size:.88rem; color:var(--muted); }

/* Desktop sticky index */
@media (min-width:1081px){
  .menu-sections{ grid-template-columns:280px 1fr; gap:48px; }
  .menu-index{
    position:sticky; top:70px; align-self:start; width:280px;
    background:rgba(255,255,255,.86); border-radius:22px; border:1px solid rgba(140,95,54,.16);
    padding:22px; box-shadow:var(--shadow-soft);
    opacity:0; pointer-events:none; transition:opacity .25s ease, box-shadow .25s ease;
    margin-left:-60px; max-height:calc(100vh - 140px); overflow:auto; overscroll-behavior:contain; -webkit-overflow-scrolling:touch;
  }
  .menu-index.is-visible{ opacity:1; pointer-events:auto; }
  .menu-index ol{ list-style:none; margin:0; padding:0; display:grid; gap:10px; font-weight:600; }
  .menu-index a{ display:block; padding:8px 12px; border-radius:12px; color:var(--muted); transition:background .2s ease; white-space:normal; line-height:1.3; }
  .menu-index a.is-active{ background:var(--accent-soft); color:var(--brand); }
  .menu-index::-webkit-scrollbar{ width:10px; }
  .menu-index::-webkit-scrollbar-track{ background:transparent; }
  .menu-index::-webkit-scrollbar-thumb{ background:rgba(140,95,54,.22); border-radius:8px; }
  .menu-index:hover::-webkit-scrollbar-thumb{ background:rgba(140,95,54,.35); }
}

/* =========================================================
   MOBILE MENU — New drawer layout
   ========================================================= */
.menu-tools{
  margin-top:18px;
  display:grid;
  gap:12px;
}
.chips-row{ display:flex; gap:8px; overflow:auto; padding-bottom:4px; -webkit-overflow-scrolling:touch; }
.chips-row::-webkit-scrollbar{ height:6px; }
.chips-row::-webkit-scrollbar-thumb{ background:rgba(140,95,54,.25); border-radius:999px; }
.chip{
  flex:0 0 auto; padding:8px 14px; border-radius:999px;
  background:rgba(255,255,255,.9); border:1px solid rgba(140,95,54,.28);
  font-weight:600; color:var(--brand); white-space:nowrap; cursor:pointer;
}
.chip.is-active{ background:var(--brand); color:#fff; border-color:transparent; }

/* Search */
.search-wrap{
  position:relative;
  width:100%;
  max-width:100%;
  margin:0;
  overflow:hidden;
}
.search-input{
  display:block;
  width:100%;
  max-width:100%;
  padding:12px 42px 12px 14px;
  border-radius:14px;
  border:1px solid rgba(140,95,54,.28);
  background:rgba(255,255,255,.92);
  font:inherit; color:var(--ink);
  box-shadow:var(--shadow-soft);
}
.clear-search{
  position:absolute; right:8px; top:50%; transform:translateY(-50%);
  width:32px; height:32px; border-radius:10px; border:0; cursor:pointer;
  background:#fff; box-shadow:var(--shadow-soft); font-size:18px; line-height:1;
}

.menu-drawers{ display:grid; gap:12px; margin:22px 0 80px; }
.drawer{
  background:rgba(255,255,255,.92); border:1px solid rgba(140,95,54,.18);
  border-radius:16px; overflow:hidden; box-shadow:var(--shadow-soft);
}
.drawer-header{
  width:100%; background:transparent; border:0; display:flex; align-items:center; justify-content:space-between;
  padding:14px 14px; cursor:pointer; font-weight:800; font-size:1.05rem; letter-spacing:.01em;
}
.drawer-header .label{ display:flex; align-items:center; gap:10px; }
.drawer-header .dot{ width:10px; height:10px; border-radius:999px; background:var(--brand); opacity:.9; }
.drawer-header .chev{ transition:transform .18s ease; }
.drawer.open .drawer-header .chev{ transform:rotate(90deg); }

.drawer-body{ display:none; padding:0 14px 14px; }
.drawer.open .drawer-body{ display:block; }

.drawer-list{ list-style:none; margin:0; padding:0; display:grid; gap:8px; }
.drawer-item{
  padding:12px 12px; border-radius:12px; border:1px solid rgba(140,95,54,.12); background:#fff;
  font-weight:600; color:var(--ink);
}

.menu-empty{
  background:rgba(255,255,255,.9); border:1px dashed rgba(140,95,54,.32); border-radius:16px;
  padding:16px; color:var(--muted); text-align:center; box-shadow:var(--shadow-soft);
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1080px){
  .highlight-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .menu-preview-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .split{ grid-template-columns:1fr; }
  .story-accent{ position:relative; width:55%; bottom:auto; right:auto; margin-left:auto; margin-top:-40px; }
  .highlight-grid{ grid-template-columns:repeat(2, minmax(260px,340px)); }
  .menu-sections{ grid-template-columns:220px 1fr; gap:36px; }
  .menu-index{ position:sticky; top:88px; margin-left:0; }
}

/* ===== MOBILE HERO (its own layout) ===== */
.menu-hero-mobile{ display:none; }
.menu-hero-mobile__inner{
  width:calc(100% - 36px);
  margin-inline:auto;
  padding:110px 0 16px; /* account for fixed header */
}
.menu-hero-mobile h1{
  margin:6px 0 6px;
  font-size:clamp(1.6rem, 6vw, 2.2rem);
  line-height:1.2;
}
.menu-hero-mobile p{ margin:0 0 12px; }

/* remove the top-shadow seam on the final section */
.section:last-of-type::before{ content:none !important; }

/* remove the feather panel on the final alt section */
.section-alt:last-of-type::after{ content:none !important; }

/* Visibility & mobile layout switches */
@media (max-width:900px){
  .menu-hero-inner{ grid-template-columns:1fr; }
  .menu-hero-inner>div:first-child{ max-width:none; }
  .menu-hero-media{ display:none; }

  /* show mobile hero + drawers; hide desktop hero + desktop content */
  .menu-hero{ display:none; }
  .menu-hero-mobile{ display:block; }

  .menu-sections{ display:none; }
  .menu-index{ display:none; }

  /* mobile overlay: keep only Αρχική + Μενού */
  .overlay-nav ul{ display:grid; gap:18px; }
  .overlay-nav li:not(:has(a[data-nav="home"], a[data-nav="menu"])){ display:none; }
}

@media (max-width:760px){
  .container{ width:calc(100% - 36px); }
  .highlight-grid, .menu-preview-grid, .item-grid{ grid-template-columns:1fr; }
  .hero-home{ padding:120px 0 100px; }
}

@media (max-width:540px){
  body{ font-size:15px; }
  .footer-inner{ flex-direction:column; align-items:flex-start; }
  .section{ padding:78px 0; }
  .card{ padding:24px; }
}

/* kill old mobile toggle if present */
.nav-toggle{ display:none !important; }

/* overlay close hidden on desktop */
.overlay-close{ display:none; }
.overlay-nav.open .overlay-close{ display:block; }

/* desktop-only: never show overlay controls */
@media (min-width:901px){
  .hamburger{ display:none !important; }
  .overlay-close{ display:none !important; }
}

/* Hide the first stat pill (11+ signature drinks) on mobile */
@media (max-width:760px){
  .hero-stats .stat-pill:first-child{ display:none; }
}

/* Force-hide mobile menu UI on desktop */
@media (min-width:901px){
  #mobileMenu,
  #menuTools,
  .menu-hero-mobile{ display:none !important; }
  #desktopMenu,
  .menu-hero{ display:grid !important; } /* keep desktop blocks on */
}

/* iOS-only: keep drawer headers from over-bolding (optional) */
@supports (-webkit-touch-callout:none){
  .drawer-header{ font-weight:700; }
}

/* ===== Back-to-top (shared) ===== */
.to-top{
  position: fixed;
  right: 14px;
  bottom: 18px;
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border: 1px solid rgba(140,95,54,.28);
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  color: var(--brand);
  box-shadow: var(--shadow-soft);
  z-index: 120;
  opacity: 0;
  transform: translateY(16px) scale(.95);
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease;
}
.to-top.show{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.to-top:active{ transform:translateY(1px) scale(.98); }

/* mobile: keep it bottom-right (already) */
@media (max-width:900px){
  .to-top{ right:14px; bottom:18px; }
}

/* desktop (only on the menu page) — show in the top-right corner */
@media (min-width:901px){
  .page-menu .to-top{
    display: grid;               /* enable on desktop for menu page */
    right: 24px;                 /* right corner */
    bottom: 28px;                /* lower corner; increase if you prefer */
    width: 48px; height: 48px;   /* a touch bigger on desktop */
    border-radius: 16px;
  }
  /* if you want it hidden on desktop home, keep it off there */
  .page-home .to-top{ display:none; }
}

/* =========================================================
   iOS blue-text fix — SCOPED ONLY to /menu/ drawers
   (does not affect the rest of the site)
   ========================================================= */
.page-menu .drawer-header,
.page-menu .drawer-header *{
  color: var(--ink) !important;
  -webkit-text-fill-color: var(--ink) !important;
}
/* If iOS injects data-detector links (phones/dates) inside the menu page */
.page-menu a[x-apple-data-detectors]{
  color: inherit !important;
  text-decoration: none !important;
  -webkit-text-fill-color: currentColor !important;
}
/* Keep any tel/mail/maps links neutral inside the drawers */
.page-menu .drawer a[href^="tel:"],
.page-menu .drawer a[href^="mailto:"],
.page-menu .drawer a[href^="sms:"],
.page-menu .drawer a[href^="maps:"],
.page-menu .drawer a[href^="http://maps.apple.com"],
.page-menu .drawer a[href^="https://maps.apple.com"]{
  color: inherit !important;
  text-decoration: none !important;
  -webkit-text-fill-color: currentColor !important;
}
