:root{
  --bg:#EAF1F6; --bg-alt:#DEE8F0; --bg-deep:#CDDBE6;
  --wood:#5A7A95; --wood-deep:#3E5A75;
  --ink:#2A3540; --ink-soft:#445566; --ink-mute:#7A8B9C;
  --line:#C4D2DD; --line-soft:#D8E2EB;
  --midnight:#0E1820; --midnight-2:#152230; --midnight-line:rgba(234,241,246,.14);
  --azure:#7FB4DC;
  --font-jp:"Shippori Mincho",serif;
  --font-en:"Cormorant Garamond",serif;
  --font-mono:"JetBrains Mono",monospace;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--ink);
  font-family:var(--font-jp); line-height:1.85; letter-spacing:.04em;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt";
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 32px}
section{padding:clamp(80px,12vw,160px) 0;position:relative}

.eyebrow{
  font-family:var(--font-en); font-style:italic; font-size:14px;
  letter-spacing:.32em; color:var(--wood); margin:0 0 18px;
}
.eyebrow::before{content:"—— "; color:var(--wood); font-style:normal}

.section-title{
  font-family:var(--font-jp); font-weight:500;
  font-size:clamp(22px,2.6vw,30px); letter-spacing:.18em; margin:0 0 12px;
}
.section-title-en{
  font-family:var(--font-en); font-style:italic; font-weight:400;
  font-size:clamp(48px,6vw,76px); letter-spacing:.04em; line-height:1; margin:0 0 12px;
}
.section-rule{width:1px;height:56px;background:var(--line);margin:32px auto 40px}
@media(max-width:760px){
  section{padding:72px 0}
  .eyebrow{font-size:11px;letter-spacing:.24em;margin:0 0 14px}
  .section-title-en{font-size:42px;letter-spacing:.02em;margin:0 0 10px}
  .section-title{font-size:15px;letter-spacing:.12em;margin:0}
  .section-rule{height:36px;margin:22px auto 28px}
}

/* Header */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px; background:rgba(234,241,246,.85);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
  gap:16px;
}
.nav-logo{font-family:var(--font-jp);font-size:16px;letter-spacing:.22em;display:flex;align-items:center;gap:12px;line-height:1.2;white-space:nowrap}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.15}
.nav-logo small{font-family:var(--font-en);font-style:italic;font-size:10px;letter-spacing:.28em;color:var(--wood);margin-top:3px;font-weight:400}
.nav-mark{
  width:44px;height:44px;display:inline-block;object-fit:contain;flex-shrink:0;
  border-radius:50%;
  background:radial-gradient(circle at 30% 28%,#FFFFFF 0%,var(--bg) 60%,var(--bg-alt) 100%);
  padding:4px;
  box-shadow:
    0 6px 14px -4px rgba(42,53,64,.32),
    0 2px 4px -2px rgba(42,53,64,.2),
    inset 0 1px 0 rgba(255,255,255,.9),
    inset 0 -2px 4px rgba(62,90,117,.18);
}
.site-nav{display:flex;gap:32px;align-items:center}
.site-nav a{font-family:var(--font-en);font-size:13px;letter-spacing:.24em;padding:4px 0;position:relative;white-space:nowrap}
.site-nav a:hover{color:var(--wood-deep)}
@media(max-width:760px){
  .site-header{padding:8px 12px;gap:6px;flex-wrap:wrap;align-items:center}
  .nav-logo{font-size:12px;letter-spacing:.14em;flex-shrink:0}
  .nav-logo small{display:none}
  .nav-mark{width:34px;height:34px;padding:3px}
  .site-nav{
    gap:10px;width:100%;justify-content:space-between;
    flex-wrap:nowrap;order:2;margin-top:4px;
    padding-top:6px;border-top:1px solid var(--line-soft);
  }
  .site-nav a{font-size:10px;letter-spacing:.08em;padding:2px 0}
}
@media(max-width:380px){
  .site-nav{gap:6px}
  .site-nav a{font-size:9px;letter-spacing:.04em}
}

/* Hero */
.hero{
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:120px 24px 120px; position:relative; overflow:hidden;
  background:#0E1820; color:#EAF1F6;
}
.hero>*{position:relative;z-index:3}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:
    radial-gradient(ellipse at 50% 50%,rgba(14,24,32,0) 0%,rgba(14,24,32,.25) 70%,rgba(14,24,32,.6) 100%),
    linear-gradient(180deg,rgba(14,24,32,.35) 0%,rgba(14,24,32,0) 25%,rgba(14,24,32,0) 70%,rgba(14,24,32,.55) 100%);
  pointer-events:none;
}
.hero-grain{
  position:absolute;inset:0;z-index:4;pointer-events:none;opacity:.18;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.7 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.hero-bg .slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;animation:hero-fade 32s infinite;
  filter:saturate(1.15) contrast(1.05) brightness(1);
  transform:scale(1);
}
.hero-bg .slide{animation-duration:32s !important}
.hero-bg .slide:nth-child(1){animation-delay:0s;background-image:url('interior.jpg')}
.hero-bg .slide:nth-child(2){animation-delay:8s;background-image:url('kitchen.jpg')}
.hero-bg .slide:nth-child(3){animation-delay:16s;background-image:url('interior.jpg')}
.hero-bg .slide:nth-child(4){animation-delay:24s;background-image:url('kitchen.jpg')}
.hero-bg .slide:nth-child(5){display:none}
@keyframes hero-fade{
  0%{opacity:0;transform:scale(1.05)}
  4%{opacity:1}
  25%{opacity:1;transform:scale(1.18)}
  29%{opacity:0;transform:scale(1.18)}
  100%{opacity:0;transform:scale(1.18)}
}

