/* ============================================================
   OLD 41 — Inner page components (menu, story, reviews, contact)
   ============================================================ */

/* ---------- Menu anchor tabs ---------- */
.menu-tabs {
  position: sticky; top: var(--header-h); z-index: 50;
  background: var(--sand); border-bottom: 1px solid var(--line);
  padding: .7rem 0;
}
.menu-tabs .container { display: flex; gap: .6rem; flex-wrap: wrap; justify-content: center; }
.menu-tabs a {
  text-decoration: none; font-weight: 700; font-size: .92rem;
  color: var(--espresso); background: var(--cream); border: 1.5px solid var(--line);
  border-radius: 999px; padding: .5rem 1.2rem; transition: background .2s, color .2s, border-color .2s;
}
.menu-tabs a:hover { border-color: var(--amber); color: var(--terracotta-dark); }

/* ---------- Menu sections ---------- */
.menu-section { scroll-margin-top: calc(var(--header-h) + 70px); }
.menu-section + .menu-section { margin-top: clamp(2.6rem, 5vw, 4rem); }
.menu-section-head { display: flex; align-items: baseline; gap: 1rem; margin-bottom: .5rem; }
.menu-section-head h3 { font-size: clamp(1.4rem, 2.6vw, 1.9rem); }
.menu-section-head::after { content: ""; flex: 1; height: 2px; background: var(--line); border-radius: 2px; }
.menu-note { font-size: .9rem; color: var(--espresso-soft); margin-bottom: 1.4rem; max-width: 720px; }
.menu-items { display: grid; grid-template-columns: 1fr 1fr; gap: .4rem 2.6rem; }
.menu-item { display: flex; flex-direction: column; padding: .7rem 0; border-bottom: 1px dashed var(--line); }
.menu-item .mi-row { display: flex; align-items: baseline; gap: .6rem; }
.menu-item .mi-name { font-weight: 700; color: var(--espresso); }
.menu-item .mi-dots { flex: 1; border-bottom: 2px dotted var(--line); transform: translateY(-4px); }
.menu-item .mi-price { font-weight: 800; color: var(--terracotta-dark); white-space: nowrap; }
.menu-item .mi-desc { font-size: .92rem; color: var(--espresso-soft); margin-top: .2rem; }
.menu-item .mi-badge {
  align-self: flex-start; margin-top: .35rem;
  font-size: .68rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase;
  background: var(--amber-soft); border-radius: 999px; padding: .2rem .7rem;
}

/* Menu photo strip */
.menu-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin: 2.2rem 0; }
.menu-strip .arch-img { aspect-ratio: 1; border-radius: var(--radius-sm); }
.menu-strip .arch-img:nth-child(odd) { border-radius: 90px 90px var(--radius-sm) var(--radius-sm); }

/* Big section divider (BREAKFAST / LUNCH) */
.menu-part {
  display: flex; align-items: center; gap: 1.2rem;
  margin: clamp(3rem, 6vw, 4.5rem) 0 clamp(1.8rem, 3vw, 2.6rem);
}
.menu-part:first-of-type { margin-top: 0; }
.menu-part h2 { font-size: clamp(2rem, 4.5vw, 3rem); }
.menu-part .sun-dot {
  width: 46px; height: 46px; flex: none; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, var(--amber-soft), var(--amber));
  border: 3px solid var(--espresso);
}
.menu-part::after { content: ""; flex: 1; height: 3px; background: var(--espresso); border-radius: 3px; opacity: .85; }

/* ---------- Story timeline ---------- */
.timeline { position: relative; margin-top: 1rem; }
.timeline::before {
  content: ""; position: absolute; left: 11px; top: 6px; bottom: 6px;
  width: 3px; background: var(--line); border-radius: 3px;
}
.tl-item { position: relative; padding: 0 0 2rem 3rem; }
.tl-item:last-child { padding-bottom: 0; }
.tl-item::before {
  content: ""; position: absolute; left: 2px; top: 6px;
  width: 21px; height: 21px; border-radius: 50%;
  background: var(--amber); border: 4px solid var(--sand);
  box-shadow: 0 0 0 2px var(--amber);
}
.tl-item .tl-year { font-weight: 800; font-size: .8rem; letter-spacing: .16em; text-transform: uppercase; color: var(--terracotta-dark); }
.tl-item h3 { margin: .25rem 0 .35rem; }
.tl-item p { font-size: .98rem; }

/* Values grid */
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.3rem; }
.value-card { text-align: center; padding: 2rem 1.5rem; }
.value-card .v-icon {
  width: 60px; height: 60px; margin: 0 auto 1rem; border-radius: 50%;
  background: var(--amber-soft); color: var(--terracotta-dark);
  display: grid; place-items: center;
}
.value-card .v-icon svg { width: 28px; height: 28px; }
.value-card p { font-size: .95rem; margin-top: .4rem; }

/* ---------- Reviews page ---------- */
.review-sources { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; margin-bottom: 2.6rem; }
.review-source {
  background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 1.1rem 1.6rem; text-align: center; min-width: 180px;
}
.review-source .rs-num { font-family: var(--font-display); font-size: 1.9rem; color: var(--espresso); line-height: 1.1; }
.review-source .rs-lbl { font-size: .85rem; color: var(--espresso-soft); margin-top: .2rem; }
.reviews-masonry { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2rem, 4vw, 3.4rem); align-items: start; }
.contact-cards { display: grid; gap: 1.1rem; }
.hours-table { width: 100%; border-collapse: collapse; }
.hours-table td { padding: .55rem 0; border-bottom: 1px dashed var(--line); font-size: .98rem; }
.hours-table td:last-child { text-align: right; font-weight: 800; color: var(--espresso); }
.hours-table tr:last-child td { border-bottom: 0; }

/* ---------- Gallery-ish band on story ---------- */
.photo-duo { display: grid; grid-template-columns: 1.3fr 1fr; gap: 1.2rem; align-items: stretch; }
.photo-duo .arch-img { min-height: 280px; }

/* ---------- Responsive ---------- */
@media (max-width: 880px) {
  .menu-items { grid-template-columns: 1fr; }
  .menu-strip { grid-template-columns: repeat(2, 1fr); }
  .values-grid, .reviews-masonry { grid-template-columns: 1fr 1fr; }
  .contact-grid, .photo-duo { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .values-grid, .reviews-masonry { grid-template-columns: 1fr; }
}
