@charset "UTF-8";
/*!
 * Sohara Toshie 公式テーマ v2.1 - main.css
 * Direction: Cultivated Warmth — refined editorial with gold leaf accents
 * Update: 1行サブタイトル / CTA可視化 / STEPローマ数字のみ / 年齢拡大 / 背景リズム再設計
 */

/* ============================================================
   Design Tokens — Cultivated Warmth Refined
   ============================================================ */
:root {
	/* Background — warm cream tones */
	--c-bg:           #F5EFE2;
	--c-bg-soft:      #FAF5EC;
	--c-bg-alt:       #EFE6D2;
	--c-surface:      #FFFFFF;
	--c-paper:        #FBF8F0;

	/* Ink — warm brown blacks */
	--c-ink:          #2C2521;
	--c-ink-mid:      #4E443B;
	--c-ink-soft:     #786C5F;
	--c-ink-faint:    #B0A795;
	--c-line:         #E0D7C3;
	--c-line-soft:    #EDE5D3;

	/* Gold — refined leaf accents */
	--c-gold:         #B8924E;
	--c-gold-light:   #D4B772;
	--c-gold-deep:    #7C5F2E;
	--c-gold-soft:    #E6CFA0;

	/* Brand accents */
	--c-rose:         #EAD3CE;
	--c-rose-deep:    #C99B91;
	--c-teal:         #2E6B6D;
	--c-teal-deep:    #1F4748;
	--c-sage:         #97A38B;

	/* Gold gradient — used selectively for foil-like effects */
	--gold-foil:      linear-gradient(135deg, #D4B772 0%, #B8924E 35%, #E6CFA0 50%, #B8924E 65%, #D4B772 100%);

	/* Typography */
	--font-serif:     "Noto Serif JP", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
	--font-sans:      "Noto Sans JP", "Yu Gothic Medium", "Yu Gothic", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
	--font-en-serif:  "Cormorant Garamond", "Noto Serif JP", serif;

	/* Spacing */
	--space-xs: .5rem;
	--space-sm: 1rem;
	--space-md: 2rem;
	--space-lg: 4rem;
	--space-xl: 6rem;
	--space-2xl: 9rem;

	/* Layout */
	--max-w:        1200px;
	--max-w-narrow: 760px;
	--max-w-wide:   1440px;

	/* Misc */
	--radius:       2px;
	--radius-lg:    6px;
	--easing:       cubic-bezier(.4, .0, .2, 1);
	--easing-out:   cubic-bezier(.2, .8, .2, 1);
}

/* ============================================================
   Reset & base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

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

/* iOS Safari でも右端ピッタリに収まるよう、viewport を厳密に制御 */
html {
	overflow-x: hidden;
	width: 100%;
	-webkit-text-size-adjust: 100%;
}
body {
	overflow-x: hidden;
	width: 100%;
	margin: 0;
	position: relative;
}

/* main 要素：iOS Safari の幅計算をはっきりさせる */
main {
	width: 100%;
	max-width: 100%;
	overflow-x: hidden;
}


body {
	margin: 0;
	background: var(--c-bg);
	color: var(--c-ink);
	font-family: var(--font-sans);
	font-size: 16px;
	font-weight: 400;
	line-height: 1.95;
	letter-spacing: .045em;
	font-feature-settings: "palt" 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, video, svg { max-width: 100%; height: auto; display: block; }

a { color: var(--c-ink); text-decoration: none; transition: color .35s var(--easing), opacity .35s var(--easing); }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-serif);
	font-weight: 400;
	letter-spacing: .1em;
	line-height: 1.55;
	margin: 0;
}

p { margin: 0 0 1.5em; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

::selection { background: var(--c-rose); color: var(--c-ink); }

/* ============================================================
   Gold leaf utility
   ============================================================ */
.gold-foil {
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
	background-position: 0% 50%;
	animation: shimmer 8s ease-in-out infinite;
}

@keyframes shimmer {
	0%, 100% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
}

/* ============================================================
   Layout helpers
   ============================================================ */
.container        { max-width: var(--max-w); margin: 0 auto; padding: 0 32px; }
.container-narrow { max-width: var(--max-w-narrow); margin: 0 auto; padding: 0 24px; }
.container-wide   { max-width: var(--max-w-wide); margin: 0 auto; padding: 0 40px; }

.section { padding: var(--space-2xl) 0; width: 100%; box-sizing: border-box; position: relative; }
.section--alt     { background: var(--c-bg-alt); }
.section--soft    { background: var(--c-bg-soft); }
.section--surface { background: var(--c-surface); }
.section--paper   { background: var(--c-paper); }

@media (max-width: 768px) {
	.section { padding: var(--space-xl) 0; }
}

.eyebrow {
	font-family: var(--font-en-serif);
	font-size: 12px;
	font-style: italic;
	letter-spacing: .42em;
	color: var(--c-gold-deep);
	display: inline-flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 1.5rem;
	text-transform: uppercase;
}
.eyebrow::before {
	content: "";
	display: inline-block;
	width: 32px;
	height: 1px;
	background: var(--c-gold);
}

.section-title {
	font-family: var(--font-serif);
	font-size: clamp(30px, 4.2vw, 46px);
	font-weight: 300;
	letter-spacing: .12em;
	line-height: 1.5;
	margin-bottom: 1em;
	color: var(--c-ink);
	word-break: keep-all;
	overflow-wrap: break-word;
}
.section-title em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}

/* 金箔の小サブタイトル（タイトル直下、1行で収まる小さめ表記） */
.section-subtitle-gold {
	display: block;
	margin-top: 1.2em;
	font-family: var(--font-serif);
	font-size: clamp(13px, 1.4vw, 17px);
	font-weight: 400;
	letter-spacing: .28em;
	line-height: 1.6;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
	white-space: nowrap;
}
@media (max-width: 480px) {
	.section-subtitle-gold { white-space: normal; }
}

.section-lead {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: 17px;
	line-height: 2.2;
	color: var(--c-ink-soft);
	max-width: 680px;
	margin-bottom: 3.5rem;
}

/* ============================================================
   Header
   ============================================================ */
.site-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 100;
	background: rgba(245, 239, 226, .82);
	backdrop-filter: blur(14px) saturate(1.1);
	-webkit-backdrop-filter: blur(14px) saturate(1.1);
	border-bottom: 1px solid transparent;
	transition: border-color .4s var(--easing), background .4s var(--easing);
}
.site-header.is-scrolled {
	border-bottom-color: var(--c-line);
	background: rgba(245, 239, 226, .95);
}

.site-header-inner {
	max-width: var(--max-w-wide);
	margin: 0 auto;
	padding: 20px 36px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.site-logo-text { display: flex; flex-direction: column; line-height: 1.1; gap: 4px; }
.logo-name {
	font-family: var(--font-serif);
	font-size: 17px;
	font-weight: 400;
	letter-spacing: .18em;
	color: var(--c-ink);
}
.logo-en {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 10.5px;
	letter-spacing: .38em;
	color: var(--c-gold-deep);
}

.global-nav { display: flex; align-items: center; gap: 36px; }
.global-nav ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 34px; }
.global-nav a {
	font-family: var(--font-serif);
	font-size: 14.5px;
	font-weight: 400;
	letter-spacing: .15em;
	color: var(--c-ink);
	position: relative;
	padding: 6px 0;
}
.global-nav a::after {
	content: "";
	position: absolute;
	left: 50%; bottom: 2px;
	transform: translateX(-50%);
	width: 0; height: 1px;
	background: var(--c-gold);
	transition: width .45s var(--easing-out);
}
.global-nav a:hover { color: var(--c-gold-deep); }
.global-nav a:hover::after { width: 100%; }

.header-cta {
	font-family: var(--font-serif);
	font-size: 12.5px;
	letter-spacing: .2em;
	padding: 11px 24px;
	border: 1px solid var(--c-teal);
	color: var(--c-teal);
	transition: background .35s var(--easing), color .35s var(--easing);
}
.header-cta:hover { background: var(--c-teal); color: var(--c-bg-soft); }

.nav-toggle { display: none; }
.mobile-nav { display: none; }

@media (max-width: 960px) {
	.site-header-inner { padding: 16px 20px; }
	.global-nav, .header-cta { display: none; }
	.nav-toggle { display: flex; flex-direction: column; justify-content: center; width: 34px; height: 34px; gap: 6px; }
	.nav-toggle span { display: block; width: 26px; height: 1px; background: var(--c-ink); transition: transform .35s var(--easing), opacity .25s var(--easing); }
	.nav-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
	.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
	.nav-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
	.mobile-nav {
		display: block;
		position: fixed; inset: 68px 0 0 0; background: var(--c-bg); padding: 48px 28px; transform: translateX(100%); transition: transform .45s var(--easing); z-index: 99; overflow-y: auto; }
	.mobile-nav.is-open { transform: translateX(0); }
	.mobile-nav ul { list-style: none; padding: 0; margin: 0; }
	.mobile-nav li { border-bottom: 1px solid var(--c-line); }
	.mobile-nav a { display: block; padding: 22px 0; font-family: var(--font-serif); font-size: 19px; letter-spacing: .18em; }
}

/* ============================================================
   Hero
   ============================================================ */
.hero {
	position: relative;
	min-height: 100vh;
	padding: 104px 0 56px;
	display: flex;
	align-items: center;
	overflow: hidden;
}
.hero::before {
	content: "";
	position: absolute;
	top: 10%; right: -10%;
	width: 580px; height: 580px;
	background: radial-gradient(circle, var(--c-rose) 0%, transparent 60%);
	opacity: .35;
	pointer-events: none;
}

.hero-inner {
	max-width: var(--max-w-wide);
	margin: 0 auto;
	padding: 0 40px;
	display: grid;
	grid-template-columns: 1fr 0.85fr;
	gap: 72px;
	align-items: center;
	width: 100%;
	position: relative;
	z-index: 1;
}

.hero-text { position: relative; }

.hero-eyebrow {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 13px;
	letter-spacing: .45em;
	color: var(--c-gold-deep);
	margin-bottom: 24px;
	display: flex;
	align-items: center;
	gap: 16px;
	text-transform: uppercase;
}
.hero-eyebrow::before {
	content: "";
	display: inline-block;
	width: 50px; height: 1px;
	background: linear-gradient(90deg, var(--c-gold), transparent);
}

.hero-tagline {
	font-family: var(--font-serif);
	font-size: clamp(34px, 4.4vw, 62px);
	font-weight: 300;
	line-height: 1.28;
	letter-spacing: .14em;
	color: var(--c-ink);
	margin: 0 0 18px;
}
.hero-tagline em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
	animation: shimmer 6s ease-in-out infinite;
}

.hero-tagline-en {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: clamp(13px, 1.2vw, 16px);
	letter-spacing: .3em;
	color: var(--c-gold-deep);
	margin: 0 0 26px;
}

.hero-subline {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: 15px;
	line-height: 2.0;
	color: var(--c-ink-soft);
	margin-bottom: 30px;
	max-width: 440px;
}

.hero-cta-group { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 30px; }

.hero-profile {
	margin-top: 26px;
	padding: 18px 26px 16px;
	background: var(--c-bg-alt);
	position: relative;
}
.hero-profile::before {
	content: ""; position: absolute;
	top: 0; left: 0; right: 0; height: 2px;
	background: linear-gradient(90deg, var(--c-gold-deep) 0%, var(--c-gold-light) 55%, transparent 100%);
}
.hero-profile-label {
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 10px; letter-spacing: .45em;
	color: var(--c-gold-deep); text-transform: uppercase;
	margin: 0 0 10px;
}
.hero-name {
	display: flex; align-items: baseline; flex-wrap: wrap;
	gap: 14px; margin: 0 0 12px;
	padding: 0; border: none; position: static;
}
.hero-name::before { display: none; }
.hero-name-jp {
	font-family: var(--font-serif);
	font-weight: 400;
	font-size: 22px;
	letter-spacing: .22em;
	color: var(--c-ink);
}
.hero-name-en {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 13.5px;
	letter-spacing: .38em;
	color: var(--c-gold-deep);
	align-self: center;
}
.hero-titles {
	margin: 0;
	padding-top: 10px;
	border-top: 1px solid var(--c-line);
	font-family: var(--font-serif);
	font-size: 12.5px;
	letter-spacing: .1em;
	color: var(--c-ink-soft);
	line-height: 1.95;
}

.hero-portrait { position: relative; aspect-ratio: 4/5; overflow: hidden; max-width: 600px; width: 100%; margin: 0 auto; }
.hero-portrait img { width: 100%; height: 100%; object-fit: cover; transition: transform 12s var(--easing-out); }
.hero-portrait:hover img { transform: scale(1.04); }
.hero-portrait::before {
	content: ""; position: absolute; inset: 0;
	box-shadow: inset 0 0 0 1px rgba(184, 146, 78, .35);
	pointer-events: none; z-index: 2;
}
.hero-portrait::after {
	content: ""; position: absolute; inset: 18px;
	border: 1px solid var(--c-gold);
	pointer-events: none; z-index: 2;
}
.hero-portrait-placeholder {
	width: 100%; height: 100%;
	background: linear-gradient(135deg, var(--c-rose) 0%, var(--c-bg-alt) 100%);
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 14px; letter-spacing: .35em; color: var(--c-ink-faint);
}

@media (max-width: 960px) {
	.hero { min-height: auto; padding: 120px 0 70px; }
	.hero::before { width: 380px; height: 380px; }
	.hero-inner { grid-template-columns: 1fr; gap: 56px; }
	.hero-portrait { max-width: 400px; margin: 0 auto; }
}
@media (max-width: 480px) {
	.hero { padding: 100px 0 60px; }
}