/* hero side rails */
.hero-rail{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:3;writing-mode:vertical-rl;text-orientation:mixed;
  font-family:var(--font-en);font-style:italic;font-size:11px;
  letter-spacing:.4em;color:rgba(234,241,246,.55);
  display:flex;align-items:center;gap:18px;
}
.hero-rail.left{left:28px}
.hero-rail.right{right:28px;transform:translateY(-50%) rotate(180deg)}
.hero-rail::before{content:"";display:block;width:1px;height:60px;background:rgba(234,241,246,.4)}

.hero-corner{
  position:absolute;z-index:3;
  font-family:var(--font-en);font-style:italic;font-size:11px;
  letter-spacing:.4em;color:rgba(234,241,246,.55);
}
.hero-corner.tl{top:108px;left:32px}
.hero-corner.tr{top:108px;right:32px}
.hero-corner.bl{bottom:32px;left:32px}
.hero-corner.br{bottom:32px;right:32px}

.hero-scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:12px;
  font-family:var(--font-en);font-style:italic;font-size:11px;
  letter-spacing:.4em;color:rgba(234,241,246,.7);
}
.hero-scroll::after{
  content:"";width:1px;height:48px;
  background:linear-gradient(to bottom,rgba(234,241,246,.9) 0%,rgba(234,241,246,0) 100%);
  animation:scroll-cue 2.4s ease-in-out infinite;
}
@keyframes scroll-cue{
  0%,100%{transform:scaleY(1);transform-origin:top;opacity:.4}
  50%{transform:scaleY(1);opacity:1}
}

.hero-eyebrow{
  font-family:var(--font-en); font-style:italic; font-size:13px;
  letter-spacing:.4em; color:rgba(234,241,246,.85); margin:0 0 36px;
  display:flex; align-items:center; justify-content:center; gap:14px;
}
.hero-eyebrow::before,.hero-eyebrow::after{
  content:""; width:36px; height:1px; background:rgba(234,241,246,.7);
}
.hero-logo-wrap{
  width:clamp(260px,34vw,400px);margin:0 auto 44px;
  display:flex;align-items:center;justify-content:center;
  position:relative;padding:24px 32px;
  animation:hero-fadeup 1.4s cubic-bezier(.2,.7,.2,1) .2s both;
}
.hero-logo-wrap::before{
  content:"";position:absolute;inset:-8px;z-index:-1;
  background:radial-gradient(ellipse at center,rgba(244,248,251,.92) 0%,rgba(244,248,251,.78) 55%,rgba(244,248,251,0) 85%);
  filter:blur(4px);
}
.hero-logo-img{width:100%;height:auto;display:block}
@keyframes hero-fadeup{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
@media(max-width:760px){
  .hero-rail,.hero-corner{display:none}
  .hero-scroll{font-size:9px;letter-spacing:.3em;bottom:20px}
  .hero-scroll::after{height:32px}
}

.character-card{width:100%;aspect-ratio:4/5;background:linear-gradient(155deg,var(--bg) 0%,var(--bg-alt) 55%,var(--bg-deep) 100%);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;gap:26px;position:sticky;top:100px;box-shadow:0 30px 60px -30px rgba(42,53,64,.35),0 8px 24px -12px rgba(42,53,64,.18),inset 0 1px 0 rgba(255,255,255,.6)}
.character-card::before{content:"";position:absolute;inset:14px;border:1px solid var(--line-soft);pointer-events:none}
.character-card::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 30% 25%,rgba(255,255,255,.55) 0%,transparent 55%)}
.character-img{
  width:92%;height:auto;display:block;position:relative;z-index:1;
  filter:
    drop-shadow(0 18px 24px rgba(42,53,64,.28))
    drop-shadow(0 6px 10px rgba(42,53,64,.18))
    drop-shadow(0 2px 3px rgba(42,53,64,.12));
  transform:translateZ(0);
}
.character-cap{font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.3em;color:var(--wood);margin:0;position:relative;z-index:1}
.hero-tagline{
  font-family:var(--font-jp); font-weight:500;
  font-size:clamp(22px,3vw,36px); letter-spacing:.24em; line-height:2;
  margin:0 0 18px; text-wrap:balance;
  color:#F4F8FB;
  animation:hero-fadeup 1.4s cubic-bezier(.2,.7,.2,1) .5s both;
}
.hero-tagline-en{
  font-family:var(--font-en); font-style:italic;
  font-size:clamp(13px,1.3vw,15px); letter-spacing:.36em;
  color:rgba(234,241,246,.7); margin:32px 0 0;
  animation:hero-fadeup 1.4s cubic-bezier(.2,.7,.2,1) .8s both;
}

/* Concept */
.concept{
  background:linear-gradient(to bottom,
    var(--midnight) 0%,var(--wood-deep) 100px,var(--wood) 180px,var(--bg-alt) 260px,var(--bg) 340px);
  padding-top:300px;text-align:center;
}
.concept-poem{
  font-family:var(--font-jp); font-size:clamp(16px,1.7vw,19px);
  line-height:2.4; letter-spacing:.16em; color:var(--ink);
  margin:0 auto 48px; max-width:640px;
}
.concept-poem p{margin:0 0 1.4em;text-wrap:pretty}
.concept-poem p:last-child{margin:0}
@media(max-width:760px){
  .concept-poem{
    font-size:15px;line-height:2.2;letter-spacing:.08em;
    padding:0 4px;
  }
  .concept-poem br{display:none}
}
.concept-sign{
  font-family:var(--font-en); font-style:italic; font-size:14px;
  letter-spacing:.32em; color:var(--wood);
}

