/* ============================================================
   焼鳥 鳥燈 -TORITŌ- / Ginza
   Editorial Premium Yakitori — Mobile First (375px base)
   Palette: Indigo × Washi × Copper (tare)
   ============================================================ */

:root{
  /* paper */
  --paper:        #F2EDE0;
  --paper-2:      #EAE2CE;
  --paper-3:      #DDD2B8;
  --paper-deep:   #C9BC9C;

  /* indigo */
  --ai:           #1A2E4F;   /* primary dark – ai-iro */
  --ai-2:         #25406B;
  --ai-3:         #3A5681;
  --ai-mute:      #4E617D;

  /* sumi (used sparingly) */
  --sumi:         #15110D;

  /* copper / tare */
  --tare:         #A8501A;   /* burnished copper */
  --tare-2:       #8C3E12;
  --tare-warm:    #C26F31;

  /* botanical */
  --moku:         #5A6E48;   /* matcha leaf */

  /* lines */
  --line:         rgba(26,46,79,.16);
  --line-soft:    rgba(26,46,79,.08);
  --line-paper:   rgba(242,237,224,.18);
  --hair-tare:    rgba(176,86,29,.45);

  /* type families */
  --serif-jp:     "Shippori Mincho B1", "Noto Serif JP", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
  --serif-jp-2:   "Noto Serif JP", "Yu Mincho", serif;
  --sans-jp:      "Noto Sans JP", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  --serif-en:     "Marcellus", "Times New Roman", serif;
  --mono:         "JetBrains Mono", "SFMono-Regular", "Menlo", "Courier New", monospace;

  /* metrics */
  --gutter:       20px;
  --maxw:         1280px;
}
@media (min-width: 720px){
  :root{ --gutter: 40px; }
}
@media (min-width: 1024px){
  :root{ --gutter: 64px; }
}

*,*::before,*::after{ box-sizing: border-box; }
html,body{ margin:0; padding:0; }
html{ -webkit-text-size-adjust: 100%; scroll-behavior: smooth; background: var(--paper); }
/* 固定ヘッダー(68px)分、ページ内リンクのジャンプ先が隠れないように */
section[id], main[id]{ scroll-margin-top: 84px; }
body{
  font-family: var(--sans-jp);
  color: var(--ai);
  background: var(--paper);
  font-feature-settings: "palt" 1;
  font-weight: 400;
  font-size: 17px;
  line-height: 1.85;
  letter-spacing: .04em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color: inherit; text-decoration: none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; padding:0; }
ul,ol{ margin:0; padding:0; list-style:none; }
hr{ border:0; border-top:1px solid var(--line); margin:0; }

/* subtle washi grain over everything */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1;
  background-image:
    radial-gradient(rgba(26,46,79,.025) 1px, transparent 1.4px),
    radial-gradient(rgba(176,86,29,.015) 1px, transparent 1.6px);
  background-size: 3px 3px, 7px 7px;
  mix-blend-mode: multiply;
  opacity:.55;
}

/* ============================================================
   TYPOGRAPHY HELPERS
   ============================================================ */
.kanji-h{ font-family: var(--serif-jp); font-weight: 500; letter-spacing: .14em; color: var(--ai); }
.serif-jp{ font-family: var(--serif-jp); }
.sans-jp { font-family: var(--sans-jp); }
.serif-en{ font-family: var(--serif-en); letter-spacing: .18em; }
.mono    { font-family: var(--mono); letter-spacing: .12em; }
.upper   { text-transform: uppercase; }

.eyebrow{
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .32em;
  color: var(--tare);
  text-transform: uppercase;
}
.eyebrow::before{
  content:""; width:28px; height:1px; background: var(--tare); opacity: .8;
}
.eyebrow.no-line::before{ display:none; }

.section-no{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--ai-mute);
}
.kanji-bullet{
  font-family: var(--serif-jp);
  color: var(--tare);
  font-weight: 500;
  letter-spacing: 0;
}

.tate{
  writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  text-orientation: mixed;
  font-feature-settings: "palt" 0;
  letter-spacing: .18em;
}

/* ============================================================
   PLACEHOLDER (images intentionally omitted)
   <div class="ph ph-16x9" data-mark="鳥" data-cap="HERO / hero.jpg"></div>
   ============================================================ */
.ph{
  position: relative;
  background:
    repeating-linear-gradient(135deg,
       rgba(26,46,79,.045) 0 1px,
       transparent 1px 13px),
    linear-gradient(180deg, var(--paper-2), var(--paper-3));
  border: 1px solid var(--line);
  overflow: hidden;
  display: grid;
  place-items: center;
  isolation: isolate;
}
.ph::before{                           /* corner ticks */
  content:"";
  position: absolute; inset: 8px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}
.ph::after{                            /* huge kanji watermark */
  content: attr(data-mark);
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-family: var(--serif-jp);
  font-weight: 500;
  font-size: clamp(72px, 22vw, 240px);
  color: var(--ai);
  opacity: .07;
  letter-spacing: 0;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}
.ph .cap{
  position: relative; z-index: 2;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  color: var(--ai-3);
  text-transform: uppercase;
  padding: 5px 10px;
  background: rgba(242,237,224,.78);
  border: 1px solid var(--line);
  border-radius: 1px;
  text-align: center;
  max-width: 80%;
}
.ph .corner{
  position: absolute; top: 10px; left: 10px; z-index: 2;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--ai-mute);
  letter-spacing: .25em;
}
.ph .corner.r{ left:auto; right:10px; }
.ph .corner.b{ top:auto; bottom:10px; }

.ph-16x9{ aspect-ratio: 16/9; }
.ph-4x3 { aspect-ratio: 4/3; }
.ph-3x4 { aspect-ratio: 3/4; }
.ph-4x5 { aspect-ratio: 4/5; }
.ph-1x1 { aspect-ratio: 1/1; }
.ph-5x4 { aspect-ratio: 5/4; }
.ph-2x3 { aspect-ratio: 2/3; }
.ph-21x9{ aspect-ratio: 21/9; }

