/* ===========================================================
   WOOT — South Horie 24h Cafe
   =========================================================== */
:root{
  --ink:#16181a;          /* near-black charcoal */
  --ink-2:#1f2326;        /* concrete dark */
  --ink-3:#2b3033;
  --cream:#f3efe6;        /* warm paper */
  --cream-2:#e9e3d6;
  --sage:#8a9678;         /* muted green */
  --sage-dim:#6f7a60;
  --amber:#d9a441;        /* pendant glow */
  --amber-soft:#e7c184;
  --line:rgba(255,255,255,.14);
  --line-dark:rgba(20,24,26,.12);
  --txt-light:#ece8df;
  --txt-mut:#b7b2a6;
  --serif:'Cormorant Garamond',serif;
  --mincho:'Shippori Mincho',serif;
  --sans:'Zen Kaku Gothic New',-apple-system,system-ui,sans-serif;
  --label:'Jost',sans-serif;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  line-height:1.85;
  font-weight:300;
  overflow-x:hidden;
  letter-spacing:.02em;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
section{position:relative}

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--label);
  font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--sage-dim);margin-bottom:1.4rem;font-weight:400;
  display:flex;align-items:center;gap:.8em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:currentColor;opacity:.7}
.eyebrow--light{color:var(--amber-soft)}
.section-title{
  font-family:var(--mincho);
  font-weight:500;
  font-size:clamp(1.8rem,4.4vw,3.1rem);
  line-height:1.32;letter-spacing:.04em;color:var(--ink);
}
.section-title--light{color:var(--cream)}
.lede{font-size:clamp(1rem,1.7vw,1.12rem);line-height:2.1;margin-top:1.5rem;max-width:46ch;color:#3a3f42}
.lede em{font-family:var(--serif);font-style:italic;font-size:1.15em;color:var(--sage-dim);letter-spacing:.03em}
.lede--light{color:var(--txt-mut)}
.body{margin-top:1.2rem;color:#4a4f52;max-width:48ch}
.img-note{font-size:.74rem;color:#9a948a;letter-spacing:.06em;font-family:var(--label)}
.img-note--center{text-align:center;margin:2.6rem auto 0;max-width:60ch;line-height:1.9}
.img-note a{color:var(--sage-dim);border-bottom:1px solid currentColor}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--label);font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
  padding:1.05em 2.3em;border-radius:100px;transition:.45s var(--ease);
  border:1px solid transparent;cursor:pointer;font-weight:400;
}
.btn--solid{background:var(--amber);color:var(--ink)}
.btn--solid:hover{background:var(--amber-soft);transform:translateY(-3px);box-shadow:0 14px 34px -12px rgba(217,164,65,.6)}
.btn--ghost{border-color:rgba(255,255,255,.4);color:var(--cream)}
.btn--ghost:hover{background:rgba(255,255,255,.1);transform:translateY(-3px)}
.btn--dark{border-color:var(--line-dark);color:var(--ink)}
.btn--dark:hover{background:var(--ink);color:var(--cream)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
/* hero is above-the-fold: never depend on JS — animate in on load via CSS */
.hero .reveal{animation:heroIn 1.2s var(--ease) both}
.hero .reveal:nth-child(2){animation-delay:.12s}
.hero .reveal:nth-child(3){animation-delay:.24s}
.hero .reveal:nth-child(4){animation-delay:.36s}
@keyframes heroIn{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:none}}

/* official WOOT logo */
.brand__logo{height:26px;width:auto;display:block;transition:.4s var(--ease)}
.nav.scrolled .brand__logo{height:23px}
.preloader__logo{width:clamp(150px,40vw,220px);height:auto;display:block;animation:blink 1.6s var(--ease) infinite}
.footer__logo{height:38px;width:auto;display:block}
/* legacy glasses mark (kept for fallback) */
.glasses{width:46px;height:auto}
.glasses circle{fill:none;stroke:currentColor;stroke-width:4.5}
.glasses line{stroke:currentColor;stroke-width:4.5;stroke-linecap:round}

/* ---------- preloader ---------- */
.preloader{
  position:fixed;inset:0;z-index:2000;background:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease),visibility .8s;
}
.preloader.done{opacity:0;visibility:hidden}
.preloader__mark{display:flex;flex-direction:column;align-items:center;gap:.7rem;color:var(--cream)}
.preloader__mark .glasses{width:78px;animation:blink 1.6s var(--ease) infinite}
.preloader__mark span{font-family:var(--label);letter-spacing:.6em;font-size:1.1rem;padding-left:.6em;opacity:.85}
@keyframes blink{0%,100%{opacity:.35}50%{opacity:1}}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:.5s var(--ease)}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;padding:1.5rem clamp(1.2rem,4vw,3rem);
  display:flex;align-items:center;justify-content:space-between;
}
.nav.scrolled{background:rgba(22,24,26,.82);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--line)}
.nav.scrolled .nav__inner{padding-top:1rem;padding-bottom:1rem}
.brand{display:flex;align-items:center;gap:.65rem;color:var(--cream)}
.brand .glasses{width:40px}
.brand__name{font-family:var(--label);font-weight:500;letter-spacing:.34em;font-size:1.15rem;padding-left:.3em}
.nav__links{display:flex;align-items:center;gap:2.1rem}
.nav__links a{
  font-family:var(--label);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--txt-light);opacity:.92;position:relative;padding:.3em 0;transition:.3s;
}
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--amber);transition:.4s var(--ease)}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__links a:hover{color:#fff}
.nav__cta{border:1px solid var(--amber);color:var(--amber)!important;border-radius:100px;padding:.55em 1.3em!important}
.nav__cta:hover{background:var(--amber);color:var(--ink)!important}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;z-index:1100}
.nav__burger span{width:26px;height:2px;background:var(--cream);transition:.4s var(--ease)}

