/*
 * WIM — Sprint 6 additions
 *
 * pptx 由来のキャッチコピー / pain solution / 4 プラン化 / 運用コスト内訳 /
 * 3 段階モデル / SaaS vs AIエージェント / プロフィールメッセージ。
 *
 * すべて var(--wim-*) トークン経由。直値カラー禁止。
 *
 * @package WIM
 */

/* ============================================================
 * Hero — sub-eyebrow / keywords バッジ
 * ============================================================ */
.wim-hero__sub-eyebrow {
	margin: 0 0 var(--wim-space-4);
	color: var(--wim-muted);
	font-size: var(--wim-fs-lead);
	letter-spacing: var(--wim-ls-body);
	font-weight: var(--wim-weight-medium);
	line-height: var(--wim-lh-body);
}

.wim-hero__title {
	/* Sprint 6: メインコピーの行間調整（serif 大見出し） */
	line-height: 1.25;
}

.wim-hero__keywords {
	list-style: none;
	padding: 0;
	margin: var(--wim-space-6) 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--wim-space-3);
}
.wim-hero__keyword {
	display: inline-flex;
	align-items: center;
	padding: 0.4em 0.9em;
	border-radius: 999px;
	background-color: var(--wim-bg-paper);
	color: var(--wim-ink);
	font-size: var(--wim-fs-caption);
	letter-spacing: var(--wim-ls-meta);
	font-weight: var(--wim-weight-medium);
	border: 1px solid var(--wim-line);
}
.wim-hero__keyword:nth-child(odd) {
	background-color: var(--wim-gold-soft);
	color: var(--wim-gold-dark);
	border-color: rgba(184, 153, 104, 0.35);
}

/* ============================================================
 * Pain points — solution 併記カード
 * ============================================================ */
.wim-pain__solution {
	margin-top: auto;
	padding-top: var(--wim-space-4);
	border-top: 1px dashed var(--wim-line);
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-2);
}
.wim-pain__solution-label {
	display: inline-block;
	width: max-content;
	padding: 0.2em 0.7em;
	border-radius: 999px;
	background-image: var(--wim-gradient-tech);
	color: var(--wim-on-dark);
	font-size: var(--wim-fs-meta);
	letter-spacing: var(--wim-ls-meta);
	font-weight: var(--wim-weight-bold);
	text-transform: uppercase;
}
.wim-pain__solution-body {
	margin: 0;
	color: var(--wim-ink);
	font-size: var(--wim-fs-body);
	line-height: var(--wim-lh-body);
}
.wim-pain__item {
	display: flex;
	flex-direction: column;
}

/* Pricing は trial banner + 3 プランの 2 段構成へ移行
 * （trial banner / --three グリッドのスタイルは front-page.css と sub-pages.css で定義） */

/* マトリクスの 4 列対応（th/td 並び調整）*/
.wim-pricing-matrix__price-row th,
.wim-pricing-matrix__price-row td {
	font-weight: var(--wim-weight-bold);
	background-color: var(--wim-bg-soft);
}
.wim-pricing-matrix__table--four th,
.wim-pricing-matrix__table--four td {
	font-size: var(--wim-fs-body-sm);
}

/* ============================================================
 * Operating cost table（運用コスト内訳）
 * ============================================================ */