/* Menu */
.menu{
  background:var(--bg-alt);
  color:var(--ink);text-align:center;overflow:hidden;
}
.menu::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 80% 10%,rgba(127,180,220,.15) 0%,transparent 50%),
    radial-gradient(ellipse at 10% 90%,rgba(90,122,149,.12) 0%,transparent 55%);
}
.menu>*{position:relative;z-index:1}
.menu .eyebrow{color:var(--wood)}
.menu .eyebrow::before{color:var(--wood)}
.menu .section-title-en{color:var(--ink)}
.menu .section-title{color:var(--ink-soft)}
.menu .section-rule{background:var(--line)}
.menu-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  margin-top:56px;
}
.menu-card{aspect-ratio:4/5;position:relative;overflow:hidden;background:var(--bg-deep);border:1px solid var(--line-soft)}
.menu::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 80% 10%,rgba(127,180,220,.10) 0%,transparent 50%),
    radial-gradient(ellipse at 10% 90%,rgba(62,90,117,.18) 0%,transparent 55%);
}
.menu>*{position:relative;z-index:1}
.menu .eyebrow{color:var(--azure)}
.menu .eyebrow::before{color:var(--azure)}
.menu .section-title-en{color:#F4F8FB}
.menu .section-title{color:rgba(234,241,246,.78)}
.menu .section-rule{background:var(--midnight-line)}
.menu-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  margin-top:56px;
}
.menu-card{aspect-ratio:4/5;position:relative;overflow:hidden;background:var(--midnight-2);border:1px solid var(--midnight-line)}
.menu-card .photo{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .8s ease;
}
.menu-card:hover .photo{transform:scale(1.04)}
.menu-card .caption{
  position:absolute;left:0;right:0;bottom:0;
  padding:18px 18px 16px;
  background:linear-gradient(to top,rgba(0,0,0,.55) 0%,rgba(0,0,0,.25) 60%,transparent 100%);
  color:#EAF1F6;text-align:left;
}
.menu-card .caption .en{
  font-family:var(--font-en);font-style:italic;font-size:18px;letter-spacing:.16em;
  color:#EAF1F6;line-height:1.1;
}
.menu-card .caption .jp{
  font-family:var(--font-jp);font-size:12px;letter-spacing:.24em;
  color:rgba(234,241,246,.85);margin-top:4px;
}
.ph-tag{
  position:absolute;top:14px;left:14px;z-index:2;
  font-family:var(--font-en);font-style:italic;font-size:11px;letter-spacing:.3em;
  color:#EAF1F6;background:rgba(14,24,32,.45);backdrop-filter:blur(4px);padding:4px 10px;
}
.photo-ph{
  width:100%;height:100%;
  background:
    repeating-linear-gradient(135deg,
      rgba(62,90,117,.06) 0,rgba(62,90,117,.06) 8px,
      rgba(62,90,117,.12) 8px,rgba(62,90,117,.12) 16px),
    var(--bg-deep);
  border:1px solid var(--line);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; color:var(--ink-mute);
  font-family:var(--font-mono); font-size:11px; letter-spacing:.18em;
  padding:20px; position:relative;
}
.photo-ph::before{content:"";position:absolute;inset:14px;border:1px solid var(--line-soft)}
.ph-label{font-size:10px;letter-spacing:.3em;color:var(--wood-deep);text-transform:uppercase}
.menu-coming{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px;
  padding:36px 56px; border:1px solid var(--line); background:var(--bg);
  margin:48px auto 0; width:fit-content; line-height:1;
}
.menu-coming-en{
  font-family:var(--font-en); font-style:italic; font-size:26px;
  letter-spacing:.18em; color:var(--wood-deep);
}
.menu-coming-jp{
  font-family:var(--font-jp); font-size:13px; letter-spacing:.3em; color:var(--ink-soft);
}
@media(max-width:760px){.menu-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

/* Lunch */
.lunch{background:var(--bg);text-align:center}
.lunch-intro{
  max-width:600px;margin:0 auto 56px;
  font-family:var(--font-jp);font-size:14px;letter-spacing:.18em;line-height:2.2;color:var(--ink-soft);
}
.lunch-courses{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin:0 0 24px;text-align:left;
}
.course-card{
  background:var(--bg-alt);border:1px solid var(--line-soft);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .35s ease;
}
.course-card:hover{transform:translateY(-3px)}
.course-photo{aspect-ratio:4/3;overflow:hidden;background:var(--bg-deep)}
.course-photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.course-card:hover .course-photo img{transform:scale(1.05)}
.course-body{padding:24px 24px 28px;display:flex;flex-direction:column;gap:8px;flex:1}
.course-letter{
  font-family:var(--font-en);font-style:italic;font-size:36px;letter-spacing:.04em;
  color:var(--wood);line-height:1;margin:0;
}
.course-name{font-family:var(--font-jp);font-size:15px;letter-spacing:.18em;color:var(--ink);font-weight:500;line-height:1.6;margin:6px 0 0}
.course-name-en{font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.16em;color:var(--ink-mute);margin:0}
.lunch-special{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  margin:32px 0 80px;padding:24px 32px;
  border:1px solid var(--wood);background:var(--bg-alt);
  font-family:var(--font-jp);font-size:13px;letter-spacing:.18em;color:var(--ink-soft);
  text-align:left;flex-wrap:wrap;
}
.lunch-special .label{
  font-family:var(--font-en);font-style:italic;font-size:18px;letter-spacing:.24em;
  color:var(--wood-deep);
}
.lunch-special .label::before{content:"— ";color:var(--wood)}
.lunch-sauces-title{
  font-family:var(--font-en);font-style:italic;font-size:32px;letter-spacing:.06em;
  color:var(--ink);margin:0 0 8px;
}
.lunch-sauces-jp{
  font-family:var(--font-jp);font-size:14px;letter-spacing:.22em;color:var(--ink-soft);
  margin:0 0 12px;
}
.lunch-sauces-note{
  font-family:var(--font-jp);font-size:12px;letter-spacing:.18em;color:var(--ink-mute);
  margin:0 auto 40px;max-width:560px;line-height:2;
}
.sauce-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
  margin:0 0 64px;text-align:left;
}
.sauce-card{
  border:1px solid var(--line-soft);padding:24px 28px;
  background:var(--bg);display:flex;flex-direction:column;gap:10px;
  position:relative;
}
.sauce-card.featured{background:var(--bg-alt);border-color:var(--wood)}
.sauce-card .badge{
  position:absolute;top:-1px;right:-1px;
  font-family:var(--font-en);font-style:italic;font-size:10px;letter-spacing:.28em;
  background:var(--wood-deep);color:var(--bg);padding:5px 12px;
}
.sauce-name{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.sauce-name .num{font-family:var(--font-en);font-style:italic;font-size:14px;letter-spacing:.16em;color:var(--wood)}
.sauce-name .jp{font-family:var(--font-jp);font-size:16px;letter-spacing:.18em;color:var(--ink);font-weight:500}
.sauce-tag{
  align-self:flex-start;
  font-family:var(--font-en);font-style:italic;font-size:10px;letter-spacing:.3em;
  color:var(--wood-deep);border:1px solid var(--line);padding:3px 10px;
}
.sauce-desc{font-family:var(--font-jp);font-size:13px;letter-spacing:.12em;line-height:2;color:var(--ink-soft);margin:0}
.lunch-set{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px 32px;
  max-width:760px;margin:0 auto 56px;text-align:left;
  padding:32px;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
}
.set-item{display:flex;align-items:flex-start;gap:14px;font-family:var(--font-jp);font-size:13px;letter-spacing:.14em;line-height:1.9;color:var(--ink-soft)}
.set-item .set-label{font-family:var(--font-en);font-style:italic;font-size:11px;letter-spacing:.24em;color:var(--wood);min-width:78px;padding-top:2px;flex-shrink:0}
.set-item strong{font-weight:500;color:var(--ink);font-size:14px;letter-spacing:.18em}
.set-item small{display:block;font-size:11px;color:var(--ink-mute);letter-spacing:.16em;margin-top:2px}
.lunch-time-card{
  display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap;
  padding:28px 36px;border:1px solid var(--ink);background:var(--bg-alt);
  max-width:600px;margin:0 auto;
}
.lunch-time-card .time-label{font-family:var(--font-en);font-style:italic;font-size:18px;letter-spacing:.24em;color:var(--wood-deep)}
.lunch-time-card .time-value{font-family:var(--font-en);font-style:italic;font-size:24px;letter-spacing:.08em;color:var(--ink)}
.lunch-time-card .time-value small{font-family:var(--font-jp);font-style:normal;font-size:11px;letter-spacing:.2em;color:var(--ink-mute);margin-left:6px}
.lunch-time-card .time-closed{font-family:var(--font-jp);font-size:12px;letter-spacing:.2em;color:var(--ink-mute);border-left:1px solid var(--line);padding-left:24px}
.lunch-foot{
  margin:48px auto 0;max-width:680px;
  font-family:var(--font-jp);font-size:13px;letter-spacing:.16em;line-height:2.2;color:var(--ink-soft);
  padding-top:32px;border-top:1px solid var(--line-soft);
}
.lunch-foot p{margin:0 0 1em}
.lunch-foot p:last-child{margin:0}
@media(max-width:760px){
  .lunch-courses{grid-template-columns:1fr;gap:14px}
  .sauce-grid{grid-template-columns:1fr}
  .lunch-set{grid-template-columns:1fr;padding:24px}
  .lunch-time-card{padding:24px;gap:20px}
  .lunch-time-card .time-closed{border-left:0;border-top:1px solid var(--line);padding:16px 0 0}
}

/* Shop / Goods */
.shop{background:var(--bg);text-align:center}

/* Shop teaser (index) */
.shop-teaser{
  background:linear-gradient(to bottom,var(--bg) 0%,var(--bg-alt) 100%);
  overflow:hidden;position:relative;
}
.shop-teaser::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 90% 30%,rgba(127,180,220,.15) 0%,transparent 55%);
}
.shop-teaser>*{position:relative;z-index:1}
.shop-teaser-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.shop-teaser-text .eyebrow{margin-top:0}
.shop-teaser-text .section-title-en,.shop-teaser-text .section-title{text-align:left}
.shop-teaser-lead{
  font-family:var(--font-jp);font-size:14px;letter-spacing:.18em;line-height:2.2;
  color:var(--ink-soft);margin:0 0 32px;max-width:440px;
}
.shop-teaser-list{
  list-style:none;padding:0;margin:0 0 40px;
  border-top:1px solid var(--line-soft);
}
.shop-teaser-list li{
  display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:20px;
  padding:18px 0;border-bottom:1px solid var(--line-soft);
}
.shop-teaser-list .num{
  font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.24em;color:var(--wood);
}
.shop-teaser-list .name{
  font-family:var(--font-en);font-style:italic;font-size:18px;letter-spacing:.04em;color:var(--ink);
}
.shop-teaser-list .name small{
  display:block;font-family:var(--font-jp);font-style:normal;font-size:11px;letter-spacing:.22em;
  color:var(--ink-mute);margin-top:3px;
}
.shop-teaser-list .price{
  font-family:var(--font-en);font-style:italic;font-size:18px;letter-spacing:.06em;color:var(--ink);
}
.shop-teaser-cta{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--font-en);font-style:italic;font-size:14px;letter-spacing:.3em;
  color:var(--wood-deep);padding-bottom:6px;border-bottom:1px solid var(--wood-deep);
  transition:gap .3s ease;
}
.shop-teaser-cta:hover{gap:22px}
.shop-teaser-visual{
  position:relative;overflow:hidden;aspect-ratio:4/5;
  border:1px solid var(--line);background:var(--bg-deep);
}
.shop-teaser-visual .bg{
  position:absolute;inset:0;
  background:url('dressing-both.jpg') center/cover no-repeat;
  transition:transform 1.2s ease;
}
.shop-teaser-visual:hover .bg{transform:scale(1.05)}
.shop-teaser-visual .overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(42,53,64,.05) 0%,rgba(42,53,64,.35) 100%);
}
.shop-teaser-visual .visual-label{
  position:absolute;left:24px;top:24px;z-index:2;
  font-family:var(--font-en);font-style:italic;font-size:12px;letter-spacing:.4em;
  color:#EAF1F6;padding:6px 14px;border:1px solid rgba(234,241,246,.5);
  backdrop-filter:blur(4px);background:rgba(14,24,32,.2);
}
@media(max-width:880px){
  .shop-teaser-grid{grid-template-columns:1fr;gap:40px}
  .shop-teaser-visual{aspect-ratio:16/10;order:-1}
}
@media(max-width:760px){
  .shop-teaser-lead{
    font-size:15px;letter-spacing:.04em;line-height:1.9;
    margin:0 0 28px;max-width:none;
  }
  .shop-teaser-lead br{display:none}
  .shop-teaser-list{margin:0 0 32px}
  .shop-teaser-list li{
    grid-template-columns:auto 1fr auto;gap:12px;
    padding:16px 0;
  }
  .shop-teaser-list .num{font-size:11px;letter-spacing:.18em}
  .shop-teaser-list .name{
    font-size:16px;letter-spacing:.02em;line-height:1.35;
  }
  .shop-teaser-list .name small{
    font-size:11px;letter-spacing:.08em;line-height:1.5;margin-top:4px;
  }
  .shop-teaser-list .price{font-size:15px;letter-spacing:.04em}
  .shop-teaser-cta{font-size:12px;letter-spacing:.24em}
}
@media(max-width:420px){
  .shop-teaser-lead{font-size:14px;line-height:1.85;letter-spacing:.02em}
  .shop-teaser-list li{gap:10px;padding:14px 0}
  .shop-teaser-list .num{font-size:10px;letter-spacing:.14em}
  .shop-teaser-list .name{font-size:15px}
  .shop-teaser-list .name small{font-size:10.5px;letter-spacing:.06em}
  .shop-teaser-list .price{font-size:14px}
}