/* dark variant for hero / featured */
.ph.dark{
  background:
    repeating-linear-gradient(135deg,
       rgba(242,237,224,.05) 0 1px,
       transparent 1px 14px),
    linear-gradient(180deg, #16243e 0%, #0F1A2E 100%);
  border-color: rgba(242,237,224,.14);
}
.ph.dark::before{ border-color: rgba(242,237,224,.10); }
.ph.dark::after { color: var(--paper); opacity: .07; }
.ph.dark .cap{
  background: rgba(15,26,46,.7);
  color: var(--paper);
  border-color: rgba(242,237,224,.2);
}
.ph.dark .corner{ color: rgba(242,237,224,.55); }

/* ============================================================
   STAGE / SHELL
   ============================================================ */
.shell{
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
section{ position: relative; z-index: 2; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position: sticky; top: 0; z-index: 80;
  background: rgba(242,237,224,.86);
  -webkit-backdrop-filter: blur(14px) saturate(1.05);
  backdrop-filter: blur(14px) saturate(1.05);
  border-bottom: 1px solid var(--line-soft);
}
.nav-inner{
  height: 68px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--gutter);
  max-width: var(--maxw);
  margin: 0 auto;
}
.brand{
  display: flex; align-items: baseline; gap: 10px;
}
.brand .mark{
  font-family: var(--serif-jp);
  font-size: 26px;
  font-weight: 600;
  letter-spacing: .3em;
  color: var(--ai);
}
.brand .mark .accent{ color: var(--tare); }
.brand .romaji{
  font-family: var(--serif-en);
  font-size: 13px;
  letter-spacing: .35em;
  color: var(--ai-mute);
}
.nav-links{
  display: none;
  gap: 28px;
  font-family: var(--sans-jp);
  font-size: 14px;
  letter-spacing: .22em;
  color: var(--ai);
}
.nav-links a{ position: relative; padding: 6px 0; }
.nav-links a::after{
  content:""; position: absolute; left:0; right:0; bottom: -2px;
  height: 1px; background: var(--tare); transform: scaleX(0);
  transform-origin: left; transition: transform .35s ease;
}
.nav-links a:hover::after{ transform: scaleX(1); }
.nav-cta{
  font-family: var(--sans-jp);
  font-size: 12px;
  letter-spacing: .3em;
  color: var(--paper);
  background: var(--ai);
  padding: 10px 16px;
  border: 1px solid var(--ai);
  transition: background .3s, color .3s;
}
.nav-cta:hover{ background: var(--tare); border-color: var(--tare); }
.nav-burger{
  display: inline-flex;
  flex-direction: column; gap: 4px;
  width: 36px; height: 36px;
  align-items: center; justify-content: center;
  border: 1px solid var(--line);
  margin-right: 8px;
}
.nav-burger span{
  width: 16px; height: 1px; background: var(--ai);
  transition: transform .3s ease;
}
/* ×ボタン: gap:4px + height:1px → translateY = (4+1)/2 = 2.5px */
.nav-burger.open span:nth-child(1){ transform: translateY(2.5px) rotate(45deg); }
.nav-burger.open span:nth-child(2){ transform: translateY(-2.5px) rotate(-45deg); }

@media (min-width: 880px){
  .nav-burger{ display: none; }
  .nav-links{ display: flex; }
}

/* mobile drawer */
.drawer{
  position: fixed; inset: 68px 0 0 0;
  background: var(--paper);
  z-index: 70;
  transform: translateY(-100%);
  transition: transform .4s cubic-bezier(.6,.05,.2,1);
  padding: 28px var(--gutter) 40px;
  border-bottom: 1px solid var(--line);
  overflow-y: auto;
}
.drawer.open{ transform: translateY(0); }
.drawer ul{ display: grid; gap: 6px; }
.drawer ul a{
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 14px 4px;
  border-bottom: 1px solid var(--line-soft);
  font-family: var(--serif-jp);
  font-size: 19px;
  letter-spacing: .22em;
  color: var(--ai);
}
.drawer ul a .en{
  font-family: var(--serif-en);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--ai-mute);
}
.drawer .drawer-cta{
  margin-top: 24px;
  display: block;
  text-align: center;
  background: var(--ai);
  color: var(--paper);
  padding: 16px;
  font-family: var(--sans-jp);
  font-size: 14px;
  letter-spacing: .3em;
}
@media (min-width: 880px){ .drawer{ display: none; } }

/* mobile-only line break */
@media (min-width: 880px){ .d-mob{ display: none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position: relative;
  padding: 28px var(--gutter) 56px;
  background: var(--paper);
}
.hero-inner{
  max-width: var(--maxw); margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  position: relative;
}
.hero-meta{
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ai-mute);
  letter-spacing: .28em;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.hero-meta .dot{ width: 6px; height: 6px; background: var(--tare); border-radius: 50%; display: inline-block; margin-right: 8px; vertical-align: middle; }
.hero-title{
  display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: start;
}
.hero-kanji{
  font-family: var(--serif-jp);
  font-weight: 500;
  color: var(--ai);
  font-size: clamp(64px, 22vw, 168px);
  line-height: .9;
  letter-spacing: -.01em;
  margin: 0;
}
.hero-kanji .small{
  display: block;
  font-size: .26em;
  letter-spacing: .35em;
  color: var(--tare);
  margin-top: 14px;
  font-weight: 500;
}
.hero-tate{
  font-family: var(--serif-jp);
  font-weight: 400;
  font-size: clamp(14px, 3.6vw, 22px);
  color: var(--ai-2);
  height: clamp(180px, 38vw, 320px);
  display: inline-block;
  padding-left: 8px;
  border-left: 1px solid var(--hair-tare);
}
.hero-sub{
  font-family: var(--serif-jp);
  font-size: 17px;
  line-height: 1.95;
  color: var(--ai-2);
  max-width: 32em;
  font-weight: 400;
  margin: 0;
}
.hero-cta-row{
  display: flex; gap: 14px; flex-wrap: wrap;
  align-items: center;
}
.btn-primary{
  background: var(--ai);
  color: var(--paper);
  padding: 16px 26px;
  font-family: var(--sans-jp);
  font-size: 14px;
  letter-spacing: .32em;
  border: 1px solid var(--ai);
  display: inline-flex; align-items: center; gap: 12px;
  transition: background .3s, border-color .3s;
}
.btn-primary:hover{ background: var(--tare); border-color: var(--tare); }
.btn-primary .arr{ font-family: var(--serif-en); font-size: 17px; }
.btn-ghost{
  color: var(--ai);
  padding: 16px 22px;
  font-family: var(--sans-jp);
  font-size: 14px;
  letter-spacing: .32em;
  border: 1px solid var(--ai);
  display: inline-flex; align-items: center; gap: 10px;
  transition: background .3s, color .3s;
}
.btn-ghost:hover{ background: var(--ai); color: var(--paper); }

.hero-figure{
  margin-top: 6px;
  position: relative;
}
.hero-figure .ph{ aspect-ratio: 4/5; }
.hero-figure-caption{
  position: absolute; left: -2px; bottom: -2px;
  padding: 10px 14px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-bottom: 0; border-left: 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--ai-mute);
}
.hero-side{
  display: flex; flex-direction: column; gap: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.hero-side .row{
  display: grid; grid-template-columns: 80px 1fr; gap: 14px;
  font-size: 14px;
}
.hero-side .row dt{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--ai-mute);
  padding-top: 2px;
}
.hero-side .row dd{
  margin: 0;
  font-family: var(--serif-jp);
  color: var(--ai);
}

