/* =========================================================================
 * 給湯器の選び方診断ツール フロントスタイル
 *
 * 既存テーマと干渉しないよう、すべてのセレクタを .ks-shindan 配下に限定し、
 * クラス名は ks- プレフィックス＋BEM 風命名で衝突を避ける。
 * 配色は信頼感のある寒色系（給湯＝水まわり）を基調にトーンを統一。
 * ====================================================================== */

.ks-shindan {
	/* --- カラートークン ---
	 * サイト既存記事の視覚言語に合わせ、オレンジ主体の配色に統一。
	 *  - オレンジ #ed5935 … 帯見出し・ボタンに使われているサイト標準色
	 *  - 黄色   #fee042 … 広告誘導 CTA ブロックの背景色
	 * ヘッダーはオレンジを少し落ち着かせた濃いめのトーン、
	 * 広告リンクボタンは黄色背景＋オレンジボタンでサイトの CTA を踏襲する。
	 */
	--ks-primary:        #ed5935;   /* メイン：サイト標準オレンジ */
	--ks-primary-dark:   #cf4824;   /* ヘッダーグラデーションの暗端 */
	--ks-primary-light:  #fdeee8;   /* 選択中・スペックカード等の淡いオレンジ */
	--ks-accent:         #ed5935;   /* 広告 CTA ボタン本体（サイト標準色） */
	--ks-accent-dark:    #d4471f;   /* CTA ホバー */
	--ks-cta-bg:         #fee042;   /* 広告 CTA ブロックの黄色背景 */
	--ks-cta-bg-edge:    #f6c81f;   /* 黄色背景の境界・締め色 */
	--ks-ink:            #2c2723;   /* 本文（暖色寄りの濃グレー） */
	--ks-ink-soft:       #6e655f;   /* 補足テキスト */
	--ks-line:           #e6ded9;   /* 罫線 */
	--ks-surface:        #ffffff;
	--ks-surface-alt:    #f7f5f3;
	--ks-eco:            #3f8f5b;   /* エコ訴求（緑は機能色として維持） */
	--ks-radius:         12px;
	--ks-radius-sm:      8px;
	--ks-shadow:         0 2px 12px rgba(237, 89, 53, .12);
	--ks-shadow-card:    0 1px 6px rgba(44, 39, 35, .08);

	/* 外枠は固定ページのコンテンツ領域いっぱいに広げ、サイトと幅を揃える。
	 * 中身の各要素は別途 --ks-inner-max で読みやすい幅に制限する。 */
	--ks-inner-max:      620px;

	width: 100%;
	margin: 2em auto;
	padding: 0;
	color: var(--ks-ink);
	font-size: 16px;
	line-height: 1.75;
	background: var(--ks-surface);
	border: 1px solid var(--ks-line);
	border-radius: var(--ks-radius);
	box-shadow: var(--ks-shadow);
	overflow: hidden;
	-webkit-font-smoothing: antialiased;
}

.ks-shindan *,
.ks-shindan *::before,
.ks-shindan *::after {
	box-sizing: border-box;
}

/* --- ヘッダー ---------------------------------------------------------- */
/* 背景（オレンジ）は外枠いっぱい。中のテキストは内側幅で中央寄せにする。 */
.ks-shindan__header {
	padding: 1.6em 1.5em 1.3em;
	background: linear-gradient( 135deg, var(--ks-primary) 0%, var(--ks-primary-dark) 100% );
	color: #fff;
}

.ks-shindan__title,
.ks-shindan__lead {
	max-width: var(--ks-inner-max);
	margin-left: auto;
	margin-right: auto;
}

.ks-shindan__title {
	margin: 0 auto .4em;
	font-size: 1.35em;
	font-weight: 700;
	line-height: 1.4;
	color: #fff;
}

.ks-shindan__lead {
	margin: 0 auto;
	font-size: .9em;
	line-height: 1.7;
	color: rgba( 255, 255, 255, .92 );
}

/* --- 進捗バー ---------------------------------------------------------- */
.ks-shindan__progress {
	height: 5px;
	background: var(--ks-line);
}

.ks-shindan__progress-bar {
	height: 100%;
	width: 0;
	background: var(--ks-accent);
	transition: width .35s ease;
}

/* --- ボディ ------------------------------------------------------------ */
/* パディングは外枠基準。中身（質問・結果）は内側幅で中央寄せにする。 */
.ks-shindan__body {
	padding: 1.6em 1.5em 1.8em;
}

