/**
 * app.css — Figma「TOP採用版」忠実実装のフロントCSS
 */

@import url("tokens.css");
@import url("components.css");

/* ---- base ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
	scroll-behavior: smooth;
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: clip;
}
body {
	background: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-body-jp);
	font-size: var(--fs-body);
	line-height: 1.9;
	letter-spacing: var(--ls-tight);
	overflow-x: clip;
}
img, svg, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { border: none; background: none; cursor: pointer; font-family: inherit; color: inherit; }
ul, ol { list-style: none; }

/* ===================================================================== */
/* ---- site header (sticky + blur) ---- */
/* ===================================================================== */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: var(--z-header);
	transition: background var(--dur-mid) ease,
		box-shadow var(--dur-mid) ease,
		backdrop-filter var(--dur-mid) ease;
}
.site-header.is-scrolled {
	background: rgba(253, 251, 247, 0.92);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	box-shadow: 0 1px 0 var(--color-border);
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 80px;
	max-width: none;
	margin: 0 auto;
	padding: 0 clamp(20px, 4vw, 50px);
	gap: var(--gap-md);
}
.site-header__logo {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	color: var(--color-text);
}
.site-header__logo-mark {
	width: 42px;
	height: 42px;
	flex-shrink: 0;
	color: var(--color-logo);
}
.site-header__logo-text {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}
.site-header__logo-title {
	font-family: var(--font-serif-jp);
	font-weight: 500;
	font-size: clamp(14px, 1.4vw, 18px);
	letter-spacing: 0.15em;
	color: var(--color-text);
}
.site-header__logo-sub {
	font-family: var(--font-display);
	font-size: clamp(10px, 0.9vw, 13px);
	letter-spacing: 0.2em;
	color: var(--color-accent);
	text-transform: capitalize;
	margin-top: 2px;
}
.site-header__nav-desktop {
	display: flex;
	align-items: center;
	gap: clamp(20px, 3vw, 40px);
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-body);
	color: var(--color-secondary);
}
.site-header__nav-desktop a {
	position: relative;
	white-space: nowrap;
	transition: color var(--dur-fast) ease;
}
.site-header__nav-desktop a::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -6px;
	width: 0;
	height: 1px;
	background: var(--color-accent);
	transition: width var(--dur-mid) var(--ease-out-expo);
}
.site-header__nav-desktop a:hover::after { width: 100%; }
.site-header__actions {
	display: flex;
	align-items: center;
	gap: 16px;
}
/* 会員ナビ：デスクトップ ghost ボタン + モバイル アイコン */
/* .site-header__member は .btn の基本サイズ（予約CTAと同一）をそのまま使用 */
.site-header__member-svg {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
}
.site-header__member-icon {
	display: none;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	color: var(--color-secondary);
}
.site-header__member-icon .site-header__member-svg {
	width: 24px;
	height: 24px;
}
.lang-switch {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-display);
	font-size: 12px;
	letter-spacing: 0.12em;
	color: var(--color-text-muted);
}
.lang-switch a { padding: 0 4px; transition: color var(--dur-fast) ease; }
.lang-switch a:hover { color: var(--color-accent); }
.lang-switch .is-active { color: var(--color-text); }
.lang-switch__sep { color: var(--color-text-muted); }
.site-header__hamburger {
	display: none;
	flex-direction: column;
	gap: 6px;
	width: 28px;
	padding: 8px 0;
}
.site-header__hamburger span {
	height: 1px;
	background: var(--color-text);
	transition: transform var(--dur-mid) ease, opacity var(--dur-fast) ease;
	display: block;
}
.site-header__hamburger.is-open span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.site-header__hamburger.is-open span:nth-child(2) { opacity: 0; }
.site-header__hamburger.is-open span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ---- mobile menu ---- */
.mobile-menu {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100dvh;
	background: var(--color-bg);
	z-index: 99;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 32px;
	transform: translateX(100%);
	transition: transform var(--dur-slow) var(--ease-out-expo);
}
.mobile-menu.is-open { transform: translateX(0); }
.mobile-menu a {
	font-family: var(--font-serif-jp);
	font-size: 18px;
	letter-spacing: 0.15em;
	color: var(--color-text);
}
.mobile-menu .btn { margin-top: 20px; }

/* ---- mobile-menu 内 言語スイッチャー ---- */
.lang-switch--mobile {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-family: var(--font-display);
	font-size: 16px;
	letter-spacing: 0.18em;
	color: var(--color-text-muted);
}
.lang-switch--mobile a {
	padding: 8px 12px;
	transition: color var(--dur-fast) ease;
}
.lang-switch--mobile a:hover,
.lang-switch--mobile a:focus-visible { color: var(--color-accent); }
.lang-switch--mobile .is-active { color: var(--color-text); }
.lang-switch--mobile [aria-disabled="true"] {
	opacity: 0.4;
	pointer-events: none;
}

@media (max-width: 1024px) {
	.site-header__nav-desktop,
	.site-header__actions .btn,
	.site-header__actions .lang-switch { display: none; }
	.site-header__hamburger,
	.site-header__member-icon { display: flex; }
}

/* スマホ幅：ロゴ占有幅を圧縮しハンバーガーが右端からはみ出さないようにする */
@media (max-width: 600px) {
	.site-header__inner {
		padding: 0 16px;
		gap: 12px;
	}
	.site-header__logo {
		gap: 8px;
	}
	.site-header__logo-mark {
		width: 36px;
		height: 36px;
	}
	.site-header__logo-title {
		font-size: 12px;
		letter-spacing: 0.08em;
	}
	.site-header__logo-sub {
		font-size: 9px;
		letter-spacing: 0.12em;
	}
}

/* site-main に sticky header分のスペースを空ける */
.site-main { padding-top: 80px; }

/* ===================================================================== */
/* ---- Hero deco wrapper (hero + concept をまたぐ装飾レイヤー) ---- */
/* ===================================================================== */
.hero-deco {
	position: relative;
	overflow: hidden;
}
.hero-deco__bg-gradient {
	position: absolute;
	left: 0;
	top: clamp(160px, 14vw, 220px);
	width: 100%;
	aspect-ratio: 1440 / 1700;
	background: linear-gradient(180deg,
		rgba(239, 232, 217, 0) 0%,
		#EDE2CB 35%,
		#EDE2CB 65%,
		rgba(239, 232, 217, 0) 100%
	);
	pointer-events: none;
	z-index: 0;
}
.hero-deco__thread {
	position: absolute;
	left: clamp(-20px, -0.2vw, 0px);
	top: clamp(440px, 46.5vw, 670px);
	width: clamp(540px, 69.3vw, 998px);
	aspect-ratio: 998 / 1227;
	pointer-events: none;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hero-deco__thread img {
	width: 29.18%;
	height: 106.17%;
	transform: scaleY(-1) rotate(35.8deg);
	transform-origin: center;
}

/* ===================================================================== */
/* ---- Hero ---- */
/* ===================================================================== */
.hero {
	position: relative;
	display: grid;
	grid-template-columns: clamp(340px, 28vw, 420px) 1fr;
	align-items: stretch;
	gap: var(--gap-xl);
	padding: 0 0 0 clamp(20px, 5vw, 80px);
	background: var(--color-bg);
	z-index: 2;
}
.hero__deco-pill {
	--pill-w: clamp(280px, 34vw, 488px);
	--pill-h: calc(var(--pill-w) * 468 / 488);
	position: absolute;
	top: calc(var(--pill-h) / -3);
	left: clamp(160px, 22vw, 320px);
	width: var(--pill-w);
	height: var(--pill-h);
	border-radius: 100px;
	background: #F4EFE1;
	z-index: 0;
	pointer-events: none;
}
.hero__left {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: clamp(20px, 2.6vw, 40px);
	padding-block: 0;
	position: relative;
	z-index: 2;
}
.hero__brand {
	position: relative;
	padding: 0 20px;
	text-align: center;
}
.hero__brand-partnership {
	display: block;
	font-family: var(--font-display);
	font-size: var(--fs-hero-en-large);
	color: var(--color-bg-ivory);
	letter-spacing: var(--ls-hero-en);
	line-height: 1;
	text-transform: capitalize;
	margin-bottom: 6px;
}
.hero__brand-script {
	display: block;
	font-family: var(--font-script);
	font-size: var(--fs-hero-script);
	color: var(--color-accent);
	transform: rotate(-4.65deg);
	line-height: 1.2;
	margin-block: -10px;
	padding-left: 30px;
}
.hero__brand-divider {
	display: block;
	width: min(255px, 80%);
	height: 1px;
	background: var(--color-accent);
	opacity: 0.4;
	margin: 8px auto;
}
.hero__brand-concierge {
	display: block;
	font-family: var(--font-display);
	font-size: var(--fs-hero-en-small);
	color: var(--color-accent);
	letter-spacing: 0.3em;
	line-height: 1;
	text-transform: capitalize;
}
.hero__title {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-hero-main);
	color: var(--color-text);
	letter-spacing: var(--ls-title);
	line-height: 1.5;
	text-align: center;
}
.hero__title-accent { color: var(--color-accent); }
.hero__ctas {
	display: flex;
	flex-direction: column;
	gap: 18px;
	align-items: center;
}
.hero__ctas .btn { min-width: 254px; }
.cta__actions .btn { min-width: 254px; }
.hero__right {
	position: relative;
	width: 100%;
	max-width: none;
	aspect-ratio: 957 / 605;
	background: url('../images/fv.webp') #D9D9D9 50% / cover no-repeat;
	border-radius: 0 0 0 100px;
	z-index: 1;
}