/* ---------- hero ---------- */
.hero{height:100svh;min-height:600px;display:flex;align-items:center;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{transform:scale(1.08);animation:slowzoom 18s var(--ease) forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.hero__overlay{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(16,18,20,.55) 0%,rgba(16,18,20,.25) 38%,rgba(16,18,20,.82) 100%);}
.hero__glow{position:absolute;top:8%;right:-6%;width:60vw;height:60vw;max-width:680px;max-height:680px;
  background:radial-gradient(circle,rgba(217,164,65,.34),transparent 62%);filter:blur(20px);pointer-events:none}
.hero__content{max-width:var(--maxw);width:100%;margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);position:relative;z-index:2}
.hero__title{
  font-family:var(--serif);color:#fff;font-weight:500;
  font-size:clamp(3.4rem,12vw,9rem);line-height:.97;letter-spacing:.01em;
  text-shadow:0 14px 60px rgba(0,0,0,.4);margin:.4rem 0 1.6rem;
}
.hero__lead{color:var(--txt-light);font-size:clamp(1rem,2vw,1.25rem);line-height:2;max-width:34ch;font-weight:300}
.hero__actions{display:flex;gap:1rem;margin-top:2.6rem;flex-wrap:wrap}
.hero__scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  font-family:var(--label);font-size:.66rem;letter-spacing:.3em;color:var(--txt-light);
  display:flex;flex-direction:column;align-items:center;gap:.8rem;opacity:.8;z-index:2;
}
.hero__scroll span{width:1px;height:46px;background:linear-gradient(var(--amber),transparent);animation:drop 2s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(.2);transform-origin:top;opacity:0}50%{opacity:1}100%{transform:scaleY(1);transform-origin:top;opacity:0}}

