/* ============================================================
   #TagCoffee Home v6.3 — scroll-film
   ============================================================ */

:root{
  --bg-deep:#0e0805; --bg-mid:#1a0e08; --bg-soft:#fdf7f0; --paper:#f6ecde;
  --ink:#1a0e08; --ink-soft:#4a342a; --muted:#8a7a6b;
  --accent:#c88745; --accent-deep:#9b6532; --cream:#fff4e5;
  --line:rgba(26,14,8,.10);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg-soft);color:var(--ink);
  font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Noto Sans TC","PingFang TC","Microsoft JhengHei","Segoe UI",sans-serif;
  font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
img{display:block;max-width:100%;height:auto}
ul,ol{list-style:none;margin:0;padding:0}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}
.m-version-badge{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ───────────────── NAV ───────────────── */
.site-nav{position:sticky;top:0;z-index:100;
  display:flex;align-items:center;gap:18px;padding:12px 18px;
  background:rgba(253,247,240,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.site-nav__brand{display:flex;flex-direction:column;line-height:1.05;flex:0 0 auto}
.brand-mark{font-weight:800;font-size:17px;color:var(--ink);letter-spacing:.01em}
.brand-sub{font-size:10.5px;color:var(--accent-deep);letter-spacing:.16em}
.site-nav__primary{display:none;flex:1;gap:18px;justify-content:center;align-items:center}
.site-nav__primary a{font-size:14px;font-weight:600;color:var(--ink-soft);padding:6px 4px;border-bottom:2px solid transparent;transition:color .18s, border-color .18s}
.site-nav__primary a:hover{color:var(--accent-deep);border-bottom-color:var(--accent)}
.site-nav__actions{display:none;gap:8px;flex:0 0 auto}
.nav-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:700;line-height:1.2;transition:transform .15s, box-shadow .18s}
.nav-btn--ghost{background:rgba(26,14,8,.06);color:var(--ink)}
.nav-btn--ghost:hover{background:rgba(26,14,8,.10)}
.nav-btn--primary{background:var(--accent);color:#1a0e08;box-shadow:0 4px 12px rgba(200,135,69,.28)}
.nav-btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(200,135,69,.38)}
.site-nav__hamburger{display:inline-flex;flex-direction:column;justify-content:center;gap:4px;
  width:36px;height:36px;padding:0;margin-left:auto;border-radius:8px;background:transparent}
.site-nav__hamburger span{display:block;width:20px;height:2px;background:var(--ink);margin:0 auto;transition:transform .2s}
.site-nav__hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.site-nav__hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.site-nav__hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media (min-width:960px){
  .site-nav{gap:24px;padding:14px 36px}
  .site-nav__primary{display:flex}
  .site-nav__actions{display:flex}
  .site-nav__hamburger{display:none}
}

.mobile-dock{position:fixed;left:0;right:0;bottom:0;z-index:90;
  display:flex;justify-content:space-around;
  padding:8px 10px calc(8px + env(safe-area-inset-bottom));
  background:rgba(253,247,240,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--line)}
.mobile-dock a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:6px 4px;font-size:11px;font-weight:700;color:var(--ink-soft)}
.mobile-dock a span{font-size:18px;line-height:1}
.mobile-dock a:hover,.mobile-dock a:focus-visible{color:var(--accent-deep)}
@media (min-width:768px){.mobile-dock{display:none}}

.mobile-drawer{position:fixed;inset:0;z-index:200;background:rgba(253,247,240,.98);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center}
.mobile-drawer[hidden]{display:none}
.mobile-drawer__close{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:50%;background:rgba(26,14,8,.06);font-size:20px}
.mobile-drawer nav{display:flex;flex-direction:column;gap:14px;text-align:center;padding:60px 22px}
.mobile-drawer nav a{font-size:20px;font-weight:700;color:var(--ink);padding:8px 0}
.mobile-drawer nav hr{width:60%;border:0;border-top:1px solid var(--line);margin:8px auto}

/* ───────────────── shared section-header ───────────────── */
.section-header{display:flex;flex-direction:column;gap:8px;margin-bottom:28px;padding:0 22px}
.eyebrow{font-size:12px;letter-spacing:.30em;color:var(--accent-deep);font-weight:700;text-transform:uppercase;margin:0}
.section-header h2{margin:0;font-size:clamp(28px,6.4vw,42px);font-weight:800;line-height:1.18;color:var(--ink)}
.section-header > p{margin:0;color:var(--ink-soft);font-size:15px;max-width:600px}
@media (min-width:768px){.section-header{padding:0 40px}}
@media (min-width:1024px){.section-header{padding:0 60px}}

/* ───────────────── 1. SCROLL FILM ───────────────── */
.m-film{position:relative;background:#0e0805;color:#fff8ed}
/* 700vh = 6 viewports of scroll runway; sticky stage pins for 6 viewports */
.m-film__stage{position:relative;height:700vh}
.m-film__sticky{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden}

/* frame stack — absolutely positioned, only one visible at a time via opacity */
.m-film__frames{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.m-film__frame{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  opacity:0;will-change:opacity;contain:layout paint;
  transform:translateZ(0)}
/* the very first frame is visible at page load until JS measures and updates */
.m-film__frame[data-frame="0"]{opacity:1}
/* Mobile (<768px) is served pre-cropped 9:16 portrait sources via <picture><source media>;
   no object-position trick needed — the source itself already frames the pour action. */

/* warm gradient overlay so copy + CTAs are legible over the frame */
.m-film__overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(14,8,5,.62) 0%, rgba(14,8,5,.18) 22%, rgba(14,8,5,0) 36%, rgba(14,8,5,0) 60%, rgba(14,8,5,.46) 86%, rgba(14,8,5,.86) 100%)}

/* copy at top */
.m-film__copy{position:absolute;top:18px;left:18px;right:18px;z-index:3;
  display:flex;flex-direction:column;gap:8px;color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.55)}
