@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Cinzel:wght@500;600&family=Noto+Serif+JP:wght@400;500;700;900&display=swap');

/* =====================================================
   Kiratt Front Page V6 - Premium Whitening Salon Design
   ===================================================== */

:root {
	--kfp-brand: #129BB9;
	--kfp-brand-dark: #0E7A92;
	--kfp-brand-deep: #0B5A6F;
	--kfp-brand-pale: #E7F6FA;
	--kfp-brand-mist: #F0F8FB;

	--kfp-gold-light: #F4E2A8;
	--kfp-gold: #D9B96E;
	--kfp-gold-dark: #A88541;
	--kfp-gold-deep: #6E5223;

	--kfp-ink: #1B2A33;
	--kfp-ink-soft: #4A5F6B;
	--kfp-line: #E5EEF2;

	--kfp-shadow-sm: 0 2px 8px rgba(11,90,111,0.06);
	--kfp-shadow-md: 0 8px 24px rgba(11,90,111,0.10);
	--kfp-shadow-lg: 0 16px 48px rgba(11,90,111,0.16);
}

/* =====================================================
   1. SECTION HEAD (全セクション統一)
   ===================================================== */
.kfp-section__head {
	text-align: center;
	margin: 0 auto 36px;
	padding: 0 16px;
	position: relative;
}
.kfp-section__pre {
	display: inline-block;
	font-family: 'Cinzel', serif;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.32em;
	color: var(--kfp-gold-dark);
	margin: 0 0 14px;
	text-transform: uppercase;
	position: relative;
	padding: 0 32px;
}
.kfp-section__pre::before,
.kfp-section__pre::after {
	content: '';
	position: absolute;
	top: 50%;
	width: 24px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--kfp-gold) 50%, transparent);
}
.kfp-section__pre::before { left: 0; }
.kfp-section__pre::after { right: 0; }

