/* Làng Sen — main.css
   Brand: emerald green + gold + cream (theo logo & ấn phẩm Làng Sen). Fine-dining, song ngữ.
   Mobile-first; breakpoints 768px / 1024px. */

:root{
  --green:#235C3A;        /* emerald đậm (brand) */
  --green-dk:#163E27;
  --green-soft:#E7EFE7;   /* nền xanh nhạt */
  --gold:#C9A24A;
  --gold-dk:#A8862F;
  --gold-soft:#F1DFAE;
  --cream:#FBF7EE;        /* nền chủ đạo */
  --ink:#23271F;          /* chữ chính */
  --muted:#7C766B;
  --surface:#FFFFFF;
  --line:#E8E0D0;
  --font-head:"Cormorant Garamond",Georgia,serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --radius:12px; --maxw:1600px;
  --sp-2:1rem; --sp-3:1.5rem; --sp-4:2.5rem; --sp-5:4.5rem;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--cream);line-height:1.65}
img{max-width:100%;height:auto;display:block}
h1,h2,h3{font-family:var(--font-head);line-height:1.12;margin:0 0 .4em;font-weight:600}
a{color:var(--gold-dk);text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--sp-2)}
.eyebrow{letter-spacing:.28em;text-transform:uppercase;font-size:.72rem;font-weight:600;color:var(--gold-dk)}
.btn{display:inline-flex;align-items:center;justify-content:center;text-align:center;line-height:1;
  background:var(--gold);color:var(--green-dk);padding:.75rem 1.5rem;
  border-radius:999px;font-weight:600;font-size:.92rem;border:1.5px solid transparent;
  cursor:pointer;transition:.2s;text-shadow:none}
.btn:hover{background:var(--gold-dk);color:#fff}
.btn.ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.7)}
.btn.ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn.green{background:var(--green);color:#fff}
.btn.green:hover{background:var(--green-dk)}

/* Lotus divider */
.lotus{text-align:center;color:var(--gold);font-size:1.4rem;letter-spacing:.5rem;margin:var(--sp-4) 0}
.lotus::before{content:"\273F";opacity:.85}

/* Flat line-icons (đơn sắc, theo currentColor) */
.ls-ic{width:1.1em;height:1.1em;display:inline-block;vertical-align:-0.18em;flex:0 0 auto}
.vi-ic .ls-ic{width:20px;height:20px;color:var(--gold-dk)}
.topbar .ls-ic{width:14px;height:14px;vertical-align:-0.15em;margin-right:.25rem}
.site-footer .ls-ic,.story-foot .ls-ic{width:15px;height:15px;vertical-align:-0.15em;margin-right:.35rem;color:var(--gold-soft)}

/* Topbar (giờ + sđt) */
.topbar{background:var(--green-dk);color:#dfe9df;font-size:.8rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding:.4rem var(--sp-2);gap:1rem;flex-wrap:wrap}
.topbar a{color:var(--gold-soft)}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:60;background:rgba(251,247,238,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.6rem var(--sp-2);max-width:var(--maxw);margin:0 auto;gap:1rem}
.brand{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--font-head);font-size:1.7rem;font-weight:700;color:var(--gold-dk)}
.brand-sub{font-size:.55rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.custom-logo-link{display:block;max-width:180px}
.nav-menu{display:none;list-style:none;gap:1.6rem;margin:0;padding:0}
.nav-menu a{color:var(--ink);font-weight:500;font-size:.95rem}
.nav-menu a:hover,.nav-menu .current-menu-item>a{color:var(--gold-dk)}
.nav-actions{display:flex;align-items:center;gap:.6rem}
.lang{font-size:.78rem;color:var(--muted);border:1px solid var(--line);padding:.3rem .6rem;border-radius:999px;
  background:transparent;font-family:inherit;cursor:pointer;letter-spacing:.05em;min-width:34px;text-align:center}
.lang:hover{border-color:var(--gold);color:var(--gold-dk)}
.hamburger{display:inline-flex;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--ink);padding:.2rem}
/* Mobile drawer */
.nav-menu.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
  background:var(--cream);border-bottom:1px solid var(--line);padding:1rem var(--sp-2);gap:.4rem;box-shadow:0 12px 24px rgba(0,0,0,.08)}