/* Shop page */
.shop-page-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:56px;text-align:left;
}
.shop-hero{
  margin:48px auto 0;max-width:960px;aspect-ratio:16/9;
  background:url('dressing-both.jpg') center/cover no-repeat var(--bg-deep);
  border:1px solid var(--line);position:relative;overflow:hidden;
}
.shop-hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(42,53,64,.05) 0%,rgba(42,53,64,.35) 100%);
  pointer-events:none;
}
.shop-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;
  margin-top:48px;text-align:left;
}
.product-card{
  background:var(--bg-alt);border:1px solid var(--line-soft);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .35s ease,box-shadow .35s ease;
}
.product-card:hover{transform:translateY(-4px);box-shadow:0 18px 48px -24px rgba(42,53,64,.35)}
.product-photo{aspect-ratio:1/1;overflow:hidden;background:var(--bg-deep)}
.product-photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.product-card:hover .product-photo img{transform:scale(1.05)}
.product-body{padding:32px 32px 36px;display:flex;flex-direction:column;gap:14px}
.product-tag{
  font-family:var(--font-en);font-style:italic;font-size:11px;letter-spacing:.32em;
  color:var(--wood);align-self:flex-start;
  border-bottom:1px solid var(--wood);padding-bottom:2px;
}
.product-name-en{font-family:var(--font-en);font-style:italic;font-size:24px;letter-spacing:.06em;color:var(--ink);line-height:1.2;margin:4px 0 0}
.product-name-jp{font-family:var(--font-jp);font-size:18px;letter-spacing:.2em;color:var(--ink);font-weight:500;line-height:1.5}
.product-meta{
  display:flex;gap:24px;align-items:baseline;
  padding-top:16px;border-top:1px solid var(--line-soft);margin-top:8px;
  font-family:var(--font-jp);font-size:13px;letter-spacing:.16em;color:var(--ink-soft);
}
.product-price{font-family:var(--font-en);font-style:italic;font-size:24px;letter-spacing:.04em;color:var(--ink);font-weight:500}
.product-price small{font-family:var(--font-jp);font-style:normal;font-size:11px;letter-spacing:.2em;color:var(--ink-mute);margin-left:4px;font-weight:400}
.product-volume{font-family:var(--font-en);font-style:italic;font-size:14px;letter-spacing:.18em;color:var(--ink-soft)}
.product-desc{font-family:var(--font-jp);font-size:13px;letter-spacing:.14em;line-height:2;color:var(--ink-soft);margin:0}
.shop-note{
  margin:48px auto 0;max-width:560px;padding:20px 28px;
  border:1px solid var(--line);background:var(--bg-alt);
  font-family:var(--font-jp);font-size:12px;letter-spacing:.2em;color:var(--ink-soft);
  line-height:2;
}
.shop-note strong{color:var(--wood-deep);font-weight:500;letter-spacing:.24em}
@media(max-width:760px){
  .shop-page-grid{grid-template-columns:1fr;gap:24px}
  .shop-hero{aspect-ratio:4/3}
  .product-body{padding:28px 24px 30px;gap:12px}
  .product-tag{font-size:10px;letter-spacing:.22em}
  .product-name-en{font-size:22px;letter-spacing:.04em}
  .product-name-jp{font-size:15px;letter-spacing:.06em;line-height:1.6}
  .product-desc{
    font-size:14px;letter-spacing:.02em;line-height:1.9;
  }
  .product-meta{gap:16px;padding-top:14px}
  .product-price{font-size:22px;letter-spacing:.02em}
  .product-price small{font-size:10px;letter-spacing:.08em}
  .product-volume{font-size:12px;letter-spacing:.1em}
}
@media(max-width:420px){
  .product-body{padding:24px 20px 26px}
  .product-name-en{font-size:20px}
  .product-name-jp{font-size:14px;letter-spacing:.04em}
  .product-desc{font-size:13.5px;letter-spacing:.01em;line-height:1.85}
  .product-price{font-size:20px}
}