/* ============================================================
   Buttons
   ============================================================ */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	padding: 18px 38px;
	font-family: var(--font-serif);
	font-weight: 400;
	font-size: 14px;
	letter-spacing: .22em;
	line-height: 1;
	border: 1px solid var(--c-ink);
	color: var(--c-ink);
	background: transparent;
	transition: background .4s var(--easing), color .4s var(--easing), border-color .4s var(--easing);
	white-space: nowrap;
	position: relative;
	overflow: hidden;
}
.btn:hover { background: var(--c-ink); color: var(--c-bg); opacity: 1; }

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

.btn--teal { background: var(--c-teal); color: var(--c-bg-soft); border-color: var(--c-teal); }
.btn--teal:hover { background: var(--c-teal-deep); border-color: var(--c-teal-deep); }

.btn--line {
	background: transparent; color: var(--c-gold-deep);
	border: none; border-bottom: 1px solid var(--c-gold);
	padding: 14px 4px; border-radius: 0;
}
.btn--line:hover { background: transparent; color: var(--c-gold); padding-left: 12px; }

.btn-arrow::after { content: "→"; transition: transform .35s var(--easing); }
.btn-arrow:hover::after { transform: translateX(6px); }

/* スマホ：長い日本語テキストでバランスが崩れないようスリム化 */
@media (max-width: 600px) {
	.btn {
		padding: 15px 24px;
		font-size: 13px;
		letter-spacing: .14em;
		gap: 10px;
	}
}
@media (max-width: 480px) {
	.btn {
		padding: 14px 20px;
		letter-spacing: .12em;
	}
}

/* ============================================================
   About intro section
   ============================================================ */
.about-intro { background: var(--c-paper); position: relative; }
.about-intro::before {
	content: ""; position: absolute; top: 0; left: 50%;
	width: 1px; height: 80px;
	background: linear-gradient(to bottom, var(--c-gold), transparent);
}
.about-intro-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 90px;
	align-items: center;
}
.about-text-block { position: relative; }
.about-text-block .section-title {
	font-size: clamp(28px, 3.8vw, 42px);
	letter-spacing: .08em;
}

.about-faces { display: grid; gap: 28px; }
.face-card {
	padding: 36px 32px;
	background: var(--c-bg);
	position: relative;
	border-top: 1px solid var(--c-gold);
	transition: transform .5s var(--easing), background .5s var(--easing);
}
.face-card::before {
	content: ""; position: absolute; top: -1px; left: 0;
	width: 20%; height: 1px; background: var(--c-gold-deep);
	transition: width .5s var(--easing-out);
}
.face-card:hover { background: var(--c-bg-soft); transform: translateX(6px); }
.face-card:hover::before { width: 100%; }
.face-card-no {
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 12px; letter-spacing: .4em; color: var(--c-gold-deep);
	margin-bottom: 14px;
}
.face-card h3 { font-size: 22px; font-weight: 400; margin-bottom: 14px; letter-spacing: .14em; }
.face-card p { font-size: 14.5px; line-height: 2.05; color: var(--c-ink-soft); margin: 0; }

@media (max-width: 960px) { .about-intro-grid { grid-template-columns: 1fr; gap: 48px; } }

/* ============================================================
   Philosophy section
   ============================================================ */
.philosophy {
	background: linear-gradient(180deg, var(--c-bg) 0%, var(--c-rose) 45%, var(--c-bg) 100%);
	text-align: center;
	position: relative;
}
.philosophy::before, .philosophy::after {
	content: ""; position: absolute; left: 50%;
	transform: translateX(-50%);
	width: 60px; height: 1px; background: var(--c-gold);
}
.philosophy::before { top: 60px; }
.philosophy::after  { bottom: 60px; }

.philosophy-mark {
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 120px; line-height: 1;
	background: var(--gold-foil); background-clip: text; -webkit-background-clip: text;
	color: transparent; background-size: 200% 100%;
	opacity: .55; margin-bottom: 24px;
}

.philosophy-quote {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(24px, 3.4vw, 38px);
	line-height: 2;
	letter-spacing: .16em;
	color: var(--c-ink);
	margin: 0 auto 64px;
	max-width: 820px;
}
.philosophy-quote em {
	font-style: normal;
	background: var(--gold-foil); background-clip: text; -webkit-background-clip: text;
	color: transparent;
}

.philosophy-pillars {
	display: grid; grid-template-columns: repeat(3, 1fr);
	gap: 56px; margin-top: 76px;
	max-width: 1000px; margin-left: auto; margin-right: auto;
}
.pillar { text-align: center; position: relative; padding: 0 8px; }
.pillar:not(:last-child)::after {
	content: ""; position: absolute;
	right: -28px; top: 50%; transform: translateY(-50%);
	width: 1px; height: 60%;
	background: linear-gradient(to bottom, transparent, var(--c-gold) 30%, var(--c-gold) 70%, transparent);
	opacity: .5;
}
.pillar-no {
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 56px; font-weight: 300; line-height: 1;
	background: var(--gold-foil); background-clip: text; -webkit-background-clip: text;
	color: transparent; background-size: 200% 100%;
	margin-bottom: 22px; display: block;
}
.pillar h3 { font-size: 22px; font-weight: 400; margin-bottom: 16px; letter-spacing: .18em; }
.pillar p { font-size: 14.5px; color: var(--c-ink-soft); line-height: 2.05; max-width: 240px; margin: 0 auto; }

@media (max-width: 768px) {
	.philosophy-pillars { grid-template-columns: 1fr; gap: 48px; }
	.pillar:not(:last-child)::after { display: none; }
}

/* ============================================================
   Program section — editorial magazine layout
   ============================================================ */
.program-section {
	background: var(--c-teal-deep);
	color: var(--c-bg);
	position: relative;
	overflow: hidden;
}
.program-section::before {
	content: ""; position: absolute;
	top: -150px; right: -150px;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(184, 146, 78, .22) 0%, transparent 65%);
	pointer-events: none;
}
.program-section .eyebrow { color: var(--c-gold-light); }
.program-section .eyebrow::before { background: var(--c-gold-light); }
.program-section .section-title { color: var(--c-bg-soft); }
.program-section .section-title em,
.program-section .section-subtitle-gold {
	background: linear-gradient(135deg, #E6CFA0 0%, #D4B772 50%, #E6CFA0 100%);
	background-clip: text; -webkit-background-clip: text;
	color: transparent;
}
.program-section .section-lead { color: rgba(245, 239, 226, .8); }

/* プログラムセクション内のボタン — 暗背景に金ベタ塗りで明確に */
.program-section .btn:not(.btn--gold) {
	background: var(--c-gold-light);
	color: var(--c-teal-deep);
	border-color: var(--c-gold-light);
}
.program-section .btn:not(.btn--gold):hover {
	background: var(--c-bg-soft);
	color: var(--c-teal-deep);
	border-color: var(--c-bg-soft);
}

.program-hero-grid {
	display: grid; grid-template-columns: 1fr 1.05fr;
	gap: 84px; align-items: center;
	margin-bottom: 100px;
}
.program-hero-image { aspect-ratio: 4/5; position: relative; overflow: hidden; }
.program-hero-image::after {
	content: ""; position: absolute; inset: 18px;
	border: 1px solid var(--c-gold-light);
	pointer-events: none;
}
.program-hero-image img { width: 100%; height: 100%; object-fit: cover; }

.program-features {
	list-style: none; padding: 0;
	margin: 36px 0 52px;
	display: grid; gap: 16px;
}
.program-features li {
	padding-left: 30px; position: relative;
	font-family: var(--font-serif); font-weight: 300;
	font-size: 16px; line-height: 1.9;
	color: rgba(245, 239, 226, .9);
}
.program-features li::before {
	content: "❋"; position: absolute;
	left: 0; top: 1px;
	color: var(--c-gold-light); font-size: 14px;
}

.program-steps-title { text-align: center; margin-bottom: 60px; }
.program-steps {
	display: grid; grid-template-columns: repeat(6, 1fr);
	gap: 1px;
	background: rgba(212, 183, 114, .18);
	border-top: 1px solid rgba(212, 183, 114, .3);
	border-bottom: 1px solid rgba(212, 183, 114, .3);
	position: relative;
}
.program-step {
	background: var(--c-teal-deep);
	padding: 48px 22px;
	text-align: center;
	transition: background .4s var(--easing);
}
.program-step:hover { background: rgba(184, 146, 78, .08); }
.program-step-no {
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 44px; font-weight: 300; line-height: 1;
	background: var(--gold-foil); background-clip: text; -webkit-background-clip: text;
	color: transparent;
	display: block;
	margin-bottom: 24px;
}
.program-step h4 {
	font-size: 16px; font-weight: 400;
	color: var(--c-bg-soft);
	margin-bottom: 14px;
	letter-spacing: .12em;
	line-height: 1.6;
}
.program-step p {
	font-size: 12.5px;
	color: rgba(245, 239, 226, .7);
	line-height: 1.9; margin: 0;
}

.program-cta { text-align: center; margin-top: 80px; }

@media (max-width: 960px) {
	.program-hero-grid { grid-template-columns: 1fr; gap: 52px; }
	.program-steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
	.program-steps { grid-template-columns: 1fr; }
}

/* ============================================================
   Timeline (人生年表) v2 — エディトリアルマガジン調
   ============================================================ */
.life-timeline-section { padding: 130px 0; }

.timeline {
	position: relative;
	max-width: 1080px;
	margin: 5rem auto 0;
	padding: 60px 0 80px;
}

/* 金色グラデーションの背骨ライン */
.timeline::before {
	content: ""; position: absolute;
	top: 40px; bottom: 60px; left: 50%;
	width: 2px;
	background: linear-gradient(to bottom,
		transparent 0%,
		rgba(184, 146, 78, .35) 6%,
		var(--c-gold) 50%,
		rgba(184, 146, 78, .35) 94%,
		transparent 100%
	);
	transform: translateX(-1px);
}

/* 上下の装飾オーナメント（小さな金の円） */
.timeline::after {
	content: "";
	position: absolute;
	top: 24px; left: 50%; transform: translateX(-50%);
	width: 12px; height: 12px;
	border-radius: 50%;
	background: var(--c-gold);
	box-shadow: 0 0 0 4px var(--c-bg-soft), 0 0 0 5px rgba(184, 146, 78, .35);
}

.timeline-item {
	display: grid;
	grid-template-columns: 1fr 96px 1fr;
	gap: 28px;
	align-items: start;
	margin-bottom: 88px;
	position: relative;
}
.timeline-item:last-child { margin-bottom: 24px; }

/* カード本体：エディトリアルマガジン調 */
.timeline-item-content {
	padding: 44px 40px;
	background: var(--c-surface);
	position: relative;
	box-shadow: 0 10px 40px rgba(44, 37, 33, .04);
	transition: transform .45s var(--easing), box-shadow .45s var(--easing);
}
.timeline-item-content:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 48px rgba(44, 37, 33, .08);
}

/* カード上端の金グラデライン（細・グラデで装飾性アップ） */
.timeline-item-content::before {
	content: ""; position: absolute;
	top: 0; left: 0; right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent 0%, var(--c-gold) 30%, var(--c-gold) 70%, transparent 100%);
}

/* ステージバッジ（カード最上部の小さな装飾ラベル） */
.timeline-stage-badge {
	display: inline-block;
	font-family: var(--font-serif);
	font-size: 13px;
	letter-spacing: .25em;
	color: var(--c-gold-deep);
	margin: 0 0 22px;
	padding: 6px 18px;
	background: linear-gradient(135deg, rgba(184, 146, 78, .06) 0%, rgba(184, 146, 78, .12) 100%);
	border-top: 1px solid var(--c-gold-soft);
	border-bottom: 1px solid var(--c-gold-soft);
}

/* 年齢ブロック */
.timeline-age {
	margin: 0 0 24px;
	line-height: 1;
	display: flex;
	align-items: baseline;
	gap: 16px;
	flex-wrap: wrap;
}
.timeline-age-num {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 120px;
	font-weight: 400;
	line-height: 1.15;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
	display: inline-block;
	padding-bottom: 6px;
}
.timeline-age-suffix {
	font-family: var(--font-serif);
	font-size: 32px;
	font-weight: 300;
	color: var(--c-gold-deep);
	letter-spacing: .1em;
}
.timeline-year {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 14px;
	letter-spacing: .25em;
	color: var(--c-gold-deep);
	padding-bottom: 4px;
	border-bottom: 1px solid var(--c-gold-soft);
}

/* タイトル：明朝でしっかりと */
.timeline-title {
	font-family: var(--font-serif);
	font-weight: 400;
	font-size: 23px;
	letter-spacing: .12em;
	line-height: 1.55;
	margin: 0 0 12px;
	color: var(--c-ink);
}

/* サブタイトル：イタリック金色 */
.timeline-subtitle {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 14px;
	letter-spacing: .14em;
	color: var(--c-gold-deep);
	margin: 0 0 22px;
	line-height: 1.7;
}

/* 本文 */
.timeline-desc {
	font-size: 14.5px;
	line-height: 2.1;
	color: var(--c-ink-soft);
	margin: 0;
}

