/* =========================================================================
   IRODORI izakaya — 居酒屋「藍灯 -aitomo-」Casual-Local-Warmth テーマ
   prefix: .iza-* (200+ 独自セレクタ目標)
   配色: インディゴ夜空 #1B2D5C × 行灯黄 #F2C75C × 朱差し #C13F2E × 麻クリーム #F5EFE2
        (夜空藍 + 行灯黄 = 既存 29 件 + 実在 6 サイトで 0 件 = 完全空白地帯)
   タイポ: Shippori Mincho B1 + Noto Sans JP + Poppins
   Preloader: L28 提灯 3 連灯シーケンス (新・業界 6/6 不採用の空白地帯)
   Hero: AA 横スク提灯バナー + 縦書きキャッチ + 営業時間バー + 直予約 4 タブ
   2026-04-28
   ========================================================================= */

/* =========================================================================
   1. Google Fonts Import
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@400;500;600;700;800&family=Noto+Sans+JP:wght@300;400;500;700&family=Poppins:wght@300;400;500;600;700&display=swap');

/* =========================================================================
   2. CSS Custom Properties (--iza-*)
   ========================================================================= */

:root {
  /* --- 夜空藍パレット --- */
  --iza-night:        #1B2D5C;
  --iza-night-deep:   #0F1C3D;
  --iza-night-soft:   #2A3F70;
  --iza-night-mid:    #1E325F;
  --iza-night-glass:  rgba(27, 45, 92, 0.88);

  /* --- 行灯黄 --- */
  --iza-lamp:         #F2C75C;
  --iza-lamp-deep:    #D4A830;
  --iza-lamp-glow:    #FFE08A;
  --iza-lamp-pale:    rgba(242, 199, 92, 0.18);
  --iza-lamp-soft:    rgba(242, 199, 92, 0.08);

  /* --- 朱差し --- */
  --iza-vermilion:    #C13F2E;
  --iza-vermilion-deep:#9B2E20;
  --iza-vermilion-pale:rgba(193, 63, 46, 0.15);

  /* --- 麻クリーム (紙系) --- */
  --iza-paper:        #F5EFE2;
  --iza-paper-warm:   #F9F2DD;
  --iza-paper-deep:   #EBE0CC;

  /* --- LINE グリーン --- */
  --iza-line-green:   #06C755;
  --iza-line-green-d: #04A344;

  /* --- テキスト / 墨 --- */
  --iza-ink:          #1A1A1A;
  --iza-text:         #2C2A26;
  --iza-text-sub:     #5C5851;
  --iza-text-mute:    #8C8680;
  --iza-text-on-dark: #F5EFE2;
  --iza-text-on-dark-sub: rgba(245, 239, 226, 0.72);

  /* --- 罫線 --- */
  --iza-line:         #D8D2C4;
  --iza-line-soft:    #EBE5D7;

  /* --- 黒板 --- */
  --iza-board-bg:     #1C2218;
  --iza-board-bg-alt: #232B1E;
  --iza-chalk-white:  #F0ECE0;
  --iza-chalk-yellow: #F5D76E;
  --iza-chalk-pink:   #F48A8A;
  --iza-chalk-green:  #8BD48B;

  /* --- フォント --- */
  --iza-font-mincho:  'Shippori Mincho B1', 'Noto Serif JP', 'Yu Mincho', serif;
  --iza-font-gothic:  'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  --iza-font-num:     'Poppins', sans-serif;

  /* --- タイプスケール --- */
  --iza-fs-body:       16px;
  --iza-lh-body:       1.9;
  --iza-ls-body:       0.06em;
  --iza-ls-heading:    0.08em;
  --iza-ls-wide:       0.16em;

  /* --- レイアウト --- */
  --iza-container:     1200px;
  --iza-container-narrow: 860px;
  --iza-px:            clamp(20px, 5vw, 60px);
  --iza-header-h:      72px;

  /* --- ラジアス --- */
  --iza-r-sm:  3px;
  --iza-r-md:  8px;
  --iza-r-lg:  16px;
  --iza-r-xl:  28px;
  --iza-r-pill:9999px;

  /* --- イージング --- */
  --iza-ease:        cubic-bezier(0.4, 0, 0.2, 1);
  --iza-ease-soft:   cubic-bezier(0.16, 1, 0.3, 1);
  --iza-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --iza-dur:         0.5s;
  --iza-dur-fast:    0.25s;
  --iza-dur-slow:    0.9s;

  /* --- 影 --- */
  --iza-shadow-card:  0 12px 36px rgba(15, 28, 61, 0.3);
  --iza-shadow-float: 0 24px 64px rgba(15, 28, 61, 0.4);
  --iza-glow-lamp:    0 0 28px rgba(242, 199, 92, 0.45);
  --iza-glow-verm:    0 0 20px rgba(193, 63, 46, 0.35);
}

/* =========================================================================
   3. Reset / Base
   ========================================================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--iza-header-h) + 8px);
}

body.iza-body {
  font-family:            var(--iza-font-gothic);
  font-size:              var(--iza-fs-body);
  line-height:            var(--iza-lh-body);
  letter-spacing:         var(--iza-ls-body);
  color:                  var(--iza-text);
  background:             var(--iza-paper);
  -webkit-font-smoothing: antialiased;
  text-rendering:         optimizeLegibility;
  overflow-x:             hidden;
}

img { max-width: 100%; height: auto; display: block; }
a   { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; padding: 0; }
ul, ol { list-style: none; }
input, select, textarea { font: inherit; }

/* =========================================================================
   4. Preloader L28 — 提灯 3 連灯シーケンス (業界 6/6 で不採用 = 空白地帯)
   ========================================================================= */

.iza-loader {
  position:   fixed;
  inset:      0;
  z-index:    9999;
  background: var(--iza-night-deep);
  display:    flex;
  flex-direction: column;
  align-items:    center;
  justify-content:center;
  gap:        clamp(24px, 4vh, 48px);
  transition: opacity 0.7s var(--iza-ease), visibility 0.7s;
}

.iza-loader.is-hidden {
  opacity:    0;
  visibility: hidden;
  pointer-events: none;
}

.iza-loader__lanterns {
  display: flex;
  align-items: flex-end;
  gap:    32px;
}

/* 提灯本体 */
.iza-loader__lantern {
  position:   relative;
  width:      44px;
  height:     64px;
  opacity:    0;
  transform:  translateY(8px);
  transition: opacity 0.5s var(--iza-ease), transform 0.5s var(--iza-ease);
}

.iza-loader__lantern.is-lit {
  opacity:   1;
  transform: translateY(0);
}

/* 提灯本体 SVG shape */
.iza-loader__lantern-body {
  width:  44px;
  height: 56px;
  background: var(--iza-vermilion);
  border-radius: 50% 50% 48% 48% / 40% 40% 50% 50%;
  position: relative;
  overflow: hidden;
  box-shadow: var(--iza-glow-verm);
  transition: box-shadow 0.6s var(--iza-ease);
}

.iza-loader__lantern.is-lit .iza-loader__lantern-body {
  box-shadow:
    var(--iza-glow-verm),
    0 0 48px rgba(242, 199, 92, 0.6),
    inset 0 -8px 20px rgba(242, 199, 92, 0.4);
}

/* 提灯内部グロー */
.iza-loader__lantern-glow {
  position: absolute;
  inset:    0;
  background: radial-gradient(
    ellipse 70% 60% at 50% 40%,
    rgba(255, 224, 138, 0.0) 0%,
    rgba(255, 224, 138, 0.0) 100%
  );
  transition: background 0.8s var(--iza-ease);
}

.iza-loader__lantern.is-lit .iza-loader__lantern-glow {
  background: radial-gradient(
    ellipse 70% 60% at 50% 40%,
    rgba(255, 224, 138, 0.75) 0%,
    rgba(242, 199, 92, 0.35) 60%,
    transparent 100%
  );
}

/* 提灯リング (上下) */
.iza-loader__lantern-body::before,
.iza-loader__lantern-body::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  height: 5px;
  background: rgba(159, 40, 24, 0.7);
}
.iza-loader__lantern-body::before { top:    10px; }
.iza-loader__lantern-body::after  { bottom: 10px; }

/* 提灯ひも (上) */
.iza-loader__lantern-string {
  width:  2px;
  height: 12px;
  background: rgba(245, 239, 226, 0.6);
  margin: 0 auto;
}

/* 提灯ひも (下・フリンジ) */
.iza-loader__lantern-fringe {
  width:  2px;
  height: 10px;
  background: rgba(245, 239, 226, 0.5);
  margin: 0 auto;
}

/* 「いらっしゃい」テキスト */
.iza-loader__text {
  font-family: var(--iza-font-mincho);
  font-size:   clamp(1.2rem, 3vw, 1.6rem);
  font-weight: 600;
  color:       var(--iza-lamp);
  letter-spacing: 0.32em;
  opacity:     0;
  transform:   translateY(12px);
  transition:  opacity 0.8s var(--iza-ease), transform 0.8s var(--iza-ease);
}

.iza-loader__text.is-visible {
  opacity:   1;
  transform: translateY(0);
}

/* 提灯揺れアニメ (lit 後) */
@keyframes iza-lantern-sway {
  0%, 100% { transform: rotate(-2deg); }
  50%       { transform: rotate(2deg); }
}

.iza-loader__lantern.is-lit {
  transform-origin: top center;
  animation: iza-lantern-sway 2.4s ease-in-out infinite;
}

/* =========================================================================
   5. Header (固定 / Tel + 予約 CTA + ハンバーガー)
   ========================================================================= */

.iza-header {
  position:   fixed;
  top:        0; left: 0; right: 0;
  z-index:    900;
  height:     var(--iza-header-h);
  background: var(--iza-night-deep);
  border-bottom: 1px solid rgba(242, 199, 92, 0.15);
  display:    flex;
  align-items:center;
  padding:    0 var(--iza-px);
  gap:        clamp(16px, 3vw, 40px);
  transition: background var(--iza-dur) var(--iza-ease),
              box-shadow var(--iza-dur) var(--iza-ease);
}

.iza-header.is-scrolled {
  background: rgba(15, 28, 61, 0.96);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* ロゴ */
.iza-header__logo {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  line-height: 1.1;
  text-decoration: none;
}

.iza-header__logo-ja {
  font-family:    var(--iza-font-mincho);
  font-size:      1.2rem;
  font-weight:    700;
  color:          var(--iza-lamp);
  letter-spacing: 0.12em;
}

.iza-header__logo-en {
  font-family:    var(--iza-font-num);
  font-size:      0.62rem;
  font-weight:    400;
  color:          var(--iza-text-on-dark-sub);
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

/* ナビ (デスクトップ) */
.iza-header__nav {
  flex:    1;
  display: flex;
  align-items: center;
  gap:    clamp(12px, 2vw, 28px);
}

.iza-header__nav-link {
  font-family:    var(--iza-font-gothic);
  font-size:      0.82rem;
  font-weight:    500;
  color:          var(--iza-text-on-dark-sub);
  letter-spacing: 0.08em;
  transition:     color var(--iza-dur-fast);
  position:       relative;
  white-space:    nowrap;
}

.iza-header__nav-link::after {
  content:    '';
  position:   absolute;
  bottom:     -4px; left: 0; right: 0;
  height:     1px;
  background: var(--iza-lamp);
  transform:  scaleX(0);
  transform-origin: left;
  transition: transform var(--iza-dur-fast) var(--iza-ease);
}

.iza-header__nav-link:hover,
.iza-header__nav-link.is-active {
  color: var(--iza-lamp);
}

.iza-header__nav-link:hover::after,
.iza-header__nav-link.is-active::after {
  transform: scaleX(1);
}

/* 電話番号 */
.iza-header__tel {
  display:     flex;
  align-items: center;
  gap:         6px;
  font-family: var(--iza-font-num);
  font-size:   1.0rem;
  font-weight: 600;
  color:       var(--iza-lamp);
  letter-spacing: 0.04em;
  text-decoration: none;
  flex-shrink: 0;
  transition:  color var(--iza-dur-fast);
}

.iza-header__tel:hover { color: var(--iza-lamp-glow); }

.iza-header__tel-icon {
  width:  18px;
  height: 18px;
  fill:   var(--iza-lamp);
  flex-shrink: 0;
}

/* 予約 CTA ボタン */
.iza-header__reserve-btn {
  display:         flex;
  align-items:     center;
  gap:             6px;
  padding:         9px 20px;
  background:      var(--iza-vermilion);
  color:           #fff;
  font-family:     var(--iza-font-gothic);
  font-size:       0.84rem;
  font-weight:     700;
  letter-spacing:  0.08em;
  border-radius:   var(--iza-r-pill);
  text-decoration: none;
  flex-shrink:     0;
  transition:      background var(--iza-dur-fast),
                   box-shadow var(--iza-dur-fast),
                   transform   var(--iza-dur-fast);
}

.iza-header__reserve-btn:hover {
  background:  var(--iza-vermilion-deep);
  box-shadow:  var(--iza-glow-verm);
  transform:   translateY(-1px);
}

/* ハンバーガー */
.iza-header__hamburger {
  display:        none;
  flex-direction: column;
  gap:            5px;
  padding:        6px;
  margin-left:    8px;
  cursor:         pointer;
}

.iza-header__hamburger span {
  display:    block;
  width:      22px;
  height:     2px;
  background: var(--iza-lamp);
  border-radius: 2px;
  transition: transform var(--iza-dur-fast) var(--iza-ease),
              opacity   var(--iza-dur-fast);
}

.iza-header__hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.iza-header__hamburger.is-open span:nth-child(2) { opacity: 0; }
.iza-header__hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* =========================================================================
   6. Drawer Menu (スマホ)
   ========================================================================= */

.iza-drawer {
  position:   fixed;
  inset:      0;
  z-index:    850;
  display:    grid;
  grid-template-columns: 1fr 72vw;
  pointer-events: none;
  visibility: hidden;
  transition: visibility 0s 0.4s;
}

.iza-drawer.is-open {
  pointer-events: all;
  visibility:     visible;
  transition:     visibility 0s;
}

.iza-drawer__overlay {
  background: rgba(15, 28, 61, 0.6);
  opacity:    0;
  transition: opacity 0.4s var(--iza-ease);
  backdrop-filter: blur(4px);
}

.iza-drawer.is-open .iza-drawer__overlay { opacity: 1; }

.iza-drawer__panel {
  background:  var(--iza-night);
  padding:     calc(var(--iza-header-h) + 32px) 32px 40px;
  overflow-y:  auto;
  transform:   translateX(100%);
  transition:  transform 0.4s var(--iza-ease-soft);
}

.iza-drawer.is-open .iza-drawer__panel { transform: translateX(0); }

.iza-drawer__nav-link {
  display:        block;
  font-family:    var(--iza-font-mincho);
  font-size:      1.25rem;
  font-weight:    600;
  color:          var(--iza-text-on-dark);
  letter-spacing: 0.1em;
  padding:        14px 0;
  border-bottom:  1px solid rgba(242, 199, 92, 0.12);
  transition:     color var(--iza-dur-fast);
}

.iza-drawer__nav-link:hover { color: var(--iza-lamp); }

.iza-drawer__contact {
  margin-top:   32px;
  padding-top:  24px;
  border-top:   1px solid rgba(242, 199, 92, 0.2);
  display:      flex;
  flex-direction:column;
  gap:          12px;
}

.iza-drawer__tel-link {
  font-family:    var(--iza-font-num);
  font-size:      1.4rem;
  font-weight:    700;
  color:          var(--iza-lamp);
  letter-spacing: 0.04em;
}

/* =========================================================================
   7. Float CTA (スマホ右下固定) — 4 経路
   ========================================================================= */

.iza-float-cta {
  position: fixed;
  bottom:   24px;
  right:    20px;
  z-index:  800;
  display:  flex;
  flex-direction: column;
  gap:      10px;
  opacity:  0;
  transform:translateY(20px);
  transition: opacity 0.5s var(--iza-ease), transform 0.5s var(--iza-ease);
  pointer-events: none;
}

.iza-float-cta.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}

.iza-float-btn {
  display:      flex;
  align-items:  center;
  justify-content:center;
  width:        52px;
  height:       52px;
  border-radius:var(--iza-r-pill);
  box-shadow:   0 6px 20px rgba(0,0,0,0.35);
  transition:   transform var(--iza-dur-fast), box-shadow var(--iza-dur-fast);
}

.iza-float-btn:hover {
  transform:  translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,0.45);
}

