/* persona-fusion MVP — styles.css
 * トンマナ: 親しみやすさ+信頼感のパステル。既存サービスのデザインは模倣しない。
 * 配色は独自（パステルブルー＋グレイッシュベージュ）。
 */

:root {
	--bg: #f4f7f8;
	--surface: #ffffff;
	--ink: #263238;
	--ink-soft: #566368;
	--primary: #2b5c8a;
	--primary-dark: #1f4669;
	--accent: #2b5c8a;
	--accent-dark: #1f4669;
	--accent-soft: #dbeaf2;
	--line: #dfe6e8;
	--ok: #2f7d68;
	--radius: 18px;
	--shadow: 0 10px 30px rgba(50, 97, 121, 0.12);
	--font:
		"Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", system-ui, sans-serif;

	/* 因子ごとの色（レーダー/バー共通） */
	--c-E: #2b5c8a;
	--c-A: #6f7d70;
	--c-C: #2f7d68;
	--c-N: #8c6b1f;
	--c-O: #2f789f;
	--c-H: #5d6470;

	/* 円ラジオ：賛成/反対の色分け（既存サービスの模倣はしない独自配色） */
	--c-agree: #4f7891;
	--c-disagree: #8d6678;
}

* {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
}

.visually-hidden,
.sr-only {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0 0 0 0) !important;
	clip-path: inset(50%) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

body {
	font-family: var(--font);
	color: var(--ink);
	background: radial-gradient(
			1200px 600px at 50% -10%,
			#e7f2f6 0%,
			var(--bg) 55%
		)
		no-repeat;
	min-height: 100vh;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}

.app {
	max-width: 560px;
	margin: 0 auto;
	padding: 20px 18px 56px;
}

.app__header {
	display: flex;
	align-items: baseline;
	gap: 10px;
	padding: 8px 4px 22px;
}

.fatal-error {
	position: sticky;
	top: 10px;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	background: #f7f3ed;
	color: var(--ink);
	border: 1px solid #d4c9ba;
	border-radius: 12px;
	box-shadow: 0 8px 18px rgba(38, 50, 56, 0.12);
	padding: 10px 12px;
	margin: 0 0 14px;
	font-size: 0.82rem;
	font-weight: 700;
	line-height: 1.45;
}

.fatal-error__reload {
	flex: 0 0 auto;
	border: 1px solid var(--primary-dark);
	border-radius: 999px;
	background: #ffffff;
	color: var(--primary-dark);
	font: inherit;
	font-size: 0.78rem;
	font-weight: 800;
	padding: 7px 10px;
	cursor: pointer;
}

.brand {
	font-weight: 800;
	letter-spacing: 0.04em;
	color: var(--primary-dark);
	font-size: 1.1rem;
}

.brand__sub {
	font-size: 0.72rem;
	color: var(--ink-soft);
}

/* ---- 画面共通 ---- */
.screen {
	background: var(--surface);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 28px 24px 32px;
	animation: rise 0.4s ease both;
}

.screen--result {
	padding: 32px 24px 36px;
	scroll-padding-top: 18px;
}

.is-hidden {
	display: none !important;
}

@keyframes rise {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ---- スタート（トップページ） ---- */
.screen--start {
	padding-top: 32px;
}

.hero {
	text-align: center;
	margin-bottom: 30px;
}

.hero__title {
	font-size: 1.75rem;
	line-height: 1.4;
	margin: 0 0 14px;
	letter-spacing: 0.01em;
}

.hero__lead {
	color: var(--ink-soft);
	margin: 0 auto 22px;
	font-size: 0.98rem;
	line-height: 1.7;
	max-width: 30em;
}

.hero-characters {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	gap: 8px;
	margin: 0 auto 18px;
	max-width: 360px;
}

.hero-characters__img {
	width: min(15vw, 52px);
	max-width: 52px;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	filter: drop-shadow(0 8px 14px rgba(50, 97, 121, 0.14));
}

/* 主役CTA：アクセント色でいちばん目立たせる（btn 単体に乗せる＝primaryと併用しない） */
.btn--cta {
	color: #fff;
	background: linear-gradient(135deg, var(--accent) 0%, var(--primary-dark) 100%);
	box-shadow: 0 10px 22px rgba(50, 97, 121, 0.32);
	font-size: 1.1rem;
	padding: 17px 20px;
	font-weight: 800;
}

.btn--cta:hover {
	transform: translateY(-2px);
}

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

.hero__cta-sub {
	margin: 10px 0 0;
	font-size: 0.8rem;
	color: var(--ink-soft);
}

.hero__mode-actions {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 10px;
	max-width: 440px;
	margin: 12px auto 0;
}

.hero__mode-btn {
	min-height: 74px;
	padding: 13px 14px;
	font-size: 0.98rem;
	flex-direction: column;
	gap: 3px;
	line-height: 1.25;
	border-radius: 14px;
}

.hero__mode-meta {
	font-size: 0.76rem;
	font-weight: 700;
	opacity: 0.82;
}

.hero__mode-btn--full {
	background: #fbfcfc;
	border-color: #cbd8dd;
}

/* 所要時間を CTA 直上で目立たせる（安心感・離脱対策） */
.hero__time {
	display: inline-block;
	margin: 0 0 12px;
	font-size: 0.86rem;
	font-weight: 800;
	color: var(--primary-dark);
	background: #e8f2f6;
	border-radius: 999px;
	padding: 6px 14px;
}

.hero__time:empty {
	display: none;
}

.hero__time--center {
	display: block;
	width: fit-content;
	margin: 0 auto 12px;
}

/* 信頼バッジ */
.trust-section {
	margin-bottom: 28px;
}

.trust-badges {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	padding: 0;
	margin: 0 0 10px;
}

.trust-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.76rem;
	font-weight: 700;
	color: var(--primary-dark);
	background: #edf5f7;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 6px 12px;
}

.trust-badge__icon {
	font-size: 0.9rem;
}

.hero__note {
	margin-top: 16px;
	font-size: 0.78rem;
	color: var(--ink-soft);
	min-height: 1.2em;
}

/* わかること / 三本柱（アイコン＋一言カード） */
.empathy,
.learn,
.pillars,
.preview,
.type-catalog,
.faq,
.seo-text {
	margin-bottom: 28px;
}

.info-cards {
	display: grid;
	gap: 10px;
}

.info-card {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	background: #fbfcfc;
	border: 1px solid var(--line);
	border-radius: 14px;
	padding: 14px 16px;
}

.info-card__icon {
	font-size: 1.5rem;
	line-height: 1.2;
	flex: 0 0 auto;
}

.info-card__body {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.info-card__title {
	font-weight: 800;
	font-size: 0.98rem;
}

.info-card__desc {
	font-size: 0.84rem;
	color: var(--ink-soft);
	line-height: 1.55;
}

/* 具体例（抽象説明だけでは伝わらない＝必ずサンプルを添える） */
.info-card__example {
	margin-top: 6px;
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--primary-dark);
	background: #edf5f7;
	border-radius: 8px;
	padding: 5px 9px;
	line-height: 1.5;
	align-self: flex-start;
}

/* 三本柱はアクセントの縦ラインで「武器」感を強調 */
.info-cards--pillar .info-card {
	background: linear-gradient(135deg, #f7fafb, #f7f3ed);
	border-left: 4px solid var(--accent);
}

.empathy__lead {
	margin: -4px auto 14px;
	max-width: 34em;
	text-align: center;
	font-size: 0.9rem;
	line-height: 1.7;
	color: var(--ink-soft);
}

.empathy__grid {
	display: grid;
	gap: 10px;
}

.empathy-card {
	background: #fbfcfc;
	border: 1px solid var(--line);
	border-radius: 14px;
	padding: 15px 16px;
}

.empathy-card__title {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--ink);
}

.empathy-card__desc {
	margin: 6px 0 0;
	font-size: 0.82rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

/* 結果プレビュー：本物の結果画面とほぼ同じ見た目のサンプル（主役） */
.result-sample {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 20px 18px;
	margin-bottom: 16px;
}

.result-sample__type {
	text-align: center;
	background: linear-gradient(160deg, #eaf4f7, #f7f3ed);
	border-radius: 14px;
	padding: 16px 12px;
	margin-bottom: 16px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.result-sample__emoji {
	font-size: 2.6rem;
	line-height: 1;
}

.result-sample__image {
	width: 104px;
	max-width: 42vw;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	margin: 0 auto 4px;
	filter: drop-shadow(0 10px 18px rgba(50, 97, 121, 0.16));
}

.result-sample__name {
	font-weight: 800;
	font-size: 1.15rem;
	color: var(--primary-dark);
}

.result-sample__catch {
	font-size: 0.82rem;
	color: var(--ink-soft);
	line-height: 1.5;
}

.result-sample__label {
	font-size: 0.8rem;
	font-weight: 800;
	color: var(--ink);
	margin: 0 0 6px;
}

.result-sample__radar-wrap {
	text-align: center;
	margin-bottom: 16px;
}

.result-sample__radar {
	width: 100%;
	max-width: 280px;
	height: auto;
}

/* ホンネ度メーター（結果ページのメーターと同じ温度感） */
.result-sample__honesty {
	margin-bottom: 16px;
}

.result-sample__honesty-head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	font-size: 0.85rem;
	font-weight: 700;
	margin-bottom: 6px;
}

.result-sample__honesty-val {
	color: var(--c-H);
	font-weight: 800;
	font-variant-numeric: tabular-nums;
}

.result-sample__meter {
	height: 12px;
	border-radius: 999px;
	background: var(--line);
	overflow: hidden;
}

.result-sample__meter-fill {
	height: 100%;
	border-radius: 999px;
	background: linear-gradient(90deg, #c7dce6, #a98bb7);
}

/* 才能TOP5（結果ページの talent と同じ見た目の縮小版） */
.result-sample__talent-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 6px;
}

.result-sample__talent {
	display: flex;
	align-items: center;
	gap: 10px;
	background: #fbfcfc;
	border: 1px solid var(--line);
	border-radius: 10px;
	padding: 8px 12px;
	font-size: 0.88rem;
	font-weight: 700;
}

.result-sample__talent-rank {
	flex: 0 0 auto;
	width: 22px;
	height: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--primary);
	color: #fff;
	font-size: 0.76rem;
	font-weight: 800;
}

.result-sample__note {
	margin: 14px 0 0;
	font-size: 0.74rem;
	color: var(--ink-soft);
	text-align: center;
}

/* 結果プレビュー（動物カードのちら見せ） */
.preview__note {
	text-align: center;
	color: var(--primary-dark);
	font-weight: 700;
	font-size: 0.9rem;
	margin: 0 0 12px;
}

.preview__cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
}