/* マーカー：外側リング + 内側ドット + ハロー */
.timeline-marker {
	width: 52px; height: 52px;
	border-radius: 50%;
	background: var(--c-bg-soft);
	border: 1px solid var(--c-gold);
	margin: 36px auto 0;
	position: relative;
	z-index: 2;
	box-shadow: 0 0 0 6px var(--c-bg-soft);
}
.timeline-marker::before {
	content: ""; position: absolute;
	inset: -6px;
	border-radius: 50%;
	border: 1px solid rgba(184, 146, 78, .25);
}
.timeline-marker::after {
	content: ""; position: absolute;
	inset: 14px;
	border-radius: 50%;
	background: var(--c-gold);
	box-shadow: 0 0 0 4px rgba(184, 146, 78, .12);
}

/* 交互配置：奇数右寄せ／偶数左寄せ */
.timeline-item:nth-child(odd) .timeline-item-content { grid-column: 1; text-align: right; }
.timeline-item:nth-child(odd) .timeline-marker       { grid-column: 2; }
.timeline-item:nth-child(odd) .timeline-spacer       { grid-column: 3; }
.timeline-item:nth-child(odd) .timeline-age          { justify-content: flex-end; }

.timeline-item:nth-child(even) .timeline-spacer       { grid-column: 1; }
.timeline-item:nth-child(even) .timeline-marker       { grid-column: 2; }
.timeline-item:nth-child(even) .timeline-item-content { grid-column: 3; text-align: left; }

@media (max-width: 768px) {
	.life-timeline-section { padding: 80px 0; }
	.timeline { padding: 40px 0 60px; }
	.timeline::before { left: 28px; }
	.timeline::after { left: 28px; }
	.timeline-item,
	.timeline-item:nth-child(odd),
	.timeline-item:nth-child(even) {
		grid-template-columns: 56px 1fr; gap: 18px;
	}
	.timeline-item:nth-child(odd) .timeline-marker,
	.timeline-item:nth-child(even) .timeline-marker {
		grid-column: 1; margin: 32px 0 0;
	}
	.timeline-item:nth-child(odd) .timeline-item-content,
	.timeline-item:nth-child(even) .timeline-item-content {
		grid-column: 2; text-align: left; padding: 32px 26px;
	}
	.timeline-item:nth-child(odd) .timeline-age,
	.timeline-item:nth-child(even) .timeline-age { justify-content: flex-start; }
	.timeline-spacer { display: none; }
	.timeline-age-num { font-size: 88px; }
	.timeline-age-suffix { font-size: 26px; }
	.timeline-marker { width: 40px; height: 40px; }
	.timeline-marker::after { inset: 11px; }
}

/* ============================================================
   SNS section — paper background でリズム作る
   ============================================================ */
.sns-section { background: var(--c-paper); }
.sns-grid {
	display: grid; grid-template-columns: 1.4fr 1fr;
	gap: 72px; align-items: center;
}
.youtube-embed {
	position: relative; aspect-ratio: 16/9;
	background: var(--c-teal-deep);
	overflow: hidden;
}
.youtube-embed::before {
	content: ""; position: absolute; inset: 0;
	box-shadow: inset 0 0 0 1px rgba(184, 146, 78, .3);
	pointer-events: none; z-index: 2;
}
.youtube-embed iframe { width: 100%; height: 100%; border: 0; }

.sns-channels { padding: 0; list-style: none; }
.sns-channels li { border-bottom: 1px solid var(--c-line); transition: border-color .35s var(--easing); }
.sns-channels li:hover { border-bottom-color: var(--c-gold); }
.sns-channels a {
	display: flex; align-items: center; gap: 24px;
	padding: 26px 4px;
	font-family: var(--font-serif); font-size: 16px;
	letter-spacing: .15em; color: var(--c-ink);
	transition: color .35s var(--easing), padding-left .35s var(--easing);
}
.sns-channels a:hover { color: var(--c-gold-deep); padding-left: 12px; }
.sns-channels-icon { width: 28px; height: 28px; color: var(--c-gold-deep); flex-shrink: 0; transition: color .35s var(--easing); }
.sns-channels a:hover .sns-channels-icon { color: var(--c-gold); }
.sns-channels-arrow { margin-left: auto; font-family: var(--font-en-serif); font-style: italic; color: var(--c-gold-deep); transition: transform .35s var(--easing); }
.sns-channels a:hover .sns-channels-arrow { transform: translateX(4px); }

@media (max-width: 960px) { .sns-grid { grid-template-columns: 1fr; gap: 48px; } }

/* SNS footer icons */
.sns-icons { display: flex; gap: 14px; list-style: none; padding: 0; margin: 24px 0 0; }
.sns-icons a {
	display: inline-flex; width: 42px; height: 42px;
	align-items: center; justify-content: center;
	border: 1px solid var(--c-line);
	color: var(--c-ink-soft);
	transition: background .35s var(--easing), color .35s var(--easing), border-color .35s var(--easing);
}
.sns-icons a:hover { background: var(--c-gold); color: var(--c-bg-soft); border-color: var(--c-gold); }
.sns-icon svg { width: 18px; height: 18px; }

/* ============================================================
   Newsletter CTA
   ============================================================ */
.newsletter {
	background: var(--c-teal-deep);
	color: var(--c-bg-soft);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.newsletter::before {
	content: ""; position: absolute;
	top: 50%; left: 50%; transform: translate(-50%, -50%);
	width: 800px; height: 800px;
	background: radial-gradient(circle, rgba(184, 146, 78, .12) 0%, transparent 60%);
	pointer-events: none;
}
.newsletter .container { position: relative; z-index: 1; }
.newsletter .section-title { color: var(--c-bg-soft); }
.newsletter .eyebrow { color: var(--c-gold-light); }
.newsletter .eyebrow::before { background: var(--c-gold-light); }
.newsletter-lead {
	font-family: var(--font-serif); font-weight: 300;
	font-size: 17px; line-height: 2.25;
	color: rgba(245, 239, 226, .85);
	max-width: 660px; margin: 0 auto 52px;
}
.newsletter-actions { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; }
.newsletter .btn--gold {
	background: var(--c-gold); color: var(--c-teal-deep); border-color: var(--c-gold);
}
.newsletter .btn--gold:hover {
	background: var(--c-bg-soft); color: var(--c-teal-deep); border-color: var(--c-bg-soft);
}

/* ============================================================
   Page header / Breadcrumb / Single content
   ============================================================ */
.page-header {
	padding: 170px 0 70px;
	background: var(--c-bg-soft);
	border-bottom: 1px solid var(--c-line);
	text-align: center;
	position: relative;
}
.page-header::after {
	content: ""; position: absolute; bottom: -1px; left: 50%;
	transform: translateX(-50%);
	width: 80px; height: 1px; background: var(--c-gold);
}
.page-header h1 { font-size: clamp(30px, 4.2vw, 44px); font-weight: 300; margin-bottom: 10px; letter-spacing: .14em; }
.page-header-en { font-family: var(--font-en-serif); font-style: italic; font-size: 13px; letter-spacing: .42em; color: var(--c-gold-deep); text-transform: uppercase; }

.breadcrumb { padding: 16px 0; background: var(--c-bg-alt); border-bottom: 1px solid var(--c-line); }
.breadcrumb ol {
	max-width: var(--max-w); margin: 0 auto; padding: 0 32px;
	list-style: none; display: flex; flex-wrap: wrap; gap: 8px;
	font-size: 12px; color: var(--c-ink-soft);
}
.breadcrumb li:not(:last-child)::after { content: "/"; margin-left: 8px; color: var(--c-ink-faint); }
.breadcrumb a:hover { color: var(--c-gold-deep); }

.entry-content {
	max-width: 720px; margin: 0 auto;
	padding: 90px 24px;
	font-size: 16px; line-height: 2.15;
	color: var(--c-ink-mid);
}
.entry-content > p:first-of-type::first-letter {
	font-family: var(--font-serif);
	font-size: 4.2em; float: left;
	line-height: .85; margin: 4px 14px 0 0;
	background: var(--gold-foil);
	background-clip: text; -webkit-background-clip: text;
	color: transparent; font-weight: 400;
}
.entry-content h2 { font-size: 28px; font-weight: 400; margin: 2.6em 0 1em; padding-bottom: .5em; border-bottom: 1px solid var(--c-line); position: relative; }
.entry-content h2::before {
	content: ""; position: absolute; bottom: -1px; left: 0;
	width: 40px; height: 1px; background: var(--c-gold);
}
.entry-content h3 { font-size: 21px; font-weight: 400; margin: 2em 0 .8em; color: var(--c-gold-deep); }
.entry-content a { color: var(--c-gold-deep); border-bottom: 1px solid var(--c-gold); }
.entry-content a:hover { color: var(--c-gold); }
.entry-content blockquote {
	margin: 2.4em 0; padding: 1.4em 2em;
	border-left: 2px solid var(--c-gold);
	background: var(--c-bg-soft);
	font-family: var(--font-serif); font-style: italic;
	color: var(--c-ink-soft); position: relative;
}
.entry-content blockquote::before {
	content: "❝"; position: absolute; top: 10px; left: 16px;
	font-size: 28px; color: var(--c-gold); opacity: .55;
}

/* ============================================================
   Archive cards
   ============================================================ */
.archive-grid {
	max-width: var(--max-w); margin: 0 auto;
	padding: 80px 32px;
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 44px;
}
.archive-card {
	background: var(--c-surface);
	border: 1px solid var(--c-line);
	transition: border-color .4s var(--easing), transform .4s var(--easing);
	position: relative;
}
.archive-card::before {
	content: ""; position: absolute; top: 0; left: 0;
	width: 0; height: 2px; background: var(--c-gold);
	transition: width .5s var(--easing-out);
}
.archive-card:hover { border-color: var(--c-gold); transform: translateY(-4px); }
.archive-card:hover::before { width: 100%; }
.archive-card a { display: block; }
.archive-card-thumb { aspect-ratio: 4/3; background: var(--c-bg-alt); overflow: hidden; }
.archive-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.5s var(--easing); }
.archive-card:hover .archive-card-thumb img { transform: scale(1.04); }
.archive-card-body { padding: 28px; }
.archive-card-date { font-family: var(--font-en-serif); font-style: italic; font-size: 12px; letter-spacing: .3em; color: var(--c-gold-deep); margin-bottom: 10px; }
.archive-card-title { font-size: 18px; font-weight: 400; margin-bottom: 14px; line-height: 1.65; letter-spacing: .08em; }
.archive-card-excerpt { font-size: 13.5px; color: var(--c-ink-soft); line-height: 1.95; }

@media (max-width: 960px) { .archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .archive-grid { grid-template-columns: 1fr; } }

/* ============================================================
   Footer
   ============================================================ */
.site-footer {
	background: var(--c-ink);
	color: rgba(245, 239, 226, .6);
	padding: 100px 0 36px;
	position: relative;
}
.site-footer::before {
	content: ""; position: absolute; top: 0; left: 50%;
	transform: translateX(-50%);
	width: 100px; height: 1px; background: var(--c-gold);
}
.footer-inner {
	max-width: var(--max-w); margin: 0 auto;
	padding: 0 32px;
	display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
	gap: 64px; margin-bottom: 72px;
}
.footer-brand .site-logo-text .logo-name { color: var(--c-bg-soft); font-size: 19px; }
.footer-brand .site-logo-text .logo-en   { color: var(--c-gold-light); }
.footer-brand p { font-size: 13.5px; color: rgba(245, 239, 226, .6); line-height: 2.05; margin-top: 22px; max-width: 340px; }

.footer-widget-title, .footer-nav-title {
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 12px; letter-spacing: .35em;
	margin-bottom: 24px;
	color: var(--c-gold-light);
	text-transform: uppercase;
}
.footer-nav ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.footer-nav a { font-family: var(--font-serif); font-size: 13.5px; color: rgba(245, 239, 226, .6); letter-spacing: .08em; transition: color .35s var(--easing); }
.footer-nav a:hover { color: var(--c-gold-light); }

.footer-bottom {
	max-width: var(--max-w); margin: 0 auto;
	padding: 28px 32px 0;
	border-top: 1px solid rgba(184, 146, 78, .18);
	display: flex; justify-content: space-between; align-items: center;
	flex-wrap: wrap; gap: 20px;
	font-family: var(--font-en-serif); font-style: italic;
	font-size: 11px; letter-spacing: .15em;
	color: rgba(245, 239, 226, .4);
}

@media (max-width: 960px) { .footer-inner { grid-template-columns: 1fr 1fr; gap: 44px; } }
@media (max-width: 600px) { .footer-inner { grid-template-columns: 1fr; } }

/* ============================================================
   Mobile refinements — 横マージン＆ヒーロー調整 (v2.3)
   ============================================================ */
@media (max-width: 768px) {
	.container,
	.container-wide,
	.footer-inner,
	.archive-grid { padding-left: 24px; padding-right: 24px; }
	.breadcrumb ol,
	.footer-bottom { padding-left: 24px; padding-right: 24px; }
	.hero-inner { padding-left: 24px; padding-right: 24px; }
	.site-header-inner { padding-left: 18px; padding-right: 18px; }
}