.iza-float-btn--tel  { background: var(--iza-vermilion); }
.iza-float-btn--web  { background: var(--iza-lamp); }
.iza-float-btn--line { background: var(--iza-line-green); }
.iza-float-btn--mail { background: var(--iza-night-soft); border: 1px solid rgba(242,199,92,0.3); }

.iza-float-btn svg {
  width: 22px; height: 22px;
  fill: #fff;
}
.iza-float-btn--web svg { fill: var(--iza-night); }

/* =========================================================================
   8. Hero AA — 横スク提灯バナー + 縦書きキャッチ + 営業時間バー + 予約タブ
   ========================================================================= */

.iza-hero {
  position:     relative;
  width:        100%;
  min-height:   100svh;
  overflow:     hidden;
  padding-top:  var(--iza-header-h);
  background:   var(--iza-night-deep);
  display:      flex;
  flex-direction:column;
}

/* --- 横スクロール画像バナー --- */
.iza-hero__slider {
  position:   relative;
  flex:       1;
  min-height: 0;
  overflow:   hidden;
}

.iza-hero__track {
  display:    flex;
  width:      100%;
  height:     100%;
  transition: transform 0.9s var(--iza-ease-soft);
}

.iza-hero__slide {
  min-width:  100%;
  height:     100%;
  position:   relative;
  overflow:   hidden;
}

.iza-hero__slide-img {
  width:     100%;
  height:    100%;
  object-fit:cover;
  object-position: center;
  transform: scale(1.06);
  animation: iza-hero-zoom 10s ease-in-out forwards;
}

@keyframes iza-hero-zoom {
  from { transform: scale(1.06); }
  to   { transform: scale(1.0);  }
}

/* オーバーレイ */
.iza-hero__overlay {
  position: absolute;
  inset:    0;
  background: linear-gradient(
    135deg,
    rgba(15, 28, 61, 0.72) 0%,
    rgba(15, 28, 61, 0.45) 50%,
    rgba(15, 28, 61, 0.62) 100%
  );
}

/* --- 縦書きキャッチコピー --- */
.iza-hero__copy {
  position:   absolute;
  top:        50%;
  left:       clamp(40px, 8vw, 120px);
  transform:  translateY(-50%);
  z-index:    10;
  display:    flex;
  flex-direction: column;
  align-items:    flex-start;
  gap:            16px;
}

.iza-hero__catch-wrap {
  writing-mode:      vertical-rl;
  text-orientation:  mixed;
  display:           flex;
  gap:               8px;
}

.iza-hero__catch-main {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(2.4rem, 5vw, 3.6rem);
  font-weight:    700;
  color:          #fff;
  line-height:    1.35;
  letter-spacing: 0.12em;
  text-shadow:    0 2px 24px rgba(15, 28, 61, 0.7);
  opacity:        0;
  transform:      translateX(12px);
  animation:      iza-fade-right 1s 0.4s var(--iza-ease-soft) forwards;
}

.iza-hero__catch-sub {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(1.1rem, 2vw, 1.6rem);
  font-weight:    400;
  color:          var(--iza-lamp);
  line-height:    1.6;
  letter-spacing: 0.14em;
  opacity:        0;
  transform:      translateX(12px);
  animation:      iza-fade-right 1s 0.7s var(--iza-ease-soft) forwards;
}

@keyframes iza-fade-right {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: translateX(0);    }
}

/* スライダーインジケーター */
.iza-hero__dots {
  position:   absolute;
  bottom:     20px;
  left:       50%;
  transform:  translateX(-50%);
  z-index:    10;
  display:    flex;
  gap:        8px;
}

.iza-hero__dot {
  width:  8px; height: 8px;
  border-radius: var(--iza-r-pill);
  background: rgba(245, 239, 226, 0.4);
  transition: background var(--iza-dur-fast), width var(--iza-dur-fast);
  cursor: pointer;
}

.iza-hero__dot.is-active {
  width:      24px;
  background: var(--iza-lamp);
}

/* --- 営業時間バー --- */
.iza-hero__time-bar {
  background:  rgba(15, 28, 61, 0.95);
  border-top:  1px solid rgba(242, 199, 92, 0.2);
  padding:     12px var(--iza-px);
  display:     flex;
  align-items: center;
  gap:         clamp(16px, 4vw, 48px);
  flex-wrap:   wrap;
  backdrop-filter: blur(8px);
}

.iza-hero__time-item {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-family: var(--iza-font-gothic);
  font-size:   0.84rem;
  color:       var(--iza-text-on-dark-sub);
}

.iza-hero__time-item strong {
  font-family: var(--iza-font-num);
  font-weight: 600;
  color:       var(--iza-lamp);
  letter-spacing: 0.04em;
}

.iza-hero__time-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--iza-vermilion);
  flex-shrink: 0;
}

.iza-hero__time-open {
  display:     flex;
  align-items: center;
  gap:         6px;
  font-size:   0.78rem;
}

.iza-hero__time-open::before {
  content:     '●';
  color:       var(--iza-line-green);
  font-size:   0.6rem;
  animation:   iza-blink 1.8s ease-in-out infinite;
}

@keyframes iza-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}

/* --- 予約導線: 電話主軸 / LINE 副 / Web 補助 (非対称・居酒屋実態) --- */
.iza-hero__reserve {
  background: linear-gradient(180deg, var(--iza-night) 0%, var(--iza-night-deep) 100%);
  border-top: 1px solid rgba(242, 199, 92, 0.18);
  padding:    clamp(18px, 2.4vh, 28px) var(--iza-px);
}

.iza-hero__reserve-inner {
  max-width: var(--iza-container);
  margin:    0 auto;
  display:   grid;
  gap:       clamp(10px, 1.6vh, 16px);
}

/* 大将のひとこと */
.iza-hero__reserve-voice {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(0.88rem, 1.4vw, 1rem);
  color:          rgba(245, 239, 226, 0.85);
  letter-spacing: 0.06em;
  margin:         0;
  display:        flex;
  align-items:    baseline;
  gap:            8px;
  flex-wrap:      wrap;
}
.iza-hero__reserve-voice-mark {
  color: var(--iza-lamp);
  font-weight: 600;
  letter-spacing: -0.05em;
}
.iza-hero__reserve-voice-by {
  font-size: 0.78rem;
  color:     rgba(242, 199, 92, 0.7);
  letter-spacing: 0.12em;
  margin-left: 2px;
}
.iza-hero__reserve-voice-by::before {
  content: " / ";
  color:   rgba(245, 239, 226, 0.35);
  margin-right: 4px;
}

/* グリッド: 電話 (主) + LINE (副) — 非対称 7:3 */
.iza-hero__reserve-grid {
  display:               grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 3fr);
  gap:                   clamp(8px, 1.2vw, 14px);
  align-items:           stretch;
}

/* === 電話 (主導線) === */
.iza-hero__reserve-tel {
  display:         flex;
  align-items:     center;
  gap:             clamp(12px, 2vw, 20px);
  padding:         clamp(12px, 2vh, 18px) clamp(16px, 2.4vw, 26px);
  background:      linear-gradient(135deg, var(--iza-lamp) 0%, #E8B847 100%);
  color:           var(--iza-night-deep);
  border-radius:   4px;
  text-decoration: none;
  position:        relative;
  overflow:        hidden;
  box-shadow:
    0 12px 30px -12px rgba(242, 199, 92, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
  transition: transform var(--iza-dur-fast) var(--iza-ease-soft),
              box-shadow var(--iza-dur-fast) var(--iza-ease-soft);
}
.iza-hero__reserve-tel::before {
  content:        '';
  position:       absolute;
  inset:          0;
  background:     radial-gradient(circle at 100% 0%, rgba(255,255,255,0.18) 0%, transparent 50%);
  pointer-events: none;
}
@media (hover: hover) {
  .iza-hero__reserve-tel:hover {
    transform:  translateY(-2px) scale(1.005);
    box-shadow:
      0 18px 40px -10px rgba(242, 199, 92, 0.6),
      inset 0 1px 0 rgba(255, 255, 255, 0.45);
  }
}

.iza-hero__reserve-tel-icon {
  flex-shrink: 0;
  width:       clamp(40px, 5vw, 52px);
  height:      clamp(40px, 5vw, 52px);
  display:     grid;
  place-items: center;
  background:  rgba(27, 45, 92, 0.12);
  border-radius: 50%;
  color:       var(--iza-night-deep);
}
.iza-hero__reserve-tel-icon svg {
  width: 60%; height: 60%;
}

.iza-hero__reserve-tel-text {
  display:        flex;
  flex-direction: column;
  gap:            2px;
  min-width:      0;
}
.iza-hero__reserve-tel-eyebrow {
  font-family:    var(--iza-font-gothic);
  font-size:      0.74rem;
  font-weight:    500;
  letter-spacing: 0.18em;
  color:          rgba(27, 45, 92, 0.72);
}
.iza-hero__reserve-tel-num {
  font-family:    var(--iza-font-num);
  font-size:      clamp(1.4rem, 2.6vw, 1.85rem);
  font-weight:    700;
  letter-spacing: 0.04em;
  color:          var(--iza-night-deep);
  line-height:    1.1;
}
.iza-hero__reserve-tel-hours {
  font-family:    var(--iza-font-gothic);
  font-size:      0.72rem;
  letter-spacing: 0.06em;
  color:          rgba(27, 45, 92, 0.62);
}

/* === LINE (副導線) === */
.iza-hero__reserve-line {
  display:         flex;
  align-items:     center;
  gap:             clamp(8px, 1.2vw, 12px);
  padding:         clamp(10px, 1.8vh, 16px) clamp(12px, 1.6vw, 18px);
  background:      transparent;
  border:          1px solid rgba(242, 199, 92, 0.4);
  border-radius:   4px;
  color:           var(--iza-paper);
  text-decoration: none;
  transition: background var(--iza-dur-fast),
              border-color var(--iza-dur-fast),
              transform var(--iza-dur-fast);
}
@media (hover: hover) {
  .iza-hero__reserve-line:hover {
    background:   rgba(242, 199, 92, 0.08);
    border-color: rgba(242, 199, 92, 0.7);
    transform:    translateY(-2px);
  }
}

.iza-hero__reserve-line-icon {
  flex-shrink: 0;
  width:       clamp(28px, 3.5vw, 36px);
  height:      clamp(28px, 3.5vw, 36px);
  display:     grid;
  place-items: center;
  color:       var(--iza-lamp);
}
.iza-hero__reserve-line-icon svg {
  width: 80%; height: 80%;
}

.iza-hero__reserve-line-text {
  display:        flex;
  flex-direction: column;
  gap:            1px;
  min-width:      0;
}
.iza-hero__reserve-line-label {
  font-family: var(--iza-font-mincho);
  font-size:   clamp(0.92rem, 1.4vw, 1.05rem);
  font-weight: 600;
  letter-spacing: 0.08em;
}
.iza-hero__reserve-line-sub {
  font-family: var(--iza-font-gothic);
  font-size:   0.7rem;
  color:       rgba(245, 239, 226, 0.55);
  letter-spacing: 0.04em;
}

/* === Web (補助・控えめテキストリンク) === */
.iza-hero__reserve-web {
  display:         inline-flex;
  align-items:     center;
  gap:             6px;
  align-self:      flex-end;
  font-family:     var(--iza-font-gothic);
  font-size:       0.78rem;
  letter-spacing:  0.08em;
  color:           rgba(245, 239, 226, 0.55);
  text-decoration: none;
  padding-bottom:  2px;
  border-bottom:   1px dotted rgba(245, 239, 226, 0.25);
  transition:      color var(--iza-dur-fast), border-color var(--iza-dur-fast);
  width:           fit-content;
  justify-self:    end;
}
.iza-hero__reserve-web svg {
  transition: transform var(--iza-dur-fast) var(--iza-ease-soft);
}
@media (hover: hover) {
  .iza-hero__reserve-web:hover {
    color:        var(--iza-lamp);
    border-color: rgba(242, 199, 92, 0.5);
  }
  .iza-hero__reserve-web:hover svg { transform: translateX(3px); }
}

/* =========================================================================
   9. Section: 本日のおすすめ — 黒板チョーク手書き風 (S19 chalk-draw)
   ========================================================================= */

.iza-board {
  background:  var(--iza-board-bg);
  padding:     clamp(64px, 10vh, 120px) var(--iza-px);
  position:    relative;
  overflow:    hidden;
}

.iza-board::before {
  content:    '';
  position:   absolute;
  inset:      0;
  background:
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.015) 0px,
      rgba(255,255,255,0.015) 1px,
      transparent 1px,
      transparent 40px
    );
  pointer-events: none;
}

