/*
Theme Name: Salon Groen — ヘアサロン グルーン
Theme URI: https://example-groen.com
Author: Salon Groen
Description: 札幌の美容室をイメージした、写真と余白を主役にする静かなエディトリアル調のオリジナルテーマ。コンセプト・メニュー・スタッフ・スタイル・アクセス・リクルートの各固定ページを備え、文字と画像はすべてカスタマイザーから編集できます。ACF不要・モバイル完全対応。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: Private
Text Domain: salon-groen
*/

/* ============================================================
   0. Design Tokens — 余白と自然光、groen（緑）の落ち着き
   ============================================================ */
:root {
  /* ペーパー系ベース */
  --c-paper:      #F6F4EE;   /* 主背景：温かみのあるオフホワイト */
  --c-paper-2:    #EFEDE4;   /* やや沈んだ紙 */
  --c-white:      #FCFBF7;   /* 限りなく白に近い */

  /* インク（黒すぎない墨色） */
  --c-ink:        #20211C;   /* 本文・見出し */
  --c-ink-soft:   #56564E;   /* サブテキスト */
  --c-ink-mute:   #8C8B81;   /* キャプション・補助 */

  /* groen — くすんだ深い緑 */
  --c-green:      #4C5A45;   /* 主役のアクセント */
  --c-green-deep: #2E382A;   /* 漆黒に近い緑（フッター等） */
  --c-green-soft: #7C8A72;   /* 中間の緑 */
  --c-green-pale: #E4E7DC;   /* 極淡い緑（面・帯） */

  /* 線・面 */
  --c-line:       #DAD6CB;   /* ヘアライン */
  --c-line-soft:  #E7E3D8;
  --c-overlay:    rgba(28,30,24,.40);

  /* タイポグラフィ */
  --f-jp-serif:  "Shippori Mincho", "Noto Serif JP", "Yu Mincho", "游明朝", serif;
  --f-jp-sans:   "Noto Sans JP", "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
  --f-en-disp:   "Cormorant Garamond", "Shippori Mincho", serif;
  --f-en-label:  "Jost", "Noto Sans JP", sans-serif;

  /* サイズ */
  --fs-hero:   clamp(2.2rem, 6vw, 4.4rem);
  --fs-h1:     clamp(1.8rem, 4.4vw, 3rem);
  --fs-h2:     clamp(1.45rem, 3.4vw, 2.2rem);
  --fs-h3:     clamp(1.1rem, 2.2vw, 1.35rem);
  --fs-body:   clamp(0.92rem, 1.5vw, 1rem);
  --fs-small:  0.82rem;
  --fs-label:  0.7rem;

  /* 余白 */
  --pad-y:     clamp(5rem, 11vw, 10rem);
  --gap:       clamp(2.5rem, 6vw, 5.5rem);

  /* 幅 */
  --w-max:     1240px;
  --w-wide:    1440px;
  --w-text:    720px;

  /* モーション */
  --ease:      cubic-bezier(.32,.08,.24,1);
  --ease-soft: cubic-bezier(.25,.1,.25,1);

  --header-h:  82px;
}

/* ============================================================
   1. Reset
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-size-adjust: 100%;
}

body {
  font-family: var(--f-jp-sans);
  font-size: var(--fs-body);
  font-weight: 400;
  line-height: 2.05;
  color: var(--c-ink);
  background: var(--c-paper);
  overflow-x: hidden;
  letter-spacing: .02em;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .35s var(--ease), opacity .35s var(--ease); }
ul, ol { list-style: none; }
button { font-family: inherit; background: none; border: none; cursor: pointer; color: inherit; }
::selection { background: var(--c-green-pale); color: var(--c-green-deep); }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.sr-only:focus {
  position: fixed; top: 1rem; left: 1rem; width: auto; height: auto;
  padding: .75rem 1.25rem; clip: auto; background: var(--c-ink); color: #fff; z-index: 9999;
}

/* ============================================================
   2. Layout primitives
   ============================================================ */