@media (min-width: 880px){
  .hero{ padding-top: 56px; padding-bottom: 96px; }
  .hero-inner{
    grid-template-columns: 1.15fr .85fr;
    gap: 56px;
    align-items: end;
  }
  .hero-meta{ grid-column: 1 / -1; }
  .hero-figure{ grid-row: 2 / span 3; grid-column: 2; align-self: stretch; }
  .hero-figure .ph{ aspect-ratio: 3/4; height: 100%; }
  .hero-title{ grid-column: 1; align-items: end; }
  .hero-sub{ grid-column: 1; }
  .hero-cta-row{ grid-column: 1; }
  .hero-side{ grid-column: 1 / -1; margin-top: 32px; }
  /* ラベル(問)と値(答)が一目で対応するよう、各組を縦積み＋列間に区切り線 */
  .hero-side{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
  .hero-side .row{
    display: flex; flex-direction: column; gap: 7px;
    padding: 2px 24px;
    border-left: 1px solid var(--line);
  }
  .hero-side .row:first-child{ border-left: none; padding-left: 0; }
  .hero-side .row dt{ padding-top: 0; }
  .hero-side .row dd{ font-size: 15px; }
}

/* ============================================================
   PROLOGUE
   ============================================================ */
.prologue{
  background: var(--paper-2);
  padding: 64px var(--gutter);
  position: relative;
}
.prologue::before{
  content:""; position: absolute; left: 0; right: 0; top:0; height: 1px; background: var(--line);
}
.prologue-inner{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: 40px;
}
.prologue-tate-wrap{
  display: flex; justify-content: center;
  padding: 12px 0;
}
.prologue-tate{
  font-family: var(--serif-jp);
  font-weight: 400;
  color: var(--ai);
  font-size: clamp(20px, 5vw, 30px);
  line-height: 2.0;
  letter-spacing: .25em;
}
.prologue-body{
  font-family: var(--serif-jp);
  font-size: 17px;
  line-height: 2.0;
  color: var(--ai-2);
}
.prologue-body p + p{ margin-top: 1.5em; }
.prologue-sign{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .3em;
  color: var(--ai-mute);
  margin-top: 28px;
  display: flex; align-items: center; gap: 12px;
}
.prologue-sign::before{ content: ""; flex: 0 0 28px; height: 1px; background: var(--tare); }

@media (min-width: 880px){
  .prologue{ padding: 140px var(--gutter); }
  .prologue-inner{
    grid-template-columns: 220px 1fr 1fr;
    gap: 64px;
    align-items: start;
  }
  .prologue-tate-wrap{ justify-content: flex-start; padding-top: 8px; }
}

/* ============================================================
   PILLARS
   ============================================================ */
.pillars{
  padding: 64px var(--gutter);
  background: var(--paper);
}
.section-head{
  max-width: var(--maxw); margin: 0 auto 48px;
  display: grid; gap: 18px;
}
.section-head .top{
  display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 8px;
}
.section-head h2{
  font-family: var(--serif-jp);
  font-weight: 500;
  font-size: clamp(28px, 6vw, 44px);
  letter-spacing: .12em;
  margin: 0;
  color: var(--ai);
  line-height: 1.3;
}
.section-head h2 .en{
  display: block;
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: .42em;
  color: var(--tare);
  margin-bottom: 14px;
  font-weight: 400;
}
.section-head .lede{
  font-family: var(--serif-jp);
  color: var(--ai-2);
  font-size: 17px;
  line-height: 1.95;
  max-width: none;
}
.pillar-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: 56px;
}
.pillar{
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  position: relative;
}
.pillar-no{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--ai-mute);
}
.pillar-mark{
  display: flex; align-items: baseline; gap: 14px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 14px;
}
.pillar-mark .kanji{
  font-family: var(--serif-jp);
  font-weight: 500;
  font-size: clamp(36px, 7vw, 52px);
  line-height: 1;
  color: var(--ai);
  letter-spacing: .04em;
}
.pillar-mark .romaji{
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: .4em;
  color: var(--tare);
}
.pillar-body{
  font-family: var(--serif-jp);
  font-size: 17px;
  line-height: 1.95;
  color: var(--ai-2);
}
.pillar-figure .ph{ aspect-ratio: 4/3; }
.pillar-meta{
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
  margin-top: 6px;
}
.pillar-meta .k{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--ai-mute);
}
.pillar-meta .v{
  font-family: var(--serif-jp);
  font-size: 15px;
  color: var(--ai);
  margin-top: 2px;
}

@media (min-width: 880px){
  .pillars{ padding: 140px var(--gutter); }
  .pillar-grid{ gap: 96px; }
  .pillar{
    grid-template-columns: 1fr 1fr;
    gap: 56px;
    align-items: start;
  }
  .pillar.flip .pillar-figure{ order: -1; }
  .pillar-figure .ph{ aspect-ratio: 5/4; }
}

/* ============================================================
   CUTS — Specimen Index
   ============================================================ */
.cuts{
  padding: 64px var(--gutter);
  background: var(--ai);
  color: var(--paper);
  position: relative;
}
.cuts::before, .cuts::after{
  content:""; position: absolute; left: 0; right: 0; height: 1px; background: rgba(242,237,224,.16);
}
.cuts::before{ top: 0; } .cuts::after{ bottom: 0; }
.cuts .section-head h2{ color: var(--paper); }
.cuts .section-head h2 .en{ color: var(--tare-warm); }
.cuts .section-head .lede{ color: rgba(242,237,224,.78); }
.cuts .section-head .top{ border-bottom: 1px solid rgba(242,237,224,.18); padding-bottom: 18px; }
.cuts-count{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--tare-warm);
}

