/* ==========================================================================
   #TagCoffee — Full local review v2  (Hero + About + Menu + Store + Gallery + Footer)
   mobile-first immersive · CSS @keyframes + IntersectionObserver reveal
   Scoped under body.twt-motion; isolated from production _immersive_v10/core.css.
   ========================================================================== */

:root{
  --twt-bg-deep:#1a0e08;
  --twt-bg-mid:#2a1810;
  --twt-bg-soft:#fdf7f0;
  --twt-bg-cream:#fbf3e9;
  --twt-text:#2a1810;
  --twt-text-soft:#5a4438;
  --twt-text-on-dark:#fff5e6;
  --twt-accent:#c89060;
  --twt-accent-deep:#92400e;
  --twt-line:rgba(58,36,28,.12);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--twt-bg-deep);color:var(--twt-text);
  font-family:"Noto Sans TC","PingFang TC","Microsoft JhengHei",ui-sans-serif,system-ui,sans-serif;
  font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;
  scroll-behavior:smooth;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;cursor:pointer}

/* ==========================================================================
   shared CTA
   ========================================================================== */
.m-cta{display:inline-flex;align-items:center;justify-content:center;
  gap:8px;padding:14px 22px;border-radius:999px;
  font-size:15px;font-weight:700;line-height:1.2;
  min-height:48px;text-align:center;
  transition:transform .18s ease, box-shadow .18s ease, background .2s ease;
  border:1.5px solid transparent}
.m-cta--primary{background:var(--twt-accent-deep);color:#fff;
  box-shadow:0 8px 26px rgba(58,36,28,.45)}
.m-cta--primary:hover,.m-cta--primary:focus-visible{transform:translateY(-1px);
  box-shadow:0 12px 32px rgba(58,36,28,.55)}
.m-cta--secondary{background:rgba(255,250,245,.95);color:var(--twt-text);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.m-cta--secondary:hover,.m-cta--secondary:focus-visible{transform:translateY(-1px);
  background:#fff}

/* ==========================================================================
   1) HERO  — 3-layer + ken-burns + steam + bean particles + fadeUp
   ========================================================================== */
.m-hero{position:relative;min-height:100vh;min-height:100svh;overflow:hidden;
  color:var(--twt-text-on-dark);display:flex;align-items:flex-end}
.m-hero__bg{position:absolute;inset:0;z-index:0;
  background:url("twtagcoffee/hero-coffee-mobile.webp") center/cover no-repeat;
  transform:scale(1.06) translate3d(0,0,0);
  animation:kenBurns 22s ease-in-out infinite alternate;
  will-change:transform}
@keyframes kenBurns{
  0%   {transform:scale(1.06) translate3d(0,0,0)}
  100% {transform:scale(1.20) translate3d(-2%,-1.5%,0)}
}
.m-hero__overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.10) 0%,rgba(0,0,0,.06) 35%,rgba(26,14,8,.55) 70%,rgba(26,14,8,.96) 100%)}
.m-hero__steam{position:absolute;left:50%;bottom:32%;z-index:2;
  width:60px;height:200px;transform:translateX(-50%);
  opacity:.55;filter:blur(2.5px);mix-blend-mode:screen;pointer-events:none}
