/* 2025年向けミニマルベース。ダーク/ライト自動・アクセシビリティ配慮 */
:root { color-scheme: light dark; }

/* Reset / Normalize（最小限） */
*,
*::before,
*::after { box-sizing: border-box; }
html, body { height: 100%; }
body {
	margin: 0;
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	line-height: 1.6;
	-webkit-text-size-adjust: 100%;
	background: Canvas;
	color: CanvasText;
}
img, svg, video { max-width: 100%; height: auto; display: block; }

/* 動きが苦手な人に配慮 */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}


/* ===== Base link ===== */
a {
	color: LinkText;                          /* OS/テーマに馴染むリンク色 */
	text-decoration: underline;
	text-decoration-thickness: .08em;         /* 少し細めの下線 */
	text-underline-offset: .18em;             /* 文字から少し離す */
	transition: color .15s ease, text-decoration-color .15s ease;
}

/* Hover / Active */
a:hover {
	text-decoration-thickness: .12em;         /* 下線を太くしてメリハリ */
	text-decoration-color: currentColor;
}
a:active { opacity: .9; }

/* Keyboard focus */
a:focus-visible {
	outline: 2px solid Highlight;             /* OS配色のハイライト色 */
	outline-offset: 2px;
	border-radius: .25rem;
}

/* Visited（必要なら有効化） */
/* a:visited { color: VisitedText; } */

/* 弱めテキスト内のリンク（本文注記など） */
.muted a {
	color: color-mix(in oklab, LinkText 85%, CanvasText 15%);
}
.muted a:hover { color: LinkText; }

/* ボタン化したリンクは下線を消す */
a.btn { text-decoration: none; }

/* 現在ページのリンク（ナビ等） */
a[aria-current="page"] {
	text-decoration: none;
	font-weight: 700;
}

/* ===== External indicator（任意） ===== */
a[target="_blank"]:not(.btn):not(.insta-banner)::after {
	content: "↗";
	font-size: .9em;
	margin-left: .25em;
	opacity: .85;
}

/* ===== Utilities（必要に応じて） ===== */
.link--no-underline { text-decoration: none; }
.link--no-underline:hover { text-decoration: underline; }
.link--contrast { color: Canvas; text-decoration-color: currentColor; } /* 色面上で白リンクにしたい時 */



/* レイアウト */
body {
	font-family: "Noto Sans JP", sans-serif;
}

/* 1画面ヒーロー */
.full-height {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
}

/* ヒーローセクション */
.section-hero {
	padding-inline: 16px;
	background-image: url("../images/kotohana-top-yoko.jpg");
	background-size: cover;
	background-position: center 30%;
}
.section-hero__inner {
	text-align: center;
	max-width: 960px;
	margin-inline: auto;
}
@media (max-width: 700px) {
	.section-hero {
		background-image: url("../images/kotohana-top.jpg");
	}
}


.section-hero__title {
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 700;
	font-size: clamp(2rem, 5vw, 2.8rem); /* 最小32px, 最大44.8px */
	line-height: 1.35;
	margin: 0 0 .6em;
	-webkit-text-stroke: 1px #FFF;
	text-stroke: 1px #FFF;
}
.section-hero__sub {
	font-size: clamp(1.1rem, 2.5vw, 1.4rem); /* 最小17.6px, 最大22.4px */
	line-height: 1.7;
	margin: 0 0 1.2em;
	color: color-mix(in oklab, CanvasText 90%, transparent);
	text-shadow: 1px 1px 3px white, 1px 1px 3px white, 1px 1px 3px white, 1px 1px 3px white;
}


/* ボタン行 */
.section-hero__actions {
	margin: 0;
}

/* ボタン（a） */
.btn {
	display: inline-block;
	padding: 1em 2em;
	margin: 1.5em .5em 0;
	color: #fff;
	border-radius: 12px;
	text-decoration: none;
	transition: opacity .2s ease;
}
.btn:hover {
	opacity: .7;
}

