/*
Theme Name: 焼鳥 康O
Theme URI: https://tabelog.com/osaka/A2701/A270101/27152566/
Author: 焼鳥 康O
Description: 焼鳥 康O（やすお）公式サイト用テーマ。北新地の隠れ家・炭火の世界観。共通部（ナビ・フッター・フォント・CSS・JS・画像）をテーマ側に集約し、各固定ページには中身のHTMLだけを貼り付けて運用します。
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: yasuo
*/

/* =========================================================
   焼鳥 康O — 炭火の隠れ家 / Design tokens & base
   ========================================================= */

:root {
  /* warm near-black ground */
  --bg:        #14100b;
  --bg-2:      #1b150e;
  --bg-3:      #241c13;
  --bg-panel:  #1f1810;

  /* warm off-white inks */
  --ink:       #ece2d2;
  --ink-soft:  #c4b59c;
  --ink-mute:  #8d7e67;

  /* ember gold accent */
  --gold:      #c9a35e;
  --gold-soft: #ddc18a;
  --gold-deep: #9c7c40;
  --ember:     #b8492f;

  --line:      rgba(201,163,94,0.20);
  --line-soft: rgba(201,163,94,0.10);
  --line-ink:  rgba(236,226,210,0.10);

  --font-jp:   "Shippori Mincho B1", "Hiragino Mincho ProN", serif;
  --font-sans: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", sans-serif;
  --font-lat:  "Cormorant Garamond", serif;

  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 64px);

  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* accent override hook (Tweaks) */
[data-accent="copper"] { --gold:#c07b45; --gold-soft:#d99a66; --gold-deep:#945a30; --line:rgba(192,123,69,0.22); --line-soft:rgba(192,123,69,0.10); }
[data-accent="silver"] { --gold:#c9c4b6; --gold-soft:#e3ded2; --gold-deep:#8f897a; --line:rgba(201,196,182,0.20); --line-soft:rgba(201,196,182,0.10); }

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

html { -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-jp);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.85;
  font-weight: 400;
  letter-spacing: 0.02em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

[data-font="gothic"] body,
[data-font="gothic"] .jp { font-family: var(--font-sans); letter-spacing: 0.04em; }

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

::selection { background: var(--gold); color: var(--bg); }

/* film grain / warm vignette over everything */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(201,163,94,0.06), transparent 55%),
    radial-gradient(100% 60% at 50% 120%, rgba(184,73,47,0.05), transparent 60%);
}

/* ---------- typographic helpers ---------- */
.lat { font-family: var(--font-lat); font-weight: 500; }
.kicker {
  font-family: var(--font-lat);
  font-size: 0.78rem;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  display: inline-block;
}
.kicker-jp {
  font-size: 0.72rem;
  letter-spacing: 0.5em;
  color: var(--gold);
}

.vlabel {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  letter-spacing: 0.5em;
  font-size: 0.8rem;
  color: var(--ink-mute);
}

.hr-gold {
  width: 56px; height: 1px;
  background: linear-gradient(90deg, var(--gold), transparent);
  border: none;
}

/* ---------- layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }
.section { position: relative; z-index: 2; }

.eyebrow-row { display: flex; align-items: center; gap: 18px; margin-bottom: 26px; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 34px;
  font-family: var(--font-jp);
  font-size: 0.98rem;
  letter-spacing: 0.18em;
  border: 1px solid var(--gold);
  color: var(--gold-soft);
  background: transparent;
  border-radius: 0;
  transition: all 0.5s var(--ease);
  position: relative;
  overflow: hidden;
}
.btn::after {
  content:""; position:absolute; inset:0;
  background: var(--gold); transform: scaleX(0); transform-origin: left;
  transition: transform 0.5s var(--ease); z-index:-1;
}
.btn:hover { color: var(--bg); }
.btn:hover::after { transform: scaleX(1); }
.btn .arrow { font-family: var(--font-lat); }

.btn-solid {
  background: var(--gold); color: var(--bg); border-color: var(--gold);
}
.btn-solid::after { background: var(--gold-soft); }
.btn-solid:hover { color: var(--bg); }

/* ---------- image placeholder ---------- */
.ph {
  position: relative;
  background-color: var(--bg-2);
  background-image:
    repeating-linear-gradient(135deg,
      rgba(201,163,94,0.05) 0, rgba(201,163,94,0.05) 1px,
      transparent 1px, transparent 11px);
  border: 1px solid var(--line-soft);
  display: grid; place-items: center;
  overflow: hidden;
}
.ph::after {
  content: attr(data-label);
  font-family: var(--font-lat);
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 6px 12px;
  border: 1px solid var(--line-soft);
  background: rgba(20,16,11,0.5);
}

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

