/* =========================================================
   SAVORHILL 山也 — Brand site styles
   Palette (brand manual B4): cocoa #70513D · orange #D29463
   cream #F9EFE3 · tea-green #959A72 · ink #1a1410
   Type: Helvetica Neue / Archivo (EN) · Noto Sans SC 思源黑体 (ZH)
   ========================================================= */

:root{
  --cocoa:#70513D;        --cocoa-dark:#523a2b;
  --orange:#D29463;       --orange-deep:#c07f4a;
  --cream:#F9EFE3;        --cream-2:#f3e7d6;
  --green:#959A72;        --green-deep:#7e8560;
  --ink:#1c1610;          --ink-soft:#3a2f26;
  --paper:#fbf6ee;
  --line:rgba(112,81,61,.18);

  --font-en:'Helvetica Neue','Archivo',Helvetica,Arial,sans-serif;
  --font-zh:'Noto Sans SC','PingFang SC','Hiragino Sans GB',sans-serif;
  --font:var(--font-en),'Noto Sans SC','PingFang SC',sans-serif;

  --wrap:1200px;
  --r:18px; --r-lg:28px; --r-pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 24px 60px -28px rgba(82,58,43,.5);
  --shadow-sm:0 10px 30px -16px rgba(82,58,43,.55);
  --header-h:74px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; font-family:var(--font); color:var(--ink); background:var(--paper);
  font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility; overflow-x:hidden;
}

img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3{margin:0; font-family:var(--font-en),var(--font-zh); font-weight:800; line-height:1.04; letter-spacing:-.02em}
:lang(zh-CN) h1,:lang(zh-CN) h2,:lang(zh-CN) h3{font-family:var(--font-zh); font-weight:900; letter-spacing:0}
p{margin:0 0 1em}
.wrap{max-width:var(--wrap); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); width:100%}
.center{text-align:center}
.section{padding:clamp(72px,11vw,140px) 0}
section[id]{scroll-margin-top:calc(var(--header-h) + 12px)}

/* hide/show by language */
[data-lang="en"] .lang-en{color:var(--ink)} [data-lang="en"] .lang-zh{opacity:.4}
[data-lang="zh"] .lang-zh{color:var(--ink)} [data-lang="zh"] .lang-en{opacity:.4}

/* ---------- Eyebrow / titles / pills ---------- */
.eyebrow{
  display:inline-block; font-family:var(--font-en); font-weight:700;
  font-size:.78rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--orange-deep); margin-bottom:18px;
}
.eyebrow--light{color:var(--orange)}
.section-title{
  font-size:clamp(1.9rem,4.6vw,3.4rem); color:inherit; margin-bottom:.4em;
}
.section-head{max-width:720px; margin-bottom:clamp(34px,5vw,60px)}
.section-lede{font-size:clamp(1.02rem,1.6vw,1.22rem); opacity:.82; max-width:60ch}
.lead{font-size:1.16rem; font-weight:500}
.pill{
  display:inline-block; padding:9px 20px; border:1.5px solid var(--line);
  border-radius:var(--r-pill); font-size:.85rem; letter-spacing:.02em; font-weight:600;
}
.fineprint{font-size:.85rem; opacity:.6}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--cocoa); --fg:var(--cream);
  display:inline-flex; align-items:center; gap:.5em; cursor:pointer;
  font-family:var(--font); font-weight:700; font-size:1rem; letter-spacing:.01em;
  padding:15px 30px; border-radius:var(--r-pill); border:1.5px solid transparent;
  background:var(--bg); color:var(--fg); transition:transform .25s var(--ease), background .25s, color .25s, box-shadow .25s;
  will-change:transform;
}
.btn:hover{transform:translateY(-3px); box-shadow:var(--shadow-sm)}
.btn:active{transform:translateY(-1px)}
.btn--solid{--bg:var(--cocoa); --fg:var(--cream)}
.btn--solid:hover{--bg:var(--cocoa-dark)}
.btn--cream{--bg:var(--cream); --fg:var(--cocoa)}
.btn--ghost{background:transparent; color:var(--cocoa); border-color:var(--cocoa)}
.btn--ghost:hover{background:var(--cocoa); color:var(--cream)}
.btn--sm{padding:10px 20px; font-size:.9rem}
.btn--lg{padding:18px 38px; font-size:1.08rem}
.link-arrow{display:inline-flex; align-items:center; gap:.4em; font-weight:600; color:var(--cocoa); border-bottom:1.5px solid currentColor; padding-bottom:2px; transition:gap .2s}
.link-arrow::after{content:"→"; transition:transform .2s var(--ease)}
.link-arrow:hover::after{transform:translateX(4px)}

