/*
 * front-page.css — 岡本工務店 LP のレイアウト。
 * page-composition.md のレイアウト型（editorial / zigzag / grid+break-box / asym split）を実装。
 * 装飾の細部・色味のクラフトは段階2で。段階1は構造・レスポンシブ・最小スタイル。
 * sections.css の雛形スタイルが当たる部分は、ここで必要箇所のみ上書きする。
 */

/* ============================================================
   共通: section-head の作法
   eyebrow（小ラベル）→ 短いアクセント罫 → 大見出し の3点セットを全セクションで揃える。
   これがクラフト統一の核。
   ============================================================ */
.section__eyebrow {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 700;
	color: var(--wp--preset--color--accent);
	letter-spacing: 0.22em;
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--xs);
	display: inline-flex;
	align-items: center;
	gap: var(--wp--preset--spacing--xs);
}

/* eyebrow の前に短い横罫を付ける（共通の作法） */
.section__eyebrow::before {
	content: "";
	display: inline-block;
	width: 32px;
	height: 1px;
	background: var(--wp--preset--color--accent);
}

.section__head {
	margin-bottom: var(--wp--preset--spacing--lg);
}

.section__head--left {
	text-align: left;
}

.section__head--center {
	text-align: center;
}

/* center の場合は eyebrow の罫を左右両側に */
.section__head--center .section__eyebrow {
	justify-content: center;
}
.section__head--center .section__eyebrow::after {
	content: "";
	display: inline-block;
	width: 32px;
	height: 1px;
	background: var(--wp--preset--color--accent);
}

/* section__title 共通: 明朝大見出し */
.section__title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: var(--wp--preset--font-size--xxl);
	font-weight: 700;
	color: var(--wp--preset--color--brand);
	line-height: 1.4;
	letter-spacing: 0.02em;
	margin: 0;
}

.section__lead {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--base);
	color: var(--wp--preset--color--ink-soft);
	line-height: 1.9;
	margin-top: var(--wp--preset--spacing--sm);
	max-width: 36em;
}

/* ============================================================
   ① hero-fullbg — eyebrow と長文タイトルの差分のみ
   sections.css の hero-fullbg を活かしつつ調整。
   ============================================================ */
.hero-fullbg__eyebrow {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--accent);
	letter-spacing: 0.16em;
	margin-bottom: var(--wp--preset--spacing--sm);
}

/* ============================================================
   ② value — editorial（番号特大・縦に積む・非対称）
   sections.css の value（中央寄せ3カラム）を上書き。
   ============================================================ */
.value {
	padding-block: var(--wp--preset--spacing--xxl);
	background: var(--wp--preset--color--base);
}

.value__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xl);
	grid-template-columns: none;
}

@media (min-width: 768px) {
	.value__list {
		grid-template-columns: none;
	}
}

.value__item {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--sm);
	text-align: left;
	background: transparent;
	padding: 0;
	box-shadow: none;
	border-radius: 0;
}

@media (min-width: 768px) {
	.value__item {
		grid-template-columns: minmax(120px, 1fr) 3fr;
		gap: var(--wp--preset--spacing--lg);
		align-items: start;
	}
	/* 偶数項目は番号を右側に寄せ、非対称リズムを作る */
	.value__item:nth-child(even) {
		grid-template-columns: 3fr minmax(120px, 1fr);
	}
	.value__item:nth-child(even) .value__num {
		order: 2;
		text-align: right;
	}
	.value__item:nth-child(even) .value__body {
		order: 1;
	}
}

.value__num {
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(4.5rem, 11vw, 8.5rem);
	font-weight: 500;
	line-height: 1;
	color: var(--wp--preset--color--accent);
	letter-spacing: -0.02em;
	display: block;
	opacity: 0.9;
}

.value__body {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
}

.value__eyebrow {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--accent);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin: 0;
}

.value__title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: var(--wp--preset--font-size--xl);
	color: var(--wp--preset--color--brand);
	line-height: 1.5;
	margin: 0;
}

.value__text {
	font-size: var(--wp--preset--font-size--base);
	color: var(--wp--preset--color--ink);
	line-height: 1.9;
	margin: 0;
}

/* ============================================================
   ③ features — zigzag（画像↔テキスト左右交互）
   sections.css の features（3カラム grid）を上書き。
   ============================================================ */
.features {
	padding-block: var(--wp--preset--spacing--xxl);
	background: var(--wp--preset--color--base-2);
}

.features__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xl);
	grid-template-columns: none;
}

@media (min-width: 768px) {
	.features__list {
		grid-template-columns: none;
	}
}

.features__item {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--md);
	background: transparent;
	box-shadow: none;
	border-radius: 0;
	overflow: visible;
}

@media (min-width: 768px) {
	.features__item {
		grid-template-columns: 1fr 1fr;
		gap: var(--wp--preset--spacing--lg);
		align-items: center;
	}
	/* zigzag: 偶数項目はテキストを左、画像を右に */
	.features__item:nth-child(even) .features__img-wrap {
		order: 2;
	}
	.features__item:nth-child(even) .features__body {
		order: 1;
	}
}