/* ---------- nav ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px var(--gut);
  transition: background 0.5s var(--ease), padding 0.5s var(--ease), border-color 0.5s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(17,13,9,0.82);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line-soft);
  padding-block: 12px;
}
.brand { display: flex; align-items: center; gap: 12px; cursor: pointer; }
.brand-yakitori {
  font-family: var(--font-jp); font-weight: 600;
  font-size: 1.18rem; letter-spacing: 0.18em; color: var(--ink);
  white-space: nowrap;
}
.brand-logo {
  height: 42px; width: auto;
  filter: brightness(1.45) drop-shadow(0 0 1px rgba(0,0,0,0.4));
  transition: height 0.5s var(--ease);
}
.nav.scrolled .brand-logo { height: 36px; }
.footer-logo { height: 64px; filter: brightness(1.4); }
.brand .mark {
  font-family: var(--font-jp); font-weight: 600;
  font-size: 1.32rem; letter-spacing: 0.14em; color: var(--ink);
  white-space: nowrap;
}
.brand .mark em { font-family: var(--font-lat); font-style: normal; color: var(--gold); }
.brand .sub { font-family: var(--font-lat); font-size: 0.66rem; letter-spacing: 0.34em; text-transform: uppercase; color: var(--ink-mute); }

.nav-links { display: flex; align-items: center; gap: 34px; }
.nav-link {
  position: relative; font-size: 0.92rem; letter-spacing: 0.14em; color: var(--ink-soft);
  padding-block: 6px; transition: color 0.4s var(--ease); background: none; border: none;
}
.nav-link .en { display:block; font-family: var(--font-lat); font-size: 0.6rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-mute); margin-top: 2px; transition: color 0.4s var(--ease); }
.nav-link::after {
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background: var(--gold);
  transition: width 0.4s var(--ease);
}
.nav-link:hover, .nav-link.active { color: var(--ink); }
.nav-link:hover .en, .nav-link.active .en { color: var(--gold); }
.nav-link.active::after, .nav-link:hover::after { width: 100%; }
.nav-cta { margin-left: 8px; }

.nav-toggle { display: none; background: none; border: none; flex-direction: column; gap: 6px; padding: 8px; }
.nav-toggle span { width: 26px; height: 1.5px; background: var(--ink); transition: transform .4s var(--ease), opacity .3s; }
.nav-toggle.open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

/* mobile menu */
.mobile-menu {
  position: fixed; inset: 0; z-index: 45;
  background: rgba(15,11,7,0.97);
  backdrop-filter: blur(8px);
  display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 6px;
  opacity: 0; pointer-events: none; transition: opacity 0.5s var(--ease);
}
.mobile-menu.open { opacity: 1; pointer-events: auto; }
.mobile-menu .m-link { font-size: 1.5rem; letter-spacing: 0.18em; color: var(--ink); padding: 14px; background:none; border:none; }
.mobile-menu .m-link .en { display:block; text-align:center; font-family: var(--font-lat); font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); margin-top: 4px; }

/* ---------- footer ---------- */
.footer { position: relative; z-index: 2; border-top: 1px solid var(--line-soft); background: var(--bg-2); margin-top: 0; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; padding-block: 72px; }
.footer h4 { font-size: 0.78rem; letter-spacing: 0.3em; color: var(--gold); font-weight: 500; margin-bottom: 18px; }
.footer p, .footer a { color: var(--ink-soft); font-size: 0.92rem; line-height: 2; }
.footer-bottom { display:flex; justify-content: space-between; align-items:center; padding-block: 24px; border-top: 1px solid var(--line-soft); font-size: 0.74rem; color: var(--ink-mute); letter-spacing: 0.1em; }

/* ---------- page heading ---------- */
.page-hero { padding-top: 168px; padding-bottom: 64px; position: relative; }
.page-hero .ttl-jp { font-size: clamp(2.4rem, 6vw, 4rem); font-weight: 600; letter-spacing: 0.12em; line-height: 1.2; }
.page-hero .ttl-en { font-family: var(--font-lat); font-size: 0.86rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--gold); display:block; margin-top: 14px; }

/* ---------- generic section title ---------- */
.sec-title { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 600; line-height: 1.35; letter-spacing: 0.06em; }
.lead { font-size: 1.04rem; color: var(--ink-soft); line-height: 2.2; max-width: 60ch; }

@media (max-width: 860px) {
  .nav-links { display: none; }
  .nav-toggle { display: flex; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; padding-block: 56px; }
  .footer-bottom { flex-direction: column; gap: 12px; }
}


/* =========================================================
   焼鳥 康O — page & hero styles
   ========================================================= */

/* ---- shared accents ---- */
.num { font-feature-settings: "lnum"; }

.link-more {
  display: inline-flex; align-items: center; gap: 10px;
  background: none; border: none; color: var(--gold-soft);
  font-family: var(--font-jp); font-size: 0.96rem; letter-spacing: 0.1em;
  margin-top: 30px; padding: 4px 0;
  border-bottom: 1px solid var(--line);
  transition: gap 0.4s var(--ease), color 0.4s var(--ease), border-color 0.4s var(--ease);
}
.link-more:hover { gap: 18px; color: var(--gold); border-color: var(--gold); }
.link-more .lat { font-size: 1.1rem; }

