

/* --- Fonts --- */
@font-face {
  font-family: 'Satoshi';
  src: url('fonts/satoshi-medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Azeret Mono';
  src: url('fonts/azeret-mono-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* --- Color Themes — uncomment one block to swap ---

  ORIGINAL TERRACOTTA:  --fg: #b84b30;  --bg: #f8f4e9;  --accent: #5f1d1a;
  BLACK:                --fg: #1a1a1a;  --bg: #f8f4e9;  --accent: #000;
  NAVY:                 --fg: #1b2a4a;  --bg: #f0ece3;  --accent: #0d1b2a;
  FOREST:               --fg: #2d5016;  --bg: #f2f0e6;  --accent: #1a3009;
  JOBSE BROWN:          --fg: #4a2115;  --bg: #f4f0e6;  --accent: #2e1409;
*/
:root {
  --terracotta: #b84b30;

  --blue: #427ade;
  --light-blue: #d7e6f6;
  --cream: #fffded;
  --red: #5f1d1a;
  --black: #000;
  --white: #fff;
  --yellow: #ffde00;
  --red: #cc2c39;
  --green: #689079;
  --hero-bg: var(--blue);
  --hero-text: var(--cream);
  --swiper-theme-color: var(--blue);

  --gutter: 20px;
  --radius: 0.875rem;
  --font-sans: 'Satoshi', -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-mono: 'Azeret Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.cream{color: var(--cream);}

/* --- Reset --- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; background: none; border: none; color: inherit; }
ul, ol { list-style: none; }
address { font-style: normal; }

body {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.35;
  background: var(--cream);
  color: var(--blue);
  overflow-x: hidden;
}

::selection { background: color-mix(in srgb, var(--blue) 90%, transparent); color: var(--cream); }
.sel-inv::selection, .sel-inv *::selection { background: var(--white); color: var(--blue); }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

svg .fill-current { fill: currentColor; }
svg .fill-wavy { fill: var(--blue); fill: var(--cream); }
.text-xl { font-size: 1.25rem; line-height: 1.25; }
svg text { font-family: var(--font-sans); font-size: 1.25rem; text-transform: uppercase; /* letter-spacing: 0.025em; */ }

/* --- Layout --- */
.container {
  width: 100%;
  max-width: 2000px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  column-gap: var(--gutter);
}

/* --- Typography --- */
.text-sm { font-size: 0.9375rem; line-height: 1.35; }
.text-base { font-size: 1rem; line-height: 1.35; }
.text-lg { font-size: 1.0625rem; line-height: 1.2; }
.text-xl { font-size: 1.25rem; line-height: 1.25; }
.text-2xl { font-size: 2.25rem; line-height: 1.2; }
.uppercase { text-transform: uppercase; }
.tracking-tight { /* letter-spacing: -0.025em; */ }
.tracking-wide { /* letter-spacing: 0.025em; */ }
.tracking-wider { /* letter-spacing: 0.05em; */ }
.tracking-widest { /* letter-spacing: 0.1em; */ }
.font-mono { font-family: var(--font-mono); }
.text-center { text-align: center; }

/* --- Pill Button --- */
.pill-btn {
  display: inline-flex;
  position: relative;
  font-size: 0.9375rem;
  text-transform: uppercase;
  /* letter-spacing: 0.1em; */
  
}
.pill-btn__label {
  border: 2px solid var(--blue);
  border-radius: 9999px;
  padding: 0.75rem 4rem;
  text-align: center;
  min-width: 15.25rem;
  background: var(--cream);
  position: relative;
  z-index: 1;
  transition: transform 0.2s ease;
  font-family: var(--font-mono);
}
.pill-btn:hover .pill-btn__label {
  transform: translate(2px, 2px);
}
.pill-btn__shadow {
  position: absolute;
  top: 4px; left: 4px;
  width: 100%; height: 100%;
  background: var(--blue);
  border-radius: 9999px;
  pointer-events: none;
}

/* Circle nav buttons */
.circle-btn {
  display: inline-flex;
  position: relative;
}
.circle-btn__inner {
  width: 2.5rem; height: 2.5rem;
  border: 2px solid var(--blue);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cream);
  position: relative;
  z-index: 1;
  transition: transform 0.1s ease;
}
.circle-btn:hover .circle-btn__inner {
  transform: translate(2px, 2px);
}
.circle-btn__shadow {
  position: absolute;
  top: 2px; left: 2px;
  width: 100%; height: 100%;
  background: var(--blue);
  border-radius: 50%;
  pointer-events: none;
}
.circle-btn svg { width: 0.875rem; height: 0.875rem; }
.circle-btn--prev svg { transform: rotate(180deg); }

/* --- Header --- */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 40;
}
.header-bar {
  position: relative;
  z-index: 41;
  background: transparent;
  border-bottom: 2px solid var(--blue);
  transition: background-color 0.2s, color 0.2s;
}
.header-bar.scrolled { background: var(--cream); }
.header-inner {
  display: flex;
  align-items: center;
  position: relative;
  height: 3rem;
}
.header-menu-btn {
  font-size: 0.9375rem;
  /* letter-spacing: 0.1em; */
  text-transform: uppercase;
  height: 100%;
  transition: color 0.2s;
}
.header-logo {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  transition: color 0.2s;
}
.header-logo svg { display: block; width: 9rem; height: auto; }
.header-logo svg path { fill: currentColor; }
.header-book {
  margin-left: auto;
 
  text-transform: uppercase;
  transition: color 0.2s;
  display: none;
}

@media (min-width: 520px) {
  .header-book { display: block; font-size:13px; }
}

@media (min-width: 768px) {
  .header-book {  font-size: 0.9375rem;
    /* letter-spacing: 0.1em; */ }
}

/* Header color states */
.header-bar:not(.scrolled) .header-menu-btn,
.header-bar:not(.scrolled) .header-logo,
.header-bar:not(.scrolled) .header-book { color: var(--hero-text); }
.header-bar.scrolled .header-menu-btn,
.header-bar.scrolled .header-logo,
.header-bar.scrolled .header-book { color: var(--blue); }

/* --- Nav Drawer --- */
.nav-drawer {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100dvh;
  z-index: 50;
  transform: translateX(-100%);
  transition: transform 0.4s cubic-bezier(0.65,0,0.35,1);
}
.nav-drawer.open { transform: translateX(0); }

.nav-drawer__panel {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  background: var(--cream);
  padding: 4rem 1.25rem 1.25rem;
  overflow-y: auto;
  position: relative;
  z-index: 2;
}
.nav-drawer__close {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  text-align: left;
  padding: 1.25rem;
  font-size: 0.9375rem;
  /* letter-spacing: 0.1em; */
  text-transform: uppercase;
  background: var(--cream);
  z-index: 3;
}
.nav-drawer__links { display: flex; flex-direction: column; gap: 0.5rem; }
.nav-drawer__links a,
.nav-drawer__links button {
  font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  text-transform: uppercase;
  text-align: left;
  display: flex;
}
.nav-drawer__social { margin-top: 5rem; }
.nav-drawer__social a { display: inline-flex; }
.nav-drawer__social svg { width: 1.25rem; height: 1.25rem; }

.nav-overlay {
  position: fixed;
  z-index: 49;
  inset: 0;
  background: rgba(0,0,0,0.4);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.nav-overlay.visible { opacity: 1; pointer-events: auto; }

/* Menu accordions (mobile nav) */
.menu-accordion { border-bottom: 2px solid var(--blue); }
.menu-accordion summary {
  list-style: none;
  padding: 1rem 0;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  text-transform: uppercase;
  outline: none;
}
.menu-accordion summary::-webkit-details-marker { display: none; }
.menu-accordion .toggle-icon {
  position: relative;
  width: 1rem; height: 1rem;
  flex-shrink: 0;
  margin-left: 1rem;
}
.toggle-icon__h, .toggle-icon__v {
  position: absolute;
  background: var(--blue);
}
.toggle-icon__h {
  top: 50%; left: 0; right: 0;
  height: 2px;
  transform: translateY(-1px);
}
.toggle-icon__v {
  left: 50%; top: 0; bottom: 0;
  width: 2px;
  transform: translateX(-1px);
}
details[open] .toggle-icon__v { display: none; }
.menu-accordion .accordion-items {
  padding: 0 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

/* --- Hero --- */
.hero {
  background: var(--hero-bg);
  color: var(--hero-text);
  padding: 4rem 0;
  position: relative;
  overflow: hidden;
  /* color: var(--blue); */
  /* background: var(--cream); */
}
.hero .grid {
  height: 100%;
  row-gap: 0;
}
.hero-info {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1rem;
  padding: 2rem 0;
  font-size:16px;
  /* font-size: 1.0625rem;
  /* letter-spacing: 0.05em; */
  /* text-transform: uppercase; */
  font-family: var(--font-sans);
}
.hero-lottie {
  grid-column: 1 / -1;
  display: flex;
  justify-content: center;
  position: relative;
}
.hero-lottie .lottie-anim {
  position: relative;
}
.hero-wheat {
  width: 280px;
  height: auto;
  color: var(--cream);
  color: var(--blue);
}
.hero-wheat svg { width: 100%; height: auto; }
.hero-wheat svg path { fill: currentColor; }
.hero-wavy {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, 65%);
  width: 677px; height: 195px;
  overflow: hidden;
}
.hero-wavy svg {
  position: absolute;
  top: 0; left: 0;
  width: 1355px; height: 195px;
  pointer-events: none;
  user-select: none;
}
.hero-scroll {
  grid-column: 1 / -1;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.9375rem;
  /* letter-spacing: -0.025em; */
  max-width: 20ch;
  margin: 0 auto;
  padding-top: 3rem;
}

/* --- Carousel Section --- */
.carousel-section {
  transform: translateY(-3rem);
  margin-bottom: -3rem;
  z-index: 1;
}
.carousel-section .col-main {
  grid-column: 1 / -1;
}
.carousel-wrap {
  position: relative;
}
.carousel-swiper {
  aspect-ratio: 16 / 9;
  border-radius: var(--radius);
  border: 2px solid var(--blue);
  overflow: hidden;
  background: var(--blue);
}
.carousel-swiper img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.carousel-nav {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  padding-top: 1rem;
}

/* --- Content Sections --- */
.section {
  border-bottom: 2px solid var(--blue);
  padding: 4rem 0;
  position: relative;
}
.section:first-child { border-bottom: none; }
.section:last-child { border-bottom: none; }

/* Intro section */
.intro-section .col-main {
  grid-column: 1 / -1;
  text-align: center;
}
.intro-lottie {
  display: flex;
  justify-content: center;
  padding-bottom: 1rem;
}
.intro-text {
  /* font-size: 1.25rem; */
  /* letter-spacing: 0.025em; */
  /* text-transform: uppercase; */
  max-width: 70ch;
  margin: 0 auto;
}
.intro-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  padding-top: 2rem;
}

/* Card sections */
.card-section {
  border-bottom: 2px solid var(--blue);
  padding: 1rem 0 4rem;
  overflow: hidden;
}
.card-section .grid { row-gap: 0; }
.card-section__swiper {
  grid-column: 1 / -1;
  order: 2;
  padding-top: 1.5rem;
}
.card-section__swiper-inner { margin: 0 3rem; }
.card-section__text {
  grid-column: 1 / -1;
  order: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}
.card-section__prose {
  font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  /* text-transform: uppercase; */
  /* text-align: center; */
  max-width: 34ch;
}
.card-section__prose p {text-transform: none;margin-top:1rem;}

.card-swiper-wrap { position: relative; }
.card-swiper {
  overflow: visible;
}
.card-swiper .swiper-slide:not(.swiper-slide-active) {
  pointer-events: none;
}
.card-swiper .swiper-slide {
  aspect-ratio: 8 / 9;
  border-radius: var(--radius);
  overflow: hidden;
  border: 2px solid var(--blue);
  background: var(--blue);
}
.card-swiper img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.card-nav {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  padding-top: 1.25rem;
}

/* --- Menu Section --- */
.menu-section {
  padding: 0;
}
.menu-section .grid {
  row-gap: 0;
}
.menu-col {
  grid-column: 1 / -1;
}
.menu-category-title {
  font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  text-transform: uppercase;
  padding-bottom: 0.75rem;
  display: none;
}

/* Desktop menu */
.menu-desktop { display: none; }
.menu-desktop ul {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.menu-desktop .two-col {
  display: none;
}

/* Mobile menu */
.menu-mobile { display: block; }

/* Menu item */
.menu-item {
  display: flex;
  justify-content: space-between;
}
.menu-item__name {
  font-size: 0.9375rem;
  /* letter-spacing: 0.05em; */
  text-transform: uppercase;
  font-weight: normal;
}
.menu-item__desc {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  /* letter-spacing: -0.025em; */
  max-width: 42ch;
  text-transform: none;
}
.menu-item__dietary {
  font-size: 0.75rem;
  font-family: var(--font-mono);
  padding-top: 0.25rem;
}
.menu-item__price {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  /* letter-spacing: -0.025em; */
  text-align: right;
  padding-left: 1.5rem;
  flex-shrink: 0;
}

.menu-subheading {
  font-size: 0.9375rem;
  /* letter-spacing: 0.05em; */
  text-transform: uppercase;
  font-weight: normal;
  padding-top: 0.5rem;
  opacity: 0.7;
}

.menu-lottie {
  display: none;
}

/* --- Pand label --- */
.pand-label {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  text-transform: uppercase;
  /* letter-spacing: 0.1em; */
  opacity: 0.6;
  margin-bottom: 0.5rem;
}

/* --- Instagram Section --- */
.insta-section { padding: 3rem 0 4rem; }
.insta-section .col-main { grid-column: 1 / -1; }
.insta-title {
  font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  /* text-transform: uppercase; */
  padding-bottom: 1.5rem;
  text-align: center;
}
.insta-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--gutter);
}
.insta-item {
  border-radius: var(--radius);
  border: 2px solid var(--blue);
  overflow: hidden;
  background: var(--blue);
  aspect-ratio: 1;
}
.insta-item img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.insta-cta {
  display: flex;
  justify-content: center;
  padding-top: 2rem;
}