/* 少しだけ余白・可読性を上げる（任意） */
@media (min-width: 900px) {
	.section-hero__title { line-height: 1.25; }
}


/* セクション全体 */
.section-concerns {
	--c-bg: color-mix(in oklab, Canvas 96%, CanvasText 4%);
	--c-card: color-mix(in oklab, Canvas 98%, CanvasText 2%);
	--c-border: color-mix(in oklab, CanvasText 15%, transparent);
	--c-accent: #2ea36a; /* お好みで変更可 */
	padding-block: clamp(2rem, 5vw, 4rem);
	background: #F0F9E0;
}

/* 見出しとリードだけ丸ゴ */
.section-concerns__title,
.section-concerns__lead {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

/* タイトル */
.section-concerns__title {
	margin: 0 auto clamp(1.25rem, 3vw, 2rem);
	text-align: center;
	font-size: clamp(1.25rem, 3vw, 1.8rem);
	line-height: 1.3;
}

/* 2カラムのグリッド（PC横並び／SP縦並び） */
.section-concerns__grid {
	display: grid;
	gap: clamp(1rem, 3vw, 1.5rem);
	grid-template-columns: 1fr;
	max-width: 1080px;
	margin-inline: auto;
	padding-inline: 16px;
}
@media (min-width: 900px) {
	.section-concerns__grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* カード */
.concern-card {
	background: var(--c-card);
	border: 1px solid var(--c-border);
	border-radius: 12px;
	padding: clamp(1rem, 3vw, 1.5rem);
	box-shadow: 0 6px 16px rgba(0,0,0,.06);
}
.concern-card__title {
	text-align: center;
	margin: 0 0 .75rem;
	font-size: clamp(1.05rem, 2.2vw, 1.25rem);
	line-height: 1.35;
}
.concern-card__image {
	max-height: 300px;
	border-radius: 10px;
	margin: .5rem auto 1rem;
	object-fit: cover;
	min-height: 300px;  /* 仮 */
	background-color: lightgray;  /* 仮 */
}

/* チェック付きリスト（Font Awesome 使用） */
.concern-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: .5rem;
}
.concern-list li {
	position: relative;
	padding-left: 1.6em;
	line-height: 1.6;
}
.concern-list li::before {
	content: "\f00c"; /* fa-check */
	font-family: "Font Awesome 6 Free";
	font-weight: 900; /* solid */
	position: absolute;
	left: 0;
	top: .1em;
	translate: 0 .06em;
	color: var(--c-accent);
}

/* 締めのリード文（丸ゴ＋中央寄せ） */
.section-concerns__lead {
	max-width: 960px;
	margin: clamp(1.25rem, 4vw, 2rem) auto 0;
	padding-inline: 16px;
	text-align: center;
	font-size: clamp(1rem, 2.4vw, 1.2rem);
	font-weight: 700;
	color: color-mix(in oklab, CanvasText 75%, transparent);
}

/* 低コントラスト環境への配慮（お好みで） */
@media (prefers-contrast: more) {
	.section-concerns {
		--c-border: color-mix(in oklab, CanvasText 30%, transparent);
	}
	.concern-card {
		border-color: var(--c-border);
	}
}

/* セクション基礎 */
.section-reasons {
	--c-bg: color-mix(in oklab, Canvas 96%, CanvasText 4%);
	--c-card: color-mix(in oklab, Canvas 98%, CanvasText 2%);
	--c-border: color-mix(in oklab, CanvasText 15%, transparent);
	--c-accent: #2ea36a; /* 必要ならブランド色に */
	padding-block: clamp(2rem, 5vw, 4rem);
	background: var(--c-bg);
}

/* タイトル（丸ゴ＋clamp） */
.section-reasons__title {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 700;
	font-size: clamp(1.25rem, 3vw, 1.8rem);
	line-height: 1.35;
	text-align: center;
	margin: 0 auto clamp(1.25rem, 3vw, 2rem);
	padding-inline: 16px;
	max-width: 1100px;
}

/* レスポンシブグリッド：SP1 / TB2 / PC3 */
.section-reasons__grid {
	display: grid;
	gap: clamp(1rem, 3vw, 1.5rem);
	grid-template-columns: 1fr;
	max-width: 1080px;
	margin-inline: auto;
	padding-inline: 16px;
}
@media (min-width: 700px) {
	.section-reasons__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 980px) {
	.section-reasons__grid { grid-template-columns: repeat(3, 1fr); }
}

/* カード */
.reason-card {
	background: var(--c-card);
	border: 1px solid var(--c-border);
	border-radius: 14px;
	padding: clamp(1rem, 3vw, 1.5rem);
	box-shadow: 0 6px 16px rgba(0,0,0,.06);
	display: flex;
	flex-direction: column;
}

/* 画像（任意：比率キープ） */
.reason-card__image {
	width: 100%;
	aspect-ratio: 16 / 9; /* 画像が未セットでも崩れにくく */
	object-fit: cover;
	border-radius: 10px;
	margin: 0 0 1rem;
	background: color-mix(in oklab, Canvas 92%, CanvasText 8%); /* プレースホルダ調 */
}

/* タイトル・本文（clampで自然に） */
.reason-card__title {
	font-weight: 700;
	font-size: clamp(1.05rem, 2.2vw, 1.3rem);
	line-height: 1.4;
	margin: 0 0 .5rem;
}
.reason-card__text {
	font-size: clamp(.95rem, 1.8vw, 1.05rem);
	line-height: 1.85;
	margin: 0;
	color: color-mix(in oklab, CanvasText 78%, transparent);
}

/* 装飾：強調ライン（任意） */
.reason-card__title {
	text-align: center;
}
/* ハイコントラスト配慮（任意） */
@media (prefers-contrast: more) {
	.section-reasons { --c-border: color-mix(in oklab, CanvasText 30%, transparent); }
	.reason-card { border-color: var(--c-border); }
}

.section-reasons {
	--c-bg: #fff;
	background: #fff;
}


/* 交互配色の“グレー面” */
.section-vision {
	--c-bg: #F0F9E0; /* 好みで #f3f4f6 や #f7f7f7 に調整可 */
	padding-block: clamp(2rem, 5vw, 4rem);
	background: var(--c-bg);
}
.section-vision__inner {
	max-width: 960px;
	margin-inline: auto;
	padding-inline: 16px;
	text-align: center;
}

/* タイトル・サブタイトルは丸ゴ */
.section-vision__title,
.section-vision__subtitle {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

/* 見出しサイズ（自然に伸縮） */
.section-vision__title {
	font-weight: 700;
	font-size: clamp(1.25rem, 3vw, 1.8rem);
	line-height: 1.3;
	margin: 0 0 .6em;
}
.section-vision__subtitle {
	font-weight: 700;
	font-size: clamp(1.05rem, 2.2vw, 1.4rem);
	line-height: 1.45;
	margin: 0 0 1em;
}

/* 本文：行間を広めに */
.section-vision__text {
	font-size: clamp(1rem, 2vw, 1.125rem);
	line-height: 1.9;
	margin: 0 0 1.5rem;
	color: color-mix(in oklab, CanvasText 78%, transparent);
}

/* 画像：比率保持＆角丸 */
.section-vision__image {
	width: 100%;
	aspect-ratio: 16 / 9; /* 画像未設定時もレイアウトが安定 */
	object-fit: contain;
	border-radius: 12px;
	box-shadow: 0 8px 20px rgba(0,0,0,.06);
	//background: color-mix(in oklab, Canvas 92%, CanvasText 8%); /* プレースホルダ */
	background: white; /* プレースホルダ */
}

/* コントラスト配慮（任意） */
@media (prefers-contrast: more) {
	.section-vision__image { box-shadow: 0 0 0 2px color-mix(in oklab, CanvasText 25%, transparent); }
}


/* 交互配色：グレー背景のステップ */
.section-steps {
	--c-bg: #fff;
	--c-card: #fff;
	--c-border: color-mix(in oklab, CanvasText 15%, transparent);
	--c-badge: #88CEEB; /* 水色の番号バッジ */
	padding-block: clamp(2rem, 5vw, 4rem);
	background: var(--c-bg);
}
.section-steps__inner {
	max-width: 1100px;
	margin-inline: auto;
	padding-inline: 16px;
	text-align: center;
}

/* タイトル（丸ゴ＋clamp） */
.section-steps__title {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 700;
	font-size: clamp(1.25rem, 3vw, 1.8rem);
	line-height: 1.3;
	margin: 0 0 clamp(1.25rem, 3vw, 2rem);
}

/* グリッド：SP1 / TB2 / PC4 */
.section-steps__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: clamp(1rem, 3vw, 1.5rem);
	grid-template-columns: 1fr;
	counter-reset: step; /* 1からの自動付番 */
}
@media (min-width: 680px) {
	.section-steps__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1080px) {
	.section-steps__grid { grid-template-columns: repeat(4, 1fr); }
}

/* カード */
.step-card {
	counter-increment: step;
	background: var(--c-card);
	border: 1px solid var(--c-border);
	border-radius: 14px;
	padding: clamp(1rem, 3vw, 1.5rem);
	box-shadow: 0 6px 16px rgba(0,0,0,.06);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: left; /* 本文は読みやすく左寄せ */
}

/* 番号バッジ（h3の上に表示） */
.step-card__title {
	position: relative;
	font-weight: 700;
	font-size: clamp(1.05rem, 2.2vw, 1.2rem);
	line-height: 1.4;
	margin: 2.4rem 0 .5rem; /* バッジのスペースを確保 */
	text-align: center;
}
.step-card__title::before {
	content: counter(step);
	position: absolute;
	inset: auto 0 100% 0; /* タイトルの上に配置（下→上） */
	margin: 0 auto .6rem;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 50%;
	background: var(--c-badge);
	color: #fff;
	font-weight: 700;
	font-size: 1.2rem;
	display: grid;
	place-items: center;
	box-shadow: 0 2px 0 rgba(0,0,0,.08), 0 0 0 4px #fff; /* 白縁で映えさせる */
}

/* 本文 */
.step-card__text {
	font-size: clamp(.95rem, 1.5vw, 1rem);
	line-height: 1.85;
	margin: 0;
	color: color-mix(in oklab, CanvasText 78%, transparent);
	width: 100%;
}


/* グレー背景にべた置き */
.section-greeting {
	--c-bg: #F0F9E0; /* 交互配色のグレー（他ブロックと揃え可） */
	padding-block: clamp(2rem, 5vw, 4rem);
	background: var(--c-bg);
}
.section-greeting__inner {
	max-width: 1100px;
	margin-inline: auto;
	padding-inline: 16px;
}

/* 見出しは丸ゴ＋自然な可変 */
.section-greeting__title {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 700;
	font-size: clamp(1.25rem, 3vw, 1.8rem);
	line-height: 1.3;
	text-align: center;
	margin: 0 0 clamp(1.25rem, 3vw, 2rem);
}

/* メディア：SP縦／TB〜PC横並び */
.greeting {
	display: grid;
	gap: clamp(1rem, 3vw, 1.5rem);
	grid-template-columns: 1fr;
	align-items: start;
}
@media (min-width: 900px) {
	.greeting {
		grid-template-columns: minmax(280px, 420px) 1fr; /* 画像幅をほどよく固定寄りに */
		align-items: center;
		gap: clamp(1.75rem, 5vw, 3rem);
	}
}

/* 画像はポートレート想定（未設定時もレイアウト安定） */
.greeting__image {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 14px;
	box-shadow: 0 8px 20px rgba(0,0,0,.06);
	background: color-mix(in oklab, Canvas 92%, CanvasText 8%);
}

/* テキスト側 */
.greeting__content {
	display: grid;
	gap: .75rem;
}

/* お名前見出しは丸ゴ＋少し強め */
.greeting__name {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 700;
	font-size: clamp(1.05rem, 2.2vw, 1.4rem);
	line-height: 1.45;
	margin: 0;
}

/* 本文は読みやすい行間 */
.greeting__text {
	font-size: clamp(1rem, 2vw, 1.125rem);
	line-height: 1.9;
	margin: 0;
	color: color-mix(in oklab, CanvasText 78%, transparent);
}


/* ページ全体：スムーススクロール（#contact へ滑らかに） */
html {
	scroll-behavior: smooth;
}

/* セクション（白背景） */
.section-recruit {
	padding-block: clamp(2rem, 5vw, 4rem);
	background: #fff;
}
.section-recruit__inner {
	max-width: 1100px;
	margin-inline: auto;
	padding-inline: 16px;
	text-align: center;
}

/* 見出し（丸ゴ） */
.section-recruit__title {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 700;
	font-size: clamp(1.25rem, 3vw, 1.8rem);
	line-height: 1.3;
	margin: 0 0 clamp(1.25rem, 3vw, 2rem);
}

/* 16:9 の横長画像 */
.section-recruit__image {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	border-radius: 12px;
	box-shadow: 0 8px 20px rgba(0,0,0,.06);
	background: color-mix(in oklab, Canvas 92%, CanvasText 8%); /* プレースホルダ色 */
	margin: 0 0 1.25rem;
}

/* 説明文 */
.section-recruit__text {
	font-size: clamp(1rem, 2vw, 1.125rem);
	line-height: 1.9;
	margin: 0 0 1.25rem;
	color: color-mix(in oklab, CanvasText 78%, transparent);
}

/* アコーディオン（details） */
.recruit-accordion {
	text-align: left;
	max-width: 980px;
	margin: 0 auto clamp(1rem, 3vw, 1.5rem);
	border-radius: 12px;
	overflow: clip; /* 角丸に合わせて子要素をクリップ */
	border: 1px solid color-mix(in oklab, CanvasText 15%, transparent);
	background: #f5f6f7;
}

/* summary：右端に＋、開くと−。ネイティブマーカーは消す */
.recruit-accordion > summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .75rem;
	padding: 1rem 1.1rem;
	cursor: pointer;
	list-style: none;
	font-weight: 700;
}
.recruit-accordion > summary::-webkit-details-marker { display: none; }
.recruit-accordion > summary::after {
	content: "+";
	font-weight: 700;
	font-size: 1.25rem;
	line-height: 1;
	color: CanvasText;
	opacity: .8;
}
.recruit-accordion[open] > summary::after {
	content: "−"; /* マイナス（U+2212） */
}