/* ============ HERO SLIDESHOW ============ */
.hero-slides { position: absolute; inset: 0; overflow: hidden; }
.hero-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.6s var(--ease); }
.hero-slide.on { opacity: 1; }
.hero-slide img { width: 100%; height: 100%; object-fit: cover; }
.hero-slide .ph { width: 100%; height: 100%; border: none; }
/* gentle ken-burns on the active slide */
@media (prefers-reduced-motion: no-preference) {
  .hero-slide img { transform: scale(1.06); transition: opacity 1.6s var(--ease), transform 8s linear; }
  .hero-slide.on img { transform: scale(1); }
}
.hero-slide-ph::after { font-size: 0.66rem; }
.hero-b-slides { position: absolute; inset: 0; }

/* ============ HERO A — centered ============ */
.hero { position: relative; }
.hero-a { height: 100vh; min-height: 640px; display: grid; place-items: center; padding-top: 78px; }
.hero-a-bg { position: absolute; inset: 0; border: none; }
.hero-a-scrim { position: absolute; inset: 0; background:
  radial-gradient(120% 90% at 50% 40%, rgba(20,16,11,0.45), rgba(20,16,11,0.86) 80%),
  linear-gradient(180deg, rgba(20,16,11,0.55), rgba(20,16,11,0.3) 40%, rgba(20,16,11,0.9)); }
.hero-a-frame { position: absolute; inset: clamp(18px, 3vw, 40px); border: 1px solid var(--line); pointer-events: none; }
.hero-a-inner { position: relative; z-index: 3; text-align: center; padding-inline: 24px; display: flex; flex-direction: column; align-items: center; }
.hero-a-yakitori { font-size: clamp(1rem, 2.6vw, 1.4rem); font-weight: 600; letter-spacing: 0.6em; color: var(--ink); margin: 20px 0 4px; padding-left: 0.6em; }
.hero-a-logo { width: clamp(240px, 40vw, 470px); filter: brightness(1.5) drop-shadow(0 6px 40px rgba(0,0,0,0.5)); }
.hero-a-title { font-size: clamp(3.4rem, 11vw, 8rem); font-weight: 600; letter-spacing: 0.12em; line-height: 1; margin-top: 26px; white-space: nowrap; }
.hero-a-title em { font-family: var(--font-lat); font-style: normal; color: var(--gold); }
.hero-a-kana { font-size: clamp(0.8rem, 2.4vw, 1.05rem); letter-spacing: 0.5em; color: var(--ink-soft); margin-top: 14px; padding-left: 0.5em; }
.hero-a-rule { width: 60px; height: 1px; background: var(--gold); margin: 22px auto; }
.hero-a-tag { font-size: clamp(0.98rem, 2.6vw, 1.25rem); line-height: 2; color: var(--ink); }
.hero-a-cta { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-top: 42px; }