.preview-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 4px;
	background: linear-gradient(160deg, #eaf4f7, #f7f3ed);
	border: 1px solid var(--line);
	border-radius: 14px;
	padding: 14px 8px;
}

.preview-card__emoji {
	font-size: 1.9rem;
	line-height: 1;
}

.preview-card__image {
	width: 64px;
	max-width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	filter: drop-shadow(0 8px 14px rgba(50, 97, 121, 0.14));
}

.preview-card__name {
	font-weight: 800;
	font-size: 0.82rem;
	color: var(--primary-dark);
}

.preview-card__catch {
	font-size: 0.74rem;
	color: var(--ink-soft);
	line-height: 1.45;
}

/* ソーシャルプルーフ枠 */
.social-proof {
	text-align: center;
	background: #f7f3ed;
	border-radius: 14px;
	padding: 16px 16px;
}

.social-proof__main {
	margin: 0;
	font-weight: 700;
	font-size: 0.9rem;
	color: var(--ink);
}

.social-proof__sub {
	margin: 4px 0 0;
	font-size: 0.78rem;
	color: var(--ink-soft);
}

/* 16タイプ一覧：タイプ別公開ページへの入口 */
.type-catalog__lead {
	margin: -4px 0 14px;
	text-align: center;
	font-size: 0.86rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

.type-catalog__note {
	margin: -6px auto 18px;
	max-width: 36em;
	text-align: center;
	font-size: 0.78rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

.type-family {
	margin-top: 18px;
}

.type-family__head {
	margin-bottom: 10px;
	padding: 0 2px;
}

.type-family__title {
	margin: 0;
	font-size: 1rem;
	line-height: 1.4;
	color: var(--ink);
}

.type-family__lead {
	margin: 4px 0 0;
	font-size: 0.8rem;
	line-height: 1.55;
	color: var(--ink-soft);
}

.type-catalog__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.type-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 5px;
	min-width: 0;
	padding: 12px 8px;
	text-align: center;
	text-decoration: none;
	color: inherit;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 14px;
	box-shadow: 0 8px 18px rgba(50, 97, 121, 0.08);
}

.type-card:focus-visible {
	outline: 3px solid rgba(111, 159, 189, 0.38);
	outline-offset: 2px;
}

.type-card__image {
	width: 58px;
	max-width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	filter: drop-shadow(0 8px 14px rgba(50, 97, 121, 0.12));
}

.type-card__name {
	font-size: 0.78rem;
	font-weight: 800;
	color: var(--primary-dark);
	line-height: 1.35;
}

.type-card__catch {
	display: -webkit-box;
	min-height: 3.9em;
	overflow: hidden;
	font-size: 0.68rem;
	line-height: 1.3;
	color: var(--ink-soft);
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}

.type-card__link {
	margin-top: auto;
	font-size: 0.68rem;
	font-weight: 800;
	color: var(--accent);
}

.catalog-link {
	margin: -10px 0 28px;
	text-align: center;
}

.catalog-link a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 14px;
	border: 1px solid #cbd8dd;
	border-radius: 999px;
	background: #fbfcfc;
	color: var(--primary-dark);
	font-size: 0.86rem;
	font-weight: 800;
	text-decoration: none;
}

.catalog-link a:hover {
	border-color: #8fb7d4;
	text-decoration: underline;
}

.faq__list {
	display: grid;
	gap: 10px;
}

.faq-item {
	background: #fbfcfc;
	border: 1px solid var(--line);
	border-radius: 14px;
	padding: 0 14px;
}

.faq-item__q {
	cursor: pointer;
	padding: 13px 2px;
	font-size: 0.92rem;
	font-weight: 800;
	line-height: 1.5;
	color: var(--ink);
}

.faq-item__a {
	margin: 0;
	padding: 0 2px 14px;
	font-size: 0.84rem;
	line-height: 1.65;
	color: var(--ink-soft);
}

.seo-text {
	margin-top: 32px;
	padding-top: 26px;
	border-top: 1px solid var(--line);
}

.seo-text__item + .seo-text__item {
	margin-top: 22px;
}

.seo-text__heading {
	margin: 0 0 8px;
	font-size: 1rem;
	line-height: 1.45;
	color: var(--ink);
}

.seo-text__item p {
	margin: 0;
	font-size: 0.86rem;
	line-height: 1.85;
	color: var(--ink-soft);
}

@media (max-width: 520px) {
	.type-catalog__grid {
		grid-template-columns: 1fr;
	}

	.type-card {
		display: grid;
		grid-template-columns: 64px minmax(0, 1fr);
		grid-template-areas:
			"image name"
			"image catch"
			"image link";
		align-items: center;
		text-align: left;
		padding: 12px 14px;
	}

	.type-card__image {
		grid-area: image;
		width: 64px;
	}

	.type-card__name {
		grid-area: name;
		font-size: 0.84rem;
	}

	.type-card__catch {
		grid-area: catch;
		min-height: auto;
	}

	.type-card__link {
		grid-area: link;
	}
}

/* ---- ボタン ---- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	border: none;
	border-radius: 999px;
	padding: 15px 20px;
	min-height: 44px;
	font-size: 1.02rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	transition:
		transform 0.12s ease,
		box-shadow 0.2s ease,
		background 0.2s ease;
}

.btn:focus-visible,
.share-link:focus-visible {
	outline: 3px solid rgba(50, 97, 121, 0.42);
	outline-offset: 3px;
}

.btn--primary {
	color: #fff;
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--primary-dark) 100%
	);
	box-shadow: 0 8px 18px rgba(50, 97, 121, 0.28);
}

.btn--primary:hover {
	transform: translateY(-1px);
}

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

.btn--primary:disabled {
	opacity: 0.5;
	cursor: not-allowed;
	transform: none;
}

.btn--ghost {
	background: transparent;
	color: var(--primary-dark);
	border: 2px solid var(--line);
}

.btn--ghost:hover {
	background: #f7fafb;
}

/* ---- 進捗・タイマー ---- */
.progress {
	margin-bottom: 26px;
}

.progress__bar {
	height: 8px;
	border-radius: 999px;
	background: var(--line);
	overflow: hidden;
}

.progress__fill {
	height: 100%;
	width: 0%;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--accent), var(--primary));
	transition: width 0.35s ease;
}

.progress__meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 8px;
	font-size: 0.82rem;
	color: var(--ink-soft);
}

.progress__remain-group {
	display: inline-flex;
	align-items: baseline;
	gap: 8px;
}

.progress__meta #progress-remain {
	font-weight: 700;
	color: var(--primary-dark);
}

/* 残り時間（あと約◯分）。終わりが見える＝離脱対策 */
.progress__remain-time {
	font-size: 0.78rem;
	color: var(--ink-soft);
}

.progress__remain-time:empty {
	display: none;
}

.progress__milestone {
	min-height: 1.5em;
	margin: 10px 0 0;
	color: var(--primary-dark);
	font-size: 0.82rem;
	font-weight: 800;
	text-align: center;
}

.progress__milestone:empty {
	display: none;
}

/* ---- 中断再開バナー ---- */
.resume {
	background: linear-gradient(135deg, #eaf4f7, #f7f3ed);
	border: 1px solid var(--line);
	border-radius: 14px;
	padding: 16px 16px;
	margin-bottom: 20px;
}

.resume__msg {
	margin: 0 0 12px;
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--ink);
	line-height: 1.55;
}

.resume__actions {
	display: grid;
	gap: 8px;
}

.resume__btn {
	font-size: 0.95rem;
	padding: 12px 16px;
}

/* ---- カウントダウン（体験の主役） ---- */
.countdown {
	position: relative;
	width: 120px;
	height: 120px;
	margin: 6px auto 4px;
}

.countdown__svg {
	width: 100%;
	height: 100%;
	transform: rotate(-90deg); /* 12時方向から減らす */
}

.countdown__track {
	fill: none;
	stroke: var(--line);
	stroke-width: 8;
}

.countdown__ring {
	fill: none;
	stroke: var(--primary);
	stroke-width: 8;
	stroke-linecap: round;
	/* dasharray/offset は JS で設定。色変化のみトランジション */
	transition: stroke 0.3s ease;
}

.countdown__num {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-variant-numeric: tabular-nums;
	font-weight: 800;
	font-size: 2.6rem;
	color: var(--primary-dark);
	transition: color 0.3s ease;
}

/* 残り僅か：警告色＋軽い鼓動（焦らせすぎない控えめな拍動） */
.countdown.is-urgent .countdown__ring {
	stroke: #e35d5d;
}

.countdown.is-urgent .countdown__num {
	color: #e35d5d;
}

.countdown.is-urgent {
	animation: heartbeat 0.9s ease-in-out infinite;
}

@keyframes heartbeat {
	0%,
	100% {
		transform: scale(1);
	}
	18% {
		transform: scale(1.07);
	}
	36% {
		transform: scale(1);
	}
}

.countdown__hint {
	text-align: center;
	font-size: 0.82rem;
	color: var(--ink-soft);
	margin: 2px 0 18px;
	min-height: 1.2em;
}

.countdown.is-urgent + .countdown__hint {
	color: #e35d5d;
	font-weight: 700;
}

/* ---- 質問 ---- */
.question {
	min-height: 88px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	margin-bottom: 18px;
}

.question__text {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0;
	line-height: 1.4;
}

/* ---- 円ラジオ（サイズ違い・数字なし・色分け） ---- */
/* 円の行を全幅にし、ラベルは下段に左右振り分け（狭い幅でも横はみ出ししない）。
   ソース順 (min → circles → max) を order で「circles上段 / ラベル下段」に並べ替える。 */
.choices {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px 8px;
	margin: 8px 0 16px;
}

.choices__circles {
	order: 1;
	flex: 1 1 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 4px;
}

.choices__label {
	flex: 1 1 0;
	min-width: 0;
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--ink-soft);
	line-height: 1.3;
}

.choices__label--min {
	order: 2;
	text-align: left;
}

.choices__label--max {
	order: 3;
	text-align: right;
}

/* 各円。タップ領域は最低44pxを padding で確保（見た目の円は --circle-size） */
.choice {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: 0;
	border: none;
	background: transparent;
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
}