.iza-board__inner {
  max-width:    var(--iza-container);
  margin:       0 auto;
  display:      grid;
  grid-template-columns: 1fr 1fr;
  gap:          clamp(40px, 6vw, 80px);
  align-items:  start;
}

.iza-board__label {
  display:        inline-flex;
  align-items:    center;
  gap:            10px;
  font-family:    var(--iza-font-num);
  font-size:      0.7rem;
  font-weight:    500;
  color:          var(--iza-chalk-green);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom:  16px;
}

.iza-board__label::before,
.iza-board__label::after {
  content:     '';
  flex:        1;
  height:      1px;
  background:  currentColor;
  opacity:     0.4;
}

.iza-board__title {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(1.8rem, 3vw, 2.6rem);
  font-weight:    700;
  color:          var(--iza-chalk-white);
  line-height:    1.35;
  letter-spacing: 0.06em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
  margin-bottom:  24px;
}

/* チョーク手書き下線 S19 */
.iza-board__chalk-underline {
  position: relative;
  display:  inline-block;
}

.iza-board__chalk-underline::after {
  content:    '';
  position:   absolute;
  bottom:     -4px; left: 0;
  width:      100%;
  height:     3px;
  background: var(--iza-chalk-yellow);
  border-radius: 3px;
  transform-origin: left;
  transform:  scaleX(0);
  transition: transform 1.2s var(--iza-ease-soft);
  filter:     url(#iza-chalk-filter);
}

.iza-board__chalk-underline.is-drawn::after {
  transform: scaleX(1);
}

/* 今日のメニューリスト */
.iza-board__menu-list {
  display:       flex;
  flex-direction:column;
  gap:           12px;
}

.iza-board__menu-item {
  display:     flex;
  align-items: baseline;
  gap:         12px;
  padding-bottom:  12px;
  border-bottom:   1px solid rgba(240, 236, 224, 0.1);
}

.iza-board__menu-item:last-child { border-bottom: 0; }

.iza-board__menu-name {
  font-family:    var(--iza-font-mincho);
  font-size:      1.05rem;
  font-weight:    600;
  color:          var(--iza-chalk-white);
  flex:           1;
  letter-spacing: 0.06em;
}

.iza-board__menu-dot {
  flex: 1;
  border-bottom: 2px dotted rgba(240, 236, 224, 0.2);
  margin-bottom: 4px;
}

.iza-board__menu-price {
  font-family:    var(--iza-font-num);
  font-size:      1.0rem;
  font-weight:    600;
  color:          var(--iza-chalk-yellow);
  letter-spacing: 0.04em;
  white-space:    nowrap;
}

.iza-board__menu-badge {
  font-family:  var(--iza-font-gothic);
  font-size:    0.65rem;
  font-weight:  700;
  color:        var(--iza-board-bg);
  background:   var(--iza-chalk-pink);
  padding:      2px 8px;
  border-radius:var(--iza-r-pill);
  flex-shrink:  0;
}

/* 大将のひとこと */
.iza-board__message {
  background:    var(--iza-board-bg-alt);
  border:        1px solid rgba(240, 236, 224, 0.12);
  border-left:   4px solid var(--iza-lamp);
  border-radius: var(--iza-r-md);
  padding:       24px 28px;
  margin-top:    32px;
}

.iza-board__message-text {
  font-family:    var(--iza-font-mincho);
  font-size:      1.0rem;
  color:          var(--iza-chalk-white);
  line-height:    1.9;
  letter-spacing: 0.06em;
  opacity:        0.9;
}

.iza-board__message-sign {
  font-family:    var(--iza-font-gothic);
  font-size:      0.78rem;
  color:          var(--iza-chalk-yellow);
  margin-top:     12px;
  letter-spacing: 0.1em;
}

/* 黒板イラスト装飾 */
.iza-board__deco {
  display:         flex;
  flex-direction:  column;
  gap:             24px;
  align-items:     center;
}

.iza-board__deco-img {
  width:         100%;
  max-width:     440px;
  aspect-ratio:  4/3;
  object-fit:    cover;
  border-radius: var(--iza-r-md);
  border:        3px solid rgba(240, 236, 224, 0.15);
  filter:        brightness(0.9) saturate(0.85);
}

/* =========================================================================
   10. Section: 看板料理 — 画像グリッド 6 枚 + ホバー詳細
   ========================================================================= */

.iza-works {
  background: var(--iza-paper);
  padding:    clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-works__inner {
  max-width: var(--iza-container);
  margin:    0 auto;
}

.iza-works__header {
  text-align:   center;
  margin-bottom:clamp(40px, 6vh, 72px);
}

.iza-section-label {
  display:        inline-flex;
  align-items:    center;
  gap:            12px;
  font-family:    var(--iza-font-num);
  font-size:      0.7rem;
  font-weight:    600;
  color:          var(--iza-vermilion);
  letter-spacing: 0.26em;
  text-transform: uppercase;
  margin-bottom:  14px;
}

.iza-section-label::before,
.iza-section-label::after {
  content:    '';
  width:      32px;
  height:     1px;
  background: currentColor;
  opacity:    0.5;
}

.iza-section-title {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(1.8rem, 3.2vw, 2.8rem);
  font-weight:    700;
  color:          var(--iza-night);
  line-height:    1.35;
  letter-spacing: 0.06em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
}

.iza-section-title--light {
  color: var(--iza-lamp);
}

.iza-section-desc {
  font-family:  var(--iza-font-gothic);
  font-size:    0.95rem;
  color:        var(--iza-text-sub);
  line-height:  2.0;
  margin-top:   16px;
  max-width:    540px;
  margin-left:  auto;
  margin-right: auto;
}

/* グリッド */
.iza-works__grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   20px;
}

.iza-works__card {
  position:      relative;
  aspect-ratio:  4/3;
  overflow:      hidden;
  border-radius: var(--iza-r-md);
  cursor:        pointer;
  background:    var(--iza-night);
}

.iza-works__card-img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  transition: transform 0.7s var(--iza-ease-soft);
}

.iza-works__card:hover .iza-works__card-img {
  transform: scale(1.07);
}

.iza-works__card-overlay {
  position:   absolute;
  inset:      0;
  background: linear-gradient(
    180deg,
    transparent 40%,
    rgba(15, 28, 61, 0.85) 100%
  );
  opacity:    0;
  transition: opacity var(--iza-dur) var(--iza-ease);
  display:    flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:    20px;
}

.iza-works__card:hover .iza-works__card-overlay {
  opacity: 1;
}

.iza-works__card-name {
  font-family:    var(--iza-font-mincho);
  font-size:      1.1rem;
  font-weight:    700;
  color:          #fff;
  letter-spacing: 0.08em;
}

.iza-works__card-price {
  font-family:    var(--iza-font-num);
  font-size:      0.9rem;
  color:          var(--iza-lamp);
  font-weight:    600;
  margin-top:     4px;
}

/* =========================================================================
   11. Section: 季節料理 4 タブ (春夏秋冬)
   ========================================================================= */