/* Info */
.info{background:var(--bg)}
.info-layout{
  display:grid; grid-template-columns:1fr 1fr; gap:64px;
  align-items:start; margin-top:56px;
}
.info-photo{position:sticky;top:100px}
.info-table{font-family:var(--font-jp);font-size:15px;letter-spacing:.08em;line-height:1.95}
.info-row{
  display:grid; grid-template-columns:130px 1fr; gap:20px;
  padding:20px 0; border-bottom:1px solid var(--line-soft);
}
.info-row:first-child{border-top:1px solid var(--line-soft)}
.info-row dt{
  font-family:var(--font-en); font-style:italic; font-size:13px;
  letter-spacing:.28em; color:var(--wood); padding-top:3px;
}
.info-row dd{margin:0}
.jp-label{
  display:block; font-family:var(--font-jp); font-size:11px;
  letter-spacing:.3em; color:var(--ink-mute); margin-bottom:4px;
}
.hours-block{display:block;margin-bottom:6px}
.hours-block:last-child{margin-bottom:0}
.hours-label{
  display:inline-block;width:78px;
  font-family:var(--font-en);font-style:italic;font-size:12px;letter-spacing:.2em;color:var(--wood);
}
.info-row dd small{font-size:12px;color:var(--ink-mute)}
.info-row dd a{border-bottom:1px solid var(--line)}
.info-row dd a:hover{color:var(--wood-deep);border-color:var(--wood-deep)}
@media(max-width:880px){
  .info-layout{grid-template-columns:1fr;gap:32px}
  .info-photo{position:static;aspect-ratio:4/3}
}