/* ラベル（必要なら丸ゴ） */
.recruit-accordion__label {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

/* パネル（開いた中身） */
.recruit-accordion__panel {
	background: #fff;
	padding: 1rem 1.1rem 1.25rem;
	border-top: 1px solid color-mix(in oklab, CanvasText 12%, transparent);
}

/* 募集要項テーブル */
.recruit-table {
	width: 100%;
	border-collapse: collapse;
	font-size: clamp(.95rem, 1.8vw, 1.05rem);
}
.recruit-table th,
.recruit-table td {
	padding: .8rem 1rem;
	border-bottom: 1px solid color-mix(in oklab, CanvasText 12%, transparent);
	vertical-align: top;
}
.recruit-table th {
	width: 10.5em;
	white-space: nowrap;
	color: color-mix(in oklab, CanvasText 80%, transparent);
	font-weight: 600;
}

/* CTAボタン（オレンジ） */
.section-recruit__actions {
	margin: clamp(.5rem, 2vw, 1rem) 0 0;
}
.btn {
	display: inline-block;
	padding: 1em 2em;
	border-radius: 12px;
	text-decoration: none;
	color: #fff;
	transition: transform .06s ease, opacity .2s ease;
}
.btn:hover { opacity: .9; }
.btn:active { transform: translateY(1px); }

.btn--cta {
	background: #FFB74D; /* 既存のオレンジと合わせる */
}

@media (min-width: 1024px) {
	.section-recruit__inner {
		max-width: 840px; /* 例：通常1100px → 840pxに */
	}
}

/* セクション（背景グレー） */
.section-contact {
	padding-block: clamp(2rem, 5vw, 4rem);
	background: #F0F9E0;
}
.section-contact__inner {
	max-width: 1100px;
	margin-inline: auto;
	padding-inline: 16px;
}
.section-contact__title {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 700;
	font-size: clamp(1.25rem, 3vw, 1.8rem);
	line-height: 1.3;
	text-align: center;
	margin: 0 0 clamp(1rem, 3vw, 1.5rem);
}
.section-contact__lead {
	text-align: center;
	font-size: clamp(1rem, 2vw, 1.125rem);
	color: color-mix(in oklab, CanvasText 78%, transparent);
	margin: 0 0 clamp(1.25rem, 3vw, 2rem);
}

/* 2カラム：SP1 / PC2 */
.contact__grid {
	display: grid;
	gap: clamp(1rem, 3vw, 1.5rem);
	grid-template-columns: 1fr;
}
@media (min-width: 980px) {
	.contact__grid {
		grid-template-columns: minmax(320px, 420px) 1fr;
		align-items: start;
	}
}

/* カード調（読みやすさ優先） */
.contact-overview,
.contact-form {
	background: #fff;
	border: 1px solid color-mix(in oklab, CanvasText 15%, transparent);
	border-radius: 14px;
	box-shadow: 0 6px 16px rgba(0,0,0,.06);
	padding: clamp(1rem, 3vw, 1.25rem);
}

/* 概要側 */
.contact-overview__title,
.contact-form__title {
	font-family: "Zen Maru Gothic", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 700;
	font-size: clamp(1.05rem, 2.2vw, 1.4rem);
	line-height: 1.4;
	margin: 0 0 .75rem;
}
.contact-overview__list {
	margin: 0 0 .5rem;
	padding: 0;
}
.dl-row {
	display: grid;
	grid-template-columns: 6em 1fr;
	gap: .5rem 1rem;
	padding: .4rem 0;
	border-bottom: 1px solid color-mix(in oklab, CanvasText 10%, transparent);
}
.dl-row:last-child { border-bottom: none; }
.dl-row dt {
	color: color-mix(in oklab, CanvasText 75%, transparent);
	white-space: nowrap;
}
.contact-overview__addr {
	margin: .75rem 0 0;
	font-style: normal;
}
.addr-line { margin: .25rem 0; }
.addr-line a { color: LinkText; text-decoration: underline; }
.note { font-size: .9em; color: color-mix(in oklab, CanvasText 65%, transparent); }

/* Google Map */
.contact-map {
	margin: .9rem 0 0;
	border-radius: 12px;
	overflow: clip;
	background: color-mix(in oklab, Canvas 92%, CanvasText 8%);
}
.contact-map__iframe {
	width: 100%;
	aspect-ratio: 16 / 9;
	border: 0;
	display: block;
}

/* フォーム側 */
.form-grid {
	display: grid;
	gap: .9rem 1rem;
	grid-template-columns: 1fr;
}
@media (min-width: 700px) {
	.form-grid { grid-template-columns: 1fr 1fr; }
}
.field { display: grid; gap: .4rem; }
.field--full { grid-column: 1 / -1; }

/* ラジオ・チェックボックス */
.field--radio { margin: 0 0 .5rem; border: 0; padding: 0; }
.field--radio legend { margin-bottom: .4rem; font-weight: 600; }
.radio, .checkbox {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	margin-right: 1rem;
	cursor: pointer;
}

/* 入力UI */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
	width: 100%;
	padding: .75rem .9rem;
	border-radius: 10px;
	border: 1px solid color-mix(in oklab, CanvasText 18%, transparent);
	background: color-mix(in oklab, Canvas 98%, CanvasText 2%);
	font-size: 1rem;
}
textarea { min-height: 9rem; resize: vertical; }