.cut-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}
.cut{
  position: relative;
  background: rgba(242,237,224,.03);
  border: 1px solid rgba(242,237,224,.12);
  padding: 16px 16px 22px;
  display: grid; gap: 14px;
}
.cut-head{
  display: flex; justify-content: space-between; align-items: baseline;
  border-bottom: 1px solid rgba(242,237,224,.16);
  padding-bottom: 10px;
}
.cut-no{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--tare-warm);
}
.cut-tier{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .3em;
  color: rgba(242,237,224,.65);
  border: 1px solid rgba(242,237,224,.25);
  padding: 3px 8px;
}
.cut-fig{ background: rgba(15,26,46,.6); }
.cut-fig.ph::after{ color: var(--paper); opacity: .07; }
.cut-fig.ph::before{ border-color: rgba(242,237,224,.10); }
.cut-fig{ aspect-ratio: 4/3; }
.cut-name{
  display: flex; align-items: baseline; gap: 12px;
}
.cut-name .jp{
  font-family: var(--serif-jp);
  font-weight: 500;
  font-size: 25px;
  letter-spacing: .12em;
  color: var(--paper);
}
.cut-name .en{
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: .35em;
  color: var(--tare-warm);
}
.cut-desc{
  font-family: var(--serif-jp);
  font-size: 16px;
  line-height: 1.85;
  color: rgba(242,237,224,.82);
}
.cut-meta{
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px 14px;
  border-top: 1px solid rgba(242,237,224,.14);
  padding-top: 10px;
  font-size: 12px;
}
.cut-meta dt{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .25em;
  color: rgba(242,237,224,.55);
}
.cut-meta dd{
  margin: 0;
  font-family: var(--serif-jp);
  color: var(--paper);
  letter-spacing: .08em;
}

@media (min-width: 640px){
  .cut-grid{ grid-template-columns: 1fr 1fr; gap: 22px; }
}
@media (min-width: 1024px){
  .cuts{ padding: 140px var(--gutter); }
  .cut-grid{ grid-template-columns: repeat(3, 1fr); gap: 28px; }
}

/* ============================================================
   COURSE
   ============================================================ */
.course{
  padding: 64px var(--gutter);
  background: var(--paper);
}
.course-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; gap: 40px;
  grid-template-columns: 1fr;
}
.course-card{
  border: 1px solid var(--line);
  background: var(--paper-2);
  padding: 28px 24px 32px;
  position: relative;
  display: grid; gap: 20px;
}
.course-card.featured{
  background: var(--ai);
  color: var(--paper);
  border-color: var(--ai);
}
.course-card.featured .course-head{ border-bottom-color: rgba(242,237,224,.22); }
.course-card.featured .course-en,
.course-card.featured .price-no,
.course-card.featured .course-item-mark{ color: var(--tare-warm); }
.course-card.featured .course-name{ color: var(--paper); }
.course-card.featured .course-item{ border-bottom-color: rgba(242,237,224,.14); }
.course-card.featured .course-item .jp{ color: var(--paper); }
.course-card.featured .course-item .en{ color: rgba(242,237,224,.6); }
.course-card.featured .course-foot{ border-top-color: rgba(242,237,224,.18); }
.course-head{
  display: flex; align-items: flex-end; justify-content: space-between; gap: 12px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.course-en{
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: .4em;
  color: var(--tare);
  display: block;
  margin-bottom: 10px;
}
.course-name{
  font-family: var(--serif-jp);
  font-weight: 500;
  font-size: 38px;
  letter-spacing: .15em;
  color: var(--ai);
  line-height: 1;
}
.course-price{
  text-align: right;
}
.course-price .price{
  font-family: var(--serif-en);
  font-size: 29px;
  letter-spacing: .04em;
  color: inherit;
}
.course-price .price .yen{ font-family: var(--serif-jp); font-size: .65em; margin-right: 2px; vertical-align: 1px; }
.course-price .tax{
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .28em;
  color: var(--ai-mute);
  margin-top: 4px;
}
.course-card.featured .course-price .tax{ color: rgba(242,237,224,.6); }

.course-tag{
  position: absolute; top: -1px; right: 18px;
  background: var(--tare);
  color: var(--paper);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .3em;
  padding: 5px 10px;
}
.course-list{
  display: grid;
}
.course-item{
  display: grid; grid-template-columns: auto 1fr auto; gap: 12px;
  align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 14px;
}
.course-item:last-child{ border-bottom: 0; }
.course-item-mark{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .2em;
  color: var(--tare);
  min-width: 22px;
}
.course-item .jp{
  font-family: var(--serif-jp);
  font-size: 15px;
  color: var(--ai);
  letter-spacing: .08em;
}
.course-item .en{
  font-family: var(--serif-en);
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--ai-mute);
  text-align: right;
}
.course-foot{
  padding-top: 18px;
  border-top: 1px solid var(--line);
  display: grid; gap: 8px;
  font-family: var(--serif-jp);
  font-size: 14px;
  color: var(--ai-2);
}
.course-card.featured .course-foot{ color: rgba(242,237,224,.82); }
.course-foot .row{
  display: flex; justify-content: space-between;
  gap: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--ai-mute);
}
.course-card.featured .course-foot .row{ color: rgba(242,237,224,.65); }
.course-foot .row strong{
  font-family: var(--serif-jp);
  font-weight: 500;
  color: var(--ai);
  letter-spacing: .12em;
}
.course-card.featured .course-foot .row strong{ color: var(--paper); }

@media (min-width: 880px){
  .course{ padding: 140px var(--gutter); }
  .course-grid{ grid-template-columns: repeat(3, 1fr); gap: 28px; align-items: start; }
  .course-card{ padding: 32px 28px 36px; }
}

/* ============================================================
   PAIRING
   ============================================================ */
.pairing{
  background: var(--paper-2);
  padding: 64px var(--gutter);
  position: relative;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.pairing-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; gap: 40px;
  grid-template-columns: 1fr;
}
.pair{
  display: grid; gap: 18px;
}
.pair .ph{ aspect-ratio: 5/6; }
.pair .head{
  display: flex; align-items: baseline; gap: 14px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}
.pair .jp{
  font-family: var(--serif-jp);
  font-size: 25px;
  letter-spacing: .14em;
  color: var(--ai);
  font-weight: 500;
}
.pair .en{
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: .38em;
  color: var(--tare);
}
.pair .body{
  font-family: var(--serif-jp);
  font-size: 16px;
  line-height: 1.95;
  color: var(--ai-2);
}
.pair-list{ display: grid; gap: 4px; margin-top: 6px; }
.pair-list li{
  display: grid; grid-template-columns: 1fr auto; align-items: baseline; gap: 10px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 14px;
}
.pair-list .name{ font-family: var(--serif-jp); color: var(--ai); }
.pair-list .price{ font-family: var(--serif-en); color: var(--ai-2); font-size: 14px; }

@media (min-width: 880px){
  .pairing-grid{ grid-template-columns: repeat(3, 1fr); gap: 40px; }
  .pairing{ padding: 140px var(--gutter); }
}

/* ============================================================
   CHEF
   ============================================================ */