/* --- Newsletter Section --- */
.newsletter-section .col-main {
  grid-column: 1 / -1;
  text-align: center;
}
.newsletter-text {
  font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  text-transform: uppercase;
  max-width: 26ch;
  margin: 0 auto;
}
.newsletter-form {
  padding-top: 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  align-items: center;
  max-width: 28rem;
  margin: 0 auto;
}
.newsletter-form input {
  width: 100%;
  border: 2px solid var(--blue);
  border-radius: 9999px;
  padding: 0.75rem 1.5rem;
  font-family: var(--font-mono);
  font-size: 0.9375rem;
  /* letter-spacing: -0.025em; */
  background: var(--cream);
  color: var(--blue);
  outline: none;
}
.newsletter-form input::placeholder { color: var(--blue); opacity: 0.5; }
.newsletter-form input:focus { box-shadow: 0 0 0 1px var(--blue); }
.newsletter-form .pill-btn { margin-top: 0.5rem; }

/* --- Footer --- */
.site-footer {
  background: var(--hero-bg);
  color: var(--hero-text);
  padding: 4rem 0 1rem;
  position: relative;
}
.footer-wavy {
  width: 100%;
  height: 195px;
  overflow: hidden;
}
.footer-wavy svg {
  width: 1355px;
  height: 195px;
  pointer-events: none;
}
.footer-grid {
  row-gap: 3rem;
}
.footer-col {
  grid-column: 1 / -1;
  text-align: center;
}
.footer-col h2, .footer-col h3 {
  font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  /* text-transform: uppercase; */
  padding-bottom: 1rem;
  font-weight: normal;
}
.footer-col p, .footer-col address, .footer-col a {
  font-size: 1rem;
  line-height: 1.35;
  /* letter-spacing: 0.05em; */
  font-family: var(--font-mono);
  /* text-transform: uppercase; */
}
.footer-col .space-y > * + * { margin-top: 1rem; }
.footer-col a:hover { opacity: 0.7; }
.footer-social {
  display: flex;
  gap: 1.25rem;
  justify-content: center;
  margin-top: 1rem;
}
.footer-social svg { width: 1.25rem; height: 1.25rem; }