/* ---------- Header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60; height:var(--header-h);
  display:flex; align-items:center;
  background:rgba(251,246,238,0); transition:background .3s, box-shadow .3s, height .3s;
}
.site-header.scrolled{background:rgba(251,246,238,.86); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); box-shadow:0 1px 0 var(--line)}
.header-inner{display:flex; align-items:center; gap:24px}
.brand{display:flex; align-items:center; margin-right:auto}
.brand-logo{height:26px; width:auto}
.brand-logo--mark{display:none; height:34px}
.main-nav{display:flex; gap:30px}
.main-nav a{font-weight:600; font-size:.98rem; position:relative; padding:4px 0; opacity:.85; transition:opacity .2s}
.main-nav a::after{content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--orange); transition:width .25s var(--ease)}
.main-nav a:hover{opacity:1}
.main-nav a:hover::after{width:100%}
.header-actions{display:flex; align-items:center; gap:14px}
.lang-toggle{background:none; border:1.5px solid var(--line); border-radius:var(--r-pill); padding:7px 14px; cursor:pointer; font-family:var(--font-en); font-weight:700; font-size:.82rem; letter-spacing:.05em; color:var(--ink); transition:border-color .2s}
.lang-toggle:hover{border-color:var(--cocoa)}
.lang-sep{opacity:.3; margin:0 3px}
.nav-burger{display:none; flex-direction:column; gap:5px; width:42px; height:42px; align-items:center; justify-content:center; background:none; border:1.5px solid var(--line); border-radius:12px; cursor:pointer}
.nav-burger span{width:18px; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s, opacity .3s}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative; padding:calc(var(--header-h) + clamp(30px,6vw,70px)) 0 clamp(40px,7vw,90px); overflow:hidden;
  background:radial-gradient(120% 90% at 80% 0%, var(--cream) 0%, var(--paper) 55%, var(--paper) 100%)}
.hero-bg{position:absolute; inset:0; color:var(--cocoa); pointer-events:none}
.hero-inner{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,70px); align-items:center; position:relative}
.hero-copy{max-width:600px}
.hero-title{font-size:clamp(2.7rem,7vw,5.4rem); letter-spacing:-.035em}
:lang(zh-CN) .hero-title{letter-spacing:-.01em}
.ink-accent{color:var(--cocoa)}
.hero-zh{font-family:var(--font-zh); font-weight:500; letter-spacing:.18em; color:var(--orange-deep); margin:18px 0 22px; font-size:clamp(.92rem,1.6vw,1.1rem)}
[data-lang="zh"] .hero-zh{font-family:var(--font-en); letter-spacing:.16em; font-weight:700; font-size:.82rem}
.hero-lede{font-size:clamp(1.05rem,1.7vw,1.25rem); max-width:48ch; opacity:.85; margin-bottom:34px}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap}

.hero-visual{position:relative; display:flex; justify-content:center}
.hero-photo{position:relative; width:min(100%,420px); aspect-ratio:3/4; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); transform:rotate(1.4deg)}
.hero-photo img{width:100%; height:100%; object-fit:cover}
.seal{position:absolute; left:-26px; bottom:-26px; width:124px; height:124px; background:var(--cream); border-radius:50%; display:grid; place-items:center; box-shadow:var(--shadow-sm)}
.seal svg{position:absolute; inset:0; width:100%; height:100%; animation:spin 22s linear infinite}
.seal-text{font-family:var(--font-en); font-size:11px; font-weight:700; letter-spacing:.07em; fill:var(--cocoa); text-transform:uppercase}
.seal-mark{width:46px; height:auto}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.seal svg{animation:none}}

/* ---------- Marquee ---------- */
.marquee{background:var(--cocoa); color:var(--cream); overflow:hidden; padding:16px 0; border-block:1px solid rgba(0,0,0,.06)}
.marquee-track{display:flex; gap:0; width:max-content; animation:marquee 34s linear infinite}
.marquee-track span{font-family:var(--font-en); font-weight:600; letter-spacing:.06em; padding-right:0; white-space:nowrap; font-size:1rem; opacity:.92}
:lang(zh-CN) .marquee-track span{font-family:var(--font)}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- About ---------- */
.about{background:var(--paper)}
.about-grid{display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,70px); align-items:center}
.about-art{aspect-ratio:1; background:var(--cream); border-radius:var(--r-lg); overflow:hidden; margin:0; box-shadow:var(--shadow)}
.about-art picture{display:block; width:100%; height:100%}
.art-img{width:100%; height:100%; object-fit:cover; display:block; transition:transform .8s var(--ease)}
.about-art:hover .art-img{transform:scale(1.04)}
.about-copy .section-title{margin-bottom:.5em}
.brand-line{font-family:var(--font-en); font-weight:700; font-size:1.18rem; color:var(--cocoa); margin:1.2em 0; line-height:1.5}
:lang(zh-CN) .brand-line{font-family:var(--font-zh)}
.two-cards{display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:clamp(40px,6vw,72px)}
.linecard{border:1.5px solid var(--line); border-radius:var(--r-lg); padding:clamp(28px,3.5vw,42px); background:var(--cream); transition:transform .3s var(--ease), box-shadow .3s}
.linecard:hover{transform:translateY(-5px); box-shadow:var(--shadow-sm)}
.linecard-k{font-family:var(--font-en); font-weight:700; font-size:.76rem; letter-spacing:.2em; text-transform:uppercase; color:var(--orange-deep)}
.linecard h3{font-size:1.6rem; margin:.5em 0 .4em}
.linecard p{margin:0; opacity:.82}