@media (max-width: 1024px) {
	.hero {
		grid-template-columns: 1fr;
		text-align: center;
		padding: 0 0 80px;
	}
	.hero__left {
		padding-inline: var(--container-pad);
	}
	.hero__right {
		order: -1;
		width: 100%;
		max-width: none;
		margin: 0;
		border-radius: 0 0 24px 24px;
	}
	.hero__deco-pill,
	.hero-deco__bg-gradient,
	.hero-deco__thread {
		display: none;
	}
}

/* ===================================================================== */
/* ---- Concept ---- */
/* ===================================================================== */
.section--concept {
	padding-block: 0;
	position: relative;
	z-index: 2;
	background: transparent;
}
.section--concept .section__inner {
	max-width: 100%;
	width: 100%;
	padding-inline: 0;
	position: relative;
}
.concept__layout {
	position: relative;
	width: 100%;
	aspect-ratio: 1440 / 1377;
}

/* 背景の糸 SVG (concept-thread.svg, viewBox 767 x 1084) */
.concept__thread {
	position: absolute;
	left: 0;
	top: 0;
	width: 53.26%;   /* 767 / 1440 */
	aspect-ratio: 767 / 1084;
	z-index: 0;
	pointer-events: none;
	opacity: 0.85;
}

/* 縦のボーダー (1 x 78.5px, stroke #E2CEBD) */
.concept__rule {
	position: absolute;
	left: calc(12.15% + 0.5em); /* 縦組みConcept (.concept__vertical) の中心に揃える */
	top: 8.10%;      /* 縦組みConceptの上, 約 109 / 1377 */
	width: 1px;
	height: clamp(50px, 5.45vw, 78.5px);
	background: #E2CEBD;
	font-size: clamp(28px, 3.06vw, 44px); /* em 計算用 (vertical と同期) */
	transform: translateX(-50%);
	z-index: 1;
}

/* 縦組み Concept装飾文字 */
.section--concept .section-heading__vertical,
.concept__vertical {
	position: absolute;
	left: 12.15%;    /* heading-text 左端と一致（padding領域に重ねる） */
	top: 14.52%;     /* 200 / 1377 */
	font-family: var(--font-display);
	font-size: clamp(28px, 3.06vw, 44px);
	font-weight: 400;
	line-height: 1;
	color: #E2CEBD;
	letter-spacing: 0.02em;
	writing-mode: vertical-rl;
	text-transform: capitalize;
	z-index: 1;
}

/* 左ピル (薄ベージュ #F6F4EE, 452 x 433) */
.concept__pill-soft {
	position: absolute;
	left: -10%;      /* pricing と統一：左端を画面外にはみ出させ約 1/3 を隠す */
	top: -3%;        /* pricing と統一 */
	width: 31.39%;   /* 452 / 1440 */
	aspect-ratio: 452 / 433;
	border-radius: clamp(50px, 6.94vw, 100px);
	background: #F6F4EE;
	z-index: 0;
}

/* 左テキストブロック */
.concept__text {
	position: absolute;
	left: 12.15%;
	top: 9.44%;
	width: 31.39%;
	aspect-ratio: 452 / 433;
	padding: clamp(40px, 5.6vw, 80px) clamp(22px, 3vw, 44px) clamp(28px, 4vw, 56px) clamp(40px, 6vw, 90px);
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: clamp(12px, 1.4vw, 20px);
}
.concept__text .section-heading {
	margin-block-end: 0;
	gap: 4px;
}
.concept__text .section-heading::before {
	display: none;
}
.concept__text .section-heading__en {
	font-size: clamp(16px, 1.5vw, 22px);
}
.concept__text .section-heading__ja {
	font-size: clamp(18px, 1.7vw, 24px);
}
.concept__body {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: clamp(11px, 0.97vw, 14px);
	color: var(--color-text);
	line-height: 1.9;
}
.concept__body p + p { margin-top: 0.6em; }

/* 右下 濃ベージュピル (#EDDFC1, 488 x 468) */
.concept__pill-warm {
	position: absolute;
	right: 1.5%;     /* 約20px from right */
	top: 63.91%;     /* 880 / 1377 */
	width: 33.89%;   /* 488 / 1440 */
	aspect-ratio: 488 / 468;
	border-radius: clamp(50px, 6.94vw, 100px);
	background: #EDDFC1;
	z-index: 0;
}

/* 画像共通 */
.concept__photo {
	position: absolute;
	border-radius: clamp(50px, 6.94vw, 100px);
	overflow: hidden;
	background: #D9D9D9;
	margin: 0;
	z-index: 1;
}
.concept__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* 画像1: 右上 (496.437 x 328.173) */
.concept__photo--1 {
	right: 8.06%;    /* (1440 - 830 - 496) / 1440 = 114 / 1440 */
	top: 15.61%;     /* 215 / 1377 */
	width: 34.47%;   /* 496 / 1440 */
	aspect-ratio: 496 / 328;
}

/* 画像2: 真ん中左側 (511.616 x 380.404) */
.concept__photo--2 {
	left: 15.63%;    /* 225 / 1440 */
	top: 34.50%;     /* 475 / 1377 */
	width: 35.53%;   /* 511 / 1440 */
	aspect-ratio: 511 / 380;
}

/* 画像3: 下段右下 (455.336 x 301.003) */
.concept__photo--3 {
	right: 16.32%;   /* 235 / 1440 */
	top: 53.74%;     /* 740 / 1377 */
	width: 31.62%;   /* 455 / 1440 */
	aspect-ratio: 455 / 301;
	z-index: 2;
}

/* コピー */
.concept__copy {
	position: absolute;
	right: 24%;      /* 画像3の下、ピル左半分にかかる位置 */
	top: 85.69%;     /* 1180 / 1377 */
	font-family: var(--font-display);
	font-size: clamp(28px, 3.06vw, 44px);
	font-weight: 400;
	line-height: 1;
	color: #C5B9B9;
	text-transform: capitalize;
	text-align: center;
	z-index: 3;
	margin: 0;
}
.concept__copy span { display: block; }
.concept__copy span + span {
	margin-top: 0.5em;
	padding-left: 2em;
}

/* ----- レスポンシブ (1024px以下) ----- */
@media (max-width: 1024px) {
	.section--concept {
		padding-block: clamp(60px, 10vw, 100px);
	}
	.section--concept .section__inner {
		padding-inline: var(--container-pad);
	}
	.concept__layout {
		aspect-ratio: auto;
		display: flex;
		flex-direction: column;
		gap: var(--gap-xl);
		align-items: center;
	}
	.section--concept .section-heading__vertical,
	.concept__vertical,
	.concept__pill-warm,
	.concept__pill-soft,
	.concept__rule,
	.concept__thread {
		display: none;
	}
	.concept__text .section-heading::before {
		display: block;
		height: 36px;
	}
	.concept__text {
		position: relative;
		left: 0;
		top: 0;
		width: 100%;
		max-width: clamp(420px, 70vw, 600px);
		aspect-ratio: auto;
		padding: clamp(28px, 4.5vw, 48px) clamp(20px, 4vw, 36px);
		background: #F6F4EE;
		border-radius: clamp(40px, 6vw, 60px);
		display: flex;
		flex-direction: column;
		gap: clamp(14px, 1.6vw, 20px);
	}
	.concept__text .section-heading::before {
		height: 36px;
		margin-block-end: 8px;
	}
	.concept__text .section-heading__en {
		font-size: clamp(16px, 2vw, 22px);
	}
	.concept__text .section-heading__ja {
		font-size: clamp(18px, 2.4vw, 26px);
	}
	.concept__body {
		font-size: 14px;
	}
	.concept__photo {
		position: static;
		left: auto;
		right: auto;
		top: auto;
		width: 100%;
		max-width: 480px;
		aspect-ratio: 4 / 3;
		border-radius: 60px;
	}
	.concept__copy {
		position: static;
		left: auto;
		right: auto;
		top: auto;
		text-align: center;
		margin-top: var(--gap-lg);
	}
	.concept__copy span + span {
		padding-left: 0;
	}
}

