/* =========================================================================
   the morning after (the night before) - scroll as a day, 08:00 to 01:00
   Bone paper -> peach aperitif -> plum dinner -> aubergine midnight.
   Accent: coral | Display: Bricolage Grotesque | Body/italic: Newsreader
   ========================================================================= */
:root {
  --bone: #f3ede4;
  --peach: #f3dcc7;
  --plum: #6d4a55;
  --aubergine: #241f38;
  --coral: #e8643c;
  --coral-deep: #cf4f2c;
  --ink-dark: #2a2440;
  --ink-light: #f3ede4;
  --rail: 158px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *, *::before, *::after { animation-duration: .01ms !important; transition: none !important; } }
body { font-family: "Newsreader", Georgia, serif; background: var(--aubergine); color: var(--ink-dark); line-height: 1.6; font-size: 1.05rem; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; }
.disp { font-family: "Bricolage Grotesque", system-ui, sans-serif; line-height: 1.0; letter-spacing: -0.02em; }
.wrap { width: min(1080px, calc(100% - 72px)); margin-inline: auto; }
.paren { color: var(--coral); }

/* ---------- left rail ---------- */
.rail {
  position: fixed; left: 0; top: 0; bottom: 0; width: var(--rail); z-index: 60;
  background: var(--aubergine); color: var(--ink-light);
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 22px 18px; border-right: 1px solid rgba(243,237,228,.16);
}
.rail .mini { font-family: "Newsreader", serif; font-style: italic; font-size: 1.05rem; line-height: 1.15; color: var(--ink-light); }
.rail .mini .p { color: var(--coral); display: block; font-size: 0.86rem; opacity: .9; }
.rail .clock { margin-top: 8px; }
.rail .clock .t { font-family: "Bricolage Grotesque", sans-serif; font-size: 2.5rem; font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
.rail .clock .city { font-size: 0.72rem; letter-spacing: 0.24em; text-transform: uppercase; opacity: .7; margin-top: 4px; }
.rail .clock .phase { display: inline-block; margin-top: 12px; font-family: "Bricolage Grotesque", sans-serif; font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--aubergine); background: var(--coral); padding: 3px 9px; }
.rail .open { font-size: 0.78rem; opacity: .72; line-height: 1.4; }
.rail .lang { display: flex; gap: 6px; }
.rail .lang button { border: 1px solid rgba(243,237,228,.3); background: transparent; color: var(--ink-light); padding: 4px 10px; cursor: pointer; font: 600 0.72rem "Bricolage Grotesque", sans-serif; }
.rail .lang button[aria-pressed="true"] { background: var(--coral); color: var(--aubergine); border-color: var(--coral); }

main { margin-left: var(--rail); }

/* ---------- day-phase sections ---------- */
.phase-sec { padding: 110px 0; position: relative; }
.s-morning { background: var(--bone); color: var(--ink-dark); }
.s-aperitif { background: var(--peach); color: #40253a; }
.s-dinner { background: var(--plum); color: var(--ink-light); }
.s-night { background: var(--aubergine); color: var(--ink-light); }
/* soft seams between day phases */
.s-aperitif { background: linear-gradient(var(--bone), var(--peach) 16%, var(--peach)); }
.s-dinner { background: linear-gradient(var(--peach), var(--plum) 18%, var(--plum)); }
.s-night { background: linear-gradient(var(--plum), var(--aubergine) 18%, var(--aubergine)); }

.stamp { display: inline-flex; align-items: baseline; gap: 10px; font-family: "Bricolage Grotesque", sans-serif; margin-bottom: 26px; }
.stamp .br { color: var(--coral); font-size: 1.6rem; font-weight: 600; }
.stamp .tm { font-size: 1.4rem; font-weight: 700; letter-spacing: -0.01em; }
.stamp .nm { font-size: 0.78rem; letter-spacing: 0.2em; text-transform: uppercase; opacity: .7; }
.sec-title { font-size: clamp(2rem, 5vw, 3.4rem); font-weight: 700; max-width: 18ch; }
.sec-intro { margin-top: 16px; max-width: 52ch; font-size: 1.12rem; opacity: .92; }
.sec-intro em { color: var(--coral); font-style: italic; }

/* ---------- hero ---------- */
.hero { min-height: 100vh; display: grid; grid-template-columns: 1.25fr 0.75fr; align-items: stretch; background: var(--bone); color: var(--ink-dark); }
@media (max-width: 900px) { .hero { grid-template-columns: 1fr; } }
.hero-l { display: flex; flex-direction: column; justify-content: center; padding: 80px 56px; }
.hero-l .kick { font-family: "Bricolage Grotesque", sans-serif; font-size: .8rem; letter-spacing: .18em; text-transform: uppercase; color: var(--coral); margin-bottom: 22px; }
.hero-l h1 { font-size: clamp(2.8rem, 7.2vw, 5.6rem); line-height: 0.98; }
.hero-l h1 .sub { display: block; font-family: "Newsreader", serif; font-style: italic; font-weight: 400; font-size: clamp(1.4rem, 3.6vw, 2.4rem); margin-top: 10px; letter-spacing: 0; opacity: .85; }
.hero-l .lead { margin-top: 28px; max-width: 40ch; font-size: 1.18rem; }
.hero-l .resv { margin-top: 30px; }
.hero-l .resv a { font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; color: var(--ink-dark); text-decoration: none; border-bottom: 2px solid var(--coral); padding-bottom: 2px; }
.hero-l .resv a:hover { color: var(--coral); }
.hero-r { position: relative; min-height: 360px; }
.hero-r img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-r figcaption { position: absolute; left: 16px; bottom: 16px; background: var(--bone); color: var(--ink-dark); font-family: "Bricolage Grotesque", sans-serif; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; padding: 5px 10px; }

/* ---------- menu lists ---------- */
.menu { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; margin-top: 40px; align-items: start; }
@media (max-width: 820px) { .menu { grid-template-columns: 1fr; gap: 30px; } }
.dishes { display: grid; gap: 0; }
.dish { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: baseline; padding: 16px 0; border-top: 1px solid currentColor; }
.dish:first-child { border-top: 0; }
.dish .nm { font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; font-size: 1.12rem; }
.dish .ds { display: block; font-family: "Newsreader", serif; font-weight: 400; font-size: .96rem; opacity: .78; margin-top: 3px; }
.dish .pin { font-family: "Bricolage Grotesque", sans-serif; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--coral); white-space: nowrap; }
.menu-photo { position: relative; }
.menu-photo img { width: 100%; aspect-ratio: 4/5; object-fit: cover; }
.menu-photo.tall img { aspect-ratio: 3/4; }
.menu-photo figcaption { position: absolute; left: 0; bottom: 0; background: var(--coral); color: var(--aubergine); font-family: "Bricolage Grotesque", sans-serif; font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; padding: 4px 9px; }

