/* ==========================================================================
   Encuentra tu Solución — Wizard Interactivo
   ========================================================================== */

.bn-finder {
	min-height: calc(100vh - 200px);
	padding: clamp(var(--space-8), 8vw, var(--space-16)) var(--container-pad) var(--space-24);
	position: relative;
}

/* ============== HEAD ============== */
.bn-finder__head {
	max-width: 720px;
	margin: 0 auto var(--space-12);
	text-align: center;
}
.bn-finder__head .bn-eyebrow {
	justify-content: center;
	display: inline-flex;
}
.bn-finder__head h1 {
	margin-bottom: var(--space-4);
}
.bn-finder__head h1 em {
	font-style: normal;
	background: linear-gradient(135deg, var(--em-400) 0%, var(--em-300) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.bn-finder__head p {
	color: var(--text-2);
	font-size: var(--fs-md);
	max-width: 60ch;
	margin: 0 auto;
	line-height: var(--lh-relaxed);
}


/* ============== WIZARD ============== */
.bn-wizard {
	max-width: 920px;
	margin: 0 auto;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: clamp(var(--space-6), 4vw, var(--space-12));
	position: relative;
	overflow: hidden;
}
.bn-wizard::before {
	content: '';
	position: absolute;
	inset: -1px;
	border-radius: inherit;
	padding: 1px;
	background: linear-gradient(135deg, rgba(4,120,87,0) 0%, rgba(4,120,87,0.4) 50%, rgba(52,211,153,0.3) 100%);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}


/* ============== PROGRESS BAR ============== */
.bn-wizard__progress {
	margin-bottom: var(--space-8);
}
.bn-wizard__bar-bg {
	height: 4px;
	background: var(--bg-subtle);
	border-radius: 999px;
	overflow: hidden;
	margin-bottom: var(--space-4);
}
.bn-wizard__bar {
	height: 100%;
	background: linear-gradient(90deg, var(--em-700) 0%, var(--em-400) 100%);
	box-shadow: 0 0 12px rgba(52, 211, 153, 0.4);
	transition: width var(--dur-slow) var(--ease-out);
	border-radius: 999px;
}
.bn-wizard__steps {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: var(--space-2);
	list-style: none;
	padding: 0;
	margin: 0;
}
.bn-wizard__steps li {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--text-dim);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	transition: color var(--dur);
}
.bn-wizard__steps li span {
	width: 28px; height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--bg-subtle);
	color: var(--text-muted);
	font-size: 11px;
	font-weight: 700;
	transition: all var(--dur);
}
.bn-wizard__steps li.is-active {
	color: var(--em-400);
}
.bn-wizard__steps li.is-active span {
	background: var(--em-700);
	color: var(--text-on-em);
	box-shadow: 0 0 12px rgba(4, 120, 87, 0.5);
}
.bn-wizard__steps li.is-done span {
	background: var(--em-500);
	color: var(--text-on-em);
}


/* ============== STEPS ============== */
.bn-step {
	display: none;
	animation: bn-step-in 0.4s var(--ease-out);
}
.bn-step.is-active {
	display: block;
}
@keyframes bn-step-in {
	from { opacity: 0; transform: translateX(20px); }
	to   { opacity: 1; transform: translateX(0); }
}
.bn-step__title {
	font-size: clamp(var(--fs-xl), 3vw, var(--fs-3xl));
	margin-bottom: var(--space-3);
	color: var(--text);
}
.bn-step__lead {
	color: var(--text-muted);
	margin-bottom: var(--space-8);
	max-width: 60ch;
	line-height: var(--lh-relaxed);
}


/* ============== OPTIONS ============== */
.bn-options {
	display: grid;
	gap: var(--space-3);
	margin-bottom: var(--space-8);
}
.bn-options--vertical { grid-template-columns: 1fr; }
.bn-options--grid4 { grid-template-columns: repeat(4, 1fr); gap: var(--space-3); }
@media (max-width: 900px) { .bn-options--grid4 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .bn-options--grid4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 380px) { .bn-options--grid4 { grid-template-columns: 1fr; } }