/* ===================================================================== */
/* ---- Concerns ---- */
/* ===================================================================== */
.section--concerns {
	padding-block: var(--section-pad);
	position: relative;
}
.concerns__heading {
	text-align: center;
	margin-block-end: var(--gap-xl);
	position: relative;
	padding-block-start: 56px;
}
.concerns__en {
	font-family: var(--font-display);
	font-size: 76px;
	font-weight: 400;
	line-height: 100%;
	color: #EFE2D9;
	text-transform: capitalize;
	text-align: center;
	margin: 0;
	position: absolute;
	inset-inline: 0;
	top: -8px;
	z-index: 0;
	pointer-events: none;
	user-select: none;
}
.concerns__ja {
	position: relative;
	z-index: 1;
	font-family: var(--font-body-jp);
	font-weight: 700;
	font-size: 28px;
	line-height: 57.6px;
	letter-spacing: 3.6px;
	color: #412707;
	text-align: center;
	display: inline-block;
}
.concerns__row {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 4vw, 72px);
	margin-block-end: var(--gap-xl);
}
.concerns__row--two {
	grid-template-columns: repeat(2, 1fr);
	max-width: 800px;
	margin-inline: auto;
}
.concerns__row--two .concern-card {
	max-width: 340px;
	margin-inline: auto;
	width: 100%;
}
.concerns__row > .concern-card:nth-child(2) .concern-card__title {
	letter-spacing: 0;
}
.concern-card {
	display: flex;
	flex-direction: column;
	gap: 22px;
}
.concern-card__image {
	width: 100%;
	max-width: 340px;
	aspect-ratio: 340 / 235;
	border-radius: 74px 74px 0 0;
	background: #D9D9D9;
	position: relative;
	margin-inline: auto;
}
.concern-card__image > img:not(.concern-card__worries) {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 74px 74px 0 0;
}
.concern-card__worries {
	position: absolute;
	width: clamp(64px, 27%, 92.96px);
	height: auto;
	aspect-ratio: 92.96 / 97.117;
	right: clamp(-36px, -3.6vw, -20px);
	top: clamp(-36px, -3.6vw, -20px);
	pointer-events: none;
	z-index: 2;
}
.concern-card__head {
	display: flex;
	align-items: center;
	gap: 8px;
}
.concern-card__icon {
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	color: var(--color-accent);
}
.concern-card__icon img { width: 100%; height: 100%; }
.concern-card__title {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-h3-card);
	color: var(--color-text);
	letter-spacing: var(--ls-card);
	line-height: 1.5;
}
.concern-card__title em {
	font-style: normal;
	font-weight: 700;
	color: var(--color-accent-strong);
}
.concern-card__body {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-body);
	color: var(--color-text);
	line-height: 1.8;
	letter-spacing: 0.05em;
	text-align: justify;
}

.concerns__cta {
	margin-block-start: var(--gap-xl);
	text-align: center;
	font-family: var(--font-body-jp);
	font-size: 29px;
	font-weight: 500;
	line-height: 77.538px;
	letter-spacing: 4.846px;
	color: #412707;
}
.concerns__cta-mark {
	position: relative;
	color: #BC8A7F;
	display: inline-block;
}
.concerns__cta-mark::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 8px;
	height: 18.846px;
	background: #F4EFE1;
	z-index: -1;
}

@media (max-width: 1024px) {
	.concerns__row,
	.concerns__row--two {
		grid-template-columns: repeat(2, 1fr);
		max-width: 760px;
		margin-inline: auto;
	}
	.concerns__row > .concern-card:nth-child(3) {
		grid-column: 1 / -1;
		max-width: 360px;
		margin-inline: auto;
	}
	.concerns__cta {
		font-size: clamp(20px, 2.6vw, 26px);
		line-height: 1.6;
		letter-spacing: 0.18em;
	}
}

@media (max-width: 768px) {
	.concerns__row,
	.concerns__row--two {
		grid-template-columns: 1fr;
		max-width: 420px;
		margin-inline: auto;
	}
	.concerns__row > .concern-card:nth-child(3) {
		grid-column: auto;
		max-width: 100%;
	}
	.concerns__en        { font-size: 48px; }
	.concerns__ja        { font-size: 22px; line-height: 1.8; letter-spacing: 0.18em; }
	.concern-card__image { width: 100%; height: auto; aspect-ratio: 312 / 216; }
	.concern-card__worries { width: 64px; height: auto; right: -20px; top: -20px; }
	.concerns__cta       { font-size: 20px; line-height: 1.8; letter-spacing: 0.18em; }
	.concerns__cta-mark::before { height: 12px; bottom: 4px; }
}

/* ===================================================================== */
/* ---- Reasons (Why Choose Us) ---- */
/* ===================================================================== */
.section--reasons {
	padding-block: var(--section-pad);
	position: relative;
	overflow: clip;
}
.section--reasons .section__inner {
	max-width: 100%;
	width: 100%;
	padding-inline: 0;
	position: relative;
}

/* ----- ヘッダー（Concept レイアウト踏襲） ----- */
.reasons__header {
	position: relative;
	width: 100%;
	min-height: clamp(360px, 30vw, 433px);
	margin-block-end: clamp(8px, 1.2vw, 24px); /* 見出し枠とポイント1が重ならない最小限の余白 */
}
.reasons__rule {
	position: absolute;
	left: calc(12.15% + 0.5em); /* 縦組み英文字 (.reasons__vertical) の中心に揃える */
	top: 0;
	width: 1px;
	height: clamp(50px, 5.45vw, 78.5px);
	background: #E2CEBD;
	font-size: clamp(28px, 3.06vw, 44px); /* em 計算用 (vertical と同期) */
	transform: translateX(-50%);
	z-index: 1;
}
.section--reasons .section-heading__vertical,
.reasons__vertical {
	position: absolute;
	left: 12.15%;    /* heading-text 左端と一致（padding領域に重ねる） */
	top: clamp(70px, 7vw, 100px);
	font-family: var(--font-display);
	font-size: clamp(28px, 3.06vw, 44px);
	font-weight: 400;
	line-height: 1;
	color: #E2CEBD;
	letter-spacing: 0.02em;
	writing-mode: vertical-rl;
	text-transform: capitalize;
	z-index: 1;
}
.reasons__pill-soft {
	position: absolute;
	left: -10%;               /* pricing と統一：左端を画面外にはみ出させ約 1/3 を隠す */
	top: -3%;                 /* pricing と統一 */
	width: 31.39%;            /* 452 / 1440 */
	aspect-ratio: 452 / 433;
	border-radius: clamp(50px, 6.94vw, 100px);
	background: #F4EFE1;
	z-index: 0;
}
.reasons__heading-text {
	position: absolute;
	left: 12.15%;
	top: 0;
	width: 31.39%;
	aspect-ratio: 452 / 433;
	padding: clamp(40px, 5.6vw, 80px) clamp(22px, 3vw, 44px) clamp(28px, 4vw, 56px) clamp(40px, 6vw, 90px);
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: clamp(12px, 1.4vw, 20px);
}
.reasons__heading-text .section-heading        { margin-block-end: 0; gap: 6px; }
.reasons__heading-text .section-heading::before { display: none; }
.reasons__heading-text .section-heading__en   { font-size: clamp(16px, 1.5vw, 22px); }
.reasons__heading-text .section-heading__ja   { font-size: clamp(18px, 1.7vw, 24px); }
.reasons__heading-text .section-heading__lead {
	font-family: var(--font-body-jp);
	font-size: clamp(13px, 1vw, 14px);
	line-height: 1.9;
	color: var(--color-text);
	margin-block-start: clamp(8px, 1vw, 14px);
}

/* ----- ポイント列 ----- */
.reasons__points {
	display: flex;
	flex-direction: column;
	gap: clamp(80px, 10vw, 140px);
	max-width: var(--container-max, 1200px);
	margin-inline: auto;
	padding-inline: var(--container-pad);
}
.reason-point {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-areas: "media body";
	gap: clamp(40px, 5vw, 80px);
	align-items: center;
}
.reason-point__media     { grid-area: media; }
.reason-point__body-wrap { grid-area: body;  }
.reason-point--reverse {
	grid-template-areas: "body media";
}

/* ----- 画像と濃ベージュ背景レイヤー ----- */
.reason-point__media {
	position: relative;
	width: 100%;
	aspect-ratio: 682 / 511.775;
}
.reason-point__visual {
	position: relative;
	z-index: 2;
	width: 100%;
	aspect-ratio: 682 / 511.775;
	border-radius: clamp(60px, 6.94vw, 100px);
	overflow: hidden;
	background: #D9D9D9;
	margin: 0;
}
.reason-point__visual img { width: 100%; height: 100%; object-fit: cover; }
.reason-point__visual-bg {
	position: absolute;
	z-index: 1;
	width: 75.07%;            /* 512 / 682 */
	aspect-ratio: 512 / 411;
	border-radius: clamp(70px, 8.05vw, 116px);
	background: #EFE8D9;
	right: -6%;
	bottom: -6%;
}
.reason-point--reverse .reason-point__visual-bg {
	right: auto;
	left: -6%;
	bottom: -6%;
}