.l-container { width: 100%; max-width: var(--w-max); margin-inline: auto; padding-inline: clamp(1.3rem, 5vw, 3.5rem); }
.l-container--wide { max-width: var(--w-wide); }
.l-container--text { max-width: var(--w-text); }
.l-section { padding-block: var(--pad-y); position: relative; }
.l-section--paper { background: var(--c-paper); }
.l-section--soft  { background: var(--c-paper-2); }
.l-section--white { background: var(--c-white); }
.l-section--green { background: var(--c-green-deep); color: var(--c-paper); }

/* エディトリアルな英字＋和文の見出し */
.c-kicker {
  font-family: var(--f-en-label);
  font-size: var(--fs-label);
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--c-green-soft);
  font-weight: 400;
  display: inline-block;
}
.c-index {
  font-family: var(--f-en-disp);
  font-style: italic;
  font-size: clamp(.95rem,1.6vw,1.15rem);
  color: var(--c-green-soft);
  letter-spacing: .04em;
}

.c-sec-head { margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.c-sec-head__en {
  display: block;
  font-family: var(--f-en-disp);
  font-size: clamp(2rem, 5vw, 3.4rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1;
  color: var(--c-ink);
  letter-spacing: .01em;
}
.c-sec-head__ja {
  display: block;
  font-family: var(--f-jp-serif);
  font-size: var(--fs-h3);
  font-weight: 500;
  letter-spacing: .22em;
  color: var(--c-ink-soft);
  margin-top: 1rem;
}
.c-sec-head--center { text-align: center; }

/* 縦書きの和文ラベル（和の余韻、AIっぽくない要素） */
.c-vertical {
  writing-mode: vertical-rl;
  font-family: var(--f-jp-serif);
  letter-spacing: .35em;
  font-size: .9rem;
  color: var(--c-ink-mute);
  line-height: 1;
}

/* リンク・ボタン */
.c-link {
  display: inline-flex; align-items: center; gap: .85em;
  font-family: var(--f-en-label);
  font-size: var(--fs-small);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--c-ink);
  padding-bottom: .35rem;
  position: relative;
}
.c-link::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 100%;
  background: var(--c-line); 
}
.c-link::before {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 1.8rem;
  background: var(--c-green); transition: width .5s var(--ease); z-index: 1;
}
.c-link:hover::before { width: 100%; }
.c-link .arrow { transition: transform .4s var(--ease); }
.c-link:hover .arrow { transform: translateX(4px); }

.c-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .8em;
  font-family: var(--f-en-label);
  font-size: var(--fs-small);
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 1.1rem 2.6rem;
  border: 1px solid var(--c-ink);
  color: var(--c-ink);
  background: transparent;
  transition: background .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease);
}
.c-btn:hover { background: var(--c-ink); color: var(--c-paper); }
.c-btn--green { border-color: var(--c-green); color: var(--c-green-deep); }
.c-btn--green:hover { background: var(--c-green); color: var(--c-paper); }
.c-btn--solid { background: var(--c-green-deep); color: var(--c-paper); border-color: var(--c-green-deep); }
.c-btn--solid:hover { background: transparent; color: var(--c-green-deep); }
.c-btn--ghost-light { border-color: rgba(246,244,238,.5); color: var(--c-paper); }
.c-btn--ghost-light:hover { background: var(--c-paper); color: var(--c-green-deep); border-color: var(--c-paper); }

.c-back-link {
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--f-en-label); font-size: var(--fs-small);
  letter-spacing: .12em; color: var(--c-ink-soft); margin-bottom: 2.5rem;
}
.c-back-link:hover { color: var(--c-green); }