.bn-option {
	display: flex;
	gap: var(--space-4);
	align-items: center;
	padding: var(--space-5);
	background: var(--bg-deep);
	border: 1px solid var(--border-strong);
	border-radius: var(--radius-md);
	cursor: pointer;
	text-align: left;
	font-family: var(--font-body);
	color: var(--text);
	transition: all var(--dur) var(--ease-out);
	min-height: 64px;
	position: relative;
}
.bn-option:hover {
	border-color: var(--em-500);
	background: rgba(4, 120, 87, 0.05);
	transform: translateX(2px);
}
.bn-option:focus-visible {
	outline: 2px solid var(--em-400);
	outline-offset: 2px;
}
.bn-option.is-selected {
	border-color: var(--em-500);
	background: linear-gradient(135deg, rgba(4, 120, 87, 0.18) 0%, rgba(20, 20, 20, 0.5) 100%);
	box-shadow: 0 0 24px rgba(4, 120, 87, 0.30);
}
.bn-option.is-selected::after {
	content: '✓';
	position: absolute;
	top: 12px;
	right: 12px;
	width: 24px; height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--em-500);
	color: var(--text-on-em);
	border-radius: 50%;
	font-weight: 700;
	font-size: 12px;
}

.bn-option__num {
	font-family: var(--font-numbers);
	font-weight: 700;
	font-size: var(--fs-2xl);
	color: var(--em-400);
	min-width: 80px;
	text-align: center;
	line-height: 1;
}
.bn-option__icon {
	min-width: 44px;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	background: rgba(4, 120, 87, 0.10);
	color: var(--em-400);
	flex-shrink: 0;
}
.bn-option__icon .bn-icon {
	width: 22px;
	height: 22px;
	stroke: currentColor;
}
.bn-option:hover .bn-option__icon,
.bn-option.is-active .bn-option__icon {
	background: var(--em-700);
	color: #ffffff;
}

/* Helper global .bn-icon */
.bn-icon {
	display: inline-block;
	vertical-align: middle;
	flex-shrink: 0;
}
.bn-option__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.bn-option__body strong {
	font-weight: 600;
	font-size: var(--fs-md);
	color: var(--text);
}
.bn-option__desc {
	font-size: var(--fs-sm);
	color: var(--text-muted);
	font-weight: 400;
	line-height: var(--lh-snug);
}

/* Compact (sectores grid) */
.bn-option--compact {
	flex-direction: column;
	align-items: flex-start;
	gap: 4px;
	padding: var(--space-4);
	min-height: 88px;
}
.bn-option--compact strong {
	font-size: var(--fs-sm);
	font-weight: 600;
}
.bn-option--compact .bn-option__desc {
	font-size: var(--fs-xs);
}


/* ============== FORM (step 4) ============== */
.bn-finder-form {
	display: grid;
	gap: var(--space-4);
	margin-bottom: var(--space-8);
}
.bn-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4);
}
@media (max-width: 600px) { .bn-form__row { grid-template-columns: 1fr; } }

.bn-form__field { display: flex; flex-direction: column; }

.bn-checkbox {
	display: flex;
	gap: var(--space-2);
	align-items: flex-start;
	font-size: var(--fs-sm);
	color: var(--text-2);
	line-height: var(--lh-snug);
	cursor: pointer;
	padding: var(--space-3);
	background: var(--bg-deep);
	border-radius: var(--radius);
	border: 1px solid var(--border);
}
.bn-checkbox input {
	margin-top: 3px;
	accent-color: var(--em-500);
	width: 16px; height: 16px;
	flex-shrink: 0;
}
.bn-checkbox a {
	color: var(--em-400);
	text-decoration: underline;
}