/* 統一h2 - 親テーマの青帯背景を完全打ち消し */
.kfp-section__h2 {
	font-family: 'Noto Serif JP', serif !important;
	font-size: 30px !important;
	font-weight: 700 !important;
	line-height: 1.5 !important;
	color: var(--kfp-brand-deep) !important;
	margin: 0 0 16px !important;
	padding: 0 !important;
	text-align: center !important;
	letter-spacing: 0.04em !important;
	background: none !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	border-bottom: none !important;
	box-shadow: none !important;
	position: static !important;
	display: block !important;
}
.kfp-section__h2::before,
.kfp-section__h2::after {
	display: none !important;
	content: none !important;
}
.kfp-section__h2 > span {
	background: linear-gradient(135deg, var(--kfp-brand) 0%, var(--kfp-brand-deep) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	display: inline-block;
	letter-spacing: 0.04em;
}
.kfp-section__lead {
	font-family: 'Noto Serif JP', serif;
	font-size: 14.5px;
	color: var(--kfp-ink-soft);
	line-height: 1.95;
	margin: 0 auto;
	max-width: 720px;
	letter-spacing: 0.04em;
}

/* レガシーh2の青帯を完全打ち消し */
.about h2.kfp-section__h2,
.voice h2.kfp-section__h2,
.flow h2.kfp-section__h2,
.menu h2.kfp-section__h2,
.access h2.kfp-section__h2,
.instagram h2.kfp-section__h2,
.welcome h2.kfp-section__h2,
.comittment h2.kfp-section__h2,
.crystalwhitening h2.kfp-section__h2,
.counseling h2.kfp-section__h2 {
	background: none !important;
	background-color: transparent !important;
	background-image: none !important;
	color: var(--kfp-brand-deep) !important;
	padding: 0 !important;
	margin: 0 0 16px !important;
	border: none !important;
	box-shadow: none !important;
	border-bottom: none !important;
}

/* ★ 古い1文字目の赤丸装飾を完全消去 ★ */
.about .kfp-section__head .red,
.about .kfp-section__head span.red {
	color: inherit !important;
	background: none !important;
}

/* セクション本体のpタグ調整 */
.kfp-section__body {
	max-width: 860px;
	margin: 0 auto;
	padding: 0 16px;
}
.kfp-section__body p {
	font-family: 'Noto Serif JP', serif;
	font-size: 15px;
	line-height: 2.0;
	color: var(--kfp-ink);
	margin: 0 0 18px;
	letter-spacing: 0.04em;
}
.kfp-section__body .marker3 {
	background: linear-gradient(transparent 60%, rgba(244,226,168,0.6) 60%);
	padding: 0 2px;
	font-weight: 600;
}

/* =====================================================
   2. TRUST BADGES (本物の月桂冠+下切れ防止)
   ===================================================== */
.kfp-trust {
	background: linear-gradient(180deg, var(--kfp-brand-mist) 0%, #FAFCFD 100%);
	padding: 56px 16px 48px;
	margin: 0 0 32px;
	position: relative;
}
.kfp-trust::before,
.kfp-trust::after {
	content: '';
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 80%;
	max-width: 480px;
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--kfp-gold-light) 30%, var(--kfp-gold) 50%, var(--kfp-gold-light) 70%, transparent 100%);
}
.kfp-trust::before { top: 24px; }
.kfp-trust::after { bottom: 20px; }
.kfp-trust__inner {
	max-width: 1080px;
	margin: 0 auto;
	display: flex;
	gap: 28px;
	justify-content: center;
	align-items: stretch;
	padding: 0 8px;
}
.kfp-trust__item {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	min-height: 220px;
	padding: 0 8px;
}
.kfp-trust__cap-en {
	font-family: 'Cinzel', serif;
	font-size: 12.5px;
	letter-spacing: 0.32em;
	font-weight: 600;
	color: var(--kfp-gold-dark);
	margin: 0 0 6px;
	text-transform: uppercase;
	line-height: 1;
}
.kfp-trust__cap-jp {
	font-family: 'Noto Serif JP', serif;
	font-size: 14px;
	font-weight: 600;
	color: var(--kfp-brand-deep);
	margin: 0 0 14px;
	letter-spacing: 0.05em;
	line-height: 1;
}
.kfp-trust__row {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	min-height: 130px;
	padding-bottom: 6px;
	width: 100%;
}
.kfp-trust__laurel {
	width: 60px;
	height: 130px;
	flex-shrink: 0;
	display: block;
}
.kfp-trust__laurel--r { transform: scaleX(-1); }
.kfp-trust__num-wrap {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	min-width: 0;
	padding: 0 4px;
}
.kfp-trust__num-row {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 5px;
	white-space: nowrap;
}
.kfp-trust__num-main {
	font-family: 'Cormorant Garamond', 'Noto Serif JP', serif;
	font-size: 68px;
	font-weight: 700;
	background: linear-gradient(180deg, var(--kfp-gold-light) 0%, var(--kfp-gold) 35%, var(--kfp-gold-dark) 70%, var(--kfp-gold-deep) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	letter-spacing: 0.01em;
	line-height: 0.95;
	position: relative;
	display: inline-block;
}
.kfp-trust__num-main::after {
	content: "※";
	position: absolute;
	top: 8px;
	right: -10px;
	font-size: 11px;
	color: var(--kfp-gold-dark);
	-webkit-text-fill-color: var(--kfp-gold-dark);
	font-family: serif;
	font-weight: 500;
}
.kfp-trust__num-tail {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0;
	padding-left: 6px;
}
.kfp-trust__num-unit {
	font-family: 'Noto Serif JP', serif;
	font-size: 17px;
	font-weight: 700;
	color: var(--kfp-brand-deep);
	letter-spacing: 0.02em;
	line-height: 1.1;
}
.kfp-trust__num-plus {
	font-family: 'Noto Serif JP', serif;
	font-size: 12px;
	font-weight: 500;
	color: #7A5F2E;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-top: 2px;
}
.kfp-trust__num-text {
	font-family: 'Noto Serif JP', serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--kfp-brand-deep);
	line-height: 1.45;
	letter-spacing: 0.06em;
	text-align: center;
	display: block;
}
.kfp-trust__note {
	text-align: center !important;
	font-family: 'Noto Serif JP', serif;
	font-size: 11px;
	color: #999;
	margin: 24px auto 0 !important;
	letter-spacing: 0.05em;
	display: block;
}