/* duo photos */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 38px; }
@media (max-width: 640px) { .duo { grid-template-columns: 1fr; } }
.duo img { width: 100%; aspect-ratio: 5/4; object-fit: cover; }

/* nightcap */
.night-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; margin-top: 36px; }
@media (max-width: 820px) { .night-grid { grid-template-columns: 1fr; } }
.night-grid .ph img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.pulls { display: grid; gap: 14px; }
.pull { font-family: "Newsreader", serif; font-style: italic; font-size: 1.25rem; padding-left: 18px; border-left: 2px solid var(--coral); }

/* ---------- contact ---------- */
.contact { background: var(--aubergine); color: var(--ink-light); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 40px; margin-top: 30px; }
@media (max-width: 820px) { .contact-grid { grid-template-columns: 1fr; } }
.contact dl { display: grid; grid-template-columns: auto 1fr; gap: 12px 20px; }
.contact dt { font-family: "Bricolage Grotesque", sans-serif; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--coral); padding-top: 3px; }
.contact dd a { color: var(--ink-light); border-bottom: 1px solid var(--coral); text-decoration: none; }
.contact .socials { margin-top: 24px; display: flex; gap: 12px; flex-wrap: wrap; }
.btn { display: inline-block; font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; font-size: .9rem; padding: 11px 20px; text-decoration: none; border: 1px solid rgba(243,237,228,.4); color: var(--ink-light); }
.btn:hover { border-color: var(--coral); color: var(--coral); }
.btn-fill { background: var(--coral); color: var(--aubergine); border-color: var(--coral); }
.btn-fill:hover { background: var(--coral-deep); color: var(--ink-light); border-color: var(--coral-deep); }
.map-box { border: 1px solid rgba(243,237,228,.2); overflow: hidden; min-height: 340px; filter: grayscale(.4) brightness(.85); }
.map-box iframe { width: 100%; height: 100%; min-height: 340px; border: 0; display: block; }

/* ---------- footer ---------- */
.foot { background: var(--aubergine); color: var(--ink-light); padding: 40px 0 44px; border-top: 1px solid rgba(243,237,228,.16); }
.foot .line { font-family: "Newsreader", serif; font-style: italic; font-size: 1.15rem; max-width: 50ch; }
.foot .meta { margin-top: 18px; display: flex; flex-wrap: wrap; justify-content: space-between; gap: 16px; font-family: "Bricolage Grotesque", sans-serif; font-size: .82rem; }
.foot .meta a { color: var(--coral); text-decoration: none; }
.disclaimer { margin-top: 22px; font-size: .76rem; opacity: .6; max-width: 74ch; line-height: 1.5; }

.r { will-change: transform, opacity; }

@media (max-width: 820px) {
  :root { --rail: 0px; }
  .rail { position: static; flex-direction: row; align-items: center; width: auto; bottom: auto; padding: 12px 18px; border-right: 0; border-bottom: 1px solid rgba(243,237,228,.16); gap: 16px; flex-wrap: wrap; }
  .rail .mini { font-size: .92rem; } .rail .clock { margin: 0; display: flex; align-items: baseline; gap: 10px; } .rail .clock .t { font-size: 1.5rem; } .rail .clock .city, .rail .open { display: none; }
  .rail .clock .phase { margin: 0; }
  main { margin-left: 0; }
  .hero-l { padding: 60px 28px; }
  .wrap { width: min(1080px, calc(100% - 40px)); }
}