.wim-ops-cost {
	margin-top: var(--wim-space-10);
	padding: var(--wim-space-7);
	background-color: var(--wim-bg-paper);
	border: 1px solid var(--wim-line);
	border-radius: var(--wim-radius-lg);
}
.wim-ops-cost__heading {
	margin-bottom: var(--wim-space-5);
}
.wim-ops-cost__eyebrow {
	display: inline-block;
	font-size: var(--wim-fs-meta);
	letter-spacing: var(--wim-ls-meta);
	text-transform: uppercase;
	color: var(--wim-muted);
	margin-bottom: var(--wim-space-2);
}
.wim-ops-cost__title {
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h3);
	margin: 0 0 var(--wim-space-3);
}
.wim-ops-cost__lead {
	margin: 0;
	color: var(--wim-muted);
	max-width: 60ch;
}
.wim-ops-cost__scroll {
	overflow-x: auto;
}
.wim-ops-cost__table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--wim-fs-body);
}
.wim-ops-cost__table th,
.wim-ops-cost__table td {
	padding: var(--wim-space-4) var(--wim-space-3);
	border-bottom: 1px solid var(--wim-line);
	text-align: left;
}
.wim-ops-cost__table thead th {
	font-weight: var(--wim-weight-bold);
	color: var(--wim-muted);
	font-size: var(--wim-fs-caption);
	letter-spacing: var(--wim-ls-meta);
	text-transform: uppercase;
	background-color: var(--wim-bg-soft);
}
.wim-ops-cost__amount-col {
	text-align: right;
	font-variant-numeric: tabular-nums;
}
.wim-ops-cost__total-row th,
.wim-ops-cost__total-row td {
	font-weight: var(--wim-weight-bold);
	font-size: var(--wim-fs-h4);
	border-top: 2px solid var(--wim-ink);
	border-bottom: none;
	padding-top: var(--wim-space-5);
}
.wim-ops-cost__total-row td {
	background-image: var(--wim-gradient-tech);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.wim-ops-cost__note {
	margin: var(--wim-space-4) 0 0;
	color: var(--wim-muted);
	font-size: var(--wim-fs-caption);
}

/* ============================================================
 * Plan flow（先導期 → 伴走期 → 自走期）
 * ============================================================ */
.wim-plan-flow {
	margin-top: var(--wim-space-10);
}
.wim-plan-flow__heading {
	text-align: left;
	margin-bottom: var(--wim-space-6);
}
.wim-plan-flow__eyebrow {
	display: inline-block;
	font-size: var(--wim-fs-meta);
	letter-spacing: var(--wim-ls-meta);
	text-transform: uppercase;
	color: var(--wim-muted);
	margin-bottom: var(--wim-space-2);
}
.wim-plan-flow__title {
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h3);
	margin: 0 0 var(--wim-space-3);
}
.wim-plan-flow__lead {
	margin: 0;
	color: var(--wim-muted);
	max-width: 60ch;
}
.wim-plan-flow__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--wim-space-5);
}
@media (max-width: 1023px) {
	.wim-plan-flow__list {
		grid-template-columns: 1fr;
	}
}
.wim-plan-flow__item {
	position: relative;
	padding: var(--wim-space-6);
	background-color: var(--wim-bg);
	border: 1px solid var(--wim-line);
	border-radius: var(--wim-radius-md);
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-3);
}
.wim-plan-flow__item:nth-child(2) {
	border-color: transparent;
	background-image:
		linear-gradient(var(--wim-bg), var(--wim-bg)),
		var(--wim-gradient-tech);
	background-origin: border-box;
	background-clip: padding-box, border-box;
	border-width: 2px;
	border-style: solid;
}
.wim-plan-flow__phase {
	display: inline-block;
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h4);
	font-weight: var(--wim-weight-bold);
	color: var(--wim-ink);
}
.wim-plan-flow__plan {
	margin: 0;
	color: var(--wim-muted);
	font-size: var(--wim-fs-caption);
	letter-spacing: var(--wim-ls-meta);
	text-transform: uppercase;
}
.wim-plan-flow__cost {
	margin: 0;
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h2);
	font-weight: var(--wim-weight-bold);
	color: var(--wim-ink);
}
.wim-plan-flow__cost span {
	font-family: var(--wim-font-sans);
	font-size: var(--wim-fs-caption);
	font-weight: var(--wim-weight-regular);
	color: var(--wim-muted);
	margin-left: var(--wim-space-2);
}
.wim-plan-flow__breakdown {
	margin: 0;
	font-size: var(--wim-fs-caption);
	color: var(--wim-muted);
	line-height: var(--wim-lh-body);
}
.wim-plan-flow__tags {
	list-style: none;
	padding: 0;
	margin: auto 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--wim-space-2);
}
.wim-plan-flow__tags li {
	padding: 0.2em 0.7em;
	border-radius: 999px;
	background-color: var(--wim-bg-soft);
	color: var(--wim-ink);
	font-size: var(--wim-fs-meta);
	letter-spacing: var(--wim-ls-meta);
	font-weight: var(--wim-weight-medium);
}