.iza-seasons {
  background:  var(--iza-night);
  padding:     clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-seasons__inner {
  max-width:  var(--iza-container);
  margin:     0 auto;
}

.iza-seasons__tabs {
  display:         flex;
  gap:             4px;
  margin-top:      40px;
  background:      rgba(255,255,255,0.06);
  border-radius:   var(--iza-r-lg);
  padding:         4px;
}

.iza-seasons__tab {
  flex:            1;
  padding:         12px 8px;
  font-family:     var(--iza-font-mincho);
  font-size:       1.0rem;
  font-weight:     600;
  color:           var(--iza-text-on-dark-sub);
  letter-spacing:  0.1em;
  text-align:      center;
  border-radius:   var(--iza-r-md);
  cursor:          pointer;
  transition:      background var(--iza-dur-fast), color var(--iza-dur-fast);
  background:      transparent;
  border:          0;
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  gap:             8px;
}

.iza-seasons__tab-icon {
  width:  20px;
  height: 20px;
  flex-shrink: 0;
  transition: transform var(--iza-dur-fast) var(--iza-ease-soft),
              stroke    var(--iza-dur-fast);
}

.iza-seasons__tab.is-active .iza-seasons__tab-icon {
  transform: scale(1.08);
}

.iza-seasons__tab.is-active {
  background: var(--iza-lamp);
  color:      var(--iza-night);
}

.iza-seasons__tab:not(.is-active):hover {
  color:      var(--iza-lamp);
  background: rgba(242, 199, 92, 0.1);
}

.iza-seasons__panel {
  display: none;
  gap:     clamp(32px, 5vw, 64px);
  margin-top: 40px;
  align-items:center;
}

.iza-seasons__panel.is-active {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.iza-seasons__panel-img {
  width:         100%;
  aspect-ratio:  3/2;
  object-fit:    cover;
  border-radius: var(--iza-r-md);
}

.iza-seasons__panel-title {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(1.6rem, 2.8vw, 2.2rem);
  font-weight:    700;
  color:          var(--iza-lamp);
  line-height:    1.35;
  letter-spacing: 0.08em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
  margin-bottom:  20px;
}

.iza-seasons__panel-desc {
  font-family:  var(--iza-font-gothic);
  font-size:    0.95rem;
  color:        var(--iza-text-on-dark-sub);
  line-height:  2.0;
  letter-spacing:0.06em;
}

.iza-seasons__panel-list {
  margin-top:    24px;
  display:       flex;
  flex-direction:column;
  gap:           8px;
}

.iza-seasons__panel-dish {
  display:     flex;
  align-items: center;
  gap:         12px;
  font-family: var(--iza-font-gothic);
  font-size:   0.9rem;
  color:       var(--iza-text-on-dark);
}

.iza-seasons__panel-dish::before {
  content:    '';
  width:      6px; height: 6px;
  border-radius: 50%;
  background: var(--iza-lamp);
  flex-shrink:0;
}

/* =========================================================================
   12. Section: 地酒・焼酎ペアリング
   ========================================================================= */

.iza-sake {
  background: var(--iza-paper);
  padding:    clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-sake__inner {
  max-width: var(--iza-container);
  margin:    0 auto;
}

.iza-sake__layout {
  display:               grid;
  grid-template-columns: 400px 1fr;
  gap:                   clamp(40px, 6vw, 80px);
  align-items:           start;
  margin-top:            48px;
}

.iza-sake__visual {
  position: sticky;
  top:      calc(var(--iza-header-h) + 24px);
}

.iza-sake__visual-img {
  width:         100%;
  aspect-ratio:  3/4;
  object-fit:    cover;
  border-radius: var(--iza-r-lg);
  box-shadow:    var(--iza-shadow-float);
}

.iza-sake__visual-label {
  text-align:     center;
  margin-top:     16px;
  font-family:    var(--iza-font-mincho);
  font-size:      0.9rem;
  font-weight:    600;
  color:          var(--iza-text-sub);
  letter-spacing: 0.1em;
}

.iza-sake__list-header {
  display:       flex;
  align-items:   center;
  justify-content:space-between;
  margin-bottom: 24px;
}

.iza-sake__count {
  font-family:    var(--iza-font-num);
  font-size:      2.4rem;
  font-weight:    700;
  color:          var(--iza-night);
  line-height:    1;
}

.iza-sake__count span {
  font-size:   1.0rem;
  font-weight: 500;
  color:       var(--iza-text-sub);
  margin-left: 4px;
}

.iza-sake__type-toggle {
  display:  flex;
  gap:      8px;
}

.iza-sake__type-btn {
  padding:         6px 18px;
  border-radius:   var(--iza-r-pill);
  border:          1px solid var(--iza-line);
  font-family:     var(--iza-font-gothic);
  font-size:       0.8rem;
  font-weight:     500;
  color:           var(--iza-text-sub);
  cursor:          pointer;
  background:      transparent;
  transition:      all var(--iza-dur-fast);
}

.iza-sake__type-btn.is-active {
  background:  var(--iza-night);
  border-color:var(--iza-night);
  color:       var(--iza-lamp);
}

.iza-sake__grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   12px;
}

.iza-sake__card {
  background:    #fff;
  border:        1px solid var(--iza-line-soft);
  border-radius: var(--iza-r-md);
  padding:       16px 20px;
  transition:    box-shadow var(--iza-dur-fast), transform var(--iza-dur-fast);
}

.iza-sake__card:hover {
  box-shadow: var(--iza-shadow-card);
  transform:  translateY(-2px);
}

.iza-sake__card-brewery {
  font-family:    var(--iza-font-gothic);
  font-size:      0.7rem;
  color:          var(--iza-text-mute);
  letter-spacing: 0.12em;
  margin-bottom:  4px;
}

.iza-sake__card-name {
  font-family:    var(--iza-font-mincho);
  font-size:      1.0rem;
  font-weight:    600;
  color:          var(--iza-night);
  letter-spacing: 0.06em;
}

.iza-sake__card-region {
  font-family:  var(--iza-font-gothic);
  font-size:    0.75rem;
  color:        var(--iza-text-sub);
  margin-top:   4px;
}

.iza-sake__card-badge {
  display:      inline-block;
  margin-top:   8px;
  padding:      2px 10px;
  border-radius:var(--iza-r-pill);
  font-family:  var(--iza-font-gothic);
  font-size:    0.65rem;
  font-weight:  600;
  letter-spacing:0.06em;
}

.iza-sake__card-badge--junmai  { background: rgba(27,45,92,0.08); color: var(--iza-night); }
.iza-sake__card-badge--ginjo   { background: rgba(242,199,92,0.2); color: var(--iza-lamp-deep); }
.iza-sake__card-badge--daiginjo{ background: rgba(193,63,46,0.12); color: var(--iza-vermilion-deep); }

/* =========================================================================
   13. Section: 個室 4 タイプ
   ========================================================================= */

.iza-rooms {
  background: var(--iza-night);
  padding:    clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-rooms__inner {
  max-width: var(--iza-container);
  margin:    0 auto;
}

.iza-rooms__grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   24px;
  margin-top:            48px;
}

.iza-room-card {
  background:    rgba(255,255,255,0.04);
  border:        1px solid rgba(242, 199, 92, 0.12);
  border-radius: var(--iza-r-lg);
  overflow:      hidden;
  transition:    transform var(--iza-dur-fast), box-shadow var(--iza-dur-fast);
}

.iza-room-card:hover {
  transform:  translateY(-4px);
  box-shadow: 0 20px 48px rgba(0,0,0,0.4);
  border-color:rgba(242, 199, 92, 0.28);
}

.iza-room-card__img {
  width:         100%;
  aspect-ratio:  16/9;
  object-fit:    cover;
  filter:        brightness(0.88);
  transition:    filter var(--iza-dur), transform var(--iza-dur);
}

.iza-room-card:hover .iza-room-card__img {
  filter:    brightness(1.0);
  transform: scale(1.03);
}

.iza-room-card__body {
  padding: 20px 24px 24px;
}

.iza-room-card__type {
  font-family:    var(--iza-font-num);
  font-size:      0.68rem;
  font-weight:    600;
  color:          var(--iza-lamp);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom:  8px;
}

.iza-room-card__name {
  font-family:    var(--iza-font-mincho);
  font-size:      1.25rem;
  font-weight:    700;
  color:          var(--iza-text-on-dark);
  letter-spacing: 0.08em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
}

.iza-room-card__capacity {
  display:     flex;
  align-items: center;
  gap:         6px;
  margin-top:  10px;
  font-family: var(--iza-font-gothic);
  font-size:   0.82rem;
  color:       var(--iza-text-on-dark-sub);
}

.iza-room-card__capacity-num {
  font-family: var(--iza-font-num);
  font-weight: 600;
  color:       var(--iza-lamp);
}

.iza-room-card__features {
  display:    flex;
  flex-wrap:  wrap;
  gap:        6px;
  margin-top: 14px;
}

.iza-room-card__feature-tag {
  padding:      4px 12px;
  border:       1px solid rgba(242, 199, 92, 0.25);
  border-radius:var(--iza-r-pill);
  font-family:  var(--iza-font-gothic);
  font-size:    0.7rem;
  color:        var(--iza-text-on-dark-sub);
  letter-spacing:0.06em;
}

/* =========================================================================
   14. Section: 大将ストーリー
   ========================================================================= */

.iza-about {
  background:  var(--iza-paper-warm);
  padding:     clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-about__inner {
  max-width:              var(--iza-container);
  margin:                 0 auto;
  display:                grid;
  grid-template-columns:  380px 1fr;
  gap:                    clamp(48px, 7vw, 96px);
  align-items:            start;
}

.iza-about__portrait-wrap {
  position: sticky;
  top:      calc(var(--iza-header-h) + 32px);
}

.iza-about__portrait {
  width:         100%;
  aspect-ratio:  4/5;
  object-fit:    cover;
  object-position:center top;
  border-radius: var(--iza-r-lg);
  box-shadow:    var(--iza-shadow-float);
}

.iza-about__portrait-caption {
  text-align:     center;
  margin-top:     16px;
  font-family:    var(--iza-font-mincho);
  font-size:      0.82rem;
  color:          var(--iza-text-sub);
  letter-spacing: 0.1em;
}

.iza-about__content {}

.iza-about__heading {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(1.8rem, 3vw, 2.6rem);
  font-weight:    700;
  color:          var(--iza-night);
  line-height:    1.45;
  letter-spacing: 0.06em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
  margin-bottom:  32px;
}

.iza-about__text {
  font-family:  var(--iza-font-gothic);
  font-size:    0.98rem;
  color:        var(--iza-text);
  line-height:  2.1;
  letter-spacing:0.06em;
  margin-bottom:24px;
}

.iza-about__career {
  margin-top:    32px;
  border-left:   3px solid var(--iza-lamp);
  padding-left:  24px;
  display:       flex;
  flex-direction:column;
  gap:           16px;
}

.iza-about__career-item {
  display: flex;
  gap:     16px;
  align-items:baseline;
}

.iza-about__career-year {
  font-family:  var(--iza-font-num);
  font-size:    0.85rem;
  font-weight:  600;
  color:        var(--iza-vermilion);
  white-space:  nowrap;
  flex-shrink:  0;
}

.iza-about__career-desc {
  font-family:  var(--iza-font-gothic);
  font-size:    0.88rem;
  color:        var(--iza-text-sub);
  line-height:  1.7;
}

/* =========================================================================
   15. Section: 店内ギャラリー 6 枚
   ========================================================================= */

.iza-gallery {
  background:  var(--iza-night-deep);
  padding:     clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-gallery__inner {
  max-width: var(--iza-container);
  margin:    0 auto;
}

.iza-gallery__grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows:        280px;
  gap:                   12px;
  margin-top:            48px;
}

.iza-gallery__grid > :first-child {
  grid-column: span 2;
}

.iza-gallery__item {
  position:      relative;
  overflow:      hidden;
  border-radius: var(--iza-r-sm);
  cursor:        pointer;
}

.iza-gallery__img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  transition: transform 0.7s var(--iza-ease-soft), filter 0.7s;
  filter:     brightness(0.88) saturate(0.9);
}

.iza-gallery__item:hover .iza-gallery__img {
  transform: scale(1.06);
  filter:    brightness(1.0) saturate(1.05);
}

.iza-gallery__item::after {
  content:    '';
  position:   absolute;
  inset:      0;
  background: linear-gradient(
    180deg,
    transparent 60%,
    rgba(15, 28, 61, 0.6) 100%
  );
  opacity:    0;
  transition: opacity var(--iza-dur);
}

.iza-gallery__item:hover::after { opacity: 1; }

/* =========================================================================
   16. Section: アクセス + 営業時間 (Schema.org LocalBusiness)
   ========================================================================= */

.iza-access {
  background:  var(--iza-paper);
  padding:     clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-access__inner {
  max-width: var(--iza-container);
  margin:    0 auto;
  display:   grid;
  grid-template-columns: 1fr 380px;
  gap:       clamp(40px, 6vw, 72px);
  align-items:start;
}

.iza-access__map {
  width:         100%;
  aspect-ratio:  16/9;
  border-radius: var(--iza-r-md);
  overflow:      hidden;
  border:        1px solid var(--iza-line);
  background:    var(--iza-night-soft);
}

.iza-access__map iframe {
  width: 100%; height: 100%; border: 0; display: block;
}

.iza-access__info-card {
  background:    #fff;
  border:        1px solid var(--iza-line-soft);
  border-radius: var(--iza-r-lg);
  padding:       32px 28px;
  box-shadow:    var(--iza-shadow-card);
}

.iza-access__info-title {
  font-family:    var(--iza-font-mincho);
  font-size:      1.1rem;
  font-weight:    700;
  color:          var(--iza-night);
  letter-spacing: 0.08em;
  margin-bottom:  24px;
  padding-bottom: 16px;
  border-bottom:  1px solid var(--iza-line-soft);
}

.iza-access__info-row {
  display:       flex;
  gap:           16px;
  padding:       12px 0;
  border-bottom: 1px solid var(--iza-line-soft);
  align-items:   baseline;
}

.iza-access__info-row:last-of-type { border-bottom: 0; }

.iza-access__info-key {
  font-family:    var(--iza-font-gothic);
  font-size:      0.76rem;
  font-weight:    500;
  color:          var(--iza-text-mute);
  letter-spacing: 0.1em;
  min-width:      64px;
  flex-shrink:    0;
}

.iza-access__info-val {
  font-family:    var(--iza-font-gothic);
  font-size:      0.9rem;
  color:          var(--iza-text);
  line-height:    1.7;
}

.iza-access__info-val strong {
  font-family:    var(--iza-font-num);
  font-size:      1.0rem;
  font-weight:    600;
  color:          var(--iza-night);
}

.iza-access__hours-table {
  width: 100%;
  margin-top: 16px;
  border-collapse: collapse;
}

.iza-access__hours-table td {
  padding:      6px 0;
  font-family:  var(--iza-font-gothic);
  font-size:    0.84rem;
  color:        var(--iza-text);
  border-bottom:1px solid var(--iza-line-soft);
}

.iza-access__hours-table td:first-child {
  color:    var(--iza-text-sub);
  width:    72px;
}

/* =========================================================================
   17. Section: CTA 4 経路 大型ボタン
   ========================================================================= */

.iza-cta {
  background:  linear-gradient(135deg, var(--iza-night-deep) 0%, var(--iza-night) 100%);
  padding:     clamp(80px, 12vh, 140px) var(--iza-px);
  position:    relative;
  overflow:    hidden;
}

/* S20 lantern-glow 背景装飾 */
.iza-cta::before {
  content:    '';
  position:   absolute;
  top:        -60%;
  left:       -20%;
  width:      700px;
  height:     700px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(242, 199, 92, 0.06) 0%,
    transparent 70%
  );
  animation: iza-cta-glow 6s ease-in-out infinite alternate;
}

@keyframes iza-cta-glow {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(60px, 40px) scale(1.15); }
}

.iza-cta::after {
  content:    '';
  position:   absolute;
  bottom:     -40%;
  right:      -10%;
  width:      500px;
  height:     500px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(193, 63, 46, 0.06) 0%,
    transparent 70%
  );
  animation: iza-cta-glow 8s 2s ease-in-out infinite alternate-reverse;
}

.iza-cta__inner {
  position:   relative;
  z-index:    1;
  max-width:  var(--iza-container);
  margin:     0 auto;
  text-align: center;
}

.iza-cta__title {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(1.8rem, 3.2vw, 2.8rem);
  font-weight:    700;
  color:          var(--iza-lamp);
  line-height:    1.45;
  letter-spacing: 0.08em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
  margin-bottom:  16px;
}

.iza-cta__sub {
  font-family:  var(--iza-font-gothic);
  font-size:    0.95rem;
  color:        var(--iza-text-on-dark-sub);
  line-height:  1.9;
  margin-bottom:clamp(40px, 6vh, 64px);
}

.iza-cta__buttons {
  display:   flex;
  flex-wrap: wrap;
  gap:       16px;
  justify-content: center;
}

.iza-cta-btn {
  display:         inline-flex;
  align-items:     center;
  gap:             10px;
  padding:         18px 36px;
  border-radius:   var(--iza-r-pill);
  font-family:     var(--iza-font-gothic);
  font-size:       1.0rem;
  font-weight:     700;
  letter-spacing:  0.08em;
  text-decoration: none;
  transition:      transform var(--iza-dur-fast) var(--iza-ease-spring),
                   box-shadow var(--iza-dur-fast);
  min-width:       200px;
  justify-content: center;
}

.iza-cta-btn:hover {
  transform:  translateY(-3px);
  box-shadow: var(--iza-shadow-float);
}

.iza-cta-btn--tel  {
  background:  var(--iza-vermilion);
  color:       #fff;
  box-shadow:  0 8px 24px rgba(193, 63, 46, 0.35);
}

.iza-cta-btn--web  {
  background:  var(--iza-lamp);
  color:       var(--iza-night);
  box-shadow:  var(--iza-glow-lamp);
}

.iza-cta-btn--line {
  background:  var(--iza-line-green);
  color:       #fff;
  box-shadow:  0 8px 24px rgba(6, 199, 85, 0.35);
}

.iza-cta-btn--mail {
  background:  transparent;
  color:       var(--iza-lamp);
  border:      2px solid rgba(242, 199, 92, 0.5);
}

.iza-cta-btn--mail:hover {
  background:  rgba(242, 199, 92, 0.08);
  border-color:var(--iza-lamp);
}

.iza-cta-btn svg {
  width: 20px; height: 20px;
  fill: currentColor;
}

/* =========================================================================
   18. LINE 予約バナー
   ========================================================================= */