/* ---------- Drinks (dark) ---------- */
.section--dark{background:var(--ink); color:var(--cream); padding:clamp(72px,11vw,140px) 0; overflow:hidden}
.section--dark .section-title{color:var(--cream)}
.section--dark .section-lede{opacity:.72}
.poster-rail{overflow:hidden; padding:10px 0 30px; -webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent); mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.poster-rail::-webkit-scrollbar{display:none}
.poster-track{display:flex; width:max-content; will-change:transform; animation:poster-scroll 55s linear infinite}
.poster-rail:hover .poster-track{animation-play-state:paused}
@keyframes poster-scroll{from{transform:translateX(0)} to{transform:translateX(-50%)}}
.poster{position:relative; flex:0 0 auto; width:min(72vw,300px); margin-right:20px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow)}
@media (prefers-reduced-motion:reduce){
  .poster-track{animation:none}
  .poster-rail{overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none}
}
.poster img{width:100%; aspect-ratio:9/16; object-fit:cover; transition:transform .6s var(--ease)}
.poster:hover img{transform:scale(1.05)}
.poster figcaption{position:absolute; left:0; right:0; bottom:0; padding:30px 20px 18px; font-family:var(--font-en); font-weight:700; letter-spacing:.02em; color:#fff; font-size:1rem;
  background:linear-gradient(to top,rgba(20,12,6,.82),transparent)}
:lang(zh-CN) .poster figcaption{font-family:var(--font)}
.drink-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin:46px 0 40px}
.drink{position:relative; margin:0; border-radius:var(--r); overflow:hidden; background:#241b14}
.drink img{width:100%; aspect-ratio:4/5; object-fit:cover; transition:transform .6s var(--ease)}
.drink:hover img{transform:scale(1.06)}
.drink-cap{padding:16px 18px}
.drink-cap b{display:block; font-family:var(--font-en); font-weight:700; font-size:1.02rem}
:lang(zh-CN) .drink-cap b{font-family:var(--font)}
.drink-cap span{font-size:.86rem; opacity:.6}

/* ---------- Bakery ---------- */
.bakery{background:var(--cream)}
.bakery-layout{display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,64px); align-items:start}
.bakery-hero{margin:0; border-radius:var(--r-lg); overflow:hidden; position:relative; box-shadow:var(--shadow-sm)}
.bakery-hero img{width:100%; aspect-ratio:4/3; object-fit:cover}
.bakery-hero figcaption{position:absolute; left:16px; bottom:16px; background:var(--cocoa); color:var(--cream); font-size:.8rem; font-weight:600; padding:7px 16px; border-radius:var(--r-pill)}
.menu-list{display:flex; flex-direction:column}
.menu-row{display:grid; grid-template-columns:1fr auto; align-items:baseline; gap:10px; padding:15px 0; border-bottom:1px dashed var(--line)}
.menu-row:first-child{padding-top:0}
.menu-name{font-weight:600}
.menu-name .zh{display:block; font-size:.82rem; opacity:.55; font-weight:400}
.menu-dots{flex:1}
.menu-price{font-family:var(--font-en); font-weight:700; color:var(--cocoa); white-space:nowrap}
.menu-price .unit{font-size:.72rem; opacity:.5; font-weight:500; margin-left:4px}
.feature-trio{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:clamp(34px,4vw,54px)}
.feature{margin:0; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm)}
.feature img{width:100%; aspect-ratio:1; object-fit:cover; transition:transform .6s var(--ease)}
.feature:hover img{transform:scale(1.06)}