/* =====================================================
   3. ANCHOR OFFSET (Deep link compatibility)
   ===================================================== */
.kfp-anchor {
	display: block;
	height: 0;
	visibility: hidden;
	scroll-margin-top: 80px;
}

/* =====================================================
   4. CARD GRID (5/6 cards) + CARDS
   ===================================================== */
.kfp-cardgrid {
	display: grid;
	gap: 18px;
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 16px;
}
.kfp-cardgrid--5 { grid-template-columns: repeat(5, 1fr); }
.kfp-cardgrid--6 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1024px) {
	.kfp-cardgrid--5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
	.kfp-cardgrid--5,
	.kfp-cardgrid--6 { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}

.kfp-card {
	display: block;
	width: 100%;
	background: #fff;
	border: 1px solid var(--kfp-line);
	border-radius: 14px;
	overflow: hidden;
	cursor: pointer;
	position: relative;
	transition: transform 0.32s ease, box-shadow 0.32s ease, border-color 0.32s ease;
	font-family: inherit;
	padding: 0;
	text-align: left;
	box-shadow: var(--kfp-shadow-sm);
	-webkit-tap-highlight-color: transparent;
}
.kfp-card:hover,
.kfp-card:focus-visible {
	transform: translateY(-4px);
	box-shadow: var(--kfp-shadow-md);
	border-color: rgba(217,185,110,0.5);
	outline: none;
}
.kfp-card__img {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	background-size: cover;
	background-position: center;
	background-color: #f5f5f5;
	transition: transform 0.5s ease;
}
.kfp-card:hover .kfp-card__img { transform: scale(1.04); }
.kfp-card__no {
	position: absolute;
	top: 12px;
	left: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 6px;
	font-family: 'Cormorant Garamond', serif;
	font-size: 22px;
	font-weight: 600;
	color: #fff;
	background: linear-gradient(135deg, var(--kfp-gold-dark) 0%, var(--kfp-gold-deep) 100%);
	border-radius: 50%;
	box-shadow: 0 2px 8px rgba(110,82,35,0.3);
	letter-spacing: -0.02em;
}
.kfp-card__body {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 14px 14px 16px;
	min-height: 64px;
}
.kfp-card__ttl {
	font-family: 'Noto Serif JP', serif;
	font-size: 14.5px;
	font-weight: 700;
	color: var(--kfp-ink);
	line-height: 1.5;
	letter-spacing: 0.02em;
	flex: 1;
}
.kfp-card__plus {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--kfp-brand);
	color: #fff;
	font-size: 18px;
	font-weight: 300;
	line-height: 1;
	flex-shrink: 0;
	transition: background 0.3s ease, transform 0.3s ease;
}
.kfp-card:hover .kfp-card__plus { background: var(--kfp-brand-deep); transform: rotate(90deg); }

@media (max-width: 768px) {
	.kfp-card__no { min-width: 30px; height: 30px; font-size: 18px; top: 8px; left: 8px; }
	.kfp-card__body { padding: 10px 10px 12px; min-height: 54px; }
	.kfp-card__ttl { font-size: 12.5px; }
	.kfp-card__plus { width: 22px; height: 22px; font-size: 14px; }
}

/* =====================================================
   5. SECTIONS - REASONS / BENEFITS / ABOUT
   ===================================================== */
.kfp-reasons,
.kfp-benefits {
	padding: 64px 0;
	background: #fff;
}
.kfp-reasons {
	background: linear-gradient(180deg, #fff 0%, var(--kfp-brand-mist) 100%);
}
.kfp-benefits {
	background: linear-gradient(180deg, var(--kfp-brand-mist) 0%, #fff 100%);
}

.about {
	padding: 64px 0;
	background: #fff;
}
.about .kfp-section__body { margin-bottom: 32px; }
.about .btn { text-align: center; margin-top: 32px; }

/* =====================================================
   6. MODAL
   ===================================================== */
body.kfp-modal-open { overflow: hidden; }

.kfp-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
	opacity: 0;
	transition: opacity 0.3s ease;
	pointer-events: none;
}
.kfp-modal:not([hidden]) { pointer-events: auto; }
.kfp-modal.is-open { opacity: 1; }

.kfp-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(11,42,51,0.65);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	cursor: pointer;
}