@media (max-width: 480px) {
	.container,
	.container-narrow,
	.container-wide,
	.footer-inner,
	.archive-grid { padding-left: 20px; padding-right: 20px; }
	.breadcrumb ol,
	.footer-bottom { padding-left: 20px; padding-right: 20px; }
	.hero-inner { padding-left: 20px; padding-right: 20px; }
	.hero { padding-top: 100px; padding-bottom: 56px; }
	.hero-tagline {
		font-size: clamp(36px, 11vw, 54px);
		letter-spacing: .08em;
		margin-bottom: 22px;
		word-break: keep-all;
		overflow-wrap: break-word;
	}
	.hero-tagline em { white-space: nowrap; }
	.hero-eyebrow { letter-spacing: .3em; margin-bottom: 28px; }
	.hero-tagline-en { font-size: 14px; letter-spacing: .22em; margin-bottom: 32px; }
	.hero-subline { font-size: 15.5px; line-height: 2.15; margin-bottom: 36px; }
	.hero-cta-group { gap: 14px; margin-bottom: 40px; }
	.hero-name-jp { font-size: 18px; }
	.hero-titles { font-size: 12px; }
	.hero-portrait::after { inset: 12px; }
	.section-title { letter-spacing: .08em; }
	.section-lead { font-size: 15.5px; line-height: 2.05; }
	.philosophy-quote { letter-spacing: .1em; }
	.timeline-item-content { padding: 26px 22px; }
}

/* ============================================================
   Animations
   ============================================================ */
.fade-in {
	opacity: 0; transform: translateY(28px);
	transition: opacity 1.2s var(--easing), transform 1.2s var(--easing);
}
.fade-in.is-visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
	.fade-in { opacity: 1; transform: none; transition: none; }
	.hero-portrait img { transition: none; }
	.gold-foil, .pillar-no, .timeline-age-num, .program-step-no, .hero-tagline em, .section-subtitle-gold { animation: none; }
	html { scroll-behavior: auto; }
}

/* ============================================================
   Accessibility
   ============================================================ */
.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;
}
a:focus-visible, button:focus-visible, input:focus-visible {
	outline: 2px solid var(--c-gold);
	outline-offset: 3px;
}


/* ============================================================
   v3.1 追加: 未来再誕アトリエ関連
   ============================================================ */

/* --- ヒーローの背景花装飾 --- */
.hero-decor {
	position: absolute;
	top: 0; right: 0;
	width: 55%;
	height: 100%;
	background-size: cover;
	background-position: center;
	opacity: .32;
	pointer-events: none;
	z-index: 0;
}
/* スマホでは右半分の切れ目を避けて全幅に */
@media (max-width: 960px) {
	.hero-decor {
		width: 100%;
		opacity: .22;
	}
}
@media (max-width: 480px) {
	.hero-decor {
		opacity: .18;
	}
}
/* .hero > * のルールは削除（.hero-decorのabsoluteを破壊してたため）*/

/* --- 3章ステージ --- */
.three-chapters { background: var(--c-paper); position: relative; }
.three-chapters::before {
	content: ""; position: absolute;
	top: 0; left: 50%; transform: translateX(-50%);
	width: 60px; height: 1px; background: var(--c-gold);
}

.chapter-stages {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 3rem;
}
.chapter-stage {
	display: block;
	padding: 44px 32px 36px;
	background: var(--c-surface);
	border-top: 1px solid var(--c-gold-light);
	position: relative;
	transition: transform .5s var(--easing), background .4s var(--easing), border-color .4s var(--easing);
	overflow: hidden;
}
.chapter-stage::after {
	content: ""; position: absolute;
	top: 0; left: 0; right: 0; height: 0;
	background: linear-gradient(180deg, rgba(184, 146, 78, .08), transparent);
	transition: height .5s var(--easing);
}
.chapter-stage:hover {
	transform: translateY(-4px);
	border-top-color: var(--c-gold);
}
.chapter-stage:hover::after { height: 100%; }
.chapter-stage > * { position: relative; z-index: 1; }

.chapter-stage-no {
	display: block;
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 64px;
	line-height: 1;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
	margin-bottom: 18px;
}
.chapter-stage-tag {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 11px;
	letter-spacing: .35em;
	color: var(--c-gold-deep);
	margin: 0 0 14px;
	text-transform: uppercase;
}
.chapter-stage h3 {
	font-family: var(--font-serif);
	font-weight: 400;
	font-size: 24px;
	letter-spacing: .14em;
	margin: 0 0 12px;
	line-height: 1.4;
}
.chapter-stage h3 small {
	display: block;
	font-size: 12px;
	letter-spacing: .3em;
	color: var(--c-gold-deep);
	font-style: italic;
	font-family: var(--font-en-serif);
	margin-top: 6px;
}
.chapter-stage p {
	font-size: 14px;
	line-height: 2.05;
	color: var(--c-ink-soft);
	margin: 0 0 22px;
}
.chapter-stage-arrow {
	display: inline-block;
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 12px;
	letter-spacing: .15em;
	color: var(--c-gold-deep);
	border-bottom: 1px solid var(--c-gold);
	padding-bottom: 4px;
	transition: padding-left .35s var(--easing);
}
.chapter-stage:hover .chapter-stage-arrow {
	padding-left: 8px;
	color: var(--c-gold);
}

/* 真ん中のステージ：少し背景を変える */
.chapter-stage--mid {
	background: var(--c-bg-soft);
}

/* 強調（第3章のアトリエ） */
.chapter-stage--featured {
	background: linear-gradient(180deg, var(--c-bg-soft) 0%, var(--c-rose) 100%);
	border-top-color: var(--c-gold);
}
.chapter-stage--featured .chapter-stage-no {
	background: linear-gradient(135deg, #D4B772, #B8924E, #C99B91, #D4B772);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}

.chapter-stage--current {
	background: linear-gradient(180deg, var(--c-bg-soft), var(--c-rose));
	border-top-width: 2px;
}
.chapter-stage-link {
	display: inline-block;
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 12px;
	letter-spacing: .15em;
	color: var(--c-gold-deep);
	border-bottom: 1px solid var(--c-gold);
	padding-bottom: 4px;
}
.chapter-stage-link--current { color: var(--c-rose-deep); border-bottom-color: var(--c-rose-deep); }

@media (max-width: 768px) {
	.chapter-stages { grid-template-columns: 1fr; }
}

/* ============================================================
   ATELIER TEASER v2 — 花画像をフルカラーで主役にした分割レイアウト
   ============================================================ */
.atelier-teaser {
	background: var(--c-teal-deep);
	color: var(--c-bg-soft);
	padding: 0;
	overflow: hidden;
}
.atelier-teaser-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: stretch;
	min-height: 620px;
}
.atelier-teaser-visual {
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
}
.atelier-teaser-visual::after {
	content: ""; position: absolute;
	top: 0; right: 0;
	width: 25%; height: 100%;
	background: linear-gradient(to right, transparent, var(--c-teal-deep));
	pointer-events: none;
}
.atelier-teaser-visual::before {
	content: ""; position: absolute;
	top: 24px; left: 24px;
	right: 24px; bottom: 24px;
	border: 1px solid rgba(212, 183, 114, .45);
	pointer-events: none;
	z-index: 1;
}
.atelier-teaser-text {
	background: var(--c-teal-deep);
	padding: 90px 72px;
	display: flex;
	align-items: center;
	position: relative;
}
.atelier-teaser-text::before {
	content: ""; position: absolute;
	top: 0; left: 50%; transform: translateX(-50%);
	width: 60px; height: 1px;
	background: var(--c-gold-light);
}
.atelier-teaser-content { max-width: 540px; width: 100%; }
.atelier-teaser-content .eyebrow {
	color: var(--c-gold-light);
}
.atelier-teaser-content .eyebrow::before {
	background: var(--c-gold-light);
}
.atelier-teaser-title {
	color: var(--c-bg-soft);
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(38px, 4.5vw, 58px);
	letter-spacing: .12em;
	line-height: 1.35;
	margin: 0 0 16px;
}
.atelier-teaser-title em {
	background: none;
	color: #F0DCA0;
	-webkit-text-fill-color: #F0DCA0;
	font-style: normal;
}
.atelier-teaser-sub {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 14.5px;
	letter-spacing: .25em;
	color: var(--c-gold-light);
	margin: 0 0 32px;
}
.atelier-teaser-lead {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(17px, 2.1vw, 23px);
	line-height: 2;
	letter-spacing: .12em;
	color: rgba(250, 245, 236, .95);
	margin: 0 0 24px;
}
.atelier-teaser-lead em {
	font-style: normal;
	color: #F0DCA0;
}
.atelier-teaser-note {
	font-size: 14px;
	line-height: 2.05;
	color: rgba(250, 245, 236, .75);
	margin: 0;
}
.atelier-teaser-note strong {
	color: var(--c-gold-light);
	font-weight: 400;
	border-bottom: 1px solid var(--c-gold);
}

@media (max-width: 960px) {
	.atelier-teaser-grid {
		grid-template-columns: 1fr;
		min-height: auto;
	}
	.atelier-teaser-visual {
		aspect-ratio: 16/10;
	}
	.atelier-teaser-visual::after {
		top: auto; right: 0; bottom: 0;
		width: 100%; height: 50%;
		background: linear-gradient(to bottom, transparent, var(--c-teal-deep));
	}
	.atelier-teaser-text { padding: 56px 28px; }
	.atelier-teaser-content { max-width: none; }
}

/* --- ローズボタン --- */
.btn--rose {
	background: var(--c-rose-deep);
	color: var(--c-bg-soft);
	border-color: var(--c-rose-deep);
}
.btn--rose:hover {
	background: var(--c-gold-light);
	color: var(--c-teal-deep);
	border-color: var(--c-gold-light);
}

/* ============================================================
   ATELIER PAGE — 未来再誕アトリエ専用
   ============================================================ */
.atelier-hero {
	position: relative;
	min-height: 80vh;
	padding: 160px 24px 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	text-align: center;
}
@media (max-width: 768px) {
	.atelier-hero {
		min-height: auto;
		padding: 130px 20px 80px;
	}
}
.atelier-hero-bg {
	position: absolute; inset: 0;
	background-size: cover; background-position: center;
	opacity: .35;
}
.atelier-hero-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(250, 245, 236, .82) 0%, rgba(245, 239, 226, .9) 100%);
}
.atelier-hero-inner {
	position: relative; z-index: 1;
	max-width: 800px;
}
.atelier-hero-title {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(42px, 6vw, 84px);
	letter-spacing: .12em;
	line-height: 1.35;
	margin: 24px 0 24px;
	color: var(--c-ink);
}
.atelier-hero-title em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
	animation: shimmer 8s ease-in-out infinite;
}
.atelier-hero-en {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: clamp(14px, 1.5vw, 17px);
	letter-spacing: .3em;
	color: var(--c-gold-deep);
	margin: 0 0 32px;
}
.atelier-hero-lead {
	font-family: var(--font-serif);
	font-size: clamp(16px, 1.8vw, 19px);
	line-height: 2.1;
	letter-spacing: .12em;
	color: var(--c-ink-soft);
	max-width: 600px;
	margin: 0 auto;
}

/* 定義セクション */
.atelier-define { background: var(--c-bg-alt); position: relative; }
.atelier-quote {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(22px, 3vw, 32px);
	line-height: 2.05;
	letter-spacing: .15em;
	color: var(--c-ink);
	text-align: center;
	margin: 0 auto;
	max-width: 720px;
}
.atelier-quote em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}

/* 4軸グリッド */
.atelier-axes-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
	margin-top: 4rem;
}
.atelier-axis {
	padding: 42px 36px;
	background: var(--c-bg-soft);
	border-top: 1px solid var(--c-gold);
	transition: transform .5s var(--easing);
}
.atelier-axis:hover { transform: translateY(-4px); }
.atelier-axis-no {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 48px;
	line-height: 1;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
	margin: 0 0 8px;
}
.atelier-axis-tag {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 10px;
	letter-spacing: .4em;
	color: var(--c-gold-deep);
	margin: 0 0 12px;
}
.atelier-axis h3 {
	font-size: 22px;
	font-weight: 400;
	margin: 0 0 16px;
	letter-spacing: .14em;
}
.atelier-axis p {
	font-size: 14.5px;
	line-height: 2.05;
	color: var(--c-ink-soft);
	margin: 0;
}

@media (max-width: 768px) {
	.atelier-axes-grid { grid-template-columns: 1fr; }
}

/* 4フェーズグリッド */
.atelier-phases-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 32px;
	margin-top: 4rem;
}
.atelier-phase {
	padding: 36px 36px;
	background: var(--c-surface);
	border-left: 2px solid var(--c-gold);
	position: relative;
}
.atelier-phase-header {
	display: flex; align-items: center; gap: 20px;
	margin-bottom: 18px;
}
.atelier-phase-no {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 44px;
	line-height: 1;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}
.atelier-phase-tag {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 10px;
	letter-spacing: .35em;
	color: var(--c-gold-deep);
	margin: 0 0 6px;
}
.atelier-phase h3 {
	font-size: 22px;
	font-weight: 400;
	margin: 0;
	letter-spacing: .14em;
}
.atelier-phase-lead {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 15px;
	color: var(--c-gold-deep);
	margin: 0 0 14px;
	letter-spacing: .1em;
}
.atelier-phase-desc {
	font-size: 14px;
	line-height: 2.05;
	color: var(--c-ink-soft);
	margin: 0;
}

@media (max-width: 768px) {
	.atelier-phases-grid { grid-template-columns: 1fr; }
}