/* ============== RESULT (step 5) ============== */
.bn-step--result .bn-result__head {
	text-align: center;
	margin-bottom: var(--space-10);
}
.bn-step--result .bn-result__head .bn-eyebrow {
	justify-content: center;
	display: inline-flex;
}
.bn-step--result h2 {
	font-size: clamp(var(--fs-2xl), 4vw, var(--fs-3xl));
	background: linear-gradient(135deg, var(--text) 0%, var(--em-400) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-bottom: var(--space-3);
}
.bn-step--result .bn-result__head p {
	color: var(--text-2);
	max-width: 60ch;
	margin: 0 auto;
	line-height: var(--lh-relaxed);
}

.bn-result__cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--space-4);
	margin-bottom: var(--space-10);
}

.bn-result-card {
	padding: var(--space-6);
	background: var(--bg-deep);
	border: 1px solid var(--border);
	border-radius: var(--radius-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	position: relative;
}
.bn-result-card--top {
	border-color: var(--em-500);
	box-shadow: 0 0 24px rgba(4, 120, 87, 0.20);
}
.bn-result-card--top::before {
	content: 'Más recomendada';
	position: absolute;
	top: -12px;
	right: 16px;
	padding: 4px 12px;
	background: var(--em-500);
	color: var(--text-on-em);
	font-family: var(--font-mono);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	border-radius: 999px;
}

.bn-result-card__code {
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	color: var(--em-400);
	text-transform: uppercase;
	letter-spacing: 0.12em;
}
.bn-result-card__title {
	font-size: var(--fs-md);
	font-weight: 700;
	color: var(--text);
	margin: 0;
}
.bn-result-card__desc {
	font-size: var(--fs-sm);
	color: var(--text-muted);
	line-height: var(--lh-snug);
	margin: 0;
	flex: 1;
}
.bn-result-card__why {
	font-size: var(--fs-xs);
	color: var(--text-2);
	padding: var(--space-2) var(--space-3);
	background: rgba(4, 120, 87, 0.10);
	border-left: 2px solid var(--em-500);
	border-radius: 4px;
	font-style: italic;
}

.bn-result__cta {
	display: flex;
	gap: var(--space-3);
	flex-wrap: wrap;
	justify-content: center;
}
@media (max-width: 600px) {
	.bn-result__cta { flex-direction: column; }
	.bn-result__cta .bn-btn { width: 100%; }
}


/* ============== NAV BUTTONS ============== */
.bn-wizard__nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-3);
	margin-top: var(--space-8);
	padding-top: var(--space-6);
	border-top: 1px solid var(--border);
}
.bn-wizard__nav .bn-btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
	pointer-events: none;
}

/* En step 5 (resultado) ocultar nav */
.bn-wizard.is-final .bn-wizard__nav { display: none; }


/* ============== TRUST SIGNALS ============== */
.bn-finder__trust {
	max-width: 920px;
	margin: var(--space-12) auto 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-6);
	padding: var(--space-6);
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: var(--radius-md);
}
@media (max-width: 700px) {
	.bn-finder__trust { grid-template-columns: 1fr; gap: var(--space-4); }
}
.bn-finder__trust-item {
	display: flex;
	flex-direction: column;
	gap: 4px;
	text-align: center;
}
.bn-finder__trust-item strong {
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	color: var(--em-400);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}
.bn-finder__trust-item span {
	font-size: var(--fs-sm);
	color: var(--text-muted);
	line-height: var(--lh-snug);
}


/* Mobile adjustments */
@media (max-width: 700px) {
	.bn-wizard__steps li {
		font-size: 9px;
	}
	.bn-wizard__steps li span {
		width: 24px; height: 24px;
		font-size: 10px;
	}
	.bn-option { flex-direction: column; align-items: flex-start; padding: var(--space-4); }
	.bn-option__num { min-width: auto; text-align: left; font-size: var(--fs-xl); }
}