.chef{
  padding: 64px var(--gutter);
  background: var(--paper);
}
.chef-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; gap: 32px;
  grid-template-columns: 1fr;
  align-items: start;
}
.chef-figure .ph{ aspect-ratio: 4/5; }
.chef-info{ display: grid; gap: 22px; }
.chef-name{
  font-family: var(--serif-jp);
  font-weight: 500;
  font-size: clamp(28px, 6vw, 44px);
  letter-spacing: .15em;
  color: var(--ai);
  line-height: 1.3;
}
.chef-name small{
  display: block;
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: .4em;
  color: var(--tare);
  margin-bottom: 10px;
}
.chef-bio{
  font-family: var(--serif-jp);
  font-size: 17px;
  line-height: 1.95;
  color: var(--ai-2);
}
.chef-bio p + p{ margin-top: 1.2em; }
.chef-cv{ display: grid; gap: 0; border-top: 1px solid var(--line); }
.chef-cv li{
  display: grid; grid-template-columns: 80px 1fr; gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
  font-size: 15px;
}
.chef-cv .yr{ font-family: var(--mono); color: var(--tare); letter-spacing: .22em; font-size: 12px; padding-top: 2px;}
.chef-cv .ev{ font-family: var(--serif-jp); color: var(--ai); }
.chef-quote{
  font-family: var(--serif-jp);
  font-size: 19px;
  line-height: 2;
  color: var(--ai);
  border-left: 2px solid var(--tare);
  padding-left: 18px;
  letter-spacing: .12em;
}

@media (min-width: 880px){
  .chef{ padding: 140px var(--gutter); }
  .chef-grid{ grid-template-columns: .9fr 1.1fr; gap: 64px; }
}

/* ============================================================
   GALLERY (interior)
   ============================================================ */
.gallery{
  padding: 64px var(--gutter);
  background: var(--paper);
  border-top: 1px solid var(--line);
}
.gal-single{
  max-width: var(--maxw); margin: 0 auto;
}
.gal-main{
  aspect-ratio: 16/7;
}
@media (max-width: 639px){
  .gal-main{ aspect-ratio: 4/3; }
}
@media (min-width: 880px){
  .gallery{ padding: 140px var(--gutter); }
}

/* ============================================================
   ROOMS
   ============================================================ */
.rooms{
  padding: 64px var(--gutter);
  background: var(--paper-2);
}
.rooms-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; gap: 32px;
  grid-template-columns: 1fr;
}
.room{ display: grid; gap: 16px; }
.room .ph{ aspect-ratio: 5/4; }
.room .head{
  display: flex; align-items: baseline; justify-content: space-between;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}
.room .jp{
  font-family: var(--serif-jp);
  font-size: 25px;
  letter-spacing: .15em;
  color: var(--ai);
  font-weight: 500;
}
.room .jp small{
  display: block;
  font-family: var(--serif-en);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--tare);
  margin-top: 4px;
}
.room .cap{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .25em;
  color: var(--ai-mute);
}
.room-body{
  font-family: var(--serif-jp);
  font-size: 16px;
  line-height: 1.95;
  color: var(--ai-2);
}
.room-specs{ display: grid; grid-template-columns: 1fr 1fr; gap: 6px 14px; margin-top: 6px; padding-top: 12px; border-top: 1px solid var(--line); }
.room-specs dt{ font-family: var(--mono); font-size: 11px; letter-spacing: .25em; color: var(--ai-mute); }
.room-specs dd{ margin: 0; font-family: var(--serif-jp); font-size: 15px; color: var(--ai); }
@media (min-width: 880px){
  .rooms{ padding: 140px var(--gutter); }
  .rooms-grid{ grid-template-columns: repeat(3, 1fr); gap: 32px; }
}

/* ============================================================
   ACCESS
   ============================================================ */
.access{
  padding: 64px var(--gutter);
  background: var(--paper);
  border-top: 1px solid var(--line);
}
.access-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; gap: 32px;
  grid-template-columns: 1fr;
}
.access-info{ display: grid; gap: 20px; }
.access-row{
  display: grid; grid-template-columns: 96px 1fr; gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.access-row dt{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .3em;
  color: var(--tare);
}
.access-row dd{
  margin: 0;
  font-family: var(--serif-jp);
  font-size: 17px;
  color: var(--ai);
  line-height: 1.85;
}
.access-row .en{
  display: block;
  font-family: var(--serif-en);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--ai-mute);
  margin-top: 4px;
}
.map-figure .ph{ aspect-ratio: 4/5; }
@media (min-width: 880px){
  .access{ padding: 140px var(--gutter); }
  .access-grid{ grid-template-columns: 1fr 1.05fr; gap: 56px; align-items: start; }
}

/* ============================================================
   FAQ
   ============================================================ */
.faq{
  padding: 64px var(--gutter);
  background: var(--paper-2);
}
.faq-list{
  max-width: 860px;
  margin: 0 auto;
  display: grid; gap: 4px;
}
.faq-item{
  border-bottom: 1px solid var(--line);
  padding: 16px 0;
}
.faq-item summary{
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 14px;
  padding: 4px 0;
}
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-q-mark{
  font-family: var(--serif-jp);
  font-weight: 500;
  color: var(--tare);
  font-size: 20px;
  width: 24px;
}
.faq-q{
  font-family: var(--serif-jp);
  font-size: 17px;
  color: var(--ai);
  letter-spacing: .08em;
  line-height: 1.8;
}
.faq-cross{
  width: 18px; height: 18px;
  position: relative; flex-shrink: 0;
}
.faq-cross::before, .faq-cross::after{
  content:""; position: absolute; background: var(--ai);
}
.faq-cross::before{ left: 0; right: 0; top: 50%; height: 1px; }
.faq-cross::after{ top: 0; bottom: 0; left: 50%; width: 1px; transition: transform .3s; }
.faq-item[open] .faq-cross::after{ transform: scaleY(0); }
.faq-a{
  display: grid; grid-template-columns: 24px 1fr;
  gap: 14px;
  padding: 12px 0 8px;
  font-family: var(--serif-jp);
  font-size: 16px;
  line-height: 1.95;
  color: var(--ai-2);
}
.faq-a-mark{
  font-family: var(--serif-jp);
  font-weight: 500;
  color: var(--ai);
  font-size: 20px;
}
@media (min-width: 880px){
  .faq{ padding: 140px var(--gutter); }
}

/* ============================================================
   CTA BLOCK
   ============================================================ */