.ks-step,
.ks-result,
.ks-loading,
.ks-result-error,
.ks-shindan__noscript {
	max-width: var(--ks-inner-max);
	margin-left: auto;
	margin-right: auto;
}

.ks-shindan__noscript {
	margin: 0;
	padding: 1em;
	background: var(--ks-surface-alt);
	border-radius: var(--ks-radius-sm);
	font-size: .9em;
}

/* --- 質問ステップ ------------------------------------------------------ */
.ks-step {
	animation: ks-fade-in .3s ease;
}

@keyframes ks-fade-in {
	from { opacity: 0; transform: translateY( 8px ); }
	to   { opacity: 1; transform: translateY( 0 ); }
}

.ks-step__count {
	margin: 0 0 .5em;
	font-size: .8em;
	font-weight: 700;
	letter-spacing: .04em;
	color: var(--ks-primary);
}

.ks-step__title {
	margin: 0 0 .5em;
	font-size: 1.15em;
	font-weight: 700;
	line-height: 1.55;
	color: var(--ks-ink);
}

.ks-step__help {
	margin: 0 0 1.1em;
	font-size: .86em;
	line-height: 1.7;
	color: var(--ks-ink-soft);
}

/* --- 選択肢 ------------------------------------------------------------ */
.ks-options {
	display: flex;
	flex-direction: column;
	gap: .6em;
	margin-bottom: 1.3em;
}

.ks-option {
	display: flex;
	flex-direction: column;
	gap: .15em;
	width: 100%;
	margin: 0;
	padding: .85em 1em;
	text-align: left;
	background: var(--ks-surface);
	border: 1.5px solid var(--ks-line);
	border-radius: var(--ks-radius-sm);
	cursor: pointer;
	font: inherit;
	color: var(--ks-ink);
	transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
}

.ks-option:hover {
	border-color: var(--ks-primary);
	background: var(--ks-primary-light);
}

.ks-option:focus-visible {
	outline: 2px solid var(--ks-primary);
	outline-offset: 2px;
}

.ks-option.is-selected {
	border-color: var(--ks-primary);
	background: var(--ks-primary-light);
	box-shadow: inset 0 0 0 1px var(--ks-primary);
}

/* 複数選択にはチェックマーク領域を用意 */
.ks-options--multi .ks-option {
	padding-left: 2.6em;
	position: relative;
}

.ks-options--multi .ks-option::before {
	content: "";
	position: absolute;
	left: 1em;
	top: 1em;
	width: 18px;
	height: 18px;
	border: 1.5px solid var(--ks-line);
	border-radius: 4px;
	background: #fff;
	transition: background .15s ease, border-color .15s ease;
}

.ks-options--multi .ks-option.is-selected::before {
	background: var(--ks-primary);
	border-color: var(--ks-primary);
}

.ks-options--multi .ks-option.is-selected::after {
	content: "";
	position: absolute;
	left: 1.4em;
	top: 1.35em;
	width: 5px;
	height: 9px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate( 45deg );
}

.ks-option__label {
	font-size: .98em;
	font-weight: 600;
	line-height: 1.5;
}

.ks-option__desc {
	font-size: .8em;
	color: var(--ks-ink-soft);
	line-height: 1.55;
}

/* --- ナビゲーション ---------------------------------------------------- */
.ks-nav {
	display: flex;
	gap: .7em;
	flex-wrap: wrap;
}

.ks-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: .75em 1.4em;
	font: inherit;
	font-size: .92em;
	font-weight: 700;
	line-height: 1.4;
	border-radius: var(--ks-radius-sm);
	border: 1.5px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: background .15s ease, color .15s ease, border-color .15s ease, transform .05s ease;
}

.ks-btn:active {
	transform: translateY( 1px );
}

.ks-btn--primary {
	background: var(--ks-primary);
	color: #fff;
	flex: 1 1 auto;
}

.ks-btn--primary:hover {
	background: var(--ks-primary-dark);
}

.ks-btn--ghost {
	background: transparent;
	color: var(--ks-ink-soft);
	border-color: var(--ks-line);
}

.ks-btn--ghost:hover {
	border-color: var(--ks-primary);
	color: var(--ks-primary);
}

/* 広告 CTA ブロック：黄色背景＋オレンジボタン（サイトの CTA を踏襲） */
.ks-cta-block {
	margin: .2em -.15em 0;
	padding: .8em .8em .85em;
	background: var(--ks-cta-bg);
	border: 1px solid var(--ks-cta-bg-edge);
	border-radius: var(--ks-radius-sm);
	text-align: center;
}