/* リビール */
.js-reveal { opacity: 0; transform: translateY(26px); transition: opacity 1.1s var(--ease-soft), transform 1.1s var(--ease-soft); }
.js-reveal.is-visible { opacity: 1; transform: none; }
.js-reveal[data-delay="1"] { transition-delay: .12s; }
.js-reveal[data-delay="2"] { transition-delay: .24s; }
.js-reveal[data-delay="3"] { transition-delay: .36s; }
@media (prefers-reduced-motion: reduce) {
  .js-reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* ============================================================
   3. Header
   ============================================================ */
.l-header {
  position: fixed; inset: 0 0 auto 0; z-index: 1000;
  height: var(--header-h);
  display: flex; align-items: center;
  transition: background .5s var(--ease), height .5s var(--ease), border-color .5s var(--ease);
  border-bottom: 1px solid transparent;
}
.l-header__inner { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.l-header.is-scrolled {
  background: rgba(246,244,238,.92);
  backdrop-filter: blur(10px);
  height: 66px;
  border-bottom-color: var(--c-line);
}

.l-logo { display: flex; flex-direction: column; line-height: 1; }
.l-logo__en {
  font-family: var(--f-en-disp); font-size: 1.65rem; font-weight: 600;
  letter-spacing: .14em; color: var(--c-ink);
}
.l-logo__ja {
  font-family: var(--f-jp-sans); font-size: .58rem; letter-spacing: .5em;
  color: var(--c-ink-soft); margin-top: .35rem; text-indent: .5em;
}
/* ヒーロー上では明色に */
body.home .l-header:not(.is-scrolled) .l-logo__en,
body.home .l-header:not(.is-scrolled) .l-logo__ja { color: var(--c-paper); }

.l-nav { display: flex; align-items: center; gap: clamp(1.4rem, 2.5vw, 2.6rem); }
.l-nav__item > a {
  font-family: var(--f-jp-sans); font-size: .8rem; letter-spacing: .18em;
  color: var(--c-ink); position: relative; padding-bottom: .3rem;
}
.l-nav__item > a::after {
  content: ""; position: absolute; left: 50%; bottom: 0; width: 0; height: 1px;
  background: var(--c-green); transition: width .4s var(--ease), left .4s var(--ease);
}
.l-nav__item > a:hover::after { width: 100%; left: 0; }
body.home .l-header:not(.is-scrolled) .l-nav__item > a { color: var(--c-paper); }

.l-nav__cta a {
  font-family: var(--f-en-label); font-size: .72rem; letter-spacing: .2em;
  text-transform: uppercase; border: 1px solid currentColor;
  padding: .7rem 1.4rem; transition: background .4s var(--ease), color .4s var(--ease);
  color: var(--c-green-deep); border-color: var(--c-green);
}
.l-nav__cta a:hover { background: var(--c-green); color: var(--c-paper); }
body.home .l-header:not(.is-scrolled) .l-nav__cta a { color: var(--c-paper); border-color: rgba(246,244,238,.6); }
body.home .l-header:not(.is-scrolled) .l-nav__cta a:hover { background: var(--c-paper); color: var(--c-green-deep); }

/* ハンバーガー */
.c-hamburger { display: none; width: 30px; height: 22px; position: relative; z-index: 1100; }
.c-hamburger__line {
  position: absolute; left: 0; width: 100%; height: 1.5px; background: var(--c-ink);
  transition: transform .4s var(--ease), opacity .3s var(--ease), background .4s var(--ease);
}
.c-hamburger__line:nth-child(1) { top: 2px; }
.c-hamburger__line:nth-child(2) { top: 10px; }
.c-hamburger__line:nth-child(3) { top: 18px; }
body.home .l-header:not(.is-scrolled) .c-hamburger__line { background: var(--c-paper); }
.c-hamburger.is-active .c-hamburger__line { background: var(--c-ink); }
.c-hamburger.is-active .c-hamburger__line:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.c-hamburger.is-active .c-hamburger__line:nth-child(2) { opacity: 0; }
.c-hamburger.is-active .c-hamburger__line:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* モバイルナビ */
.l-mobile-nav {
  position: fixed; inset: 0; z-index: 1050;
  background: var(--c-paper); padding: calc(var(--header-h) + 2rem) clamp(1.5rem,8vw,4rem) 3rem;
  display: flex; flex-direction: column; justify-content: center; gap: 1.4rem;
  transform: translateY(-100%); transition: transform .6s var(--ease); 
  overflow-y: auto;
}
.l-mobile-nav.is-open { transform: translateY(0); }
.l-mobile-nav__item a {
  font-family: var(--f-jp-serif); font-size: 1.35rem; letter-spacing: .16em;
  color: var(--c-ink); display: flex; align-items: baseline; gap: 1rem;
  padding-block: .5rem; border-bottom: 1px solid var(--c-line-soft);
}
.l-mobile-nav__item a .num { font-family: var(--f-en-disp); font-style: italic; font-size: .85rem; color: var(--c-green-soft); }

/* ============================================================
   4. Hero
   ============================================================ */
.p-hero {
  position: relative; min-height: 100svh; display: flex; align-items: flex-end;
  overflow: hidden; color: var(--c-paper);
}
.p-hero__media { position: absolute; inset: 0; z-index: -2; }
.p-hero__media img, .p-hero__media video { width: 100%; height: 100%; object-fit: cover; }
.p-hero__media img { transform: scale(1.12); transition: transform 9s var(--ease-soft); }
.p-hero.is-loaded .p-hero__media img { transform: scale(1); }
.p-hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(20,22,18,.28) 0%, rgba(20,22,18,.05) 38%, rgba(20,22,18,.55) 100%);
}
.p-hero__inner { width: 100%; padding-bottom: clamp(3.5rem, 8vw, 7rem); }
.p-hero__copy {
  font-family: var(--f-jp-serif); font-weight: 500;
  font-size: var(--fs-hero); line-height: 1.6; letter-spacing: .12em;
  text-shadow: 0 2px 30px rgba(0,0,0,.25);
}
.p-hero__copy span { display: block; overflow: hidden; }
.p-hero__copy span i { display: block; font-style: normal; transform: translateY(110%); animation: heroLine 1.4s var(--ease) forwards; }
.p-hero__copy span:nth-child(1) i { animation-delay: .35s; }
.p-hero__copy span:nth-child(2) i { animation-delay: .55s; }
.p-hero__copy span:nth-child(3) i { animation-delay: .75s; }
@keyframes heroLine { to { transform: translateY(0); } }
.p-hero__sub {
  margin-top: 1.8rem; font-family: var(--f-jp-sans); font-size: var(--fs-small);
  letter-spacing: .24em; opacity: 0; animation: fadeUp 1.2s var(--ease) 1s forwards;
}
@keyframes fadeUp { from { opacity: 0; transform: translateY(14px);} to { opacity: .9; transform: none;} }