.cta{
  padding: 64px var(--gutter);
  background: var(--ai);
  color: var(--paper);
  position: relative;
}
.cta-inner{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; gap: 28px;
  align-items: end;
}
.cta-title{
  font-family: var(--serif-jp);
  font-weight: 500;
  font-size: clamp(28px, 6.5vw, 56px);
  letter-spacing: .15em;
  line-height: 1.4;
  color: var(--paper);
}
.cta-title small{
  display: block;
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: .42em;
  color: var(--tare-warm);
  margin-bottom: 14px;
}
.cta-sub{
  font-family: var(--serif-jp);
  font-size: 17px;
  line-height: 1.95;
  color: rgba(242,237,224,.82);
  max-width: 32em;
}
.cta-actions{ display: flex; gap: 14px; flex-wrap: wrap; }
.cta .btn-primary{ background: var(--tare); border-color: var(--tare); }
.cta .btn-primary:hover{ background: var(--paper); color: var(--ai); border-color: var(--paper); }
.cta .btn-ghost{ color: var(--paper); border-color: var(--paper); }
.cta .btn-ghost:hover{ background: var(--paper); color: var(--ai); }
.cta-phone{
  font-family: var(--serif-en);
  font-size: 34px;
  letter-spacing: .14em;
  color: var(--paper);
  display: block;
  margin-top: 6px;
}
.cta-phone small{
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .3em;
  color: rgba(242,237,224,.6);
  margin-bottom: 6px;
}
@media (min-width: 880px){
  .cta{ padding: 140px var(--gutter); }
  .cta-inner{ grid-template-columns: 1.2fr .9fr; gap: 56px; }
}

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  padding: 56px var(--gutter) 36px;
  background: var(--sumi);
  color: var(--paper);
}
.foot-inner{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; gap: 40px;
  grid-template-columns: 1fr;
}
.foot-brand{ display: grid; gap: 14px; }
.foot-brand .mark{
  font-family: var(--serif-jp);
  font-weight: 600;
  font-size: 25px;
  letter-spacing: .3em;
}
.foot-brand .mark .accent{ color: var(--tare-warm); }
.foot-brand .romaji{
  font-family: var(--serif-en);
  font-size: 11px;
  letter-spacing: .42em;
  color: rgba(242,237,224,.6);
}
.foot-brand .desc{
  font-family: var(--serif-jp);
  font-size: 14px;
  line-height: 2;
  color: rgba(242,237,224,.7);
  max-width: 28em;
}
.foot-cols{
  display: grid; gap: 28px;
  grid-template-columns: 1fr 1fr;
}
.foot-col h3{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--tare-warm);
  margin: 0 0 14px;
  text-transform: uppercase;
  font-weight: 500;
}
.foot-col ul{ display: grid; gap: 8px; font-size: 14px; }
.foot-col li a{
  font-family: var(--serif-jp);
  color: rgba(242,237,224,.78);
  letter-spacing: .12em;
}
.foot-col li a:hover{ color: var(--tare-warm); }
.foot-bottom{
  margin-top: 40px;
  padding-top: 18px;
  border-top: 1px solid rgba(242,237,224,.15);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .25em;
  color: rgba(242,237,224,.55);
}
.foot-bottom a:hover{ color: var(--tare-warm); }

@media (min-width: 880px){
  footer{ padding: 96px var(--gutter) 40px; }
  .foot-inner{ grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 56px; }
  .foot-cols{ display: contents; }
  .foot-col{ display: block; }
}

/* ============================================================
   MISC ANIMATIONS
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity: 0; transform: translateY(14px); transition: opacity .9s ease, transform .9s ease; }
  .reveal.in{ opacity: 1; transform: none; }
}

/* generated photography */
.ph.has-image{
  background: var(--ai);
}
.ph.has-image::after{
  display: none;
}
.ph.has-image img{
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(.94) contrast(1.05);
  transform: scale(1.01);
}
.ph.has-image::before{
  z-index: 1;
  border-color: rgba(242,237,224,.18);
}
.ph.has-image .corner,
.ph.has-image .cap{
  display: none;
}
.hero-figure .ph.has-image img,
.chef-figure .ph.has-image img,
.map-figure .ph.has-image img,
.pair .ph.has-image img{
  object-position: center;
}

/* selection */
::selection{ background: var(--ai); color: var(--paper); }

/* ============================================================
   可読性チューニング（2026-06-13 追記）
   ・本文を一回り大きく・太く・濃く（線が細い／小さいを解消）
   ・9〜10pxの装飾ラベルを12px以上へ
   ・日本語を等幅／欧文書体から読みやすいゴシックへ
   ============================================================ */

/* 本文ベース */
body{ font-size: 18px; line-height: 1.9; }

/* 明朝の本文：太さ500・濃いインク・サイズ確保 */
.hero-sub,
.prologue-body,
.pillar-body,
.section-head .lede,
.chef-bio,
.pair .body,
.room-body,
.faq-a,
.faq-q,
.access-row dd{
  font-weight: 500;
  color: #1f3456;
  font-size: 18px;
  line-height: 1.95;
}
.prologue-tate,
.hero-tate{ font-weight: 500; }
.chef-quote{ font-weight: 500; color: var(--ai); }

/* 紺地セクションの本文：白寄りで濃く（コントラスト確保） */
.cut-desc{ font-weight: 500; color: rgba(244,238,224,.94); font-size: 17px; line-height: 1.9; }
.cuts .section-head .lede{ color: rgba(244,238,224,.92); }
.cta-sub{ font-weight: 500; color: rgba(244,238,224,.92); font-size: 18px; }