.ks-cta-block__lead {
	margin: 0 0 .55em;
	font-size: .8em;
	font-weight: 700;
	line-height: 1.5;
	color: #6b4a00;
}

.ks-btn--cta {
	background: var(--ks-accent);
	color: #fff;
	width: 100%;
	padding: .92em 1.2em;
	font-size: 1em;
	box-shadow: 0 2px 0 var(--ks-accent-dark);
}

.ks-btn--cta:hover {
	background: var(--ks-accent-dark);
}

/* --- インラインエラー -------------------------------------------------- */
.ks-inline-error {
	margin: 0 0 .8em;
	padding: .6em .9em;
	font-size: .85em;
	color: #b3261e;
	background: #fdeceb;
	border-radius: var(--ks-radius-sm);
}

/* --- ローディング ------------------------------------------------------ */
.ks-loading {
	text-align: center;
	padding: 2.5em 1em;
}

.ks-loading__spinner {
	width: 38px;
	height: 38px;
	margin: 0 auto .9em;
	border: 3px solid var(--ks-line);
	border-top-color: var(--ks-primary);
	border-radius: 50%;
	animation: ks-spin .8s linear infinite;
}

@keyframes ks-spin {
	to { transform: rotate( 360deg ); }
}

.ks-loading__text {
	margin: 0;
	font-size: .9em;
	color: var(--ks-ink-soft);
}

/* --- 結果画面 ---------------------------------------------------------- */
.ks-result {
	animation: ks-fade-in .35s ease;
}

.ks-result__eyebrow {
	margin: 0 0 .25em;
	font-size: .8em;
	font-weight: 700;
	letter-spacing: .06em;
	color: var(--ks-accent);
}

.ks-result__title {
	margin: 0 0 1em;
	font-size: 1.2em;
	font-weight: 700;
	line-height: 1.5;
}

/* スペックカード */
.ks-spec {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .7em;
	margin-bottom: 1.1em;
}

.ks-spec__item {
	display: flex;
	flex-direction: column;
	gap: .25em;
	padding: .9em 1em;
	background: var(--ks-primary-light);
	border-radius: var(--ks-radius-sm);
}

.ks-spec__item:first-child {
	grid-column: 1 / -1;
}

.ks-spec__label {
	font-size: .76em;
	font-weight: 600;
	color: var(--ks-primary-dark);
}

.ks-spec__value {
	font-size: 1.25em;
	font-weight: 700;
	line-height: 1.4;
	color: var(--ks-ink);
}

.ks-result__desc {
	margin: 0 0 1em;
	font-size: .9em;
	line-height: 1.75;
	color: var(--ks-ink-soft);
}

/* 注記ボックス */
.ks-note {
	margin: 0 0 .8em;
	padding: .8em 1em;
	font-size: .85em;
	line-height: 1.7;
	border-radius: var(--ks-radius-sm);
	border-left: 3px solid var(--ks-primary);
	background: var(--ks-surface-alt);
}

.ks-note--eco {
	border-left-color: var(--ks-eco);
}

.ks-note--info {
	border-left-color: var(--ks-accent);
}

.ks-result__notes {
	margin: 0 0 1.3em;
	padding-left: 1.2em;
	font-size: .85em;
	line-height: 1.7;
	color: var(--ks-ink-soft);
}

.ks-result__notes li {
	margin-bottom: .35em;
}

/* --- 業者一覧 ---------------------------------------------------------- */
.ks-offices {
	margin-top: 1.6em;
	padding-top: 1.5em;
	border-top: 1px dashed var(--ks-line);
}

.ks-offices__heading {
	margin: 0 0 .5em;
	font-size: 1.08em;
	font-weight: 700;
	color: var(--ks-ink);
}

.ks-offices__note,
.ks-offices__empty {
	margin: 0 0 1.1em;
	font-size: .85em;
	line-height: 1.7;
	color: var(--ks-ink-soft);
}

.ks-offices__list {
	display: flex;
	flex-direction: column;
	gap: 1em;
}

/* 業者カード */
.ks-office {
	padding: 1.1em 1.15em;
	background: var(--ks-surface);
	border: 1px solid var(--ks-line);
	border-radius: var(--ks-radius-sm);
	box-shadow: var(--ks-shadow-card);
}

