/* ==========================================================================
   トップページ固有スタイル
   front-page.php でのみ読み込まれる
   セクションごとにブロックで管理する
   ========================================================================== */

/* ==========================================================================
   FV（ファーストビュー）
   ========================================================================== */

.p-hero {
	padding-block: var(--space-xl);
	background-color: var(--color-bg);
	text-align: center;
}

.p-hero__sub {
	font-size: clamp(1rem, 2vw, 1.25rem);
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.6;
	margin-bottom: var(--space-sm);
}

.p-hero__title {
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-text);
	margin-bottom: var(--space-md);
}

.p-hero__desc {
	font-size: 1rem;
	color: var(--color-text-sub);
	line-height: 1.8;
	margin-bottom: var(--space-lg);
}

.p-hero__btn {
	display: inline-block;
}

/* ==========================================================================
   悩み訴求セクション
   ========================================================================== */

/* 見出し */
.p-pain__heading {
	text-align: center;
	font-size: clamp(1.125rem, 2.5vw, 1.5rem);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1em;
}

.p-pain__heading::before,
.p-pain__heading::after {
	content: "";
	flex: 1;
	max-width: 80px;
	height: 2px;
	background-color: var(--color-accent);
}

/* リード文 */
.p-pain__lead {
	text-align: center;
	font-size: 1rem;
	color: var(--color-text-sub);
	line-height: 1.8;
	margin-bottom: var(--space-lg);
}

/* カードグリッド */
.p-pain__list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-lg);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-sm);
}

@media (max-width: 680px) {
	.p-pain__list {
		grid-template-columns: 1fr 1fr;
	}
}

.p-pain__item {
	background-color: var(--color-bg);
	border-radius: 8px;
	padding: var(--space-sm) var(--space-md);
	font-size: 0.9375rem;
	color: var(--color-text);
	line-height: 1.6;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* 結論ライン */
.p-pain__note {
	text-align: center;
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--color-text);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1em;
}

.p-pain__note::before,
.p-pain__note::after {
	content: "";
	flex: 1;
	max-width: 60px;
	height: 2px;
	background-color: var(--color-primary);
}

/* ==========================================================================
   CTAセクション
   ========================================================================== */

.p-cta {
	background-color: #FEF5C8;
	padding-block: var(--space-xl);
	border-top: 6px solid var(--color-primary);
}

.p-cta__inner {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-sm);
}

.p-cta__label {
	font-size: 0.875rem;
	color: var(--color-primary);
	font-weight: 700;
	letter-spacing: 0.05em;
}

.p-cta__title {
	font-size: clamp(1.125rem, 2.5vw, 1.625rem);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.6;
}

.p-cta__desc {
	font-size: 0.9375rem;
	color: var(--color-text-sub);
	line-height: 1.8;
	margin-bottom: var(--space-xs);
}

/* CTAセクション用ボタン */
.c-btn--white {
	background-color: var(--color-primary);
	color: #fff;
	border: none;
	font-weight: 700;
	box-shadow: 0 4px 16px rgba(58, 125, 28, 0.3);
	letter-spacing: 0.03em;
	padding: 1em 3em;
}

.c-btn--white:hover {
	background-color: #2D6B1A;
	opacity: 1;
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(58, 125, 28, 0.4);
}

/* ==========================================================================
   制作の流れセクション
   ========================================================================== */

.p-flow__list {
	list-style: none;
	padding: 0;
	margin: 0;
	max-width: 640px;
	margin-inline: auto;
}

.p-flow__item {
	display: flex;
	gap: var(--space-md);
}

.p-flow__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	flex-shrink: 0;
}

.p-flow__num {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: var(--color-primary);
	color: #fff;
	font-weight: 700;
	font-size: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.p-flow__line {
	width: 2px;
	flex: 1;
	background-color: var(--color-border);
	margin-block: var(--space-xs);
	min-height: 2rem;
}

.p-flow__body {
	padding-bottom: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.p-flow__item:last-child .p-flow__body {
	padding-bottom: 0;
}

.p-flow__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-text);
	padding-top: 0.5em; /* 番号の丸と高さを揃える */
}

.p-flow__desc {
	font-size: 0.9375rem;
	color: var(--color-text-sub);
	line-height: 1.8;
}

/* ==========================================================================
   選ばれる理由セクション
   ========================================================================== */

.p-reasons__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
	list-style: none;
	padding: 0;
	margin: 0;
}

/* 下段2枚を中央寄せ */
.p-reasons__item:nth-child(4) { grid-column: 1 / 2; }
.p-reasons__item:nth-child(5) { grid-column: 2 / 3; }

@media (max-width: 680px) {
	.p-reasons__list {
		grid-template-columns: 1fr;
	}
	.p-reasons__item:nth-child(n) {
		grid-column: auto;
	}
}

.p-reasons__item {
	background-color: var(--color-bg);
	border-radius: 8px;
	padding: var(--space-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.p-reasons__num {
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-primary);
	opacity: 0.25;
	line-height: 1;
}

.p-reasons__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-text);
}

.p-reasons__desc {
	font-size: 0.9375rem;
	color: var(--color-text-sub);
	line-height: 1.8;
}

/* ==========================================================================
   実績紹介セクション
   ========================================================================== */