/* ----- 矢印型バッジ ----- */
.reason-point__badge {
	position: absolute;
	right: clamp(-12px, -1vw, 0px);
	bottom: clamp(-12px, -1vw, -4px);
	width: clamp(120px, 11.24vw, 161.858px);
	aspect-ratio: 161.858 / 96.949;
	display: grid;
	place-items: center;
	z-index: 3;
	filter: drop-shadow(var(--shadow-sm));
}
.reason-point__badge-shape {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}
.reason-point__badge-text {
	position: relative;
	z-index: 1;
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: clamp(13px, 1.25vw, 18px);
	line-height: 1.4;
	letter-spacing: 0.1em;
	color: #FFF7E4;
	text-align: center;
	padding-inline: 0.6em;
}

/* ----- ラベル / タイトル / divider / 本文 ----- */
.reason-point__label {
	display: block;
	font-family: var(--font-script);
	font-weight: 400;
	font-size: 20px;
	line-height: 0.8;
	letter-spacing: 0.1em;
	color: #949494;
	text-transform: capitalize;
	margin-block-end: clamp(16px, 1.6vw, 24px);
}
.reason-point__title {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-h3);
	color: var(--color-accent);
	letter-spacing: 0.1em;
	line-height: 1.5;
	margin: 0;
}
.reason-point__divider {
	display: block;
	width: 100%;
	height: 1px;
	background: #BB8B80;
	border: 0;
	margin-block: clamp(16px, 1.6vw, 24px);
}
.reason-point__body {
	font-family: var(--font-body-jp);
	font-weight: 400;
	font-size: var(--fs-body);
	color: var(--color-text);
	line-height: 2;
	text-align: justify;
	letter-spacing: 0.05em;
	margin: 0;
}

@media (max-width: 1024px) {
	.reasons__rule,
	.reasons__vertical,
	.section--reasons .section-heading__vertical,
	.reasons__pill-soft { display: none; }

	.reasons__header {
		min-height: 0;
		margin-block-end: var(--gap-xl);
		padding-inline: var(--container-pad);
	}
	.reasons__heading-text {
		position: relative;
		left: 0;
		top: 0;
		width: 100%;
		max-width: clamp(420px, 70vw, 600px);
		margin-inline: auto;
		aspect-ratio: auto;
		padding: clamp(28px, 4.5vw, 48px) clamp(20px, 4vw, 36px);
		background: #F6F4EE;
		border-radius: clamp(40px, 6vw, 60px);
		display: flex;
		flex-direction: column;
		gap: clamp(14px, 1.6vw, 20px);
	}
	.reasons__heading-text .section-heading__en { font-size: clamp(16px, 2vw, 22px); }
	.reasons__heading-text .section-heading__ja { font-size: clamp(18px, 2.4vw, 26px); }
	.reasons__heading-text .section-heading::before {
		display: block;
		height: 36px;
		margin-block-end: 8px;
	}

	.reason-point,
	.reason-point--reverse {
		grid-template-columns: 1fr;
		grid-template-areas: "media" "body";
		gap: var(--gap-lg);
	}

	.reason-point__visual-bg { display: none; }

	.reason-point__visual {
		border-radius: clamp(40px, 8vw, 60px);
	}

	.reason-point__badge {
		width: clamp(96px, 28vw, 130px);
		right: 8px;
		bottom: -8px;
	}
}

/* ===================================================================== */
/* ---- Pricing ---- */
/* ===================================================================== */
.section--pricing {
	padding-block: var(--section-pad);
	background: transparent;
	position: relative;
}
.section--pricing .section__inner {
	max-width: 100%;
	width: 100%;
	padding-inline: 0;
	position: relative;
}
.pricing__layout {
	position: relative;
	width: 100%;
}
.pricing__rule {
	position: absolute;
	left: calc(12.15% + 0.5em); /* 縦組み Pricing (.pricing__vertical) の中心に揃える / reasons・concept と統一 */
	top: 0;
	width: 1px;
	height: clamp(50px, 5.45vw, 78.5px);
	background: #F4EFE1;
	font-size: clamp(28px, 3.06vw, 44px); /* em 計算用 (vertical と同期) */
	transform: translateX(-50%);
	z-index: 3;
}
.section--pricing .section-heading__vertical,
.pricing__vertical {
	position: absolute;
	left: 12.15%; /* heading-text 左端と一致（padding領域に重ねる） */
	top: clamp(70px, 7vw, 100px); /* reasons と統一 */
	font-family: var(--font-display);
	font-size: clamp(28px, 3.06vw, 44px);
	font-weight: 400;
	line-height: 1;
	color: #F4EFE1;
	letter-spacing: 0.02em;
	writing-mode: vertical-rl;
	text-transform: capitalize;
	z-index: 3;
}
.pricing__heading-pill {
	position: absolute;
	left: -10%;
	top: -3%;
	width: 31.39%;
	aspect-ratio: 452 / 433;
	border-radius: clamp(50px, 6.94vw, 100px);
	background: #EDDFC1;
	z-index: 2;
}
.pricing__heading-text {
	position: absolute;
	left: 12.15%;
	top: 0;
	width: 31.39%;
	aspect-ratio: 452 / 433;
	padding: clamp(40px, 5.6vw, 80px) clamp(22px, 3vw, 44px) clamp(28px, 4vw, 56px) clamp(40px, 6vw, 90px);
	z-index: 3;
	display: flex;
	flex-direction: column;
	gap: clamp(12px, 1.4vw, 20px);
}
.pricing__heading-text .section-heading        { margin-block-end: 0; gap: 6px; }
.pricing__heading-text .section-heading::before { display: none; }
.pricing__heading-text .section-heading__en   { font-size: clamp(16px, 1.5vw, 22px); }
.pricing__heading-text .section-heading__ja   { font-size: clamp(18px, 1.7vw, 24px); }
.pricing__heading-lead {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: clamp(11px, 0.97vw, 14px);
	color: var(--color-text);
	line-height: 1.9;
	margin: 0;
	margin-block-start: clamp(8px, 1vw, 14px);
}
.pricing__container {
	position: relative;
	width: 91.32%;
	margin-inline: auto;
	min-height: clamp(680px, 65vw, 936px);
	padding: clamp(60px, 7vw, 100px) clamp(60px, 6vw, 90px) clamp(80px, 9vw, 130px) clamp(440px, 42vw, 600px);
	border-radius: clamp(50px, 6.94vw, 100px);
	background: var(--color-bg-cream);
	z-index: 1;
}
.pricing__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(40px, 6vw, 88px);
}
.pricing-card {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.pricing-card__en {
	font-family: var(--font-script);
	font-size: var(--fs-plan-en);
	color: var(--color-accent);
	line-height: 1.2;
}
.pricing-card__ja {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-body-lead);
	color: var(--color-accent);
	letter-spacing: 0.1em;
}
.pricing-card__divider {
	width: 100%;
	height: 1px;
	background: var(--color-accent);
	opacity: 0.4;
}
.pricing-card__lead {
	font-family: var(--font-body-jp);
	font-weight: 400;
	font-size: var(--fs-body);
	color: var(--color-text);
	line-height: 2;
	text-align: justify;
	letter-spacing: 0.05em;
}
.pricing-card__table {
	display: flex;
	flex-direction: column;
	gap: 20px;
	font-family: var(--font-body-jp);
	font-weight: 400;
	color: var(--color-text);
}
.pricing-card__row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	font-size: var(--fs-body);
	letter-spacing: 0.05em;
	border-bottom: 1px dashed var(--color-border);
	padding-bottom: 8px;
}
.pricing-card__price {
	font-size: var(--fs-price-big);
	font-weight: 500;
}
.pricing-card__price-unit {
	font-size: var(--fs-xs);
	color: var(--color-text-body);
	margin-left: 4px;
}
.pricing-card__features {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: 26px 42px;
	display: flex;
	flex-direction: column;
	gap: 17px;
	box-shadow: var(--shadow-card);
}
.pricing-card__feature {
	display: flex;
	align-items: center;
	gap: 12px;
	font-family: var(--font-body-jp);
	font-weight: 400;
	font-size: 14px;
	color: var(--color-text-body);
	letter-spacing: 0.04em;
}
.pricing-card__feature::before {
	content: '';
	display: inline-block;
	width: 12px;
	height: 6px;
	border-left: 1px solid var(--color-accent);
	border-bottom: 1px solid var(--color-accent);
	transform: rotate(-45deg);
	flex-shrink: 0;
}
.pricing__note {
	position: absolute;
	right: clamp(60px, 6vw, 90px);
	bottom: clamp(30px, 4vw, 60px);
	max-width: 360px;
	margin: 0;
	font-family: var(--font-body-jp);
	font-weight: 400;
	font-size: var(--fs-xs);
	color: var(--color-text-body);
	line-height: 1.8;
	text-align: right;
}
.pricing__detail-link {
	margin-block-start: clamp(36px, 5vw, 56px);
	text-align: center;
}