.p-hero__scroll {
  position: absolute; right: clamp(1.3rem,5vw,3.5rem); bottom: clamp(2rem,5vw,3.5rem);
  display: flex; flex-direction: column; align-items: center; gap: 1rem; z-index: 2;
}
.p-hero__scroll span {
  writing-mode: vertical-rl; font-family: var(--f-en-label); font-size: .62rem;
  letter-spacing: .3em; text-transform: uppercase; opacity: .85;
}
.p-hero__scroll i { width: 1px; height: 56px; background: rgba(246,244,238,.5); position: relative; overflow: hidden; }
.p-hero__scroll i::after { content: ""; position: absolute; top: -56px; left: 0; width: 100%; height: 56px; background: var(--c-paper); animation: scrollLine 2.4s var(--ease-soft) infinite; }
@keyframes scrollLine { 0% { top: -56px; } 60%,100% { top: 56px; } }

/* ============================================================
   5. Concept（コンセプト）
   ============================================================ */
.p-concept { position: relative; }
.p-concept__grid {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2.5rem, 6vw, 6rem); align-items: center;
}
.p-concept__text { max-width: 30rem; }
.p-concept__lead {
  font-family: var(--f-jp-serif); font-size: clamp(1.25rem,2.6vw,1.7rem);
  line-height: 2.1; letter-spacing: .12em; color: var(--c-ink); margin: 1.8rem 0 2rem;
}
.p-concept__body { color: var(--c-ink-soft); font-size: var(--fs-body); line-height: 2.2; white-space: pre-line; margin-bottom: 2.4rem; }
.p-concept__media { position: relative; }
.p-concept__media-main { aspect-ratio: 4/5; overflow: hidden; }
.p-concept__media-main img { width: 100%; height: 100%; object-fit: cover; }
.p-concept__media-cap {
  position: absolute; left: -1.5rem; bottom: 1.5rem;
}
.p-concept__deco {
  position: absolute; top: -2.5rem; right: -1rem; font-family: var(--f-en-disp);
  font-style: italic; font-size: clamp(3rem,7vw,5.5rem); color: var(--c-green-pale);
  line-height: 1; z-index: -1; user-select: none;
}