.p-works__list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--space-md);
	list-style: none;
	padding: 0;
	margin: 0;
}

.p-works__item {
	border-left: 3px solid var(--color-primary);
	padding: var(--space-sm) var(--space-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.p-works__category {
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: 0.05em;
}

.p-works__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-text);
}

.p-works__desc {
	font-size: 0.9375rem;
	color: var(--color-text-sub);
	line-height: 1.8;
}

.p-works__result {
	font-size: 0.9375rem;
	color: var(--color-text);
	line-height: 1.8;
	font-weight: 500;
}

/* ==========================================================================
   サービス紹介セクション
   ========================================================================== */

.p-products__heading {
	text-align: center;
	font-size: clamp(1.125rem, 2.5vw, 1.5rem);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1em;
}

.p-products__heading::before,
.p-products__heading::after {
	content: "";
	flex: 1;
	height: 2px;
	background-color: var(--color-accent);
}

.p-products__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
	list-style: none;
	padding: 0;
	margin: 0;
	align-items: start;
}

@media (max-width: 680px) {
	.p-products__list {
		grid-template-columns: 1fr;
	}
}

.p-products__item {
	background-color: var(--color-bg);
	border-radius: 8px;
	padding: var(--space-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	border: 1px solid var(--color-border);
}

.p-products__item--main {
	border-color: var(--color-primary);
	box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}

/* ラベル（丸バッジ）*/
.p-products__label {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-text-sub);
	background-color: var(--color-bg-light);
	border-radius: 2em;
	padding: 0.2em 0.8em;
	width: fit-content;
}

.p-products__label--main {
	color: var(--color-primary);
	background-color: color-mix(in srgb, var(--color-primary) 10%, white);
}

.p-products__title {
	font-size: 1.0625rem;
	font-weight: 700;
	color: var(--color-text);
}

.p-products__desc {
	font-size: 0.9375rem;
	color: var(--color-text-sub);
	line-height: 1.8;
	flex: 1;
}

/* 効果エリア */
.p-products__metrics {
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-sm);
}

.p-products__metrics-label {
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-text-sub);
	margin-bottom: 0.25em;
}

.p-products__metrics ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.25em;
}

.p-products__metrics li {
	font-size: 0.875rem;
	color: var(--color-primary);
	font-weight: 700;
}

.p-products__btn {
	width: 100%;
	text-align: center;
}

/* アウトラインボタン */
.c-btn--outline {
	background-color: transparent;
	color: var(--color-primary);
	border: 2px solid var(--color-primary);
}

.c-btn--outline:hover {
	background-color: var(--color-primary);
	color: #fff;
	opacity: 1;
}

/* ==========================================================================
   できることセクション
   ========================================================================== */

.p-service__heading {
	text-align: center;
	font-size: clamp(1.125rem, 2.5vw, 1.5rem);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1em;
}

.p-service__heading::before,
.p-service__heading::after {
	content: "";
	flex: 1;
	max-width: 80px;
	height: 2px;
	background-color: var(--color-accent);
}

.p-service__lead {
	text-align: center;
	font-size: 1rem;
	color: var(--color-text-sub);
	line-height: 1.8;
	margin-bottom: var(--space-lg);
}

.p-service__list {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: var(--space-md);
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-lg);
}

/* 上段：3つ均等 */
.p-service__item:nth-child(1) { grid-column: 1 / 3; }
.p-service__item:nth-child(2) { grid-column: 3 / 5; }
.p-service__item:nth-child(3) { grid-column: 5 / 7; }

/* 下段：2つ中央寄せ */
.p-service__item:nth-child(4) { grid-column: 2 / 4; }
.p-service__item:nth-child(5) { grid-column: 4 / 6; }

@media (max-width: 680px) {
	.p-service__list {
		grid-template-columns: repeat(2, 1fr);
	}
	.p-service__item:nth-child(n) {
		grid-column: auto;
	}
}

@media (max-width: 480px) {
	.p-service__list {
		grid-template-columns: 1fr;
	}
}

.p-service__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-xs);
	background-color: var(--color-bg-light);
	border-radius: 8px;
	padding: var(--space-md);
}

.p-service__icon {
	width: 48px;
	height: 48px;
	color: var(--color-primary);
}

.p-service__icon svg {
	width: 100%;
	height: 100%;
}

.p-service__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-text);
}

.p-service__desc {
	font-size: 0.875rem;
	color: var(--color-text-sub);
	line-height: 1.6;
}

.p-service__metrics {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.25em;
}

.p-service__metrics li {
	font-size: 0.8125rem;
	color: var(--color-primary);
	font-weight: 700;
}


/* ==========================================================================
   セクションタイトル共通（components.css に移すかも）
   ========================================================================== */

.c-section-title {
	text-align: center;
	font-size: clamp(1.25rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-lg);
}

/* --- CTAボタン共通（components.css に移すかも） --- */
.c-btn {
	display: inline-block;
	background-color: var(--color-primary);
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	padding: 1em 2.5em;
	border-radius: 4px;
	text-decoration: none;
	transition: all 0.2s;
}

.c-btn:hover {
	opacity: 0.85;
	color: #fff;
	transform: translateY(-1px);
}