.scroll-cue { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.scroll-cue span { font-family: var(--font-lat); font-size: 0.62rem; letter-spacing: 0.34em; color: var(--ink-mute); }
.scroll-cue i { width: 1px; height: 36px; background: linear-gradient(var(--gold), transparent); animation: cueDrop 2.4s var(--ease) infinite; transform-origin: top; }
@media (max-height: 760px) { .scroll-cue { display: none; } }
@keyframes cueDrop { 0%{transform:scaleY(0);opacity:0;} 40%{transform:scaleY(1);opacity:1;} 100%{transform:scaleY(1) translateY(46px);opacity:0;} }

/* ============ HERO B — split ============ */
.hero-b { min-height: 100vh; display: grid; grid-template-columns: 1fr 0.92fr; }
.hero-b-text { display: flex; flex-direction: column; justify-content: center; padding: 130px var(--gut) 80px; }
.hero-b-logo { width: clamp(220px, 26vw, 340px); margin: 18px 0 6px; filter: brightness(1.5) drop-shadow(0 4px 24px rgba(0,0,0,0.4)); }
.hero-b-title { font-size: clamp(2.6rem, 6vw, 5rem); font-weight: 600; line-height: 1.18; letter-spacing: 0.06em; margin-top: 18px; }
.hero-b-lead { font-size: clamp(1rem, 2vw, 1.15rem); line-height: 2.1; color: var(--ink-soft); margin-top: 30px; max-width: 46ch; }
.hero-b-meta { display: flex; gap: 40px; margin: 42px 0; }
.hero-b-meta > div { display: flex; flex-direction: column; }
.hero-b-meta .num { font-family: var(--font-lat); font-size: 2.6rem; color: var(--gold); line-height: 1; }
.hero-b-meta small { color: var(--ink-mute); font-size: 0.8rem; letter-spacing: 0.1em; margin-top: 6px; }
.hero-b-media { position: relative; }
.hero-b-vname { position: absolute; top: 50%; left: 36px; transform: translateY(-50%); z-index: 4; writing-mode: vertical-rl; }
.hero-b-vname span { font-size: clamp(2rem, 4vw, 3.4rem); font-weight: 600; letter-spacing: 0.2em; color: var(--ink); text-shadow: 0 2px 30px rgba(0,0,0,0.6); }

/* ============ HERO C — minimal ============ */
.hero-c { min-height: 100vh; display: grid; grid-template-rows: 1fr auto; position: relative; overflow: hidden; }
.hero-c-glow { position: absolute; inset: 0; background: radial-gradient(60% 50% at 50% 42%, rgba(184,73,47,0.22), transparent 70%), radial-gradient(40% 40% at 50% 44%, rgba(201,163,94,0.16), transparent 72%); }
.hero-c-side { position: absolute; top: 0; bottom: 0; display: flex; align-items: center; z-index: 3; }
.hero-c-left { left: clamp(16px, 3vw, 44px); }
.hero-c-right { right: clamp(16px, 3vw, 44px); }
.hero-c-side span { writing-mode: vertical-rl; letter-spacing: 0.4em; font-size: 0.74rem; color: var(--ink-mute); }
.hero-c-right span { writing-mode: vertical-rl; }
.hero-c-inner { position: relative; z-index: 4; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding-top: 80px; }
.hero-c-yakitori { font-size: clamp(1rem, 2.6vw, 1.4rem); font-weight: 600; letter-spacing: 0.6em; color: var(--ink); margin-bottom: 10px; padding-left: 0.6em; }
.hero-c-logo { width: clamp(300px, 52vw, 640px); filter: brightness(1.55) drop-shadow(0 8px 50px rgba(184,73,47,0.25)); }
.hero-c-title { font-size: clamp(4rem, 16vw, 12rem); font-weight: 700; letter-spacing: 0.04em; line-height: 0.92; white-space: nowrap; }
.hero-c-title em { font-family: var(--font-lat); font-style: normal; color: var(--gold); display: inline-block; }
.hero-c-tag { font-size: clamp(1rem, 3vw, 1.5rem); letter-spacing: 0.24em; color: var(--ink-soft); margin-top: 28px; }
.hero-c-strip { position: relative; z-index: 3; display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; height: clamp(120px, 18vh, 200px); border-top: 1px solid var(--line-soft); }
.hero-c-strip .ph { border: none; height: 100%; }
.hero-c-cell { position: relative; overflow: hidden; height: 100%; }
.hero-c-cell img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease); }
.hero-c-cell:hover img { transform: scale(1.06); }
.hero-c-cell .ph { width: 100%; height: 100%; }

/* ============ CONCEPT ============ */
.concept { padding-block: clamp(90px, 12vw, 160px); }
.concept-grid { display: grid; grid-template-columns: 80px 1fr; gap: 0; }
.concept-side { position: relative; }
.concept-side .vlabel { position: sticky; top: 140px; }
.concept-body { max-width: 60ch; }

/* ============ STAT BAND ============ */
.statband { border-block: 1px solid var(--line-soft); background: var(--bg-2); }
.statband-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 54px 20px; text-align: center; border-left: 1px solid var(--line-soft); }
.stat:first-child { border-left: none; }
.stat .num { font-family: var(--font-lat); font-size: clamp(2.6rem, 5vw, 3.8rem); color: var(--gold); line-height: 1; display: block; }
.stat p { color: var(--ink-soft); font-size: 0.9rem; letter-spacing: 0.08em; margin-top: 12px; }

/* ============ JIDORI FEATURE (home) ============ */
.jidori-feat { padding-block: clamp(90px, 12vw, 150px); }
.jidori-feat-head { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: end; margin-bottom: 56px; }
.jidori-marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.jidori-track { display: flex; gap: 16px; width: max-content; animation: marquee 42s linear infinite; }
.jidori-marquee:hover .jidori-track { animation-play-state: paused; }
@keyframes marquee { to { transform: translateX(-50%); } }
.jchip { flex: none; display: flex; flex-direction: column; gap: 8px; padding: 26px 32px; border: 1px solid var(--line-soft); background: var(--bg-2); min-width: 180px; transition: border-color 0.4s, background 0.4s; }
.jchip:hover { border-color: var(--gold); background: var(--bg-3); }
.jchip-area { font-size: 0.7rem; letter-spacing: 0.3em; color: var(--gold); }
.jchip-name { font-size: 1.25rem; font-weight: 600; letter-spacing: 0.06em; }

/* ============ COURSE FEATURE (home) ============ */
.course-feat { padding-block: clamp(80px, 10vw, 140px); background: var(--bg-2); border-block: 1px solid var(--line-soft); }
.course-feat-grid { display: grid; grid-template-columns: 0.9fr 1fr; gap: clamp(40px, 6vw, 90px); align-items: center; }
.course-feat-media { position: relative; aspect-ratio: 4/5; }
.course-feat-img { width: 100%; height: 100%; object-fit: cover; }
.course-feat-badge { position: absolute; bottom: -24px; right: -24px; background: var(--bg); border: 1px solid var(--gold); padding: 22px 30px; display: flex; flex-direction: column; align-items: center; }
.course-feat-badge .num { font-family: var(--font-lat); font-size: 2.4rem; color: var(--gold); line-height: 1; }
.course-feat-badge small { color: var(--ink-soft); font-size: 0.8rem; letter-spacing: 0.1em; margin-top: 4px; }

