/* ============================================================
   CAFÉ MENU — page-specific styles
   Extends main.css (all tokens, components, and animations
   are inherited from the shared stylesheet)
   ============================================================ */

/* Non-card content should settle straight — override the default -1deg comic-reveal rotation
   for layout containers that hold flowing text rather than tiltable card elements */
.menu-section__header.comic-reveal.is-visible,
.visit-cta .comic-reveal.is-visible {
  transform:scale(1) rotate(0deg);
}

/* Active nav link highlight */
.nav__link--active {
  color:white !important;
  background:var(--color-blue) !important;
  border-color:var(--color-warm-black) !important;
  box-shadow:2px 2px 0 var(--color-warm-black) !important;
  transform:rotate(-1.5deg);
}

/* ============================================================
   1. MENU HERO — split layout: text left, image right
   ============================================================ */
.menu-hero {
  padding:var(--space-3xl) 0 var(--space-xl);
}
.menu-hero__grid {
  display:grid;
  grid-template-columns:1fr;
  gap:var(--space-xl);
  align-items:center;
}
@media (min-width:900px) {
  .menu-hero__grid {
    grid-template-columns:1fr 1fr;
    gap:var(--space-3xl);
  }
}
.menu-hero__eyebrow {
  color:var(--color-red);
}
.menu-hero__heading {
  font-family:var(--font-display);
  font-size:var(--text-4xl);
  font-weight:var(--weight-black);
  line-height:1.08;
  color:var(--color-warm-black);
  margin-bottom:var(--space-md);
  letter-spacing:-0.02em;
}
@media (min-width:900px) {
  .menu-hero__heading { font-size:var(--text-5xl); }
}
.menu-hero__heading em {
  font-style:normal;
  color:var(--color-blue);
}
.menu-hero__body {
  font-size:var(--text-base);
  color:var(--color-warm-black);
  line-height:var(--leading-relaxed);
  max-width:50ch;
  margin-bottom:var(--space-md);
}
.menu-hero__allergen {
  font-size:var(--text-base);
  color:var(--color-grey-dark);
  line-height:var(--leading-relaxed);
  margin-bottom:var(--space-lg);
}
.menu-hero__image {
  border:4px solid var(--color-warm-black);
  border-radius:var(--radius-lg);
  box-shadow:5px 5px 0 var(--color-warm-black);
  overflow:hidden;
  aspect-ratio:4/3;
  transform:rotate(1.2deg);
}
.menu-hero__image img {
  width:100%;
  height:100%;
  object-fit:cover;
}
@media (max-width:899px) {
  .menu-hero__image {
    transform:rotate(0.5deg);
    max-height:320px;
  }
}

/* ============================================================
   2. JUMP LINKS — sticky anchor navigation
   ============================================================ */