.m-film__eyebrow{margin:0;font-size:10.5px;letter-spacing:.32em;font-weight:700;text-transform:uppercase;color:var(--accent)}
.m-film__h1{margin:0;font-size:clamp(22px,6.4vw,36px);line-height:1.18;font-weight:800}
.m-film__lead{margin:0;font-size:13px;color:#fff4e5;line-height:1.55;max-width:520px}
.m-film__captions{position:relative;height:30px;margin-top:6px}
.m-film__cap{position:absolute;left:0;top:0;font-size:14px;font-weight:700;color:#fff;
  opacity:0;transition:opacity .35s ease-out;letter-spacing:.02em;
  text-shadow:0 2px 12px rgba(0,0,0,.7)}

/* progress bar (slim, lower) */
.m-film__progress{position:absolute;left:18px;right:18px;bottom:160px;z-index:3;
  display:flex;flex-direction:column;gap:6px}
.m-film__progress-bar{position:relative;height:3px;background:rgba(255,244,229,.20);border-radius:2px;overflow:hidden}
.m-film__progress-bar::after{content:'';position:absolute;left:0;top:0;bottom:0;width:var(--pp, 0%);
  background:linear-gradient(90deg,var(--accent),#e6b076);border-radius:2px;transition:width .12s linear}
.m-film__progress-ticks{display:flex;justify-content:space-between;font-size:9.5px;font-weight:700;color:rgba(255,244,229,.6);letter-spacing:.10em}
.m-film__progress-ticks span{display:inline-flex;flex-direction:column;align-items:center}
.m-film__progress-ticks span::after{content:attr(data-label);font-size:9px;font-weight:500;color:rgba(255,244,229,.45);margin-top:2px;letter-spacing:0}

/* CTAs at bottom */
.m-film__ctas{position:absolute;left:18px;right:18px;bottom:88px;z-index:3;display:flex;flex-direction:column;gap:8px}
.m-film__cta{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:13px 18px;
  border-radius:999px;font-size:14px;font-weight:700;min-height:46px;transition:transform .15s, box-shadow .18s}
.m-film__cta--primary{background:var(--accent);color:#1a0e08;box-shadow:0 6px 18px rgba(200,135,69,.45)}
.m-film__cta--ghost{background:rgba(255,244,229,.10);color:#fff;border:1.5px solid rgba(255,244,229,.30);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.m-film__cta:hover,.m-film__cta:focus-visible{transform:translateY(-1px)}

.m-film__hint{position:absolute;left:0;right:0;bottom:48px;text-align:center;z-index:3;
  margin:0;font-size:11.5px;color:rgba(255,244,229,.55);letter-spacing:.06em;
  animation:hintBob 2.4s ease-in-out infinite}
@keyframes hintBob{0%,100%{transform:translateY(0);opacity:.55}50%{transform:translateY(4px);opacity:.85}}

/* desktop: copy on left, frame still fills viewport (object-fit cover crops slightly) */
@media (min-width:768px){
  .m-film__copy{top:36px;left:6vw;right:auto;max-width:46vw;gap:14px}
  .m-film__h1{font-size:clamp(36px,4.6vw,56px)}
  .m-film__lead{font-size:16px;color:#fff4e5}
  .m-film__captions{height:34px}
  .m-film__cap{font-size:16px}
  .m-film__progress{left:6vw;right:6vw;bottom:120px}
  .m-film__ctas{left:6vw;right:auto;bottom:48px;flex-direction:row;gap:10px}
  .m-film__cta{flex:0 0 auto}
  .m-film__hint{left:6vw;right:auto;bottom:18px;text-align:left}
  .m-film__overlay{
    background:linear-gradient(90deg, rgba(14,8,5,.72) 0%, rgba(14,8,5,.40) 36%, rgba(14,8,5,.08) 60%, rgba(14,8,5,0) 78%),
               linear-gradient(180deg, rgba(14,8,5,0) 60%, rgba(14,8,5,.34) 88%, rgba(14,8,5,.6) 100%)
  }
}

/* ───────────────── 2. MENU ───────────────── */
.m-menu-v6{padding:80px 0;background:var(--bg-soft)}
.m-menu-v6__inner{max-width:1180px;margin:0 auto}
.m-menu-v6__group{padding:32px 22px;border-top:1px solid var(--line)}
.m-menu-v6__group:first-of-type{border-top:0}
.m-menu-v6__group-title{margin:0 0 6px;font-size:clamp(18px,4vw,22px);font-weight:800;display:flex;align-items:center;gap:8px;color:var(--ink)}
.m-menu-v6__group-title .ico{font-size:1.2em}
.m-menu-v6__group-note{margin:0 0 18px;color:var(--ink-soft);font-size:13.5px;background:rgba(200,135,69,.10);border-left:3px solid var(--accent);padding:8px 12px;border-radius:0 8px 8px 0}
.m-menu-v6__cards{display:grid;grid-template-columns:1fr;gap:14px;margin-top:18px}
.m-menu-v6__card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;
  display:flex;flex-direction:column;gap:6px;box-shadow:0 4px 14px rgba(58,36,28,.04);
  opacity:0;transform:translateY(18px);transition:opacity .55s ease-out, transform .55s cubic-bezier(.2,.7,.2,1)}
.m-menu-v6.is-in .m-menu-v6__card{opacity:1;transform:translateY(0)}
.m-menu-v6.is-in .m-menu-v6__card[data-i="1"]{transition-delay:.04s}
.m-menu-v6.is-in .m-menu-v6__card[data-i="2"]{transition-delay:.08s}
.m-menu-v6.is-in .m-menu-v6__card[data-i="3"]{transition-delay:.12s}
.m-menu-v6.is-in .m-menu-v6__card[data-i="4"]{transition-delay:.16s}
.m-menu-v6.is-in .m-menu-v6__card[data-i="5"]{transition-delay:.20s}
.m-menu-v6.is-in .m-menu-v6__card[data-i="6"]{transition-delay:.24s}
.m-menu-v6__card .en{font-size:11px;letter-spacing:.18em;color:var(--accent-deep);text-transform:uppercase;font-weight:700}
.m-menu-v6__card h4{margin:0;font-size:19px;font-weight:800;color:var(--ink)}
.m-menu-v6__card p{margin:0;font-size:14px;color:var(--ink-soft);line-height:1.65;flex:1}
.m-menu-v6__card--brunch{background:#fbf6ee}
.m-menu-v6__chip{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
  padding:7px 13px;border-radius:999px;background:var(--accent);color:#1a0e08;
  font-size:12.5px;font-weight:700;margin-top:6px;transition:transform .15s, box-shadow .18s}
.m-menu-v6__chip:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(200,135,69,.34)}
.m-menu-v6__status{align-self:flex-start;font-size:11.5px;background:rgba(74,52,42,.08);color:var(--ink-soft);padding:5px 10px;border-radius:999px;margin-top:6px}
.m-menu-v6__group--beans p{font-size:14px;color:var(--ink-soft);margin:8px 0 16px}
.cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:999px;font-size:14px;font-weight:700;min-height:46px;transition:transform .15s, box-shadow .18s}
.cta-btn--primary{background:var(--accent);color:#1a0e08;box-shadow:0 6px 18px rgba(200,135,69,.40)}
.cta-btn--primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(200,135,69,.50)}
@media (min-width:768px){.m-menu-v6{padding:96px 0}.m-menu-v6__group{padding:40px}.m-menu-v6__cards{grid-template-columns:repeat(3,1fr);gap:18px}}
@media (min-width:1024px){.m-menu-v6__group{padding:48px 60px}}

/* ───────────────── 3. TIPS ───────────────── */
.m-tips{padding:80px 0;background:linear-gradient(180deg,#fbf2e5 0%,#f6ecde 100%)}
.m-tips__inner{max-width:1100px;margin:0 auto}
.m-tips__chips{display:grid;grid-template-columns:1fr;gap:12px;padding:0 22px}
.tip-chip{display:flex;align-items:center;gap:12px;padding:18px 22px;
  background:#fff;border:1px solid var(--line);border-radius:18px;text-align:left;
  box-shadow:0 4px 16px rgba(58,36,28,.06);cursor:pointer;
  opacity:0;transform:translateY(16px);
  transition:opacity .55s ease-out, transform .55s cubic-bezier(.2,.7,.2,1), box-shadow .25s, border-color .25s}
.m-tips.is-in .tip-chip{opacity:1;transform:translateY(0)}
.m-tips.is-in .tip-chip:nth-child(1){transition-delay:.04s}
.m-tips.is-in .tip-chip:nth-child(2){transition-delay:.10s}
.m-tips.is-in .tip-chip:nth-child(3){transition-delay:.16s}
.tip-chip:hover,.tip-chip:focus-visible{transform:translateY(-2px);box-shadow:0 12px 28px rgba(58,36,28,.12);border-color:var(--accent)}
.tip-chip__num{flex:0 0 auto;font-size:24px;font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums}
.tip-chip__title{flex:1;font-size:17px;font-weight:800;color:var(--ink)}
.tip-chip__hint{flex:0 0 auto;font-size:12px;color:var(--ink-soft);letter-spacing:.05em}
@media (min-width:768px){.m-tips__chips{grid-template-columns:repeat(3,1fr);padding:0 40px}.tip-chip{flex-direction:column;align-items:flex-start;gap:10px;padding:24px}}
@media (min-width:1024px){.m-tips__chips{padding:0 60px}}

/* ───────────────── 4. MOMENTS ───────────────── */
.m-moments{padding:80px 0;background:#fff}
.m-moments__inner{max-width:1180px;margin:0 auto}
.m-moments__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 22px}
.m-moments__grid figure{margin:0;border-radius:10px;overflow:hidden;aspect-ratio:1}
.m-moments__grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.m-moments__grid figure:hover img{transform:scale(1.05)}
.m-moments__reviews{padding:28px 22px 0;text-align:center}
.m-moments__reviews-note{font-size:13.5px;color:var(--muted);max-width:540px;margin:0 auto}
@media (min-width:768px){.m-moments__grid{grid-template-columns:repeat(3,1fr);gap:12px;padding:0 40px}.m-moments__reviews{padding:36px 40px 0}}
@media (min-width:1024px){.m-moments__grid{padding:0 60px}.m-moments__reviews{padding:48px 60px 0}}

/* ───────────────── 5. CONTACT ───────────────── */
.m-contact{padding:80px 0 120px;background:linear-gradient(180deg,#fdf7f0 0%,#1a0e08 100%);color:var(--cream)}
.m-contact__inner{max-width:920px;margin:0 auto}
.m-contact .section-header h2{color:var(--ink)}
.m-contact__info{display:grid;grid-template-columns:1fr;gap:16px;padding:0 22px;margin:0 0 36px}
.m-contact__info div{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 18px;display:grid;grid-template-columns:80px 1fr;gap:8px;align-items:start}
.m-contact__info dt{font-size:12.5px;color:var(--accent-deep);font-weight:700;letter-spacing:.06em}
.m-contact__info dd{margin:0;font-size:14px;color:var(--ink);line-height:1.7}
.m-contact__info dd a{color:var(--accent-deep);font-weight:700;text-decoration:underline;text-decoration-color:rgba(155,101,50,.3);text-underline-offset:3px}
.m-contact__info dd .muted{color:var(--muted);font-size:13px}
.m-contact__info dd strong{color:var(--ink)}
.m-contact__final{margin:48px 22px 0;padding:36px 22px;background:rgba(255,244,229,.06);border:1px solid rgba(255,244,229,.18);border-radius:18px;text-align:center;backdrop-filter:blur(10px)}
.m-contact__final-eyebrow{font-size:11px;letter-spacing:.32em;color:var(--accent);font-weight:700;text-transform:uppercase;margin:0 0 6px}
.m-contact__final h3{margin:0 0 18px;font-size:clamp(20px,5vw,28px);font-weight:800;color:var(--cream)}
.cta-final{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--accent);color:#1a0e08;border-radius:999px;font-size:15px;font-weight:800;box-shadow:0 8px 24px rgba(200,135,69,.50);transition:transform .15s, box-shadow .18s}
.cta-final::after{content:'→';transition:transform .2s}
.cta-final:hover,.cta-final:focus-visible{transform:translateY(-2px);box-shadow:0 12px 32px rgba(200,135,69,.65)}
.cta-final:hover::after{transform:translateX(4px)}
@media (min-width:768px){.m-contact__info{grid-template-columns:repeat(2,1fr);padding:0 40px}}

/* ───────────────── FOOTER ───────────────── */
.site-foot{background:#0e0805;color:#cbb59a;padding:48px 22px 88px}
.site-foot__cols{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1100px;margin:0 auto}
.site-foot__cols h4{margin:0 0 10px;font-size:13px;color:var(--cream);letter-spacing:.06em}
.site-foot__cols a,.site-foot__cols p{display:block;font-size:13px;color:#a89580;line-height:1.9}
.site-foot__cols a:hover{color:var(--accent)}
.site-foot__copy{margin:32px auto 0;padding-top:20px;border-top:1px solid rgba(255,244,229,.10);text-align:center;font-size:12px;color:#8a7560;max-width:1100px}
.site-foot__copy a{color:#a89580;text-decoration:underline}
@media (min-width:768px){.site-foot{padding:64px 40px 48px}.site-foot__cols{grid-template-columns:repeat(4,1fr)}}

/* ───────────────── MODAL ───────────────── */
.modal{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;padding:22px}
.modal[aria-hidden="false"]{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(14,8,5,.66);border:0;cursor:pointer;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.modal__panel{position:relative;background:#fff;border-radius:22px;padding:32px 24px 26px;max-width:460px;width:100%;box-shadow:0 30px 80px rgba(0,0,0,.45);animation:modalPop .26s cubic-bezier(.2,.7,.2,1)}
@keyframes modalPop{from{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:none}}
.modal__close{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:rgba(26,14,8,.06);font-size:18px;color:var(--ink)}
.modal__close:hover{background:rgba(26,14,8,.12)}
.modal__eyebrow{margin:0 0 6px;font-size:11px;letter-spacing:.28em;color:var(--accent-deep);font-weight:700;text-transform:uppercase}
.modal__panel h3{margin:0 0 12px;font-size:22px;font-weight:800;color:var(--ink);line-height:1.3}
.modal__panel p{margin:0 0 18px;font-size:15px;color:var(--ink-soft);line-height:1.75}
.modal__cta{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;background:var(--accent);color:#1a0e08;border-radius:999px;font-size:14px;font-weight:800;min-height:44px;box-shadow:0 6px 18px rgba(200,135,69,.36)}
.modal__cta:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(200,135,69,.50)}
.modal__cta--ghost{background:rgba(26,14,8,.06);color:var(--ink);box-shadow:none}
.modal__panel--final{background:linear-gradient(180deg,#fff 0%,#fff8ed 100%)}
.modal__final-list{margin:0 0 14px;padding:0;display:flex;flex-direction:column;gap:10px}
.modal__final-list li{font-size:15px;color:var(--ink-soft);line-height:1.6;padding-left:18px;position:relative}
.modal__final-list li::before{content:'•';position:absolute;left:0;color:var(--accent);font-weight:800;font-size:20px;line-height:1.3}
.modal__final-list li strong{color:var(--ink);font-weight:800}
.modal__final-list li em{font-style:normal;color:var(--accent-deep);font-weight:800}
.modal__final-summary{margin:0 0 16px;padding:12px 14px;font-size:14px;color:var(--ink-soft);background:rgba(200,135,69,.10);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;line-height:1.65}
.modal__final-ctas{display:flex;flex-direction:column;gap:8px}
@media (min-width:480px){.modal__final-ctas{flex-direction:row}.modal__final-ctas .modal__cta{flex:1}}

body.modal-open{overflow:hidden}
body.drawer-open{overflow:hidden}

/* ───────────────── prefers-reduced-motion fallback ───────────────── */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  .m-menu-v6__card,.tip-chip{opacity:1 !important;transform:none !important}
  /* show the final pour state as a static image */
  .m-film__stage{height:auto}
  .m-film__sticky{position:relative;height:100vh;height:100svh}
  /* override the base rule that keeps frame_0 visible at page load */
  .m-film__frame{opacity:0 !important}
  .m-film__frame[data-frame="12"]{opacity:1 !important}
  .m-film__progress-bar::after{width:100% !important}
  .m-film__cap[data-from="0.78"]{opacity:1}
  .m-film__cap:not([data-from="0.78"]){opacity:0}
}