.m-hero__steam path{animation:steamRise 6s ease-in-out infinite;transform-origin:50% 100%}
.m-hero__steam path:nth-child(2){animation-delay:-2s}
.m-hero__steam path:nth-child(3){animation-delay:-4s}
@keyframes steamRise{
  0%   {transform:translate3d(0,0,0) scaleX(1); opacity:0}
  18%  {opacity:.9}
  100% {transform:translate3d(0,-110px,0) scaleX(1.4); opacity:0}
}
.m-hero__bean{position:absolute;z-index:2;width:9px;height:13px;
  background:radial-gradient(ellipse at 35% 35%, #5a3823 0%, #2a1810 70%);
  border-radius:50%/60%;opacity:.42;pointer-events:none;
  animation:floatBean 9s ease-in-out infinite;will-change:transform}
.m-hero__bean:nth-child(odd){animation-duration:12s}
@keyframes floatBean{
  0%   {transform:translate3d(0,0,0) rotate(0)}
  50%  {transform:translate3d(10px,-18px,0) rotate(180deg)}
  100% {transform:translate3d(0,0,0) rotate(360deg)}
}

.m-hero__inner{position:relative;z-index:3;width:100%;
  padding:40px 22px 50px;display:flex;flex-direction:column;gap:14px;
  max-width:560px;margin:0 auto}
.m-hero__eyebrow{font-size:12px;letter-spacing:.25em;color:var(--twt-accent);
  font-weight:700;text-transform:uppercase;
  opacity:0;animation:fadeUp .8s ease-out .3s forwards}
.m-hero__h1{margin:0;font-size:clamp(28px,7.6vw,52px);line-height:1.18;
  font-weight:800;letter-spacing:.01em;text-shadow:0 2px 22px rgba(0,0,0,.65);
  opacity:0;animation:fadeUp .95s cubic-bezier(.2,.7,.2,1) .55s forwards}
.m-hero__sub{margin:0;font-size:15px;color:#f3e6d5;line-height:1.65;
  opacity:0;animation:fadeUp .8s ease-out .9s forwards}
.m-hero__ctas{display:flex;flex-direction:column;gap:10px;margin-top:8px;
  opacity:0;animation:fadeUp .8s ease-out 1.2s forwards}
@keyframes fadeUp{
  from{opacity:0;transform:translate3d(0,26px,0)}
  to  {opacity:1;transform:translate3d(0,0,0)}
}
.m-hero__scroll{position:absolute;left:50%;bottom:20px;z-index:4;
  transform:translateX(-50%);width:24px;height:38px;
  border:2px solid rgba(255,245,230,.55);border-radius:999px;opacity:0;
  animation:fadeUp .8s ease-out 1.5s forwards, bobble 2.4s ease-in-out 2.3s infinite}
.m-hero__scroll::after{content:'';position:absolute;left:50%;top:7px;
  width:3px;height:8px;background:var(--twt-accent);border-radius:2px;
  transform:translateX(-50%);animation:scrollDot 2.4s ease-in-out 2.3s infinite}
@keyframes bobble{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,6px)}}
@keyframes scrollDot{0%{transform:translate(-50%,0);opacity:1}60%{transform:translate(-50%,14px);opacity:0}100%{transform:translate(-50%,0);opacity:1}}

/* ==========================================================================
   2) ABOUT  — sticky pinned canvas + IO reveal
   ========================================================================== */
.m-about{position:relative;
  background:linear-gradient(180deg,var(--twt-bg-deep) 0%,var(--twt-bg-mid) 18%,#4a2e1e 38%,#8a6850 65%,var(--twt-bg-soft) 100%);
  color:var(--twt-text)}
.m-about::before{content:'';position:absolute;left:0;right:0;top:-1px;height:120px;
  background:linear-gradient(180deg,var(--twt-bg-deep),transparent);pointer-events:none;z-index:1}
.m-about__stage{position:relative;height:280vh}
.m-about__sticky{position:sticky;top:0;height:100vh;height:100svh;
  display:flex;flex-direction:column;overflow:hidden;z-index:2}
.m-about__media{position:absolute;inset:0;
  background:url("twtagcoffee/beans-closeup.webp") center/cover no-repeat;
  transform:scale(1.08);transition:transform 2.2s cubic-bezier(.2,.7,.2,1)}
.m-about__media.is-zoomed{transform:scale(1.30)}
.m-about__overlay{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(26,14,8,.10) 0%,rgba(26,14,8,.40) 50%,rgba(253,247,240,.92) 100%)}
.m-about__copy{position:absolute;left:22px;right:22px;bottom:0;z-index:3;
  display:flex;flex-direction:column;gap:20px;padding:0 0 60px;max-width:560px;margin:0 auto}
.m-about__line{opacity:0;transform:translate3d(0,32px,0);
  transition:opacity .9s ease-out, transform .9s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}
.m-about__line.is-in{opacity:1;transform:translate3d(0,0,0)}
.m-about__line h2{margin:0;font-size:clamp(24px,6vw,38px);font-weight:800;line-height:1.25;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.55)}
.m-about__line p {margin:0;font-size:16px;line-height:1.75;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.55)}
.m-about__line[data-line="3"] h2,.m-about__line[data-line="3"] p{color:var(--twt-text);text-shadow:none}