.choice__dot {
	position: relative;
	display: block;
	width: var(--circle-size, 40px);
	height: var(--circle-size, 40px);
	border-radius: 50%;
	border: 2.5px solid var(--c-disagree);
	background: transparent;
	transition:
		transform 0.15s ease,
		background 0.15s ease,
		box-shadow 0.2s ease,
		border-color 0.15s ease;
}

.choice__symbol {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: calc(var(--circle-size, 40px) * 0.44);
	font-weight: 900;
	line-height: 1;
	opacity: 0;
	transform: scale(0.8);
	transition:
		opacity 0.15s ease,
		transform 0.15s ease;
}

/* 賛成側＝青紫 / 反対側＝ピーチ / 中立＝グレー（色だけに頼らず位置と大小も差にする） */
.choice[data-side="agree"] .choice__dot {
	border-color: var(--c-agree);
}

.choice[data-side="disagree"] .choice__dot {
	border-color: var(--c-disagree);
}

.choice[data-side="neutral"] .choice__dot {
	border-color: var(--ink-soft);
}

.choice:hover .choice__dot {
	transform: scale(1.08);
}

.choice:active .choice__dot {
	transform: scale(0.92);
}

/* 選択時：塗りつぶし＋発光（心地よいフィードバック） */
.choice.is-selected .choice__dot {
	transform: scale(1.12);
	animation: pop 0.22s ease;
}

.choice.is-selected .choice__symbol {
	opacity: 1;
	transform: scale(1);
}

.choice[data-side="agree"].is-selected .choice__dot {
	background: var(--c-agree);
	box-shadow: 0 0 0 6px rgba(111, 159, 189, 0.18);
}

.choice[data-side="disagree"].is-selected .choice__dot {
	background: var(--c-disagree);
	box-shadow: 0 0 0 6px rgba(201, 143, 165, 0.18);
}

.choice[data-side="neutral"].is-selected .choice__dot {
	background: var(--ink-soft);
	box-shadow: 0 0 0 6px rgba(102, 113, 118, 0.16);
}

.choice:focus-visible {
	outline: none;
}

.choice:focus-visible .choice__dot {
	box-shadow: 0 0 0 4px rgba(50, 97, 121, 0.34);
}

@keyframes pop {
	0% {
		transform: scale(0.85);
	}
	60% {
		transform: scale(1.22);
	}
	100% {
		transform: scale(1.12);
	}
}

/* ---- 結果 ---- */
.result-type {
	text-align: center;
	background: linear-gradient(135deg, #eaf4f7, #f7f3ed);
	border-radius: 16px;
	padding: 26px 18px;
	margin-bottom: 26px;
}

.result-type__code {
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	color: var(--ink-soft);
	font-weight: 700;
}

.result-type__name {
	font-size: 1.9rem;
	font-weight: 800;
	margin: 6px 0 4px;
	color: var(--primary-dark);
}

.result-type__image {
	display: block;
	width: min(48vw, 180px);
	max-width: 180px;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	margin: 8px auto 10px;
	filter: drop-shadow(0 14px 24px rgba(50, 97, 121, 0.18));
}

.result-type__catch {
	font-size: 1.02rem;
	color: var(--ink);
	margin: 0 0 12px;
}

.result-type__executive {
	width: min(100%, 640px);
	margin: 12px auto 14px;
	padding: 14px 16px;
	border-left: 5px solid var(--accent);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.78);
	color: var(--ink);
	font-size: 1.02rem;
	font-weight: 850;
	line-height: 1.75;
	text-align: left;
}

.result-type__personal {
	width: min(100%, 520px);
	margin: 10px auto 12px;
	padding: 10px 12px;
	border: 1px solid rgba(122, 180, 166, 0.28);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.64);
	color: var(--ink);
	font-size: 0.9rem;
	font-weight: 800;
	line-height: 1.6;
	text-align: left;
	overflow-wrap: anywhere;
}

.result-type__talent-summary {
	width: min(100%, 520px);
	margin: 10px auto 14px;
	padding: 10px 12px;
	border: 1px solid rgba(231, 227, 242, 0.9);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.72);
	color: var(--primary-dark);
	font-size: 0.9rem;
	font-weight: 800;
	line-height: 1.6;
	text-align: left;
	overflow-wrap: anywhere;
}

.result-type__snapshot {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 96px;
	gap: 12px;
	align-items: stretch;
	margin: 14px 0;
	text-align: left;
}

.result-type__mini,
.result-type__honesty {
	border: 1px solid rgba(231, 227, 242, 0.9);
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.72);
	padding: 12px;
}

.result-type__mini-head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 8px;
	margin-bottom: 8px;
	font-size: 0.8rem;
	font-weight: 800;
	color: var(--primary-dark);
}

.result-type__mini-note {
	font-size: 0.68rem;
	font-weight: 700;
	color: var(--ink-soft);
	white-space: nowrap;
}

.result-type__mini-bars {
	display: grid;
	gap: 6px;
}

.result-type__mini-bar {
	display: grid;
	grid-template-columns: minmax(4.7em, 1fr) minmax(72px, 1.25fr) 2.1em;
	align-items: center;
	gap: 7px;
	min-height: 18px;
	font-size: 0.72rem;
}

.result-type__mini-label {
	color: var(--ink);
	font-weight: 700;
	line-height: 1.25;
	overflow-wrap: anywhere;
}

.result-type__mini-track {
	position: relative;
	display: block;
	height: 7px;
	overflow: hidden;
	border-radius: 999px;
	background: rgba(231, 227, 242, 0.95);
}

.result-type__mini-fill {
	display: block;
	height: 100%;
	border-radius: inherit;
}

.result-type__mini-score {
	color: var(--ink-soft);
	font-weight: 800;
	text-align: right;
	font-variant-numeric: tabular-nums;
}

.result-type__honesty {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.result-type__honesty-label {
	font-size: 0.72rem;
	font-weight: 800;
	color: var(--ink-soft);
}

.result-type__honesty-score {
	color: var(--c-H);
	font-size: 2rem;
	font-weight: 900;
	line-height: 1;
	font-variant-numeric: tabular-nums;
}

.result-type__honesty-score small {
	font-size: 0.78rem;
	font-weight: 800;
}

.result-type__cta-row {
	display: grid;
	gap: 6px;
	justify-items: center;
	margin: 6px 0 14px;
}

.result-type__pair-btn {
	width: min(100%, 260px);
}

.result-type__copy-status {
	min-height: 1.1em;
	color: var(--primary-dark);
	font-size: 0.78rem;
	font-weight: 700;
	overflow-wrap: anywhere;
}

.result-type__narrative {
	font-size: 0.92rem;
	color: var(--ink-soft);
	text-align: left;
	margin: 0;
	white-space: pre-line;
}

.result-type__placeholder {
	font-size: 0.78rem;
	color: var(--accent);
	margin-top: 10px;
}

/* ---- 任意属性・匿名利用同意 ---- */
.data-options {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #fff;
	padding: 16px;
	margin: 0 0 18px;
}

.data-options__title {
	color: var(--primary-dark);
	font-size: 1rem;
	margin: 0 0 6px;
}

.data-options__lead,
.data-options__note,
.data-options__status {
	color: var(--ink-soft);
	font-size: 0.84rem;
	line-height: 1.6;
	margin: 0;
}

.data-options__choices {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 8px;
	margin: 12px 0;
}

.data-options__choice {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #f7fbfa;
	color: var(--ink);
	cursor: pointer;
	font: inherit;
	font-size: 0.84rem;
	font-weight: 900;
	min-height: 44px;
	padding: 8px 10px;
}

.data-options__choice:hover,
.data-options__choice:focus-visible {
	background: #edf5f7;
	border-color: #c8dfe4;
}

.data-options__choice:disabled,
.data-options__skip:disabled,
.data-options__consent input:disabled {
	cursor: default;
	opacity: 0.72;
}

.data-options__consent {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	color: var(--ink);
	font-size: 0.84rem;
	font-weight: 800;
	line-height: 1.5;
	margin: 0 0 10px;
}

.data-options__consent input {
	accent-color: var(--primary);
	margin-top: 0.25em;
}

.data-options__actions {
	display: flex;
	justify-content: flex-start;
	margin: 0 0 10px;
}

.data-options__skip {
	min-width: 120px;
}

.result-type__eyebrow {
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	color: var(--ink-soft);
	font-weight: 700;
}

.result-type__name--soft {
	color: var(--ink);
	font-size: 1.5rem;
}

.result-type__prep {
	font-size: 0.86rem;
	color: var(--ink-soft);
	margin: 4px 0 12px;
}

.result-toc {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 34px;
	padding: 10px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.82);
}

.result-toc__link {
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	padding: 8px 12px;
	border: 1px solid #d7e4ea;
	border-radius: 999px;
	color: var(--accent-dark);
	background: #f7fafb;
	font-size: 0.82rem;
	font-weight: 800;
	text-decoration: none;
}

.result-toc__link:hover {
	background: #e7f2f6;
}

/* ---- 信頼度バッジ（三重防御の見える化） ---- */
.reliability {
	border-radius: 14px;
	padding: 14px 16px;
	margin: 0 0 24px;
	border: 1px solid var(--line);
	background: #f7f5fd;
}

.reliability__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 6px;
}

.reliability__eyebrow {
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	font-weight: 700;
	color: var(--ink-soft);
}

.reliability__badge {
	flex: 0 0 auto;
	font-size: 0.82rem;
	font-weight: 800;
	color: #fff;
	background: var(--primary);
	border-radius: 999px;
	padding: 4px 12px;
}

.reliability__badge-group {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 6px;
}

.reliability__badge--precise {
	color: var(--primary-dark);
	background: #f7f3ed;
	border: 1px solid #d8cab7;
}

.reliability__msg {
	margin: 0;
	font-size: 0.86rem;
	line-height: 1.55;
	color: var(--ink);
}

/* 高=安心グリーン / 中=ニュートラル紫 / 低=やさしいピーチ（責めない） */
.reliability--high {
	background: #eef9f4;
	border-color: #cdebe0;
}
.reliability--high .reliability__badge {
	background: var(--ok);
}

.reliability--mid {
	background: #f3f1fb;
	border-color: #e0d9f5;
}
.reliability--mid .reliability__badge {
	background: var(--primary);
}

