/* ═══════════════════════════════════════════════
   Parceiro Theme — configurator.css
   シミュレーター（コンフィギュレーター）専用スタイル
   スペックシート／ギアカタログの空気感
   ※ ビジュアルイラストはv0.003で一旦撤去（メニューのみ）
═══════════════════════════════════════════════ */

.pc-cfg { background: var(--paper); }

.pc-cfg-layout {
	max-width: 920px;
	margin: 0 auto;
}

/* ───── 操作パネル ─────
   デスクトップは2カラム（1カラー/2パッケージ → 3オプション/まとめ） */
.pc-cfg-panel {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px 44px;
	align-items: start;
}

.pc-cfg-group { margin-bottom: 24px; }
.pc-cfg-group-title {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 14px;
	font-size: 15px;
	font-weight: 900;
	letter-spacing: 0.1em;
}
.pc-cfg-group-title span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	background: var(--ink);
	color: #fff;
	font-family: var(--font-en);
	font-size: 13px;
	font-weight: 600;
	border-radius: var(--radius);
}

/* カラー選択 */
.pc-cfg-colors { display: flex; flex-wrap: wrap; gap: 8px; }
.pc-cfg-color {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	min-width: 66px;
	min-height: 44px;
	padding: 8px 6px;
	background: var(--white);
	border: 1.5px solid var(--line);
	border-radius: var(--radius);
	cursor: pointer;
	transition: border-color 0.15s ease;
}
.pc-cfg-color::before {
	content: '';
	width: 32px;
	height: 32px;
	border-radius: var(--radius);
	background: var(--swatch);
	border: 1.5px solid rgba(29, 31, 28, 0.3);
}
.pc-cfg-color:hover { border-color: var(--ink); }
.pc-cfg-color.is-active { border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--orange); }
.pc-cfg-color-name { font-size: 10.5px; font-weight: 700; color: var(--ink); letter-spacing: 0.02em; }

/* パッケージ選択 */
.pc-cfg-packages { display: flex; flex-direction: column; gap: 8px; }
.pc-cfg-package {
	display: flex;
	flex-direction: column;
	gap: 2px;
	text-align: left;
	min-height: 44px;
	padding: 13px 16px;
	background: var(--white);
	border: 1.5px solid var(--line);
	border-radius: var(--radius);
	cursor: pointer;
	font-family: var(--font-jp);
	transition: border-color 0.15s ease;
}
.pc-cfg-package strong { font-size: 14px; font-weight: 700; letter-spacing: 0.03em; color: var(--ink); }
.pc-cfg-package small { font-size: 11.5px; color: var(--muted); }
.pc-cfg-package:hover { border-color: var(--ink); }
.pc-cfg-package.is-active {
	border: 2px solid var(--ink);
	box-shadow: 3px 3px 0 var(--orange);
}

/* オプション */
.pc-cfg-options { display: flex; flex-direction: column; gap: 8px; }
.pc-cfg-option {
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 44px;
	padding: 10px 14px;
	background: var(--white);
	border: 1.5px solid var(--line);
	border-radius: var(--radius);
	cursor: pointer;
	transition: border-color 0.15s ease;
}
.pc-cfg-option:hover { border-color: var(--ink); }
.pc-cfg-option input { position: absolute; opacity: 0; pointer-events: none; }
.pc-cfg-option-box {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	border: 1.5px solid var(--ink);
	border-radius: var(--radius);
	background: var(--white);
	position: relative;
	transition: background 0.15s ease;
}
.pc-cfg-option input:checked + .pc-cfg-option-box {
	background: var(--orange);
}
.pc-cfg-option input:checked + .pc-cfg-option-box::after {
	content: '';
	position: absolute;
	left: 4px;
	top: 5px;
	width: 10px;
	height: 5px;
	border-left: 2.5px solid #fff;
	border-bottom: 2.5px solid #fff;
	transform: rotate(-45deg);
}
.pc-cfg-option input:focus-visible + .pc-cfg-option-box { outline: 2px solid var(--orange); outline-offset: 2px; }
.pc-cfg-option:has(input:checked) { border: 2px solid var(--ink); }
.pc-cfg-option:has(input:disabled) { opacity: 0.55; cursor: not-allowed; }
.pc-cfg-option-text { display: flex; flex-direction: column; }
.pc-cfg-option-text strong { font-size: 13.5px; }
.pc-cfg-option-text small { font-size: 11.5px; color: var(--muted); }
.pc-cfg-included-note { margin: 10px 0 0; font-size: 12px; color: var(--ink-soft); font-weight: 500; }

/* 選択内容まとめ（スペックシート風） */
.pc-cfg-summary {
	background: var(--ink);
	border-radius: var(--radius);
	padding: 22px 24px;
	color: #fff;
}
.pc-cfg-summary-title {
	margin: 0 0 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.25);
	font-family: var(--font-en);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: #fff;
}
.pc-cfg-summary-title::before { content: 'SPEC / '; color: var(--orange); }
#pc-cfg-summary-list { margin: 0 0 18px; display: flex; flex-direction: column; gap: 8px; }
#pc-cfg-summary-list div { display: flex; gap: 14px; font-size: 13px; }
#pc-cfg-summary-list dt {
	flex-shrink: 0;
	width: 96px;
	opacity: 0.6;
}
#pc-cfg-summary-list dd { margin: 0; font-weight: 700; }
.pc-cfg-submit { width: 100%; border-color: #fff; }
.pc-cfg-summary-note {
	margin: 12px 0 0;
	font-size: 11.5px;
	opacity: 0.65;
	text-align: center;
}

@media (max-width: 760px) {
	.pc-cfg-panel { grid-template-columns: 1fr; gap: 0; }
}