.iza-line-banner {
  background:  linear-gradient(135deg, #05B04A 0%, #04D455 100%);
  padding:     clamp(32px, 5vh, 56px) var(--iza-px);
}

.iza-line-banner__inner {
  max-width:   var(--iza-container);
  margin:      0 auto;
  display:     flex;
  align-items: center;
  gap:         24px;
  flex-wrap:   wrap;
}

.iza-line-banner__icon {
  width:  48px; height: 48px;
  flex-shrink: 0;
}

.iza-line-banner__text {
  flex: 1;
}

.iza-line-banner__title {
  font-family:    var(--iza-font-gothic);
  font-size:      1.1rem;
  font-weight:    700;
  color:          #fff;
  letter-spacing: 0.06em;
}

.iza-line-banner__desc {
  font-family:  var(--iza-font-gothic);
  font-size:    0.84rem;
  color:        rgba(255,255,255,0.85);
  margin-top:   4px;
}

.iza-line-banner__btn {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  padding:         12px 28px;
  background:      #fff;
  color:           #04A344;
  border-radius:   var(--iza-r-pill);
  font-family:     var(--iza-font-gothic);
  font-size:       0.9rem;
  font-weight:     700;
  letter-spacing:  0.06em;
  text-decoration: none;
  flex-shrink:     0;
  transition:      transform var(--iza-dur-fast);
}

.iza-line-banner__btn:hover { transform: translateY(-2px); }

/* =========================================================================
   19. Footer
   ========================================================================= */

.iza-footer {
  background:   var(--iza-night-deep);
  padding-top:  clamp(56px, 8vh, 96px);
  border-top:   1px solid rgba(242, 199, 92, 0.12);
}

.iza-footer__inner {
  max-width:  var(--iza-container);
  margin:     0 auto;
  padding:    0 var(--iza-px);
  display:    grid;
  grid-template-columns: 240px 1fr 1fr 1fr;
  gap:        clamp(32px, 4vw, 64px);
  padding-bottom: clamp(48px, 7vh, 80px);
  border-bottom:  1px solid rgba(242, 199, 92, 0.08);
}

.iza-footer__brand {
  display:        flex;
  flex-direction: column;
  gap:            16px;
}

.iza-footer__logo-ja {
  font-family:    var(--iza-font-mincho);
  font-size:      1.3rem;
  font-weight:    700;
  color:          var(--iza-lamp);
  letter-spacing: 0.12em;
}

.iza-footer__logo-en {
  font-family:    var(--iza-font-num);
  font-size:      0.62rem;
  font-weight:    400;
  color:          var(--iza-text-on-dark-sub);
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.iza-footer__address {
  font-family:  var(--iza-font-gothic);
  font-size:    0.8rem;
  color:        var(--iza-text-on-dark-sub);
  line-height:  1.9;
  margin-top:   4px;
}

.iza-footer__col-title {
  font-family:    var(--iza-font-gothic);
  font-size:      0.72rem;
  font-weight:    700;
  color:          var(--iza-lamp);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom:  16px;
  padding-bottom: 10px;
  border-bottom:  1px solid rgba(242, 199, 92, 0.15);
}

.iza-footer__nav-list {
  display:        flex;
  flex-direction: column;
  gap:            10px;
}

.iza-footer__nav-link {
  font-family:  var(--iza-font-gothic);
  font-size:    0.84rem;
  color:        var(--iza-text-on-dark-sub);
  transition:   color var(--iza-dur-fast);
}

.iza-footer__nav-link:hover { color: var(--iza-lamp); }

.iza-footer__bottom {
  max-width:  var(--iza-container);
  margin:     0 auto;
  padding:    20px var(--iza-px);
  display:    flex;
  align-items:center;
  justify-content:space-between;
  gap:        16px;
  flex-wrap:  wrap;
}

.iza-footer__copy {
  font-family:  var(--iza-font-gothic);
  font-size:    0.72rem;
  color:        rgba(245, 239, 226, 0.35);
  letter-spacing:0.06em;
}

.iza-footer__policy-links {
  display:  flex;
  gap:      16px;
}

.iza-footer__policy-link {
  font-family:  var(--iza-font-gothic);
  font-size:    0.72rem;
  color:        rgba(245, 239, 226, 0.4);
  transition:   color var(--iza-dur-fast);
}

.iza-footer__policy-link:hover { color: var(--iza-lamp); }

/* =========================================================================
   20. Common Section Header (light on dark)
   ========================================================================= */

.iza-section-header--light .iza-section-label {
  color: var(--iza-lamp);
}

.iza-section-header--light .iza-section-title {
  color: var(--iza-text-on-dark);
}

.iza-section-header--light .iza-section-desc {
  color: var(--iza-text-on-dark-sub);
}

/* Container */
.iza-container {
  max-width: var(--iza-container);
  margin:    0 auto;
}

/* Divider */
.iza-divider {
  width:   48px;
  height:  2px;
  background: linear-gradient(
    90deg,
    var(--iza-lamp) 0%,
    var(--iza-vermilion) 100%
  );
  margin: 20px auto 0;
  border-radius: var(--iza-r-pill);
}

/* =========================================================================
   21. Scroll Animations — S1 fade-up / S6 staggered / S11 parallax-soft
   ========================================================================= */

/* S1 fade-up */
.iza-fade-up {
  opacity:   0;
  transform: translateY(28px);
  transition:opacity 0.7s var(--iza-ease-soft),
              transform 0.7s var(--iza-ease-soft);
}

.iza-fade-up.is-visible {
  opacity:   1;
  transform: translateY(0);
}

/* S6 staggered (親要素に .iza-stagger を付与) */
.iza-stagger > * {
  opacity:   0;
  transform: translateY(24px);
  transition:opacity 0.6s var(--iza-ease-soft),
              transform 0.6s var(--iza-ease-soft);
}

.iza-stagger.is-visible > * { opacity: 1; transform: translateY(0); }

.iza-stagger.is-visible > *:nth-child(1)  { transition-delay: 0.0s; }
.iza-stagger.is-visible > *:nth-child(2)  { transition-delay: 0.1s; }
.iza-stagger.is-visible > *:nth-child(3)  { transition-delay: 0.2s; }
.iza-stagger.is-visible > *:nth-child(4)  { transition-delay: 0.3s; }
.iza-stagger.is-visible > *:nth-child(5)  { transition-delay: 0.4s; }
.iza-stagger.is-visible > *:nth-child(6)  { transition-delay: 0.5s; }

/* S11 parallax-soft */
.iza-parallax {
  will-change: transform;
  transition:  transform 0.1s linear;
}

/* S19 chalk-draw — キーフレーム */
@keyframes iza-chalk-draw {
  0%   { stroke-dashoffset: 1000; }
  100% { stroke-dashoffset: 0; }
}

.iza-chalk-path {
  stroke-dasharray: 1000;
  stroke-dashoffset:1000;
  animation: none;
}

.iza-chalk-path.is-drawn {
  animation: iza-chalk-draw 2s var(--iza-ease-soft) forwards;
}

/* S20 lantern-glow — 提灯 glow パルス */
@keyframes iza-lantern-glow-pulse {
  0%, 100% {
    box-shadow: 0 0 20px rgba(242,199,92,0.35),
                0 0 40px rgba(242,199,92,0.15);
  }
  50% {
    box-shadow: 0 0 32px rgba(242,199,92,0.55),
                0 0 64px rgba(242,199,92,0.25);
  }
}

.iza-lantern-glow {
  animation: iza-lantern-glow-pulse 3s ease-in-out infinite;
}

/* =========================================================================
   22. Utility Classes
   ========================================================================= */

.iza-visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

.iza-text-center { text-align: center; }
.iza-text-left   { text-align: left; }
.iza-mt-sm { margin-top: 16px; }
.iza-mt-md { margin-top: 32px; }
.iza-mt-lg { margin-top: 56px; }

.iza-btn-base {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  padding:         12px 28px;
  border-radius:   var(--iza-r-pill);
  font-family:     var(--iza-font-gothic);
  font-size:       0.9rem;
  font-weight:     700;
  letter-spacing:  0.08em;
  text-decoration: none;
  cursor:          pointer;
  border:          0;
  transition:      transform var(--iza-dur-fast), box-shadow var(--iza-dur-fast), background var(--iza-dur-fast);
}

.iza-btn-primary {
  background: var(--iza-lamp);
  color:      var(--iza-night);
  box-shadow: var(--iza-glow-lamp);
}

.iza-btn-primary:hover {
  background: var(--iza-lamp-glow);
  transform:  translateY(-2px);
}

.iza-btn-secondary {
  background:  transparent;
  color:       var(--iza-night);
  border:      2px solid var(--iza-night);
}

.iza-btn-secondary:hover {
  background: var(--iza-night);
  color:      var(--iza-lamp);
}

.iza-btn-ghost-light {
  background: transparent;
  color:      var(--iza-lamp);
  border:     2px solid rgba(242,199,92,0.45);
}

.iza-btn-ghost-light:hover {
  background: rgba(242,199,92,0.1);
  border-color:var(--iza-lamp);
  transform:  translateY(-2px);
}

/* =========================================================================
   23. News / Blog カード
   ========================================================================= */

.iza-news {
  background: var(--iza-paper);
  padding:    clamp(80px, 12vh, 140px) var(--iza-px);
}

.iza-news__inner {
  max-width: var(--iza-container);
  margin:    0 auto;
}

.iza-news__grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   28px;
  margin-top:            48px;
}

.iza-news-card {
  background:    #fff;
  border:        1px solid var(--iza-line-soft);
  border-radius: var(--iza-r-lg);
  overflow:      hidden;
  transition:    transform var(--iza-dur-fast), box-shadow var(--iza-dur-fast);
}

.iza-news-card:hover {
  transform:  translateY(-4px);
  box-shadow: var(--iza-shadow-card);
}

.iza-news-card__thumb {
  width:       100%;
  aspect-ratio:16/9;
  object-fit:  cover;
  transition:  transform 0.7s var(--iza-ease-soft);
}

.iza-news-card:hover .iza-news-card__thumb {
  transform: scale(1.05);
}

.iza-news-card__img-wrap {
  overflow: hidden;
}

.iza-news-card__body {
  padding: 20px 22px 24px;
}

.iza-news-card__category {
  font-family:    var(--iza-font-gothic);
  font-size:      0.68rem;
  font-weight:    700;
  color:          var(--iza-vermilion);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom:  8px;
}

.iza-news-card__title {
  font-family:    var(--iza-font-mincho);
  font-size:      1.0rem;
  font-weight:    600;
  color:          var(--iza-night);
  line-height:    1.55;
  letter-spacing: 0.04em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
  display:        -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient:vertical;
  overflow:       hidden;
}

.iza-news-card__date {
  font-family:    var(--iza-font-num);
  font-size:      0.75rem;
  color:          var(--iza-text-mute);
  margin-top:     10px;
}

/* =========================================================================
   24. Recruit セクション (TOPコンポーネント)
   ========================================================================= */

.iza-recruit-banner {
  position:    relative;
  overflow:    hidden;
  background:  var(--iza-night-soft);
  padding:     clamp(64px, 10vh, 100px) var(--iza-px);
}

.iza-recruit-banner__bg {
  position:   absolute;
  inset:      0;
  object-fit: cover;
  width:      100%;
  height:     100%;
  opacity:    0.25;
  filter:     blur(2px) brightness(0.7);
}

.iza-recruit-banner__inner {
  position:   relative;
  z-index:    1;
  max-width:  var(--iza-container);
  margin:     0 auto;
  display:    flex;
  align-items:center;
  justify-content:space-between;
  gap:        32px;
  flex-wrap:  wrap;
}

.iza-recruit-banner__copy {
  font-family:    var(--iza-font-mincho);
  font-size:      clamp(1.6rem, 3vw, 2.4rem);
  font-weight:    700;
  color:          #fff;
  line-height:    1.45;
  letter-spacing: 0.06em;
  word-break:     auto-phrase;
  overflow-wrap:  anywhere;
}

.iza-recruit-banner__sub {
  font-family:  var(--iza-font-gothic);
  font-size:    0.9rem;
  color:        rgba(255,255,255,0.75);
  margin-top:   10px;
  line-height:  1.8;
}

/* =========================================================================
   25. SVG Filter: chalk テクスチャ (黒板用)
   ========================================================================= */

.iza-chalk-filter-defs {
  position: absolute;
  width: 0; height: 0;
  overflow: hidden;
}

/* =========================================================================
   26. Responsive — Tablet (1024px 以下)
   ========================================================================= */

@media (max-width: 1024px) {
  .iza-header__nav { display: none; }
  .iza-header__hamburger { display: flex; }
  .iza-header__tel { display: none; }

  .iza-board__inner {
    grid-template-columns: 1fr;
  }

  .iza-about__inner {
    grid-template-columns: 1fr;
  }

  .iza-about__portrait-wrap {
    position: static;
    max-width: 360px;
    margin: 0 auto;
  }

  .iza-sake__layout {
    grid-template-columns: 1fr;
  }

  .iza-sake__visual {
    position: static;
    max-width: 320px;
    margin: 0 auto;
  }

  .iza-access__inner {
    grid-template-columns: 1fr;
  }

  .iza-footer__inner {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }

  .iza-hero__catch-main {
    font-size: clamp(2.0rem, 4vw, 3.0rem);
  }
}

/* =========================================================================
   27. Responsive — Mobile (768px 以下)
   ========================================================================= */

@media (max-width: 768px) {
  :root {
    --iza-header-h: 60px;
  }

  .iza-header__reserve-btn {
    padding: 8px 14px;
    font-size: 0.76rem;
  }

  .iza-hero__copy {
    left: 24px;
  }

  .iza-hero__catch-main {
    font-size: clamp(1.8rem, 6vw, 2.6rem);
  }

  /* 予約導線: モバイルは縦積み (電話 → LINE)、Web は中央 */
  .iza-hero__reserve-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .iza-hero__reserve-tel-num {
    font-size: clamp(1.3rem, 5.4vw, 1.6rem);
  }
  .iza-hero__reserve-web {
    align-self: center;
    justify-self: center;
  }

  .iza-works__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  .iza-seasons__panel.is-active {
    grid-template-columns: 1fr;
  }

  .iza-rooms__grid {
    grid-template-columns: 1fr;
  }

  .iza-sake__grid {
    grid-template-columns: 1fr;
  }

  .iza-gallery__grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 160px;
  }

  .iza-gallery__grid > :first-child {
    grid-column: span 2;
  }

  .iza-cta__buttons {
    flex-direction: column;
    align-items: stretch;
  }

  .iza-cta-btn {
    min-width: 0;
  }

  .iza-footer__inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .iza-news__grid {
    grid-template-columns: 1fr;
  }

  .iza-line-banner__inner {
    flex-direction: column;
    text-align: center;
  }

  .iza-float-cta {
    bottom: 16px;
    right:  14px;
  }

  .iza-float-btn {
    width:  46px;
    height: 46px;
  }

  .iza-hero__time-bar {
    gap: 12px;
  }

  .iza-hero__time-item { font-size: 0.78rem; }
}

/* =========================================================================
   28. Responsive — Small Mobile (480px 以下)
   ========================================================================= */

@media (max-width: 480px) {
  .iza-works__grid {
    grid-template-columns: 1fr;
  }

  .iza-seasons__tabs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }

  .iza-hero__copy {
    left: 16px;
    right: 16px;
  }

  .iza-hero__catch-wrap {
    writing-mode:  horizontal-tb;
    text-orientation:  mixed;
    flex-direction:column;
  }

  .iza-hero__catch-main {
    font-size:   clamp(1.6rem, 7vw, 2.2rem);
  }
}

/* =========================================================================
   29. prefers-reduced-motion
   ========================================================================= */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration:   0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration:  0.01ms !important;
    scroll-behavior:      auto !important;
  }

  .iza-loader__lantern.is-lit {
    animation: none;
  }

  .iza-hero__slide-img {
    animation: none;
    transform: none;
  }

  .iza-cta::before,
  .iza-cta::after {
    animation: none;
  }

  .iza-lantern-glow {
    animation: none;
  }
}

/* =========================================================================
   30. Print styles
   ========================================================================= */

@media print {
  .iza-header,
  .iza-loader,
  .iza-float-cta,
  .iza-drawer {
    display: none !important;
  }

  body.iza-body {
    background: #fff;
    color: #000;
  }

  .iza-night,
  .iza-board,
  .iza-seasons,
  .iza-rooms,
  .iza-gallery,
  .iza-cta {
    background: #f5f5f5 !important;
  }
}

/* =========================================================================
   31. WordPress 6.7 互換 / カスタマイザー hooks
   ========================================================================= */

/* アライメント (Gutenberg) */
.iza-body .alignfull  { margin-left: calc(-1 * var(--iza-px)); margin-right: calc(-1 * var(--iza-px)); width: auto; }
.iza-body .alignwide  { max-width: calc(var(--iza-container) + 2 * var(--iza-px)); }
.iza-body .wp-block-image { margin: 0; }

/* カスタマイザー CSS フック */
.iza-body.has-custom-font-mincho * {
  font-family: var(--iza-font-mincho);
}

/* =========================================================================
   32. Additional Keyframes (完全体)
   ========================================================================= */