.reliability--low {
	background: #fff4ef;
	border-color: var(--accent-soft);
}
.reliability--low .reliability__badge {
	background: var(--accent);
}

.reliability .reliability__badge--precise {
	color: var(--primary-dark);
	background: #f7f3ed;
	border: 1px solid #d8cab7;
}

/* 信頼度の点数（◯/100）＋判定基準（凡例）＋補足 */
.reliability__score-line {
	margin: 2px 0 6px;
	display: flex;
	align-items: baseline;
	gap: 3px;
}

.reliability__score {
	font-size: 1.8rem;
	font-weight: 800;
	line-height: 1;
	color: var(--primary-dark);
	font-variant-numeric: tabular-nums;
}

.reliability--high .reliability__score {
	color: var(--ok);
}
.reliability--low .reliability__score {
	color: var(--accent);
}

.reliability__unit {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--ink-soft);
}

.reliability__legend {
	margin: 0 0 8px;
	font-size: 0.76rem;
	color: var(--ink-soft);
	line-height: 1.5;
}

.reliability__legend-label {
	font-weight: 800;
	margin-right: 6px;
	color: var(--ink);
}

.reliability__note {
	margin: 8px 0 0;
	font-size: 0.76rem;
	color: var(--ink-soft);
	line-height: 1.5;
}

.reliability__parts {
	display: grid;
	gap: 8px;
	margin: 8px 0 10px;
}

.reliability-part {
	display: grid;
	grid-template-columns: minmax(7em, auto) 1fr 2.5em;
	align-items: center;
	gap: 8px;
	font-size: 0.76rem;
}

.reliability-part__label {
	color: var(--ink-soft);
	font-weight: 700;
	white-space: nowrap;
}

.reliability-part__track {
	height: 7px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
	overflow: hidden;
}

.reliability-part__fill {
	display: block;
	height: 100%;
	border-radius: 999px;
}

.reliability-part__score {
	color: var(--ink);
	font-weight: 800;
	text-align: right;
	font-variant-numeric: tabular-nums;
}

.section-title {
	font-size: 1.05rem;
	margin: 34px 0 12px;
	scroll-margin-top: 18px;
}

.screen--result > :first-child + .result-type,
.result-type .section-title {
	margin-top: 0;
}

.radar-wrap {
	display: flex;
	justify-content: center;
	margin-bottom: 22px;
	aspect-ratio: 1 / 0.95;
	min-height: 260px;
}

.radar {
	width: 100%;
	max-width: 360px;
	height: 100%;
	min-height: 260px;
}

/* ---- 共通メーター（SVG） ---- */
.meter-svg {
	width: 100%;
	max-width: 260px;
	margin: 0 auto;
}

.meter-svg svg {
	display: block;
	width: 100%;
	height: auto;
	overflow: visible;
}

.meter-svg__track,
.meter-svg__fill {
	fill: none;
	stroke-width: 14;
	stroke-linecap: round;
}

.meter-svg__track {
	stroke: rgba(231, 227, 242, 0.95);
}

.meter-svg__fill {
	transition: stroke 0.2s ease;
}

.meter-svg__thumb {
	stroke: #fff;
	stroke-width: 3;
	filter: drop-shadow(0 2px 5px rgba(44, 42, 58, 0.18));
}

.meter-svg__labels {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	margin-top: -8px;
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--ink-soft);
}

.meter-svg--reliability {
	margin-top: 4px;
	margin-bottom: 6px;
}

.meter-svg--honesty {
	flex: 0 1 210px;
	min-width: 160px;
	margin: 0;
}

/* ---- 第6軸メーター ---- */
.honesty-meter {
	margin-bottom: 24px;
}

.honesty-meter__lead {
	margin: 0 0 12px;
	font-size: 0.88rem;
	color: var(--ink-soft);
	line-height: 1.6;
}

.honesty-meter__panel {
	display: flex;
	align-items: center;
	gap: 18px;
	border: 1px solid #f0d9ea;
	border-radius: 14px;
	background: linear-gradient(135deg, #fdf6fb, #ffffff 62%);
	padding: 16px 16px 14px;
}

.honesty-meter__body {
	flex: 1 1 auto;
	min-width: 0;
}

.honesty-meter__score {
	margin: 0 0 4px;
	color: var(--c-H);
	font-size: 0.92rem;
	font-weight: 800;
	font-variant-numeric: tabular-nums;
}

.honesty-meter__score span {
	font-size: 2rem;
	line-height: 1;
}

.honesty-meter__band {
	margin: 0 0 6px;
	font-weight: 800;
	color: var(--ink);
}

.honesty-meter__msg {
	margin: 0;
	font-size: 0.86rem;
	color: var(--ink-soft);
	line-height: 1.6;
}

.bars {
	display: grid;
	gap: 14px;
	margin-bottom: 26px;
}

.kv-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
	margin-bottom: 4px;
}

.kv-box {
	min-height: 90px;
	padding: 14px 12px;
	border: 1px solid #d7e4ea;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff, #f3f8fa);
	box-shadow: 0 8px 20px rgba(31, 70, 105, 0.08);
}

.kv-box strong {
	display: block;
	color: var(--accent-dark);
	font-size: clamp(1.8rem, 7vw, 2.6rem);
	line-height: 1;
	font-weight: 900;
	font-variant-numeric: tabular-nums;
}

.kv-box span {
	display: block;
	margin-top: 8px;
	color: var(--ink-soft);
	font-size: 0.78rem;
	font-weight: 800;
	line-height: 1.35;
	overflow-wrap: anywhere;
}

.bar-row__head {
	display: flex;
	justify-content: space-between;
	font-size: 0.85rem;
	margin-bottom: 5px;
}

.bar-row__name {
	font-weight: 700;
}

.bar-row__val {
	color: var(--ink-soft);
	font-variant-numeric: tabular-nums;
}

.bar-row__track {
	height: 12px;
	border-radius: 999px;
	background: var(--line);
	overflow: hidden;
}

.bar-row__fill {
	height: 100%;
	border-radius: 999px;
	width: 0;
	transition: width 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---- 5能力プロファイル ---- */
.ability-chart {
	display: grid;
	gap: 10px;
}

.ability-bar {
	border: 1px solid var(--line);
	border-radius: 12px;
	background: #fbfcfc;
	padding: 12px 14px;
}

.ability-bar__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 4px;
}

.ability-bar__name {
	font-weight: 800;
	font-size: 0.96rem;
}

.ability-bar__score {
	flex: 0 0 auto;
	color: var(--primary-dark);
	font-weight: 800;
	font-size: 0.84rem;
	font-variant-numeric: tabular-nums;
}

.ability-bar__desc,
.ability-bar__note {
	margin: 0;
	color: var(--ink-soft);
	line-height: 1.55;
}

.ability-bar__desc {
	font-size: 0.8rem;
}

.ability-bar__note {
	font-size: 0.72rem;
}

.ability-bar__talent {
	margin: 8px 0 0;
	padding: 8px 10px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid var(--line);
	color: var(--ink);
	font-size: 0.78rem;
	line-height: 1.55;
}

.ability-bar__track {
	height: 10px;
	border-radius: 999px;
	background: var(--line);
	overflow: hidden;
	margin: 9px 0 6px;
}

.ability-bar__fill {
	display: block;
	height: 100%;
	border-radius: 999px;
	background: var(--ability-color, var(--primary));
}

/* ---- 才能TOP5 ---- */
.talents {
	margin-bottom: 26px;
}

/* 才能セクション冒頭の「意味の説明」 */
.talents__intro {
	margin: 0 0 14px;
	font-size: 0.9rem;
	line-height: 1.7;
	color: var(--ink-soft);
}

.business-source {
	margin: -6px 0 14px;
	font-size: 0.78rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

.business-source a {
	color: var(--primary-dark);
	font-weight: 800;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.business-summary {
	display: grid;
	gap: 12px;
	margin: 0 0 18px;
}

.business-summary__overall,
.business-group {
	border: 1px solid var(--line);
	border-radius: 12px;
	background: #fff;
	padding: 12px 14px;
}

.business-summary__overall {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	background: #f3f1fb;
}

.business-summary__label,
.business-summary__subhead {
	font-size: 0.82rem;
	font-weight: 800;
	color: var(--primary-dark);
}

.business-summary__score,
.business-group__score {
	flex: 0 0 auto;
	font-variant-numeric: tabular-nums;
	font-weight: 900;
	color: var(--primary-dark);
}

.business-group__score-label {
	margin-right: 0.45em;
	font-size: 0.7rem;
	font-weight: 800;
	color: var(--ink-soft);
}

.business-summary__groups {
	display: grid;
	gap: 10px;
}

.business-summary__subhead {
	margin: 2px 0 0;
}

.business-group__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
}

.business-group__name {
	font-size: 0.92rem;
	font-weight: 800;
	color: var(--ink);
}

.business-group__desc {
	margin: 5px 0 8px;
	font-size: 0.78rem;
	line-height: 1.55;
	color: var(--ink-soft);
}

.business-group__track {
	height: 9px;
	border-radius: 999px;
	background: var(--line);
	overflow: hidden;
}

.business-group__fill {
	display: block;
	height: 100%;
	border-radius: 999px;
	background: var(--business-color, var(--primary));
}

.talents__list {
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: talent;
	display: grid;
	gap: 10px;
}

.talent {
	display: flex;
	align-items: center;
	gap: 12px;
	background: #fbfcfc;
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 12px 14px;
	counter-increment: talent;
}

.talent::before {
	content: counter(talent);
	flex: 0 0 auto;
	width: 26px;
	height: 26px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--primary);
	color: #fff;
	font-weight: 800;
	font-size: 0.82rem;
}

.talent__dot {
	flex: 0 0 auto;
	width: 10px;
	height: 10px;
	border-radius: 50%;
}