/* ============================================================
   6. Menu（メニュー・料金）
   ============================================================ */
.p-menu__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(2rem,4vw,4rem) clamp(3rem,7vw,7rem); }
.p-menu__item { border-top: 1px solid var(--c-line); padding-top: 1.6rem; }
.p-menu__item-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.p-menu__item-title { font-family: var(--f-jp-serif); font-size: var(--fs-h3); letter-spacing: .1em; }
.p-menu__item-en { font-family: var(--f-en-disp); font-style: italic; color: var(--c-green-soft); font-size: 1rem; }
.p-menu__rows { display: flex; flex-direction: column; gap: .7rem; }
.p-menu__row { display: flex; align-items: baseline; gap: .8rem; font-size: var(--fs-small); color: var(--c-ink-soft); }
.p-menu__row .name { flex: 0 0 auto; }
.p-menu__row .dots { flex: 1 1 auto; border-bottom: 1px dotted var(--c-line); transform: translateY(-4px); }
.p-menu__row .price { flex: 0 0 auto; font-family: var(--f-en-label); letter-spacing: .05em; color: var(--c-ink); }
.p-menu__row .price small { font-size: .7rem; color: var(--c-ink-mute); }
.p-menu__note { margin-top: 3rem; font-size: var(--fs-small); color: var(--c-ink-mute); line-height: 1.9; }

/* ============================================================
   7. Stylists（スタッフ）
   ============================================================ */
.p-staff__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem,3.5vw,3rem); }
.p-staff-card__media { aspect-ratio: 3/4; overflow: hidden; margin-bottom: 1.3rem; background: var(--c-paper-2); }
.p-staff-card__media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.02); transition: filter 1s var(--ease), transform 1.4s var(--ease); }
.p-staff-card:hover .p-staff-card__media img { filter: grayscale(0); transform: scale(1.04); }
.p-staff-card__role { font-family: var(--f-en-label); font-size: var(--fs-label); letter-spacing: .26em; text-transform: uppercase; color: var(--c-green-soft); }
.p-staff-card__name { font-family: var(--f-jp-serif); font-size: 1.2rem; letter-spacing: .1em; margin: .6rem 0 .2rem; }
.p-staff-card__name-en { font-family: var(--f-en-disp); font-style: italic; color: var(--c-ink-mute); font-size: .9rem; }
.p-staff-card__msg { margin-top: .9rem; font-size: var(--fs-small); color: var(--c-ink-soft); line-height: 1.95; }

/* ============================================================
   8. Gallery / Style
   ============================================================ */
.p-gallery__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(.6rem,1.4vw,1rem); }
.p-gallery__cell { aspect-ratio: 3/4; overflow: hidden; background: var(--c-paper-2); position: relative; }
.p-gallery__cell:nth-child(4n+1) { aspect-ratio: 3/4; }
.p-gallery__cell img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.55); transition: filter 1s var(--ease), transform 1.6s var(--ease); }
.p-gallery__cell:hover img { filter: grayscale(0); transform: scale(1.05); }
.p-gallery__cell::after { content: ""; position: absolute; inset: 0; border: 1px solid rgba(0,0,0,.04); }

/* ============================================================
   9. Access / Info
   ============================================================ */
