/**
 * PASS24 Solution Configurator — styles
 *
 * @package PASS24_Child
 */

/* ------------------------------------------------------------------
   Wrapper
   ------------------------------------------------------------------ */

.p24-cfg-wrapper {
	max-width: 680px;
	margin: 0 auto;
}

/* ------------------------------------------------------------------
   Progress bar
   ------------------------------------------------------------------ */

.p24-cfg-progress {
	height: 6px;
	background: var(--p24-border);
	border-radius: 3px;
	overflow: hidden;
	margin-bottom: 0.5rem;
}

.p24-cfg-progress__fill {
	height: 100%;
	background: var(--p24-primary);
	border-radius: 3px;
	transition: width 0.3s ease;
}

.p24-cfg-progress__label {
	font-size: 0.8125rem;
	color: var(--p24-text-secondary);
	margin: 0 0 1.5rem;
}

/* ------------------------------------------------------------------
   Step card
   ------------------------------------------------------------------ */

.p24-cfg-step {
	background: #ffffff;
	border: 1px solid var(--p24-border);
	border-radius: var(--p24-radius-xl);
	padding: 2rem;
}

.p24-cfg-step .p24-h3 {
	margin-bottom: 1.25rem;
}

/* ------------------------------------------------------------------
   Options grid (radio)
   ------------------------------------------------------------------ */

.p24-cfg-options {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}

/* Checkbox options — same grid */
.p24-cfg-options--multi {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}

/* Option card */
.p24-cfg-option {
	display: flex;
	align-items: flex-start;
	gap: 0.625rem;
	border: 1.5px solid var(--p24-border);
	border-radius: var(--p24-radius-lg);
	padding: 0.875rem 1rem;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
}

.p24-cfg-option:has( input:checked ) {
	border-color: var(--p24-primary);
	background: #eff6ff;
}

.p24-cfg-option input {
	margin-top: 2px;
	flex-shrink: 0;
	accent-color: var(--p24-primary);
}

.p24-cfg-option__label {
	font-weight: 500;
	font-size: 0.9375rem;
	line-height: 1.4;
}

/* ------------------------------------------------------------------
   Navigation
   ------------------------------------------------------------------ */

.p24-cfg-nav {
	display: flex;
	flex-direction: row;
	gap: 0.75rem;
	justify-content: flex-end;
	margin-top: 0.5rem;
}

/* ------------------------------------------------------------------
   Results card
   ------------------------------------------------------------------ */

.p24-cfg-results {
	background: #ffffff;
	border: 1px solid var(--p24-border);
	border-radius: var(--p24-radius-xl);
	overflow: hidden;
}

.p24-cfg-results__plan {
	background: linear-gradient( 135deg, var(--p24-primary), #1d4ed8 );
	padding: 2rem;
	text-align: center;
	color: #ffffff;
}

.p24-cfg-plan-hint {
	font-size: 0.8125rem;
	opacity: 0.8;
	margin: 0 0 0.5rem;
}

.p24-cfg-plan-name {
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 0.375rem;
	letter-spacing: 0.03em;
}

.p24-cfg-plan-price {
	font-size: 1.125rem;
	opacity: 0.9;
	margin: 0;
}

/* ------------------------------------------------------------------
   Feature list
   ------------------------------------------------------------------ */

.p24-cfg-feature-list {
	list-style: none;
	padding: 1.5rem 1.5rem 0;
	margin: 0;
}

.p24-cfg-feature-list li {
	padding: 0.4rem 0 0.4rem 1.75rem;
	position: relative;
	font-size: 0.9375rem;
}

.p24-cfg-feature-list li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--p24-primary);
	font-weight: 700;
}

/* ------------------------------------------------------------------
   Contact form block
   ------------------------------------------------------------------ */

.p24-cfg-contact {
	border-top: 1px solid var(--p24-border);
	padding: 1.5rem;
	margin-top: 1rem;
}

.p24-cfg-contact-form {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

/* ------------------------------------------------------------------
   Contact success block
   ------------------------------------------------------------------ */

.p24-cfg-contact-success {
	padding: 1.5rem;
	text-align: center;
}

/* ------------------------------------------------------------------
   Restart button area
   ------------------------------------------------------------------ */

.p24-cfg-results > .p24-btn-secondary {
	margin: 0 1.5rem 1.5rem;
	width: calc( 100% - 3rem );
}

/* ------------------------------------------------------------------
   Responsive
   ------------------------------------------------------------------ */

@media ( max-width: 520px ) {
	.p24-cfg-options,
	.p24-cfg-options--multi {
		grid-template-columns: 1fr;
	}

	.p24-cfg-step {
		padding: 1.25rem;
	}

	.p24-cfg-nav {
		flex-direction: column-reverse;
	}
}