@keyframes iza-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes iza-slide-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes iza-slide-down {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes iza-scale-in {
  from { opacity: 0; transform: scale(0.9); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes iza-shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}

/* 行灯黄シマー (CTA / バッジ用) */
.iza-shimmer {
  background: linear-gradient(
    90deg,
    var(--iza-lamp) 0%,
    var(--iza-lamp-glow) 50%,
    var(--iza-lamp) 100%
  );
  background-size: 200% auto;
  animation: iza-shimmer 3s linear infinite;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* =========================================================================
   34. SUB-PAGE COMMON (page-hero / breadcrumb / section / btn-outline)
   ========================================================================= */

.iza-section {
  padding: clamp(56px, 8vh, 96px) var(--iza-px);
  position: relative;
}
.iza-section--dark   { background: var(--iza-night); color: var(--iza-paper); }
.iza-section--accent { background: var(--iza-paper); color: var(--iza-night); }
.iza-section--cta {
  background: linear-gradient(135deg, var(--iza-night-deep) 0%, var(--iza-night) 100%);
  color: var(--iza-paper);
  padding: clamp(64px, 10vh, 120px) var(--iza-px);
  text-align: center;
}

.iza-section-head {
  display: flex; flex-direction: column; gap: 10px;
  margin-bottom: clamp(36px, 6vh, 56px);
}

.iza-container--narrow { max-width: 920px; margin: 0 auto; }

.iza-btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px;
  border-radius: var(--iza-r-pill);
  border: 1px solid rgba(242,199,92,0.5);
  color: var(--iza-paper);
  font-family: var(--iza-font-gothic);
  font-size: 0.86rem; font-weight: 600;
  letter-spacing: 0.08em;
  text-decoration: none;
  background: transparent;
  transition: background var(--iza-dur-fast), border-color var(--iza-dur-fast), color var(--iza-dur-fast);
}
.iza-btn-outline:hover {
  background: rgba(242,199,92,0.1);
  border-color: var(--iza-lamp);
  color: var(--iza-lamp);
}

/* --- page hero (サブページ共通ヘッダー) --- */
.iza-page-hero {
  position: relative;
  min-height: clamp(280px, 42vh, 380px);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: calc(var(--iza-header-h) + 56px) var(--iza-px) 64px;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  display: block;
}
.iza-page-hero--simple {
  min-height: clamp(200px, 30vh, 260px);
  background: linear-gradient(135deg, var(--iza-night-deep) 0%, var(--iza-night) 100%);
}
.iza-page-hero__overlay {
  position: absolute; inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(15,28,61,0.35) 0%, rgba(15,28,61,0.88) 100%);
  pointer-events: none;
}
.iza-page-hero__content {
  position: relative;
  max-width: var(--iza-container);
  width: 100%;
  margin: 0 auto;
  display: flex; flex-direction: column; gap: 10px;
  z-index: 1;
}
.iza-page-hero__label {
  font-family: var(--iza-font-gothic);
  font-size: 0.78rem;
  letter-spacing: 0.32em;
  color: var(--iza-lamp);
  text-transform: uppercase;
  margin: 0;
}
.iza-page-hero__title {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.9rem, 4.4vw, 2.9rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  margin: 0;
  line-height: 1.25;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.iza-page-hero__sub {
  font-family: var(--iza-font-mincho);
  font-size: clamp(0.95rem, 1.6vw, 1.1rem);
  color: rgba(245,239,226,0.88);
  margin: 0;
  letter-spacing: 0.04em;
}

/* breadcrumb: page-hero 内に配置される (HTML 構造) */
.iza-breadcrumb {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 2;
  background: rgba(15, 28, 61, 0.6);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding: 12px var(--iza-px);
  border-top: 1px solid rgba(242,199,92,0.18);
  font-family: var(--iza-font-gothic);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: rgba(245,239,226,0.7);
}
.iza-breadcrumb ol {
  list-style: none;
  display: flex; flex-wrap: wrap;
  gap: 6px;
  margin: 0; padding: 0;
  max-width: var(--iza-container);
  margin-inline: auto;
}
.iza-breadcrumb li {
  display: inline-flex; align-items: center;
}
.iza-breadcrumb li:not(:last-child)::after {
  content: "/";
  color: rgba(245,239,226,0.3);
  margin-left: 6px;
}
.iza-breadcrumb a {
  color: var(--iza-lamp);
  text-decoration: none;
}
.iza-breadcrumb a:hover { text-decoration: underline; }

/* =========================================================================
   35. ABOUT — 物語 / 哲学 / 数字 / 年表
   ========================================================================= */

.iza-about-story {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}
.iza-about-story__media {}
.iza-about-story__img {
  width: 100%; height: auto;
  border-radius: var(--iza-r-md);
  box-shadow: var(--iza-shadow-soft);
}
.iza-about-story__body {}
.iza-about-story__heading {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  margin: 0 0 20px;
  color: var(--iza-night);
  line-height: 1.4;
}
.iza-about-story__text {
  font-family: var(--iza-font-gothic);
  font-size: 1rem;
  line-height: 1.95;
  color: var(--iza-night);
  margin: 0 0 16px;
  letter-spacing: 0.03em;
}

.iza-philosophy-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(20px, 2.4vw, 32px);
}
.iza-philosophy-card {
  padding: clamp(24px, 3vw, 36px);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(242,199,92,0.18);
  border-radius: var(--iza-r-md);
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
.iza-philosophy-card__num {
  font-family: var(--iza-font-num);
  font-size: clamp(2rem, 3.5vw, 2.6rem);
  font-weight: 600;
  color: var(--iza-lamp);
  line-height: 1;
}
.iza-philosophy-card__title {
  font-family: var(--iza-font-mincho);
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0;
  letter-spacing: 0.06em;
  color: var(--iza-paper);
}
.iza-philosophy-card__body {
  font-size: 0.9rem;
  line-height: 1.85;
  color: rgba(245,239,226,0.78);
  margin: 0;
}

.iza-numbers-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: clamp(16px, 2vw, 28px);
}
.iza-number-item {
  text-align: center;
  padding: clamp(20px, 2.4vw, 28px) 16px;
  background: var(--iza-paper);
  border-top: 3px solid var(--iza-lamp);
  border-radius: 2px;
}
.iza-number-item__value {
  font-family: var(--iza-font-num);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: var(--iza-night);
  line-height: 1;
  display: inline-block;
}
.iza-number-item__unit {
  font-family: var(--iza-font-gothic);
  font-size: 0.86rem;
  color: var(--iza-night-soft);
  margin-left: 4px;
}
.iza-number-item__label {
  display: block;
  margin-top: 8px;
  font-family: var(--iza-font-gothic);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  color: var(--iza-night-soft);
}

.iza-timeline {
  display: flex; flex-direction: column;
  gap: 0;
  position: relative;
}
.iza-timeline::before {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  left: clamp(40px, 7vw, 80px);
  width: 1px;
  background: linear-gradient(180deg, var(--iza-lamp) 0%, rgba(242,199,92,0.2) 100%);
}
.iza-timeline__item {
  position: relative;
  display: grid;
  grid-template-columns: clamp(72px, 9vw, 110px) 1fr;
  gap: clamp(20px, 3vw, 36px);
  padding: clamp(16px, 2vh, 24px) 0;
  align-items: start;
}
.iza-timeline__item::before {
  content: '';
  position: absolute;
  top: clamp(22px, 2.6vh, 32px);
  left: clamp(36px, 6.6vw, 76px);
  width: 9px; height: 9px;
  background: var(--iza-lamp);
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(242,199,92,0.18);
}
.iza-timeline__year {
  font-family: var(--iza-font-num);
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  font-weight: 600;
  color: var(--iza-lamp);
  letter-spacing: 0.04em;
}
.iza-timeline__content {
  display: flex; flex-direction: column; gap: 6px;
}
.iza-timeline__title {
  font-family: var(--iza-font-mincho);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--iza-paper);
  margin: 0;
  letter-spacing: 0.04em;
}
.iza-timeline__body {
  font-size: 0.9rem;
  line-height: 1.9;
  color: rgba(245,239,226,0.75);
  margin: 0;
}

/* =========================================================================
   36. SERVICES / WORKS — お品書き・看板料理
   ========================================================================= */

.iza-service-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: center;
  padding: clamp(40px, 6vh, 72px) 0;
  border-bottom: 1px dashed rgba(27,45,92,0.12);
}
.iza-service-block:last-child { border-bottom: 0; }
.iza-service-block--reverse .iza-service-block__media { order: 2; }
.iza-service-block__media img {
  width: 100%; height: auto;
  border-radius: var(--iza-r-md);
  object-fit: cover;
  aspect-ratio: 4/3;
}
.iza-service-block__body {
  display: flex; flex-direction: column; gap: 14px;
}
.iza-service-block__tag {
  display: inline-block;
  align-self: flex-start;
  padding: 4px 12px;
  font-family: var(--iza-font-gothic);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  background: var(--iza-lamp);
  color: var(--iza-night);
  border-radius: 2px;
  font-weight: 700;
}
.iza-service-block__title {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.4rem, 2.6vw, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--iza-night);
  margin: 0;
  line-height: 1.4;
}
.iza-service-block__desc {
  font-size: 0.96rem;
  line-height: 1.95;
  color: var(--iza-night-soft);
  margin: 0;
  letter-spacing: 0.02em;
}
.iza-service-block__details,
.iza-service-block__plans {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 8px;
}
.iza-service-block__note {
  font-size: 0.82rem;
  color: var(--iza-night-soft);
  font-style: italic;
}

.iza-dishes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(20px, 2.6vw, 32px);
}
.iza-dish-card {
  background: var(--iza-paper);
  border-radius: var(--iza-r-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 6px 20px -8px rgba(15,28,61,0.18);
  transition: transform var(--iza-dur-fast) var(--iza-ease-soft),
              box-shadow var(--iza-dur-fast) var(--iza-ease-soft);
}
@media (hover: hover) {
  .iza-dish-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 36px -10px rgba(15,28,61,0.28);
  }
}
.iza-dish-card__img-wrap {
  aspect-ratio: 4/3;
  overflow: hidden;
  position: relative;
}
.iza-dish-card__img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--iza-ease-soft);
}
.iza-dish-card:hover .iza-dish-card__img-wrap img { transform: scale(1.06); }
.iza-dish-card__badge {
  position: absolute;
  top: 12px; left: 12px;
  padding: 4px 10px;
  background: var(--iza-vermilion);
  color: #fff;
  font-family: var(--iza-font-gothic);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  font-weight: 700;
  border-radius: 2px;
}
.iza-dish-card__body {
  padding: clamp(16px, 2vw, 22px);
  display: flex; flex-direction: column; gap: 8px;
  flex: 1;
}
.iza-dish-card__name {
  font-family: var(--iza-font-mincho);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--iza-night);
  margin: 0;
  line-height: 1.4;
}
.iza-dish-card__ingredient {
  font-family: var(--iza-font-gothic);
  font-size: 0.78rem;
  color: var(--iza-night-soft);
  letter-spacing: 0.04em;
}
.iza-dish-card__desc {
  font-size: 0.86rem;
  line-height: 1.8;
  color: var(--iza-night-soft);
  margin: 0;
  flex: 1;
}
.iza-dish-card__price {
  font-family: var(--iza-font-num);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--iza-vermilion);
  letter-spacing: 0.04em;
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px dashed rgba(27,45,92,0.12);
}

.iza-plan-card {
  padding: clamp(24px, 3vw, 36px);
  background: var(--iza-paper);
  border: 1px solid rgba(27,45,92,0.1);
  border-radius: var(--iza-r-md);
  text-align: center;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
}
.iza-plan-card--featured {
  border: 2px solid var(--iza-lamp);
  background: linear-gradient(180deg, #FFF8E8 0%, var(--iza-paper) 100%);
  box-shadow: 0 8px 24px -10px rgba(242,199,92,0.4);
}
.iza-plan-card__name {
  font-family: var(--iza-font-mincho);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--iza-night);
  margin: 0;
}
.iza-plan-card__price {
  font-family: var(--iza-font-num);
  font-size: clamp(1.5rem, 3vw, 1.9rem);
  font-weight: 700;
  color: var(--iza-vermilion);
}
.iza-plan-card__note {
  font-size: 0.8rem;
  color: var(--iza-night-soft);
  letter-spacing: 0.04em;
}

.iza-sake-spec {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px 18px;
  font-family: var(--iza-font-gothic);
  font-size: 0.86rem;
  margin-top: 12px;
}
.iza-sake-spec dt {
  color: var(--iza-night-soft);
  letter-spacing: 0.08em;
  font-weight: 600;
}
.iza-sake-spec dd {
  margin: 0;
  color: var(--iza-night);
}

.iza-info-table-wrap { overflow-x: auto; }
.iza-info-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--iza-font-gothic);
  font-size: 0.92rem;
}
.iza-info-table th,
.iza-info-table td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid rgba(27,45,92,0.1);
  vertical-align: top;
}
.iza-info-table th {
  font-weight: 600;
  background: rgba(242,199,92,0.06);
  width: 28%;
  color: var(--iza-night);
  letter-spacing: 0.04em;
}
.iza-info-table--compact th,
.iza-info-table--compact td { padding: 10px 12px; font-size: 0.86rem; }

/* =========================================================================
   37. STAFF — 大将フィーチャー + チームカード
   ========================================================================= */

.iza-staff-feature {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
}
.iza-staff-feature__img-wrap {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border-radius: var(--iza-r-md);
  box-shadow: var(--iza-shadow-soft);
}
.iza-staff-feature__img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.iza-staff-feature__body {
  display: flex; flex-direction: column; gap: 16px;
}
.iza-staff-feature__header {
  display: flex; flex-direction: column; gap: 6px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(27,45,92,0.12);
}
.iza-staff-feature__role {
  font-family: var(--iza-font-gothic);
  font-size: 0.78rem;
  letter-spacing: 0.24em;
  color: var(--iza-vermilion);
  text-transform: uppercase;
}
.iza-staff-feature__name {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.6rem, 3vw, 2.1rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--iza-night);
  margin: 0;
}
.iza-staff-feature__name-en {
  font-family: var(--iza-font-num);
  font-size: 0.88rem;
  letter-spacing: 0.18em;
  color: var(--iza-night-soft);
  text-transform: uppercase;
}
.iza-staff-feature__quote {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.05rem, 1.8vw, 1.2rem);
  font-style: italic;
  color: var(--iza-vermilion);
  border-left: 3px solid var(--iza-vermilion);
  padding-left: 16px;
  margin: 0;
  letter-spacing: 0.04em;
  line-height: 1.7;
}
.iza-staff-feature__profile {
  font-size: 0.96rem;
  line-height: 1.95;
  color: var(--iza-night);
  margin: 0;
}
.iza-staff-feature__career {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px dashed rgba(27,45,92,0.12);
}
.iza-staff-feature__career-title {
  font-family: var(--iza-font-mincho);
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 12px;
  color: var(--iza-night);
  letter-spacing: 0.06em;
}