.features__img-wrap {
	aspect-ratio: 3 / 2;
	overflow: hidden;
}

.features__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.features__body {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
	padding: 0;
}

.features__tag {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--accent);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin: 0;
}

.features__title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: var(--wp--preset--font-size--xxl);
	color: var(--wp--preset--color--brand);
	margin: 0;
	line-height: 1.4;
}

.features__text {
	font-size: var(--wp--preset--font-size--base);
	color: var(--wp--preset--color--ink);
	line-height: 1.9;
	margin: 0;
}

.features__targets {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--xs);
}

.features__target {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--ink);
	background: var(--wp--preset--color--base);
	padding: 4px 12px;
	border-radius: 999px;
	border: 1px solid var(--wp--preset--color--line);
}

/* ============================================================
   ④ works — grid + break-box（1枚目は見せ場）
   完全新規。雛形なし。
   ============================================================ */
.works {
	padding-block: var(--wp--preset--spacing--xxl);
	background: var(--wp--preset--color--base);
	overflow: hidden; /* break-boxのはみ出しを横スクロール無しでクリップ */
}

.works__inner {
	max-width: var(--wp--style--global--wide-size, 1200px);
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--md);
}

/* 1枚目: 見せ場（box を破る） */
.works__featured {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--md);
	margin-bottom: var(--wp--preset--spacing--xl);
}

.works__featured-media {
	aspect-ratio: 16 / 11;
	overflow: hidden;
}

.works__featured-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.works__featured-body {
	background: var(--wp--preset--color--base);
	padding: var(--wp--preset--spacing--md) 0 0;
}

@media (min-width: 768px) {
	.works__featured {
		grid-template-columns: 8fr 5fr;
		gap: 0;
		align-items: end;
		margin-bottom: var(--wp--preset--spacing--xxl);
	}
	.works__featured-media {
		grid-column: 1 / 2;
		grid-row: 1 / 2;
		aspect-ratio: 16 / 10;
		/* 大胆にはみ出す（box破り見せ場）。inner=1200pxからはみ出す分は overflow:hidden で吸収 */
		margin-right: calc(-1 * var(--wp--preset--spacing--xxl) * 1.5);
		margin-left: calc(-1 * var(--wp--preset--spacing--xl));
		box-shadow: 0 20px 60px rgb(46 38 32 / .12);
	}
	.works__featured-body {
		grid-column: 2 / 3;
		grid-row: 1 / 2;
		background: var(--wp--preset--color--base);
		padding: var(--wp--preset--spacing--xl) var(--wp--preset--spacing--lg) var(--wp--preset--spacing--lg);
		/* 画像にカードがしっかり食い込む */
		margin-left: calc(-1 * var(--wp--preset--spacing--xxl));
		margin-bottom: calc(-1 * var(--wp--preset--spacing--xl));
		position: relative;
		z-index: 1;
		border-left: 3px solid var(--wp--preset--color--accent);
	}
}

.works__featured-category {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 700;
	color: var(--wp--preset--color--accent);
	letter-spacing: 0.22em;
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--sm);
}

.works__featured-title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(1.5rem, 2.4vw, 2rem);
	color: var(--wp--preset--color--brand);
	line-height: 1.5;
	letter-spacing: 0.02em;
	margin: 0 0 var(--wp--preset--spacing--sm);
}

.works__featured-area {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--ink-soft);
	margin: 0;
}

/* 2件目以降: 通常 grid */
.works__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--md);
}

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

@media (min-width: 1025px) {
	.works__list {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--wp--preset--spacing--lg);
	}
}

.works__item {
	display: block;
}

.works__figure {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--sm);
}

.works__img {
	width: 100%;
	height: auto;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
}

.works__caption {
	padding: 0;
}

.works__category {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--accent);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--xs);
}

.works__title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: var(--wp--preset--font-size--lg);
	color: var(--wp--preset--color--brand);
	line-height: 1.5;
	margin: 0 0 var(--wp--preset--spacing--xs);
}

.works__area {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--ink-soft);
	margin: 0;
}

/* ============================================================
   ⑤ flow — editorial（base-2背景・全幅・縦に積む）
   sections.css の flow（4カラム grid）を上書き。
   ============================================================ */
.flow {
	padding-block: var(--wp--preset--spacing--xxl);
	background: var(--wp--preset--color--base-2);
}

.flow__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--lg);
	grid-template-columns: none;
}

@media (min-width: 768px) {
	.flow__list {
		grid-template-columns: none;
		gap: var(--wp--preset--spacing--lg);
	}
}

@media (min-width: 1025px) {
	.flow__list {
		grid-template-columns: none;
	}
}

.flow__item {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--sm);
	background: transparent;
	box-shadow: none;
	border-radius: 0;
	padding: 0;
	position: relative;
}