.talent__body {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.talent__name {
	font-weight: 700;
	font-size: 0.96rem;
}

.talent__facet {
	font-size: 0.78rem;
	font-weight: 800;
	color: var(--primary-dark);
}

.talent__desc {
	font-size: 0.8rem;
	color: var(--ink-soft);
}

.talent__uses {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin-top: 5px;
}

.talent__use {
	display: inline-flex;
	align-items: center;
	min-height: 22px;
	border-radius: 999px;
	padding: 2px 8px;
	background: #eef8f5;
	color: #277c68;
	font-size: 0.7rem;
	font-weight: 800;
	line-height: 1.2;
	white-space: nowrap;
}

.talent__hint {
	margin-top: 7px;
	padding: 7px 9px;
	border-radius: 8px;
	background: #fff;
	border: 1px solid rgba(119, 91, 196, 0.16);
	color: var(--ink);
	font-size: 0.78rem;
	line-height: 1.55;
}

.talent__hint strong {
	margin-right: 0.45em;
	color: var(--primary-dark);
	font-size: 0.72rem;
}

.talent__first-step {
	margin-top: 6px;
	color: var(--ink);
	font-size: 0.78rem;
	line-height: 1.55;
}

.talent__first-step strong {
	margin-right: 0.45em;
	color: #277c68;
	font-size: 0.72rem;
}

/* 文脈ラベル（強い／頼ると楽）＋強い領域（因子名）の併記行 */
.talent__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	margin-top: 5px;
}

.talent__context {
	font-size: 0.7rem;
	font-weight: 700;
	border-radius: 999px;
	padding: 2px 8px;
	white-space: nowrap;
}

.talent__context--strength {
	color: var(--primary-dark);
	background: #ece8fb;
}

.talent__context--growth {
	color: #b76b4a;
	background: #ffe9e0;
}

.talent__area {
	font-size: 0.72rem;
	color: var(--ink-soft);
}

.talent__score {
	flex: 0 0 auto;
	font-variant-numeric: tabular-nums;
	font-weight: 800;
	color: var(--primary-dark);
}

.talents__locked {
	background: #f3f1fb;
	border-radius: 12px;
	padding: 16px 16px;
	margin: 0;
	font-size: 0.88rem;
	color: var(--ink-soft);
	text-align: center;
}

.talents__locked strong {
	color: var(--primary-dark);
}

.profile-grid,
.manual-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.profile-disclaimer {
	margin: 0 0 14px;
	padding: 10px 12px;
	border-radius: 10px;
	background: #f7fafb;
	border: 1px solid var(--line);
	color: var(--ink-soft);
	font-size: 0.9rem;
	line-height: 1.65;
}

.note {
	border: 1px solid var(--line);
	border-left: 5px solid var(--accent);
	border-radius: 8px;
	background: #f7fafb;
	padding: 14px 16px;
	color: var(--ink);
}

.note h3 {
	margin: 0 0 8px;
	color: var(--accent-dark);
	font-size: 0.98rem;
	line-height: 1.4;
}

.note p {
	margin: 0;
	color: var(--ink-soft);
	font-size: 0.9rem;
	line-height: 1.75;
}

.note ul {
	margin: 0;
	padding-left: 1.15em;
	color: var(--ink-soft);
	font-size: 0.9rem;
	line-height: 1.75;
}

.note.good {
	border-left-color: #2f7d68;
	background: #f1f8f5;
}

.note.warn {
	border-left-color: #b7791f;
	background: #fff8ec;
}

.note.crit {
	border-left-color: #b84a3a;
	background: #fff1ef;
}

.priority-list {
	display: grid;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.priority-card {
	border: 1px solid #d7e4ea;
	border-radius: 8px;
	background: #fff;
	overflow: hidden;
}

.priority-card__head {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	gap: 10px;
	align-items: center;
	padding: 12px 14px;
	background: #e7f2f6;
	color: var(--accent-dark);
	font-weight: 900;
}

.priority-card__rank {
	font-size: 0.78rem;
	color: var(--ink-soft);
}

.priority-card__axis {
	overflow-wrap: anywhere;
}

.priority-card__score {
	font-variant-numeric: tabular-nums;
}

.priority-card__body {
	display: grid;
	gap: 8px;
	padding: 14px;
}

.priority-card__body p {
	margin: 0;
	color: var(--ink-soft);
	font-size: 0.9rem;
	line-height: 1.7;
}

.priority-card__body strong {
	display: inline-block;
	min-width: 6.5em;
	margin-right: 0.4em;
	color: var(--ink);
}

.manual-section {
	margin: 28px 0;
}

.manual-card {
	border: 1px solid #cfdde3;
	border-radius: 8px;
	background: linear-gradient(180deg, #ffffff, #f4f8fa);
	box-shadow: var(--shadow);
	padding: 18px;
}

.manual-card__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 14px;
}

.manual-card__head > div {
	min-width: 0;
	flex: 1 1 auto;
}

.manual-card__head .section-title {
	margin: 0;
	white-space: normal;
	overflow-wrap: break-word;
	line-height: 1.45;
}

.manual-card__eyebrow {
	margin: 0 0 4px;
	color: var(--ink-soft);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	white-space: normal;
	overflow-wrap: break-word;
}

.manual-card__copy {
	flex: 0 0 auto;
	max-width: 45%;
	white-space: normal;
}

.manual-card__identity {
	margin-bottom: 14px;
	padding: 14px 16px;
	border-radius: 8px;
	background: #e7f2f6;
}

.manual-card__type {
	display: block;
	color: var(--accent-dark);
	font-size: 1.12rem;
	font-weight: 900;
}

.manual-card__identity p {
	margin: 6px 0 0;
	color: var(--ink);
	font-size: 0.94rem;
	font-weight: 750;
	line-height: 1.7;
}

.manual-note {
	min-height: 100%;
}

.manual-card__status {
	min-height: 1.2em;
	margin: 10px 0 0;
	color: var(--accent-dark);
	font-size: 0.82rem;
	font-weight: 800;
	overflow-wrap: anywhere;
}

.historical-section {
	margin: 28px 0;
}

.historical-card {
	border: 1px solid #d8dfd6;
	border-radius: 8px;
	background: #fffdf7;
	box-shadow: var(--shadow);
	padding: 18px;
}

.historical-card__head {
	margin-bottom: 14px;
}

.historical-card__head .section-title {
	margin: 0;
}

.historical-card__eyebrow {
	margin: 0 0 4px;
	color: var(--ink-soft);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.08em;
}

.historical-card__lead,
.historical-card__disclaimer {
	margin: 8px 0 0;
	color: var(--ink-soft);
	font-size: 0.88rem;
	line-height: 1.7;
}

.historical-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
}

.historical-person {
	display: grid;
	gap: 10px;
	min-width: 0;
	padding: 15px;
	border: 1px solid #d7e3ea;
	border-radius: 8px;
	background: #ffffff;
}

.historical-person h3 {
	margin: 0;
	color: var(--ink);
	font-size: 1rem;
	line-height: 1.4;
}

.historical-person__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.historical-person__tags span {
	padding: 4px 8px;
	border-radius: 999px;
	background: #eef5f8;
	color: #26394b;
	font-size: 0.72rem;
	font-weight: 800;
	line-height: 1.35;
}

.historical-person p {
	margin: 0;
	color: var(--ink-soft);
	font-size: 0.9rem;
	line-height: 1.75;
}

.quick-reference {
	margin: 28px 0;
}

.quick-card {
	border: 1px solid #d7e4ea;
	border-radius: 8px;
	background: #fff;
	overflow: hidden;
}

.quick-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
	line-height: 1.65;
}

.quick-table th,
.quick-table td {
	padding: 12px 14px;
	border-bottom: 1px solid var(--line);
	vertical-align: top;
}

.quick-table tr:nth-child(even) td {
	background: #f7fafb;
}

.quick-table tr:last-child th,
.quick-table tr:last-child td {
	border-bottom: 0;
}

.quick-table th {
	width: 9.5em;
	color: #fff;
	background: var(--accent);
	font-weight: 900;
	text-align: left;
}

.quick-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.quick-pill {
	display: inline-flex;
	gap: 4px;
	align-items: baseline;
	padding: 4px 8px;
	border-radius: 999px;
	background: #e7f2f6;
	color: var(--accent-dark);
	font-weight: 800;
}

.quick-pill strong,
.quick-list span {
	font-variant-numeric: tabular-nums;
}

.quick-list {
	margin: 0;
	padding-left: 1.2em;
}

.quick-list li + li {
	margin-top: 4px;
}

.screen--manual-only > :not(#result-title):not(#manual-section) {
	display: none !important;
}

.screen--manual-only #manual-section {
	margin-top: 0;
}

/* のびしろ（これから育つ才能）: 別リストとして再採番＆色を控えめに */
.talents__list--growth {
	margin-top: 16px;
	counter-reset: talent;
}

.talents__subhead {
	font-size: 0.9rem;
	font-weight: 800;
	color: var(--primary-dark);
	margin-bottom: 2px;
}

/* subhead は番号を振らない（counter を増やさない） */
.talents__subhead::before {
	display: none;
}

/* のびしろの説明文（頼ってもいい領域の思想）。番号を振らない。 */
.talents__growth-intro {
	list-style: none;
	margin: 0 0 10px;
	font-size: 0.84rem;
	line-height: 1.7;
	color: var(--ink-soft);
}

.talents__growth-intro::before {
	display: none;
}

.talent--growth {
	background: #fff7f4; /* のびしろは温かみのあるピーチ寄り。ネガに見せない */
	border-color: var(--accent-soft);
}

.talent--growth::before {
	background: var(--accent);
}

/* ---- なぜ当たるか（誠実な根拠） ---- */
.why-accurate {
	background: #f3f1fb;
	border-radius: 14px;
	padding: 18px 16px;
	margin-bottom: 26px;
}

.why-accurate .section-title {
	margin-top: 0;
}

.why-accurate__lead {
	font-size: 0.88rem;
	color: var(--ink-soft);
	margin: 0 0 12px;
}

.why-accurate__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 10px;
}

.why-accurate__item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
}

.why-accurate__icon {
	font-size: 1.2rem;
	line-height: 1.4;
	flex: 0 0 auto;
}

.why-accurate__body {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.why-accurate__title {
	font-weight: 800;
	font-size: 0.92rem;
}

.why-accurate__desc {
	font-size: 0.84rem;
	color: var(--ink-soft);
	line-height: 1.6;
}

/* ---- 因子の3段ナラティブ（モバイルで読みやすい折りたたみ） ---- */
.factors {
	margin-bottom: 26px;
}

.factors__lead {
	font-size: 0.88rem;
	color: var(--ink-soft);
	line-height: 1.6;
	margin: 0 0 14px;
}

.factors__personal {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--primary-dark);
	background: #f3f0ff;
	border: 1px solid #e3def8;
	border-radius: 10px;
	padding: 10px 12px;
	margin: 0 0 12px;
	line-height: 1.6;
}