@media (max-width: 1024px) {
	.section--pricing {
		padding-block: clamp(60px, 10vw, 100px);
	}
	.section--pricing .section__inner {
		padding-inline: var(--container-pad);
	}
	.pricing__layout {
		display: flex;
		flex-direction: column;
		gap: var(--gap-lg);
		align-items: center;
	}
	.section--pricing .section-heading__vertical,
	.pricing__vertical,
	.pricing__rule,
	.pricing__heading-pill {
		display: none;
	}
	.pricing__heading-text {
		position: relative;
		left: 0;
		top: 0;
		width: 100%;
		max-width: clamp(420px, 70vw, 600px);
		margin-inline: auto;
		aspect-ratio: auto;
		padding: clamp(28px, 4.5vw, 48px) clamp(20px, 4vw, 36px);
		background: #F6F4EE;
		border-radius: clamp(40px, 6vw, 60px);
		display: flex;
		flex-direction: column;
		gap: clamp(14px, 1.6vw, 20px);
	}
	.pricing__heading-text .section-heading__en { font-size: clamp(16px, 2vw, 22px); }
	.pricing__heading-text .section-heading__ja { font-size: clamp(18px, 2.4vw, 26px); }
	.pricing__heading-text .section-heading::before {
		display: block;
		height: 36px;
		margin-block-end: 8px;
	}
	.pricing__container {
		position: relative;
		width: 100%;
		min-height: 0;
		padding: clamp(40px, 8vw, 60px) var(--container-pad);
		border-radius: 60px;
		background: var(--color-bg-cream);
	}
	.pricing__grid {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.pricing__note {
		position: relative;
		right: auto;
		bottom: auto;
		max-width: 100%;
		margin-top: 32px;
		text-align: center;
	}
}

/* ===================================================================== */
/* ---- Voices ---- */
/* ===================================================================== */
.section--voices {
	padding-block: var(--section-pad);
	background: var(--color-bg);
	position: relative;
}
.voices__heading {
	text-align: center;
	margin-block-end: var(--gap-xl);
	position: relative;
	padding-block-start: 56px;
}
.voices__en {
	font-family: var(--font-display);
	font-size: 76px;
	font-style: normal;
	font-weight: 400;
	line-height: 100%;
	color: var(--color-cta-bg);
	text-align: center;
	text-transform: capitalize;
	margin: 0;
	position: absolute;
	inset-inline: 0;
	top: 10px;
	z-index: 0;
	pointer-events: none;
	user-select: none;
}
.voices__ja {
	position: relative;
	z-index: 1;
	display: inline-block;
	font-family: var(--font-body-jp);
	font-weight: 700;
	font-size: var(--fs-h2);
	color: var(--color-text);
	letter-spacing: var(--ls-wide);
	margin-top: 8px;
}
.voices__list {
	display: flex;
	flex-direction: column;
	gap: 56px;
	max-width: 1100px;
	margin: 0 auto;
}
.voice-bubble {
	position: relative;
	background: var(--color-white);
	border-radius: 46px;
	padding: 32px 70px;
	box-shadow: var(--shadow-sm);
}
.voice-bubble::before,
.voice-bubble::after {
	position: absolute;
	font-family: var(--font-display);
	font-size: var(--fs-quote);
	color: var(--color-bg-cream);
	line-height: 0.5;
	pointer-events: none;
}
.voice-bubble::before {
	content: '"';
	left: 18px;
	top: 34px;
}
.voice-bubble::after {
	content: '"';
	right: 18px;
	bottom: 0;
	transform: scale(-1, -1);
	z-index: 3;
}
.voice-bubble__body {
	font-family: var(--font-body-jp);
	font-weight: 400;
	font-size: var(--fs-body);
	color: var(--color-text);
	line-height: 1.9;
	letter-spacing: 0.03em;
	margin: 0;
}
.voice-bubble__author {
	position: absolute;
	bottom: 0;
	right: 56px;
	transform: translateY(50%);
	z-index: 2;
	background: var(--color-accent);
	color: var(--color-white);
	border-radius: 116px;
	padding: 14px 28px;
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-xs);
	letter-spacing: 0.06em;
	min-width: 260px;
	text-align: center;
}
.voices__note {
	text-align: center;
	margin-block: 24px;
	font-family: var(--font-body-jp);
	font-size: var(--fs-small);
	color: var(--color-text-muted);
}
.voices__actions { display: flex; justify-content: center; margin-top: 16px; position: relative; z-index: 1; }

/* 糸装飾（voice-thread.svg, 619×1084） — 吹き出しの背後・背景の上 */
.voices__thread {
	position: absolute;
	right: 4%;
	top: clamp(160px, 18vw, 260px);
	width: clamp(280px, 36vw, 520px);
	aspect-ratio: 619 / 1084;
	z-index: 0;
	opacity: 0.85;
	pointer-events: none;
	user-select: none;
}
.voices__list { position: relative; z-index: 1; }
.voice-bubble { z-index: 1; }

@media (max-width: 1024px) {
	.voices__thread {
		right: -8%;
		top: 220px;
		width: 70%;
		opacity: 0.6;
	}
}