.kfp-modal__panel {
	position: relative;
	background: #fff;
	border-radius: 18px;
	max-width: 560px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	overflow-x: hidden;
	box-shadow: 0 24px 64px rgba(0,0,0,0.4);
	transform: translateY(20px) scale(0.97);
	transition: transform 0.32s cubic-bezier(0.4,0,0.2,1);
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}
.kfp-modal.is-open .kfp-modal__panel { transform: translateY(0) scale(1); }

.kfp-modal__close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: rgba(255,255,255,0.95);
	border: 1px solid var(--kfp-line);
	color: var(--kfp-ink);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 10;
	transition: background 0.2s, color 0.2s, transform 0.2s;
	box-shadow: 0 2px 8px rgba(0,0,0,0.15);
	padding: 0;
}
.kfp-modal__close svg { width: 16px; height: 16px; display: block; }
.kfp-modal__close:hover {
	background: var(--kfp-brand);
	color: #fff;
	border-color: var(--kfp-brand);
	transform: rotate(90deg);
}

.kfp-modal__img-wrap {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #f5f5f5;
}
.kfp-modal__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.kfp-modal__img-wrap::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(11,42,51,0.4) 100%);
}
.kfp-modal__no {
	position: absolute;
	bottom: 16px;
	left: 16px;
	font-family: 'Cormorant Garamond', serif;
	font-size: 38px;
	font-weight: 600;
	color: var(--kfp-gold-light);
	line-height: 1;
	letter-spacing: -0.02em;
	z-index: 2;
	text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}

.kfp-modal__body {
	padding: 32px 28px 28px;
}
.kfp-modal__head {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	margin-bottom: 22px;
}
.kfp-modal__deco {
	width: 30px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--kfp-gold) 50%, transparent);
	flex-shrink: 0;
}
.kfp-modal__ttl {
	font-family: 'Noto Serif JP', serif !important;
	font-size: 19px !important;
	font-weight: 700 !important;
	color: var(--kfp-brand-deep) !important;
	margin: 0 !important;
	padding: 0 !important;
	text-align: center;
	letter-spacing: 0.04em;
	background: none !important;
	line-height: 1.5 !important;
	border: none !important;
}

/* リッチコンテンツ用 (旧kfp-modal__desc置換) */
.kfp-modal__desc {
	font-family: 'Noto Serif JP', serif;
	color: var(--kfp-ink);
	line-height: 1.95;
	font-size: 14.5px;
	letter-spacing: 0.04em;
	margin: 0 0 24px;
}
.kfp-modal__desc:empty { display: none; margin: 0; }
.kfp-modal__desc > *:first-child { margin-top: 0; }
.kfp-modal__desc > *:last-child { margin-bottom: 0; }
.kfp-modal__desc p { margin: 0 0 14px; }

.kfp-modal__rich {
	font-family: 'Noto Serif JP', serif;
	color: var(--kfp-ink);
	line-height: 1.95;
	font-size: 14.5px;
	letter-spacing: 0.04em;
	margin: 0 0 24px;
}
.kfp-modal__rich:empty { display: none; margin: 0; }
.kfp-modal__rich > *:first-child { margin-top: 0; }
.kfp-modal__rich > *:last-child { margin-bottom: 0; }
.kfp-mc-text {
	font-family: 'Noto Serif JP', serif;
	color: var(--kfp-ink);
	line-height: 1.95;
	font-size: 14.5px;
	margin: 0 0 14px;
	letter-spacing: 0.04em;
}