/* リスト・スペック系の小さめ本文を底上げ */
.course-item .jp{ font-size: 17px; font-weight: 500; }
.course-item .en{ font-size: 14px; }
.course-foot{ font-size: 16px; color: #1f3456; }
.course-card.featured .course-foot{ color: rgba(244,238,224,.9); }
.pair-list li{ font-size: 16px; }
.pair-list .name{ font-weight: 500; }
.pair-list .price{ font-family: var(--sans-jp); font-size: 15px; letter-spacing: .04em; }
.room-specs dd{ font-size: 16px; font-weight: 500; }
.pillar-meta .v{ font-size: 16px; font-weight: 500; }
.cut-meta dd{ font-size: 15px; }
.hero-side .row dd{ font-size: 16px; font-weight: 500; }
.chef-cv li{ font-size: 16px; }
.chef-cv .ev{ font-weight: 500; }

/* 装飾ラベル：日本語はゴシック・太字・12px以上へ統一 */
.eyebrow,
.pillar-no,
.cut-tier,
.course-tag,
.course-price .tax,
.cut-meta dt,
.pillar-meta .k,
.room-specs dt,
.hero-side .row dt,
.access-row dt,
.cta-phone small,
.foot-col h3,
.room .cap,
.course-foot .row{
  font-family: var(--sans-jp);
  font-weight: 600;
  letter-spacing: .12em;
  font-size: 14px;
}
.eyebrow::before{ width: 24px; }

/* キャプション・メタ（やや軽め） */
.prologue-sign,
.hero-meta,
.hero-figure-caption{
  font-family: var(--sans-jp);
  font-weight: 500;
  letter-spacing: .1em;
  font-size: 14px;
}

/* 紺地上のラベルはコントラストを上げる */
.cut-meta dt{ color: rgba(244,238,224,.82); }
.course-card.featured .course-price .tax{ color: rgba(244,238,224,.78); }

/* 和文を欧文書体に流用していた箇所を和文書体へ */
.course-en{ font-family: var(--serif-jp); font-weight: 500; font-size: 15px; letter-spacing: .16em; }
.brand .romaji{ font-family: var(--sans-jp); font-size: 14px; letter-spacing: .2em; color: var(--ai-mute); font-weight: 500; }
.foot-brand .romaji{ font-family: var(--sans-jp); font-size: 14px; letter-spacing: .2em; }

/* ラテン数字ラベルは等幅のまま底上げ */
.cut-no,
.course-item-mark,
.chef-cv .yr{ font-size: 14px; }

/* ナビ・ボタンの文字を少し大きく */
.nav-links{ font-size: 15px; }
.nav-cta{ font-size: 14px; }
.btn-primary,
.btn-ghost,
.drawer-cta{ font-size: 15px; }

/* フッター */
.foot-brand .desc{ font-size: 16px; color: rgba(242,237,224,.82); line-height: 1.95; }
.foot-col ul{ font-size: 16px; }
.foot-col li a{ color: rgba(242,237,224,.85); }
.foot-bottom{ font-size: 14px; color: rgba(242,237,224,.72); }

/* アクセス地図（Googleマップ埋め込み） */
.map-figure{ margin: 0; }
.map-embed{
  position: relative;
  aspect-ratio: 4/5;
  border: 1px solid var(--line);
  overflow: hidden;
  background: var(--paper-2);
}
.map-embed iframe{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
  filter: grayscale(.1) contrast(1.02);
}
@media (max-width: 639px){
  .map-embed{ aspect-ratio: 4/3; }
}

/* ============================================================
   MULTI-PAGE COMPONENTS（複数ページ化 2026-06-14 追記）
   既存の鳥燈デザイン（藍×銅×和紙）に揃えた、回遊用の追加部品。
   ============================================================ */

/* --- SUBHERO（下層ページ見出し） --- */
.subhero{
  padding: 38px var(--gutter) 34px;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
  position: relative;
}
.subhero-inner{ max-width: var(--maxw); margin: 0 auto; display: grid; gap: 16px; }
.crumb{
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-family: var(--sans-jp); font-weight: 500;
  font-size: 14px; letter-spacing: .1em; color: var(--ai-mute);
}
.crumb a{ color: var(--ai-mute); transition: color .3s; }
.crumb a:hover{ color: var(--tare); }
.crumb .sep{ color: var(--paper-deep); }
.crumb .here{ color: var(--ai); }
.subhero h1{
  font-family: var(--serif-jp); font-weight: 500;
  font-size: clamp(30px, 8vw, 54px); letter-spacing: .1em;
  color: var(--ai); line-height: 1.24; margin: 0;
}
.subhero h1 .en{
  display: block; font-family: var(--serif-en);
  font-size: 12px; letter-spacing: .42em; color: var(--tare);
  margin-bottom: 12px; font-weight: 400;
}
.subhero .lead{
  font-family: var(--serif-jp); font-weight: 500;
  font-size: 18px; line-height: 1.95; color: #1f3456; max-width: 46em;
}
@media (min-width: 880px){
  .subhero{ padding: 72px var(--gutter) 56px; }
}

/* --- NEWS BAR（トップのお知らせ） --- */
.news-bar{
  background: var(--ai); color: var(--paper);
  padding: 14px var(--gutter); border-bottom: 1px solid var(--line);
}
.news-bar-inner{
  max-width: var(--maxw); margin: 0 auto;
  display: flex; align-items: center; gap: 14px 18px; flex-wrap: wrap;
}
.news-tag{
  font-family: var(--sans-jp); font-weight: 600;
  font-size: 12px; letter-spacing: .2em; color: var(--tare-warm);
  border: 1px solid rgba(242,237,224,.3); padding: 5px 11px; flex-shrink: 0;
}
.news-line{ display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.news-line .date{
  font-family: var(--mono); font-size: 12px; letter-spacing: .1em;
  color: rgba(242,237,224,.6);
}
.news-line .ttl{
  font-family: var(--serif-jp); font-weight: 500; font-size: 16px;
  color: rgba(242,237,224,.92); letter-spacing: .04em;
}

/* --- MORE LINK（ダイジェスト用「詳しく」） --- */
.more-wrap{ margin-top: 30px; }
.more-wrap.center{ text-align: center; }
.more-link{
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--sans-jp); font-weight: 600;
  font-size: 15px; letter-spacing: .16em; color: var(--ai);
  border-bottom: 1px solid var(--tare); padding-bottom: 6px;
  transition: color .3s, border-color .3s;
}
.more-link:hover{ color: var(--tare); }
.more-link .arr{ font-family: var(--serif-en); font-size: 17px; }
.more-link.light{ color: var(--paper); border-color: var(--tare-warm); }
.more-link.light:hover{ color: var(--tare-warm); }

/* --- SIGNATURE（トップの名物ダイジェスト） --- */
.signature{
  padding: 64px var(--gutter); background: var(--paper-2);
  border-bottom: 1px solid var(--line);
}
.signature-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: 28px; align-items: center;
}
.signature-figure{
  position: relative; overflow: hidden; border: 1px solid var(--line);
  background: var(--ai); aspect-ratio: 4/5;
}
.signature-figure img{
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; filter: saturate(.94) contrast(1.05);
}
.signature-meta{ display: grid; gap: 18px; }
.signature-title{
  font-family: var(--serif-jp); font-weight: 500;
  font-size: clamp(28px, 7vw, 46px); letter-spacing: .08em;
  color: var(--ai); line-height: 1.26;
}
.signature-title small{
  display: block; font-family: var(--serif-en);
  font-size: 14px; letter-spacing: .3em; color: var(--tare);
  margin-top: 12px; font-weight: 400;
}
.signature-body{
  font-family: var(--serif-jp); font-weight: 500;
  font-size: 18px; line-height: 1.95; color: #1f3456;
}
.signature-price{
  display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap;
  border-top: 1px solid var(--ai); border-bottom: 1px solid var(--line);
  padding: 16px 0;
}
.signature-price .lbl{
  font-family: var(--sans-jp); font-weight: 600;
  font-size: 14px; letter-spacing: .12em; color: var(--ai-mute);
}
.signature-price .price{
  font-family: var(--serif-en); font-size: 32px; color: var(--ai);
}
.signature-price .price .yen{ font-family: var(--serif-jp); font-size: .62em; margin-right: 2px; }
.signature-price .price small{
  font-family: var(--sans-jp); font-weight: 500; font-size: 14px;
  letter-spacing: .06em; color: var(--ai-mute); margin-left: 6px;
}
@media (min-width: 880px){
  .signature{ padding: 120px var(--gutter); }
  .signature-grid{ grid-template-columns: 1fr 1fr; gap: 64px; }
  .signature-figure{ aspect-ratio: 5/6; }
}