/* 言葉の意味セクション */
.atelier-meaning { background: var(--c-paper); }
.atelier-meaning-grid {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: 72px;
	align-items: center;
}
.atelier-meaning-image {
	aspect-ratio: 3/4;
	background-size: cover;
	background-position: center;
	position: relative;
}
.atelier-meaning-image::after {
	content: ""; position: absolute; inset: 18px;
	border: 1px solid var(--c-gold);
	pointer-events: none;
}
.atelier-meaning-list { margin: 3rem 0 0; }
.atelier-meaning-list > div {
	display: grid;
	grid-template-columns: 100px 1fr;
	gap: 28px;
	padding: 22px 0;
	border-bottom: 1px solid var(--c-line);
}
.atelier-meaning-list dt {
	font-family: var(--font-serif);
	font-size: 14px;
	letter-spacing: .18em;
	color: var(--c-gold-deep);
}
.atelier-meaning-list dd {
	margin: 0;
	font-size: 14.5px;
	line-height: 2.05;
	color: var(--c-ink-soft);
}

@media (max-width: 768px) {
	.atelier-meaning-grid { grid-template-columns: 1fr; gap: 36px; }
}

/* メッセージセクション（深いティール背景） */
.atelier-message {
	color: var(--c-bg-soft);
	text-align: center;
}
.atelier-message .eyebrow { color: var(--c-gold-light); }
.atelier-message .eyebrow::before { background: var(--c-gold-light); }
.atelier-message-text {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(19px, 2.4vw, 26px);
	line-height: 2.2;
	letter-spacing: .13em;
	color: rgba(250, 245, 236, .95);
	margin: 2rem 0;
}
.atelier-message-text em {
	font-style: normal;
	background: linear-gradient(135deg, #E6CFA0, #D4B772, #E6CFA0);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
}
.atelier-message-closing {
	font-family: var(--font-serif);
	font-size: 15.5px;
	line-height: 2.15;
	letter-spacing: .12em;
	color: rgba(250, 245, 236, .75);
	margin: 3rem 0 0;
}
.atelier-message-closing strong {
	color: var(--c-gold-light);
	font-weight: 400;
	font-size: 22px;
	letter-spacing: .18em;
}

/* ============================================================
   ABOUT PAGE — リッチプロフィール用
   ============================================================ */
.about-hero { padding-top: 180px; padding-bottom: 80px; position: relative; }

.about-rich-grid {
	display: grid;
	grid-template-columns: .9fr 1.1fr;
	gap: 72px;
	align-items: start;
}
.about-rich-photo {
	position: relative;
	aspect-ratio: 3/4;
}
.about-rich-photo img {
	width: 100%; height: 100%;
	object-fit: cover;
	position: relative; z-index: 1;
}
.about-photo-placeholder {
	width: 100%; height: 100%;
	background: linear-gradient(135deg, var(--c-rose), var(--c-bg-alt));
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-en-serif); font-style: italic; letter-spacing: .35em; color: var(--c-ink-faint);
}
.about-photo-frame {
	position: absolute;
	top: 24px; left: 24px;
	width: 100%; height: 100%;
	border: 1px solid var(--c-gold);
	pointer-events: none;
	z-index: 0;
}
.about-photo-flower {
	position: absolute;
	bottom: -30px; right: -30px;
	width: 160px; height: 160px;
	background-size: cover;
	background-position: center;
	border-radius: 50%;
	opacity: .85;
	z-index: 2;
	border: 4px solid var(--c-bg);
	box-shadow: 0 4px 16px rgba(0,0,0,.08);
}

.about-rich-text .section-title em {
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}

.about-titles-list {
	margin: 2rem 0 0;
	padding: 0;
}
.about-titles-list > div {
	display: grid;
	grid-template-columns: 70px 1fr;
	gap: 18px;
	padding: 14px 0;
	border-bottom: 1px solid var(--c-line);
}
.about-titles-list dt {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 12px;
	letter-spacing: .25em;
	color: var(--c-gold-deep);
	text-transform: uppercase;
}
.about-titles-list dd {
	margin: 0;
	font-family: var(--font-serif);
	font-size: 14.5px;
	letter-spacing: .08em;
}

@media (max-width: 768px) {
	.about-rich-grid { grid-template-columns: 1fr; gap: 48px; }
	.about-photo-flower { width: 100px; height: 100px; }
}

/* 3つの役割 */
.about-roles-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 4rem;
}
.about-role {
	background: var(--c-surface);
	overflow: hidden;
	transition: transform .5s var(--easing);
}
.about-role:hover { transform: translateY(-4px); }
.about-role-image {
	aspect-ratio: 5/3;
	background-size: cover;
	background-position: center;
	position: relative;
}
.about-role-image::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(to bottom, transparent, rgba(44, 37, 33, .25));
}
.about-role-body { padding: 32px 28px; }
.about-role-tag {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 11px;
	letter-spacing: .35em;
	color: var(--c-gold-deep);
	margin: 0 0 14px;
}
.about-role-body h3 {
	font-size: 22px;
	font-weight: 400;
	margin: 0 0 8px;
	letter-spacing: .14em;
}
.about-role-body p:not([style]) {
	font-size: 14px;
	line-height: 2;
	color: var(--c-ink-soft);
	margin: 0;
}

@media (max-width: 960px) {
	.about-roles-grid { grid-template-columns: 1fr; }
}

/* 経歴年表 */
.about-career-list { margin: 0; padding: 0; }
.about-career-row {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 32px;
	padding: 24px 0;
	border-bottom: 1px solid var(--c-line);
}
.about-career-row dt {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 18px;
	letter-spacing: .1em;
	color: var(--c-gold-deep);
}
.about-career-row dd {
	margin: 0;
	font-family: var(--font-serif);
	font-size: 15px;
	line-height: 1.9;
}

@media (max-width: 600px) {
	.about-career-row { grid-template-columns: 1fr; gap: 4px; }
}

/* ============================================================
   PROGRAM PAGE — 華やか化用
   ============================================================ */
.program-page-hero {
	position: relative;
	padding: 160px 24px 100px;
	overflow: hidden;
	border-bottom: 1px solid var(--c-gold-soft);
}
.program-page-hero-decor {
	position: absolute;
	bottom: -10%; right: -10%;
	width: 50%; height: 80%;
	background-size: cover;
	background-position: center;
	opacity: .15;
	pointer-events: none;
	border-radius: 50% 0 0 0;
}


/* ============================================================
   v3.2 追加: 全ページ用「画像showcase 分割ヘッダー」
   ============================================================ */
.page-hero-split {
	padding: 0;
	overflow: hidden;
	border-bottom: 1px solid var(--c-line);
	position: relative;
}
.page-hero-split-grid {
	display: grid;
	grid-template-columns: 1fr .9fr;
	align-items: stretch;
	min-height: 460px;
}
.page-hero-split-text {
	padding: 160px 60px 80px;
	display: flex;
	align-items: center;
	position: relative;
}
.page-hero-split-text-inner { max-width: 520px; width: 100%; }
.page-hero-split-visual {
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
}
.page-hero-split-visual::before {
	content: ""; position: absolute; inset: 24px;
	border: 1px solid rgba(184, 146, 78, .35);
	z-index: 1; pointer-events: none;
}

.page-hero-split h1 {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(34px, 4.4vw, 50px);
	letter-spacing: .14em;
	line-height: 1.45;
	margin: 16px 0 12px;
	color: var(--c-ink);
	word-break: keep-all;
}
/* ヒーロー見出しのモバイル専用改行（PCでは非表示・1行のまま） */
.hero-br-sp { display: none; }
.page-hero-split h1 em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}
.page-hero-split .page-header-en {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 13px;
	letter-spacing: .42em;
	color: var(--c-gold-deep);
	margin: 0;
}
.page-hero-split-sub {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 14px;
	letter-spacing: .3em;
	color: var(--c-gold-deep);
	margin: 18px 0 0;
}

/* テーマカラーバリエーション */
.page-hero-split--cream { background: var(--c-bg-soft); }
.page-hero-split--cream .page-hero-split-visual::after {
	content: ""; position: absolute; top: 0; left: 0;
	width: 25%; height: 100%;
	background: linear-gradient(to right, var(--c-bg-soft), transparent);
	pointer-events: none;
}

.page-hero-split--alt { background: var(--c-bg-alt); }
.page-hero-split--alt .page-hero-split-visual::after {
	content: ""; position: absolute; top: 0; left: 0;
	width: 25%; height: 100%;
	background: linear-gradient(to right, var(--c-bg-alt), transparent);
	pointer-events: none;
}

.page-hero-split--rose { background: linear-gradient(135deg, var(--c-bg) 0%, var(--c-rose) 100%); }
.page-hero-split--rose .page-hero-split-visual::after {
	content: ""; position: absolute; top: 0; left: 0;
	width: 25%; height: 100%;
	background: linear-gradient(to right, var(--c-rose), transparent);
	pointer-events: none;
}

@media (max-width: 960px) {
	/* セクション全体に20pxの左右余白（本文より少し狭めで品よく） */
	.page-hero-split {
		padding: 0 20px;
		box-sizing: border-box;
	}
	.page-hero-split-grid { grid-template-columns: 1fr; min-height: auto; width: 100%; }
	.page-hero-split-visual {
		aspect-ratio: 16/10;
		order: -1;
		width: 100%;
		max-width: 100%;
	}
	/* スマホでもゴールド枠を見やすくする */
	.page-hero-split-visual::before {
		inset: 16px;
		border: 1px solid rgba(184, 146, 78, .45);
	}
	.page-hero-split-visual::after,
	.page-hero-split--cream .page-hero-split-visual::after,
	.page-hero-split--alt .page-hero-split-visual::after,
	.page-hero-split--rose .page-hero-split-visual::after {
		top: auto; left: 0; bottom: 0;
		width: 100%; height: 50%;
	}
	.page-hero-split--cream .page-hero-split-visual::after { background: linear-gradient(to bottom, transparent, var(--c-bg-soft)); }
	.page-hero-split--alt .page-hero-split-visual::after { background: linear-gradient(to bottom, transparent, var(--c-bg-alt)); }
	.page-hero-split--rose .page-hero-split-visual::after { background: linear-gradient(to bottom, transparent, var(--c-rose)); }
	/* テキスト：内側で 4px 追加して本文(24px)と揃える */
	.page-hero-split-text { padding: 70px 4px 60px; }
}

/* スマホ：h1のフォント調整＋本文(24px)と左端を揃える＋長い見出しは改行 */
@media (max-width: 600px) {
	.page-hero-split h1 {
		font-size: clamp(26px, 7vw, 38px);
		letter-spacing: .1em;
	}
	/* 横4px = セクション余白20px + 4px で本文の24pxに揃える */
	.page-hero-split-text { padding: 70px 4px 50px; }
	.hero-br-sp { display: block; }
}

/* /atelier/ heroのオーバーレイ軽量化（画像をもっと見せる） */
.atelier-hero-bg { opacity: .65 !important; }
.atelier-hero-overlay {
	background: linear-gradient(180deg, rgba(250, 245, 236, .55) 0%, rgba(245, 239, 226, .72) 100%) !important;
}


/* ============================================================
   PROGRAM CTA — 全ページ末尾の誘導セクション（花装飾つき）
   ============================================================ */
.program-cta-section {
	position: relative;
	padding: 140px 24px;
	background: linear-gradient(135deg, var(--c-bg-soft) 0%, var(--c-rose) 50%, var(--c-bg-soft) 100%);
	overflow: hidden;
	text-align: center;
}

/* 左右の花装飾（円形・部分的に画面外でレイヤード） */
.program-cta-decor {
	position: absolute;
	background-size: cover;
	background-position: center;
	border-radius: 50%;
	z-index: 1;
	box-shadow: 0 12px 48px rgba(44, 37, 33, .1);
	border: 1px solid rgba(184, 146, 78, .2);
}
.program-cta-decor::after {
	content: ""; position: absolute;
	inset: 8px;
	border-radius: 50%;
	border: 1px solid rgba(184, 146, 78, .35);
	pointer-events: none;
}
.program-cta-decor--left {
	top: 60px; left: -110px;
	width: 320px; height: 320px;
	transform: rotate(-6deg);
}
.program-cta-decor--right {
	bottom: 50px; right: -130px;
	width: 380px; height: 380px;
	transform: rotate(7deg);
}

/* 中央のテキストカード */
.program-cta-card {
	position: relative;
	z-index: 2;
	max-width: 720px;
	margin: 0 auto;
	background: var(--c-bg-soft);
	padding: 80px 64px;
	box-shadow: 0 20px 60px rgba(44, 37, 33, .08);
	border-top: 2px solid var(--c-gold);
}
.program-cta-card::before {
	content: ""; position: absolute;
	inset: 14px;
	border: 1px solid rgba(184, 146, 78, .2);
	pointer-events: none;
}

.program-cta-card .eyebrow {
	justify-content: center;
}

.program-cta-card .section-title em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}

.program-cta-lead {
	font-family: var(--font-serif);
	font-size: clamp(15px, 1.7vw, 17px);
	line-height: 2.15;
	letter-spacing: .12em;
	color: var(--c-ink-soft);
	margin: 2rem 0 2.5rem;
}

.program-cta-actions {
	display: flex;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
}
@media (max-width: 600px) {
	.program-cta-actions {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
	}
	.program-cta-actions .btn {
		justify-content: center;
	}
}

@media (max-width: 960px) {
	.program-cta-section { padding: 100px 16px; }
	.program-cta-decor--left {
		width: 200px; height: 200px;
		left: -80px; top: 40px;
	}
	.program-cta-decor--right {
		width: 240px; height: 240px;
		right: -90px; bottom: 30px;
	}
	.program-cta-card { padding: 56px 32px; }
}