.footer-lottie {
  grid-column: 1 / -1;
  display: flex;
  justify-content: center;
  padding-top: 2rem;
}

.footer-bottom {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding-top: 1rem;
  font-family: var(--font-mono);
  font-size: 0.9375rem;
  /* letter-spacing: -0.025em; */
  color: var(--cream);
  color: var(--hero-text);
  text-align: center;
}
.footer-bottom a:hover { opacity: 0.7; }

.footer-bottom a{font-size: smaller;}

/* Lottie animations */
.lottie-anim { display: flex; align-items: center; justify-content: center; }
.lottie-anim svg { width: 100%; height: 100%; }

/* Hero pastry: 720x680 original */
.hero-lottie .lottie-anim { width: 306px; height: 290px; }
/* Hello-smile: 770x340 */
.intro-lottie .lottie-anim { width: 200px; height: 88px; }
/* Coffee: 680x640 */
.card-section__text .lottie-anim { width: 180px; height: 170px; }
.card-illustration { color: var(--blue); width: 180px; }
.card-section--b .card-illustration { width: 360px; }
.card-illustration svg { width: 100%; height: auto; }
.card-illustration svg path { fill: currentColor; }
/* Menu coffee-cup: 640x390 */
.menu-lottie .lottie-anim { width: 163px; height: 100px; }
/* Footer: 1920x660 */
.footer-lottie .lottie-anim { width: 345px; height: 119px; }