/* Hero */
.hero{position:relative;color:#fff;text-align:center;
  background:linear-gradient(rgba(22,62,39,.62),rgba(22,62,39,.72)),
    url("../img/hero.jpg") center/cover, var(--green)}
.hero-inner{max-width:46rem;margin:0 auto;padding:var(--sp-5) var(--sp-2)}
.hero .eyebrow{color:var(--gold-soft)}
.hero h1{font-size:clamp(2.6rem,8vw,4.6rem);color:#fff;font-style:italic;font-weight:600;margin:.3em 0}
.hero p{font-size:1.12rem;color:#eef4ee;max-width:34rem;margin:0 auto var(--sp-3)}
.hero .cta-row{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.hero .badges{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:var(--sp-3)}
.hero .badge{background:rgba(35,92,58,.6);border:1px solid var(--gold);color:#fff;
  border-radius:10px;padding:.5rem .9rem;font-size:.82rem}
.hero .badge b{color:var(--gold-soft)}

/* Sections */
.section{padding:var(--sp-5) 0}
.section.alt{background:var(--surface)}
.section.green{background:var(--green);color:#eef4ee}
.section.green .section-head h2,.section.green h2,.section.green h3{color:#fff}
.section-head{text-align:center;max-width:40rem;margin:0 auto var(--sp-4)}
.section-head h2{font-size:clamp(2rem,5vw,3rem)}
.section-head p{color:var(--muted)}
.section.green .section-head p{color:#cfe0cf}

/* Dish grid */
.grid{display:grid;grid-template-columns:1fr;gap:var(--sp-4)}
.dish{display:flex;flex-direction:column}
.dish-media{position:relative;aspect-ratio:1/1;border-radius:var(--radius);overflow:hidden;background:var(--green-soft)}
.dish-media img{width:100%;height:100%;object-fit:cover}
.dish-media .ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;
  background:radial-gradient(circle at 50% 35%,#2f7349,#163E27);color:var(--gold-soft);padding:1rem}
.dish-media .ph span{font-family:var(--font-head);font-size:1.5rem;font-style:italic}
.dish-tag{position:absolute;top:.7rem;left:.7rem;background:var(--gold);color:var(--green-dk);
  font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.25rem .6rem;border-radius:999px}
.dish-row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-top:.8rem}
.name-vi{font-family:var(--font-head);font-size:1.4rem;font-weight:600;color:var(--ink)}
.name-en{font-style:italic;color:var(--muted);font-size:.9rem;margin-top:1px}
.price{font-family:var(--font-head);font-size:1.35rem;font-weight:700;color:var(--green);white-space:nowrap}
.center-cta{text-align:center;margin-top:var(--sp-4)}

/* Story split */
.split{display:grid;grid-template-columns:1fr;gap:var(--sp-4);align-items:center}
.story-img{aspect-ratio:4/3;border-radius:var(--radius);background:radial-gradient(circle at 40% 30%,#2f7349,#163E27);
  display:flex;align-items:center;justify-content:center;color:var(--gold-soft);font-family:var(--font-head);font-style:italic;font-size:1.4rem}

/* Testimonials */
.quotes{display:grid;grid-template-columns:1fr;gap:var(--sp-3)}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:var(--sp-3)}
.quote p{font-family:var(--font-head);font-style:italic;font-size:1.25rem;margin:0 0 .6rem}
.quote .who{font-weight:600;color:var(--gold-dk);font-size:.9rem}
.stars{color:var(--gold);letter-spacing:.1em;margin-bottom:.4rem}

/* Visit / hours */
.info-list{list-style:none;padding:0;margin:0}
.info-list li{display:flex;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.18)}
.map-ph{aspect-ratio:16/10;border-radius:var(--radius);background:#cdd9cd;display:flex;align-items:center;justify-content:center;color:var(--green-dk)}

/* Footer */
.site-footer{background:var(--green-dk);color:#cfe0cf;padding:var(--sp-5) 0 var(--sp-3)}
.foot-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-3)}
.site-footer h4{font-family:var(--font-head);color:#fff;font-size:1.3rem;margin:0 0 .5rem}
.site-footer a{color:var(--gold-soft)}
.site-footer .copy{border-top:1px solid rgba(255,255,255,.15);margin-top:var(--sp-3);padding-top:var(--sp-3);font-size:.82rem;text-align:center;color:#9fb39f}

/* Tablet */
@media(min-width:768px){
  .nav-menu{display:flex !important;position:static;flex-direction:row;background:none;border:0;padding:0;box-shadow:none}
  .hamburger{display:none}
  .grid{grid-template-columns:1fr 1fr}
  .quotes{grid-template-columns:1fr 1fr 1fr}
  .split{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:2fr 1fr 1fr}
  .visit-split{grid-template-columns:1fr 1fr}
}
/* Desktop */
@media(min-width:1024px){
  .grid{grid-template-columns:repeat(3,1fr)}
}

/* =========================================================
   STORYTELLING MODE (scoped .story-home) — ViePilot vp-design
   Mỗi section = 100vh, scroll-snap mandatory, 1 scroll = 1 section.
   ========================================================= */
.story-home .topbar{display:none}
.story-home .site-header{position:fixed;top:0;left:0;right:0;background:transparent;
  backdrop-filter:none;border-bottom:1px solid transparent;transition:.35s}
.story-home .site-header .brand-name{color:#fff;text-shadow:0 1px 12px rgba(0,0,0,.35)}
.story-home .site-header .brand-sub{color:rgba(255,255,255,.85)}
.story-home .site-header .nav-menu a{color:#fff;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.story-home .site-header .lang{color:#fff;border-color:rgba(255,255,255,.5)}
.story-home .site-header .hamburger{color:#fff}
/* Header chuyển nền khi cuộn khỏi hero */
.story-home .site-header.scrolled{background:rgba(251,247,238,.95);backdrop-filter:blur(10px);
  border-bottom-color:var(--line)}
.story-home .site-header.scrolled .brand-name{color:var(--gold-dk);text-shadow:none}
.story-home .site-header.scrolled .brand-sub{color:var(--muted)}
.story-home .site-header.scrolled .nav-menu a{color:var(--ink);text-shadow:none}
.story-home .site-header.scrolled .nav-menu .current-menu-item>a{color:var(--gold-dk)}
.story-home .site-header.scrolled .lang{color:var(--muted);border-color:var(--line)}
.story-home .site-header.scrolled .hamburger{color:var(--ink)}

/* Snap điều khiển bằng JS (2 chiều) — bỏ CSS scroll-snap để không kẹt khi cuộn lên */
html{scroll-behavior:smooth}
/* Nền dự phòng + tránh lộ màu đen ở bất kỳ khe hở nào */
html,body{background:var(--cream)}
.story-scroll{position:relative}

/* Mỗi section = 1 viewport. Desktop: snap bằng JS. Mobile: snap bằng CSS (proximity). */
.story{min-height:100vh;min-height:100dvh;position:relative;
  display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  padding:6rem 1.25rem 3rem;overflow:hidden}
/* Mobile/touch: cuộn theo section (proximity — section dài vẫn cuộn trong được, không kẹt) */
@media(max-width:899px){
  html{scroll-snap-type:y proximity}
  .story{scroll-snap-align:start;scroll-snap-stop:always}
  .story-foot{scroll-snap-align:start}
}
.story .panel{max-width:var(--maxw);width:100%;margin:0 auto}
.story .lead{font-size:clamp(1.05rem,2.4vw,1.3rem);max-width:40rem;margin:1rem auto 0;color:inherit;opacity:.92}
.story h2{font-size:clamp(2.2rem,6vw,3.8rem)}
.story .big{font-family:var(--font-head);font-style:italic;font-size:clamp(2.6rem,8vw,5rem);line-height:1.05;font-weight:600}

/* Variants nền tạo nhịp điệu */
.story--cream{background:var(--cream);color:var(--ink)}
.story--green{background:radial-gradient(circle at 50% 0%,#2f7349,var(--green) 55%,var(--green-dk));color:#eef4ee}
.story--green h2,.story--green .big{color:#fff}
.story--green .eyebrow{color:var(--gold-soft)}
/* Image panels: lớp ảnh (::before, Ken Burns) + lớp phủ gradient (::after) + nội dung trên cùng */
.story--image,.story--image2,.story--signature,.story--broth{color:#fff;background:var(--green-dk)}
.story--image .eyebrow,.story--image2 .eyebrow,.story--signature .eyebrow,.story--broth .eyebrow{color:var(--gold-soft)}
.story--image::before,.story--image2::before,.story--signature::before,.story--broth::before{content:"";position:absolute;inset:0;z-index:0;
  background-position:center;background-size:cover;transform:scale(1.06);
  animation:kenburns 22s ease-out both;animation-play-state:paused}
.story--image::before{background-image:url("../img/hero.jpg")}
.story--image2::before{background-image:url("../img/story.jpg")}
.story--signature::before{background-image:url("../img/signature.jpg")}
.story--broth::before{background-image:url("../img/broth.jpg")}
.story--image.in-view::before,.story--image2.in-view::before,.story--signature.in-view::before,.story--broth.in-view::before{animation-play-state:running}
/* Overlay xanh CHỈ ở dải trên (sau header) + dải dưới; giữa ảnh trong suốt → ảnh rõ. */
/* Chỉ dải MỜ mỏng trên cùng để nav header đọc được — ảnh vẫn rõ. */
.story--image::after,.story--image2::after,.story--signature::after,.story--broth::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to bottom, rgba(18,40,26,.32) 0%, rgba(18,40,26,0) 16%)}
/* SPOTLIGHT mềm sau khối chữ: tối ở giữa, mờ dần ra trong suốt
   → chữ trắng nổi rõ, phần ảnh xung quanh giữ nguyên độ nét. */
.story--image .panel,.story--image2 .panel,.story--signature .panel,.story--broth .panel{
  position:relative;z-index:2;padding:2.6rem 2rem;
  background:radial-gradient(ellipse 75% 62% at 50% 50%,
    rgba(6,14,9,.62) 0%, rgba(6,14,9,.42) 38%, rgba(6,14,9,.14) 62%, rgba(6,14,9,0) 78%)}
.story--image .panel > *,.story--image2 .panel > *,.story--signature .panel > *,.story--broth .panel > *{
  text-shadow:0 2px 18px rgba(0,0,0,.7)}
.story .scroll-cue{position:absolute;z-index:2;text-shadow:0 1px 12px rgba(0,0,0,.75)}

/* Visit section — info card (icon) + Google Maps embed */
.visit-grid{display:grid;grid-template-columns:1fr;gap:1.4rem;margin-top:1.6rem;text-align:left;align-items:stretch}
@media(min-width:820px){.visit-grid{grid-template-columns:1fr 1.15fr}}
.visit-info{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.6rem 1.7rem;display:flex;flex-direction:column}
.vi-row{display:flex;gap:.95rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--line)}
.vi-row:first-of-type{padding-top:0}
.vi-ic{flex:0 0 auto;width:42px;height:42px;border-radius:50%;background:var(--green-soft);display:grid;place-items:center;font-size:1.12rem}
.vi-row strong{display:block;font-family:var(--font-head);font-size:1.1rem;margin-bottom:.12rem;color:var(--ink)}
.vi-row span{color:var(--muted);font-size:.92rem;line-height:1.55}
.vi-row a{color:var(--gold-dk);text-decoration:none}
.vi-row a:hover{color:var(--green)}
.visit-info .btn{margin-top:1.4rem;align-self:flex-start}
.visit-map{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  min-height:340px;box-shadow:0 12px 30px rgba(22,62,39,.12)}
.visit-map iframe{display:block;width:100%;height:100%;min-height:340px;border:0}

/* FOOTER: dải xanh đậm, sibling sau các panel (cuộn tới được nhờ proximity) */
.story-foot{position:relative;z-index:2;width:100%;background:var(--green-dk);color:#cfe0cf;
  padding:3rem 1.25rem 1.6rem;text-align:left}
.foot-cols{display:grid;grid-template-columns:1fr;gap:1.6rem;max-width:var(--maxw);margin:0 auto}
.story-foot h4{font-family:var(--font-head);color:#fff;font-size:1.3rem;margin:0 0 .55rem}
.story-foot p{margin:0;color:#bcd0bc;font-size:.9rem;line-height:1.6}
.story-foot a{display:block;color:var(--gold-soft);text-decoration:none;padding:.22rem 0;font-size:.92rem}
.story-foot a:hover{color:#fff}
.foot-copy{max-width:var(--maxw);margin:1.6rem auto 0;padding-top:1.2rem;
  border-top:1px solid rgba(255,255,255,.15);text-align:center;font-size:.82rem;color:#9fb39f}
@media(min-width:768px){.foot-cols{grid-template-columns:2fr 1fr 1.3fr}}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.2)}}

/* Hero panel */
.story--hero h1{font-size:clamp(3rem,11vw,6rem);color:#fff;font-style:italic;font-weight:700;margin:.2em 0;
  text-shadow:0 4px 30px rgba(0,0,0,.4)}
.story--hero .badges{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:var(--sp-3)}
.story--hero .badge{background:rgba(35,92,58,.55);border:1px solid var(--gold);color:#fff;border-radius:10px;padding:.5rem .9rem;font-size:.82rem}
.story--hero .badge b{color:var(--gold-soft)}

/* Scroll cue */
.scroll-cue{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);color:#fff;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;opacity:.85;display:flex;flex-direction:column;align-items:center;gap:.4rem}
.scroll-cue .chev{width:15px;height:15px;border-right:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(45deg);animation:cue 1.3s infinite ease-in-out}
/* Mũi tên nhấp nháy (blink) + nảy nhẹ xuống */
@keyframes cue{0%,100%{opacity:1;transform:rotate(45deg) translate(0,0)}50%{opacity:.15;transform:rotate(45deg) translate(3px,3px)}}

/* Dot navigation */
.dotnav{position:fixed;right:1.1rem;top:50%;transform:translateY(-50%);z-index:70;display:none;flex-direction:column;gap:.7rem}
.dotnav button{width:11px;height:11px;border-radius:50%;border:1.5px solid var(--gold);background:transparent;cursor:pointer;padding:0;transition:.25s;position:relative}
.dotnav button:hover{background:var(--gold)}
.dotnav button.active{background:var(--gold);transform:scale(1.25)}
.dotnav button .tip{position:absolute;right:20px;top:50%;transform:translateY(-50%);white-space:nowrap;
  background:var(--green-dk);color:#fff;font-size:.72rem;padding:.2rem .5rem;border-radius:6px;opacity:0;pointer-events:none;transition:.2s}
.dotnav button:hover .tip{opacity:1}

/* Menu showcase: ảnh nền đổi theo món + sidebar trong suốt bên trái = danh sách món */
.menu-showcase{padding:0;justify-content:center;text-align:left}
.ms-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;
  transition:opacity .45s ease;will-change:opacity}
.ms-scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(18,40,26,.96) 0%,rgba(18,40,26,.82) 32%,rgba(18,40,26,.35) 62%,rgba(18,40,26,0) 100%)}
.ms-panel{position:relative;z-index:2;color:#fff;width:100%;max-width:520px;padding:5.5rem 2rem 2rem 0;
  align-self:flex-start;margin-left:max(var(--sp-2),calc((100vw - var(--maxw)) / 2 + var(--sp-2)));max-height:100dvh}
.ms-panel .eyebrow{color:var(--gold-soft)}
.ms-panel h2{color:#fff;font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:.3rem}
.ms-list{list-style:none;padding:0;margin:.9rem 0 1.2rem}
.ms-item{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;width:100%;position:relative;
  background:none;border:0;border-bottom:1px solid rgba(255,255,255,.16);padding:.58rem .2rem;
  cursor:pointer;font:inherit;color:#e7efe7;text-align:left;transition:.2s}
.ms-item .v{font-family:var(--font-head);font-size:1.3rem;line-height:1.1}
.ms-item .e{display:block;font-style:italic;font-size:.8rem;color:#bcd0bc;margin-top:0}
.ms-item .p{font-family:var(--font-head);font-size:1.85rem;font-weight:700;color:var(--gold-soft);white-space:nowrap}
.ms-item:hover{padding-left:.7rem;color:#fff}
.ms-item.active .v{color:var(--gold-soft)}
.ms-item.active::before{content:"";position:absolute;left:-.95rem;top:.85rem;bottom:.85rem;width:3px;background:var(--gold);border-radius:2px}
@media(max-width:820px){
  .ms-scrim{background:linear-gradient(180deg,rgba(18,40,26,.55) 0%,rgba(18,40,26,.9) 50%)}
  .ms-panel{max-width:none;padding:6rem 1.5rem 2.5rem;margin-left:0}
}

/* Scroll-reveal (gate sau .js-reveal — JS off thì nội dung vẫn hiện) */
.js-reveal .story .panel > *{opacity:0;transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
.js-reveal .story.in-view .panel > *{opacity:1;transform:none}
.js-reveal .story.in-view .panel > *:nth-child(1){transition-delay:.05s}
.js-reveal .story.in-view .panel > *:nth-child(2){transition-delay:.18s}
.js-reveal .story.in-view .panel > *:nth-child(3){transition-delay:.31s}
.js-reveal .story.in-view .panel > *:nth-child(4){transition-delay:.44s}
.js-reveal .story.in-view .panel > *:nth-child(5){transition-delay:.57s}
.js-reveal .story.in-view .panel > *:nth-child(n+6){transition-delay:.7s}
/* Scroll cue fade theo panel */
.js-reveal .story .scroll-cue{opacity:0;transition:opacity .6s .6s}
.js-reveal .story.in-view .scroll-cue{opacity:.85}

/* Hover ảnh món + thẻ */
.dish-media img{transition:transform .6s cubic-bezier(.22,.61,.36,1)}
.dish:hover .dish-media img{transform:scale(1.07)}
.dish-media{transition:box-shadow .3s}
.dish:hover .dish-media{box-shadow:0 14px 32px rgba(22,62,39,.18)}
/* Hover dish placeholder (khi chưa có ảnh) */
.dish:hover .dish-media .ph{filter:brightness(1.08)}
/* Nút có chuyển động nhẹ */
.btn{transition:background .2s,transform .2s,box-shadow .2s}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.18)}
/* Dot nav mượt */
.dotnav button{transition:background .25s,transform .25s}

/* Reduced motion — tắt mọi hiệu ứng chuyển động */
@media (prefers-reduced-motion: reduce){
  html{scroll-snap-type:none}
  .scroll-cue .chev{animation:none}
  .story--image::before,.story--image2::before{animation:none;transform:none}
  .story .panel > *{opacity:1 !important;transform:none !important;transition:none}
  .story .scroll-cue{opacity:.85}
  .dish:hover .dish-media img{transform:none}
  .btn:hover{transform:none}
}

