/* AIコンシェルジュ：検索画面全体を整える */
.ai-concierge {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	color: #1f2937;
}

/* AIコンシェルジュ：配下要素のbox-sizingを統一する */
.ai-concierge * {
	box-sizing: border-box;
}

/* AIコンシェルジュ：ヒーロー部分を整える */
.ai-concierge__hero {
	padding: 24px 0;
	border-bottom: 1px solid #e5e7eb;
}

/* AIコンシェルジュ：ラベルを整える */
.ai-concierge__label {
	margin: 0 0 8px;
	font-size: 13px;
	letter-spacing: 0.08em;
	color: #6b7280;
	text-transform: uppercase;
}

/* AIコンシェルジュ：タイトルを整える */
.ai-concierge__title {
	margin: 0 0 12px;
	font-size: 28px;
	line-height: 1.35;
}

/* AIコンシェルジュ：説明文を整える */
.ai-concierge__lead {
	margin: 0;
	font-size: 16px;
	line-height: 1.8;
	color: #4b5563;
}

/* AIコンシェルジュ：検索エリアを整える */
.ai-concierge__search {
	padding: 0;
}

/* AIコンシェルジュ：フォームラベルを整える */
.ai-concierge__form-label {
	display: block;
	margin-bottom: 10px;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.6;
}

/* AIコンシェルジュ：フォーム行を整える */
.ai-concierge__form-row {
	display: flex;
	gap: 12px;
	align-items: stretch;
}

/* AIコンシェルジュ：入力欄を整える */
.ai-concierge__input {
	flex: 1 1 auto;
	width: 100%;
	min-height: 56px;
	padding: 10px 16px;
	border: 1px solid #d1d5db;
	border-radius: 8px;
	font-size: 16px;
}

/* AIコンシェルジュ：検索ボタンを整える */
.ai-concierge__button {
	flex: 0 0 auto;
	min-height: 56px;
	padding: 10px 22px;
	border: 0;
	border-radius: 8px;
	background: #111827;
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	white-space: nowrap;
}

/* AIコンシェルジュ：検索ボタンの無効状態を整える */
.ai-concierge__button:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* AIコンシェルジュ：ローディング表示を画面全体に重ねる */
.ai-concierge__loading {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
	background: rgba(17, 24, 39, 0.45);
}

/* AIコンシェルジュ：hidden属性が付いている間はローディングを必ず非表示にする */
.ai-concierge__loading[hidden] {
	display: none !important;
}

/* AIコンシェルジュ：ローディングボックスを整える */
.ai-concierge__loading-box {
	width: 100%;
	max-width: 420px;
	padding: 24px 20px;
	border-radius: 12px;
	background: #ffffff;
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.18);
	text-align: center;
}

/* AIコンシェルジュ：ローディング中のスピナーを整える */
.ai-concierge__spinner {
	width: 52px;
	height: 52px;
	margin: 0 auto 16px;
	border: 4px solid #dbeafe;
	border-top-color: #1d4ed8;
	border-radius: 50%;
	animation: ai-concierge-spin 0.9s linear infinite;
}

/* AIコンシェルジュ：ローディング中の主文を整える */
.ai-concierge__loading-title {
	margin: 0 0 10px;
	font-size: 18px;
	font-weight: 700;
	color: #111827;
	line-height: 1.6;
}

/* AIコンシェルジュ：ローディング中の補足文を整える */
.ai-concierge__loading-text {
	margin: 0;
	font-size: 14px;
	line-height: 1.8;
	color: #4b5563;
}

/* AIコンシェルジュ：スピナー回転アニメーションを定義する */
@keyframes ai-concierge-spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

/* AIコンシェルジュ：結果エリアを整える */
.ai-concierge__result {
	margin-top: 20px;
}

/* AIコンシェルジュ：回答ボックスを整える */
.ai-concierge__answer {
	padding: 16px;
	border: 1px solid #dbeafe;
	border-radius: 8px;
	background: #eff6ff;
}

/* AIコンシェルジュ：回答見出しを整える */
.ai-concierge__answer-title,
.ai-concierge__pages-title {
	margin: 0 0 8px;
	font-size: 18px;
}

/* AIコンシェルジュ：回答本文を整える */
.ai-concierge__answer-text {
	margin: 0;
	font-weight: 700;
	line-height: 1.8;
}

/* AIコンシェルジュ：関連ページエリアを整える */
.ai-concierge__pages {
	margin-top: 20px;
}

/* AIコンシェルジュ：注記を整える */
.ai-concierge__notice {
	margin: 0 0 12px;
	color: #6b7280;
	font-size: 14px;
}

/* AIコンシェルジュ：関連ページリストを整える */
.ai-concierge__page-list {
	display: grid;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

/* AIコンシェルジュ：関連ページカードを整える */
.ai-concierge__page-item {
	padding: 14px;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	background: #fff;
}

/* AIコンシェルジュ：関連ページタイトルを整える */
.ai-concierge__page-title {
	margin: 0 0 6px;
	font-size: 16px;
	line-height: 1.6;
}

/* AIコンシェルジュ：関連ページリンクを整える */
.ai-concierge__page-title a {
	color: #1d4ed8;
	text-decoration: underline;
}

/* AIコンシェルジュ：更新日を整える */
.ai-concierge__page-date {
	margin: 0 0 6px;
	font-size: 13px;
	color: #6b7280;
}

/* AIコンシェルジュ：抜粋を整える */
.ai-concierge__page-excerpt {
	margin: 0;
	font-size: 14px;
	line-height: 1.7;
	color: #4b5563;
}

/* AIコンシェルジュ：注意書きを整える */
.ai-concierge__note {
	margin-top: 24px;
	padding: 14px;
	border-left: 4px solid #9ca3af;
	background: #f9fafb;
	color: #4b5563;
	font-size: 14px;
	line-height: 1.8;
}

/* AIコンシェルジュ：エラー表示を整える */
.ai-concierge__error {
	padding: 14px;
	border: 1px solid #fecaca;
	border-radius: 8px;
	background: #fef2f2;
	color: #991b1b;
	font-weight: 700;
}

/* AIコンシェルジュ：スマートフォン表示を整える */
@media (max-width: 640px) {
	.ai-concierge {
		padding: 18px 12px;
	}

	.ai-concierge__title {
		font-size: 22px;
	}

	.ai-concierge__form-row {
		display: block;
	}

	.ai-concierge__button {
		width: 100%;
		margin-top: 8px;
	}
}

/* AIコンシェルジュ：フォーム自体の余白をなくす */
.ai-concierge__form {
	margin: 0;
}

/* AIコンシェルジュ：埋め込み時に横幅いっぱいで使えるようにする */
.ai-concierge__search,
.ai-concierge__result {
	width: 100%;
}

/* AIコンシェルジュ：スマホではボタンを下段へ回す */
@media (max-width: 767px) {
	.ai-concierge__form-row {
		flex-direction: column;
	}

	.ai-concierge__button {
		width: 100%;
	}
}