/* ============ CTA BAND ============ */
.cta-band { position: relative; padding-block: clamp(100px, 14vw, 180px); overflow: hidden; text-align: center; }
.cta-glow { position: absolute; inset: 0; background: radial-gradient(60% 80% at 50% 60%, rgba(184,73,47,0.16), transparent 70%), radial-gradient(40% 60% at 50% 50%, rgba(201,163,94,0.12), transparent 72%); }
.cta-inner { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; }
.cta-title { font-size: clamp(2.2rem, 6vw, 4rem); font-weight: 600; line-height: 1.25; letter-spacing: 0.06em; margin-top: 22px; }
.cta-sub { color: var(--ink-soft); font-size: 1.02rem; line-height: 2; margin-top: 24px; max-width: 46ch; }
.cta-actions { display: flex; gap: 16px; flex-wrap: wrap; justify-content: center; margin-top: 42px; }

/* ============ OCCASIONS (home) ============ */
.occasions { padding-block: clamp(90px, 12vw, 150px); }
.occasions-head { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: end; margin-bottom: 56px; }
.occasions-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); }
.occasion-card { background: var(--bg); padding: 40px 32px 44px; display: flex; flex-direction: column; gap: 12px; transition: background 0.5s var(--ease); }
.occasion-card:hover { background: var(--bg-2); }
.occasion-no { font-family: var(--font-lat); font-size: 1.3rem; color: var(--gold-deep); margin-bottom: 6px; }
.occasion-jp { font-size: 1.32rem; font-weight: 600; letter-spacing: 0.05em; display: flex; flex-direction: column; gap: 8px; }
.occasion-tag { font-size: 0.66rem; letter-spacing: 0.1em; color: var(--gold); border: 1px solid var(--line); padding: 3px 10px; align-self: flex-start; font-weight: 400; white-space: nowrap; }
.occasion-card p { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.95; }

/* ============ STORY (about) ============ */
.story { position: relative; padding-block: clamp(90px, 13vw, 170px); background: var(--bg-2); border-block: 1px solid var(--line-soft); overflow: hidden; }
.story-glow { position: absolute; inset: 0; background: radial-gradient(55% 70% at 50% 50%, rgba(184,73,47,0.12), transparent 70%); }
.story-inner { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; text-align: center; }
.story-mark { font-family: var(--font-jp); font-weight: 600; font-size: clamp(3.4rem, 9vw, 6rem); letter-spacing: 0.1em; margin: 26px 0 34px; line-height: 1; white-space: nowrap; }
.story-mark .lat { font-family: var(--font-lat); color: var(--gold); font-style: normal; }
.story-lines { max-width: 52ch; display: flex; flex-direction: column; gap: 14px; }
.story-lines p { font-size: clamp(1.05rem, 2.4vw, 1.3rem); line-height: 2.1; color: var(--ink); letter-spacing: 0.04em; }
.story-lines p:last-child { color: var(--ink-soft); margin-top: 6px; }

/* ============ ABOUT ============ */
.about-intro { padding-bottom: clamp(80px, 10vw, 130px); }
.about-intro-grid { display: grid; grid-template-columns: 0.8fr 1fr; gap: clamp(40px, 6vw, 84px); align-items: center; }
.about-intro-media { aspect-ratio: 4/5; overflow: hidden; }
.about-intro-img { width: 100%; height: 100%; object-fit: cover; }
.values { padding-block: clamp(70px, 9vw, 120px); background: var(--bg-2); border-block: 1px solid var(--line-soft); }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); }
.value-card {
  position: relative;
  background-color: var(--bg-2);
  background-size: cover;
  background-position: center;
  padding: 44px 38px;
  min-height: 380px;
  display: flex; flex-direction: column; gap: 14px; justify-content: flex-end;
  isolation: isolate;
}
.value-card::before {
  content: "";
  position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(14,10,6,0.20) 0%, rgba(14,10,6,0.38) 42%, rgba(14,10,6,0.84) 100%);
  transition: background 0.6s var(--ease);
}
.value-card:hover::before {
  background: linear-gradient(180deg, rgba(14,10,6,0.06) 0%, rgba(14,10,6,0.24) 42%, rgba(14,10,6,0.76) 100%);
}
.value-card > * { position: relative; text-shadow: 0 1px 10px rgba(0,0,0,0.9), 0 0 26px rgba(0,0,0,0.65); }
.value-card .value-num { margin-bottom: auto; }
.value-num { font-family: var(--font-lat); font-size: 1.6rem; color: var(--gold-deep); }
.value-jp { font-size: 1.4rem; font-weight: 600; letter-spacing: 0.05em; margin-top: 4px; }
.value-card p { color: var(--ink); line-height: 2; font-size: 0.95rem; }