/* Map */
.map{
  background:linear-gradient(to bottom,
    var(--bg) 0%,var(--bg-alt) 40px,var(--wood) 140px,var(--midnight-2) 240px,
    var(--midnight-2) calc(100% - 240px),var(--wood) calc(100% - 140px),var(--bg-alt) calc(100% - 40px),var(--bg) 100%);
  color:#EAF1F6;padding:160px 0;overflow:hidden;
}
.map .eyebrow{color:var(--azure)}
.map .eyebrow::before{color:var(--azure)}
.map .section-title-en{color:#F4F8FB}
.map .section-title{color:rgba(234,241,246,.78)}
.map .section-rule{background:var(--midnight-line)}
.map-frame{
  position:relative;margin-top:48px;
  border:1px solid var(--midnight-line);background:var(--midnight);
  overflow:hidden;
}
.map-frame iframe{
  display:block;width:100%;height:480px;border:0;
  filter:invert(.92) hue-rotate(180deg) saturate(.7) contrast(.9);
}
.map-meta{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  margin-top:24px;flex-wrap:wrap;
}
.map-addr{
  font-family:var(--font-jp);font-size:14px;letter-spacing:.14em;
  color:rgba(234,241,246,.7);line-height:1.9;
}
.map-addr strong{font-weight:500;color:#F4F8FB;letter-spacing:.18em;display:block;margin-bottom:4px}
.map-link{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.24em;
  color:var(--azure);border:1px solid var(--azure);
  padding:14px 22px;transition:all .25s ease;
}
.map-link:hover{background:var(--azure);color:var(--midnight)}
.map-link svg{width:14px;height:14px}
@media(max-width:760px){
  .map-frame iframe{height:360px}
}

/* Reserve */
.reserve{
  background:linear-gradient(to bottom,var(--bg) 0%,var(--bg-alt) 60%,var(--bg-deep) 100%);
  color:var(--ink);text-align:center;overflow:hidden;
}
.reserve::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 20% 30%,rgba(127,180,220,.22) 0%,transparent 50%),
    radial-gradient(ellipse at 80% 80%,rgba(90,122,149,.18) 0%,transparent 55%);
}
.reserve>*{position:relative;z-index:1}
.reserve .eyebrow{color:var(--wood)}
.reserve .eyebrow::before{color:var(--wood)}
.reserve .section-title-en{color:var(--ink)}
.reserve .section-title{color:var(--ink-soft)}
.reserve .section-rule{background:var(--line)}
.reserve-buttons{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:14px;
  min-width:280px; padding:20px 32px;
  font-family:var(--font-jp); font-size:14px; letter-spacing:.22em;
  background:rgba(255,255,255,.55); backdrop-filter:blur(4px);
  border:1px solid var(--wood-deep); color:var(--ink);
  position:relative; overflow:hidden; transition:color .35s ease;
}
.btn::before{
  content:""; position:absolute; inset:0; background:var(--wood-deep);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s cubic-bezier(.7,0,.3,1); z-index:0;
}
.btn:hover{color:#fff}
.btn:hover::before{transform:scaleX(1)}
.btn>*{position:relative;z-index:1}
.btn-en{font-family:var(--font-en);font-style:italic;font-size:12px;letter-spacing:.26em;color:var(--wood)}
.btn:hover .btn-en{color:var(--azure)}
.btn-arrow{display:inline-block;width:14px;height:1px;background:currentColor;position:relative}
.btn-arrow::after{
  content:""; position:absolute; right:0; top:-3px;
  width:7px; height:7px; border-top:1px solid currentColor; border-right:1px solid currentColor;
  transform:rotate(45deg);
}
.reserve-note{
  margin-top:36px; font-family:var(--font-jp); font-size:12px;
  letter-spacing:.18em; color:var(--ink-mute);
}

/* Footer */
.footer{background:var(--ink);color:var(--bg);padding:72px 0 36px;text-align:center}
.footer-logo{font-family:var(--font-jp);font-size:20px;letter-spacing:.4em;margin-bottom:6px}
.footer-en{font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.3em;color:var(--wood);margin-bottom:32px}
.footer-contact{font-family:var(--font-jp);font-size:12px;letter-spacing:.16em;line-height:2;color:rgba(234,241,246,.7);margin-bottom:32px}
.footer-rule{width:60px;height:1px;background:rgba(234,241,246,.2);margin:28px auto}
.footer-copy{font-family:var(--font-en);font-size:11px;letter-spacing:.32em;color:rgba(234,241,246,.4)}


/* ===== Menu Selector (index page) ===== */
.menu-select{
  background:linear-gradient(to bottom,var(--bg) 0%,var(--bg-alt) 100%);
  color:var(--ink);text-align:center;overflow:hidden;
}
.menu-select::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 80% 10%,rgba(127,180,220,.18) 0%,transparent 50%),
    radial-gradient(ellipse at 10% 90%,rgba(90,122,149,.14) 0%,transparent 55%);
}
.menu-select>*{position:relative;z-index:1}
.menu-select-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:56px;
}
.menu-select-card{
  position:relative;display:block;overflow:hidden;
  aspect-ratio:4/5;background:var(--midnight-2);
  border:1px solid var(--midnight-line);
  text-align:left;
  transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s ease;
}
.menu-select-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(14,24,32,.55)}
.menu-select-card .bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform 1.4s ease,filter .6s ease;
  filter:saturate(1.1) contrast(1.06) brightness(.78);
}
.menu-select-card:hover .bg{transform:scale(1.06);filter:saturate(1.18) contrast(1.08) brightness(.82)}
.menu-select-card .bg.lunch{background-image:url('menu-pork.jpg')}
.menu-select-card .bg.dinner{background-image:url('menu-steak.jpg')}
.menu-select-card .overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,24,32,.15) 0%,rgba(14,24,32,.55) 60%,rgba(14,24,32,.85) 100%);
}
.menu-select-card .inner{
  position:absolute;inset:0;z-index:2;
  padding:40px 44px;display:flex;flex-direction:column;justify-content:space-between;color:#EAF1F6;
}
.menu-select-card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.menu-select-card .badge{
  font-family:var(--font-en);font-style:italic;font-size:11px;letter-spacing:.36em;
  color:rgba(234,241,246,.85);
  padding:6px 12px;border:1px solid rgba(234,241,246,.4);
}
.menu-select-card .hours{
  font-family:var(--font-en);font-style:italic;font-size:11px;letter-spacing:.28em;
  color:rgba(234,241,246,.78);text-align:right;line-height:1.7;
}
.menu-select-card .title-en{
  font-family:var(--font-en);font-style:italic;font-weight:400;
  font-size:clamp(48px,6vw,82px);letter-spacing:.04em;line-height:.95;
  color:#F4F8FB;margin:0 0 12px;
}
.menu-select-card .title-jp{
  font-family:var(--font-jp);font-size:14px;letter-spacing:.3em;
  color:rgba(234,241,246,.8);margin:0 0 18px;
}
.menu-select-card .desc{
  font-family:var(--font-jp);font-size:13px;letter-spacing:.14em;line-height:2;
  color:rgba(234,241,246,.78);margin:0 0 24px;max-width:340px;
}
.menu-select-card .cta{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.3em;
  color:var(--azure);padding-bottom:4px;border-bottom:1px solid var(--azure);
  align-self:flex-start;transition:gap .3s ease;
}
.menu-select-card:hover .cta{gap:18px}
@media(max-width:760px){
  .menu-select-grid{grid-template-columns:1fr;gap:16px}
  .menu-select-card{aspect-ratio:5/6}
  .menu-select-card .inner{padding:28px}
}