/* Body state: drawer open */
body.drawer-open { overflow: hidden; }

.intro-text p { margin-top: 1rem; text-align: left; font-size: 1.25rem; }
h2 { font-size: 1.5rem; text-align: left; }
/* Wheat on top + centered on mobile in intro section */
.intro-section { display: flex; flex-direction: column-reverse; }
.intro-section .hero-wheat { margin: 0 auto 1.5rem; }

/* ============================================
   DESKTOP (1024px+)
   ============================================ */
@media (min-width: 1024px) {
  .grid {
    grid-template-columns: repeat(12, 1fr);
  }
  .container {
    padding: 0 2.5rem;
  }

  /* Header */
  .header-bar { border-bottom: none; }
  .header-inner { height: 5rem; }
  .header-logo svg { width: 14rem; }
  .header-logo { transition: none; }
  .header-logo svg { will-change: width; }


  /* Desktop: header is always transparent, color swaps via data-nav-colour */
  .header-bar { background: transparent !important; }

  /* Over hero/footer: header matches hero text color */
  body:not([data-nav-colour="dark"]) .header-bar .header-menu-btn,
  body:not([data-nav-colour="dark"]) .header-bar .header-logo,
  body:not([data-nav-colour="dark"]) .header-bar .header-book { color: var(--hero-text); }

  /* Over content sections (cream bg): header is blue */
  body[data-nav-colour="dark"] .header-bar .header-menu-btn,
  body[data-nav-colour="dark"] .header-bar .header-logo,
  body[data-nav-colour="dark"] .header-bar .header-book { color: var(--blue); }

  /* Nav drawer */
  .nav-drawer__panel {
    width: 30rem;
    border-right: 2px solid var(--blue);
    padding-top: 6rem;
  }
  .nav-drawer__close {
    width: 30rem;
    border-right: 2px solid var(--blue);
  }
  .nav-drawer__links a,
  .nav-drawer__links button {
    font-size: 2.5rem;
    /* letter-spacing: 0.025em; */
  }

  /* Hero */
  .hero {
    height: 54dvh;
    height:350px;
    padding: 8rem 0;
  }
  .hero-info {
    grid-column: 2 / span 10;
    flex-direction: row;
    justify-content: space-between;
    padding: 0;
    font-size: 1rem;
    font-family: var(--font-mono);
  }
  .hero-info > :first-child { transform: translateX(-4rem); max-width: 160px;}
  .hero-info > :last-child { transform: translateX(4rem); max-width: 160px;}
  .hero-lottie {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -65%);
    flex-direction: row;
  }
  .hero-lottie .lottie-anim { width: 360px; height: 340px; }
  .hero-wheat {
    width: 500px;
    position: absolute;
    bottom: 100px;
    left: -80px;
}
  .hero-scroll {
    position: absolute;
    left: 0; right: 0;
    bottom: 7rem;
    padding-top: 0;
  }

  /* Carousel */
  .carousel-section {
    transform: translateY(-6rem);
    margin-bottom: -5rem;
  }
  .carousel-section .col-main {
    grid-column: 2 / span 10;
    max-width: 75%;
    margin: 0 auto;
  }

  /* Sections */
  .section { padding: 9rem 0; }

  /* Intro */
  .intro-section { display: block; }
  .intro-section .hero-wheat { margin: 0; }
  h2 { text-align: left; }
  .intro-section .col-main {
    grid-column: 3 / span 8;
  }
  .intro-lottie { padding-bottom: 3.5rem; }
  .intro-lottie .lottie-anim { width: 274px; height: 121px; }
 .intro-text h2, .intro-text h1 { font-size: 2.25rem; text-align:center;}
 .intro-text p {font-size: 1.25rem;
  /* letter-spacing: 0.025em; */
  text-align: center; }
  .intro-cta {
    gap: var(--gutter);
    padding-top: 3.5rem;
  }

  /* Card sections */
  .card-section__prose { font-size: 1.25rem; }
  .card-section { padding: 9rem 0; overflow: hidden; }
  .card-section .grid { row-gap: 0; }
  .card-section__swiper {
    grid-column: 2 / span 5;
    order: unset;
    padding-top: 2rem;
  }
  .card-section__swiper-inner { margin: 0; }
  .card-section__text {
    grid-column: 8 / span 4;
    grid-row: 1;
    order: unset;
    justify-content: center;
    gap: 2rem;
  }
  .card-section__text .lottie-anim { width: 260px; height: 245px; }
  .card-illustration { width: 260px; }
  .card-section--b .card-illustration { width: 480px; }
  /* Section B: reversed */
  .card-section--b .card-section__swiper { grid-column: 7 / span 5; }
  .card-section--b .card-section__text { grid-column: 2 / span 4; }

  /* Menu */
  .menu-section .grid {
    row-gap: 3rem;
  }
  .menu-section { padding: 9rem 0; }
  .menu-col { grid-column: span 4; }
  .menu-category-title { display: block; font-size: 2.25rem; padding-bottom: 2.5rem; }
  .menu-desktop { display: block; }
  .menu-desktop ul { gap: 2rem; }
  .menu-desktop .two-col {
    display: flex;
    gap: 4rem;
    padding-right: 2.5rem;
  }
  .menu-desktop .two-col ul { flex: 1; }

  /* All Day Menu spans full width on desktop */
  .menu-section .menu-col[style*="grid-column: 1 / -1"] {
    grid-column: 1 / -1;
  }
  .menu-section .menu-col:not([style]) {
    grid-column: span 4;
  }
  .menu-mobile { display: none; }
  .menu-item__name { font-size: 1.0625rem; }
  .menu-item__desc { font-size: 1rem; max-width: 38ch; }
  .menu-item__price { font-size: 1rem; }
  .menu-lottie {
    display: flex;
    position: absolute;
    bottom: -3rem;
    right: 7rem;
  }
  .menu-lottie .lottie-anim { width: 163px; height: 100px; }

  /* Instagram */
  .insta-section { padding: 9rem 0; }
  .insta-title {  font-size: 2.25rem; padding-bottom: 2rem; }
  .insta-grid { grid-template-columns: repeat(6, 1fr); }
  .insta-cta { padding-top: 3rem; }

  /* Newsletter */
  .newsletter-text { font-size: 2.25rem; }
  .newsletter-form {
    padding-top: 3.5rem;
    flex-direction: row;
    max-width: none;
    justify-content: center;
  }
  .newsletter-form input { width: auto; min-width: 14rem; }

  /* Footer */
  .site-footer { padding-top: 8rem; }
  .footer-col:nth-child(1) { grid-column: 1 / span 3; }
  .footer-col:nth-child(2) { grid-column: 5 / span 4; }
  .footer-col:nth-child(3) { grid-column: 10 / span 3; }
  .footer-col h2, .footer-col h3 { font-size: 2.25rem; padding-bottom: 2rem; }
  .footer-col p, .footer-col address, .footer-col a {
    font-size: 1.0625rem;
    /* letter-spacing: 0.05em; */
  }
  .footer-lottie { padding-top: 4rem; padding-bottom: 1rem; }
  .footer-lottie .lottie-anim { width: 690px; height: 237px; }
  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}

/* Wavy text — scroll-driven, no CSS animation */