.p-access__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2.5rem,6vw,5rem); align-items: stretch; }
.p-access__info { display: flex; flex-direction: column; justify-content: center; }
.p-access__dl { margin-top: 2rem; }
.p-access__row { display: grid; grid-template-columns: 8rem 1fr; gap: 1rem; padding: 1.1rem 0; border-bottom: 1px solid var(--c-line); }
.p-access__row dt { font-family: var(--f-en-label); font-size: var(--fs-label); letter-spacing: .2em; text-transform: uppercase; color: var(--c-green-soft); padding-top: .35rem; }
.p-access__row dd { font-size: var(--fs-small); color: var(--c-ink); line-height: 1.9; white-space: pre-line; }
.p-access__row dd .tel { font-family: var(--f-en-disp); font-size: 1.5rem; letter-spacing: .04em; font-style: italic; }
.p-access__map { min-height: 360px; background: var(--c-paper-2); overflow: hidden; }
.p-access__map iframe { width: 100%; height: 100%; min-height: 360px; border: 0; filter: grayscale(.3) contrast(1.05); }
.p-access__map-empty { width: 100%; height: 100%; min-height: 360px; display: flex; align-items: center; justify-content: center; color: var(--c-ink-mute); font-family: var(--f-en-label); letter-spacing: .2em; font-size: var(--fs-small); }

/* ============================================================
   10. News
   ============================================================ */
.p-news__list { display: flex; flex-direction: column; }
.p-news-card { border-bottom: 1px solid var(--c-line); }
.p-news-card__link { display: grid; grid-template-columns: 9rem 1fr auto; gap: clamp(1rem,3vw,2.5rem); align-items: center; padding: 1.6rem 0; transition: opacity .4s var(--ease); }
.p-news-card__link:hover { opacity: .55; }
.p-news-card__date { font-family: var(--f-en-disp); font-style: italic; font-size: 1.05rem; color: var(--c-green-soft); letter-spacing: .04em; }
.p-news-card__cat { font-family: var(--f-en-label); font-size: var(--fs-label); letter-spacing: .2em; text-transform: uppercase; color: var(--c-ink-mute); display: inline-block; margin-left: 1rem; }
.p-news-card__title { font-family: var(--f-jp-serif); font-size: 1.05rem; letter-spacing: .04em; line-height: 1.7; }
.p-news-card__arrow { font-family: var(--f-en-label); color: var(--c-ink-mute); }
/* カード型（一覧ページ） */
.p-news__cards { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.5rem,3vw,2.5rem); }
.p-news-tile__media { aspect-ratio: 4/3; overflow: hidden; background: var(--c-paper-2); margin-bottom: 1.1rem; }
.p-news-tile__media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.3); transition: filter .8s var(--ease), transform 1.2s var(--ease); }
.p-news-tile:hover .p-news-tile__media img { filter: grayscale(0); transform: scale(1.04); }
.p-news-tile__media-empty { width:100%; height:100%; display:flex; align-items:center; justify-content:center; color: var(--c-green-soft); font-family: var(--f-en-disp); font-style: italic; font-size: 1.4rem; }
.p-news-tile__date { font-family: var(--f-en-disp); font-style: italic; color: var(--c-green-soft); font-size: .95rem; }
.p-news-tile__title { font-family: var(--f-jp-serif); font-size: 1.02rem; line-height: 1.7; margin-top: .4rem; }

/* ============================================================
   11. Recruit CTA
   ============================================================ */
.p-recruit { position: relative; overflow: hidden; }
.p-recruit__media { position: absolute; inset: 0; z-index: -2; }
.p-recruit__media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.4); }
.p-recruit::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(90deg, rgba(46,56,42,.92), rgba(46,56,42,.55)); }
.p-recruit__inner { padding-block: clamp(4.5rem,9vw,8rem); color: var(--c-paper); max-width: 34rem; }
.p-recruit__title { font-family: var(--f-jp-serif); font-size: var(--fs-h2); line-height: 1.7; letter-spacing: .1em; margin: 1.2rem 0 1.5rem; }
.p-recruit__body { font-size: var(--fs-small); line-height: 2.1; opacity: .9; margin-bottom: 2.4rem; }

/* ============================================================
   12. Dividers / quote
   ============================================================ */
.c-divider { padding-block: clamp(3.5rem,8vw,6.5rem); text-align: center; }
.c-divider--green { background: var(--c-green-deep); color: var(--c-paper); }
.c-divider--paper { background: var(--c-paper-2); }
.c-divider__en { font-family: var(--f-en-disp); font-style: italic; font-size: clamp(1.4rem,3vw,2.2rem); letter-spacing: .04em; }
.c-divider__ja { font-family: var(--f-jp-serif); font-size: var(--fs-small); letter-spacing: .3em; margin-top: 1rem; opacity: .85; }