.iza-staff-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(20px, 2.6vw, 32px);
}
.iza-staff-card {
  display: flex; flex-direction: column;
  background: var(--iza-paper);
  border-radius: var(--iza-r-md);
  overflow: hidden;
  box-shadow: 0 6px 18px -8px rgba(15,28,61,0.16);
}
.iza-staff-card__img-wrap {
  aspect-ratio: 4/5;
  overflow: hidden;
}
.iza-staff-card__img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.iza-staff-card__body {
  padding: clamp(16px, 2vw, 22px);
  display: flex; flex-direction: column; gap: 6px;
  flex: 1;
}
.iza-staff-card__role {
  font-family: var(--iza-font-gothic);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  color: var(--iza-vermilion);
  text-transform: uppercase;
}
.iza-staff-card__name {
  font-family: var(--iza-font-mincho);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--iza-night);
  margin: 0;
}
.iza-staff-card__name-en {
  font-family: var(--iza-font-num);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  color: var(--iza-night-soft);
}
.iza-staff-card__tenure {
  font-size: 0.78rem;
  color: var(--iza-night-soft);
  margin-top: 2px;
}
.iza-staff-card__bio {
  font-size: 0.86rem;
  line-height: 1.8;
  color: var(--iza-night);
  margin: 8px 0 0;
}
.iza-staff-card__tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 8px;
}
.iza-staff-tag {
  display: inline-block;
  padding: 3px 10px;
  font-family: var(--iza-font-gothic);
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  background: rgba(242,199,92,0.14);
  color: var(--iza-night);
  border: 1px solid rgba(242,199,92,0.3);
  border-radius: 2px;
}

/* =========================================================================
   38. ACCESS — 駅カード / 地図 / 周辺情報
   ========================================================================= */

.iza-access-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 48px);
  align-items: start;
}
.iza-access-info {
  background: var(--iza-paper);
  padding: clamp(24px, 3vw, 36px);
  border-radius: var(--iza-r-md);
  box-shadow: var(--iza-shadow-soft);
}
.iza-access-info__title {
  font-family: var(--iza-font-mincho);
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0 0 16px;
  color: var(--iza-night);
  letter-spacing: 0.06em;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--iza-lamp);
}
.iza-access-map {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: var(--iza-r-md);
  box-shadow: var(--iza-shadow-soft);
}
.iza-access-map iframe {
  width: 100%; height: 100%; border: 0;
}
.iza-access-map__link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 12px;
  font-family: var(--iza-font-gothic);
  font-size: 0.86rem;
  color: var(--iza-vermilion);
  text-decoration: none;
  border-bottom: 1px dotted currentColor;
}
.iza-access-map__link:hover { color: var(--iza-lamp); }

.iza-stations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(16px, 2vw, 24px);
}
.iza-station-card {
  padding: clamp(18px, 2.4vw, 26px);
  background: var(--iza-paper);
  border-radius: var(--iza-r-md);
  border-left: 4px solid var(--iza-lamp);
  display: flex; flex-direction: column; gap: 8px;
}
.iza-station-card__header {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
}
.iza-station-card__line {
  display: inline-block;
  padding: 3px 10px;
  font-family: var(--iza-font-gothic);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #fff;
  border-radius: 2px;
  background: var(--iza-night-soft);
}
.iza-station-card__line--ginza      { background: #F39700; }
.iza-station-card__line--marunouchi { background: #E60012; }
.iza-station-card__line--hibiya     { background: #B5B5AC; color: #1a1a1a; }
.iza-station-card__line--asakusa    { background: #EC6F1B; }
.iza-station-card__line--jretokaido { background: #F39800; }
.iza-station-card__name {
  font-family: var(--iza-font-mincho);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--iza-night);
  margin: 0;
}
.iza-station-card__time {
  font-family: var(--iza-font-num);
  font-size: 0.92rem;
  color: var(--iza-vermilion);
  font-weight: 600;
}
.iza-station-card__route {
  font-size: 0.84rem;
  line-height: 1.7;
  color: var(--iza-night-soft);
  margin: 0;
}

.iza-access-others {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.iza-access-other-card {
  padding: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(242,199,92,0.18);
  border-radius: var(--iza-r-md);
}
.iza-access-other-card__title {
  font-family: var(--iza-font-mincho);
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--iza-paper);
  letter-spacing: 0.04em;
}

/* =========================================================================
   39. CONTACT — フォーム / 予約方法カード
   ========================================================================= */

.iza-reserve-methods {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(16px, 2vw, 24px);
  margin-bottom: clamp(32px, 5vh, 56px);
}
.iza-reserve-method-card {
  padding: clamp(20px, 2.6vw, 28px);
  background: var(--iza-paper);
  border-radius: var(--iza-r-md);
  border-top: 3px solid var(--iza-lamp);
  display: flex; flex-direction: column; gap: 10px;
  text-align: center;
  text-decoration: none;
  color: var(--iza-night);
  transition: transform var(--iza-dur-fast) var(--iza-ease-soft),
              box-shadow var(--iza-dur-fast);
}
@media (hover: hover) {
  .iza-reserve-method-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 32px -12px rgba(15,28,61,0.25);
  }
}
.iza-reserve-method-card__icon {
  width: 48px; height: 48px;
  margin: 0 auto;
  display: grid; place-items: center;
  background: var(--iza-lamp);
  border-radius: 50%;
  color: var(--iza-night);
}
.iza-reserve-method-card__icon svg { width: 24px; height: 24px; }
.iza-reserve-method-card__title {
  font-family: var(--iza-font-mincho);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin: 0;
  color: var(--iza-night);
}
.iza-reserve-method-card__note {
  font-size: 0.82rem;
  line-height: 1.7;
  color: var(--iza-night-soft);
  margin: 0;
}

.iza-contact-form {
  display: flex; flex-direction: column;
  gap: clamp(18px, 2.4vw, 24px);
  background: var(--iza-paper);
  padding: clamp(28px, 4vw, 48px);
  border-radius: var(--iza-r-md);
  box-shadow: var(--iza-shadow-soft);
}
.iza-form-group {
  display: flex; flex-direction: column; gap: 6px;
}
.iza-form-group--checkbox { gap: 8px; }
.iza-form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(14px, 2vw, 22px);
}
.iza-form-label {
  font-family: var(--iza-font-gothic);
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--iza-night);
  letter-spacing: 0.04em;
}
.iza-form-required {
  margin-left: 6px;
  padding: 1px 6px;
  font-size: 0.7rem;
  background: var(--iza-vermilion);
  color: #fff;
  border-radius: 2px;
  letter-spacing: 0.04em;
}
.iza-form-optional {
  margin-left: 6px;
  padding: 1px 6px;
  font-size: 0.7rem;
  background: var(--iza-night-soft);
  color: #fff;
  border-radius: 2px;
}
.iza-form-input,
.iza-form-select,
.iza-form-textarea {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--iza-font-gothic);
  font-size: 0.95rem;
  background: #fff;
  border: 1px solid rgba(27,45,92,0.18);
  border-radius: 4px;
  color: var(--iza-night);
  transition: border-color var(--iza-dur-fast), box-shadow var(--iza-dur-fast);
}
.iza-form-input:focus,
.iza-form-select:focus,
.iza-form-textarea:focus {
  outline: 0;
  border-color: var(--iza-lamp);
  box-shadow: 0 0 0 3px rgba(242,199,92,0.18);
}
.iza-form-textarea { resize: vertical; min-height: 140px; }
.iza-form-hint {
  font-size: 0.78rem;
  color: var(--iza-night-soft);
}
.iza-form-checkbox {
  width: 18px; height: 18px;
  accent-color: var(--iza-lamp);
  cursor: pointer;
}
.iza-form-checkbox-label {
  display: inline-flex; align-items: flex-start; gap: 8px;
  font-size: 0.88rem;
  line-height: 1.6;
  color: var(--iza-night);
  cursor: pointer;
}
.iza-form-checkbox-label a {
  color: var(--iza-vermilion);
  text-decoration: underline;
}
.iza-form-submit {
  align-self: flex-start;
  padding: 14px 36px;
  background: var(--iza-vermilion);
  color: #fff;
  font-family: var(--iza-font-mincho);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  border: 0; border-radius: var(--iza-r-pill);
  cursor: pointer;
  transition: transform var(--iza-dur-fast), background var(--iza-dur-fast);
}
.iza-form-submit:hover {
  transform: translateY(-2px);
  background: #A53324;
}
.iza-form-note {
  font-size: 0.82rem;
  color: var(--iza-night-soft);
  line-height: 1.7;
  margin: 0;
}

/* =========================================================================
   40. FAQ — アコーディオン
   ========================================================================= */

.iza-faq-list {
  display: flex; flex-direction: column;
  gap: 12px;
}
.iza-faq-item {
  background: var(--iza-paper);
  border-radius: var(--iza-r-md);
  overflow: hidden;
  border: 1px solid rgba(27,45,92,0.08);
}
.iza-faq-item[open] {
  box-shadow: 0 6px 20px -10px rgba(15,28,61,0.2);
}
.iza-faq-item__question {
  display: flex; align-items: flex-start; gap: 14px;
  padding: clamp(16px, 2vw, 22px) clamp(18px, 2.4vw, 26px);
  font-family: var(--iza-font-mincho);
  font-size: 1rem;
  font-weight: 700;
  color: var(--iza-night);
  cursor: pointer;
  list-style: none;
  letter-spacing: 0.04em;
  position: relative;
}
.iza-faq-item__question::-webkit-details-marker { display: none; }
.iza-faq-item__question::after {
  content: '+';
  margin-left: auto;
  font-family: var(--iza-font-num);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--iza-lamp);
  transition: transform var(--iza-dur-fast);
}
.iza-faq-item[open] .iza-faq-item__question::after { content: '−'; }
.iza-faq-item__q-mark,
.iza-faq-item__a-mark {
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: grid; place-items: center;
  font-family: var(--iza-font-num);
  font-weight: 700;
  border-radius: 50%;
}
.iza-faq-item__q-mark {
  background: var(--iza-vermilion);
  color: #fff;
}
.iza-faq-item__a-mark {
  background: var(--iza-lamp);
  color: var(--iza-night);
}
.iza-faq-item__answer {
  display: flex; gap: 14px;
  padding: 0 clamp(18px, 2.4vw, 26px) clamp(16px, 2vw, 22px);
  font-size: 0.92rem;
  line-height: 1.95;
  color: var(--iza-night-soft);
}
.iza-faq-item__answer p { margin: 0 0 8px; }

.iza-faq-contact {
  margin-top: clamp(40px, 6vh, 64px);
  padding: clamp(28px, 4vw, 48px);
  background: rgba(242,199,92,0.08);
  border: 1px dashed rgba(242,199,92,0.4);
  border-radius: var(--iza-r-md);
  text-align: center;
}

/* =========================================================================
   41. RECRUIT — 求人カード
   ========================================================================= */

.iza-job-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(20px, 2.6vw, 32px);
}
.iza-job-card {
  padding: clamp(24px, 3vw, 32px);
  background: var(--iza-paper);
  border-radius: var(--iza-r-md);
  border-top: 3px solid var(--iza-vermilion);
  display: flex; flex-direction: column; gap: 14px;
  box-shadow: var(--iza-shadow-soft);
}
.iza-job-card__header {
  display: flex; flex-direction: column; gap: 6px;
  padding-bottom: 12px;
  border-bottom: 1px dashed rgba(27,45,92,0.12);
}
.iza-job-card__type {
  font-family: var(--iza-font-gothic);
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  color: var(--iza-vermilion);
  text-transform: uppercase;
}
.iza-job-card__title {
  font-family: var(--iza-font-mincho);
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--iza-night);
  margin: 0;
}
.iza-job-card__count {
  font-family: var(--iza-font-num);
  font-size: 0.86rem;
  color: var(--iza-night-soft);
}
.iza-job-card__action {
  margin-top: auto;
  padding-top: 14px;
}

.iza-recruit-message {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.1rem, 2vw, 1.3rem);
  line-height: 1.9;
  color: var(--iza-night);
  letter-spacing: 0.04em;
  text-align: center;
  margin-bottom: clamp(28px, 4vh, 48px);
}

/* =========================================================================
   42. NEWS / ARTICLE — 一覧 + 個別記事
   ========================================================================= */