.factor-card {
	border: 1px solid var(--line);
	border-radius: 14px;
	background: var(--surface);
	padding: 0;
	margin-bottom: 12px;
	overflow: hidden;
}

/* 第6軸（正直さ）の持ち味カード。差別化を示すローズ系のアクセント */
.factor-card--sixth {
	border-color: #f0d9ea;
	background: linear-gradient(135deg, #fdf6fb, var(--surface) 60%);
}

.factor-card__eyebrow {
	display: block;
	font-size: 0.7rem;
	letter-spacing: 0.06em;
	font-weight: 800;
	color: #c25d9e;
	margin-bottom: 6px;
}

.factor-card__featured {
	display: inline-block;
	font-size: 0.72rem;
	font-weight: 800;
	color: #fff;
	background: var(--primary-dark);
	border-radius: 999px;
	padding: 3px 10px;
	margin: 0 0 8px;
}

.factor-card__summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	min-height: 44px;
	padding: 16px;
	cursor: pointer;
	list-style: none;
}

.factor-card__summary::-webkit-details-marker {
	display: none;
}

.factor-card__summary-main {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.factor-card__head {
	display: flex;
	align-items: center;
	gap: 9px;
	margin-bottom: 0;
}

.factor-card__dot {
	flex: 0 0 auto;
	width: 12px;
	height: 12px;
	border-radius: 50%;
}

.factor-card__name {
	flex: 1 1 auto;
	font-weight: 800;
	font-size: 1.02rem;
	min-width: 0;
}

.factor-card__score {
	flex: 0 0 auto;
	font-variant-numeric: tabular-nums;
	font-weight: 800;
	color: var(--primary-dark);
}

.factor-card__toggle {
	flex: 0 0 auto;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 5px 10px;
	color: var(--primary-dark);
	background: #f7fafb;
	font-size: 0.82rem;
	font-weight: 800;
}

.factor-card[open] .factor-card__toggle::before {
	content: "閉じる";
}

.factor-card:not([open]) .factor-card__toggle::before {
	content: "開く";
}

.factor-card__detail {
	padding: 0 16px 18px;
}

.factor-card__track {
	height: 8px;
	border-radius: 999px;
	background: var(--line);
	overflow: hidden;
	margin-bottom: 12px;
}

.factor-card__fill {
	height: 100%;
	border-radius: 999px;
}

.factor-card__lead {
	font-weight: 700;
	font-size: 0.95rem;
	color: var(--ink);
	margin: 0;
	line-height: 1.55;
}

.factor-card__facet {
	font-size: 0.88rem;
	line-height: 1.65;
	color: var(--ink);
	background: #f7fbff;
	border: 1px solid #dcecf8;
	border-radius: 10px;
	padding: 9px 10px;
	margin: 0 0 10px;
}

.factor-card__facet-hint {
	display: block;
	margin-top: 6px;
	color: #2c6f95;
	font-weight: 700;
}

.factor-card__recognition {
	font-size: 0.92rem;
	color: var(--primary-dark);
	font-weight: 600;
	margin: 0 0 8px;
	line-height: 1.65;
}

.factor-card__specifics {
	font-size: 0.92rem;
	color: var(--ink);
	line-height: 1.75;
	margin: 0 0 10px;
}

.factor-card__cost,
.factor-card__action {
	font-size: 0.88rem;
	line-height: 1.7;
	margin: 0 0 8px;
	color: var(--ink);
}

.factor-card__action:last-child {
	margin-bottom: 0;
}

.factor-card__tag {
	display: inline-block;
	font-size: 0.72rem;
	font-weight: 800;
	border-radius: 6px;
	padding: 2px 8px;
	margin-right: 6px;
	vertical-align: 0.06em;
}

.factor-card__tag--cost {
	background: #fff0ea;
	color: #c2693f;
}

/* 活かし方: 仕事＝青緑 / 恋愛・人間関係＝ローズ（女性層に響く差し色） */
.factor-card__tag--work {
	background: #eaf6f1;
	color: #2f8f6e;
}

.factor-card__tag--life {
	background: #fdeef5;
	color: #c25d8e;
}

.factor-card__tag--facet {
	background: #e7f2fb;
	color: #2c6f95;
}

/* ---- 締めの前向きメッセージ ---- */
.closing {
	background: linear-gradient(135deg, #eaf4f7, #f7f3ed);
	border-radius: 16px;
	padding: 22px 18px;
	margin-bottom: 24px;
	text-align: center;
}

.closing__heading {
	font-size: 1.1rem;
	font-weight: 800;
	color: var(--primary-dark);
	margin: 0 0 10px;
}

.closing__body {
	font-size: 0.92rem;
	color: var(--ink);
	line-height: 1.8;
	margin: 0;
}

.closing__share {
	font-size: 0.86rem;
	font-weight: 700;
	color: var(--primary-dark);
	margin: 12px 0 0;
}

/* ---- 友だちに見せるカード ---- */
.share-cards {
	margin: 0 0 24px;
}

.share-cards__lead {
	margin: 0 0 12px;
	font-size: 0.88rem;
	line-height: 1.65;
	color: var(--ink-soft);
}

.share-cards__grid {
	display: grid;
	gap: 10px;
}

.share-card {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #fff;
	padding: 14px;
	overflow: hidden;
}

.share-card--result {
	background: linear-gradient(135deg, #f7f3ed, #eaf4f7);
	border-color: var(--accent-soft);
}

.share-card--quote {
	background: linear-gradient(135deg, #f2fbf7, #f7fafb);
	border-color: #d7eee4;
}

.share-card--pair {
	background: linear-gradient(135deg, #eef8ff, #f7f3ed);
	border-color: #d7e8f2;
}

.share-card__top,
.share-card__body {
	display: flex;
	align-items: center;
	gap: 12px;
}

.share-card__top {
	justify-content: space-between;
	margin-bottom: 10px;
}

.share-card__label {
	font-size: 0.78rem;
	font-weight: 800;
	color: var(--primary-dark);
}

.share-card__badge {
	flex: 0 0 auto;
	font-size: 0.72rem;
	font-weight: 800;
	color: #fff;
	background: var(--primary);
	border-radius: 999px;
	padding: 3px 9px;
}

.share-card__image {
	flex: 0 0 auto;
	width: 74px;
	max-width: 22vw;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	filter: drop-shadow(0 8px 14px rgba(50, 97, 121, 0.14));
}

.share-card__copy {
	min-width: 0;
}

.share-card__title {
	margin: 0 0 4px;
	font-size: 1.02rem;
	line-height: 1.35;
	color: var(--ink);
}

.share-card__text {
	margin: 0;
	font-size: 0.86rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

.share-card__url {
	margin-top: 10px;
	border: 1px solid var(--line);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
	color: var(--primary-dark);
	font: inherit;
	font-size: 0.78rem;
	font-weight: 800;
	padding: 6px 12px;
	min-height: 44px;
	cursor: pointer;
}

.share-card__url:focus-visible {
	outline: 3px solid rgba(94, 115, 255, 0.25);
	outline-offset: 2px;
}

/* ---- 当たり度フィードバック ---- */
.feedback {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #fff;
	padding: 16px;
	margin: 0 0 24px;
}

.feedback__lead,
.feedback__status,
.feedback__saved {
	font-size: 0.86rem;
	line-height: 1.6;
	color: var(--ink-soft);
	margin: 0;
}

.feedback__form {
	display: grid;
	gap: 12px;
}

.feedback__scale {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	align-items: center;
	gap: 8px;
}

.feedback__scale-label {
	font-size: 0.72rem;
	font-weight: 800;
	color: var(--ink-soft);
	white-space: nowrap;
}

.feedback__ratings {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 6px;
}

.feedback__rating {
	min-width: 0;
	min-height: 44px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #f8f6ff;
	color: var(--primary-dark);
	font: inherit;
	font-weight: 900;
	cursor: pointer;
	transition: transform 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.feedback__rating:hover,
.feedback__rating.is-selected {
	background: var(--primary);
	color: #fff;
	transform: translateY(-1px);
}

.feedback__field {
	display: grid;
	gap: 6px;
	font-size: 0.82rem;
	font-weight: 800;
	color: var(--ink);
}

.feedback__text {
	width: 100%;
	resize: vertical;
	border: 1px solid var(--line);
	border-radius: 8px;
	padding: 10px 12px;
	font: inherit;
	color: var(--ink);
	background: #fff;
}

.feedback__check {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 0.84rem;
	line-height: 1.5;
	color: var(--ink-soft);
}

.feedback__check input {
	margin-top: 0.25em;
	accent-color: var(--primary);
}

.feedback__submit {
	width: 100%;
}

.feedback__thanks {
	display: grid;
	gap: 6px;
	text-align: center;
}

.feedback__thanks-main {
	font-size: 0.94rem;
	font-weight: 800;
	color: var(--primary-dark);
	margin: 0;
}

/* ---- 向いてる仕事（適職） ---- */
.career {
	margin-bottom: 26px;
}

.career__lead {
	font-size: 0.84rem;
	color: var(--ink-soft);
	margin: 0 0 12px;
	line-height: 1.55;
}

.career__lead strong {
	color: var(--primary-dark);
}

.career__card {
	background: linear-gradient(135deg, #eef4fd, #f6f1ff);
	border: 1px solid #dde6f5;
	border-radius: 14px;
	padding: 18px 16px;
}

.career__keyword {
	font-weight: 800;
	font-size: 1.15rem;
	color: var(--primary-dark);
	margin: 0 0 8px;
}

.career__keyword--soft {
	color: var(--ink-soft);
	font-size: 1rem;
}

.career__reason {
	font-size: 0.9rem;
	color: var(--ink);
	line-height: 1.6;
	margin: 0 0 12px;
}

.career__roles {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 0;
	margin: 0;
}

.career__role {
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--primary-dark);
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 999px;
	padding: 6px 12px;
}

.career__supplements {
	list-style: none;
	padding: 0;
	margin: 14px 0 0;
	display: grid;
	gap: 8px;
}

.career__supplement {
	position: relative;
	padding-left: 22px;
	font-size: 0.84rem;
	color: var(--ink);
	line-height: 1.55;
}

.career__supplement::before {
	content: "＋";
	position: absolute;
	left: 2px;
	top: 0;
	color: var(--accent);
	font-weight: 800;
}

.career__talent-hint {
	margin: 14px 0 0;
	padding: 12px 13px;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid var(--line);
	color: var(--ink);
	font-size: 0.84rem;
	line-height: 1.6;
}

.career__talent-hint span {
	display: inline-block;
	margin-right: 8px;
	color: var(--primary-dark);
	font-weight: 800;
}

.career__disclaimer {
	font-size: 0.76rem;
	color: var(--ink-soft);
	line-height: 1.6;
	margin: 12px 2px 0;
}

/* ---- 16タイプ相性マップ ---- */
.compat-section {
	margin-bottom: 26px;
}

.compat-contexts {
	display: grid;
	gap: 18px;
}

.compat-context {
	display: grid;
	gap: 12px;
	border: 1px solid var(--line);
	border-radius: 8px;
	padding: 0;
	background: #fff;
	overflow: hidden;
}

.compat-context__summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	min-height: 44px;
	padding: 14px 14px;
	cursor: pointer;
	list-style: none;
	background: #f7fafb;
}

.compat-context__summary::-webkit-details-marker {
	display: none;
}

.compat-context__toggle {
	flex: 0 0 auto;
	border-radius: 999px;
	border: 1px solid #d7e4ea;
	background: #ffffff;
	color: var(--primary-dark);
	font-size: 0.82rem;
	font-weight: 800;
	padding: 5px 10px;
}

.compat-context[open] .compat-context__toggle::before {
	content: "閉じる";
}

.compat-context:not([open]) .compat-context__toggle::before {
	content: "開く";
}

.compat-context__head {
	display: grid;
	gap: 6px;
	padding: 0 14px;
}

.compat-context__title {
	margin: 0;
	font-size: 1rem;
	color: var(--primary-dark);
}

.compat-context__lead,
.compat-context__rule {
	margin: 0;
	font-size: 0.84rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

.compat-context__rule {
	color: var(--ink);
	font-weight: 700;
}

.compat-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 10px;
	padding: 0 14px 14px;
}

.compat {
	min-height: 168px;
	background: linear-gradient(135deg, #f7f3ed, #eaf4f7);
	border: 1px solid var(--accent-soft);
	border-radius: 8px;
	padding: 14px 14px;
}

.compat-context--work .compat {
	background: linear-gradient(135deg, #eef8ff, #f2fbf5);
	border-color: rgba(74, 168, 216, 0.24);
}

.compat--self {
	border-color: var(--accent);
	box-shadow: 0 0 0 1px rgba(232, 96, 127, 0.14) inset;
}

.compat__rank {
	flex: 0 0 auto;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--accent);
	color: #fff;
	font-weight: 800;
	font-size: 0.86rem;
}

.compat__body {
	display: flex;
	flex-direction: column;
	min-width: 0;
	gap: 6px;
}

.compat__name {
	font-weight: 700;
	font-size: 1rem;
	color: var(--primary-dark);
}

.compat__name--soft {
	color: var(--ink);
	font-weight: 700;
}

.compat__reason {
	font-size: 0.86rem;
	color: var(--ink-soft);
	line-height: 1.55;
}

/* 相性セクションのリード文（相性度の説明） */
.compat-lead {
	margin: 0 0 12px;
	font-size: 0.86rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

.compat__name-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	min-height: 24px;
}

.compat__self {
	flex: 0 0 auto;
	padding: 3px 8px;
	border-radius: 999px;
	background: rgba(232, 96, 127, 0.12);
	color: var(--accent-dark, #c25d9e);
	font-size: 0.72rem;
	font-weight: 800;
}

/* 相性度：ハート/星＋点数。色だけに頼らず形でも度合いが分かる。 */
.compat__score-row {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	margin: 4px 0 2px;
}

.compat__marks {
	display: inline-flex;
	gap: 1px;
	font-size: 0.98rem;
	line-height: 1;
}

.compat__mark {
	color: #e3c8d6; /* 空ハート（淡いローズ） */
}

.compat__marks--star .compat__mark {
	color: #c7dbe5;
}

.compat__mark.is-on {
	color: #e8607f; /* 満ちたハート（はっきりしたローズ） */
}

.compat__marks--star .compat__mark.is-on {
	color: #4aa8d8;
}

.compat__score {
	font-size: 0.82rem;
	font-weight: 800;
	color: var(--accent-dark, #c25d9e);
	font-variant-numeric: tabular-nums;
}

.compat__score-label {
	font-weight: 700;
	color: var(--ink-soft);
	margin-right: 4px;
}

@media (max-width: 520px) {
	.kv-grid,
	.profile-grid,
	.manual-grid,
	.historical-grid {
		grid-template-columns: 1fr;
	}

	.manual-card__head {
		display: grid;
		grid-template-columns: 1fr;
	}

	.manual-card__copy {
		max-width: none;
		width: 100%;
	}

	.quick-table,
	.quick-table tbody,
	.quick-table tr,
	.quick-table th,
	.quick-table td {
		display: block;
		width: 100%;
	}

	.quick-table th {
		border-bottom: 0;
	}

	.quick-table td {
		border-bottom: 1px solid var(--line);
	}

	.compat-grid {
		grid-template-columns: 1fr;
	}

	.compat {
		min-height: auto;
	}
}

/* 情緒安定性(=100-N)・正直さ(第6軸)は「6つの軸」に統合（旧 .condition / .honesty 別枠は廃止）。
   第6軸の差別化アクセントは .factor-card--sixth / .factor-card__eyebrow に移設済み。 */

.result-actions {
	display: grid;
	gap: 10px;
}

.share-link {
	text-decoration: none;
}

.share-hint {
	text-align: center;
	font-size: 0.8rem;
	color: var(--primary-dark);
	margin: 10px 0 0;
	min-height: 1.1em;
	word-break: break-all;
}

.pair-result {
	margin: 0 0 24px;
}

.pair-result__lead {
	text-align: center;
	color: var(--ink-soft);
	font-size: 0.9rem;
	line-height: 1.65;
	margin: -8px 0 14px;
}

.pair-result__grid {
	display: grid;
	gap: 12px;
}

.pair-result__share-card {
	border: 1px solid #d7e8f2;
	border-radius: 8px;
	background: linear-gradient(135deg, #eef8ff, #f7f3ed);
	padding: 16px;
	margin-bottom: 12px;
	overflow: hidden;
}

.pair-result__people {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	align-items: start;
	gap: 10px;
}

.pair-result__person {
	min-width: 0;
	display: grid;
	justify-items: center;
	gap: 4px;
	text-align: center;
}

.pair-result__avatar-img,
.pair-result__avatar-fallback {
	width: min(108px, 34vw);
	aspect-ratio: 1 / 1;
	object-fit: contain;
	filter: drop-shadow(0 10px 16px rgba(74, 168, 216, 0.16));
}

.pair-result__avatar-fallback {
	display: grid;
	place-items: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.74);
	color: var(--primary-dark);
	font-weight: 900;
}

.pair-result__join {
	align-self: center;
	color: var(--primary-dark);
	font-size: 0.9rem;
	font-weight: 900;
}

.pair-result__role {
	font-size: 0.72rem;
	font-weight: 800;
	color: var(--ink-soft);
}

.pair-result__type-name {
	max-width: 100%;
	color: var(--ink);
	font-size: 0.98rem;
	font-weight: 900;
	line-height: 1.35;
	overflow-wrap: anywhere;
}

.pair-result__pills {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-top: 12px;
}

.pair-result__pill {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	border: 1px solid rgba(74, 168, 216, 0.2);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
	padding: 6px 10px;
}

.pair-result__pill--featured {
	border-color: rgba(255, 126, 99, 0.42);
	background: #fff7f4;
	box-shadow: 0 8px 18px rgba(255, 126, 99, 0.16);
}

.pair-result__pill-badge {
	align-self: center;
	border-radius: 999px;
	background: var(--accent);
	color: #fff;
	font-size: 0.68rem;
	font-weight: 900;
	line-height: 1;
	padding: 4px 6px;
	white-space: nowrap;
}

.pair-result__pill-label {
	color: var(--ink-soft);
	font-size: 0.78rem;
	font-weight: 800;
}

.pair-result__pill-score {
	color: var(--primary-dark);
	font-size: 0.9rem;
	font-weight: 900;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.pair-result__tip {
	margin: 12px 0 0;
	color: var(--ink);
	font-size: 0.9rem;
	font-weight: 700;
	line-height: 1.65;
	text-align: center;
}

.pair-result__tip span {
	display: inline-block;
	margin-right: 6px;
	color: var(--accent-dark);
	font-size: 0.74rem;
	font-weight: 900;
}

.pair-result__card {
	border: 1px solid var(--line);
	background: #fff;
	border-radius: 8px;
	padding: 14px 16px;
}

.pair-result__card--featured {
	border-color: rgba(255, 126, 99, 0.38);
	background: #fffaf7;
	box-shadow: 0 10px 22px rgba(255, 126, 99, 0.12);
}

.pair-result__label {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	font-weight: 800;
	color: var(--primary-dark);
	margin-bottom: 8px;
}

.pair-result__label-badge {
	border-radius: 999px;
	background: var(--accent);
	color: #fff;
	font-size: 0.68rem;
	font-weight: 900;
	line-height: 1;
	padding: 4px 6px;
	white-space: nowrap;
}

.pair-result__score-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 8px;
}

.pair-result__score {
	font-weight: 800;
	color: var(--ink);
	white-space: nowrap;
}

.pair-result__reason {
	display: block;
	color: var(--ink-soft);
	font-size: 0.88rem;
	line-height: 1.6;
}

.pair-result__talent {
	display: block;
	border-left: 3px solid rgba(74, 168, 216, 0.42);
	background: #f4fbff;
	color: var(--ink);
	font-size: 0.82rem;
	font-weight: 700;
	line-height: 1.6;
	margin-top: 10px;
	padding: 8px 10px;
}

.pair-result__talent--card {
	margin: 10px auto 0;
	max-width: 34rem;
	text-align: left;
}

.pair-result__copy-row {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}

.pair-result__share-preview {
	flex-basis: 100%;
	display: grid;
	gap: 4px;
	border: 1px solid rgba(111, 159, 189, 0.2);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.82);
	padding: 10px 12px;
}

.pair-result__share-preview-label {
	color: var(--primary-dark);
	font-size: 0.72rem;
	font-weight: 900;
}

.pair-result__share-preview-text {
	color: var(--ink);
	font-size: 0.82rem;
	line-height: 1.6;
	overflow-wrap: anywhere;
}

.pair-result__share-preview-count {
	color: var(--muted);
	font-size: 0.72rem;
	font-weight: 800;
	line-height: 1.5;
}

.pair-result__copy-btn {
	border: 1px solid rgba(111, 159, 189, 0.28);
	border-radius: 999px;
	background: #edf5f7;
	color: var(--primary-dark);
	cursor: pointer;
	font: inherit;
	font-size: 0.78rem;
	font-weight: 900;
	min-height: 36px;
	padding: 7px 12px;
}

.pair-result__copy-btn:hover {
	background: #ede8ff;
}

.pair-result__share-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 126, 99, 0.3);
	border-radius: 999px;
	background: #fff7f4;
	color: #b94c35;
	font-size: 0.78rem;
	font-weight: 900;
	min-height: 36px;
	padding: 7px 12px;
	text-decoration: none;
}

.pair-result__share-link:hover {
	background: #ffe9e2;
}

.pair-result__copy-status {
	color: var(--primary-dark);
	font-size: 0.76rem;
	font-weight: 800;
	overflow-wrap: anywhere;
}

.pair-result__share-note {
	flex-basis: 100%;
	color: var(--muted);
	font-size: 0.78rem;
	line-height: 1.6;
}

@media (max-width: 420px) {
	.app {
		padding: 14px 12px 44px;
	}

	.screen {
		padding: 24px 16px 28px;
	}

	.screen--result {
		padding: 28px 24px 34px;
	}

	.screen--result p,
	.screen--result li,
	.screen--result a,
	.screen--result button,
	.screen--result th,
	.screen--result td,
	.screen--result textarea,
	.screen--result label {
		font-size: 1rem;
	}

	.hero__title {
		font-size: 1.5rem;
	}

	.hero__lead,
	.seo-text__item p {
		font-size: 1rem;
	}

	.question__text {
		font-size: 1.28rem;
	}

	.choices__circles {
		gap: 0;
	}

	.choice {
		min-width: 46px;
		min-height: 46px;
	}

	.choice__dot {
		max-width: 52px;
		max-height: 52px;
	}

	.pair-result__share-card {
		padding: 14px 12px;
	}

	.pair-result__people {
		gap: 6px;
	}

	.pair-result__avatar-img,
	.pair-result__avatar-fallback {
		width: min(92px, 31vw);
	}

	.pair-result__type-name {
		font-size: 0.9rem;
	}
}

.result__disclaimer {
	text-align: center;
	font-size: 0.74rem;
	color: var(--ink-soft);
	margin: 18px 0 0;
}

.error-banner {
	background: #ffecec;
	color: #b23b3b;
	border-radius: 12px;
	padding: 14px 16px;
	font-size: 0.86rem;
	margin-top: 16px;
}

/* ---- アクセシビリティ: 動きを抑える設定の尊重 ---- */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}
	.countdown.is-urgent {
		animation: none;
	}
	.choice.is-selected .choice__dot {
		animation: none;
	}

	.countdown__ring,
	.countdown__num,
	.progress__fill,
	.bar-row__fill,
	.meter-svg__fill {
		transition: none !important;
	}
}

/* ===== フッター（全画面共通） ===== */
.site-footer {
	margin-top: 28px;
	padding: 22px 4px 8px;
	border-top: 1px solid var(--line);
	text-align: center;
}

.site-footer__nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 4px 8px;
}

.site-footer__nav a {
	color: var(--ink-soft);
	text-decoration: none;
	font-size: 0.85rem;
	/* タップ領域 44px を確保 */
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	padding: 0 8px;
}

.site-footer__nav a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

.site-footer__copy {
	margin: 14px 0 0;
	font-size: 0.72rem;
	color: var(--ink-soft);
}

/* ===== 法務・運営ページ（legal.html） ===== */
.brand--link {
	text-decoration: none;
}

.brand--link:hover {
	text-decoration: underline;
}

.legal-draft-notice {
	background: #fff4ef;
	border: 1px solid var(--accent-soft);
	border-radius: 12px;
	padding: 12px 14px;
	font-size: 0.82rem;
	color: #b5673f;
	margin: 0 0 18px;
	line-height: 1.6;
}

.legal-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 22px;
}

.legal-nav__link {
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--primary-dark);
	background: #edf5f7;
	border: 1px solid var(--line);
	border-radius: 999px;
	text-decoration: none;
	/* タップ領域 44px */
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	padding: 0 14px;
}

.legal-nav__link:hover {
	background: #e7e1fb;
}

.legal-section {
	background: var(--surface);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 22px 20px;
	margin-bottom: 18px;
	scroll-margin-top: 16px;
}

.legal-section__title {
	font-size: 1.25rem;
	margin: 0 0 8px;
	color: var(--primary-dark);
}

.legal-section__intro {
	font-size: 0.9rem;
	color: var(--ink-soft);
	line-height: 1.7;
	margin: 0 0 14px;
}

.legal-block {
	margin-bottom: 16px;
}

.legal-block__heading {
	font-size: 0.98rem;
	font-weight: 800;
	margin: 0 0 6px;
}

.legal-block__p {
	font-size: 0.88rem;
	line-height: 1.75;
	color: var(--ink);
	margin: 0 0 6px;
}

.legal-section__intro strong,
.legal-block__p strong {
	color: var(--primary-dark);
	font-weight: 900;
}

.legal-checklist {
	list-style: none;
	display: grid;
	gap: 10px;
	margin: 16px 0 0;
	padding: 0;
}

.legal-checklist-summary {
	border: 1px solid #f3d7c8;
	border-radius: 14px;
	background: #fff8f3;
	margin: 18px 0 0;
	padding: 14px 16px;
}

.legal-checklist-summary--done {
	border-color: #cdeedc;
	background: #f3fbf7;
}

.legal-checklist-summary__title {
	color: var(--ink);
	font-size: 0.94rem;
	font-weight: 900;
	margin: 0;
}

.legal-checklist-summary__intro {
	color: var(--ink-soft);
	font-size: 0.84rem;
	line-height: 1.65;
	margin: 6px 0 0;
}

.legal-checklist-summary__list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	list-style: none;
	margin: 10px 0 0;
	padding: 0;
}