.menu-nav {
  position:sticky;
  top:76px; /* below nav height */
  z-index:50;
  background:var(--color-blue);
  border-top:3px solid var(--color-warm-black);
  border-bottom:3px solid var(--color-warm-black);
  padding:var(--space-sm) 0;
}
.menu-nav__list {
  list-style:none;
  display:flex;
  gap:var(--space-sm);
  /* extra padding so box-shadows aren't clipped */
  padding:6px var(--space-xs);
  overflow-x:auto;
  overflow-y:visible;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.menu-nav.is-stuck { border-top:none; }
.menu-nav__sentinel { height:0; }
.menu-nav__list::-webkit-scrollbar { display:none; }
.menu-nav__link {
  display:inline-flex;
  align-items:center;
  gap:var(--space-xs);
  padding:8px 18px;
  font-family:var(--font-body);
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:rgba(255,255,255,0.85);
  text-decoration:none;
  white-space:nowrap;
  border:2px solid transparent;
  border-radius:var(--radius-full);
  transition:all var(--duration-fast) var(--ease-bounce);
}
.menu-nav__link:hover,
.menu-nav__link.is-active {
  background:white;
  color:var(--color-blue);
  border-color:var(--color-warm-black);
  box-shadow:2px 2px 0 var(--color-warm-black);
  transform:rotate(-1deg);
}
.menu-nav__link:focus-visible {
  outline:none;
  box-shadow:var(--focus-ring);
}
.menu-nav__link svg {
  width:16px;
  height:16px;
  stroke-width:2.5;
}

/* ============================================================
   3. MENU SECTIONS — category with items grid
   ============================================================ */
.menu-section {
  padding:var(--space-3xl) 0 var(--space-2xl);
}
.menu-section + .menu-section {
  border-top:3px solid var(--color-grey-light);
}
.menu-section__header {
  display:grid;
  grid-template-columns:1fr;
  gap:var(--space-xl);
  margin-bottom:var(--space-xl);
  align-items:start;
}
@media (min-width:900px) {
  .menu-section__header {
    grid-template-columns:1fr 1fr;
    gap:var(--space-2xl);
  }
}
.menu-section__info {
  /* text side */
}
.menu-section__eyebrow {
  color:var(--color-blue);
}
.menu-section__heading {
  font-family:var(--font-display);
  font-size:var(--text-3xl);
  font-weight:var(--weight-black);
  line-height:1.1;
  color:var(--color-warm-black);
  margin-bottom:var(--space-sm);
  letter-spacing:-0.02em;
}
@media (min-width:900px) {
  .menu-section__heading { font-size:var(--text-4xl); }
}
.menu-section__desc {
  font-size:var(--text-base);
  color:var(--color-warm-black);
  line-height:var(--leading-relaxed);
  max-width:50ch;
  margin-bottom:var(--space-md);
}
.menu-section__badges {
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-sm);
}
.menu-badge {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:5px 14px;
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:var(--color-warm-black);
  background:var(--color-blue-light);
  border:2px solid var(--color-warm-black);
  border-radius:var(--radius-full);
  box-shadow:2px 2px 0 var(--color-warm-black);
  white-space:nowrap;
  transform:rotate(-0.5deg);
}
/* Dietary / positive indicator badges — brand yellow */
.menu-badge--green {
  background:var(--color-yellow);
  color:var(--color-warm-black);
}
/* Red-light for any alert/contains badges */
.menu-badge--orange {
  background:var(--color-red-light);
  color:var(--color-warm-black);
}
/* Informational service note — solid blue, white text, smaller weight */
.menu-badge--info {
  background:var(--color-blue);
  color:white;
  font-weight:var(--weight-medium);
  font-size:var(--text-sm);
  border-color:var(--color-blue-dark);
  box-shadow:2px 2px 0 var(--color-blue-dark);
  transform:none;
  gap:6px;
}
.menu-badge--info svg {
  width:13px;
  height:13px;
  flex-shrink:0;
  stroke-width:2.5;
}

.menu-section__image {
  border:4px solid var(--color-warm-black);
  border-radius:var(--radius-lg);
  box-shadow:5px 5px 0 var(--color-warm-black);
  overflow:hidden;
  aspect-ratio:16/10;
  transform:rotate(0.8deg);
}
.menu-section__image img {
  width:100%;
  height:100%;
  object-fit:cover;
}
@media (max-width:899px) {
  .menu-section__image {
    max-height:240px;
    transform:rotate(0.4deg);
  }
}

/* ============================================================
   4. MENU ITEMS — two-column table-like grid
   ============================================================ */
.menu-items {
  border:4px solid var(--color-warm-black);
  border-radius:var(--radius-lg);
  box-shadow:5px 5px 0 var(--color-warm-black);
  overflow:hidden;
}
.menu-items__columns {
  display:grid;
  grid-template-columns:1fr;
}
@media (min-width:900px) {
  .menu-items__columns {
    grid-template-columns:1fr 1fr;
  }
}
.menu-items__column {
  /* left/right column */
}
@media (min-width:900px) {
  .menu-items__column:first-child {
    border-right:3px solid var(--color-warm-black);
  }
}
@media (max-width:899px) {
  .menu-items__column + .menu-items__column {
    border-top:3px solid var(--color-warm-black);
  }
}

.menu-item {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:var(--space-md);
  padding:var(--space-md) var(--space-lg);
  border-bottom:1px solid var(--color-grey-light);
  transition:background var(--duration-fast) var(--ease-out);
  cursor:default;
}
.menu-item:last-child {
  border-bottom:none;
}
.menu-item:hover {
  background:var(--color-blue-light);
}
.menu-item__info {
  flex:1;
  min-width:0;
}
.menu-item__name {
  font-family:var(--font-display);
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:var(--color-warm-black);
  margin-bottom:2px;
}
.menu-item__desc {
  font-size:var(--text-base);
  color:var(--color-grey-dark);
  line-height:var(--leading-normal);
}
.menu-item__dietary {
  display:inline-flex;
  gap:4px;
  margin-top:4px;
}
.menu-item__dietary-tag {
  display:inline-flex;
  align-items:center;
  font-size:13px;
  font-weight:var(--weight-bold);
  color:var(--color-warm-black);
  background:var(--color-blue-light);
  padding:2px 10px;
  border:2px solid var(--color-warm-black);
  border-radius:var(--radius-full);
  box-shadow:1px 1px 0 var(--color-warm-black);
  white-space:nowrap;
}
/* Dietary tags — brand yellow, same as section-level badges */
.menu-item__dietary-tag--green {
  background:var(--color-yellow);
  color:var(--color-warm-black);
}
.menu-item__price {
  font-family:var(--font-display);
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:var(--color-warm-black);
  white-space:nowrap;
  flex-shrink:0;
}