/* カード上部：サムネイル＋見出しの横並び */
.ks-office__head {
	margin-bottom: .7em;
}

.ks-office__head--thumb {
	display: flex;
	gap: .8em;
	align-items: flex-start;
}

.ks-office__thumb {
	flex: 0 0 84px;
	width: 84px;
}

.ks-office__thumb img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 6px;
	border: 1px solid var(--ks-line);
}

.ks-office__headtext {
	flex: 1 1 auto;
	min-width: 0;
}

.ks-office__name {
	margin: 0 0 .25em;
	font-size: 1.05em;
	font-weight: 700;
	line-height: 1.45;
	color: var(--ks-ink);
}

.ks-office__catch {
	margin: 0;
	font-size: .85em;
	line-height: 1.65;
	color: var(--ks-accent-dark);
}

/* リード文（紹介文） */
.ks-office__lead {
	margin: 0 0 .8em;
	padding: .7em .85em;
	font-size: .83em;
	line-height: 1.75;
	color: var(--ks-ink-soft);
	background: var(--ks-surface-alt);
	border-radius: var(--ks-radius-sm);

	/* 指定行数で表示を打ち切り、超過分は「…」で省略する。
	 * --ks-lead-lines は JS が業者カードごとに設定（既定3行）。 */
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: var(--ks-lead-lines, 3);
	line-clamp: var(--ks-lead-lines, 3);
	overflow: hidden;
}

/* リード文中のマーカー強調（サイトの <span class="marker"> を再現）。
 * 文字の下半分に黄色い蛍光ペンを引いたような表現。 */
.ks-office__lead .marker {
	background: linear-gradient( transparent 60%, var(--ks-cta-bg) 60% );
	font-weight: 700;
	color: var(--ks-ink);
}

/* バッジ */
.ks-office__badges {
	display: flex;
	flex-wrap: wrap;
	gap: .4em;
	margin-bottom: .7em;
}

/* メーカー名バッジ：淡いオレンジ。情報量が多いため控えめに */
.ks-badge {
	display: inline-block;
	padding: .2em .6em;
	font-size: .72em;
	font-weight: 600;
	line-height: 1.5;
	color: #9a3d1f;
	background: var(--ks-primary-light);
	border-radius: 4px;
}

/* エコキュート対応バッジ：機能色の緑 */
.ks-badge--eco {
	color: #2c6b41;
	background: #e5f2e9;
}

/* 即日対応バッジ：重要情報のため、塗りのオレンジで強く見せる */
.ks-badge--soku {
	color: #fff;
	background: var(--ks-primary);
	font-weight: 700;
}

/* セリングポイント */
.ks-office__points {
	margin: 0 0 .9em;
	padding-left: 1.15em;
	font-size: .83em;
	line-height: 1.7;
	color: var(--ks-ink-soft);
}

.ks-office__points li {
	margin-bottom: .2em;
}

/* アクション */
.ks-office__actions {
	display: flex;
	flex-direction: column;
	gap: .55em;
}

/* サイト内記事へのリンクは色指定せず、既存テーマのリンク色を継承させる */
.ks-link-detail {
	font-size: .82em;
	font-weight: 600;
	text-align: center;
}

/* --- 結果フッター ------------------------------------------------------ */
.ks-result__disclaimer {
	margin: 1.5em 0 .8em;
	font-size: .76em;
	line-height: 1.7;
	color: var(--ks-ink-soft);
}

.ks-result__restart {
	display: block;
	margin: 0 auto;
}

/* --- エラー画面 -------------------------------------------------------- */
.ks-result-error {
	text-align: center;
	padding: 2em 1em;
}

.ks-result-error__msg {
	margin: 0 0 1.1em;
	font-size: .9em;
	color: #b3261e;
}

/* --- レスポンシブ ------------------------------------------------------ */
@media ( max-width: 540px ) {
	.ks-shindan {
		margin: 1.2em 0;
		border-radius: 0;
		border-left: none;
		border-right: none;
	}

	.ks-shindan__header,
	.ks-shindan__body {
		padding-left: 1.1em;
		padding-right: 1.1em;
	}

	.ks-spec {
		grid-template-columns: 1fr;
	}

	.ks-spec__item:first-child {
		grid-column: auto;
	}

	.ks-nav {
		flex-direction: column-reverse;
	}

	.ks-btn--ghost,
	.ks-btn--primary {
		width: 100%;
	}
}