@media (max-width: 640px) {
	.voices__en { font-size: 56px; }

	.voices__list { gap: 72px; }

	.voice-bubble { padding: 22px 24px 40px; }

	.voice-bubble::before { top: 0; }

	.voice-bubble__author {
		right: 50%;
		transform: translate(50%, 50%);
		min-width: 0;
		width: auto;
		max-width: calc(100% - 32px);
		padding: 10px 18px;
		font-size: 11px;
		letter-spacing: 0.04em;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.voices__note { margin-block: 40px 24px; }
}

/* ===================================================================== */
/* ---- Information (Concept/Pricing 準拠の左ピル＋縦字レイアウト) ---- */
/* ===================================================================== */
.section--info {
	padding-block: var(--section-pad);
	background: linear-gradient(180deg, rgba(239,232,217,0) 0%, #EDE2CB 50%, #EDE2CB 100%);
	position: relative;
}
.section--info .section__inner {
	max-width: 100%;
	width: 100%;
	padding-inline: 0;
	position: relative;
}
.info__layout {
	position: relative;
	width: 100%;
	min-height: clamp(460px, 34vw, 500px);
}
.info__rule {
	position: absolute;
	left: calc(12.15% + 0.5em);
	top: 0;
	width: 1px;
	height: clamp(50px, 5.45vw, 78.5px);
	background: #E2CEBD;
	font-size: clamp(28px, 3.06vw, 44px);
	transform: translateX(-50%);
	z-index: 3;
}
.section--info .section-heading__vertical,
.info__vertical {
	position: absolute;
	left: 12.15%;
	top: clamp(70px, 7vw, 100px);
	font-family: var(--font-display);
	font-size: clamp(28px, 3.06vw, 44px);
	font-weight: 400;
	line-height: 1;
	color: #E2CEBD;
	letter-spacing: 0.02em;
	writing-mode: vertical-rl;
	text-transform: capitalize;
	z-index: 3;
}
.info__heading-pill {
	position: absolute;
	left: -10%;
	top: -3%;
	width: 31.39%;             /* 452 / 1440 */
	aspect-ratio: 452 / 433;
	border-radius: clamp(50px, 6.94vw, 100px);
	background: #F6F4EE;
	z-index: 0;
}
.info__heading-text {
	position: absolute;
	left: 12.15%;
	top: 0;
	width: 31.39%;
	aspect-ratio: 452 / 433;
	padding: clamp(40px, 5.6vw, 80px) clamp(22px, 3vw, 44px) clamp(28px, 4vw, 56px) clamp(40px, 6vw, 90px);
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: clamp(12px, 1.4vw, 20px);
}
.info__heading-text .section-heading        { margin-block-end: 0; gap: 6px; }
.info__heading-text .section-heading::before { display: none; }
.info__heading-text .section-heading__en   { font-size: clamp(16px, 1.5vw, 22px); }
.info__heading-text .section-heading__ja   { font-size: clamp(18px, 1.7vw, 24px); }

/* 右側コンテンツ領域（Pricing __container 準拠） */
.info__container {
	position: relative;
	width: 91.32%;
	margin-inline: auto;
	padding: clamp(40px, 5vw, 72px) clamp(40px, 4vw, 60px) clamp(40px, 5vw, 72px) clamp(440px, 42vw, 600px);
	z-index: 1;
}

.info__list {
	border-top: 1px solid var(--color-border);
	margin-top: 0;
}
.info__item {
	display: grid;
	grid-template-columns: 120px 100px 1fr;
	gap: 24px;
	align-items: center;
	padding: 28px 16px;
	border-bottom: 1px solid var(--color-border);
}
.info__date {
	font-family: var(--font-display);
	font-size: var(--fs-small);
	color: var(--color-text-body);
	letter-spacing: 0.08em;
}
.info__label {
	display: inline-block;
	padding: 4px 12px;
	border-radius: var(--radius-pill);
	background: var(--color-cta-bg);
	color: var(--color-secondary);
	font-family: var(--font-body-jp);
	font-size: var(--fs-xs);
	text-align: center;
}
.info__title {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-body);
	color: var(--color-text);
}
.info__empty {
	padding: 60px 20px;
	text-align: center;
	font-family: var(--font-body-jp);
	color: var(--color-text-body);
	background: var(--color-white);
	border-radius: var(--radius-md);
	font-size: var(--fs-body);
	line-height: 2;
}
.info__actions { display: flex; justify-content: center; margin-top: var(--gap-lg); }

/* ===================================================================== */
/* ---- Column ---- */
/* ===================================================================== */
.section--column {
	padding-block: var(--section-pad);
	background: linear-gradient(180deg, #EDE2CB 0%, var(--color-bg-cream) clamp(160px, 22vw, 280px), var(--color-bg-cream) 100%);
}
.section--column .section-heading {
	text-align: center;
	align-items: center;
	position: relative;
	padding-block-start: 56px;
	margin-block-end: var(--gap-xl);
}
.section--column .section-heading::before {
	display: none;
}
.section--column .section-heading__en {
	font-family: var(--font-display);
	font-size: 76px;
	font-weight: 400;
	line-height: 100%;
	color: var(--color-cta-bg);
	text-align: center;
	text-transform: capitalize;
	letter-spacing: 0.02em;
	margin: 0;
	position: absolute;
	inset-inline: 0;
	top: 10px;
	z-index: 0;
	pointer-events: none;
	user-select: none;
}
.section--column .section-heading__ja {
	position: relative;
	z-index: 1;
	display: inline-block;
	margin-top: 8px;
}
@media (max-width: 640px) {
	.section--column .section-heading__en { font-size: 56px; }
}
.column__empty {
	padding: 60px 20px;
	text-align: center;
	font-family: var(--font-body-jp);
	color: var(--color-text-body);
	background: var(--color-white);
	border-radius: var(--radius-md);
	font-size: var(--fs-body);
	line-height: 2;
}
.column__actions { display: flex; justify-content: center; margin-top: var(--gap-lg); }

.column__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--gap-lg);
	margin-top: var(--gap-lg);
}
.column-card {
	background: var(--color-white);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
}
.column-card__thumb {
	aspect-ratio: 375 / 227;
	background: var(--color-bg-cream);
	overflow: hidden;
}
.column-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.column-card__body { padding: 20px 24px; display: flex; flex-direction: column; gap: 12px; }
.column-card__meta { display: flex; align-items: center; gap: 12px; font-size: var(--fs-xs); color: var(--color-text-body); }
.column-card__title {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: var(--fs-body-lead);
	color: var(--color-text);
	line-height: 1.6;
}
.column-card__excerpt {
	font-family: var(--font-body-jp);
	font-size: var(--fs-small);
	color: var(--color-text-body);
	line-height: 1.8;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ----- Information ≤1024px：Pricing/Reasons と同じフォールバック ----- */
@media (max-width: 1024px) {
	.section--info {
		padding-block: clamp(60px, 10vw, 100px);
	}
	.section--info .section__inner {
		padding-inline: var(--container-pad);
	}
	.info__layout {
		display: flex;
		flex-direction: column;
		gap: var(--gap-lg);
		align-items: stretch;
	}
	.section--info .section-heading__vertical,
	.info__vertical,
	.info__rule,
	.info__heading-pill { display: none; }
	.info__heading-text {
		position: relative;
		left: 0;
		top: 0;
		width: 100%;
		max-width: clamp(420px, 70vw, 600px);
		aspect-ratio: auto;
		padding: clamp(28px, 4.5vw, 48px) clamp(20px, 4vw, 36px);
		margin-inline: auto;
		background: #F6F4EE;
		border-radius: clamp(40px, 6vw, 60px);
		display: flex;
		flex-direction: column;
		gap: clamp(14px, 1.6vw, 20px);
	}
	.info__heading-text .section-heading__en { font-size: clamp(16px, 2vw, 22px); }
	.info__heading-text .section-heading__ja { font-size: clamp(18px, 2.4vw, 26px); }
	.info__heading-text .section-heading::before {
		display: block;
		height: 36px;
		margin-block-end: 8px;
	}
	.info__container {
		width: 100%;
		padding: 0 var(--container-pad);
	}
}

@media (max-width: 768px) {
	.info__item { grid-template-columns: 1fr; gap: 8px; padding: 20px 8px; }
	.column__grid { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; }
}

/* ===================================================================== */
/* ---- CTA (Contact) ---- */
/* ===================================================================== */
.section--cta {
	padding-block: 0;
	background:
		url('../images/contact-bg.webp') center center / 100% 100% no-repeat,
		#FAF9F6;
	position: relative;
}
.section--cta .section__inner {
	max-width: 100%;
	width: 100%;
	padding-inline: 0;
	position: relative;
}

/* レイアウト土台（背景画像 2880x986 と同じ比率で約500px高さに） */
.cta__layout {
	position: relative;
	width: 100%;
	aspect-ratio: 2880 / 986;     /* viewport 1440 → 約 493px */
	min-height: 460px;
}

/* 左ベージュピル（concept と同じ 452x433 / radius 100 / #F6F4EE、縦中央配置） */
.cta__pill-soft {
	position: absolute;
	left: -10%;
	top: 50%;
	transform: translateY(-50%);
	width: 31.39%;                /* 452 / 1440 */
	aspect-ratio: 452 / 433;
	border-radius: clamp(50px, 6.94vw, 100px);
	background: #F6F4EE;
	z-index: 0;
}

/* ピル内テキスト：筆記体 Contact + 日本語 お問い合わせ（ピルと同じ位置・サイズ） */
.cta__heading-text {
	position: absolute;
	left: 12.15%;
	top: 50%;
	transform: translateY(-50%);
	width: 31.39%;
	aspect-ratio: 452 / 433;
	padding: clamp(40px, 5.6vw, 80px) clamp(22px, 3vw, 44px) clamp(28px, 4vw, 56px) clamp(40px, 6vw, 90px);
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: clamp(12px, 1.4vw, 20px);
}
.cta__heading-text .section-heading        { margin-block-end: 0; gap: 6px; }
.cta__heading-text .section-heading::before { display: none; }
.cta__heading-text .section-heading__en   { font-size: clamp(16px, 1.5vw, 22px); }
.cta__heading-text .section-heading__ja   { font-size: clamp(18px, 1.7vw, 24px); }

/* 縦書き Contact（縦中央＋少し上寄り） */
.section--cta .section-heading__vertical,
.cta__vertical {
	position: absolute;
	left: 12.15%;
	top: 50%;
	transform: translateY(-50%);
	font-family: var(--font-display);
	font-size: clamp(28px, 3.06vw, 44px);
	font-weight: 400;
	line-height: 1;
	color: #E2CEBD;
	letter-spacing: 0.02em;
	writing-mode: vertical-rl;
	text-transform: capitalize;
	z-index: 3;
}

/* 縦棒線（縦字 Contact の真上に配置） */
.cta__rule {
	position: absolute;
	left: calc(12.15% + 0.5em);
	top: 50%;
	width: 1px;
	height: clamp(50px, 5.45vw, 78.5px);
	background: #E2CEBD;
	font-size: clamp(28px, 3.06vw, 44px);
	transform: translate(-50%, calc(-50% - clamp(80px, 9vw, 130px)));
	z-index: 3;
}

/* 中央コンテンツ：viewport 中央に配置（縦も中央） */
.cta__content {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	max-width: 600px;
	z-index: 1;
	text-align: left;
}
.cta__title {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: clamp(22px, 2.6vw, 28px);
	color: var(--color-text-sub);
	letter-spacing: var(--ls-wide);
	line-height: 1.6;
	margin-block-end: 16px;
}
.cta__lead {
	font-family: var(--font-body-jp);
	font-weight: 400;
	font-size: var(--fs-body);
	color: var(--color-text);
	line-height: 1.9;
	margin-block-end: clamp(20px, 2.4vw, 32px);
}
.cta__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 16px;
}