.jidori-list { padding-block: clamp(80px, 10vw, 130px); }
.jidori-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border-top: 1px solid var(--line-soft); }
.jidori-item { display: flex; gap: 24px; padding: 28px 24px; border-bottom: 1px solid var(--line-soft); align-items: baseline; transition: background 0.4s; }
.jidori-item:nth-child(odd) { border-right: 1px solid var(--line-soft); }
.jidori-item:hover { background: var(--bg-2); }
.ji-no { font-family: var(--font-lat); font-size: 1.1rem; color: var(--gold-deep); min-width: 32px; }
.ji-top { display: flex; align-items: baseline; gap: 16px; }
.ji-name { font-size: 1.3rem; font-weight: 600; letter-spacing: 0.05em; }
.ji-area { font-size: 0.74rem; letter-spacing: 0.2em; color: var(--gold); padding: 2px 10px; border: 1px solid var(--line); }
.ji-note { color: var(--ink-mute); font-size: 0.9rem; margin-top: 6px; }

/* ============ MENU ============ */
.menu-course { padding-block: clamp(20px, 4vw, 50px) clamp(70px, 9vw, 120px); }
.course-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; padding-bottom: 40px; border-bottom: 1px solid var(--line); margin-bottom: 20px; flex-wrap: wrap; }
.course-name { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 600; letter-spacing: 0.06em; margin-top: 14px; }
.course-note { color: var(--ink-mute); margin-top: 10px; letter-spacing: 0.08em; }
.course-price { text-align: right; white-space: nowrap; }
.course-price .num { font-family: var(--font-lat); font-size: clamp(3rem, 7vw, 4.6rem); color: var(--gold); line-height: 1; }
.course-price small { display: block; color: var(--ink-soft); letter-spacing: 0.1em; margin-top: 4px; }

.course-flow { display: flex; flex-direction: column; }
.flow-row { display: grid; grid-template-columns: 64px 1fr; gap: 20px; padding: 26px 0; border-bottom: 1px solid var(--line-soft); align-items: baseline; }
.flow-no { font-family: var(--font-lat); font-size: 1.2rem; color: var(--gold-deep); }
.flow-titles { display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; }
.flow-jp { font-size: 1.5rem; font-weight: 600; letter-spacing: 0.06em; }
.flow-en { font-size: 0.86rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold); white-space: nowrap; }
.flow-tag { font-size: 0.7rem; letter-spacing: 0.14em; color: var(--ink-mute); padding: 2px 10px; border: 1px solid var(--line-soft); }
.flow-d { color: var(--ink-soft); margin-top: 8px; line-height: 1.9; }
.menu-disclaimer { color: var(--ink-mute); font-size: 0.84rem; margin-top: 28px; letter-spacing: 0.04em; }

.menu-drinks { padding-block: clamp(70px, 9vw, 120px); background: var(--bg-2); border-top: 1px solid var(--line-soft); }
.drinks-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); }
.drink-card { background: var(--bg-2); padding: 38px 30px; display: flex; flex-direction: column; gap: 12px; }
.drink-jp { font-size: 1.4rem; font-weight: 600; letter-spacing: 0.05em; }
.drink-card p { color: var(--ink-soft); font-size: 0.9rem; line-height: 1.9; }

/* ============ INFO ============ */
.info-main { padding-block: clamp(20px, 4vw, 50px) clamp(70px, 9vw, 120px); }
.info-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(40px, 6vw, 80px); }
.info-row { display: grid; grid-template-columns: 120px 1fr; gap: 24px; padding: 22px 0; border-bottom: 1px solid var(--line-soft); }
.info-row:first-child { border-top: 1px solid var(--line-soft); }
.info-k { color: var(--gold); font-size: 0.92rem; letter-spacing: 0.14em; }
.info-v { color: var(--ink); line-height: 1.8; }
.info-aside { display: flex; flex-direction: column; gap: 30px; }
.info-map-cap { padding: 22px; border: 1px solid var(--line-soft); border-top: none; }
.info-map-frame { display: block; width: 100%; height: 300px; border: 1px solid var(--line-soft); border-bottom: none; filter: grayscale(0.3) contrast(0.95) brightness(0.9); }
.info-map-cap .vlabel { color: var(--gold); font-size: 0.7rem; }
.info-map-cap p { color: var(--ink-soft); font-size: 0.88rem; line-height: 1.9; margin-top: 10px; }
.info-hours { border: 1px solid var(--line-soft); padding: 28px; }
.info-hours h4 { font-size: 0.78rem; letter-spacing: 0.3em; color: var(--gold); margin-bottom: 18px; }
.hours-row { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--line-soft); }
.hours-row:last-of-type { border-bottom: none; }