/* ---------- Cream section ---------- */
.section--cream{background:var(--paper); padding:clamp(72px,11vw,140px) 0}
.cream-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:22px}
.cream-card{margin:0; border-radius:var(--r-lg); overflow:hidden; background:var(--cream); box-shadow:var(--shadow-sm); transition:transform .3s var(--ease)}
.cream-card:hover{transform:translateY(-6px)}
.cream-card img{width:100%; aspect-ratio:4/5; object-fit:cover}
.cream-card figcaption{padding:16px 18px}
.cream-card b{display:block; font-family:var(--font-en); font-size:1.02rem}
:lang(zh-CN) .cream-card b{font-family:var(--font)}
.cream-card span{font-size:.84rem; opacity:.6}

/* ---------- Order CTA ---------- */
.order-cta{background:var(--orange); color:#fff}
.order-cta .section-title{color:#fff}
.order-inner{display:flex; align-items:center; justify-content:space-between; gap:40px; padding-block:clamp(54px,7vw,86px); flex-wrap:wrap}
.order-inner .section-lede{opacity:.92; color:#fff}
.order-cta .fineprint{color:rgba(255,255,255,.78)}
.order-cta .btn--solid{--bg:var(--cocoa); --fg:#fff}
.order-cta .btn--solid:hover{--bg:var(--cocoa-dark)}

/* ---------- Visit ---------- */
.visit{background:var(--cream)}
.visit-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(30px,5vw,60px); align-items:stretch}
.visit-info{display:flex; flex-direction:column; gap:30px}
.info-block{padding-bottom:26px; border-bottom:1px solid var(--line)}
.info-block:last-child{border-bottom:none; padding-bottom:0}
.info-label{display:block; font-family:var(--font-en); font-weight:700; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--orange-deep); margin-bottom:12px}
.info-addr{font-size:1.3rem; font-weight:600; line-height:1.4; margin-bottom:10px}
.info-phone{font-size:1.5rem; font-weight:700; font-family:var(--font-en); margin-bottom:10px}
.status{display:inline-flex; align-items:center; gap:8px; padding:7px 16px; border-radius:var(--r-pill); font-weight:700; font-size:.86rem; margin-bottom:16px}
.status .dot{width:9px; height:9px; border-radius:50%}
.status.open{background:rgba(149,154,114,.2); color:var(--green-deep)}
.status.open .dot{background:var(--green-deep); box-shadow:0 0 0 0 rgba(126,133,96,.6); animation:pulse 2s infinite}
.status.shut{background:rgba(112,81,61,.12); color:var(--cocoa)}
.status.shut .dot{background:var(--cocoa)}
@keyframes pulse{70%{box-shadow:0 0 0 7px rgba(126,133,96,0)}100%{box-shadow:0 0 0 0 rgba(126,133,96,0)}}
.hours{list-style:none; margin:0; padding:0}
.hours li{display:flex; justify-content:space-between; gap:16px; padding:8px 0; border-bottom:1px dotted var(--line); font-size:.98rem}
.hours li:last-child{border-bottom:none}
.hours li.is-today{font-weight:700; color:var(--cocoa)}
.hours .day-h{opacity:.9}
.hours li.is-closed .day-h{opacity:.5}
.hours .today-tag{font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--orange-deep); margin-left:8px; font-weight:700}
.visit-map{position:relative; border-radius:var(--r-lg); overflow:hidden; min-height:360px; box-shadow:var(--shadow-sm); border:1px solid var(--line)}
.map-canvas{width:100%; height:100%; min-height:360px; background:#F4E9D5}
.visit-map .maplibregl-ctrl-attrib{background:rgba(249,239,227,.7); font-size:10px}
.visit-map .maplibregl-ctrl-attrib a{color:var(--cocoa)}
.visit-map .maplibregl-ctrl-group{box-shadow:var(--shadow-sm); border:none; background:var(--cream)}
.visit-map .maplibregl-ctrl-group button{background:var(--cream); width:30px; height:30px}
.visit-map .maplibregl-ctrl-group button+button{border-top:1px solid var(--line)}
.savor-pin{display:flex; flex-direction:column; align-items:center; cursor:default}
.savor-pin__label{font-family:var(--font); font-weight:700; font-size:11px; letter-spacing:.02em; color:var(--cocoa); background:rgba(249,239,227,.92); padding:3px 9px; border-radius:var(--r-pill); white-space:nowrap; margin-bottom:4px; box-shadow:0 2px 6px rgba(82,58,43,.28)}
.savor-pin__icon{display:block; filter:drop-shadow(0 4px 5px rgba(82,58,43,.4))}
.map-link{position:absolute; right:12px; bottom:12px; background:var(--cream); color:var(--cocoa); font-family:var(--font-en); font-weight:700; font-size:.82rem; padding:9px 16px; border-radius:var(--r-pill); box-shadow:var(--shadow-sm); transition:transform .2s var(--ease)}
.map-link:hover{transform:translateY(-2px)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink); color:var(--cream); padding:clamp(54px,7vw,80px) 0 30px}
.footer-inner{display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; padding-bottom:40px; border-bottom:1px solid rgba(249,239,227,.14)}
.footer-logo{height:34px; width:auto; margin-bottom:16px}
.footer-tag{font-family:var(--font-en); font-size:1.1rem; opacity:.8; margin:0}
:lang(zh-CN) .footer-tag{font-family:var(--font)}
.footer-cols{display:flex; gap:60px; flex-wrap:wrap}
.footer-cols a{opacity:.85} .footer-cols a:hover{opacity:1}
.footer-cols .info-addr{font-size:1rem; font-weight:400; opacity:.8}
.footer-base{display:flex; justify-content:space-between; gap:16px; padding-top:24px; font-size:.82rem; opacity:.6; flex-wrap:wrap}

/* ---------- Reveal animation ---------- */
.js .reveal{opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease)}
.js .reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1; transform:none; transition:none}}