/* モーダル本文 リッチコンテンツ */
.kfp-mc-lead {
	font-family: 'Noto Serif JP', serif !important;
	font-size: 16px;
	font-weight: 700;
	color: var(--kfp-brand-deep);
	line-height: 1.7;
	margin: 0 0 18px !important;
	padding-bottom: 14px;
	border-bottom: 1px dashed var(--kfp-line);
	letter-spacing: 0.04em;
}
.kfp-mc-em {
	background: linear-gradient(transparent 60%, rgba(244,226,168,0.6) 60%);
	padding: 0 2px;
	font-weight: 700;
	color: var(--kfp-ink);
}
.kfp-mc-list {
	list-style: none;
	padding: 14px 18px;
	margin: 0 0 14px;
	background: var(--kfp-brand-mist);
	border-radius: 10px;
	border-left: 3px solid var(--kfp-brand);
}
.kfp-mc-list li {
	position: relative;
	padding: 4px 0 4px 24px;
	font-size: 14px;
	line-height: 1.7;
	color: var(--kfp-ink);
}
.kfp-mc-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 12px;
	width: 14px;
	height: 14px;
	background: var(--kfp-brand);
	border-radius: 50%;
}
.kfp-mc-list li::after {
	content: '';
	position: absolute;
	left: 4px;
	top: 16px;
	width: 6px;
	height: 3px;
	border-left: 2px solid #fff;
	border-bottom: 2px solid #fff;
	transform: rotate(-45deg);
}

.kfp-modal__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--kfp-brand) 0%, var(--kfp-brand-deep) 100%);
	color: #fff !important;
	border-radius: 50px;
	text-decoration: none;
	font-family: 'Noto Serif JP', serif;
	font-size: 14.5px;
	font-weight: 700;
	letter-spacing: 0.05em;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	box-shadow: 0 4px 14px rgba(18,155,185,0.3);
}
.kfp-modal__cta::after {
	content: '→';
	font-size: 16px;
	transition: transform 0.3s ease;
}
.kfp-modal__cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 22px rgba(18,155,185,0.4);
}
.kfp-modal__cta:hover::after { transform: translateX(3px); }

@media (max-width: 768px) {
	.kfp-modal { padding: 12px; }
	.kfp-modal__panel { max-height: 92vh; border-radius: 14px; }
	.kfp-modal__body { padding: 24px 18px 22px; }
	.kfp-modal__ttl { font-size: 17px !important; }
	.kfp-modal__no { font-size: 30px; bottom: 12px; left: 12px; }
	.kfp-modal__desc { font-size: 14px; }
	.kfp-mc-lead { font-size: 15px; }
	.kfp-mc-list { padding: 12px 14px; }
	.kfp-mc-list li { font-size: 13px; padding-left: 22px; }
}

/* =====================================================
   7. PROMISE (3つの安心制度)
   ===================================================== */
.kfp-promise {
	padding: 64px 16px;
	background: linear-gradient(180deg, #fff 0%, var(--kfp-brand-mist) 100%);
}
.kfp-promise__grid {
	max-width: 1080px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
}
.kfp-promise__card {
	background: #fff;
	border-radius: 16px;
	padding: 32px 24px 28px;
	position: relative;
	border: 1px solid var(--kfp-line);
	box-shadow: var(--kfp-shadow-sm);
	transition: transform 0.32s ease, box-shadow 0.32s ease;
	text-align: center;
}
.kfp-promise__card:hover {
	transform: translateY(-4px);
	box-shadow: var(--kfp-shadow-md);
}
.kfp-promise__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--kfp-gold) 0%, var(--kfp-gold-dark) 100%);
	margin-bottom: 16px;
	box-shadow: 0 4px 12px rgba(168,133,65,0.25);
}
.kfp-promise__badge span {
	font-family: 'Cormorant Garamond', serif;
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	letter-spacing: -0.02em;
}
.kfp-promise__ttl {
	font-family: 'Noto Serif JP', serif;
	font-size: 17px;
	font-weight: 700;
	color: var(--kfp-brand-deep);
	margin: 0 0 6px;
	letter-spacing: 0.04em;
}
.kfp-promise__pitch {
	font-family: 'Noto Serif JP', serif;
	font-size: 13px;
	color: var(--kfp-gold-dark);
	font-weight: 600;
	margin: 0 0 14px;
	letter-spacing: 0.05em;
}
.kfp-promise__desc {
	font-family: 'Noto Serif JP', serif;
	font-size: 13.5px;
	line-height: 1.85;
	color: var(--kfp-ink-soft);
	margin: 0;
	letter-spacing: 0.03em;
	text-align: left;
}
@media (max-width: 768px) {
	.kfp-promise__grid { grid-template-columns: 1fr; gap: 14px; }
	.kfp-promise { padding: 48px 16px; }
}