@media (max-width: 600px) {
	.program-cta-decor--left {
		width: 140px; height: 140px;
		left: -60px; top: 20px;
	}
	.program-cta-decor--right {
		width: 170px; height: 170px;
		right: -70px; bottom: 20px;
	}
	.program-cta-card { padding: 48px 24px; }
}


/* ============================================================
   ミニ3章ナビ（/program/ のYOUR CHAPTERセクション用）
   ============================================================ */
.chapter-mini-nav {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	margin-top: 4rem;
}
.chapter-mini-card {
	text-align: center;
	padding: 24px 16px;
	border: 1px solid var(--c-line);
	background: var(--c-paper);
	position: relative;
}
.chapter-mini-card--inactive { opacity: .55; }
.chapter-mini-card--current {
	border: 2px solid var(--c-gold);
	background: var(--c-bg-soft);
	padding: 28px 16px 24px;
}
.chapter-mini-now {
	position: absolute;
	top: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--c-gold);
	color: var(--c-bg-soft);
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 10px;
	letter-spacing: .3em;
	padding: 4px 14px;
	white-space: nowrap;
}
.chapter-mini-num {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 22px;
	color: var(--c-gold-deep);
	margin: 0 0 8px;
}
.chapter-mini-num--lg { font-size: 28px; }
.chapter-mini-en {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 10px;
	letter-spacing: .35em;
	color: var(--c-gold-deep);
	margin: 0;
}
.chapter-mini-jp {
	font-size: 14px;
	margin: 12px 0 0;
}
.chapter-mini-jp--bold { font-weight: 500; }

/* スマホでは縦積み */
@media (max-width: 768px) {
	.chapter-mini-nav {
		grid-template-columns: 1fr;
		gap: 14px;
		margin-top: 3.5rem;
	}
}


/* ============================================================
   FORMAT TABLE — プログラム形式テーブル（白カード）
   ============================================================ */
.format-card {
	margin-top: 4rem;
	background: var(--c-surface);
	padding: 24px 56px;
	box-shadow: 0 16px 48px rgba(44, 37, 33, .08);
	border-top: 2px solid var(--c-gold);
	position: relative;
}
.format-card::before {
	content: ""; position: absolute;
	inset: 12px;
	border: 1px solid rgba(184, 146, 78, .15);
	pointer-events: none;
}
.format-list {
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 1;
}
.format-row {
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 24px;
	padding: 24px 0;
	border-bottom: 1px solid var(--c-line);
}
.format-row:last-child {
	border-bottom: none;
}
.format-label {
	font-family: var(--font-serif);
	font-size: 14px;
	letter-spacing: .15em;
	color: var(--c-gold-deep);
	margin: 0;
	align-self: start;
}
.format-value {
	margin: 0;
	font-size: 15px;
	line-height: 1.95;
	color: var(--c-ink);
}

@media (max-width: 768px) {
	.format-card {
		padding: 18px 28px;
		margin-top: 3rem;
	}
	.format-card::before { inset: 8px; }
	.format-row {
		grid-template-columns: 1fr;
		gap: 6px;
		padding: 20px 0;
	}
	.format-label {
		font-size: 12.5px;
		letter-spacing: .2em;
	}
}


/* ============================================================
   HEART OF LIFE — 大切なものに、もう一度出会う
   ============================================================ */
.heart-of-life {
	background: linear-gradient(180deg, var(--c-rose) 0%, var(--c-bg-soft) 60%, var(--c-surface) 100%);
	position: relative;
	overflow: hidden;
}
.heart-of-life::before {
	content: "";
	position: absolute;
	top: -8%; left: -4%;
	width: 320px; height: 320px;
	background: radial-gradient(circle, rgba(184, 146, 78, .08) 0%, transparent 70%);
	pointer-events: none;
}
.heart-of-life::after {
	content: "";
	position: absolute;
	bottom: -10%; right: -6%;
	width: 380px; height: 380px;
	background: radial-gradient(circle, rgba(184, 146, 78, .06) 0%, transparent 70%);
	pointer-events: none;
}
.story-passage {
	margin: 5rem auto 0;
	max-width: 680px;
	position: relative;
	z-index: 1;
}
.story-passage > p {
	font-family: var(--font-serif);
	font-size: 16px;
	line-height: 2.3;
	color: var(--c-ink);
	margin: 0 0 2.2rem;
	letter-spacing: .04em;
}
.story-passage em {
	font-style: normal;
	color: var(--c-gold-deep);
	font-weight: 400;
}
.story-quote {
	margin-top: 4rem;
	padding: 48px 36px;
	background: rgba(255, 252, 246, .55);
	border-top: 1px solid rgba(184, 146, 78, .25);
	border-bottom: 1px solid rgba(184, 146, 78, .25);
	text-align: center;
}
.story-quote p {
	font-family: var(--font-serif);
	font-size: 16px;
	line-height: 2.1;
	color: var(--c-ink-soft);
	margin: 0 0 1.5rem;
	letter-spacing: .06em;
}
.story-quote .story-quote-strong {
	font-size: 22px;
	line-height: 2;
	color: var(--c-ink);
	margin: 0;
	letter-spacing: .08em;
	font-weight: 400;
}

/* ============================================================
   THREE FLOWERS — 仕事 / 家族 / 使命
   ============================================================ */
.three-flowers-section {
	background: var(--c-surface);
}
.three-flowers-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	margin-top: 5rem;
}
.flower-card {
	background: var(--c-bg-soft);
	padding: 0 0 48px;
	text-align: center;
	border-top: 2px solid var(--c-gold);
	position: relative;
	overflow: hidden;
	transition: transform .4s ease, box-shadow .4s ease;
	box-shadow: 0 4px 16px rgba(44, 37, 33, .04);
}
.flower-card-image {
	width: 100%;
	height: 200px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	margin-bottom: 32px;
	position: relative;
}
.flower-card-image::after {
	content: ""; position: absolute;
	left: 0; right: 0; bottom: 0;
	height: 40%;
	background: linear-gradient(to bottom, transparent, var(--c-bg-soft));
	pointer-events: none;
}
.flower-card .flower-no,
.flower-card .flower-tag,
.flower-card h3,
.flower-card .flower-desc {
	padding-left: 32px;
	padding-right: 32px;
}
.flower-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(44, 37, 33, .07);
}
.flower-card .flower-no {
	display: block;
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 44px;
	color: var(--c-gold-deep);
	line-height: 1;
	margin-bottom: 12px;
}
.flower-card .flower-tag {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 10.5px;
	letter-spacing: .35em;
	color: var(--c-gold);
	margin: 0 0 18px;
}
.flower-card h3 {
	font-size: 26px;
	font-weight: 400;
	letter-spacing: .14em;
	color: var(--c-ink);
	margin: 0 0 22px;
}
.flower-card .flower-desc {
	font-family: var(--font-serif);
	font-size: 14.5px;
	line-height: 2.05;
	color: var(--c-ink-soft);
	margin: 0;
	letter-spacing: .04em;
}
.closing-whisper {
	font-family: var(--font-serif);
	font-size: 18px;
	line-height: 2.2;
	color: var(--c-gold-deep);
	letter-spacing: .08em;
	margin: 0;
}
.closing-whisper em {
	font-style: italic;
	font-size: 20px;
	color: var(--c-ink);
}

@media (max-width: 768px) {
	.heart-of-life::before,
	.heart-of-life::after { width: 200px; height: 200px; }
	.story-passage { margin-top: 3rem; padding: 0 4px; }
	.story-passage > p { font-size: 15px; line-height: 2.15; margin-bottom: 1.8rem; }
	.story-quote { padding: 32px 20px; margin-top: 3rem; }
	.story-quote p { font-size: 14.5px; }
	.story-quote .story-quote-strong { font-size: 18px; line-height: 1.95; }
	.three-flowers-grid {
		grid-template-columns: 1fr;
		gap: 20px;
		margin-top: 3rem;
	}
	.flower-card { padding: 0 0 36px; }
	.flower-card-image { height: 160px; margin-bottom: 24px; }
	.flower-card .flower-no,
	.flower-card .flower-tag,
	.flower-card h3,
	.flower-card .flower-desc { padding-left: 24px; padding-right: 24px; }
	.flower-card h3 { font-size: 22px; }
	.flower-card .flower-no { font-size: 38px; }
	.closing-whisper { font-size: 16px; line-height: 2.05; }
	.closing-whisper em { font-size: 17px; }
}


/* ============================================================
   PRIVACY POLICY — 柔らかい語り口のプライバシーポリシー
   ============================================================ */
.privacy-intro {
	text-align: center;
	padding: 2rem 0 4rem;
}
.privacy-intro p {
	font-family: var(--font-serif);
	font-size: 16px;
	line-height: 2.4;
	color: var(--c-ink-soft);
	margin: 0 0 2.2rem;
	letter-spacing: .06em;
}
.privacy-intro p:last-child { margin-bottom: 0; }

.privacy-content {
	background: var(--c-surface);
}
.privacy-section {
	padding: 56px 0;
	border-bottom: 1px solid var(--c-line);
}
.privacy-section:last-child { border-bottom: none; padding-bottom: 1rem; }
.privacy-section:first-child { padding-top: 1rem; }

.privacy-section .privacy-no {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 32px;
	color: var(--c-gold-deep);
	line-height: 1;
	margin: 0 0 18px;
	letter-spacing: .04em;
}
.privacy-section h2 {
	font-size: 22px;
	font-weight: 400;
	letter-spacing: .12em;
	color: var(--c-ink);
	margin: 0 0 24px;
	padding-bottom: 16px;
	border-bottom: 1px solid rgba(184, 146, 78, .25);
	display: inline-block;
	min-width: 60%;
}
.privacy-section p {
	font-family: var(--font-serif);
	font-size: 15px;
	line-height: 2.2;
	color: var(--c-ink-soft);
	letter-spacing: .04em;
	margin: 0 0 20px;
}
.privacy-section p:last-child { margin-bottom: 0; }

.privacy-list {
	list-style: none;
	padding: 0;
	margin: 8px 0 0;
}
.privacy-list li {
	position: relative;
	padding: 8px 0 8px 24px;
	font-family: var(--font-serif);
	font-size: 15px;
	line-height: 2.1;
	color: var(--c-ink-soft);
	letter-spacing: .04em;
}
.privacy-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 22px;
	width: 12px;
	height: 1px;
	background: var(--c-gold);
}

.privacy-date {
	margin-top: 4rem;
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 13px;
	letter-spacing: .2em;
	color: var(--c-ink-soft);
}

@media (max-width: 768px) {
	.privacy-intro { padding: 1rem 0 2rem; }
	.privacy-intro p { font-size: 14.5px; line-height: 2.15; }
	.privacy-section { padding: 40px 0; }
	.privacy-section .privacy-no { font-size: 26px; }
	.privacy-section h2 { font-size: 19px; min-width: 80%; }
	.privacy-section p,
	.privacy-list li { font-size: 14.5px; line-height: 2.05; }
	.privacy-date { font-size: 12px; }
}


/* ============================================================
   PROGRAM v3.2 — 人生から生まれた / 開催日程 / 受講料
   ============================================================ */

/* --- 理論ではなく、人生から生まれた --- */
.born-from-life {
	background: linear-gradient(180deg, var(--c-bg-soft) 0%, var(--c-rose) 100%);
}
.born-passage {
	max-width: 680px;
	margin: 4.5rem auto 0;
	text-align: center;
}
.born-passage > p {
	font-family: var(--font-serif);
	font-size: 16px;
	line-height: 2.35;
	color: var(--c-ink);
	margin: 0 0 2rem;
	letter-spacing: .04em;
}
.born-passage strong {
	font-weight: 400;
	color: var(--c-gold-deep);
}
.born-quote {
	margin-top: 3.5rem;
	padding: 44px 32px;
	background: rgba(255, 252, 246, .6);
	border-top: 1px solid rgba(184, 146, 78, .3);
	border-bottom: 1px solid rgba(184, 146, 78, .3);
}
.born-quote p {
	font-family: var(--font-serif);
	font-size: 18px;
	line-height: 2.1;
	color: var(--c-ink);
	margin: 0;
	letter-spacing: .06em;
}
.born-quote strong {
	font-weight: 400;
	color: var(--c-gold-deep);
	font-size: 19px;
}

/* --- 開催日程 --- */
.schedule-list { margin: 0; padding: 0; }
.schedule-row {
	display: grid;
	grid-template-columns: 48px 90px 100px 1fr;
	align-items: center;
	gap: 16px;
	padding: 16px 0;
	border-bottom: 1px solid var(--c-line);
}
.schedule-row:last-child { border-bottom: none; }
.schedule-no {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 18px;
	color: var(--c-gold-deep);
}
.schedule-date {
	font-family: var(--font-serif);
	font-size: 17px;
	color: var(--c-ink);
	letter-spacing: .04em;
}
.schedule-place {
	font-size: 12px;
	letter-spacing: .12em;
	text-align: center;
	padding: 5px 0;
	border-radius: 2px;
}
.schedule-place--zoom {
	background: rgba(31, 71, 72, .08);
	color: #1f4748;
}
.schedule-place--real {
	background: var(--gold-foil);
	color: #fff;
	background-size: 200% 100%;
}
.schedule-time {
	font-family: var(--font-serif);
	font-size: 14.5px;
	color: var(--c-ink-soft);
	letter-spacing: .04em;
}
.schedule-note {
	margin: 28px 0 0;
	font-family: var(--font-serif);
	font-size: 13px;
	color: var(--c-ink-soft);
	line-height: 1.9;
}