/* ============ FAQ ============ */
.faq { padding-block: clamp(70px, 9vw, 120px); background: var(--bg-2); border-top: 1px solid var(--line-soft); }
.faq-list { border-top: 1px solid var(--line-soft); }
.faq-item { border-bottom: 1px solid var(--line-soft); }
.faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 20px; background: none; border: none; padding: 26px 0; text-align: left; color: var(--ink); font-family: var(--font-jp); font-size: 1.12rem; letter-spacing: 0.04em; }
.faq-plus { font-family: var(--font-lat); font-size: 1.6rem; color: var(--gold); transition: transform 0.4s; }
.faq-item.open .faq-plus { transform: rotate(180deg); }
.faq-a { overflow: hidden; transition: max-height 0.5s var(--ease); }
.faq-a p { color: var(--ink-soft); line-height: 2; padding-bottom: 26px; max-width: 70ch; }

/* ============ RESERVE ============ */
.reserve { padding-block: clamp(20px, 4vw, 40px) clamp(80px, 10vw, 130px); }
.reserve-grid { display: grid; grid-template-columns: 1.5fr 0.9fr; gap: clamp(36px, 5vw, 70px); align-items: start; }
.reserve-form { display: flex; flex-direction: column; gap: 26px; }
.field-block { display: flex; flex-direction: column; gap: 10px; }
.field-row { display: grid; gap: 26px; }
.field-row.two { grid-template-columns: 1fr 1fr; }
.field-label { font-size: 0.9rem; letter-spacing: 0.12em; color: var(--ink-soft); display: flex; align-items: center; gap: 10px; }
.field-label em { font-style: normal; font-size: 0.66rem; letter-spacing: 0.1em; color: var(--ember); border: 1px solid rgba(184,73,47,0.4); padding: 1px 8px; }
.field-hint { font-size: 0.78rem; color: var(--ink-mute); }
.fld { background: var(--bg-2); border: 1px solid var(--line-soft); color: var(--ink); font-family: var(--font-jp); font-size: 1rem; padding: 15px 16px; border-radius: 0; transition: border-color 0.3s; width: 100%; }
.fld::placeholder { color: var(--ink-mute); }
.fld:focus { outline: none; border-color: var(--gold); }
.fld.err { border-color: var(--ember); }
textarea.fld { resize: vertical; line-height: 1.8; }
.field-err { font-size: 0.8rem; color: var(--ember); letter-spacing: 0.04em; }
.chips { display: flex; gap: 10px; flex-wrap: wrap; }
.chip { background: var(--bg-2); border: 1px solid var(--line-soft); color: var(--ink-soft); padding: 11px 20px; font-family: var(--font-jp); font-size: 0.96rem; letter-spacing: 0.06em; transition: all 0.3s; white-space: nowrap; }
.chip:hover { border-color: var(--gold-deep); color: var(--ink); }
.chip.on { background: var(--gold); border-color: var(--gold); color: var(--bg); }
.reserve-submit { justify-content: center; margin-top: 8px; }
.reserve-legal { font-size: 0.8rem; color: var(--ink-mute); text-align: center; line-height: 1.8; }

