/* ════ Shared styles for The Terrace web menu pages ════ */
:root{
  --cream:#F7F3EB; --cream-deep:#ECE3D4; --paper:#FCFAF5;
  --ink:#262420; --ink-soft:#5A554C; --line:#E2D8C6;
  --sage-deep:#5C6A4C; --gold:#B28E4C; --gold-light:#D7B570;
  --ease:cubic-bezier(.22,1,.36,1); --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--cream);color:var(--ink);line-height:1.55;font-weight:300;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.serif{font-family:'Cormorant Garamond',serif}

header{position:sticky;top:0;z-index:100;background:rgba(247,243,235,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.hd{max-width:var(--maxw);margin:0 auto;padding:15px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand .name{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:600;letter-spacing:.16em;color:var(--ink)}
.brand .loc{font-size:9px;letter-spacing:.36em;text-transform:uppercase;color:var(--ink-soft);margin-top:2px}
.hd-cta{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.hd-cta a.back{color:var(--ink-soft)}
.hd-cta a.back:hover{color:var(--gold)}
.hd-cta a.book{background:var(--gold);color:#fff;padding:10px 18px;border-radius:2px;font-weight:500;transition:background .3s var(--ease)}
.hd-cta a.book:hover{background:var(--sage-deep)}

.layout{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:262px 1fr;gap:54px;align-items:start}

.side{position:sticky;top:90px;padding:48px 0 40px}
.side .kick{font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);font-weight:500}
.side h1{font-family:'Cormorant Garamond',serif;font-size:clamp(36px,5vw,52px);font-weight:500;line-height:1;margin:12px 0 6px}
.side .hours{font-size:12.5px;color:var(--ink-soft);letter-spacing:.04em}
.side .pdf-btn{display:inline-flex;align-items:center;gap:8px;margin-top:20px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;border:1px solid var(--ink);color:var(--ink);padding:11px 20px;border-radius:2px;transition:all .35s var(--ease)}
.side .pdf-btn:hover{background:var(--ink);color:var(--cream)}
.side .nav-h{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin:36px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.side nav a{display:block;font-size:13.5px;color:var(--ink-soft);padding:7px 0 7px 14px;border-left:2px solid transparent;transition:all .25s var(--ease)}
.side nav a:hover{color:var(--ink)}
.side nav a.active{color:var(--ink);border-left-color:var(--gold);font-weight:500}
.side .others{margin-top:30px}
.side .others a{display:block;font-size:13px;color:var(--ink-soft);padding:6px 0}
.side .others a:hover{color:var(--gold)}
.side .others a.cur{color:var(--ink);font-weight:500}

.main{padding:48px 0 30px;min-width:0}
.sec{margin-bottom:50px;scroll-margin-top:84px}
.sec > h2{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,3.2vw,34px);font-weight:500;color:var(--ink);padding-bottom:12px;margin-bottom:22px;border-bottom:1px solid var(--line)}
.sec .note{font-size:13px;color:var(--ink-soft);font-style:italic;margin:-12px 0 20px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:16px}
.dcard{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:18px 20px;transition:border-color .3s var(--ease),box-shadow .3s var(--ease),transform .3s var(--ease)}
.dcard:hover{border-color:var(--gold-light);box-shadow:0 14px 34px -22px rgba(38,36,32,.5);transform:translateY(-3px)}
.dcard .top{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.dcard h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;color:var(--ink);line-height:1.15}
.dcard .pr{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--gold);white-space:nowrap}
.dcard p{font-size:13px;color:var(--ink-soft);margin-top:7px;line-height:1.5}
.dcard .add{font-size:12px;color:var(--gold);margin-top:7px}
.sec.compact .cards{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
.sec.compact .dcard p{display:none}
.lead{font-size:13.5px;color:var(--ink-soft);margin:-10px 0 18px}
.sauces{font-size:13.5px;color:var(--ink-soft);margin-top:18px;background:var(--cream-deep);border-radius:8px;padding:14px 18px}
.sauces b{color:var(--ink);font-weight:500}
.priceline{font-size:12.5px;color:var(--gold);letter-spacing:.04em;margin:-12px 0 18px}

.legal{margin-top:10px;padding-top:24px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-soft);line-height:1.7}
.legal .key{color:var(--ink);margin-bottom:6px}

footer{background:#131110;color:#CFC6B8;padding:38px 0 28px;margin-top:30px}
.ft{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:12px;color:#7d7367}
.ft a{color:var(--gold-light)}

@media(max-width:900px){
  .layout{grid-template-columns:1fr;gap:8px}
  .side{position:static;top:auto;padding:40px 0 6px;border-bottom:1px solid var(--line)}
  .side .nav-h{margin-top:26px}
  .side nav{display:flex;flex-wrap:wrap;gap:4px 6px}
  .side nav a{padding:8px 14px;border:1px solid var(--line);border-radius:20px;font-size:12px}
  .side nav a.active{border-color:var(--gold);background:rgba(178,142,76,.07)}
  .side .others{display:none}
  .main{padding-top:30px}
}
@media print{header,.side .pdf-btn,.side nav,.side .others,footer{display:none}.layout{grid-template-columns:1fr}body{background:#fff}}

/* ─── dietary labels ─── */
.tag{display:inline-block;font-family:'Jost',sans-serif;font-size:9px;font-weight:600;letter-spacing:.06em;line-height:1;padding:3px 5px;border-radius:3px;vertical-align:middle}
.dcard h3 .tag{margin-left:5px;transform:translateY(-2px)}
.tag-v{background:#7E8C6E;color:#fff}
.tag-vg{background:#5C6A4C;color:#fff}
.tag-gf{background:#ECE3D4;color:#5A554C;border:1px solid #D7B570}
.menu-legend{font-size:12.5px;color:var(--ink-soft);margin:4px 0 32px;display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.menu-legend span span.tag{margin-right:5px}

/* ─── phone refinements (iPhone / small Android) ─── */
body{overflow-x:hidden}
@media(max-width:600px){
  .hd{padding:12px 18px;gap:10px}
  .brand .name{font-size:18px;letter-spacing:.12em}
  .brand .loc{font-size:8px;letter-spacing:.3em}
  .hd-cta{gap:10px;font-size:10px;letter-spacing:.12em}
  .hd-cta a.book{padding:9px 13px}
  .layout{padding:0 18px}
  .main{padding:26px 0 20px}
  .side{padding:30px 0 4px}
  .side h1{font-size:clamp(34px,10vw,44px)}
  .cards,.sec.compact .cards{grid-template-columns:1fr}
  .sec{margin-bottom:38px;scroll-margin-top:70px}
  .sec > h2{font-size:25px}
  .dcard{padding:16px 18px}
  .dcard h3{font-size:18px}
  .dcard .top{gap:10px}
  .menu-legend{gap:8px 14px;font-size:12px;margin-bottom:24px}
  .ft{flex-direction:column;text-align:center;gap:6px}
}
/* very small (≤360px) — keep the header from crowding */
@media(max-width:360px){
  .hd-cta a.back{display:none}
}