.iza-news-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(20px, 2.6vw, 32px);
}
.iza-news-list--compact {
  grid-template-columns: 1fr;
  gap: 14px;
}
.iza-news-card {
  background: var(--iza-paper);
  border-radius: var(--iza-r-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 6px 20px -10px rgba(15,28,61,0.16);
  transition: transform var(--iza-dur-fast) var(--iza-ease-soft),
              box-shadow var(--iza-dur-fast);
}
@media (hover: hover) {
  .iza-news-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 32px -12px rgba(15,28,61,0.26);
  }
}
.iza-news-card__link {
  display: flex; flex-direction: column;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.iza-news-card__meta {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 18px 0;
  flex-wrap: wrap;
}
.iza-news-card__cat {
  display: inline-block;
  padding: 3px 10px;
  font-family: var(--iza-font-gothic);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  border-radius: 2px;
  color: #fff;
  background: var(--iza-night-soft);
}
.iza-news-cat--menu  { background: var(--iza-vermilion); }
.iza-news-cat--sake  { background: var(--iza-lamp); color: var(--iza-night); }
.iza-news-cat--event { background: #5B7CB5; }
.iza-news-cat--info  { background: var(--iza-night-soft); }
.iza-news-card__excerpt {
  padding: 12px 18px 18px;
  font-size: 0.92rem;
  line-height: 1.85;
  color: var(--iza-night);
  margin: 0;
  flex: 1;
}

.iza-news-compact-card {
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: 14px;
  padding: 14px 16px;
  align-items: center;
  background: var(--iza-paper);
  border-radius: 4px;
  border-left: 3px solid var(--iza-lamp);
  text-decoration: none;
  color: inherit;
}
.iza-news-compact-card:hover { background: rgba(242,199,92,0.08); }

.iza-pagination {
  display: flex; justify-content: center; align-items: center;
  gap: 8px;
  margin-top: clamp(32px, 5vh, 48px);
}
.iza-pagination__item {
  display: inline-grid; place-items: center;
  min-width: 40px; height: 40px;
  padding: 0 12px;
  font-family: var(--iza-font-num);
  font-size: 0.9rem;
  color: var(--iza-night);
  text-decoration: none;
  border: 1px solid rgba(27,45,92,0.18);
  border-radius: 4px;
  background: var(--iza-paper);
}
.iza-pagination__item:hover { background: rgba(242,199,92,0.1); }
.iza-pagination__item--current {
  background: var(--iza-night);
  color: var(--iza-lamp);
  border-color: var(--iza-night);
}
.iza-pagination__item--next {
  font-family: var(--iza-font-gothic);
  letter-spacing: 0.08em;
}

/* article (個別記事) */
.iza-article {
  max-width: 760px;
  margin: 0 auto;
  background: var(--iza-paper);
  padding: clamp(32px, 5vw, 64px);
  border-radius: var(--iza-r-md);
  box-shadow: var(--iza-shadow-soft);
}
.iza-article__header {
  margin-bottom: clamp(24px, 4vh, 36px);
  padding-bottom: clamp(16px, 2.4vh, 24px);
  border-bottom: 1px solid rgba(27,45,92,0.1);
}
.iza-article__meta {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.iza-article__date {
  font-family: var(--iza-font-num);
  font-size: 0.86rem;
  color: var(--iza-night-soft);
  letter-spacing: 0.06em;
}
.iza-article__title {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.5;
  color: var(--iza-night);
  margin: 0;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.iza-article__eyecatch {
  margin: 0 0 24px;
  border-radius: var(--iza-r-md);
  overflow: hidden;
}
.iza-article__eyecatch img { width: 100%; height: auto; display: block; }
.iza-article__body {
  font-family: var(--iza-font-gothic);
  font-size: 1rem;
  line-height: 2.05;
  color: var(--iza-night);
}
.iza-article__body h2,
.iza-article-section {
  font-family: var(--iza-font-mincho);
  font-size: 1.35rem;
  font-weight: 700;
  margin: clamp(28px, 4vh, 40px) 0 14px;
  letter-spacing: 0.04em;
  padding-left: 14px;
  border-left: 4px solid var(--iza-lamp);
  color: var(--iza-night);
}
.iza-article__body h3 {
  font-family: var(--iza-font-mincho);
  font-size: 1.1rem;
  font-weight: 700;
  margin: 24px 0 10px;
  color: var(--iza-night);
}
.iza-article__body p { margin: 0 0 16px; }
.iza-article__body strong { color: var(--iza-vermilion); font-weight: 700; }
.iza-article__body em { font-style: normal; background: linear-gradient(transparent 60%, rgba(242,199,92,0.4) 60%); padding: 0 2px; }
.iza-article__body ul,
.iza-article__body ol {
  padding-left: 1.4em;
  margin: 0 0 16px;
}
.iza-article__body li { margin-bottom: 6px; }
.iza-article__body blockquote {
  margin: 20px 0;
  padding: 16px 20px;
  background: rgba(242,199,92,0.08);
  border-left: 3px solid var(--iza-lamp);
  border-radius: 0 4px 4px 0;
  font-family: var(--iza-font-mincho);
  font-style: italic;
  color: var(--iza-night-soft);
}
.iza-article__menu-list,
.iza-article__sake-list {
  list-style: none;
  padding: 0;
  margin: 16px 0;
  display: grid;
  gap: 8px;
}
.iza-article__menu-item {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 10px 14px;
  background: rgba(242,199,92,0.06);
  border-radius: 4px;
  border-bottom: 1px dashed rgba(27,45,92,0.1);
  font-size: 0.94rem;
}
.iza-article__menu-price {
  font-family: var(--iza-font-num);
  font-weight: 600;
  color: var(--iza-vermilion);
}
.iza-article__sake-detail {
  margin: 16px 0;
  padding: 16px 20px;
  background: rgba(242,199,92,0.06);
  border: 1px solid rgba(242,199,92,0.2);
  border-radius: 4px;
  font-size: 0.9rem;
  line-height: 1.85;
}
.iza-article__quote {
  margin: 20px 0;
  padding: 18px 22px;
  background: rgba(193,63,46,0.06);
  border-left: 3px solid var(--iza-vermilion);
  font-family: var(--iza-font-mincho);
  font-style: italic;
  color: var(--iza-night);
  letter-spacing: 0.04em;
  line-height: 1.85;
}
.iza-article__pairing-list {
  list-style: none;
  padding: 0;
  margin: 16px 0;
  display: grid;
  gap: 8px;
}
.iza-article__pairing-list li {
  padding: 10px 14px;
  background: rgba(91,124,181,0.08);
  border-radius: 4px;
  border-left: 3px solid #5B7CB5;
  font-size: 0.92rem;
}
.iza-article__alert {
  margin: 16px 0;
  padding: 14px 18px;
  background: rgba(193,63,46,0.08);
  border-left: 3px solid var(--iza-vermilion);
  border-radius: 0 4px 4px 0;
  font-size: 0.9rem;
  line-height: 1.85;
  color: var(--iza-night);
}

.iza-article__sign {
  margin-top: clamp(28px, 4vh, 40px);
  padding-top: 16px;
  border-top: 1px dashed rgba(27,45,92,0.18);
  font-family: var(--iza-font-mincho);
  font-style: italic;
  color: var(--iza-night-soft);
  text-align: right;
  font-size: 0.92rem;
}
.iza-article__footer {
  margin-top: clamp(32px, 5vh, 48px);
  padding-top: clamp(20px, 3vh, 28px);
  border-top: 1px solid rgba(27,45,92,0.1);
  display: flex; flex-direction: column; gap: 16px;
}
.iza-article__tags {
  display: flex; flex-wrap: wrap;
  gap: 6px;
}
.iza-article__tag {
  display: inline-block;
  padding: 4px 12px;
  font-family: var(--iza-font-gothic);
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  background: rgba(27,45,92,0.06);
  color: var(--iza-night);
  border-radius: var(--iza-r-pill);
  text-decoration: none;
}
.iza-article__tag:hover { background: rgba(242,199,92,0.18); }
.iza-article__nav {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.iza-article-related {
  margin-top: clamp(40px, 6vh, 64px);
  max-width: 1100px;
  margin-inline: auto;
}
.iza-article-related__title {
  font-family: var(--iza-font-mincho);
  font-size: 1.3rem;
  font-weight: 700;
  margin: 0 0 24px;
  text-align: center;
  letter-spacing: 0.06em;
  color: var(--iza-night);
}

/* =========================================================================
   43. LEGAL — terms / privacy
   ========================================================================= */

.iza-legal-doc {
  max-width: 820px;
  margin: 0 auto;
  background: var(--iza-paper);
  padding: clamp(32px, 5vw, 64px);
  border-radius: var(--iza-r-md);
  box-shadow: var(--iza-shadow-soft);
}
.iza-legal-doc__title {
  font-family: var(--iza-font-mincho);
  font-size: clamp(1.4rem, 2.6vw, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  margin: 0 0 8px;
  color: var(--iza-night);
}
.iza-legal-doc__updated {
  font-family: var(--iza-font-num);
  font-size: 0.82rem;
  color: var(--iza-night-soft);
  margin: 0 0 24px;
  letter-spacing: 0.04em;
}
.iza-legal-doc__intro {
  font-family: var(--iza-font-gothic);
  font-size: 0.96rem;
  line-height: 1.95;
  color: var(--iza-night);
  margin: 0 0 32px;
  padding: 16px;
  background: rgba(242,199,92,0.06);
  border-radius: 4px;
}
.iza-legal-doc__footer {
  margin-top: 40px;
  padding-top: 20px;
  border-top: 1px dashed rgba(27,45,92,0.18);
  font-size: 0.86rem;
  color: var(--iza-night-soft);
  font-family: var(--iza-font-gothic);
  line-height: 1.85;
}
.iza-legal-section {
  margin-bottom: clamp(24px, 4vh, 36px);
}
.iza-legal-section h2 {
  font-family: var(--iza-font-mincho);
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0 0 12px;
  padding-left: 12px;
  border-left: 3px solid var(--iza-lamp);
  letter-spacing: 0.04em;
  color: var(--iza-night);
}
.iza-legal-section p {
  font-size: 0.94rem;
  line-height: 1.95;
  color: var(--iza-night);
  margin: 0 0 12px;
}
.iza-legal-section ol,
.iza-legal-section ul {
  padding-left: 1.6em;
  margin: 8px 0 12px;
}
.iza-legal-section li {
  font-size: 0.92rem;
  line-height: 1.85;
  color: var(--iza-night);
  margin-bottom: 6px;
}
.iza-legal-section-item {
  margin-bottom: 12px;
}

/* =========================================================================
   44. SUB-PAGE RESPONSIVE
   ========================================================================= */

@media (max-width: 900px) {
  .iza-about-story,
  .iza-staff-feature,
  .iza-access-layout,
  .iza-service-block {
    grid-template-columns: 1fr;
  }
  .iza-service-block--reverse .iza-service-block__media { order: 0; }
  .iza-form-row { grid-template-columns: 1fr; }
  .iza-info-table th { width: 38%; }
  .iza-timeline::before { left: 22px; }
  .iza-timeline__item { grid-template-columns: 60px 1fr; gap: 16px; }
  .iza-timeline__item::before { left: 18px; }
}

@media (max-width: 560px) {
  .iza-page-hero {
    min-height: 220px;
    padding: calc(var(--iza-header-h) + 28px) var(--iza-px) 28px;
  }
  .iza-page-hero__title { font-size: clamp(1.5rem, 6vw, 1.9rem); }
  .iza-article {
    padding: 24px 18px;
  }
  .iza-faq-item__question { font-size: 0.95rem; }
  .iza-section { padding: clamp(40px, 6vh, 56px) var(--iza-px); }
}

/* =========================================================================
   45. Debug helpers (開発時のみ、本番 remove)
   ========================================================================= */

/* [data-iza-debug] * { outline: 1px solid rgba(193,63,46,0.3); } */

/* --------------------------------------------------------------------------
   30. WP Block FSE Header & Navigation
   -------------------------------------------------------------------------- */

html { overflow-x: hidden; }
.wp-site-blocks { overflow-x: hidden; }

.irodori-header {
  position: sticky;
  top: 0; left: 0; right: 0;
  width: 100%;
  z-index: 800;
  background: transparent;
  color: #fff;
  transition: background 0.4s ease, box-shadow 0.4s ease, color 0.4s ease;
}
.irodori-header.is-scrolled {
  background: rgba(255, 255, 255, 0.97);
  box-shadow: var(--iza-shadow-soft);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--iza-text);
}
.irodori-header__inner {
  height: 72px;
  padding: 0 clamp(20px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.irodori-header__logo .wp-block-site-logo img {
  max-height: 44px;
  width: auto;
}
.irodori-header .wp-block-navigation-item__content {
  color: inherit;
  text-decoration: none;
  font-size: 13px;
  letter-spacing: 0.06em;
  padding: 6px 10px;
  transition: opacity 0.2s;
  white-space: nowrap;
}
.irodori-header .wp-block-navigation-item__content:hover { opacity: 0.7; }
.irodori-header .wp-block-navigation .wp-block-navigation-item { list-style: none; }
.irodori-header__cta-btn {
  display: inline-flex;
  align-items: center;
  padding: 10px 22px;
  background: #1a5276;
  color: #fff !important;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  white-space: nowrap;
  text-decoration: none;
  transition: opacity 0.2s;
}
.irodori-header__cta-btn:hover { opacity: 0.85; }
.irodori-header .wp-block-navigation__responsive-container-open,
.irodori-header .wp-block-navigation__responsive-container-close { display: none !important; }
.irodori-header .wp-block-navigation__responsive-container {
  display: contents !important;
  background: none !important;
}
.wp-site-blocks > * + * { margin-block-start: 0 !important; }
footer .wp-block-navigation { flex-direction: column !important; }
.wp-block-group.irodori-section.is-layout-constrained > *,
.wp-block-group.irodori-section > * {
  max-width: 100% !important;
  width: 100%;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.wp-block-post-content > .wp-block-group.irodori-section,
.wp-block-post-content > .wp-block-group.irodori-section + .wp-block-group.irodori-section {
  margin-block: 0;
}
@media (max-width: 1100px) {
  .irodori-header__toggle {
    display: flex; flex-direction: column; justify-content: center; align-items: center;
    gap: 6px; width: 34px; height: 34px; cursor: pointer; position: relative;
    z-index: 10001; flex-shrink: 0;
  }
  .irodori-header__toggle span {
    display: block; width: 22px; height: 1.8px;
    background: currentColor; transition: transform 0.3s ease, opacity 0.3s ease;
  }
  .irodori-header__toggle-input { display: none; }
  .wp-block-group.irodori-header__nav {
    display: none; position: fixed; inset: 0;
    background: rgba(255,255,255,0.98); z-index: 10000;
    flex-direction: column; align-items: center; justify-content: center; padding: 40px;
  }
  #irodori-nav-toggle:checked ~ .wp-block-group.irodori-header__nav { display: flex; }
  #irodori-nav-toggle:checked ~ label.irodori-header__toggle span:nth-child(1) {
    transform: translateY(7.8px) rotate(45deg);
  }
  #irodori-nav-toggle:checked ~ label.irodori-header__toggle span:nth-child(2) { opacity: 0; }
  #irodori-nav-toggle:checked ~ label.irodori-header__toggle span:nth-child(3) {
    transform: translateY(-7.8px) rotate(-45deg);
  }
  .irodori-header--hamburger .irodori-header__nav .wp-block-navigation {
    display: flex !important; flex-direction: column; align-items: center; width: 100%;
  }
  .irodori-header--hamburger .irodori-header__nav .wp-block-navigation__container {
    display: flex; flex-direction: column; align-items: center;
    gap: 2rem; list-style: none; margin: 0; padding: 0;
  }
  .irodori-header--hamburger .irodori-header__nav .wp-block-navigation__container a {
    font-size: clamp(18px, 4vw, 24px); font-weight: 600; letter-spacing: 0.06em;
    color: var(--iza-text);
  }
  .irodori-header__cta { margin-top: 32px; }
}

/* ===== WP 7.0 Bug Fixes ===== */

/* ---------------------------------------------------------------
   WP 7.0 Fix: ナビゲーション デスクトップ表示強制
   親テーマ .irodori-header--hamburger が position:fixed/opacity:0 を
   全ブレークポイントに適用するため !important で解除
   --------------------------------------------------------------- */
@media (min-width: 1101px) {
  .irodori-header .wp-block-group.irodori-header__nav {
    position: relative !important;
    opacity: 1 !important;
    visibility: visible !important;
    inset: auto !important;
    background: none !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 24px !important;
    padding: 0 !important;
    z-index: auto !important;
  }
  .irodori-header__toggle {
    display: none !important;
  }
}

/* ---------------------------------------------------------------
   WP 7.0 Fix: ヒーロー背景 全幅解除
   WP is-layout-constrained が max-width:1280px/margin:auto を
   hero bg 要素に適用するため強制解除
   --------------------------------------------------------------- */
.is-layout-constrained > [class*="-hero__bg"],
.is-layout-constrained > [class*="-hero-bg"],
.is-layout-constrained > [class*="-hero__slide"],
.is-layout-constrained > [class*="-hero__image"],
.is-layout-constrained > [class*="-hero__visual"] {
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