/* =====================================================
   8. CTA BANNER
   ===================================================== */
.kfp-cta-banner {
	margin: 56px 0;
	padding: 0 16px;
}
.kfp-cta-banner__inner {
	max-width: 980px;
	margin: 0 auto;
	background: linear-gradient(135deg, var(--kfp-brand) 0%, var(--kfp-brand-deep) 100%);
	border-radius: 22px;
	padding: 56px 32px;
	text-align: center;
	color: #fff;
	position: relative;
	overflow: hidden;
	box-shadow: var(--kfp-shadow-lg);
}
.kfp-cta-banner__inner::before {
	content: '';
	position: absolute;
	inset: -20% -10%;
	background: radial-gradient(circle at 80% 0%, rgba(244,226,168,0.18), transparent 50%);
	pointer-events: none;
}
.kfp-cta-banner__pre {
	font-family: 'Cinzel', serif;
	font-size: 13px;
	letter-spacing: 0.32em;
	color: var(--kfp-gold-light);
	margin: 0 0 14px;
	font-weight: 600;
	position: relative;
}
.kfp-cta-banner__h2 {
	font-family: 'Noto Serif JP', serif !important;
	font-size: 28px !important;
	font-weight: 700 !important;
	line-height: 1.5 !important;
	color: #fff !important;
	margin: 0 0 18px !important;
	padding: 0 !important;
	background: none !important;
	letter-spacing: 0.04em !important;
	border: none !important;
	position: relative;
}

/* CTAバナー内の section__head は白文字で上書き */
.kfp-cta-banner .kfp-section__h2,
.kfp-cta-banner .kfp-section__h2 * {
	color: #fff !important;
	background: none !important;
	-webkit-text-fill-color: #fff !important;
}
.kfp-cta-banner .kfp-section__h2 > span {
	background: linear-gradient(135deg, var(--kfp-gold-light) 0%, var(--kfp-gold) 100%) !important;
	-webkit-background-clip: text !important;
	background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	color: transparent !important;
	display: inline-block;
}
.kfp-cta-banner .kfp-section__pre {
	color: var(--kfp-gold-light) !important;
}
.kfp-cta-banner .kfp-section__pre::before,
.kfp-cta-banner .kfp-section__pre::after {
	background: linear-gradient(90deg, transparent, var(--kfp-gold-light) 50%, transparent) !important;
}
.kfp-cta-banner .kfp-section__lead {
	color: rgba(255,255,255,0.92) !important;
}
.kfp-cta-banner__h2 > span {
	background: linear-gradient(135deg, var(--kfp-gold-light) 0%, var(--kfp-gold) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	display: inline-block;
}
.kfp-cta-banner__lead {
	font-family: 'Noto Serif JP', serif;
	font-size: 14.5px;
	line-height: 1.95;
	margin: 0 auto 28px;
	max-width: 620px;
	letter-spacing: 0.04em;
	position: relative;
	color: rgba(255,255,255,0.92);
}
.kfp-cta-banner__btns {
	display: flex;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
	position: relative;
}
.kfp-cta-banner__btn {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 16px 28px;
	border-radius: 50px;
	text-decoration: none;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	font-size: 14.5px;
	transition: transform 0.32s ease, box-shadow 0.32s ease;
	min-width: 240px;
	letter-spacing: 0.05em;
	box-shadow: 0 4px 16px rgba(0,0,0,0.18);
}
.kfp-cta-banner__btn--primary {
	background: linear-gradient(135deg, var(--kfp-gold-light) 0%, var(--kfp-gold) 50%, var(--kfp-gold-dark) 100%);
	color: var(--kfp-brand-deep) !important;
}
.kfp-cta-banner__btn--secondary {
	background: rgba(255,255,255,0.12);
	color: #fff !important;
	border: 1.5px solid rgba(255,255,255,0.6);
	backdrop-filter: blur(8px);
}
.kfp-cta-banner__btn:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 24px rgba(0,0,0,0.25);
}
.kfp-cta-banner__btn-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.25);
	flex-shrink: 0;
}
.kfp-cta-banner__btn--primary .kfp-cta-banner__btn-icon { background: rgba(11,90,111,0.15); }
.kfp-cta-banner__btn-icon svg { width: 18px; height: 18px; }
.kfp-cta-banner__btn-txt { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.3; }
.kfp-cta-banner__btn-main { font-size: 15px; font-weight: 700; }
.kfp-cta-banner__btn-sub { font-size: 11px; opacity: 0.78; letter-spacing: 0.08em; margin-top: 1px; }
@media (max-width: 768px) {
	.kfp-cta-banner__inner { padding: 42px 22px; border-radius: 16px; }
	.kfp-cta-banner__h2 { font-size: 22px !important; }
	.kfp-cta-banner__btn { width: 100%; min-width: 0; padding: 14px 20px; }
}