.legal-checklist-summary__list li {
	border-radius: 999px;
	background: #ffffff;
	border: 1px solid #f3d7c8;
	color: #8d4f30;
	font-size: 0.78rem;
	font-weight: 800;
	line-height: 1.2;
	padding: 7px 10px;
}

.legal-checklist__item {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 10px;
	align-items: start;
	border-top: 1px solid var(--line);
	padding: 12px 0 0;
}

.legal-checklist__item:first-child {
	border-top: 0;
	padding-top: 0;
}

.legal-checklist__status {
	border-radius: 999px;
	background: #fff4ef;
	color: #b5673f;
	font-size: 0.74rem;
	font-weight: 800;
	line-height: 1;
	padding: 7px 9px;
	white-space: nowrap;
}

.legal-checklist__item--done .legal-checklist__status {
	background: #e9f8f0;
	color: #217a4e;
}

.legal-checklist-done {
	border: 1px solid #dcefe6;
	border-radius: 14px;
	background: #f7fcfa;
	margin: 12px 0 0;
	padding: 0;
}

.legal-checklist-done__summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	min-height: 44px;
	padding: 0 14px;
	color: #217a4e;
	cursor: pointer;
	font-size: 0.86rem;
	font-weight: 900;
	list-style: none;
}

.legal-checklist-done__summary::-webkit-details-marker {
	display: none;
}