/* ===== Sub-page Hero (Lunch / Dinner) ===== */
.sub-hero{
  min-height:72vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  padding:160px 24px 100px;position:relative;overflow:hidden;
  background:var(--midnight);color:#EAF1F6;
}
.sub-hero>*{position:relative;z-index:3}
.sub-hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;
  filter:saturate(1.1) contrast(1.05) brightness(.7);animation:sub-zoom 24s ease-out infinite alternate;
}
@keyframes sub-zoom{from{transform:scale(1)}to{transform:scale(1.12)}}
.sub-hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse at center,rgba(14,24,32,.2) 0%,rgba(14,24,32,.6) 70%,rgba(14,24,32,.92) 100%);
}
.sub-hero-eyebrow{
  font-family:var(--font-en);font-style:italic;font-size:12px;letter-spacing:.5em;
  color:rgba(234,241,246,.7);margin:0 0 28px;
  display:flex;align-items:center;justify-content:center;gap:14px;
}
.sub-hero-eyebrow::before,.sub-hero-eyebrow::after{
  content:"";width:36px;height:1px;background:rgba(234,241,246,.5);
}
.sub-hero h1{
  font-family:var(--font-en);font-style:italic;font-weight:400;
  font-size:clamp(64px,9vw,128px);letter-spacing:.02em;line-height:.95;
  color:#F4F8FB;margin:0 0 18px;
}
.sub-hero .jp{
  font-family:var(--font-jp);font-size:clamp(14px,1.4vw,18px);letter-spacing:.34em;
  color:rgba(234,241,246,.82);margin:0;
}
.sub-hero .meta{
  margin-top:32px;font-family:var(--font-en);font-style:italic;font-size:12px;
  letter-spacing:.32em;color:var(--azure);
}
.sub-hero .meta span{margin:0 14px}