.reserve-aside { display: flex; flex-direction: column; gap: 18px; position: sticky; top: 110px; }
.aside-card { border: 1px solid var(--line-soft); background: var(--bg-2); padding: 28px; }
.aside-card h4 { font-size: 0.76rem; letter-spacing: 0.28em; color: var(--gold); margin-bottom: 16px; }
.aside-list { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.aside-list li { position: relative; padding-left: 20px; color: var(--ink-soft); font-size: 0.92rem; line-height: 1.7; }
.aside-list li::before { content: "—"; position: absolute; left: 0; color: var(--gold); }
.aside-tel { font-size: 1.7rem; color: var(--gold-soft); letter-spacing: 0.04em; }

/* ============ RESERVE DONE ============ */
.reserve-done { position: relative; min-height: 86vh; display: grid; place-items: center; overflow: hidden; padding-top: 120px; }
.reserve-done-inner { position: relative; z-index: 2; text-align: center; display: flex; flex-direction: column; align-items: center; max-width: 620px; }
.reserve-done-title { font-size: clamp(2.4rem, 6vw, 4rem); font-weight: 600; line-height: 1.25; margin-top: 22px; }
.reserve-done-sub { color: var(--ink-soft); line-height: 2; margin-top: 22px; }
.receipt { width: 100%; border: 1px solid var(--line); background: var(--bg-2); padding: 14px 30px; margin: 40px 0; }
.receipt-row { display: flex; justify-content: space-between; gap: 20px; padding: 16px 0; border-bottom: 1px solid var(--line-soft); text-align: left; }
.receipt-row:last-child { border-bottom: none; }
.receipt-row span { color: var(--ink-mute); font-size: 0.86rem; letter-spacing: 0.1em; min-width: 80px; }
.receipt-row strong { color: var(--ink); font-weight: 600; text-align: right; }

/* ============ RESPONSIVE ============ */
@media (max-width: 980px) {
  .hero-b { grid-template-columns: 1fr; }
  .hero-b-media { min-height: 50vh; order: -1; }
  .reserve-grid { grid-template-columns: 1fr; }
  .reserve-aside { position: static; }
  .info-grid { grid-template-columns: 1fr; }
  .course-feat-grid, .about-intro-grid { grid-template-columns: 1fr; }
  .course-feat-media { aspect-ratio: 16/11; }
  .course-feat-badge { bottom: 16px; right: 16px; }
  .jidori-feat-head { grid-template-columns: 1fr; gap: 20px; }
  .drinks-grid { grid-template-columns: repeat(2, 1fr); }
  .values-grid { grid-template-columns: 1fr; }
  .occasions-head { grid-template-columns: 1fr; gap: 20px; }
  .occasions-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .concept-grid { grid-template-columns: 1fr; }
  .concept-side { display: none; }
  .statband-grid { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(3) { border-left: none; }
  .stat { padding: 38px 12px; }
  .jidori-grid { grid-template-columns: 1fr; }
  .jidori-item:nth-child(odd) { border-right: none; }
  .field-row.two { grid-template-columns: 1fr; }
  .drinks-grid { grid-template-columns: 1fr; }
  .info-row { grid-template-columns: 90px 1fr; gap: 16px; }
  .receipt { padding: 8px 20px; }
  .occasions-grid { grid-template-columns: 1fr; }
}


/* =========================================================
   WordPress テーマ用 追記・上書き
   （画像はテーマ内 assets/img/ をCSS背景として読み込み）
   ========================================================= */

/* reveal: JSが無い/失敗してもコンテンツは必ず表示（プログレッシブ・エンハンスメント） */
.reveal { opacity: 1; transform: none; }
.has-js .reveal { opacity: 0; transform: translateY(26px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
.has-js .reveal.in { opacity: 1; transform: none; }

/* メディア差し替え用の画像変数（カスタマイザー未設定時はテーマ標準を使用） */
:root {
  --img-logo:   url(assets/img/logo.png);
  --img-hero1:  url(assets/img/hero1.jpg);
  --img-hero2:  url(assets/img/hero2.jpg);
  --img-hero3:  url(assets/img/hero3.jpg);
  --img-hero4:  url(assets/img/hero4.jpg);
  --img-course: url(assets/img/course.jpg);
  --img-about:  url(assets/img/about.jpg);
  --img-val1:   url(assets/img/val1.jpg);
  --img-val2:   url(assets/img/val2.jpg);
  --img-val3:   url(assets/img/val3.jpg);
}

/* ヒーローのロゴ（背景divとして描画） */
.hero-a-logo, .hero-b-logo, .hero-c-logo {
  background: var(--img-logo) center/contain no-repeat;
  aspect-ratio: 500 / 334;
}

/* ヒーロー クロスフェード（背景画像） */
.hero-slide { background-size: cover; background-position: center; }
.hero-a-bg .hero-slide:nth-child(1), .hero-b-slides .hero-slide:nth-child(1) { background-image: var(--img-hero1); }
.hero-a-bg .hero-slide:nth-child(2), .hero-b-slides .hero-slide:nth-child(2) { background-image: var(--img-hero2); }
.hero-a-bg .hero-slide:nth-child(3), .hero-b-slides .hero-slide:nth-child(3) { background-image: var(--img-hero3); }
.hero-a-bg .hero-slide:nth-child(4), .hero-b-slides .hero-slide:nth-child(4) { background-image: var(--img-hero4); }
@media (prefers-reduced-motion: no-preference) {
  .hero-slide { transform: scale(1.06); transition: opacity 1.6s var(--ease), transform 8s linear; }
  .hero-slide.on { transform: scale(1); }
}

/* ミニマル・ヒーローの帯（背景画像） */
.hero-c-cell { background-size: cover; background-position: center; transition: transform 1.2s var(--ease); }
.hero-c-strip .hero-c-cell:nth-child(1) { background-image: var(--img-hero1); }
.hero-c-strip .hero-c-cell:nth-child(2) { background-image: var(--img-hero2); }
.hero-c-strip .hero-c-cell:nth-child(3) { background-image: var(--img-hero3); }
.hero-c-strip .hero-c-cell:nth-child(4) { background-image: var(--img-hero4); }

/* 各セクションの写真（背景画像） */
.course-feat-img { background: var(--img-course) center/cover no-repeat; width: 100%; height: 100%; }
.about-intro-img { background: var(--img-about) center/cover no-repeat; width: 100%; height: 100%; }
.value-card.v1 { background-image: var(--img-val1); }
.value-card.v2 { background-image: var(--img-val2); }
.value-card.v3 { background-image: var(--img-val3); }

/* FAQ は初期状態で閉じる（JSが開いたときに max-height を付与） */
.faq-a { max-height: 0; }

/* 予約ページ：プラグインのショートコード貼り付け領域 */
.reserve-embed { min-height: 120px; }
.reserve-embed:empty::before { content: "［予約フォーム：プラグインのショートコードをここに貼り付けてください］"; color: var(--ink-mute); font-size: 0.9rem; display:block; padding: 24px 0; }

/* メイン領域 */
.site-main { display: block; }

/* WordPress 管理バー表示時、固定ナビが隠れないように */
.admin-bar .nav { top: 32px; }
@media (max-width: 782px) { .admin-bar .nav { top: 46px; } }