/* --- 受講料 --- */
.tuition-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 28px;
	margin-top: 4rem;
}
.tuition-card {
	background: var(--c-surface);
	padding: 48px 40px;
	text-align: center;
	position: relative;
	border-top: 2px solid var(--c-gold);
	box-shadow: 0 8px 28px rgba(44, 37, 33, .05);
}
.tuition-card--premium {
	background: linear-gradient(180deg, #fffdf8 0%, var(--c-bg-alt) 100%);
	border-top-color: var(--c-gold-deep);
}
.tuition-card--premium::before {
	content: "RECOMMENDED";
	position: absolute;
	top: 14px; right: 14px;
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 9px;
	letter-spacing: .25em;
	color: var(--c-gold-deep);
}
.tuition-rank {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 12px;
	letter-spacing: .35em;
	color: var(--c-gold-deep);
	margin: 0 0 12px;
}
.tuition-card h3 {
	font-size: 24px;
	font-weight: 400;
	letter-spacing: .1em;
	color: var(--c-ink);
	margin: 0 0 20px;
}
.tuition-price {
	font-family: var(--font-serif);
	font-size: 52px;
	font-weight: 300;
	color: var(--c-ink);
	line-height: 1;
	margin: 0 0 28px;
	letter-spacing: .02em;
}
.tuition-price span {
	font-size: 18px;
	margin-left: 4px;
	color: var(--c-ink-soft);
}
.tuition-features {
	list-style: none;
	padding: 24px 0 0;
	margin: 0;
	border-top: 1px solid var(--c-line);
	text-align: left;
}
.tuition-features li {
	position: relative;
	padding: 9px 0 9px 24px;
	font-family: var(--font-serif);
	font-size: 14.5px;
	line-height: 1.7;
	color: var(--c-ink-soft);
}
.tuition-features li::before {
	content: "";
	position: absolute;
	left: 0; top: 18px;
	width: 12px; height: 1px;
	background: var(--c-gold);
}
.tuition-features strong {
	font-weight: 400;
	color: var(--c-gold-deep);
}
.tuition-common {
	text-align: center;
	margin: 28px 0 0;
	font-family: var(--font-serif);
	font-size: 13.5px;
	color: var(--c-ink-soft);
	line-height: 1.9;
}
.tuition-option {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 28px;
	margin-top: 3rem;
	padding: 32px 40px;
	background: var(--c-bg-soft);
	border: 1px solid var(--c-gold-soft);
}
.tuition-option-label {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 13px;
	letter-spacing: .25em;
	color: var(--c-gold-deep);
	margin: 0;
	white-space: nowrap;
}
.tuition-option-body h4 {
	font-size: 18px;
	font-weight: 400;
	letter-spacing: .08em;
	color: var(--c-ink);
	margin: 0 0 8px;
}
.tuition-option-body p {
	font-family: var(--font-serif);
	font-size: 14px;
	line-height: 1.9;
	color: var(--c-ink-soft);
	margin: 0;
}
.tuition-option-note { font-size: 12.5px !important; margin-top: 4px !important; }
.tuition-option-price {
	font-family: var(--font-serif);
	font-size: 34px;
	font-weight: 300;
	color: var(--c-ink);
	margin: 0;
	white-space: nowrap;
}
.tuition-option-price span { font-size: 15px; margin-left: 3px; color: var(--c-ink-soft); }

@media (max-width: 768px) {
	.born-passage { margin-top: 3rem; padding: 0 4px; }
	.born-passage > p { font-size: 15px; line-height: 2.15; }
	.born-quote { padding: 32px 20px; }
	.born-quote p { font-size: 16px; }
	.born-quote strong { font-size: 16.5px; }

	.schedule-row {
		grid-template-columns: 36px 70px 1fr;
		grid-template-areas: "no date place" "no date time";
		gap: 4px 12px;
		padding: 14px 0;
	}
	.schedule-no { grid-area: no; font-size: 16px; }
	.schedule-date { grid-area: date; font-size: 15px; }
	.schedule-place { grid-area: place; font-size: 11px; justify-self: start; padding: 4px 10px; }
	.schedule-time { grid-area: time; font-size: 13px; }

	.tuition-grid { grid-template-columns: 1fr; gap: 20px; margin-top: 3rem; }
	.tuition-card { padding: 36px 28px; }
	.tuition-price { font-size: 44px; }
	.tuition-option {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 28px 24px;
		text-align: center;
	}
	.tuition-option-price { font-size: 30px; }
}


/* --- ATELIER 活動内容（PLAN C ミニマル） --- */
.activities-minimal {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 4.5rem;
	background: var(--c-surface);
	border: 1px solid var(--c-gold-soft);
	box-shadow: 0 12px 40px rgba(44, 37, 33, .05);
}
.activity-col {
	text-align: center;
	padding: 52px 30px 48px;
	border-right: 1px solid rgba(184, 146, 78, .18);
	display: flex;
	flex-direction: column;
	align-items: center;
}
.activity-col:last-child { border-right: none; }
.activity-col-icon {
	color: var(--c-gold);
	display: block;
}
.activity-col-icon svg { width: 40px; height: 40px; }
.activity-col-num {
	font-family: var(--font-serif);
	font-size: 30px;
	font-weight: 400;
	color: var(--c-gold-deep);
	letter-spacing: .05em;
	margin: 20px 0 0;
	line-height: 1.4;
}
.activity-col-num--sm { font-size: 23px; }
.activity-col-line {
	display: block;
	width: 34px; height: 1px;
	background: var(--c-gold);
	margin: 18px 0;
}
.activity-col h3 {
	font-size: 16.5px;
	font-weight: 400;
	letter-spacing: .08em;
	color: var(--c-ink);
	margin: 0 0 16px;
	line-height: 1.75;
	min-height: 2.6em;
	display: flex;
	align-items: center;
}
.activity-col-meta {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 12px;
	letter-spacing: .2em;
	color: var(--c-gold-deep);
	margin: 0;
}

@media (max-width: 768px) {
	.activities-minimal {
		grid-template-columns: 1fr;
		margin-top: 3rem;
	}
	.activity-col {
		border-right: none;
		border-bottom: 1px solid rgba(184, 146, 78, .18);
		padding: 40px 30px;
	}
	.activity-col:last-child { border-bottom: none; }
	.activity-col h3 { min-height: 0; }
}


/* ============================================================
   PROGRAM v3.3 — 画像入り華やかデザイン
   ============================================================ */

/* --- born-from-life 2カラム --- */
.born-layout {
	display: grid;
	grid-template-columns: 0.85fr 1fr;
	gap: 56px;
	align-items: center;
	margin-top: 4.5rem;
}
.born-image {
	background-size: cover;
	background-position: center;
	aspect-ratio: 4/5;
	position: relative;
	box-shadow: 0 18px 50px rgba(44, 37, 33, .12);
}
.born-image::after {
	content: "";
	position: absolute;
	inset: 16px;
	border: 1px solid var(--c-gold);
	pointer-events: none;
}
/* 2カラム時は born-passage の上マージンを消す（layout側で制御） */
.born-layout .born-passage {
	margin-top: 0;
	max-width: 100%;
	text-align: left;
}
.born-layout .born-passage > p { text-align: left; }
.born-layout .born-quote { text-align: center; }

/* --- 6 STEPS 縦型エディトリアル（堅牢版・aspect-ratioで高さ保証） --- */
.steps-flow {
	margin: 5rem auto 0;
	display: flex;
	flex-direction: column;
	gap: 36px;
	max-width: 960px;
}
.step-row {
	display: grid;
	grid-template-columns: 320px 1fr;
	background: var(--c-surface);
	box-shadow: 0 14px 44px rgba(44, 37, 33, .08);
	overflow: hidden;
	position: relative;
	transition: transform .5s var(--easing-out), box-shadow .5s var(--easing-out);
}
.step-row:hover {
	transform: translateY(-5px);
	box-shadow: 0 26px 60px rgba(44, 37, 33, .14);
}
.step-row:nth-child(even) { grid-template-columns: 1fr 320px; }
.step-row:nth-child(even) .step-row-img { grid-column: 2; grid-row: 1; }
.step-row:nth-child(even) .step-row-body { grid-column: 1; grid-row: 1; text-align: right; }

.step-row-img {
	position: relative;
	aspect-ratio: 4/5;
	min-height: 100%;
	background-size: cover;
	background-position: center;
}
.step-row-img::after {
	content: "";
	position: absolute; inset: 0;
	background: linear-gradient(160deg, rgba(184, 146, 78, .08) 0%, rgba(44, 37, 33, .45) 100%);
}
.step-row-no {
	position: absolute;
	left: 28px; bottom: 18px;
	z-index: 1;
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 84px;
	line-height: 1;
	color: #fff;
	text-shadow: 0 3px 18px rgba(44, 37, 33, .5);
}
.step-row:nth-child(even) .step-row-no { left: 28px; right: auto; }

.step-row-body {
	padding: 48px 52px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: relative;
}
.step-row-body::before {
	content: "";
	position: absolute;
	top: 48px; left: 52px;
	width: 44px; height: 2px;
	background: var(--gold-foil);
	background-size: 200% 100%;
}
.step-row:nth-child(even) .step-row-body::before { left: auto; right: 52px; }

.step-row-step {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 12px;
	letter-spacing: .35em;
	color: var(--c-gold-deep);
	margin: 26px 0 14px;
}
.step-row-title {
	font-size: 29px;
	font-weight: 400;
	letter-spacing: .1em;
	color: var(--c-ink);
	margin: 0 0 12px;
	line-height: 1.4;
}
.step-row-sub {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 16px;
	color: var(--c-gold-deep);
	margin: 0 0 22px;
	letter-spacing: .06em;
}
.step-row-desc {
	font-size: 14.5px;
	line-height: 2.1;
	color: var(--c-ink-soft);
	margin: 0;
}

/* --- NEXT CHAPTER ダークティール --- */
.next-chapter { position: relative; }
.eyebrow--light { color: var(--c-gold-light) !important; }
.eyebrow--light::before { background: linear-gradient(90deg, var(--c-gold-light), transparent) !important; }
.next-chapter-inner {
	text-align: center;
	max-width: 640px;
	margin: 0 auto;
	padding: 56px 40px;
	position: relative;
}
.next-chapter-inner::before {
	content: "";
	position: absolute; inset: 0;
	border: 1px solid rgba(212, 184, 124, .4);
	pointer-events: none;
}
.next-chapter-inner::after {
	content: "";
	position: absolute;
	inset: 10px;
	border: 1px solid rgba(212, 184, 124, .18);
	pointer-events: none;
}
.next-chapter-title {
	font-family: var(--font-serif);
	font-size: clamp(32px, 4.5vw, 48px);
	font-weight: 300;
	letter-spacing: .12em;
	color: #fff;
	margin: 0 0 28px;
	line-height: 1.4;
}
.next-chapter-title em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}
.next-chapter-lead {
	font-family: var(--font-serif);
	font-size: 16px;
	line-height: 2.2;
	color: rgba(255, 252, 246, .9);
	margin: 0 0 2.5rem;
	letter-spacing: .06em;
}
.next-chapter-lead strong { font-weight: 400; color: var(--c-gold-light); }
.next-chapter-cta { margin-top: .5rem; }

@media (max-width: 960px) {
	.born-layout {
		grid-template-columns: 1fr;
		gap: 36px;
		margin-top: 3rem;
	}
	.born-image { aspect-ratio: 16/11; max-width: 480px; margin: 0 auto; width: 100%; }
	.born-layout .born-passage > p { text-align: center; }
}
@media (max-width: 860px) {
	.step-row,
	.step-row:nth-child(even) { grid-template-columns: 1fr; }
	.step-row-img,
	.step-row:nth-child(even) .step-row-img {
		grid-column: 1; grid-row: 1;
		aspect-ratio: 16/9;
		min-height: 200px;
	}
	.step-row-no,
	.step-row:nth-child(even) .step-row-no { left: 24px; right: auto; font-size: 66px; bottom: 14px; }
	.step-row-body,
	.step-row:nth-child(even) .step-row-body { grid-column: 1; grid-row: 2; text-align: left; padding: 36px 30px 40px; }
	.step-row-body::before,
	.step-row:nth-child(even) .step-row-body::before { left: 30px; right: auto; top: 36px; }
	.step-row-step { margin-top: 22px; }
	.step-row-title { font-size: 25px; }
}
@media (max-width: 768px) {
	.steps-flow { margin-top: 3rem; gap: 32px; }
	.next-chapter-inner { padding: 44px 24px; }
}


/* ============================================================
   CONTACT FORM 7 — エレガントなフォームスタイル
   ============================================================ */
.contact-form-section { background: var(--c-bg-soft); }
.contact-form-wrap {
	max-width: 640px;
	margin: 0 auto;
	background: var(--c-surface);
	padding: 56px 56px 48px;
	border-top: 2px solid var(--c-gold);
	box-shadow: 0 16px 48px rgba(44, 37, 33, .07);
	position: relative;
}
.contact-form-wrap::before {
	content: ""; position: absolute;
	inset: 12px;
	border: 1px solid rgba(184, 146, 78, .12);
	pointer-events: none;
}

/* フォーム要素 */
.wpcf7-form {
	position: relative;
	z-index: 1;
}
.wpcf7-form p {
	margin: 0 0 24px;
	font-family: var(--font-serif);
}
.contact-form-wrap label {
	display: block;
	font-family: var(--font-serif);
	font-size: 14px;
	letter-spacing: .1em;
	color: var(--c-ink);
	margin-bottom: 8px;
	line-height: 1.8;
}
.contact-form-wrap .req {
	font-size: 11px;
	color: var(--c-gold-deep);
	font-family: var(--font-en-serif);
	font-style: italic;
	letter-spacing: .15em;
	margin-left: 8px;
}