/* Breadcrumb / back */
.subnav{
  background:var(--midnight);color:rgba(234,241,246,.65);
  padding:24px 0;border-top:1px solid var(--midnight-line);
  font-family:var(--font-en);font-style:italic;font-size:12px;letter-spacing:.28em;
}
.subnav .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.subnav a{color:#EAF1F6;display:inline-flex;align-items:center;gap:10px;transition:color .25s ease}
.subnav a:hover{color:var(--azure)}
.subnav .other{display:flex;gap:24px;align-items:center}
.subnav .other a{padding-bottom:2px;border-bottom:1px solid transparent;transition:border-color .25s ease}
.subnav .other a:hover{border-color:var(--azure)}
.subnav .arrow{display:inline-block;width:14px;height:1px;background:currentColor;position:relative}
.subnav .arrow.back::before{
  content:"";position:absolute;left:0;top:-3px;
  width:7px;height:7px;border-top:1px solid currentColor;border-left:1px solid currentColor;
  transform:rotate(-45deg);
}

/* Sub-page body container */
.subpage{padding-top:0}
.subpage section{padding:clamp(80px,10vw,140px) 0}

/* ===== Dinner page ===== */
.dinner-intro{
  max-width:600px;margin:0 auto 64px;
  font-family:var(--font-jp);font-size:14px;letter-spacing:.18em;line-height:2.2;color:var(--ink-soft);
}
.dinner-section{background:var(--bg);text-align:center;padding:clamp(80px,10vw,140px) 0}
.dinner-section.alt{background:var(--bg-alt)}
.dinner-section.dark{
  background:var(--midnight);color:#EAF1F6;
}
.dinner-section.dark .eyebrow,.dinner-section.dark .eyebrow::before{color:var(--azure)}
.dinner-section.dark .section-title-en{color:#F4F8FB}
.dinner-section.dark .section-title{color:rgba(234,241,246,.78)}
.dinner-section.dark .section-rule{background:var(--midnight-line)}

.dish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px;text-align:left}
.dish-card{
  background:var(--bg-alt);border:1px solid var(--line-soft);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .35s ease,box-shadow .35s ease;
}
.dish-card:hover{transform:translateY(-4px);box-shadow:0 18px 42px -24px rgba(42,53,64,.35)}
.dish-card .photo{aspect-ratio:4/3;overflow:hidden;background:var(--bg-deep)}
.dish-card .photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.dish-card:hover .photo img{transform:scale(1.05)}
.dish-card .body{padding:24px 26px 28px;display:flex;flex-direction:column;gap:6px;flex:1}
.dish-card .cat{
  font-family:var(--font-en);font-style:italic;font-size:11px;letter-spacing:.3em;
  color:var(--wood);align-self:flex-start;border-bottom:1px solid var(--wood);padding-bottom:2px;margin-bottom:8px;
}
.dish-card .en{font-family:var(--font-en);font-style:italic;font-size:20px;letter-spacing:.04em;color:var(--ink);line-height:1.2;margin:0}
.dish-card .jp{font-family:var(--font-jp);font-size:14px;letter-spacing:.18em;color:var(--ink);font-weight:500;line-height:1.6;margin:4px 0 0}
.dish-card .price{
  margin-top:14px;padding-top:14px;border-top:1px solid var(--line-soft);
  font-family:var(--font-en);font-style:italic;font-size:18px;letter-spacing:.06em;color:var(--ink);
}
.dish-card .price small{font-family:var(--font-jp);font-style:normal;font-size:11px;letter-spacing:.2em;color:var(--ink-mute);margin-left:4px}

.wine-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:56px;text-align:left;
}
.wine-card{
  border:1px solid var(--midnight-line);padding:28px 28px;background:var(--midnight-2);
  display:flex;flex-direction:column;gap:6px;
}
.wine-card .num{font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.24em;color:var(--azure)}
.wine-card .type{
  font-family:var(--font-en);font-style:italic;font-size:11px;letter-spacing:.32em;
  color:rgba(234,241,246,.6);align-self:flex-start;margin-bottom:6px;border-bottom:1px solid rgba(234,241,246,.2);padding-bottom:2px;
}
.wine-card .name{font-family:var(--font-en);font-style:italic;font-size:22px;letter-spacing:.04em;color:#F4F8FB;line-height:1.2;margin:6px 0 0}
.wine-card .jp{font-family:var(--font-jp);font-size:13px;letter-spacing:.18em;color:rgba(234,241,246,.78);margin:4px 0 12px}
.wine-card .row{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding-top:14px;border-top:1px solid var(--midnight-line);
  font-family:var(--font-en);font-style:italic;font-size:13px;letter-spacing:.2em;color:rgba(234,241,246,.7);
}
.wine-card .row .price{color:#F4F8FB;font-size:18px}
.wine-note{
  margin:48px auto 0;max-width:600px;padding:20px 28px;
  border:1px solid var(--midnight-line);background:var(--midnight-2);
  font-family:var(--font-jp);font-size:12px;letter-spacing:.2em;color:rgba(234,241,246,.78);line-height:2;
}
@media(max-width:760px){
  .dish-grid{grid-template-columns:1fr;gap:14px}
  .wine-grid{grid-template-columns:1fr}
}