/* --- REASONS（トップのこだわりダイジェスト・藍地） --- */
.reasons{
  padding: 64px var(--gutter); background: var(--ai); color: var(--paper);
  border-bottom: 1px solid var(--line);
}
.reasons .section-head h2{ color: var(--paper); }
.reasons .section-head .lede{ color: rgba(244,238,224,.9); }
.reasons-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: 0;
  border-top: 1px solid rgba(242,237,224,.22);
}
.reason{
  display: grid; grid-template-columns: auto 1fr; gap: 18px;
  padding: 24px 0; border-bottom: 1px solid rgba(242,237,224,.16);
}
.reason .n{
  font-family: var(--serif-en); font-size: 15px; letter-spacing: .2em;
  color: var(--tare-warm); padding-top: 3px;
}
.reason h3{
  font-family: var(--serif-jp); font-weight: 500; font-size: 21px;
  letter-spacing: .08em; color: var(--paper); margin: 0 0 8px;
}
.reason p{
  font-family: var(--serif-jp); font-weight: 500; font-size: 16px;
  line-height: 1.9; color: rgba(244,238,224,.85); margin: 0;
}
@media (min-width: 880px){
  .reasons{ padding: 120px var(--gutter); }
  .reasons-grid{ grid-template-columns: repeat(3, 1fr); gap: 40px; border-top: 0; }
  .reason{ display: block; border-bottom: 0; border-top: 1px solid rgba(242,237,224,.3); padding: 24px 0 0; }
  .reason .n{ display: block; margin-bottom: 14px; padding-top: 0; }
}

/* --- GATEWAY（トップから各ページへの導線カード） --- */
.gateway{ padding: 64px var(--gutter); background: var(--paper); }
.gateway-grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: 14px;
}
.gw-card{
  position: relative; display: block; overflow: hidden;
  border: 1px solid var(--line); background: var(--ai); aspect-ratio: 16/10;
}
.gw-card img{
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; transition: transform .6s ease;
  filter: saturate(.94) contrast(1.05);
}
.gw-card:hover img{ transform: scale(1.05); }
.gw-card::after{
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,26,46,.04) 28%, rgba(15,26,46,.82));
}
.gw-card .label{
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  padding: 18px 20px; display: flex; align-items: flex-end;
  justify-content: space-between; gap: 12px;
}
.gw-card .label .t{
  font-family: var(--serif-jp); font-weight: 500; font-size: 23px;
  letter-spacing: .08em; color: var(--paper); text-shadow: 0 1px 6px rgba(0,0,0,.55);
}
.gw-card .label .t .s{
  display: block; font-family: var(--sans-jp); font-weight: 400;
  font-size: 14px; color: rgba(242,237,224,.85); margin-top: 6px;
  letter-spacing: .04em; text-shadow: 0 1px 5px rgba(0,0,0,.5);
}
.gw-card .label .arr{ font-family: var(--serif-en); font-size: 18px; color: var(--paper); flex-shrink: 0; }
@media (min-width: 760px){
  .gateway-grid{ grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .gw-card{ aspect-ratio: 16/9; }
}
@media (min-width: 880px){ .gateway{ padding: 120px var(--gutter); } }

/* --- GALLERY GRID（店内ページの複数枚ギャラリー） --- */
.gal-grid{
  max-width: var(--maxw); margin: 24px auto 0;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
}
.gal-cell{
  position: relative; overflow: hidden; border: 1px solid var(--line);
  background: var(--ai); aspect-ratio: 4/3;
}
.gal-cell img{
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; filter: saturate(.94) contrast(1.05);
  transition: transform .6s ease;
}
.gal-cell:hover img{ transform: scale(1.04); }
.gal-cell.wide{ grid-column: 1 / -1; aspect-ratio: 16/7; }
@media (max-width: 639px){ .gal-cell.wide{ aspect-ratio: 4/3; } }
@media (min-width: 880px){
  .gal-grid{ grid-template-columns: repeat(3, 1fr); gap: 16px; }
  .gal-cell.wide{ aspect-ratio: 21/9; }
}

/* --- PAGENAV（ページ下部の次ページ導線） --- */
.pagenav{
  padding: 52px var(--gutter) 76px; background: var(--paper-2);
  border-top: 1px solid var(--line);
}
.pagenav-inner{ max-width: var(--maxw); margin: 0 auto; }
.pagenav-label{
  font-family: var(--sans-jp); font-weight: 600; font-size: 12px;
  letter-spacing: .28em; color: var(--tare); margin-bottom: 18px;
  text-transform: uppercase;
}
.pagenav-grid{
  display: grid; grid-template-columns: 1fr; gap: 0;
  border-top: 1px solid var(--ai);
}
.pagenav-grid a{
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding: 18px 0; border-bottom: 1px solid var(--line);
  transition: color .3s;
}
.pagenav-grid a:hover{ color: var(--tare); }
.pagenav-grid .pn-k{
  display: block; font-family: var(--sans-jp); font-weight: 600;
  font-size: 12px; letter-spacing: .2em; color: var(--ai-mute); margin-bottom: 5px;
}
.pagenav-grid .pn-t{
  font-family: var(--serif-jp); font-weight: 500; font-size: 20px;
  letter-spacing: .08em; color: var(--ai);
}
.pagenav-grid a:hover .pn-t{ color: var(--tare); }
.pagenav-grid .arr{ font-family: var(--serif-en); font-size: 18px; color: var(--tare); }
@media (min-width: 880px){
  .pagenav-grid{ grid-template-columns: repeat(3, 1fr); gap: 32px; border-top: 0; }
  .pagenav-grid a{ border-bottom: 0; border-top: 1px solid var(--ai); padding: 20px 0 0; align-items: flex-start; }
}

/* --- NAV アクティブ状態（複数ページ用） --- */
.nav-links a.is-active{ color: var(--tare); }
.nav-links a.is-active::after{ transform: scaleX(1); }
.drawer ul a.is-active{ color: var(--tare); }
.drawer ul a.is-active .en{ color: var(--tare); }