/* ==========================================================================
   2.5) SKETCH  — scroll-driven latte-art line drawing (between About & Menu)
   ========================================================================== */
.m-sketch{position:relative;
  background:linear-gradient(180deg,
    var(--twt-bg-soft) 0%,
    #f5e8d6 35%,
    #f0dec5 70%,
    var(--twt-bg-mid) 100%);
  color:var(--twt-text);overflow:hidden}
.m-sketch__stage{position:relative;height:220vh}
.m-sketch__sticky{position:sticky;top:0;height:100vh;height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:18px;padding:40px 22px;text-align:center}
.m-sketch__eyebrow{font-size:11px;letter-spacing:.32em;color:var(--twt-accent-deep);
  font-weight:700;text-transform:uppercase;margin:0;
  opacity:0;animation:none}
.m-sketch.is-in .m-sketch__eyebrow{opacity:1;transition:opacity .8s ease-out}
.m-sketch__title{margin:0;font-size:clamp(22px,5.8vw,34px);font-weight:800;
  line-height:1.35;color:var(--twt-text);max-width:520px;
  opacity:0;transform:translate3d(0,18px,0);
  transition:opacity .9s ease-out, transform .9s cubic-bezier(.2,.7,.2,1)}
.m-sketch.is-in .m-sketch__title{opacity:1;transform:translate3d(0,0,0);transition-delay:.15s}

.m-sketch__svg{width:min(78vw,360px);max-height:60vh;height:auto;
  filter:drop-shadow(0 6px 18px rgba(58,36,28,.12))}
.sk-line{
  fill:none;
  stroke:#3a241c;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
  /* dasharray & dashoffset set by JS once getTotalLength() known */
}
/* Initial invisible state (before JS measures) — appears as no stroke */
.sk-line:not([style*="dashoffset"]){stroke-opacity:0}