/* レスポンシブ（concept / info と同じ 1024px ブレーク） */
@media (max-width: 1024px) {
	.section--cta {
		background-image: none;
		background-color: #FAF9F6;
		padding-block: clamp(60px, 10vw, 100px);
	}
	.section--cta .section__inner {
		padding-inline: var(--container-pad);
	}
	.cta__layout {
		aspect-ratio: auto;
		min-height: 0;
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: var(--gap-lg);
	}
	.section--cta .section-heading__vertical,
	.cta__vertical,
	.cta__rule,
	.cta__pill-soft { display: none; }
	.cta__heading-text {
		position: relative;
		left: 0;
		top: 0;
		width: 100%;
		max-width: clamp(420px, 70vw, 600px);
		aspect-ratio: auto;
		padding: clamp(28px, 4.5vw, 48px) clamp(20px, 4vw, 36px);
		margin-inline: auto;
		background: #F6F4EE;
		border-radius: clamp(40px, 6vw, 60px);
		display: flex;
		flex-direction: column;
		gap: clamp(14px, 1.6vw, 20px);
		align-items: center;
	}
	.cta__heading-text .section-heading__en { font-size: clamp(16px, 2vw, 22px); }
	.cta__heading-text .section-heading__ja { font-size: clamp(18px, 2.4vw, 26px); }
	.cta__heading-text .section-heading::before {
		display: block;
		height: 36px;
		margin-block-end: 8px;
	}
	.cta__heading-text .section-heading {
		align-items: center;
		text-align: center;
	}
	.cta__content {
		position: relative;
		left: 0;
		top: 0;
		transform: none;
		padding-inline: 0;
		text-align: center;
	}
	.cta__actions {
		justify-content: center;
	}
}

/* ===================================================================== */
/* ---- site footer ---- */
/* ===================================================================== */
.site-footer {
	background: #EFE8D9;
	padding-block: 80px 32px;
	position: relative;
}
.site-footer__inner {
	max-width: 1320px;
	width: 100%;
	margin: 0 auto;
	padding-inline: var(--container-pad);
}
.site-footer__tagline {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: 18px;
	color: #9A7F6C;
	text-align: center;
	letter-spacing: 1.8px;
	line-height: 1.6;
	padding-block: 16px 14px;
	border-bottom: 1px solid #9A7F6C;
	margin-block-end: 56px;
}
.site-footer__tagline-br { display: none; }
.site-footer__grid {
	display: grid;
	grid-template-columns: minmax(360px, 1.4fr) repeat(3, 1fr);
	column-gap: clamp(24px, 4vw, 64px);
	row-gap: clamp(24px, 3vw, 40px);
	margin-block-end: 32px;
}
.site-footer__brand {
	grid-row: span 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	text-align: center;
}
.site-footer__brand-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-logo);
}
.site-footer__brand-mark-icon { width: 80px; height: 80px; flex-shrink: 0; }
.site-footer__brand-title {
	font-family: var(--font-serif-jp);
	font-weight: 500;
	font-size: 18px;
	color: var(--color-text);
	letter-spacing: 0.15em;
	white-space: nowrap;
}
.site-footer__brand-sub {
	font-family: var(--font-display);
	font-size: 13px;
	color: var(--color-accent);
	letter-spacing: 0.2em;
	text-transform: capitalize;
	margin-top: -2px;
	white-space: nowrap;
}
.site-footer__social {
	display: flex;
	gap: 20px;
	justify-content: center;
	list-style: none;
	padding: 0;
	margin: 12px 0 0;
}
.site-footer__social li { line-height: 0; }
.site-footer__social a {
	display: inline-flex;
	width: 32px;
	height: 32px;
	align-items: center;
	justify-content: center;
	transition: transform var(--dur-fast) var(--ease-out-expo);
}
.site-footer__social a:hover { transform: translateY(-2px); }
.site-footer__social img { width: 100%; height: 100%; object-fit: contain; }
.site-footer__nav-column {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.site-footer__nav-title {
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--font-display);
	font-size: 18px;
	font-weight: 400;
	line-height: 30px;
	letter-spacing: 1.8px;
	color: #333;
	margin: 0 0 4px;
	text-transform: capitalize;
}
.site-footer__nav-title::before {
	content: '';
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: #E2CEBD;
	flex-shrink: 0;
}
.site-footer__nav-column a {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-body-jp);
	font-size: 15px;
	font-weight: 500;
	line-height: 30px;
	letter-spacing: 1.5px;
	color: #333;
	transition: color var(--dur-fast) ease;
}
.site-footer__nav-column a::before {
	content: '';
	width: 9px;
	height: 0;
	border-top: 2px solid #E2CEBD;
	flex-shrink: 0;
}
.site-footer__nav-column a:hover { color: var(--color-accent); }
.site-footer__cta {
	grid-column: 2 / -1;
	display: flex;
	gap: 24px;
	justify-content: center;
	margin-block: 16px 8px;
}
.site-footer__cta .btn { min-width: 240px; }
.site-footer__copyright {
	font-family: var(--font-body-jp);
	font-weight: 500;
	font-size: 12px;
	color: var(--color-text-footer);
	letter-spacing: 0.1em;
	text-align: center;
	padding-top: 24px;
}

@media (max-width: 1024px) {
	.site-footer__grid {
		grid-template-columns: 1fr 1fr;
	}
	.site-footer__brand { grid-column: 1 / -1; grid-row: auto; }
	.site-footer__cta   { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
	.site-footer__grid { grid-template-columns: 1fr; }
	.site-footer__cta { flex-direction: column; align-items: stretch; }
	.site-footer__cta .btn { min-width: 0; width: 100%; }
	.site-footer__tagline-comma { display: none; }
	.site-footer__tagline-br { display: inline; }
}

/* ---- mobile CTA bar (既存挙動継続) ---- */
.mobile-cta-bar {
	position: fixed;
	inset-inline: 0;
	bottom: 0;
	z-index: var(--z-mobile-cta);
	display: flex;
	background: var(--color-white);
	box-shadow: 0 -4px 12px rgba(0,0,0,0.08);
	transform: translateY(100%);
	transition: transform var(--dur-mid) var(--ease-out-expo);
}
.mobile-cta-bar.is-visible { transform: translateY(0); }
.mobile-cta-bar__item {
	flex: 1;
	padding: 16px 8px;
	text-align: center;
	font-family: var(--font-body-jp);
	font-size: var(--fs-small);
	font-weight: 500;
	letter-spacing: 0.08em;
}
.mobile-cta-bar__item--line { background: var(--color-bg-cream); color: var(--color-secondary); }
.mobile-cta-bar__item--primary { background: var(--color-cta-bg); color: var(--color-secondary); }
@media (min-width: 769px) {
	.mobile-cta-bar { display: none; }
}

/* ===================================================================== */
/* ---- bus tour (page-tour.php) ---- */
/* ===================================================================== */
.section--tour { padding-block: clamp(60px, 10vw, 140px); }
.section--tour .section__inner {
	max-width: 880px;
	margin: 0 auto;
	padding-inline: clamp(20px, 4vw, 40px);
}
.tour-intro { margin-block: var(--gap-lg); line-height: 1.9; }

/* ---- tour-overview ---- */
.tour-overview { margin-block: var(--gap-xl); }
.tour-overview__list {
	display: grid;
	gap: var(--gap-sm);
	margin-top: var(--gap-md);
	background: var(--color-bg-warm);
	border-radius: var(--radius-md);
	padding: clamp(20px, 3vw, 32px);
}
.tour-overview__row {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: var(--gap-md);
	align-items: baseline;
	padding-block: 12px;
	border-bottom: 1px solid var(--color-border);
}
.tour-overview__row:last-child { border-bottom: none; padding-bottom: 0; }
.tour-overview__row dt {
	font-family: var(--font-serif-jp);
	font-weight: 500;
	color: var(--color-text-sub);
	letter-spacing: 0.08em;
}
.tour-overview__row dd {
	color: var(--color-text);
	line-height: 1.8;
}
@media (max-width: 600px) {
	.tour-overview__row { grid-template-columns: 1fr; gap: 4px; }
}

/* ---- tour-meeting (集合場所のご案内) ---- */
.tour-meeting { margin-block: var(--gap-xl); }
.tour-meeting__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: clamp(16px, 2vw, 24px);
	margin-top: var(--gap-md);
}
.tour-meeting__card {
	background: var(--color-bg-warm);
	border-radius: var(--radius-md);
	padding: clamp(24px, 3vw, 32px);
	display: flex;
	flex-direction: column;
	gap: 6px;
	box-shadow: var(--shadow-sm);
}
.tour-meeting__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-pill);
	background: var(--color-white);
	color: var(--color-accent);
	margin-bottom: 4px;
}
.tour-meeting__label {
	font-family: var(--font-serif-jp);
	font-size: var(--fs-small);
	color: var(--color-text-sub);
	letter-spacing: var(--ls-wide);
}
.tour-meeting__region {
	font-size: var(--fs-xs);
	color: var(--color-secondary);
	letter-spacing: var(--ls-wide);
	margin: 0;
}
.tour-meeting__value {
	font-family: var(--font-serif-jp);
	font-size: clamp(18px, 1.8vw, 22px);
	font-weight: 600;
	color: var(--color-text);
	line-height: 1.6;
	margin: 0;
}
.tour-meeting__note {
	font-size: var(--fs-small);
	color: var(--color-text-body);
	line-height: 1.7;
	margin: 4px 0 0;
}
.tour-meeting__map-button {
	margin-top: auto;
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 22px;
	background: var(--color-accent);
	color: var(--color-white);
	border-radius: var(--radius-pill);
	text-decoration: none;
	font-family: var(--font-serif-jp);
	font-size: var(--fs-small);
	font-weight: 600;
	letter-spacing: var(--ls-card);
	transition: opacity var(--dur-fast) var(--easing), transform var(--dur-fast) var(--easing);
}
.tour-meeting__map-button:hover,
.tour-meeting__map-button:focus-visible {
	opacity: 0.88;
	transform: translateY(-1px);
}
.tour-meeting__map-button svg { flex-shrink: 0; }
.tour-meeting__card--date .tour-meeting__map-button { margin-top: var(--gap-sm); }
@media (max-width: 720px) {
	.tour-meeting__grid { grid-template-columns: 1fr; }
}