/* =====================================================
   9. FAQ
   ===================================================== */
.kfp-faq {
	padding: 64px 16px;
	background: #fff;
}
.kfp-faq__list {
	max-width: 880px;
	margin: 0 auto 36px;
	border-top: 1px solid var(--kfp-line);
}
.kfp-faq__item {
	border-bottom: 1px solid var(--kfp-line);
	background: #fff;
	transition: background 0.3s ease;
}
.kfp-faq__item[open] { background: var(--kfp-brand-mist); }
.kfp-faq__q {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 22px 18px;
	cursor: pointer;
	list-style: none;
	transition: color 0.3s ease;
}
.kfp-faq__q::-webkit-details-marker { display: none; }
.kfp-faq__q-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--kfp-brand) 0%, var(--kfp-brand-deep) 100%);
	color: #fff;
	font-family: 'Cormorant Garamond', serif;
	font-size: 18px;
	font-weight: 700;
	flex-shrink: 0;
	box-shadow: 0 2px 6px rgba(18,155,185,0.3);
}
.kfp-faq__q-txt {
	flex: 1;
	font-family: 'Noto Serif JP', serif;
	font-size: 15px;
	font-weight: 700;
	color: var(--kfp-ink);
	line-height: 1.65;
	letter-spacing: 0.03em;
	padding-top: 4px;
}
.kfp-faq__q-arrow {
	position: relative;
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	margin-top: 6px;
}
.kfp-faq__q-arrow::before,
.kfp-faq__q-arrow::after {
	content: '';
	position: absolute;
	background: var(--kfp-brand);
	transition: transform 0.32s ease;
}
.kfp-faq__q-arrow::before {
	width: 14px;
	height: 2px;
	left: 3px;
	top: 9px;
}
.kfp-faq__q-arrow::after {
	width: 2px;
	height: 14px;
	left: 9px;
	top: 3px;
}
.kfp-faq__item[open] .kfp-faq__q-arrow::after { transform: scaleY(0); }
.kfp-faq__a {
	display: flex;
	gap: 14px;
	padding: 0 18px 24px;
	animation: kfpFadeUp 0.32s ease;
}
.kfp-faq__a-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--kfp-gold) 0%, var(--kfp-gold-dark) 100%);
	color: #fff;
	font-family: 'Cormorant Garamond', serif;
	font-size: 18px;
	font-weight: 700;
	flex-shrink: 0;
	box-shadow: 0 2px 6px rgba(168,133,65,0.3);
}
.kfp-faq__a-txt {
	flex: 1;
	font-family: 'Noto Serif JP', serif;
}
.kfp-faq__a-headline {
	font-size: 14.5px;
	font-weight: 700;
	color: var(--kfp-brand-deep);
	margin: 4px 0 10px;
	letter-spacing: 0.03em;
	line-height: 1.7;
}
.kfp-faq__a-txt p:not(.kfp-faq__a-headline) {
	font-size: 13.5px;
	color: var(--kfp-ink-soft);
	line-height: 1.95;
	margin: 0;
	letter-spacing: 0.03em;
}
.kfp-faq .btn { text-align: center; }
@keyframes kfpFadeUp {
	from { opacity: 0; transform: translateY(-6px); }
	to   { opacity: 1; transform: translateY(0); }
}
@media (max-width: 768px) {
	.kfp-faq { padding: 48px 12px; }
	.kfp-faq__q { padding: 18px 12px; gap: 10px; }
	.kfp-faq__a { padding: 0 12px 20px; gap: 10px; }
	.kfp-faq__q-txt { font-size: 14px; }
}