/* ============================================================
 * Flow Phases（page-flow 3 段階モデル）
 * ============================================================ */
.wim-flow-phases__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-8);
}
.wim-flow-phases__item {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: var(--wim-space-6);
	align-items: flex-start;
}
@media (max-width: 599px) {
	.wim-flow-phases__item {
		grid-template-columns: 56px 1fr;
		gap: var(--wim-space-4);
	}
}
.wim-flow-phases__marker {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--wim-space-2);
	min-height: 100%;
}
.wim-flow-phases__num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background-image: var(--wim-gradient-tech);
	color: var(--wim-on-dark);
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h4);
	font-weight: var(--wim-weight-bold);
	flex-shrink: 0;
}
@media (max-width: 599px) {
	.wim-flow-phases__num {
		width: 48px;
		height: 48px;
		font-size: var(--wim-fs-body);
	}
}
.wim-flow-phases__line {
	display: block;
	flex-grow: 1;
	width: 2px;
	background: linear-gradient(to bottom, var(--wim-line), transparent);
	min-height: 80px;
}
.wim-flow-phases__body {
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-3);
	padding-bottom: var(--wim-space-6);
}
.wim-flow-phases__eyebrow {
	font-size: var(--wim-fs-meta);
	letter-spacing: var(--wim-ls-meta);
	text-transform: uppercase;
	color: var(--wim-muted);
}
.wim-flow-phases__phase {
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h2);
	font-weight: var(--wim-weight-bold);
	margin: 0;
	color: var(--wim-ink);
}
.wim-flow-phases__duration {
	display: inline-block;
	width: max-content;
	padding: 0.3em 0.9em;
	border-radius: 999px;
	background-color: var(--wim-bg-soft);
	color: var(--wim-ink);
	font-size: var(--wim-fs-caption);
	font-weight: var(--wim-weight-medium);
}
.wim-flow-phases__title-text {
	margin: 0;
	font-size: var(--wim-fs-lead);
	font-weight: var(--wim-weight-bold);
	color: var(--wim-ink);
}
.wim-flow-phases__lead,
.wim-flow-phases__detail {
	margin: 0;
	color: var(--wim-muted);
	line-height: var(--wim-lh-body);
}
.wim-flow-phases__roles {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--wim-space-4);
	margin: var(--wim-space-3) 0 0;
}
@media (max-width: 599px) {
	.wim-flow-phases__roles {
		grid-template-columns: 1fr;
	}
}
.wim-flow-phases__role {
	padding: var(--wim-space-4);
	border-radius: var(--wim-radius-md);
	background-color: var(--wim-bg-soft);
}
.wim-flow-phases__role--ai {
	background-image: var(--wim-gradient-tech-soft);
}
.wim-flow-phases__role dt {
	font-size: var(--wim-fs-meta);
	letter-spacing: var(--wim-ls-meta);
	text-transform: uppercase;
	color: var(--wim-muted);
	margin: 0 0 var(--wim-space-2);
	font-weight: var(--wim-weight-bold);
}
.wim-flow-phases__role dd {
	margin: 0;
	color: var(--wim-ink);
	font-size: var(--wim-fs-body);
	line-height: var(--wim-lh-body);
}

/* ============================================================
 * Flow results（成果例）— ダーク背景
 * ============================================================ */