label .req { color: #d32f2f; margin-left: .25em; }

/* フォーカス可視化 */
:focus-visible {
	outline: 2px solid Highlight;
	outline-offset: 2px;
}

/* 送信ボタン */
.contact-form__actions { margin-top: .5rem; text-align: right; }
.btn {
	display: inline-block;
	padding: .9rem 1.4rem;
	border-radius: 12px;
	text-decoration: none;
	color: #fff;
	border: none;
	background: #FFB74D;
	transition: transform .06s ease, opacity .2s ease;
}
.btn:hover { opacity: .92; }
.btn:active { transform: translateY(1px); }

/* 同意前は送信不可（CSSのみで） */
.contact-form form:not(:has(#agree:checked)) .btn--submit {
	opacity: .5;
	pointer-events: none;
}


/* フッター：背景グレー＆中央揃え */
.site-footer {
	background: #F0F9E0;
}

.site-footer .container {
	max-width: 1100px;
	margin-inline: auto;
	padding: clamp(1.25rem, 3vw, 2rem) 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.site-footer small {
	display: block;
	font-size: clamp(.9rem, 1.6vw, 1rem);
	color: color-mix(in oklab, CanvasText 72%, transparent);
}

/* フッター内リンクの体裁（必要なら） */
.site-footer a {
	color: inherit;
	text-decoration: underline;
}
.site-footer a:hover {
	opacity: .85;
}


/* Instagram バナー（白背景でさりげなく） */
.section-instagram {
	background: #fff; /* 交互配色を崩さず白面のまま */
	padding-block: clamp(1rem, 4vw, 2rem);
}
.section-instagram__inner {
	max-width: 560px;              /* 採用セクションに寄せて少し狭め */
	margin-inline: auto;
	padding-inline: 16px;
	display: flex;
	justify-content: center;
}

/* バナーのサイズ感：SP広め、PCは最大約480pxに抑える */
.insta-banner {
	display: block;
	320px, 70vw, 480px
	width: 100%;
}
.insta-banner img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 12px;
	box-shadow: 0 6px 16px rgba(0,0,0,.06);
	transition: transform .15s ease, opacity .2s ease;
}

/* さりげないインタラクション（強調し過ぎない） */
.insta-banner:hover img { transform: scale(1.01); opacity: .98; }
.insta-banner:focus-visible { outline: 2px solid Highlight; outline-offset: 4px; border-radius: 14px; }



/* カラー（元ルールをクラス化） */
.btn--primary {
	background-color: #FFB74D;
}
.btn--secondary {
	background-color: #88CEEB;
}

.form-status {
	display: none;
	margin: .75rem 0 1rem;
	padding: .9rem 1rem;
	border-radius: 12px;
	font-size: clamp(.95rem, 1.8vw, 1.05rem);
}
.form-status.is-success {
	display: block;
	background: #F1F8E9;            /* 薄いグリーン */
	border: 1px solid #C5E1A5;
	color: #33691E;
}
.form-status.is-error {
	display: block;
	background: #FDECEA;            /* 薄いレッド */
	border: 1px solid #F5C2C7;
	color: #842029;
}
.form-status ul { margin: 0; padding-left: 1.1em; }