/* ---- tour-pricing ---- */
.tour-pricing { margin-block: var(--gap-xl); }
.tour-pricing__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--gap-sm);
	margin-top: var(--gap-md);
}
.tour-pricing__card {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: clamp(16px, 2.5vw, 24px);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-bg);
}
.tour-pricing__card--member_female,
.tour-pricing__card--member_male {
	background: var(--color-bg-cream);
	border-color: var(--color-accent);
}
.tour-pricing__label {
	font-size: var(--fs-small);
	color: var(--color-text-sub);
	letter-spacing: 0.05em;
}
.tour-pricing__sub {
	display: block;
	margin-top: 2px;
	font-size: 12px;
	color: var(--color-text-sub);
	letter-spacing: 0.04em;
}
.tour-pricing__amount {
	font-family: var(--font-serif-jp);
	font-size: clamp(20px, 2vw, 26px);
	font-weight: 600;
	color: var(--color-text);
}
.tour-pricing__note {
	margin-top: var(--gap-sm);
	font-size: var(--fs-small);
	color: var(--color-text-body);
	line-height: 1.7;
}
@media (max-width: 480px) {
	.tour-pricing__grid { grid-template-columns: 1fr; }
}

/* ---- tour form (CF7) ---- */
.section--tour-form { margin-block: var(--gap-xl); }
.tour-form-wrap { margin-top: var(--gap-md); }
.tour-form-wrap form { display: grid; gap: var(--gap-md); }

.tour-fieldset {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: clamp(16px, 3vw, 28px);
	background: var(--color-bg);
}
.tour-fieldset > legend {
	padding: 4px 16px;
	font-family: var(--font-serif-jp);
	font-weight: 500;
	font-size: var(--fs-body-lead);
	color: var(--color-accent-strong);
	background: var(--color-bg-warm);
	border-radius: var(--radius-pill);
	letter-spacing: 0.08em;
}
.tour-fieldset p { margin-block: 12px; }
.tour-fieldset label { display: block; font-size: var(--fs-small); color: var(--color-text-sub); line-height: 1.7; }
.tour-fieldset input[type="text"],
.tour-fieldset input[type="email"],
.tour-fieldset input[type="tel"],
.tour-fieldset input[type="number"],
.tour-fieldset select,
.tour-fieldset textarea {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-white, #fff);
	font-family: var(--font-body-jp);
	font-size: var(--fs-body);
	color: var(--color-text);
	transition: border-color var(--dur-mid) ease;
}
.tour-fieldset input:focus,
.tour-fieldset select:focus,
.tour-fieldset textarea:focus {
	outline: none;
	border-color: var(--color-accent);
}
.tour-fieldset .wpcf7-list-item { display: inline-block; margin-right: var(--gap-sm); margin-bottom: 4px; }
.tour-fieldset .wpcf7-list-item input { margin-right: 4px; }
.tour-fieldset .wpcf7-acceptance .wpcf7-list-item { display: block; margin: 6px 0; }

.tour-fieldset .dob-row { display: inline-flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.tour-fieldset .dob-row input { width: 6em; }

/* 送信ボタンを含む段落（CF7 が <p> でラップする）を中央寄せ */
.tour-form-wrap form > p:has(input[type="submit"]),
.tour-form-wrap form > p:has(.wpcf7-submit),
.tour-form-wrap .tour-form-submit {
	text-align: center;
	margin-top: var(--gap-lg);
}
.tour-form-wrap input[type="submit"],
.tour-form-wrap .wpcf7-submit {
	display: inline-block;
	padding: 16px 48px;
	background: var(--color-accent);
	color: #fff;
	border: none;
	border-radius: var(--radius-pill);
	font-family: var(--font-body-jp);
	font-weight: 600;
	font-size: var(--fs-body-lead);
	letter-spacing: 0.08em;
	cursor: pointer;
	transition: background var(--dur-mid) ease, transform var(--dur-mid) ease;
}
.tour-form-wrap input[type="submit"]:hover,
.tour-form-wrap .wpcf7-submit:hover {
	background: var(--color-accent-strong);
	transform: translateY(-1px);
}

/* ---- timerex intro note (韓国語予約案内など、CTA直前の前置き) ---- */
.timerex-intro-note {
	margin: var(--gap-md) auto;
	max-width: 720px;
	padding: clamp(16px, 2.5vw, 24px);
	border-radius: var(--radius-md);
	background: var(--color-bg-warm);
	border-left: 4px solid var(--color-accent);
	font-size: var(--fs-small);
	line-height: 1.9;
	color: var(--color-text);
	text-align: left;
}
.timerex-intro-note p { margin: 0 0 0.6em; }
.timerex-intro-note p:last-child { margin-bottom: 0; }
.timerex-intro-note ol,
.timerex-intro-note ul {
	margin: 0.4em 0 0.6em;
	padding-left: 1.4em;
}

/* ---- tour-notes ---- */
.tour-notes { margin-block: var(--gap-xl); }
.tour-notes__body {
	margin-top: var(--gap-md);
	padding: clamp(20px, 3vw, 32px);
	background: var(--color-bg-warm);
	border-radius: var(--radius-md);
	line-height: 1.9;
	color: var(--color-text);
}
.tour-notes__body p { margin-bottom: 1em; }
.tour-notes__body p:last-child { margin-bottom: 0; }
.tour-notes__body ul,
.tour-notes__body ol { padding-left: 1.5em; margin-bottom: 1em; }
.tour-notes__body ul { list-style: disc; }
.tour-notes__body ol { list-style: decimal; }

/* ---- top page CTA banner ---- */
.section--tour-cta { padding-block: clamp(40px, 8vw, 80px); }
.section--tour-cta .section__inner {
	max-width: 1200px;
	margin: 0 auto;
	padding-inline: clamp(20px, 4vw, 40px);
}
.tour-cta-banner {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--gap-sm);
	padding: clamp(40px, 8vw, 80px) clamp(20px, 4vw, 40px);
	border-radius: var(--radius-lg);
	background: linear-gradient(135deg, var(--color-bg-cream) 0%, var(--color-bg-ivory) 100%);
	background-size: cover;
	background-position: center;
	text-align: center;
	overflow: hidden;
	box-shadow: var(--shadow-md);
}
.tour-cta-banner--has-image { color: #fff; }
.tour-cta-banner__eyebrow {
	font-family: var(--font-display);
	font-size: clamp(13px, 1.2vw, 16px);
	letter-spacing: 0.2em;
	text-transform: uppercase;
}
.tour-cta-banner--has-image .tour-cta-banner__eyebrow { color: rgba(255,255,255,0.9); }
.tour-cta-banner:not(.tour-cta-banner--has-image) .tour-cta-banner__eyebrow { color: var(--color-accent); }
.tour-cta-banner__title {
	font-family: var(--font-serif-jp);
	font-weight: 500;
	font-size: clamp(22px, 2.4vw, 32px);
	line-height: 1.5;
	max-width: 28ch;
}
.tour-cta-banner:not(.tour-cta-banner--has-image) .tour-cta-banner__title { color: var(--color-text); }
.tour-cta-banner__lead {
	font-size: var(--fs-body);
	line-height: 1.9;
	max-width: 50ch;
	opacity: 0.9;
}
.tour-cta-banner__button { margin-top: var(--gap-sm); }