/* lighter strokes for atmospheric layers */
.sk-steam{stroke:#7a5b48;stroke-width:1.6;opacity:.7}
.sk-saucer{stroke-width:2}
.sk-cup{stroke-width:2.4}
.sk-rim{stroke-width:2.2}
.sk-surface{stroke:#92400e;stroke-width:1.6;opacity:.85}
.sk-handle{stroke-width:2.4}
.sk-heart-l,.sk-heart-r,.sk-heart-tip{
  stroke:#92400e;  /* warm caramel for the latte art lines */
  stroke-width:2.6}

.m-sketch__caption{margin:0;font-size:13px;color:var(--twt-text-soft);
  letter-spacing:.06em;
  opacity:0;transform:translate3d(0,10px,0);
  transition:opacity .8s ease-out, transform .8s ease-out}
.m-sketch.is-in .m-sketch__caption{opacity:.85;transform:translate3d(0,0,0);transition-delay:.4s}

@media (min-width:768px){
  .m-sketch__sticky{padding:60px 40px;gap:24px}
  .m-sketch__svg{width:min(56vw,400px);max-height:64vh}
}

/* ==========================================================================
   3) MENU  — dark coffee atmosphere · caramel drizzle draw · cards stagger
   ========================================================================== */
.m-menu{position:relative;overflow:hidden;
  background:var(--twt-bg-mid);color:var(--twt-text-on-dark);padding:64px 0 72px}
.m-menu__bg{position:absolute;inset:0;
  background:url("twtagcoffee/menu-drinks.webp") center/cover no-repeat;
  opacity:.30;filter:blur(2px) saturate(.9)}
.m-menu__overlay{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(26,14,8,.85) 0%,rgba(26,14,8,.92) 50%,rgba(26,14,8,.96) 100%)}
.m-menu__drizzle{position:absolute;top:60px;left:0;right:0;height:46px;width:100%;
  opacity:0;z-index:1;pointer-events:none}
.m-menu__drizzle path{stroke-dasharray:1200;stroke-dashoffset:1200}
.m-menu.is-in .m-menu__drizzle{opacity:1;transition:opacity .3s ease-out .1s}
.m-menu.is-in .m-menu__drizzle path{animation:drawDrizzle 2.2s ease-out .2s forwards}
@keyframes drawDrizzle{to{stroke-dashoffset:0}}

.m-menu__head{position:relative;z-index:2;max-width:1100px;margin:0 auto 30px;padding:0 22px;
  display:flex;flex-direction:column;gap:8px}
.m-menu__eyebrow{font-size:12px;letter-spacing:.25em;color:var(--twt-accent);font-weight:700;text-transform:uppercase}
.m-menu__head h2{margin:0;font-size:clamp(24px,6.2vw,38px);font-weight:800;color:#fff}
.m-menu__head p{margin:0;color:#cbb59a;font-size:14px}

.m-menu__cards{position:relative;z-index:2;list-style:none;padding:0 22px;margin:0;
  display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;
  max-width:1200px;margin:0 auto}
.m-menu__cards::-webkit-scrollbar{display:none}
.m-menu__card{flex:0 0 80%;max-width:300px;scroll-snap-align:start;
  background:linear-gradient(180deg,rgba(255,245,230,.07),rgba(255,245,230,.03));
  border:1px solid rgba(255,245,230,.13);border-radius:18px;
  padding:22px 18px;display:flex;flex-direction:column;gap:8px;min-height:200px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;transform:translate3d(0,28px,0);
  transition:opacity .7s ease-out, transform .7s cubic-bezier(.2,.7,.2,1), box-shadow .25s, background .25s}
.m-menu.is-in .m-menu__card{opacity:1;transform:translate3d(0,0,0)}
.m-menu.is-in .m-menu__card[data-i="1"]{transition-delay:.15s}
.m-menu.is-in .m-menu__card[data-i="2"]{transition-delay:.30s}
.m-menu.is-in .m-menu__card[data-i="3"]{transition-delay:.45s}
.m-menu.is-in .m-menu__card[data-i="4"]{transition-delay:.60s}
.m-menu.is-in .m-menu__card[data-i="5"]{transition-delay:.75s}
.m-menu.is-in .m-menu__card[data-i="6"]{transition-delay:.90s}
.m-menu__card:hover,.m-menu__card:focus-within{transform:translate3d(0,-4px,0);
  background:linear-gradient(180deg,rgba(255,245,230,.10),rgba(255,245,230,.05));
  box-shadow:0 14px 34px rgba(0,0,0,.45)}
.m-menu__card-en{font-size:13px;color:var(--twt-accent);letter-spacing:.10em;text-transform:uppercase}
.m-menu__card h3{margin:0;font-size:19px;font-weight:700;color:#fff}
.m-menu__card p{margin:0;font-size:14px;color:#e7d4be;line-height:1.65;flex:1}
.m-menu__card--brunch{border-color:rgba(200,144,96,.32)}
.m-menu__chip{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:999px;background:var(--twt-accent);color:#1a0e08;
  font-size:13px;font-weight:700;margin-top:auto;transition:transform .15s, box-shadow .15s}
.m-menu__chip:hover,.m-menu__chip:focus-visible{transform:translateY(-1px);box-shadow:0 6px 14px rgba(200,144,96,.40)}

@media (min-width:768px){
  .m-menu{padding:88px 0}
  .m-menu__cards{flex-wrap:wrap;overflow:visible;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:0 40px}
  .m-menu__card{flex:none;max-width:none}
}
@media (min-width:1024px){
  .m-menu__head{padding-left:60px;padding-right:60px}
  .m-menu__cards{padding-left:60px;padding-right:60px}
}

/* ==========================================================================
   4) STORE INFO  — frosted card on cafe-counter bg · rows stagger · path draw
   ========================================================================== */
.m-store{position:relative;overflow:hidden;padding:64px 0 72px;color:var(--twt-text)}
.m-store__bg{position:absolute;inset:0;
  background:url("twtagcoffee/cafe-counter.webp") center/cover no-repeat;filter:saturate(1.05)}
.m-store__veil{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(58,36,28,.62) 0%,rgba(58,36,28,.55) 100%)}
.m-store__path{position:absolute;top:34px;left:0;right:0;height:46px;width:100%;
  opacity:0;z-index:1;pointer-events:none}
.m-store__path path{stroke-dasharray:520;stroke-dashoffset:520}
.m-store.is-in .m-store__path{opacity:1;transition:opacity .3s ease-out}
.m-store.is-in .m-store__path path{animation:drawPath 2.4s ease-out .3s forwards}
@keyframes drawPath{to{stroke-dashoffset:0}}

.m-store__card{position:relative;z-index:2;max-width:560px;margin:0 22px;
  background:rgba(255,250,245,.97);border-radius:22px;
  padding:30px 26px 28px;box-shadow:0 30px 80px -20px rgba(0,0,0,.45);
  opacity:0;transform:translate3d(0,32px,0);
  transition:opacity .9s ease-out, transform .9s cubic-bezier(.2,.7,.2,1)}
.m-store.is-in .m-store__card{opacity:1;transform:translate3d(0,0,0)}

.m-store__head{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.m-store__eyebrow{font-size:11px;letter-spacing:.28em;color:var(--twt-accent-deep);font-weight:700;text-transform:uppercase}
.m-store__head h2{margin:0;font-size:clamp(22px,5.5vw,32px);font-weight:800;color:var(--twt-text)}

.m-store__rows{list-style:none;padding:0;margin:0}
.m-store__row{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px dashed var(--twt-line);
  opacity:0;transform:translate3d(0,16px,0);
  transition:opacity .55s ease-out, transform .55s cubic-bezier(.2,.7,.2,1)}
.m-store__row:last-child{border-bottom:none}
.m-store.is-in .m-store__row{opacity:1;transform:translate3d(0,0,0)}
.m-store.is-in .m-store__row[data-i="1"]{transition-delay:.25s}
.m-store.is-in .m-store__row[data-i="2"]{transition-delay:.38s}
.m-store.is-in .m-store__row[data-i="3"]{transition-delay:.51s}
.m-store.is-in .m-store__row[data-i="4"]{transition-delay:.64s}
.m-store.is-in .m-store__row[data-i="5"]{transition-delay:.77s}
.m-store.is-in .m-store__row[data-i="6"]{transition-delay:.90s}
.m-store__icon{font-size:20px;width:28px;line-height:1.4;flex:none}
.m-store__body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0;
  user-select:text;-webkit-user-select:text}
.m-store__label{font-size:12px;color:var(--twt-text-soft);letter-spacing:.05em}
.m-store__value{font-size:16px;color:var(--twt-text);font-weight:600;word-break:break-all}
.m-store__value a{color:var(--twt-accent-deep);font-weight:700}

.m-store__ctas{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.m-store__ctas .m-cta{width:100%;opacity:0;transform:translate3d(0,16px,0);
  transition:opacity .55s ease-out, transform .55s cubic-bezier(.2,.7,.2,1)}
.m-store.is-in .m-store__ctas .m-cta{opacity:1;transform:translate3d(0,0,0)}
.m-store.is-in .m-store__ctas .m-cta[data-i="1"]{transition-delay:1.05s}
.m-store.is-in .m-store__ctas .m-cta[data-i="2"]{transition-delay:1.18s}
.m-store.is-in .m-store__ctas .m-cta[data-i="3"]{transition-delay:1.31s}

@media (min-width:768px){
  .m-store{padding:88px 0}
  .m-store__card{margin:0 auto;padding:40px 36px}
  .m-store__ctas{flex-direction:row;flex-wrap:wrap}
  .m-store__ctas .m-cta{width:auto;flex:1;min-width:160px}
}

/* ==========================================================================
   5) GALLERY  — horizontal scroll rail with stagger reveal + drift
   ========================================================================== */
.m-gallery{position:relative;background:var(--twt-bg-deep);color:var(--twt-text-on-dark);padding:64px 0 72px;overflow:hidden}
.m-gallery__head{max-width:1200px;margin:0 auto 24px;padding:0 22px;display:flex;flex-direction:column;gap:6px}
.m-gallery__eyebrow{font-size:12px;letter-spacing:.25em;color:var(--twt-accent);font-weight:700;text-transform:uppercase}
.m-gallery__head h2{margin:0;font-size:clamp(24px,6vw,36px);font-weight:800;color:#fff}
.m-gallery__head p{margin:0;color:#cbb59a;font-size:14px}

.m-gallery__rail{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:6px 22px 16px;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}
.m-gallery__rail::-webkit-scrollbar{display:none}

.m-gallery__item{flex:0 0 70%;max-width:300px;scroll-snap-align:start;margin:0;
  border-radius:16px;overflow:hidden;background:#3a241c;
  box-shadow:0 14px 30px rgba(0,0,0,.45);
  opacity:0;transform:translate3d(0,30px,0);
  transition:opacity .7s ease-out, transform .7s cubic-bezier(.2,.7,.2,1)}
.m-gallery.is-in .m-gallery__item{opacity:1;transform:translate3d(0,0,0)}
.m-gallery.is-in .m-gallery__item[data-i="1"]{transition-delay:.10s}
.m-gallery.is-in .m-gallery__item[data-i="2"]{transition-delay:.22s; transform:translate3d(0,-10px,0)}
.m-gallery.is-in .m-gallery__item[data-i="3"]{transition-delay:.34s}
.m-gallery.is-in .m-gallery__item[data-i="4"]{transition-delay:.46s; transform:translate3d(0,-10px,0)}
.m-gallery.is-in .m-gallery__item[data-i="5"]{transition-delay:.58s}
.m-gallery.is-in .m-gallery__item[data-i="6"]{transition-delay:.70s; transform:translate3d(0,-10px,0)}
.m-gallery__item img{width:100%;height:auto;aspect-ratio:3/4;object-fit:cover;
  transition:transform .8s ease}
.m-gallery__item:hover img{transform:scale(1.05)}

@media (min-width:768px){
  .m-gallery{padding:88px 0}
  .m-gallery__rail{padding-left:40px;padding-right:40px}
  .m-gallery__item{flex:0 0 280px}
}
@media (min-width:1024px){
  .m-gallery__head{padding-left:60px;padding-right:60px}
  .m-gallery__rail{padding-left:60px;padding-right:60px;gap:18px}
  .m-gallery__item{flex:0 0 320px}
}

/* ==========================================================================
   6) FOOTER
   ========================================================================== */
.m-foot{background:var(--twt-bg-deep);color:#e7d4be;padding:48px 0 32px;
  border-top:1px solid rgba(255,245,230,.08)}
.m-foot__inner{max-width:1200px;margin:0 auto;padding:0 22px;
  display:flex;flex-direction:column;gap:28px}
.m-foot__brand{display:flex;flex-direction:column;gap:6px}
.m-foot__name{font-size:22px;font-weight:800;color:#fff;letter-spacing:.02em}
.m-foot__tag{font-size:13px;color:var(--twt-accent);letter-spacing:.08em}
.m-foot__cols{display:grid;grid-template-columns:1fr;gap:24px}
.m-foot__col h4{margin:0 0 10px;font-size:13px;letter-spacing:.18em;color:var(--twt-accent);font-weight:700;text-transform:uppercase}
.m-foot__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.m-foot__col li{font-size:14px;color:#d9c4ad;line-height:1.65;user-select:text;-webkit-user-select:text}
.m-foot__col a{color:#d9c4ad}
.m-foot__col a:hover{color:#fff}
.m-foot__copy{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,245,230,.10);
  font-size:12px;color:#a89180}
@media (min-width:768px){
  .m-foot{padding:64px 0 40px}
  .m-foot__inner{padding:0 40px}
  .m-foot__cols{grid-template-columns:1fr 1fr}
}
@media (min-width:1024px){
  .m-foot__inner{padding:0 60px}
  .m-foot__cols{grid-template-columns:1fr 1fr 1fr}
}

/* ==========================================================================
   prefers-reduced-motion
   ========================================================================== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  .m-hero__eyebrow,.m-hero__h1,.m-hero__sub,.m-hero__ctas,.m-hero__scroll,
  .m-about__line,.m-menu__card,.m-store__card,.m-store__row,.m-store__ctas .m-cta,
  .m-gallery__item{opacity:1 !important;transform:none !important}
  .m-hero__bg{transform:scale(1.06)}
  .m-about__media{transform:scale(1.12)}
  .m-hero__steam,.m-hero__bean{display:none}
  .m-menu__drizzle path,.m-store__path path{stroke-dashoffset:0}
  .m-menu__drizzle,.m-store__path{opacity:.6}
  /* sketch: show complete drawing immediately */
  .sk-line{stroke-dasharray:none !important;stroke-dashoffset:0 !important;stroke-opacity:1 !important}
  .m-sketch__eyebrow,.m-sketch__title,.m-sketch__caption{opacity:1 !important;transform:none !important}
}