.legal-checklist-done__summary::after {
	content: "開く";
	color: var(--ink-soft);
	font-size: 0.76rem;
	font-weight: 800;
}

.legal-checklist-done[open] .legal-checklist-done__summary::after {
	content: "閉じる";
}

.legal-checklist-done__count {
	border-radius: 999px;
	background: #e9f8f0;
	color: #217a4e;
	font-size: 0.74rem;
	line-height: 1;
	padding: 6px 9px;
	white-space: nowrap;
}

.legal-checklist-done .legal-checklist {
	margin: 0;
	padding: 0 14px 14px;
}

.legal-checklist-done .legal-checklist__item:first-child {
	border-top: 1px solid #dcefe6;
	padding-top: 12px;
}

.legal-checklist__body {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.legal-checklist__label {
	font-size: 0.9rem;
	font-weight: 800;
	color: var(--ink);
}

.legal-checklist__detail {
	font-size: 0.84rem;
	line-height: 1.65;
	color: var(--ink-soft);
}

.legal-error {
	background: #ffecec;
	color: #b23b3b;
	border-radius: 12px;
	padding: 14px 16px;
	font-size: 0.86rem;
}

.legal-back {
	text-align: center;
	margin: 22px 0 0;
}

.legal-back a {
	color: var(--ink-soft);
	font-size: 0.85rem;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 12px;
}

.legal-back a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

@media (max-width: 420px) {
	.app {
		padding-inline: 12px;
	}

	.screen {
		padding-inline: 16px;
	}

	.screen--result {
		padding-inline: 24px;
	}

	.reliability__head,
	.bar-row__head,
	.ability-bar__head {
		align-items: flex-start;
		flex-direction: column;
		gap: 4px;
	}

	.reliability__badge {
		align-self: flex-start;
	}

	.reliability-part {
		grid-template-columns: 1fr 2.4em;
	}

	.reliability-part__label {
		grid-column: 1 / -1;
	}

	.honesty-meter__panel {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
	}

	.meter-svg--honesty {
		width: 100%;
		max-width: 240px;
		margin: 0 auto;
	}

	.honesty-meter__body {
		text-align: center;
	}

	.result-type {
		padding-inline: 14px;
	}

	.data-options__choices {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.result-type__snapshot {
		grid-template-columns: 1fr;
	}

	.result-type__honesty {
		min-height: 86px;
	}

	.result-type__mini-head {
		align-items: flex-start;
		flex-direction: column;
		gap: 2px;
	}

	.result-type__mini-bar {
		grid-template-columns: minmax(0, 5.2em) minmax(80px, 1fr) 2em;
	}

	.radar {
		max-width: 100%;
	}

	.share-card__body {
		align-items: flex-start;
	}

	.share-card__image {
		width: 62px;
		max-width: 24vw;
	}

	.feedback__scale {
		grid-template-columns: 1fr;
	}

	.feedback__scale-label {
		text-align: center;
	}
}