.wim-flow-results__grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--wim-space-5);
}
@media (max-width: 1023px) {
	.wim-flow-results__grid {
		grid-template-columns: 1fr;
	}
}
.wim-flow-results__item {
	padding: var(--wim-space-6);
	background-color: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--wim-radius-md);
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-4);
	position: relative;
	overflow: hidden;
}
.wim-flow-results__item::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--wim-accent-cyan), var(--wim-accent-violet));
}
.wim-flow-results__phase {
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h3);
	margin: 0;
	color: #ffffff;
	font-weight: var(--wim-weight-bold);
	letter-spacing: 0.02em;
}
.wim-flow-results__roles {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-3);
}
.wim-flow-results__role dt {
	font-size: var(--wim-fs-meta);
	letter-spacing: var(--wim-ls-meta);
	text-transform: uppercase;
	color: var(--wim-accent-cyan);
	font-weight: var(--wim-weight-bold);
	margin: 0 0 var(--wim-space-1);
}
.wim-flow-results__role dd {
	margin: 0;
	color: #ffffff;
	line-height: var(--wim-lh-body);
}
.wim-flow-results__note {
	margin: var(--wim-space-8) auto 0;
	max-width: 800px;
	text-align: center;
	color: var(--wim-on-dark-mid);
	font-size: var(--wim-fs-body);
	line-height: var(--wim-lh-body);
}

/* ============================================================
 * SaaS vs AIエージェント比較
 * ============================================================ */
.wim-saas-compare__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--wim-space-5);
	align-items: stretch;
}
@media (max-width: 768px) {
	.wim-saas-compare__grid {
		grid-template-columns: 1fr;
	}
}
.wim-saas-compare__col {
	padding: var(--wim-space-7);
	border-radius: var(--wim-radius-lg);
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-4);
}
.wim-saas-compare__col--muted {
	background-color: var(--wim-bg-soft);
	border: 1px solid var(--wim-line);
}
.wim-saas-compare__col--tech {
	background-color: var(--wim-bg-dark-tech);
	color: var(--wim-on-dark);
	border: 2px solid transparent;
	background-image:
		linear-gradient(var(--wim-bg-dark-tech), var(--wim-bg-dark-tech)),
		var(--wim-gradient-tech);
	background-origin: border-box;
	background-clip: padding-box, border-box;
	box-shadow: var(--wim-shadow-tech);
}
.wim-saas-compare__col-title {
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h3);
	margin: 0;
}
.wim-saas-compare__col--tech .wim-saas-compare__col-title {
	background-image: var(--wim-gradient-tech);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.wim-saas-compare__col-lead {
	margin: 0;
	color: var(--wim-muted);
	font-size: var(--wim-fs-body);
}
.wim-saas-compare__col--tech .wim-saas-compare__col-lead {
	color: var(--wim-on-dark-mid);
}
.wim-saas-compare__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wim-space-3);
}
.wim-saas-compare__list li {
	display: flex;
	align-items: flex-start;
	gap: var(--wim-space-3);
	font-size: var(--wim-fs-body);
	line-height: var(--wim-lh-body);
}
.wim-saas-compare__col--muted .wim-saas-compare__list li svg {
	color: var(--wim-muted);
	flex-shrink: 0;
	margin-top: 0.3em;
}
.wim-saas-compare__col--tech .wim-saas-compare__list li {
	color: var(--wim-on-dark);
}
.wim-saas-compare__col--tech .wim-saas-compare__list li svg {
	color: var(--wim-accent-cyan);
	flex-shrink: 0;
	margin-top: 0.3em;
}
.wim-saas-compare__note {
	margin: var(--wim-space-6) 0 0;
	color: var(--wim-muted);
	font-size: var(--wim-fs-caption);
	text-align: center;
}

/* ============================================================
 * Profile message（運営者メッセージ）
 * ============================================================ */
.wim-profile__message {
	margin: 0 0 var(--wim-space-5);
	padding: var(--wim-space-5);
	border-left: 3px solid var(--wim-accent-cyan);
	background-color: var(--wim-bg-soft);
	border-radius: 0 var(--wim-radius-md) var(--wim-radius-md) 0;
}
.wim-profile__message p {
	margin: 0;
	font-family: var(--wim-font-serif);
	font-size: var(--wim-fs-h4);
	font-weight: var(--wim-weight-bold);
	line-height: 1.6;
	color: var(--wim-ink);
}