/* ---------- Mobile nav drawer ---------- */
@media (max-width:880px){
  .brand-logo--wide{display:none} .brand-logo--mark{display:block}
  .nav-burger{display:flex}
  .order-link{display:none}
  .main-nav{
    position:fixed; inset:var(--header-h) 0 auto 0; flex-direction:column; gap:0;
    background:rgba(251,246,238,.97); backdrop-filter:blur(14px);
    padding:8px clamp(20px,5vw,40px) 24px; box-shadow:0 20px 40px -24px rgba(82,58,43,.5);
    transform:translateY(-12px); opacity:0; pointer-events:none; transition:transform .3s var(--ease), opacity .3s;
  }
  .main-nav.open{transform:none; opacity:1; pointer-events:auto}
  .main-nav a{padding:16px 0; border-bottom:1px solid var(--line); font-size:1.1rem}
  .main-nav a::after{display:none}
}

/* ---------- FAQ ---------- */
.faq{background:var(--paper)}
.faq-list{max-width:820px; border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  list-style:none; cursor:pointer; position:relative;
  padding:24px 48px 24px 0; font-weight:700; font-size:clamp(1.05rem,1.8vw,1.28rem);
  color:var(--ink); line-height:1.35;
}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{
  content:""; position:absolute; right:6px; top:50%; width:13px; height:13px;
  margin-top:-9px; border-right:2px solid var(--cocoa); border-bottom:2px solid var(--cocoa);
  transform:rotate(45deg); transition:transform .3s var(--ease);
}
.faq-item[open] .faq-q::after{transform:rotate(-135deg)}
.faq-q:hover{color:var(--cocoa)}
.faq-a{
  margin:0; padding:0 48px 26px 0; max-width:68ch;
  font-size:clamp(1rem,1.5vw,1.1rem); line-height:1.65; color:var(--ink-soft);
}
@media (max-width:620px){
  .faq-q{padding-right:38px; font-size:1.06rem}
  .faq-a{padding-right:0}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr; gap:40px}
  .hero-visual{order:-1}
  .hero-copy{max-width:none}
  .about-grid{grid-template-columns:1fr}
  .about-art{max-width:300px}
  .bakery-layout{grid-template-columns:1fr}
  .visit-grid{grid-template-columns:1fr}
  .drink-grid{grid-template-columns:repeat(2,1fr)}
  .cream-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  body{font-size:16px}
  .two-cards{grid-template-columns:1fr}
  .feature-trio{grid-template-columns:1fr 1fr}
  .feature-trio .feature:last-child{grid-column:1/-1}
  .order-inner{flex-direction:column; align-items:flex-start}
  .footer-inner{flex-direction:column; gap:24px}
  .hero-photo{width:min(86vw,360px)}
  .seal{width:104px; height:104px; left:-14px}
  .seal-mark{width:38px}
}
@media (max-width:430px){
  .drink-grid{grid-template-columns:1fr 1fr; gap:14px}
  .cream-grid{grid-template-columns:1fr 1fr; gap:14px}
}