/* =====================================================
   10. MENU - 人気No.1 タグ追加
   ===================================================== */
.kfp-menu .course .box.popular,
.menu .course .box.popular {
	position: relative;
	border: 2px solid var(--kfp-gold);
	box-shadow: 0 4px 16px rgba(217,185,110,0.25);
}
.kfp-menu .course .popular-tag,
.menu .course .popular-tag {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: linear-gradient(135deg, var(--kfp-gold) 0%, var(--kfp-gold-dark) 100%);
	color: #fff;
	font-family: 'Noto Serif JP', serif;
	font-size: 12px;
	font-weight: 700;
	padding: 4px 16px;
	border-radius: 50px;
	letter-spacing: 0.08em;
	white-space: nowrap;
	box-shadow: 0 2px 8px rgba(168,133,65,0.3);
	z-index: 2;
}

/* =====================================================
   11. SECTION SPACING & LEGACY OVERRIDES
   ===================================================== */
section.about,
section.voice,
section.flow,
section.menu,
section.access,
section.instagram,
section.kfp-promise,
section.kfp-faq {
	margin-top: 0;
	margin-bottom: 0;
}
section.voice,
section.flow,
section.menu,
section.access,
section.instagram { padding: 64px 0; }

/* レガシーh2の青帯背景・装飾を完全打ち消し（バックアップ） */
.about > h2:not(.kfp-section__h2),
.voice > h2:not(.kfp-section__h2),
.flow > h2:not(.kfp-section__h2),
.menu > h2:not(.kfp-section__h2),
.access > h2:not(.kfp-section__h2),
.instagram > h2:not(.kfp-section__h2) { display: none !important; }

/* =====================================================
   12. RESPONSIVE BREAKPOINT (Mobile)
   ===================================================== */
@media (max-width: 768px) {
	.kfp-trust { padding: 36px 8px 32px; }
	.kfp-trust__inner { gap: 4px; padding: 0; }
	.kfp-trust__item { min-height: 170px; padding: 0 2px; }
	.kfp-trust__cap-en { font-size: 9.5px; letter-spacing: 0.18em; margin-bottom: 4px; }
	.kfp-trust__cap-jp { font-size: 10.5px; margin-bottom: 8px; }
	.kfp-trust__row { min-height: 96px; gap: 0; padding-bottom: 4px; }
	.kfp-trust__laurel { width: 38px; height: 90px; }
	.kfp-trust__num-wrap { padding: 0; }
	.kfp-trust__num-main { font-size: 40px; }
	.kfp-trust__num-main::after { font-size: 8px; right: -7px; top: 4px; }
	.kfp-trust__num-tail { padding-left: 3px; }
	.kfp-trust__num-unit { font-size: 11px; }
	.kfp-trust__num-plus { font-size: 9px; }
	.kfp-trust__num-text { font-size: 14px; }
	.kfp-trust__note { font-size: 9.5px; margin-top: 14px; }

	.kfp-section__head { margin-bottom: 28px; padding: 0 12px; }
	.kfp-section__pre { font-size: 11px; letter-spacing: 0.26em; padding: 0 24px; }
	.kfp-section__pre::before, .kfp-section__pre::after { width: 16px; }
	.kfp-section__h2 { font-size: 22px !important; }
	.kfp-section__lead { font-size: 13px; line-height: 1.85; }

	.kfp-section__body p { font-size: 14px; line-height: 1.95; }

	.kfp-reasons,
	.kfp-benefits,
	.about,
	section.voice,
	section.flow,
	section.menu,
	section.access,
	section.instagram { padding: 48px 0; }
}