/* ---------- marquee ---------- */
.marquee{background:var(--ink);color:var(--cream);padding:1.15rem 0;overflow:hidden;border-block:1px solid var(--line)}
.marquee__track{display:inline-flex;align-items:center;gap:2.4rem;white-space:nowrap;animation:scroll 26s linear infinite;will-change:transform}
.marquee__track span{font-family:var(--serif);font-style:italic;font-size:1.4rem;letter-spacing:.05em}
.marquee__track i{color:var(--amber);font-style:normal;font-size:.8rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- concept ---------- */
.concept{background:var(--cream);padding:clamp(5rem,11vw,9rem) 0}
.concept__grid{
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,6vw,6rem);align-items:center;
}
.concept__facts{list-style:none;display:flex;gap:2.4rem;margin-top:2.8rem;flex-wrap:wrap}
.concept__facts li{display:flex;flex-direction:column;gap:.2rem}
.concept__facts strong{font-family:var(--serif);font-size:2.6rem;line-height:1;color:var(--sage-dim);font-weight:600}
.concept__facts span{font-size:.78rem;letter-spacing:.1em;color:#6f6a60}
.concept__media{position:relative;aspect-ratio:4/5;border-radius:6px;overflow:hidden;box-shadow:0 40px 80px -40px rgba(22,24,26,.55)}
.concept__media img{transition:transform 1.4s var(--ease)}
.concept__media:hover img{transform:scale(1.05)}
.concept__badge{
  position:absolute;right:-1.2rem;bottom:-1.2rem;background:var(--ink);color:var(--cream);
  width:130px;height:130px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:0 20px 40px -16px rgba(0,0,0,.5);border:1px solid var(--amber);
}
.concept__badge-top,.concept__badge-bot{font-family:var(--label);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--amber-soft)}
.concept__badge-big{font-family:var(--serif);font-size:3rem;line-height:1;font-weight:600;margin:.1rem 0}

/* ---------- atmosphere ---------- */
.atmos{background:var(--ink);color:var(--cream);padding:clamp(5rem,11vw,9rem) 0;overflow:hidden}
.atmos::before{content:"";position:absolute;top:-10%;left:-10%;width:50vw;height:50vw;max-width:560px;max-height:560px;
  background:radial-gradient(circle,rgba(217,164,65,.16),transparent 60%);pointer-events:none}
.atmos__head{max-width:var(--maxw);margin:0 auto 3.4rem;padding:0 clamp(1.4rem,5vw,3.4rem);position:relative}
.atmos__mosaic{
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);
  display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:14px;
}
.atmos__cell{position:relative;overflow:hidden;border-radius:5px}
.atmos__cell--tall{grid-row:span 2}
.atmos__cell--wide{grid-column:span 2}
.atmos__cell img{transition:transform 1.2s var(--ease);filter:brightness(.92)}
.atmos__cell:hover img{transform:scale(1.07);filter:brightness(1)}
.atmos__cell figcaption{
  position:absolute;left:1rem;bottom:.9rem;font-family:var(--label);font-size:.68rem;letter-spacing:.18em;
  text-transform:uppercase;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.7);
  opacity:0;transform:translateY(8px);transition:.5s var(--ease);
}
.atmos__cell:hover figcaption{opacity:1;transform:none}

/* ---------- signature ---------- */
.signature{background:var(--cream-2);padding:clamp(4.5rem,10vw,8rem) 0}
.signature__head{max-width:var(--maxw);margin:0 auto 3rem;padding:0 clamp(1.4rem,5vw,3.4rem)}
.signature__row{
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;
}
.sig-card{text-align:center}
.sig-card__img{aspect-ratio:1/1;border-radius:50%;overflow:hidden;margin:0 auto 1.5rem;width:100%;max-width:230px;
  box-shadow:0 24px 44px -24px rgba(22,24,26,.5)}
