/* =========================================================
   ONE DAY IN PARIS — live website (demo) · client brand palette
   cream #F1EFE7 · wine #32111B · tan-gold #A89879 · blush
   ========================================================= */
:root{
  --cream:#F1EFE7; --paper:#FAF8F2; --blush:#F4ECE6;
  --ink:#241A16; --ink-soft:#5C4F45; --faint:#978777;
  --wine:#32111B; --wine-2:#4E1B29; --olive:#34341D;
  --gold:#9C7C45; --gold-soft:#A89879; --poppy:#C2606A;
  --line:#E1D8C8; --line-2:#D4C8B4;
  --shadow:0 24px 60px -28px rgba(50,17,27,.30);
  --shadow-2:0 40px 90px -36px rgba(50,17,27,.42);
  --serif:"Newsreader","Cormorant Garamond",Georgia,serif;
  --body:"Montserrat","Helvetica Neue",Arial,sans-serif;
  --maxw:1180px;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ font-family:var(--body); color:var(--ink); background:var(--cream); line-height:1.7; font-weight:400; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.06; letter-spacing:-0.01em; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 26px; }
.sp{ padding:clamp(64px,9vw,120px) 0; }
.center{ text-align:center; }
.eyebrow{ font-weight:600; font-size:.66rem; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.lead{ font-size:clamp(1rem,1.5vw,1.18rem); color:var(--ink-soft); }
em.it{ font-style:italic; color:var(--wine); }
.flourish{ display:flex; align-items:center; justify-content:center; gap:12px; color:var(--gold); margin:0 auto 22px; }
.flourish::before,.flourish::after{ content:""; height:1px; width:50px; background:linear-gradient(90deg,transparent,var(--gold)); }
.flourish::after{ background:linear-gradient(90deg,var(--gold),transparent); }

.btn{ display:inline-flex; align-items:center; gap:9px; cursor:pointer; font-weight:600; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; padding:15px 32px; border-radius:2px; border:1.5px solid transparent; transition:all .3s; }
.btn-wine{ background:var(--wine); color:var(--cream); }
.btn-wine:hover{ background:var(--wine-2); transform:translateY(-2px); }
.btn-gold{ background:var(--gold); color:#fff; }
.btn-gold:hover{ background:#856537; transform:translateY(-2px); }
.btn-ghost{ background:transparent; border-color:currentColor; }
.btn-ghost.light{ color:#fff; border-color:rgba(255,255,255,.5); }
.btn-ghost.light:hover{ background:#fff; color:var(--wine); }
.btn-ghost.dark{ color:var(--ink); }
.btn-ghost.dark:hover{ background:var(--ink); color:var(--cream); }

/* demo ribbon */
.ribbon{ background:var(--gold); color:#fff; text-align:center; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; padding:8px; font-weight:600; position:relative; z-index:60; }
.ribbon a{ text-decoration:underline; }

/* nav */
.nav{ position:sticky; top:0; z-index:50; background:rgba(241,239,231,.9); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.nav .in{ display:flex; align-items:center; justify-content:space-between; padding:14px 26px; max-width:1300px; margin:0 auto; }
.brand{ display:flex; align-items:center; gap:9px; }
.brand svg{ width:26px;height:26px; color:var(--poppy); }
.brand b{ font-family:var(--serif); font-weight:500; font-size:1.3rem; }
.nav .links{ display:flex; gap:26px; align-items:center; }
.nav .links a{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); transition:color .25s; }
.nav .links a:hover{ color:var(--wine); }
.nav .res{ font-size:.68rem !important; padding:11px 22px; }
@media (max-width:860px){ .nav .links a:not(.res){ display:none; } }

/* hero */
.hero{ position:relative; min-height:88vh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.hero img.bg{ position:absolute; inset:0; width:100%;height:100%;object-fit:cover; }
.hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(50,17,27,.42),rgba(50,17,27,.62)); }
.hero .wrap{ position:relative; z-index:2; }
.hero .eyebrow{ color:var(--gold-soft); }
.hero h1{ font-size:clamp(2.8rem,7vw,5.6rem); font-weight:500; margin:18px 0 0; max-width:16ch; }
.hero h1 em{ font-style:italic; color:var(--blush); }
.hero p{ font-size:1.2rem; color:rgba(255,255,255,.9); max-width:46ch; margin:22px 0 34px; }
.hero .cta-row{ display:flex; gap:14px; flex-wrap:wrap; }

/* section heads */
.head{ max-width:680px; }
.head.center{ margin:0 auto; }
.head .eyebrow{ display:block; margin-bottom:12px; }
.head h2{ font-size:clamp(2.2rem,4.6vw,3.6rem); }
.head h2 em{ font-style:italic; color:var(--wine); }
.head .lead{ margin-top:16px; }

/* story */
.story{ background:var(--paper); }
.story .grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.story img{ border-radius:4px; box-shadow:var(--shadow); }
.story .quote{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--wine); margin:18px 0; line-height:1.4; }
@media (max-width:860px){ .story .grid{ grid-template-columns:1fr; gap:40px; } }

/* pillars (alternating) */
.pillar{ display:grid; grid-template-columns:1fr 1fr; align-items:center; }
.pillar .img{ position:relative; min-height:480px; }
.pillar .img img{ position:absolute; inset:0; width:100%;height:100%;object-fit:cover; }
.pillar .txt{ padding:clamp(40px,6vw,90px); }
.pillar .txt .n{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1.1rem; }
.pillar .txt h3{ font-size:clamp(1.9rem,3.4vw,2.8rem); margin:6px 0 14px; }
.pillar .txt p{ color:var(--ink-soft); margin-bottom:20px; }
.pillar:nth-child(even) .img{ order:2; }
.pillar.wine{ background:var(--wine); color:var(--cream); }
.pillar.wine .txt p{ color:rgba(255,255,255,.82); }
.pillar.wine .txt h3{ color:#fff; }
.pillar.olive{ background:var(--blush); }
@media (max-width:820px){ .pillar{ grid-template-columns:1fr; } .pillar .img{ min-height:300px; } .pillar:nth-child(even) .img{ order:0; } }

/* menu */
.menu{ background:var(--cream); }
.menu .cols{ display:grid; grid-template-columns:1fr 1fr; gap:50px; margin-top:46px; }
.menu .cat{ font-size:.62rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.menu .row{ display:flex; justify-content:space-between; gap:16px; padding:13px 0; border-bottom:1px dashed var(--line-2); }
.menu .row .n{ font-family:var(--serif); font-size:1.35rem; }
.menu .row .d{ font-size:.78rem; color:var(--faint); }
.menu .row .p{ font-family:var(--serif); font-size:1.25rem; color:var(--wine); white-space:nowrap; }
@media (max-width:760px){ .menu .cols{ grid-template-columns:1fr; gap:36px; } }

/* reservations band */
.resv{ position:relative; color:#fff; text-align:center; overflow:hidden; }
.resv img.bg{ position:absolute; inset:0; width:100%;height:100%;object-fit:cover; }
.resv::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(50,17,27,.8),rgba(36,12,18,.88)); }
.resv .wrap{ position:relative; z-index:2; }
.resv h2{ font-size:clamp(2.2rem,5vw,3.6rem); }
.resv h2 em{ font-style:italic; color:var(--gold-soft); }
.resv p{ color:rgba(255,255,255,.85); max-width:42ch; margin:16px auto 28px; }
.resv .booking{ display:inline-flex; gap:10px; background:var(--paper); color:var(--ink); border-radius:6px; padding:10px; flex-wrap:wrap; justify-content:center; box-shadow:var(--shadow); }
.resv .booking .fld{ display:flex; align-items:center; gap:8px; padding:11px 16px; border:1px solid var(--line); border-radius:3px; font-size:.78rem; color:var(--ink-soft); }
.resv .pw{ font-size:.62rem; color:rgba(255,255,255,.6); margin-top:14px; letter-spacing:.08em; }

/* events */
.events{ background:var(--paper); }
.events .grid{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.events img{ border-radius:4px; box-shadow:var(--shadow); }
.events .tags{ display:flex; gap:9px; flex-wrap:wrap; margin:20px 0 24px; }
.events .tags span{ font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; border:1px solid var(--line-2); padding:7px 14px; border-radius:30px; color:var(--ink-soft); }
@media (max-width:860px){ .events .grid{ grid-template-columns:1fr; gap:38px; } }

/* journal */
.journal{ background:var(--cream); }
.bgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:46px; }
@media (max-width:880px){ .bgrid{ grid-template-columns:1fr; } }
.bcard{ background:var(--paper); border:1px solid var(--line); border-radius:6px; overflow:hidden; transition:transform .4s,box-shadow .4s; }
.bcard:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.bcard .im{ height:200px; overflow:hidden; position:relative; }
.bcard .im img{ width:100%;height:100%;object-fit:cover; transition:transform .6s; }
.bcard:hover .im img{ transform:scale(1.06); }
.bcard .cat{ position:absolute; top:14px; left:14px; font-size:.56rem; letter-spacing:.14em; text-transform:uppercase; background:var(--cream); color:var(--wine); padding:6px 12px; border-radius:30px; }
.bcard .b{ padding:24px; }
.bcard .b h3{ font-size:1.4rem; line-height:1.15; margin-bottom:10px; }
.bcard .b p{ font-size:.84rem; color:var(--ink-soft); }
.bcard .b .m{ display:flex; justify-content:space-between; margin-top:16px; font-size:.64rem; letter-spacing:.08em; text-transform:uppercase; color:var(--faint); }
.bcard .b .m .r{ color:var(--gold); }

/* footer */
footer{ background:var(--wine); color:rgba(255,255,255,.66); padding:64px 0 32px; font-size:.85rem; }
footer .grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; }
footer h4{ color:#fff; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; margin-bottom:16px; font-family:var(--body); font-weight:600; }
footer .fbrand{ display:flex; align-items:center; gap:10px; color:#fff; margin-bottom:14px; }
footer .fbrand svg{ width:26px;height:26px; color:var(--gold-soft); }
footer .fbrand b{ font-family:var(--serif); font-weight:500; font-size:1.3rem; }
footer p{ color:rgba(255,255,255,.6); line-height:1.8; }
footer a:hover{ color:var(--gold-soft); }
footer .row{ display:block; padding:3px 0; color:rgba(255,255,255,.66); }
footer .fine{ margin-top:44px; padding-top:24px; border-top:1px solid rgba(255,255,255,.14); font-size:.68rem; color:rgba(255,255,255,.45); text-align:center; }
@media (max-width:760px){ footer .grid{ grid-template-columns:1fr 1fr; gap:30px; } }

/* reveal */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.7,.3,1), transform .8s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }
.d1{ transition-delay:.1s; } .d2{ transition-delay:.2s; }
::selection{ background:var(--poppy); color:#fff; }

/* =========================================================
   MULTI-PAGE additions
   ========================================================= */

/* nav: active + mobile toggle */
.nav .links a.active{ color:var(--wine); border-bottom:1.5px solid var(--gold); padding-bottom:2px; }
.nav .burger{ display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
.nav .burger span{ width:24px; height:2px; background:var(--ink); transition:.3s; }
@media (max-width:860px){
  .nav .burger{ display:flex; }
  .nav .links{ position:absolute; top:100%; left:0; right:0; background:var(--cream); border-bottom:1px solid var(--line);
    flex-direction:column; align-items:stretch; gap:0; padding:8px 0; box-shadow:var(--shadow); display:none; }
  .nav .links.open{ display:flex; }
  .nav .links a:not(.res){ display:block; padding:14px 26px; border-bottom:1px solid var(--line); }
  .nav .links a.active{ border-bottom:1px solid var(--line); }
  .nav .links .res{ margin:12px 26px; text-align:center; justify-content:center; }
}

/* page hero (interior pages) */
.phero{ position:relative; min-height:62vh; display:flex; align-items:flex-end; color:#fff; overflow:hidden; }
.phero img.bg{ position:absolute; inset:0; width:100%;height:100%;object-fit:cover; }
.phero::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(50,17,27,.25),rgba(50,17,27,.72)); }
.phero .wrap{ position:relative; z-index:2; padding-bottom:clamp(40px,6vw,80px); }
.phero .eyebrow{ color:var(--gold-soft); }
.phero h1{ font-size:clamp(2.6rem,6vw,5rem); font-weight:500; margin-top:14px; max-width:18ch; }
.phero h1 em{ font-style:italic; color:var(--blush); }
.phero p{ font-size:1.15rem; color:rgba(255,255,255,.9); max-width:52ch; margin-top:18px; }
.crumb{ font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.7); margin-bottom:8px; }
.crumb a:hover{ color:#fff; }

/* prose / intro */
.prose{ max-width:740px; margin:0 auto; }
.prose p{ font-size:1.12rem; color:var(--ink-soft); margin-bottom:22px; line-height:1.85; }
.prose p.first::first-letter{ font-family:var(--serif); font-size:3.4rem; float:left; line-height:.8; padding:6px 12px 0 0; color:var(--wine); }
.prose h3{ font-size:1.8rem; margin:34px 0 14px; }
.lead-quote{ font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,3vw,2.3rem); color:var(--wine); text-align:center; max-width:820px; margin:0 auto; line-height:1.35; }
.lead-quote .by{ display:block; font-family:var(--body); font-style:normal; font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--faint); margin-top:18px; }

/* half split (image + text) */
.half{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.half.rev > .h-img{ order:2; }
.half .h-img img{ border-radius:4px; box-shadow:var(--shadow); width:100%; }
.half .h-txt .eyebrow{ display:block; margin-bottom:10px; }
.half .h-txt h2{ font-size:clamp(1.9rem,3.6vw,2.8rem); }
.half .h-txt h2 em{ font-style:italic; color:var(--wine); }
.half .h-txt p{ color:var(--ink-soft); margin-top:14px; }
@media (max-width:860px){ .half{ grid-template-columns:1fr; gap:36px; } .half.rev > .h-img{ order:0; } }

/* stats strip */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.stats .s b{ font-family:var(--serif); font-weight:500; font-size:clamp(2.2rem,4vw,3rem); color:var(--wine); display:block; line-height:1; }
.stats .s span{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-top:6px; display:block; }
@media (max-width:640px){ .stats{ grid-template-columns:repeat(2,1fr); gap:32px; } }

/* gallery */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.gallery a{ position:relative; overflow:hidden; border-radius:3px; aspect-ratio:4/3; }
.gallery.tall a:nth-child(1){ grid-row:span 2; aspect-ratio:auto; }
.gallery img{ width:100%;height:100%;object-fit:cover; transition:transform .6s; }
.gallery a:hover img{ transform:scale(1.06); }
@media (max-width:640px){ .gallery{ grid-template-columns:1fr 1fr; } }

/* full menu (page) */
.fullmenu{ max-width:820px; margin:0 auto; }
.fullmenu .mcat{ margin-bottom:40px; }
.fullmenu .mcat .ct{ display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.fullmenu .mcat .ct h3{ font-size:1.7rem; white-space:nowrap; }
.fullmenu .mcat .ct .ln{ flex:1; height:1px; background:var(--line); }
.fullmenu .mcat .ct .pr{ font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.fullmenu .mrow{ display:flex; justify-content:space-between; gap:16px; padding:12px 0; border-bottom:1px dashed var(--line-2); }
.fullmenu .mrow .n{ font-family:var(--serif); font-size:1.3rem; }
.fullmenu .mrow .d{ font-size:.8rem; color:var(--faint); }
.fullmenu .mrow .p{ font-family:var(--serif); font-size:1.2rem; color:var(--wine); white-space:nowrap; }

/* hours + contact */
.hours{ display:grid; grid-template-columns:repeat(2,1fr); gap:0 50px; max-width:520px; }
.hours .hr{ display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--line); font-size:.95rem; }
.hours .hr .d{ color:var(--ink); font-weight:500; }
.hours .hr .t{ color:var(--ink-soft); }
@media (max-width:540px){ .hours{ grid-template-columns:1fr; } }
.info-card{ background:var(--paper); border:1px solid var(--line); border-radius:8px; padding:30px; }
.info-card h4{ font-size:1.3rem; margin-bottom:6px; }
.info-card p{ color:var(--ink-soft); font-size:.95rem; }
.map-embed{ width:100%; min-height:340px; border-radius:8px; overflow:hidden; border:1px solid var(--line); position:relative; background:linear-gradient(135deg,var(--blush),var(--cream)); }
.map-embed .pin{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; color:var(--wine); }
.map-embed .pin svg{ width:40px;height:40px; }
.map-embed .pin span{ font-family:var(--serif); font-size:1.2rem; }

/* FAQ */
.faq{ max-width:760px; margin:0 auto; }
.faq details{ border-bottom:1px solid var(--line); padding:6px 0; }
.faq summary{ cursor:pointer; list-style:none; padding:18px 0; font-family:var(--serif); font-size:1.3rem; display:flex; justify-content:space-between; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--gold); font-size:1.6rem; transition:.3s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ color:var(--ink-soft); padding:0 0 20px; font-size:.98rem; }

/* form */
.form{ max-width:640px; margin:0 auto; display:grid; gap:16px; }
.form .fr{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form label{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); display:block; margin-bottom:7px; }
.form input, .form select, .form textarea{ width:100%; background:var(--paper); border:1px solid var(--line); border-radius:4px; padding:13px 15px; font-family:var(--body); font-size:.95rem; color:var(--ink); }
.form textarea{ min-height:120px; resize:vertical; }
@media (max-width:560px){ .form .fr{ grid-template-columns:1fr; } }

/* simple CTA band */
.ctaband{ background:var(--wine); color:#fff; text-align:center; }
.ctaband h2{ font-size:clamp(2rem,4.4vw,3.2rem); }
.ctaband h2 em{ font-style:italic; color:var(--gold-soft); }
.ctaband p{ color:rgba(255,255,255,.82); max-width:46ch; margin:14px auto 26px; }

/* cards row */
.crow{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.crow .card{ background:var(--paper); border:1px solid var(--line); border-radius:8px; overflow:hidden; transition:transform .4s, box-shadow .4s; }
.crow .card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.crow .card .ci{ height:180px; overflow:hidden; } .crow .card .ci img{ width:100%;height:100%;object-fit:cover; }
.crow .card .cb{ padding:24px; }
.crow .card .cb h3{ font-size:1.5rem; margin-bottom:8px; }
.crow .card .cb p{ font-size:.88rem; color:var(--ink-soft); }
.crow .card .cb a{ display:inline-block; margin-top:14px; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); }
@media (max-width:820px){ .crow{ grid-template-columns:1fr; } }

/* hero / page-hero video background */
.hero video.bg, .phero video.bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
/* chef teaser (home) */
.chef-teaser{ background:var(--wine); color:var(--cream); }
.chef-teaser .half .h-txt h2{ color:#fff; }
.chef-teaser .half .h-txt p{ color:rgba(255,255,255,.85); }
.chef-teaser .eyebrow{ color:var(--gold-soft); }

/* ===== Cinematic scroll-motion band (chef plate) ===== */
.cine{ position:relative; height:78vh; min-height:480px; overflow:hidden; display:flex; align-items:center; justify-content:center; text-align:center; color:#fff; background:#1a0d10; }
.cine .media{ position:absolute; inset:0; overflow:hidden; }
.cine .media img, .cine .media video{ width:100%; height:108%; object-fit:cover; object-position:center 38%; animation:kenburns 14s ease-in-out infinite alternate; }
@keyframes kenburns{ from{ transform:scale(1.02) translateY(0); } to{ transform:scale(1.12) translateY(-2%); } }
.cine::after{ content:""; position:absolute; inset:0; z-index:1;
  background:radial-gradient(60% 70% at 72% 60%, rgba(255,140,40,.0), rgba(50,17,27,.55) 70%), linear-gradient(180deg, rgba(26,13,16,.45), rgba(26,13,16,.35) 45%, rgba(26,13,16,.78)); }
.cine .glow{ position:absolute; inset:0; z-index:1; mix-blend-mode:screen; pointer-events:none;
  background:radial-gradient(45% 55% at 74% 62%, rgba(255,138,48,.42), transparent 70%); animation:flicker 2.6s ease-in-out infinite; }
@keyframes flicker{ 0%,100%{ opacity:.55; } 25%{ opacity:.85; } 50%{ opacity:.4; } 75%{ opacity:.7; } }
.cine .cap{ position:relative; z-index:2; max-width:760px; padding:0 26px; }
.cine .cap .eyebrow{ color:var(--gold-soft); }
.cine .cap h2{ font-size:clamp(2.2rem,5vw,3.8rem); color:#fff; margin-top:12px; }
.cine .cap h2 em{ font-style:italic; color:var(--gold-soft); }
.cine .cap p{ color:rgba(255,255,255,.85); margin-top:14px; font-size:1.05rem; }
.cine .playtag{ position:absolute; bottom:18px; right:22px; z-index:2; font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.6); display:flex; align-items:center; gap:7px; }
.cine .playtag::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--gold-soft); animation:flicker 2s infinite; }

/* ===== Menu dish camera + lightbox ===== */
.dish-cam{ display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; margin-left:9px; vertical-align:middle; border:1px solid var(--line-2); border-radius:50%; background:var(--paper); color:var(--gold); cursor:pointer; transition:transform .2s, background .2s, color .2s; padding:0; position:relative; top:-2px; }
.dish-cam svg{ width:14px; height:14px; }
.dish-cam:hover{ background:var(--gold); color:#fff; border-color:var(--gold); transform:scale(1.1); }
.dish-cam::after{ content:"View"; position:absolute; bottom:120%; left:50%; transform:translateX(-50%); background:var(--wine); color:#fff; font-family:var(--body); font-size:.52rem; letter-spacing:.12em; text-transform:uppercase; padding:3px 7px; border-radius:4px; white-space:nowrap; opacity:0; pointer-events:none; transition:opacity .2s; }
.dish-cam:hover::after{ opacity:1; }

.dish-modal{ position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; padding:24px; }
.dish-modal.open{ display:flex; }
.dish-modal .dm-backdrop{ position:absolute; inset:0; background:rgba(26,13,16,.72); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); }
.dish-modal .dm-box{ position:relative; z-index:2; background:var(--paper); border-radius:12px; overflow:hidden; max-width:560px; width:100%; box-shadow:var(--shadow-2); animation:dmpop .35s cubic-bezier(.2,.7,.3,1); }
@keyframes dmpop{ from{ opacity:0; transform:translateY(16px) scale(.97);} to{ opacity:1; transform:none;} }
.dish-modal .dm-img{ width:100%; height:380px; object-fit:cover; display:block; background:var(--blush); }
.dish-modal figcaption{ padding:20px 24px 24px; }
.dish-modal .dm-name{ font-family:var(--serif); font-weight:500; font-size:1.8rem; }
.dish-modal .dm-desc{ color:var(--ink-soft); font-size:.92rem; margin-top:6px; }
.dish-modal .dm-price{ float:right; font-family:var(--serif); font-size:1.4rem; color:var(--wine); }
.dish-modal .dm-close{ position:absolute; top:12px; right:12px; z-index:3; width:38px; height:38px; border-radius:50%; border:none; background:rgba(255,255,255,.92); color:var(--wine); font-size:1.5rem; cursor:pointer; display:flex; align-items:center; justify-content:center; line-height:1; }
.dish-modal .dm-close:hover{ background:#fff; transform:scale(1.05); }
.dish-modal .dm-tag{ position:absolute; top:14px; left:14px; z-index:3; background:rgba(50,17,27,.82); color:#fff; font-size:.56rem; letter-spacing:.14em; text-transform:uppercase; padding:6px 12px; border-radius:30px; }
@media(max-width:560px){ .dish-modal .dm-img{ height:280px; } }