/* 予約バー（下部固定） */
.c-reserve-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 900;
  display: none; grid-template-columns: 1fr 1fr; 
  background: var(--c-green-deep); color: var(--c-paper);
  transform: translateY(100%); transition: transform .5s var(--ease);
}
.c-reserve-bar.is-shown { transform: translateY(0); }
.c-reserve-bar a { padding: 1.1rem; text-align: center; font-family: var(--f-en-label); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; display: flex; align-items: center; justify-content: center; gap: .5rem; }
.c-reserve-bar a + a { border-left: 1px solid rgba(246,244,238,.2); }
.c-reserve-bar a:hover { background: var(--c-green); }

/* ============================================================
   13. Page hero（下層ページ共通）
   ============================================================ */
.p-pagehero { position: relative; padding-top: calc(var(--header-h) + clamp(3rem,7vw,6rem)); padding-bottom: clamp(2.5rem,6vw,4.5rem); overflow: hidden; }
.p-pagehero--media { min-height: 56vh; display: flex; align-items: flex-end; color: var(--c-paper); padding-bottom: clamp(2.5rem,6vw,4rem); }
.p-pagehero--media .p-pagehero__media { position: absolute; inset: 0; z-index: -2; }
.p-pagehero--media .p-pagehero__media img { width: 100%; height: 100%; object-fit: cover; }
.p-pagehero--media::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(20,22,18,.25), rgba(20,22,18,.55)); }
.p-pagehero__en { font-family: var(--f-en-disp); font-style: italic; font-weight: 500; font-size: clamp(2.6rem,7vw,5rem); line-height: 1; display: block; }
.p-pagehero__ja { font-family: var(--f-jp-serif); font-size: var(--fs-h3); letter-spacing: .26em; margin-top: 1.2rem; display: block; }
.p-pagehero--media .p-pagehero__ja { color: var(--c-paper); }

/* 章立て（詳細ページ） */
.p-chapter { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem,6vw,5.5rem); align-items: center; }
.p-chapter--rev .p-chapter__media { order: 2; }
.p-chapter__media { aspect-ratio: 4/5; overflow: hidden; }
.p-chapter__media img { width: 100%; height: 100%; object-fit: cover; }
.p-chapter__title { font-family: var(--f-jp-serif); font-size: var(--fs-h2); line-height: 1.6; letter-spacing: .08em; margin-bottom: 1.6rem; }
.p-chapter__title em { font-style: normal; color: var(--c-green); }
.p-chapter__lead { font-family: var(--f-jp-serif); font-size: 1.08rem; line-height: 2.1; color: var(--c-ink); white-space: pre-line; margin-bottom: 1.5rem; }
.p-chapter__body { color: var(--c-ink-soft); line-height: 2.15; white-space: pre-line; }

.p-bleed { margin-block: clamp(3.5rem,8vw,6rem); }
.p-bleed img { width: 100%; aspect-ratio: 21/9; object-fit: cover; }

.p-quote { text-align: center; padding-block: clamp(3.5rem,8vw,6rem); }
.p-quote__text { font-family: var(--f-jp-serif); font-size: clamp(1.4rem,3.4vw,2.2rem); line-height: 1.9; letter-spacing: .1em; }
.p-quote__text em { font-style: normal; color: var(--c-green); }
.p-quote__author { margin-top: 1.6rem; font-family: var(--f-en-label); font-size: var(--fs-small); letter-spacing: .2em; color: var(--c-ink-mute); }

/* 本文（投稿・固定ページ） */
.c-entry { max-width: var(--w-text); margin-inline: auto; line-height: 2.15; color: var(--c-ink); }
.c-entry > * + * { margin-top: 1.5rem; }
.c-entry h2 { font-family: var(--f-jp-serif); font-size: var(--fs-h2); letter-spacing: .06em; margin-top: 3rem; }
.c-entry h3 { font-family: var(--f-jp-serif); font-size: var(--fs-h3); margin-top: 2.4rem; }
.c-entry a { color: var(--c-green); border-bottom: 1px solid var(--c-line); }
.c-entry img { margin-block: 2rem; }
.c-entry blockquote { border-left: 2px solid var(--c-green); padding-left: 1.4rem; color: var(--c-ink-soft); font-family: var(--f-jp-serif); }