.sig-card__img img{transition:transform 1.2s var(--ease)}
.sig-card:hover .sig-card__img img{transform:scale(1.08)}
.sig-card h3{font-family:var(--mincho);font-weight:500;font-size:1.2rem;letter-spacing:.04em;margin-bottom:.4rem}
.sig-card p{font-size:.82rem;color:#6a655c;line-height:1.7;max-width:24ch;margin:0 auto .7rem}
.sig-card .price{font-family:var(--serif);font-size:1.3rem;color:var(--sage-dim);font-weight:600}

/* ---------- menu ---------- */
.menu{background:var(--ink-2);color:var(--cream);padding:clamp(5rem,11vw,9rem) 0}
.menu__head{max-width:var(--maxw);margin:0 auto 2.6rem;padding:0 clamp(1.4rem,5vw,3.4rem)}
.menu__tabs{max-width:var(--maxw);margin:0 auto 3rem;padding:0 clamp(1.4rem,5vw,3.4rem);display:flex;gap:.6rem;flex-wrap:wrap}
.menu__tab{
  font-family:var(--label);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.8em 1.7em;border-radius:100px;border:1px solid var(--line);background:none;color:var(--txt-mut);
  cursor:pointer;transition:.4s var(--ease);
}
.menu__tab.is-active{background:var(--amber);color:var(--ink);border-color:var(--amber)}
.menu__tab:hover:not(.is-active){border-color:var(--amber-soft);color:var(--cream)}
.menu__panel{display:none;max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);
  grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.menu__panel.is-active{display:grid;animation:fadeup .7s var(--ease)}
@keyframes fadeup{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.menu__feature{position:relative;aspect-ratio:4/5;border-radius:6px;overflow:hidden;position:sticky;top:120px;
  box-shadow:0 36px 70px -36px rgba(0,0,0,.7)}
.menu__feature img{filter:brightness(.96)}
.menu__feature-cap{position:absolute;left:1.4rem;bottom:1.3rem;right:1.4rem;color:#fff}
.menu__feature-cap span{font-family:var(--label);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--amber-soft)}
.menu__feature-cap p{font-family:var(--mincho);font-size:1rem;margin-top:.4rem;text-shadow:0 2px 14px rgba(0,0,0,.7)}
.menu__list{list-style:none}
.menu__list li{display:flex;align-items:baseline;gap:1rem;padding:1.15rem 0;border-bottom:1px solid var(--line)}
.menu__item-main{display:flex;flex-direction:column;gap:.25rem;flex:1}
.menu__name{font-family:var(--mincho);font-size:1.06rem;letter-spacing:.03em;color:var(--cream)}
.menu__desc{font-size:.76rem;color:var(--txt-mut);letter-spacing:.04em}
.menu__price{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--amber-soft);white-space:nowrap}

/* ---------- voice ---------- */
.voice{background:var(--cream);padding:clamp(5rem,11vw,9rem) 0;text-align:center}
.voice__head{max-width:var(--maxw);margin:0 auto 3rem;padding:0 clamp(1.4rem,5vw,3.4rem);display:flex;flex-direction:column;align-items:center}
.voice__head .eyebrow{justify-content:center}
.voice__head .lede{text-align:center}
.voice__grid{max-width:var(--maxw);margin:0 auto 3rem;padding:0 clamp(1.4rem,5vw,3.4rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.voice__card{background:#fff;border:1px solid var(--line-dark);border-radius:8px;padding:2rem 1.6rem;text-align:left;
  display:flex;flex-direction:column;gap:1rem;box-shadow:0 20px 40px -30px rgba(22,24,26,.4);transition:.5s var(--ease)}
.voice__card:hover{transform:translateY(-6px);box-shadow:0 30px 54px -30px rgba(22,24,26,.45)}
.voice__card .stars{color:var(--amber);letter-spacing:.15em;font-size:.95rem}
.voice__card p{font-size:.92rem;line-height:1.95;color:#3f433f}
.voice__card cite{font-family:var(--label);font-style:normal;font-size:.72rem;letter-spacing:.14em;color:#8d887d;text-transform:uppercase}

/* ---------- access ---------- */
.access{background:var(--ink);color:var(--cream);padding:clamp(5rem,11vw,9rem) 0}
.access__inner{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}
.access__dl{margin-top:2.4rem}
.access__dl>div{display:grid;grid-template-columns:120px 1fr;gap:1rem;padding:1.2rem 0;border-bottom:1px solid var(--line)}
.access__dl dt{font-family:var(--label);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber-soft);padding-top:.2rem}
.access__dl dd{font-size:.98rem;line-height:1.8;color:var(--txt-light)}
.access__dl .tag{display:inline-block;margin-left:.7rem;font-size:.66rem;letter-spacing:.1em;border:1px solid var(--amber);color:var(--amber);
  border-radius:100px;padding:.1em .9em;vertical-align:middle}
.access__dl a{border-bottom:1px solid var(--line)}
.access__sns{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.access__sns a{font-family:var(--label);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:100px;padding:.7em 1.5em;transition:.4s var(--ease)}
.access__sns a:hover{background:var(--amber);color:var(--ink);border-color:var(--amber)}
.access__map{aspect-ratio:1/1;border-radius:8px;overflow:hidden;box-shadow:0 36px 70px -40px rgba(0,0,0,.7);border:1px solid var(--line)}
.access__map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05)}

/* ---------- cta ---------- */
.cta{position:relative;padding:clamp(5rem,12vw,9rem) 0;text-align:center;color:var(--cream);overflow:hidden}
.cta__bg{position:absolute;inset:0;z-index:-2;filter:brightness(.4)}
.cta::after{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(circle at 50% 40%,rgba(217,164,65,.22),rgba(16,18,20,.7))}
.cta__inner{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);display:flex;flex-direction:column;align-items:center}
.cta__inner .eyebrow{justify-content:center}
.cta__title{font-family:var(--mincho);font-weight:500;font-size:clamp(1.7rem,4.6vw,3rem);line-height:1.5;margin:.6rem 0 2.2rem;letter-spacing:.04em}

/* ---------- footer ---------- */
.footer{background:#0e1012;color:var(--txt-mut);padding:clamp(3.5rem,7vw,5rem) 0 2rem}
.footer__inner{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,3.4rem);
  display:grid;grid-template-columns:1.2fr 1fr 1.2fr;gap:2.5rem;align-items:start}
.footer__brand{display:flex;flex-direction:column;gap:.5rem;color:var(--cream)}
.footer__brand .brand__name{font-family:var(--label);letter-spacing:.34em;font-size:1.2rem}
.footer__brand .glasses{width:48px;color:var(--cream)}
.footer__brand p{font-family:var(--serif);font-style:italic;color:var(--amber-soft);font-size:1rem;letter-spacing:.06em}
.footer__nav{display:flex;flex-direction:column;gap:.8rem}
.footer__nav a{font-family:var(--label);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;transition:.3s}
.footer__nav a:hover{color:var(--amber-soft)}
.footer__meta p{font-size:.84rem;line-height:1.9}
.footer__copy{text-align:center;margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.08);
  font-size:.72rem;letter-spacing:.08em;color:#6b665d}

/* ---------- to top ---------- */
.totop{position:fixed;right:1.4rem;bottom:1.4rem;width:46px;height:46px;border-radius:50%;
  background:var(--ink);color:var(--cream);border:1px solid var(--amber);cursor:pointer;font-size:1.1rem;
  opacity:0;pointer-events:none;transition:.4s var(--ease);z-index:900}
.totop.show{opacity:1;pointer-events:auto}
.totop:hover{background:var(--amber);color:var(--ink);transform:translateY(-4px)}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:1024px){
  .signature__row{grid-template-columns:repeat(2,1fr);gap:2.4rem 1.6rem}
  .voice__grid{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}
@media(max-width:880px){
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);height:100svh;
    background:rgba(18,20,22,.97);backdrop-filter:blur(20px);
    flex-direction:column;justify-content:center;gap:2rem;
    transform:translateX(100%);transition:transform .55s var(--ease);padding:2rem;
  }
  .nav__links.open{transform:translateX(0)}
  .nav__links a{font-size:1rem}
  .nav__burger{display:flex}
  .nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__burger.open span:nth-child(2){opacity:0}
  .nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .concept__grid{grid-template-columns:1fr;gap:3.5rem}
  .concept__media{max-width:460px;margin:0 auto;width:100%}
  .menu__panel.is-active{grid-template-columns:1fr;gap:2.4rem}
  .menu__feature{position:relative;top:0;max-width:460px;margin:0 auto;width:100%;aspect-ratio:16/10}
  .access__inner{grid-template-columns:1fr;gap:3rem}
  .access__map{max-width:520px;margin:0 auto;width:100%;aspect-ratio:4/3}
  .atmos__mosaic{grid-auto-rows:160px}
}
@media(max-width:600px){
  body{line-height:1.66;letter-spacing:.01em}
  /* --- compact section rhythm --- */
  .concept,.atmos,.signature,.menu,.voice,.access,.cta{padding-top:3rem;padding-bottom:3rem}
  .eyebrow{margin-bottom:.9rem;font-size:.62rem;letter-spacing:.32em}
  .eyebrow::before{width:24px}
  .section-title{font-size:clamp(1.5rem,6.6vw,1.95rem);line-height:1.34}
  .lede{margin-top:.9rem;font-size:.9rem;line-height:1.78;max-width:36ch}
  .body{margin-top:.8rem;font-size:.86rem;line-height:1.74;max-width:40ch}
  .img-note--center{margin-top:1.5rem;font-size:.66rem;line-height:1.7}

  /* --- hero --- */
  .hero{min-height:520px;height:90svh}
  .hero__title{margin:.2rem 0 1rem}
  .hero__lead{font-size:.94rem;line-height:1.72;max-width:30ch}
  .hero__actions{margin-top:1.6rem;flex-direction:column;align-items:stretch;gap:.65rem}
  .hero__actions .btn{width:100%;padding:.92em 2em}
  .marquee{padding:.8rem 0}
  .marquee__track{gap:1.5rem}
  .marquee__track span{font-size:1rem}

  /* --- concept: shorter image + tight facts --- */
  .concept__grid{gap:2rem}
  .concept__media{max-width:100%;aspect-ratio:4/3}
  .concept__badge{width:92px;height:92px;right:-.5rem;bottom:-.5rem}
  .concept__badge-big{font-size:2rem}
  .concept__facts{gap:1.1rem;margin-top:1.6rem}
  .concept__facts strong{font-size:1.85rem}
  .concept__facts span{font-size:.66rem}

  /* --- atmosphere: tidy 2×2 + bottom banner --- */
  .atmos__head{margin-bottom:1.6rem}
  .atmos__mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:118px;gap:8px}
  .atmos__cell--tall{grid-row:span 1}
  .atmos__cell--wide{grid-column:span 1}
  .atmos__cell:last-child{grid-column:span 2}
  .atmos__cell figcaption{opacity:1;font-size:.6rem;left:.7rem;bottom:.6rem}

  /* --- signature: 2×2 --- */
  .signature__head{margin-bottom:1.6rem}
  .signature__row{grid-template-columns:repeat(2,1fr);gap:1.7rem 1rem}
  .sig-card__img{max-width:140px;margin-bottom:.85rem}
  .sig-card h3{font-size:.96rem;margin-bottom:.2rem}
  .sig-card p{font-size:.72rem;line-height:1.55;margin-bottom:.4rem}
  .sig-card .price{font-size:1.02rem}

  /* --- menu --- */
  .menu__head{margin-bottom:1.4rem}
  .menu__tabs{margin-bottom:1.6rem;gap:.45rem}
  .menu__tab{padding:.62em 1.15em;font-size:.7rem;letter-spacing:.1em}
  .menu__panel.is-active{gap:1.5rem}
  .menu__feature{aspect-ratio:16/9}
  .menu__feature-cap p{font-size:.9rem}
  .menu__list li{padding:.8rem 0;gap:.7rem}
  .menu__name{font-size:.92rem}
  .menu__desc{font-size:.68rem}
  .menu__price{font-size:1.12rem}

  /* --- voice: 2×2 --- */
  .voice__head{margin-bottom:1.6rem}
  .voice__grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.8rem}
  .voice__card{padding:1.1rem .95rem;gap:.6rem;border-radius:6px}
  .voice__card .stars{font-size:.78rem}
  .voice__card p{font-size:.74rem;line-height:1.6}
  .voice__card cite{font-size:.6rem}

  /* --- access --- */
  .access__inner{gap:1.9rem}
  .access__dl{margin-top:1.6rem}
  .access__dl>div{grid-template-columns:84px 1fr;gap:.5rem;padding:.85rem 0}
  .access__dl dt{font-size:.66rem}
  .access__dl dd{font-size:.88rem;line-height:1.65}
  .access__map{aspect-ratio:4/3}
  .access__sns{margin-top:1.5rem;gap:.7rem}
  .access__sns a{padding:.58em 1.15em;font-size:.7rem}

  /* --- cta + footer --- */
  .cta__title{font-size:clamp(1.35rem,5.4vw,1.85rem);line-height:1.42;margin:.4rem 0 1.5rem}
  .footer__inner{grid-template-columns:1fr;gap:1.5rem;text-align:center}
  .footer__nav{flex-flow:row wrap;justify-content:center;gap:.55rem 1.3rem}
  .footer__meta p{font-size:.76rem}
  .footer__copy{margin-top:1.9rem;font-size:.66rem}
  .totop{right:1rem;bottom:1rem;width:42px;height:42px}
}
@media(max-width:380px){
  .atmos__mosaic{grid-auto-rows:102px}
  .sig-card__img{max-width:120px}
  .sig-card p{font-size:.68rem}
  .voice__card p{font-size:.7rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