/* ============================================================
   5. CAKES GRID — image cards
   ============================================================ */
.cakes-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-lg);
}
@media (max-width:900px) {
  .cakes-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px) {
  .cakes-grid { grid-template-columns:1fr; }
}
.cake-card {
  border:4px solid var(--color-warm-black);
  border-radius:var(--radius-lg);
  box-shadow:5px 5px 0 var(--color-warm-black);
  overflow:hidden;
  background:white;
  transition:all var(--duration-normal) var(--ease-out);
}
.cake-card:hover {
  transform:translateY(-4px);
  box-shadow:8px 8px 0 var(--color-warm-black);
}
.cake-card__image {
  aspect-ratio:4/3;
  overflow:hidden;
}
.cake-card__image img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform var(--duration-slow) var(--ease-out);
}
.cake-card:hover .cake-card__image img {
  transform:scale(1.05);
}
.cake-card__body {
  padding:var(--space-md) var(--space-lg);
}
.cake-card__name {
  font-family:var(--font-display);
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:var(--color-warm-black);
  margin-bottom:2px;
}
.cake-card__desc {
  font-size:var(--text-base);
  color:var(--color-grey-dark);
  margin-bottom:var(--space-sm);
}
.cake-card__footer {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-sm);
}
.cake-card__price {
  font-family:var(--font-display);
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:var(--color-warm-black);
}
.cake-card__dietary {
  display:inline-flex;
  gap:4px;
}

/* ============================================================
   6. VISIT CTA — dark banner with opening hours
   ============================================================ */
.visit-cta {
  background:var(--color-blue-dark);
  color:white;
  padding:var(--space-3xl) 0;
}
.visit-cta__grid {
  display:grid;
  grid-template-columns:1fr;
  gap:var(--space-2xl);
  align-items:center;
}
@media (min-width:900px) {
  .visit-cta__grid {
    grid-template-columns:1.2fr 0.8fr;
  }
}
.visit-cta__eyebrow {
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:rgba(255,255,255,0.6);
  margin-bottom:var(--space-sm);
}
.visit-cta__heading {
  font-family:var(--font-display);
  font-size:var(--text-3xl);
  font-weight:var(--weight-black);
  line-height:1.15;
  color:white;
  margin-bottom:var(--space-md);
  letter-spacing:-0.02em;
}
@media (min-width:900px) {
  .visit-cta__heading { font-size:var(--text-4xl); }
}
.visit-cta__status {
  display:inline-flex;
  align-items:center;
  gap:var(--space-sm);
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:white;
  margin-bottom:var(--space-md);
}
.visit-cta__dot {
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--color-success);
  animation:pulse 2s infinite;
}
.visit-cta__body {
  font-size:var(--text-base);
  color:rgba(255,255,255,0.8);
  line-height:var(--leading-relaxed);
  margin-bottom:var(--space-lg);
  max-width:50ch;
}
.visit-cta__hours {
  display:flex;
  flex-direction:column;
  gap:var(--space-sm);
}
.visit-cta__hours-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:var(--space-md) var(--space-lg);
  background:white;
  border:3px solid var(--color-warm-black);
  border-radius:var(--radius-md);
  box-shadow:4px 4px 0 rgba(0,0,0,0.3);
  transition:transform var(--duration-fast) var(--ease-bounce), box-shadow var(--duration-fast) var(--ease-bounce);
}
.visit-cta__hours-row:hover {
  transform:translateY(-2px);
  box-shadow:6px 6px 0 rgba(0,0,0,0.3);
}
.visit-cta__day {
  font-size:var(--text-base);
  font-weight:var(--weight-black);
  color:var(--color-warm-black);
}
.visit-cta__time {
  font-size:var(--text-base);
  font-weight:var(--weight-bold);
  color:var(--color-blue);
}
/* Give the white-solid button a stronger shadow against the dark bg */
.visit-cta .btn--white-solid {
  box-shadow:3px 3px 0 var(--color-warm-black);
  border-color:var(--color-warm-black);
}
.visit-cta .btn--white-solid:hover {
  box-shadow:5px 5px 0 var(--color-warm-black);
}

/* ============================================================
   MENU PAGE RESPONSIVE OVERRIDES
   ============================================================ */
@media (max-width:600px) {
  .menu-hero__heading { font-size:var(--text-2xl); }
  .menu-section__heading { font-size:var(--text-2xl); }
  .visit-cta__heading { font-size:var(--text-2xl); }
}
