/* ==========================================================================
   Unified configurator
   ========================================================================== */

.picos-configurator {
	background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}

.picos-configurator__intro {
	max-width: 860px;
	margin: 0 auto 32px;
	text-align: center;
}

.picos-configurator__eyebrow {
	margin-bottom: 12px;
	font-size: var(--font-tiny);
	font-weight: var(--font-weight-black);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--primary);
}

.picos-configurator__title {
	margin-bottom: 14px;
	font-size: var(--font-h2);
}

.picos-configurator__lead {
	color: var(--text-light);
	font-size: var(--font-body-large);
}

.picos-configurator__progress {
	position: sticky;
	top: calc(var(--header-height) + 8px);
	z-index: 10;
	margin-bottom: 24px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--bg-white);
	box-shadow: var(--shadow-card);
}

.picos-configurator__steps {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	list-style: none;
}

.picos-configurator__steps li {
	padding: 14px 16px;
	text-align: center;
	font-size: var(--font-small);
	color: var(--text-light);
	border-right: 1px solid var(--border);
}

.picos-configurator__steps li:last-child {
	border-right: 0;
}

.picos-configurator__steps li.is-active {
	color: var(--primary);
	font-weight: var(--font-weight-semibold);
	background: var(--primary-light);
}

.picos-configurator__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 24px;
	align-items: start;
}

.picos-configurator__main {
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--bg-white);
	box-shadow: var(--shadow-card);
	padding: 28px;
}

.picos-configurator__panel-title {
	font-size: var(--font-h3);
	margin-bottom: 10px;
}

.picos-configurator__panel-lead {
	margin-bottom: 18px;
	color: var(--text-light);
}

.picos-configurator__type-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.picos-configurator__type-card {
	display: grid;
	gap: 8px;
	padding: 18px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--bg-white);
	text-align: left;
	cursor: pointer;
	transition: var(--transition), var(--transition-transform);
}

.picos-configurator__type-card:hover,
.picos-configurator__type-card:focus-visible {
	border-color: rgba(111, 16, 183, 0.35);
	transform: var(--hover-lift);
}

.picos-configurator__type-card.is-selected {
	border-color: var(--primary);
	background: var(--primary-light);
}

.picos-configurator__type-title {
	font-weight: var(--font-weight-bold);
	font-size: var(--font-body);
	color: var(--text);
}

.picos-configurator__type-text {
	font-size: var(--font-small);
	color: var(--text-light);
}

.picos-configurator__option-groups {
	display: grid;
	gap: 16px;
}

.picos-configurator__option-group {
	padding: 16px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--bg-light);
}

.picos-configurator__option-group h3 {
	font-size: var(--font-body);
	margin-bottom: 10px;
}

.picos-configurator__option-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

.picos-configurator__option {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: var(--touch-target);
	padding: 10px 12px;
	border: 1px solid var(--border);
	border-radius: 8px;
	background: var(--bg-white);
	font-size: var(--font-small);
}

.picos-configurator__option input {
	accent-color: var(--primary);
}

.picos-configurator__form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.picos-configurator__field {
	display: grid;
	gap: 8px;
	font-size: var(--font-small);
	color: var(--text);
}

.picos-configurator__field input,
.picos-configurator__field textarea {
	width: 100%;
	min-height: var(--touch-target);
	padding: 12px;
	border: 1px solid var(--border);
	border-radius: var(--radius-input);
	font: inherit;
}

.picos-configurator__field--full {
	margin-top: 14px;
}

.picos-configurator__actions {
	display: flex;
	gap: 12px;
	margin-top: 22px;
}

.picos-configurator__summary {
	position: sticky;
	top: calc(var(--header-height) + 96px);
	padding: 20px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--bg-white);
	box-shadow: var(--shadow-card);
}

.picos-configurator__summary h3 {
	font-size: var(--font-body);
	margin-bottom: 10px;
}

.picos-configurator__summary-type {
	font-weight: var(--font-weight-semibold);
	margin-bottom: 12px;
}

.picos-configurator__summary-list {
	list-style: none;
	display: grid;
	gap: 8px;
	font-size: var(--font-small);
	color: var(--text-light);
}

.picos-configurator__mobile-summary {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 80;
	display: none;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 12px var(--container-padding);
	background: rgba(255, 255, 255, 0.96);
	border-top: 1px solid var(--border);
	backdrop-filter: blur(8px);
}

.picos-configurator__mobile-summary strong {
	display: block;
	font-size: var(--font-small);
}

.picos-configurator__mobile-summary span {
	font-size: var(--font-tiny);
	color: var(--text-light);
}

.picos-configurator__fluentform {
	margin-top: 8px;
}

.picos-configurator__fluentform .picos-fluentform {
	margin-top: 0;
}

.picos-configurator__form-fallback {
	color: var(--text-light);
	font-size: var(--font-small);
}

.picos-configurator.is-submitted .picos-configurator__summary {
	opacity: 1;
}

@media (max-width: 1023px) {
	.picos-configurator__panel.is-success-state .picos-ff-success {
		margin-bottom: 72px;
	}
}

@media (max-width: 1023px) {
	.picos-configurator__layout {
		grid-template-columns: 1fr;
	}

	.picos-configurator__summary {
		display: none;
	}

	.picos-configurator__mobile-summary {
		display: flex;
	}
}

@media (max-width: 767px) {
	.picos-configurator__main {
		padding: 20px;
	}

	.picos-configurator__type-grid,
	.picos-configurator__option-grid,
	.picos-configurator__form-grid {
		grid-template-columns: 1fr;
	}

	.picos-configurator__actions {
		flex-direction: column;
	}

	.picos-configurator__actions .btn {
		width: 100%;
	}

	.picos-configurator__steps li {
		font-size: var(--font-tiny);
		padding-inline: 10px;
	}
}