/* 入力欄 */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea {
	width: 100%;
	box-sizing: border-box;
	font-family: var(--font-serif);
	font-size: 15px;
	color: var(--c-ink);
	background: var(--c-bg-soft);
	border: 1px solid var(--c-line);
	border-radius: 0;
	padding: 13px 16px;
	transition: border-color .3s ease, background .3s ease, box-shadow .3s ease;
	-webkit-appearance: none;
	appearance: none;
}
.wpcf7-form textarea { min-height: 150px; line-height: 1.9; resize: vertical; }
.wpcf7-form select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23b8924e' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	padding-right: 40px;
	cursor: pointer;
}
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus {
	outline: none;
	border-color: var(--c-gold);
	background: #fff;
	box-shadow: 0 0 0 3px rgba(184, 146, 78, .1);
}
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder { color: var(--c-ink-faint); }

/* 送信ボタン */
.wpcf7-form .wpcf7-submit {
	display: inline-block;
	width: auto;
	min-width: 240px;
	font-family: var(--font-serif);
	font-size: 15px;
	letter-spacing: .18em;
	color: #fff;
	background: var(--gold-foil);
	background-size: 200% 100%;
	border: none;
	border-radius: 0;
	padding: 16px 48px;
	margin-top: 8px;
	cursor: pointer;
	transition: opacity .3s ease, transform .3s ease, background-position .6s ease;
}
.wpcf7-form .wpcf7-submit:hover { background-position: 100% 0; transform: translateY(-2px); }
.contact-form-submit-wrap { text-align: center; margin-top: 12px; }

/* スピナー */
.wpcf7-spinner { margin: 0 0 0 12px; }

/* バリデーション・応答メッセージ */
.wpcf7-not-valid-tip {
	font-family: var(--font-serif);
	font-size: 12.5px;
	color: #a8453a;
	margin-top: 6px;
	letter-spacing: .04em;
}
.wpcf7-form input.wpcf7-not-valid,
.wpcf7-form select.wpcf7-not-valid,
.wpcf7-form textarea.wpcf7-not-valid {
	border-color: #c97b72;
	background: #fcf4f2;
}
.wpcf7-response-output {
	font-family: var(--font-serif) !important;
	font-size: 14px !important;
	line-height: 1.9 !important;
	letter-spacing: .04em;
	border-radius: 0 !important;
	margin: 28px 0 0 !important;
	padding: 16px 20px !important;
}
.wpcf7 form.sent .wpcf7-response-output {
	border: 1px solid var(--c-gold) !important;
	background: var(--c-bg-alt);
	color: var(--c-ink) !important;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output {
	border: 1px solid #c97b72 !important;
	background: #fcf4f2;
	color: #a8453a !important;
}

@media (max-width: 768px) {
	.contact-form-wrap { padding: 36px 24px 32px; }
	.contact-form-wrap::before { inset: 8px; }
	.wpcf7-form .wpcf7-submit { width: 100%; min-width: 0; }
}


/* ============================================================
   PERSONAL MENTORING — エディトリアル・マガジン構成
   ============================================================ */
:root { --font-script: 'Parisienne', cursive; }

/* 共通：スクリプト装飾 */
.mt-script {
	font-family: var(--font-script);
	color: var(--c-gold);
	line-height: 1;
	pointer-events: none;
	-webkit-user-select: none;
	user-select: none;
}
/* 共通：エディトリアル・ラベル */
.mt-eyebrow {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 12px;
	letter-spacing: .35em;
	color: var(--c-gold-deep);
	text-transform: uppercase;
	display: flex;
	align-items: center;
	gap: 14px;
	margin: 0 0 18px;
}
.mt-eyebrow--center { justify-content: center; }
.mt-eyebrow-line { width: 42px; height: 1px; background: linear-gradient(90deg, var(--c-gold), transparent); display: inline-block; }
.mt-eyebrow--center .mt-eyebrow-line:last-child { background: linear-gradient(90deg, transparent, var(--c-gold)); }
.mt-eyebrow--light { color: var(--c-gold-light); }
.mt-eyebrow-line--light { background: linear-gradient(90deg, var(--c-gold-light), transparent) !important; }
.mt-eyebrow--center .mt-eyebrow-line--light:last-child { background: linear-gradient(90deg, transparent, var(--c-gold-light)) !important; }

.mt-h2 {
	font-family: var(--font-serif);
	font-size: clamp(26px, 3.4vw, 40px);
	font-weight: 300;
	letter-spacing: .1em;
	line-height: 1.5;
	color: var(--c-ink);
	margin: 0;
}
.mt-h2--center { text-align: center; }
.mt-h2 em {
	font-style: normal;
	background: var(--gold-foil);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
	background-size: 200% 100%;
}
.mt-head { position: relative; margin-bottom: 1rem; }
.mt-script--head {
	display: block;
	text-align: center;
	font-size: 52px;
	margin-bottom: -18px;
	opacity: .55;
}

/* ---- OPENING ---- */
.mt-opening { background: linear-gradient(180deg, var(--c-bg-soft) 0%, var(--c-rose) 100%); overflow: hidden; }
.mt-opening-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 72px;
	align-items: center;
}
.mt-opening-visual { position: relative; min-height: 520px; }
.mt-opening-img {
	position: absolute;
	background-size: cover;
	background-position: center;
	box-shadow: 0 20px 50px rgba(44, 37, 33, .14);
}
.mt-opening-img--main {
	width: 72%; aspect-ratio: 3/4;
	top: 0; left: 0;
	z-index: 1;
}
.mt-opening-img--main::after {
	content: ""; position: absolute; inset: 14px;
	border: 1px solid var(--c-gold); pointer-events: none;
}
.mt-opening-img--sub {
	width: 48%; aspect-ratio: 1/1;
	right: 0; bottom: 0;
	z-index: 2;
	border: 6px solid var(--c-bg-soft);
}
.mt-script--open {
	position: absolute;
	top: -6px; right: -4px;
	font-size: 64px;
	z-index: 3;
	transform: rotate(-6deg);
}
.mt-vertical {
	position: absolute;
	left: -34px; top: 30%;
	writing-mode: vertical-rl;
	font-family: var(--font-serif);
	font-size: 13px;
	letter-spacing: .5em;
	color: var(--c-gold-deep);
	z-index: 3;
}
.mt-bignum {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 64px;
	line-height: 1;
	color: var(--c-gold);
	opacity: .5;
	margin: 0 0 12px;
}
.mt-body {
	font-family: var(--font-serif);
	font-size: 15.5px;
	line-height: 2.2;
	color: var(--c-ink-soft);
	margin: 24px 0 0;
	letter-spacing: .03em;
}
.mt-body strong { font-weight: 400; color: var(--c-gold-deep); }
.mt-pullquote {
	margin: 36px 0 0;
	padding: 24px 0 0;
	border-top: 1px solid rgba(184, 146, 78, .3);
	font-family: var(--font-serif);
	font-size: 15px;
	line-height: 2.1;
	color: var(--c-ink);
}
.mt-pullquote em { font-style: normal; color: var(--c-gold-deep); font-size: 17px; }

/* ---- FOR WHOM ---- */
.mt-list { list-style: none; padding: 0; margin: 3.5rem 0 0; counter-reset: none; }
.mt-list-item {
	display: grid;
	grid-template-columns: 80px 1fr;
	align-items: center;
	gap: 24px;
	padding: 26px 8px;
	border-bottom: 1px solid var(--c-line);
	transition: padding-left .4s var(--easing-out), background .4s var(--easing-out);
}
.mt-list-item:first-child { border-top: 1px solid var(--c-line); }
.mt-list-item:hover { padding-left: 24px; background: var(--c-bg-soft); }
.mt-list-no {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 38px;
	color: var(--c-gold);
	line-height: 1;
	text-align: center;
}
.mt-list-text {
	font-family: var(--font-serif);
	font-size: 16.5px;
	line-height: 1.9;
	color: var(--c-ink);
	letter-spacing: .04em;
}

/* ---- THE FLOW（写真バンド＋割り込みカード） ---- */
.mt-flow { padding-top: 0; }
.mt-flow-band {
	position: relative;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	margin-bottom: 5.5rem;
}
.mt-flow-photo {
	height: 500px;
	background-size: cover;
	background-position: center;
	position: relative;
}
.mt-flow-photo::after { content: ""; position: absolute; inset: 0; background: rgba(44, 37, 33, .12); }
.mt-flow-card {
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
	width: min(400px, 76%);
	background: var(--c-surface);
	padding: 40px 36px;
	text-align: center;
	box-shadow: 0 24px 60px rgba(44, 37, 33, .22);
	z-index: 2;
}
.mt-flow-card::before { content: ""; position: absolute; inset: 12px; border: 1px solid rgba(184, 146, 78, .3); pointer-events: none; }
.mt-script--card { display: block; font-size: 50px; line-height: .8; margin: 2px 0 8px; }

.mt-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.mt-step { text-align: center; position: relative; padding-top: 28px; }
.mt-step::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 1px; height: 16px; background: var(--c-gold);
}
.mt-step-no {
	font-family: var(--font-en-serif);
	font-style: italic;
	font-size: 30px;
	color: var(--c-gold-deep);
	display: block;
	margin-bottom: 6px;
}
.mt-step-en {
	font-family: var(--font-script);
	font-size: 26px;
	color: var(--c-gold);
	margin: 0 0 8px;
	line-height: 1;
}
.mt-step-body h3 {
	font-size: 19px; font-weight: 400; letter-spacing: .1em;
	color: var(--c-ink); margin: 0 0 14px;
}
.mt-step-body p {
	font-family: var(--font-serif); font-size: 14px; line-height: 2.05;
	color: var(--c-ink-soft); margin: 0; text-align: left;
}

/* ---- FORMAT head の script は共通 mt-script--head 利用 ---- */
.mt-format .format-card { margin-top: 2.5rem; }

/* ---- MESSAGE ---- */
.mt-message { position: relative; overflow: hidden; }
.mt-script--msg {
	position: absolute;
	top: 8%; left: 50%;
	transform: translateX(-50%);
	font-size: clamp(80px, 16vw, 200px);
	color: rgba(212, 184, 124, .14);
	z-index: 0;
	white-space: nowrap;
}
.mt-message-text {
	font-family: var(--font-serif);
	font-size: clamp(19px, 2.4vw, 26px);
	font-weight: 300;
	line-height: 2.1;
	color: #fff;
	letter-spacing: .08em;
	margin: 1.5rem 0 0;
}
.mt-message-text em { font-style: normal; background: var(--gold-foil); background-clip: text; -webkit-background-clip: text; color: transparent; background-size: 200% 100%; }
.mt-message-closing {
	font-family: var(--font-serif);
	font-size: 15px;
	line-height: 2.2;
	color: rgba(255, 252, 246, .85);
	margin: 2.5rem 0 0;
	letter-spacing: .06em;
}
.mt-message-closing strong { font-weight: 400; color: var(--c-gold-light); font-size: 18px; letter-spacing: .14em; }

/* ---- レスポンシブ ---- */
@media (max-width: 960px) {
	.mt-opening-grid { grid-template-columns: 1fr; gap: 60px; }
	.mt-opening-visual { min-height: 420px; max-width: 420px; margin: 0 auto; }
	.mt-vertical { left: -24px; }
}
@media (max-width: 768px) {
	.mt-opening-visual { min-height: 360px; }
	.mt-script--open { font-size: 48px; }
	.mt-bignum { font-size: 50px; }
	.mt-list-item { grid-template-columns: 56px 1fr; gap: 16px; padding: 22px 4px; }
	.mt-list-no { font-size: 30px; }
	.mt-list-text { font-size: 15px; }
	.mt-flow-band { grid-template-columns: 1fr; min-height: 0; }
	.mt-flow-photo { height: 200px; }
	.mt-flow-card { position: static; transform: none; width: auto; margin: -60px 20px 0; }
	.mt-steps { grid-template-columns: 1fr; gap: 28px; }
	.mt-step { padding-top: 24px; }
	.mt-step-body p { text-align: center; }
	.mt-script--head { font-size: 42px; }
}


/* ============================================================
   FRONT PAGE — エディトリアル筆記体アクセント
   ============================================================ */
/* ヒーローの大きな筆記体オーバーレイ */
.hero-script {
	position: absolute;
	top: 9%;
	right: 3%;
	font-family: var(--font-script);
	font-size: clamp(72px, 13vw, 196px);
	line-height: 1;
	color: var(--c-gold);
	opacity: .13;
	z-index: 0;
	pointer-events: none;
	transform: rotate(-4deg);
	white-space: nowrap;
}

/* セクション見出しの筆記体アクセント */
.fp-script {
	display: block;
	font-family: var(--font-script);
	font-size: 46px;
	line-height: 1;
	color: var(--c-gold);
	opacity: .65;
	margin-bottom: -6px;
}
.fp-script--center { text-align: center; }
.fp-script--light { color: var(--c-gold-light); opacity: .85; }

@media (max-width: 900px) {
	.hero-script { font-size: clamp(60px, 18vw, 120px); top: auto; bottom: 6%; right: 4%; opacity: .1; }
}
@media (max-width: 768px) {
	.fp-script { font-size: 38px; }
}