/* CTA（詳細ページ下部） */
.p-cta { text-align: center; }
.p-cta__title { font-family: var(--f-jp-serif); font-size: var(--fs-h2); letter-spacing: .08em; margin-bottom: 1.2rem; }
.p-cta__lead { color: var(--c-ink-soft); font-size: var(--fs-small); line-height: 2; margin-bottom: 2.4rem; white-space: pre-line; }

/* ============================================================
   14. Footer
   ============================================================ */
.l-footer { background: var(--c-green-deep); color: var(--c-paper); padding-block: clamp(4rem,8vw,6rem) 2.5rem; }
.l-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(2.5rem,5vw,4rem); padding-bottom: 3.5rem; border-bottom: 1px solid rgba(246,244,238,.14); }
.l-footer__brand-en { font-family: var(--f-en-disp); font-size: 2rem; font-weight: 600; letter-spacing: .12em; }
.l-footer__brand-ja { font-family: var(--f-jp-sans); font-size: .62rem; letter-spacing: .42em; opacity: .7; margin-top: .5rem; }
.l-footer__brand-desc { margin-top: 1.6rem; font-size: var(--fs-small); line-height: 2; opacity: .8; max-width: 22rem; white-space: pre-line; }
.l-footer__col-title { font-family: var(--f-en-label); font-size: var(--fs-label); letter-spacing: .26em; text-transform: uppercase; opacity: .6; margin-bottom: 1.4rem; }
.l-footer__list li { margin-bottom: .9rem; }
.l-footer__list a { font-size: var(--fs-small); letter-spacing: .08em; opacity: .85; }
.l-footer__list a:hover { opacity: 1; color: var(--c-green-soft); }
.l-footer__bottom { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding-top: 2rem; font-size: .72rem; letter-spacing: .1em; opacity: .6; }

/* ============================================================
   15. 404
   ============================================================ */
.p-404 { min-height: 70vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 1.5rem; }
.p-404__num { font-family: var(--f-en-disp); font-style: italic; font-size: clamp(5rem,16vw,11rem); color: var(--c-green-pale); line-height: 1; }

/* ============================================================
   16. Responsive
   ============================================================ */
@media (max-width: 1024px) {
  .p-staff__grid { grid-template-columns: repeat(2, 1fr); }
  .p-gallery__grid { grid-template-columns: repeat(3, 1fr); }
  .p-news__cards { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 768px) {
  :root { --header-h: 64px; }
  .l-nav { display: none; }
  .c-hamburger { display: block; }

  .p-concept__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .p-concept__media { order: -1; }
  .p-concept__deco { display: none; }
  .p-concept__media-cap { left: 0; }

  .p-menu__grid { grid-template-columns: 1fr; }
  .p-staff__grid { grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }
  .p-gallery__grid { grid-template-columns: repeat(2, 1fr); }
  .p-access__grid { grid-template-columns: 1fr; }
  .p-access__map { min-height: 280px; }

  .p-chapter, .p-chapter--rev { grid-template-columns: 1fr; gap: 2rem; }
  .p-chapter--rev .p-chapter__media { order: -1; }
  .p-chapter__media { order: -1; }

  .p-news-card__link { grid-template-columns: 1fr auto; row-gap: .4rem; }
  .p-news-card__date { grid-column: 1; }
  .p-news-card__title { grid-column: 1 / -1; }
  .p-news-card__arrow { display: none; }
  .p-news__cards { grid-template-columns: 1fr; }

  .l-footer__grid { grid-template-columns: 1fr; gap: 2.5rem; }

  .c-reserve-bar { display: grid; }
  body { padding-bottom: 0; }
  .p-hero__scroll { display: none; }
}

@media (max-width: 480px) {
  .p-staff__grid { grid-template-columns: 1fr; }
  .p-gallery__grid { grid-template-columns: repeat(2, 1fr); }
}
