/* Cormorant Garamond — self-hosted */
@font-face { font-family:'Cormorant Garamond'; font-style:italic; font-weight:400; font-display:swap;
  src:url(/fonts/cormorant-garamond-italic-400-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Cormorant Garamond'; font-style:italic; font-weight:400; font-display:swap;
  src:url(/fonts/cormorant-garamond-italic-400-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:300; font-display:swap;
  src:url(/fonts/cormorant-garamond-300-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:300; font-display:swap;
  src:url(/fonts/cormorant-garamond-300-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:400; font-display:swap;
  src:url(/fonts/cormorant-garamond-400-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:400; font-display:swap;
  src:url(/fonts/cormorant-garamond-400-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:500; font-display:swap;
  src:url(/fonts/cormorant-garamond-500-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:500; font-display:swap;
  src:url(/fonts/cormorant-garamond-500-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:600; font-display:swap;
  src:url(/fonts/cormorant-garamond-600-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:600; font-display:swap;
  src:url(/fonts/cormorant-garamond-600-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
/* Source Sans 3 — self-hosted */
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:300; font-display:swap;
  src:url(/fonts/source-sans-3-300-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:300; font-display:swap;
  src:url(/fonts/source-sans-3-300-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:400; font-display:swap;
  src:url(/fonts/source-sans-3-400-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:400; font-display:swap;
  src:url(/fonts/source-sans-3-400-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:500; font-display:swap;
  src:url(/fonts/source-sans-3-500-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:500; font-display:swap;
  src:url(/fonts/source-sans-3-500-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:600; font-display:swap;
  src:url(/fonts/source-sans-3-600-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Source Sans 3'; font-style:normal; font-weight:600; font-display:swap;
  src:url(/fonts/source-sans-3-600-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }

:root {
  --navy: #2c4a73;
  --navy-90: rgba(44,74,115,0.92);
  --navy-70: rgba(44,74,115,0.65);
  --sand: #f6f2ee;
  --cream: #faf8f5;
  --teal: #c0565a;
  --paper: #fdfcfa;
  --gold: #b08d57;
  --gold-light: #c9a96e;
  --font-display: 'Cormorant Garamond', 'Georgia', serif;
  --font-body: 'Source Sans 3', 'Segoe UI', system-ui, sans-serif;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body); font-size: 1rem; line-height: 1.7;
  color: var(--navy); background: var(--paper); overflow-x: hidden;
  -webkit-font-smoothing: antialiased; font-weight: 300;
  padding-bottom: 60px; padding-top: 52px; /* space for sticky bars */
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--teal); text-decoration: none; transition: color 0.3s; }
a:hover { color: var(--navy); }
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 400; line-height: 1.15; }
h2 { font-weight: 300; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

/* ============================================================
   TOP NAV
   ============================================================ */
.top-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 998;
  background: rgba(253,252,250,0.97); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(44,74,115,0.08);
  padding: 0;
}
.top-nav__inner {
  max-width: 1200px; margin: 0 auto; display: flex; align-items: center;
  justify-content: space-between; padding: 0 1.5rem; height: 52px;
}
.top-nav__brand {
  font-family: var(--font-display); font-size: 1.2rem; font-weight: 500;
  color: var(--navy); font-style: italic; white-space: nowrap;
}
.top-nav__brand small { font-size: 0.78rem; font-style: normal; color: var(--navy); opacity: 0.5; letter-spacing: 0.08em; margin-left: 0.5rem; font-weight: 400; }
.top-nav__links {
  display: flex; gap: 1.8rem; align-items: center; list-style: none;
}
.top-nav__links a {
  color: var(--navy-70); font-size: 0.88rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none;
  transition: color 0.2s;
}
.top-nav__links a:hover { color: var(--navy); }
.top-nav__phone {
  background: var(--gold); color: #fff !important; padding: 0.4rem 1.2rem;
  border-radius: 3px; font-weight: 500;
}
.top-nav__phone:hover { background: var(--gold-light); color: #fff !important; }

/* ============================================================
   MENU SECTION
   ============================================================ */
.menu-section { background: var(--paper); padding: 4rem 0 5rem; }
.menu-cats {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
  margin: 2rem auto; max-width: 900px;
}
.menu-cats a {
  padding: 0.5rem 1.2rem; background: var(--sand); border-radius: 4px;
  color: var(--navy); font-size: 0.82rem; font-weight: 500; text-decoration: none;
  transition: background 0.2s, color 0.2s; letter-spacing: 0.03em;
}
.menu-cats a:hover, .menu-cats a.active { background: var(--navy); color: #fff; }
.menu-category { margin-bottom: 0; scroll-margin-top: 70px; border-bottom: 1px solid rgba(44,74,115,0.08); }
.menu-category h3 {
  font-family: var(--font-display); font-size: 1.3rem; color: var(--navy);
  margin: 0; font-weight: 400; cursor: pointer; padding: 1.2rem 0;
  display: flex; justify-content: space-between; align-items: center;
}
.menu-category h3::after {
  content: '+'; font-size: 1.4rem; color: var(--gold); font-weight: 300;
  transition: transform 0.3s;
}
.menu-category.open h3::after { transform: rotate(45deg); }
.menu-category .cat-content { display: none; padding-bottom: 1.5rem; }
.menu-category.open .cat-content { display: block; }
.menu-category .cat-desc {
  font-size: 0.9rem; color: rgba(44,74,115,0.5); margin-bottom: 1rem; font-style: italic;
}
.menu-item {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 0.7rem 0; border-bottom: 1px solid rgba(44,74,115,0.06);
  gap: 1rem;
}
.menu-item:last-child { border-bottom: none; }
.menu-item__info { flex: 1; }
.menu-item__name { font-weight: 500; color: var(--navy); font-size: 0.95rem; }
.menu-item__desc { font-size: 0.82rem; color: rgba(44,74,115,0.5); margin-top: 4px; display: block; }
.menu-item__tag {
  display: inline-block; font-size: 0.68rem; padding: 1px 6px; border-radius: 3px;
  font-weight: 600; letter-spacing: 0.03em; margin-left: 6px; vertical-align: middle;
}
.menu-tag--bestseller { background: #fef3cd; color: #856404; }
.menu-tag--new { background: #d4edda; color: #155724; }
.menu-tag--flag { background: #cce5ff; color: #004085; }
.menu-tag--premium { background: #f8d7da; color: #721c24; }
.menu-tag--only { background: #e2d5f1; color: #4a2076; }
.menu-item__price {
  font-family: var(--font-display); font-size: 1.15rem; color: var(--gold);
  white-space: nowrap; font-weight: 400;
}
.menu-item__pnote { font-size: 0.72rem; color: rgba(44,74,115,0.4); }
.menu-item__portion { font-size: 0.75rem; color: rgba(44,74,115,0.4); display: block; margin-top: 1px; }

/* ============================================================
   STICKY PHONE BAR
   ============================================================ */
.sticky-bar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 999;
  background: var(--navy); padding: 0;
  box-shadow: 0 -2px 20px rgba(0,0,0,0.2);
  display: flex; align-items: stretch;
}
.sticky-bar a {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 0.5rem;
  color: #fff; font-weight: 500; font-size: 0.88rem; letter-spacing: 0.05em;
  text-transform: uppercase; padding: 1rem; text-decoration: none;
  transition: background 0.2s;
}
.sticky-bar a:first-child { background: var(--gold); }
.sticky-bar a:first-child:hover { background: var(--gold-light); color: #fff; }
.sticky-bar a:last-child:hover { background: rgba(255,255,255,0.1); color: #fff; }
.sticky-bar svg { width: 18px; height: 18px; fill: currentColor; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; min-height: 92vh; min-height: 92dvh;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  padding: 6rem 2rem 3rem; overflow: hidden; text-align: center;
  background: var(--navy) url('/img/hero-spread.jpg') center/cover no-repeat;
}
.hero::before {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg,
    rgba(44,74,115,0.25) 0%, rgba(44,74,115,0.35) 40%,
    rgba(44,74,115,0.65) 75%, rgba(44,74,115,0.88) 100%);
}
.hero::after {
  content: ''; position: absolute; inset: 0; z-index: 2; opacity: 0.04; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px;
}
.hero-content { position: relative; z-index: 3; max-width: 720px; }
.since {
  display: inline-block;
  background: var(--gold); border: none;
  padding: 0.7rem 2.5rem; margin-bottom: 2rem; border-radius: 4px;
  font-family: var(--font-body); font-size: 0.85rem; font-style: normal;
  color: #fff; letter-spacing: 0.12em; font-weight: 500; text-transform: uppercase;
  box-shadow: 0 4px 15px rgba(0,0,0,0.3);
}
.hero h1 {
  font-size: clamp(2.4rem, 6vw, 4.2rem); color: #fff; font-weight: 300;
  margin-bottom: 1rem; letter-spacing: -0.02em; line-height: 1.1;
}
.hero h1 em { font-style: italic; color: var(--gold-light); }
.hero .tagline {
  font-family: var(--font-body); font-size: clamp(1rem, 1.8vw, 1.15rem);
  color: rgba(255,255,255,0.85); margin-bottom: 1.2rem;
  font-weight: 400; line-height: 1.7;
}
.hero .fomo {
  display: inline-block; font-family: var(--font-body); font-size: 0.9rem;
  color: #fff; margin-bottom: 2rem;
  font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  background: rgba(192,86,90,0.7); padding: 0.5rem 1.5rem; border-radius: 4px;
}
.hero-cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.85rem 2rem; font-weight: 500;
  font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase;
  transition: all 0.4s var(--ease-out); text-decoration: none;
}
.btn-primary {
  background: rgba(255,255,255,0.18); color: #fff;
  border: 1px solid rgba(255,255,255,0.45);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.btn-primary:hover { background: rgba(255,255,255,0.3); color: #fff; }
.btn-secondary {
  background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.9);
  border: 1px solid rgba(255,255,255,0.3);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.btn-secondary:hover { color: #fff; background: rgba(255,255,255,0.18); border-color: rgba(255,255,255,0.5); }
.btn-gold {
  background: var(--gold); color: #fff; border: none;
  padding: 0.9rem 2.4rem; font-size: 0.85rem;
}
.btn-gold:hover { background: var(--gold-light); color: #fff; transform: translateY(-2px); }

/* ============================================================
   MAKŁOWICZ BADGE
   ============================================================ */
.maklowicz-badge {
  background: var(--navy); padding: 2rem 1rem; text-align: center;
}
.maklowicz-badge p {
  font-family: var(--font-display); font-size: clamp(1.4rem, 3vw, 1.9rem); font-style: italic;
  color: #fff; max-width: 700px; margin: 0 auto; line-height: 1.4;
}
.maklowicz-badge .author {
  font-family: var(--font-body); font-style: normal;
  font-size: 0.9rem; color: var(--gold-light); font-weight: 500;
  letter-spacing: 0.08em; margin-top: 0.6rem; display: block; text-transform: uppercase;
}

/* ============================================================
   FOOD STRIP
   ============================================================ */
.food-strip { background: var(--navy); padding: 0; overflow: hidden; }
.food-strip__track {
  display: flex; gap: 4px; animation: scroll-strip 40s linear infinite; width: max-content;
}
.food-strip__item { flex: 0 0 260px; height: 180px; overflow: hidden; }
.food-strip__item img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(0.85); transition: filter 0.4s, transform 0.4s;
}
.food-strip__item:hover img { filter: saturate(1); transform: scale(1.05); }
@keyframes scroll-strip {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ============================================================
   SECTIONS
   ============================================================ */
section { padding: 5rem 0; scroll-margin-top: 60px; }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); margin-bottom: 1.5rem; color: var(--navy); text-align: center; }
h2 span { color: var(--gold); }
.lead { font-size: 1.1rem; max-width: 750px; margin: 0 auto 2.5rem; text-align: center; color: rgba(44,74,115,0.7); font-weight: 300; }

/* INTRO */
.intro { background: var(--paper); }
.intro-body { max-width: 800px; margin: 2rem auto 0; font-size: 1.1rem; color: var(--navy); font-weight: 400; }
.intro-body p { margin-bottom: 1.2rem; line-height: 1.8; }
.intro-body strong { color: var(--navy); font-weight: 600; }
.intro-body a { color: var(--navy); font-weight: 600; border-bottom: 2px solid var(--gold); }
.city-guide { margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid rgba(44,74,115,0.1); }
.city-guide h3 { font-family: var(--font-display); font-size: 1.3rem; color: var(--navy); margin: 1.5rem 0 0.8rem; }
.city-guide ul { list-style: none; padding: 0; }
.city-guide li { padding: 0.4rem 0 0.4rem 1.5rem; position: relative; color: var(--navy); }
.city-guide li::before { content: '\2022'; color: var(--gold); position: absolute; left: 0; font-size: 1.2rem; }

/* HISTORY */
.history { background: #fff; }
.history-timeline {
  max-width: 700px; margin: 2.5rem auto 0; position: relative;
  padding-left: 2.5rem; border-left: 2px solid var(--gold-light);
}
.history-item {
  position: relative; margin-bottom: 2.5rem; padding-left: 1rem;
}
.history-item::before {
  content: ''; position: absolute; left: -2.95rem; top: 0.4rem;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--gold); border: 2px solid #fff;
}
.history-item .year {
  font-family: var(--font-display); font-size: 1.4rem; color: var(--gold);
  font-weight: 400; margin-bottom: 0.3rem;
}
.history-item p {
  color: var(--navy); font-size: 1rem; line-height: 1.7;
}

/* SPECIALTY */
.specialty { background: var(--sand); }
.specialty-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; margin-top: 2rem; }
.specialty-item {
  background: #fff; padding: 28px 24px; border-radius: 6px;
  border-left: 3px solid var(--gold);
  box-shadow: 0 2px 12px rgba(44,74,115,0.06);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s;
}
.specialty-item:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(44,74,115,0.1); }
.specialty-item h3 { color: var(--navy); margin-bottom: 8px; font-size: 1.15rem; }
.specialty-item p { color: rgba(44,74,115,0.65); font-size: 0.95rem; }

/* ROUTE + MAP */
.route { background: #fff; }
.route-map { position: relative; margin-bottom: 1.5rem; text-align: center; }
.route-map iframe { width: 100%; height: 420px; border: 0; border-radius: 8px; box-shadow: 0 4px 20px rgba(44,74,115,0.1); }
.route-nav-btn { display: inline-flex; margin-top: 1.2rem; font-size: 0.9rem; padding: 1rem 2.8rem; }
.route-legend {
  display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap;
  margin-top: 1rem; font-size: 0.85rem; color: var(--navy);
}
.route-legend span { display: flex; align-items: center; gap: 0.4rem; }
.route-legend .dot {
  width: 12px; height: 12px; border-radius: 50%; display: inline-block;
}
.route-legend .dot--kg { background: #c0392b; }
.route-legend .dot--park { background: #2980b9; }
.route-box { background: var(--sand); padding: 2rem; border-radius: 8px; margin: 1.5rem 0; border-left: 5px solid var(--navy); }
.route-box h3 { color: var(--navy); margin-bottom: 0.8rem; font-size: 1.1rem; }
.route-box p { margin-bottom: 0.5rem; }
.route-box strong { color: var(--navy); }

/* GALLERY */
.gallery { background: #fff; padding: 5rem 0; }
.gallery h2 { margin-bottom: 0.5rem; }
.gallery-subtitle { text-align: center; font-family: var(--font-display); font-style: italic; color: rgba(44,74,115,0.5); font-size: 1.1rem; margin-bottom: 2.5rem; }
.gallery-grid { columns: 3; column-gap: 12px; max-width: 1000px; margin: 0 auto; }
.gallery-item { break-inside: avoid; margin-bottom: 12px; overflow: hidden; border-radius: 6px; cursor: pointer; position: relative; }
.gallery-item img { width: 100%; display: block; transition: transform 0.5s var(--ease-out), filter 0.5s; filter: saturate(0.9); }
.gallery-item:hover img { transform: scale(1.03); filter: saturate(1); }
.gallery-item figcaption {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 2rem 1rem 0.8rem; background: linear-gradient(transparent, rgba(44,74,115,0.75));
  color: #fff; font-size: 0.82rem; font-weight: 400; opacity: 0; transition: opacity 0.4s;
}
.gallery-item:hover figcaption { opacity: 1; }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews { background: var(--sand); }
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; margin-top: 2rem; }
.review-card {
  background: #fff; padding: 2rem; border-radius: 8px;
  box-shadow: 0 2px 12px rgba(44,74,115,0.05); position: relative;
}
.review-card::before {
  content: '\201E'; position: absolute; top: 0.5rem; left: 1.2rem;
  font-family: var(--font-display); font-size: 3.5rem; color: var(--gold-light); opacity: 0.4; line-height: 1;
}
.review-card p { font-style: italic; color: var(--navy); margin-bottom: 1rem; padding-top: 1.5rem; font-size: 0.98rem; line-height: 1.7; }
.review-card .review-author { font-style: normal; font-size: 0.82rem; color: var(--gold); font-weight: 500; }
.review-card .review-stars { color: var(--gold); font-size: 0.9rem; margin-bottom: 0.3rem; }
.reviews-badge {
  text-align: center; margin-top: 2.5rem; display: flex; gap: 2rem; justify-content: center; flex-wrap: wrap;
}
.reviews-badge-item {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.85rem; color: var(--navy); font-weight: 500;
}
.reviews-badge-item .badge-score {
  font-family: var(--font-display); font-size: 1.8rem; font-weight: 400; color: var(--gold);
}

/* WHY US */
.why { background: var(--navy); color: #fff; }
.why h2 { color: #fff; }
.why h2 span { color: var(--gold-light); }
.why-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; margin-top: 2rem; }
.why-item {
  padding: 2rem 1.5rem; background: rgba(255,255,255,0.06); border-radius: 6px; text-align: center;
  transition: background 0.3s;
}
.why-item:hover { background: rgba(255,255,255,0.1); }
.why-item .num { font-family: var(--font-display); font-size: 2.5rem; color: var(--gold-light); font-weight: 300; display: block; margin-bottom: 0.5rem; }
.why-item strong { font-size: 0.95rem; letter-spacing: 0.03em; }
.why-item p { margin-top: 0.5rem; color: rgba(255,255,255,0.6); font-size: 0.9rem; }

/* PRICING */
.pricing { background: var(--paper); }
.pricing-examples {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px; max-width: 800px; margin: 2rem auto 0;
}
.pricing-card {
  background: var(--sand); padding: 1.5rem; border-radius: 8px; text-align: center;
}
.pricing-card h3 { font-size: 1.1rem; color: var(--navy); margin-bottom: 0.5rem; }
.pricing-card .price-tag {
  font-family: var(--font-display); font-size: 2rem; color: var(--gold); font-weight: 400;
  margin: 0.5rem 0;
}
.pricing-card p { font-size: 0.88rem; color: rgba(44,74,115,0.6); }

/* FAQ */
.faq { background: var(--paper); }
.faq-item { background: var(--sand); margin-bottom: 12px; border-radius: 6px; border-left: 3px solid var(--gold); }
.faq-item summary { padding: 1.2rem 1.5rem; cursor: pointer; font-weight: 500; color: var(--navy); font-size: 1.02rem; list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: '+'; float: right; font-size: 1.3rem; color: var(--gold); font-weight: 300; transition: transform 0.3s; }
.faq-item[open] summary::before { transform: rotate(45deg); }
.faq-item[open] summary { border-bottom: 1px solid rgba(44,74,115,0.1); }
.faq-item p { padding: 1rem 1.5rem 1.2rem; color: rgba(44,74,115,0.7); }

/* CONTACT */
.contact { background: var(--sand); }
.contact-box {
  background: #fff; padding: 2.5rem; border-radius: 8px;
  max-width: 750px; margin: 0 auto; text-align: center;
  box-shadow: 0 4px 24px rgba(44,74,115,0.07);
}
.contact-box h3 { color: var(--navy); margin-bottom: 1.2rem; font-size: 1.4rem; }
.contact-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1.5rem; margin: 1.5rem 0; }
.contact-item { text-align: center; }
.contact-item strong { color: var(--navy); display: block; margin-bottom: 4px; font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; }
.contact-item a { color: var(--navy); font-size: 1.05rem; }
.contact-item a:hover { color: var(--gold); }
.practical-info {
  display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap;
  margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--sand);
}
.practical-info span {
  font-size: 0.82rem; color: rgba(44,74,115,0.6); display: flex; align-items: center; gap: 0.3rem;
}

/* SOCIAL */
.social-links {
  display: flex; gap: 1.2rem; justify-content: center; margin-top: 1.2rem;
}
.social-links a {
  display: flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 1rem; background: var(--sand); border-radius: 4px;
  color: var(--navy); font-size: 0.82rem; font-weight: 500;
  transition: background 0.2s, color 0.2s;
}
.social-links a:hover { background: var(--navy); color: #fff; }

/* FOOTER */
footer { background: #1a2d44; color: rgba(255,255,255,0.45); padding: 2.5rem 0; text-align: center; font-size: 0.85rem; }
footer a { color: var(--gold-light); }
footer p { margin: 0.5rem 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  section { padding: 3.5rem 0; }
  body { padding-top: 48px; }
  .hero { min-height: 80vh; padding: 5rem 1.5rem 2.5rem; }
  .top-nav__inner { height: 48px; padding: 0 1rem; }
  .top-nav__links { display: none; }
  .top-nav__brand small { display: none; }
  .food-strip__item { flex: 0 0 200px; height: 140px; }
  .gallery-grid { columns: 2; column-gap: 8px; }
  .gallery-item { margin-bottom: 8px; }
  .route-map iframe { height: 320px; }
  .reviews-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .hero { min-height: 75vh; }
  .hero h1 { font-size: 2rem; }
  .gallery-grid { columns: 1; }
  .btn { padding: 0.75rem 1.5rem; font-size: 0.78rem; }
  .specialty-grid { grid-template-columns: 1fr; }
  .pricing-examples { grid-template-columns: 1fr; }
}
@media (min-width: 769px) {
  .sticky-bar a { font-size: 0.92rem; padding: 0.85rem 2rem; }
}

/* YouTube facade */
.yt-facade { position:absolute;top:0;left:0;width:100%;height:100%;cursor:pointer; }
.yt-facade img { position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover; }