@media (min-width: 768px) {
	.flow__item {
		grid-template-columns: minmax(120px, 160px) 1fr;
		gap: var(--wp--preset--spacing--xl);
		align-items: start;
		padding-bottom: var(--wp--preset--spacing--lg);
		border-bottom: 0;
	}
	/* 番号同士を縦線で繋ぐ（流れの視覚化） */
	.flow__item:not(:last-child)::before {
		content: "";
		position: absolute;
		left: clamp(60px, 7vw, 78px);
		top: 4.5rem;
		bottom: 0;
		width: 1px;
		background: linear-gradient(to bottom, var(--wp--preset--color--accent), var(--wp--preset--color--line));
		opacity: 0.5;
	}
}

.flow__num {
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 500;
	font-size: clamp(3rem, 7vw, 5.5rem);
	line-height: 1;
	color: var(--wp--preset--color--accent);
	position: static;
	letter-spacing: -0.02em;
	display: block;
}

.flow__body {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
}

.flow__title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: var(--wp--preset--font-size--xl);
	color: var(--wp--preset--color--brand);
	margin: 0;
}

.flow__text {
	font-size: var(--wp--preset--font-size--base);
	color: var(--wp--preset--color--ink);
	line-height: 1.9;
	margin: 0;
}

/* ============================================================
   ⑥ testimonials — asymmetric split（写真と引用を 4:6 非対称・左右交互）
   完全新規。
   ============================================================ */
.testimonials {
	padding-block: var(--wp--preset--spacing--xxl);
	background: var(--wp--preset--color--base);
}

.testimonials__inner {
	max-width: var(--wp--style--global--wide-size, 1200px);
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--md);
}

.testimonials__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xl);
}

.testimonials__item {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--md);
}

@media (min-width: 768px) {
	.testimonials__item {
		grid-template-columns: 4fr 6fr;
		gap: var(--wp--preset--spacing--lg);
		align-items: center;
	}
	/* 偶数項目は写真を右、引用を左に */
	.testimonials__item:nth-child(even) {
		grid-template-columns: 6fr 4fr;
	}
	.testimonials__item:nth-child(even) .testimonials__media {
		order: 2;
	}
	.testimonials__item:nth-child(even) .testimonials__quote {
		order: 1;
	}
}

.testimonials__media {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}

.testimonials__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.testimonials__quote {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--sm);
}

.testimonials__text {
	font-family: var(--wp--preset--font-family--serif);
	font-size: var(--wp--preset--font-size--lg);
	color: var(--wp--preset--color--ink);
	line-height: 1.9;
	margin: 0;
}

.testimonials__text::before {
	content: "\201C";
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.6em;
	color: var(--wp--preset--color--accent);
	line-height: 0;
	vertical-align: -0.3em;
	margin-right: 0.1em;
}

.testimonials__footer {
	border-left: 2px solid var(--wp--preset--color--accent);
	padding-left: var(--wp--preset--spacing--sm);
}

.testimonials__cite {
	font-style: normal;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.testimonials__name {
	font-weight: 700;
	font-size: var(--wp--preset--font-size--base);
	color: var(--wp--preset--color--ink);
}

.testimonials__meta {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--ink-soft);
}

/* ============================================================
   ⑦ faq — sections.css のスタイルをほぼそのまま使用
   eyebrow の余白だけ補正。
   ============================================================ */
.faq {
	background: var(--wp--preset--color--base-2);
}

.faq .section__head {
	margin-bottom: var(--wp--preset--spacing--lg);
}

/* ============================================================
   ⑧ company — asymmetric split（写真と概要 dl）
   完全新規。
   ============================================================ */
.company {
	padding-block: var(--wp--preset--spacing--xxl);
	background: var(--wp--preset--color--base);
}

.company__inner {
	max-width: var(--wp--style--global--wide-size, 1200px);
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--md);
}

.company__body {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--lg);
}

@media (min-width: 768px) {
	.company__body {
		grid-template-columns: 5fr 7fr;
		gap: var(--wp--preset--spacing--xl);
		align-items: start;
	}
}

.company__media {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}

.company__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.company__info {
	margin: 0;
}

.company__row {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: var(--wp--preset--spacing--sm);
	padding-block: var(--wp--preset--spacing--sm);
	border-bottom: 1px solid var(--wp--preset--color--line);
	margin: 0;
}

.company__row:last-child {
	border-bottom: 0;
}

.company__label {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--brand);
	margin: 0;
}

.company__value {
	font-size: var(--wp--preset--font-size--base);
	color: var(--wp--preset--color--ink);
	line-height: 1.7;
	margin: 0;
}

.company__tel {
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 700;
	color: var(--wp--preset--color--brand);
	text-decoration: none;
	font-size: var(--wp--preset--font-size--lg);
}

.company__tel:hover {
	color: var(--wp--preset--color--accent);
}

/* ============================================================
   ⑨ cta — sections.css の cta を活かしつつ eyebrow 追加
   ============================================================ */
.cta__eyebrow {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--base);
	opacity: 0.7;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--xs);
}
