/* ===== Variables ===== */
:root {
	--vr-primario:       #2563eb;
	--vr-primario-osc:   #1d4ed8;
	--vr-secundario:     #64748b;
	--vr-exito:          #16a34a;
	--vr-error:          #dc2626;
	--vr-advertencia:    #d97706;
	--vr-fondo:          #f8fafc;
	--vr-borde:          #e2e8f0;
	--vr-texto:          #1e293b;
	--vr-texto-suave:    #64748b;
	--vr-blanco:         #ffffff;
	--vr-radio:          8px;
	--vr-sombra:         0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);
	--vr-sombra-md:      0 4px 6px -1px rgba(0,0,0,.1);
	--vr-fuente:         -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	--vr-transicion:     .18s ease;
}

/* ===== Contenedor ===== */
.vectiss-wizard {
	font-family: var(--vr-fuente);
	color: var(--vr-texto);
	max-width: 980px;
	margin: 0 auto;
	padding: 24px 16px 56px;
	position: relative;
	box-sizing: border-box;
}
.vectiss-wizard *,
.vectiss-wizard *::before,
.vectiss-wizard *::after { box-sizing: inherit; }

/* ===== Nav de pasos ===== */
.vectiss-pasos-nav { margin-bottom: 32px; }

.vectiss-pasos-lista {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
}

.vectiss-paso-nav {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	position: relative;
}

.vectiss-paso-nav::before {
	content: '';
	position: absolute;
	top: 17px;
	left: 50%;
	right: -50%;
	height: 2px;
	background: var(--vr-borde);
	z-index: 0;
}
.vectiss-paso-nav:last-child::before { display: none; }

.vectiss-paso-num {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--vr-borde);
	color: var(--vr-texto-suave);
	font-size: 14px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 1;
	transition: background var(--vr-transicion), color var(--vr-transicion);
}

.vectiss-paso-label {
	font-size: 11px;
	color: var(--vr-texto-suave);
	text-align: center;
	font-weight: 500;
}

.vectiss-paso-nav.activo .vectiss-paso-num {
	background: var(--vr-primario);
	color: var(--vr-blanco);
}
.vectiss-paso-nav.activo .vectiss-paso-label {
	color: var(--vr-primario);
	font-weight: 700;
}
.vectiss-paso-nav.completado .vectiss-paso-num {
	background: var(--vr-exito);
	color: var(--vr-blanco);
}

/* ===== Contenido de pasos ===== */
.vectiss-paso { display: none; }
.vectiss-paso.activo {
	display: block;
	animation: vr-entrar .22s ease;
}
@keyframes vr-entrar {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ===== Sección de paso ===== */
.vectiss-seccion-paso {
	background: var(--vr-blanco);
	border: 1px solid var(--vr-borde);
	border-radius: 12px;
	padding: 28px;
	box-shadow: var(--vr-sombra);
}

.vectiss-titulo-paso {
	font-size: 22px;
	font-weight: 700;
	margin: 0 0 24px;
	line-height: 1.2;
}

.vectiss-subtitulo {
	font-size: 15px;
	font-weight: 600;
	margin: 0 0 14px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--vr-borde);
}

.vectiss-cabecera-paso {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 20px;
}
.vectiss-cabecera-paso .vectiss-titulo-paso { margin: 0; }

/* ===== Formularios ===== */
.vectiss-form { display: flex; flex-direction: column; gap: 20px; }

.vectiss-fila-dos-col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

.vectiss-campo-grupo { display: flex; flex-direction: column; gap: 5px; }

.vectiss-label { font-size: 14px; font-weight: 600; }
.vectiss-requerido { color: var(--vr-error); }

.vectiss-input,
.vectiss-select {
	width: 100%;
	padding: 10px 14px;
	border: 1.5px solid var(--vr-borde);
	border-radius: var(--vr-radio);
	font-size: 15px;
	font-family: var(--vr-fuente);
	color: var(--vr-texto);
	background: var(--vr-blanco);
	transition: border-color var(--vr-transicion), box-shadow var(--vr-transicion);
	outline: none;
	-webkit-appearance: none;
	appearance: none;
}
.vectiss-input:focus,
.vectiss-select:focus {
	border-color: var(--vr-primario);
	box-shadow: 0 0 0 3px rgba(37,99,235,.15);
}
.vectiss-input.vectiss-input-error,
.vectiss-select.vectiss-input-error { border-color: var(--vr-error); }

.vectiss-error-campo { font-size: 12px; color: var(--vr-error); min-height: 16px; }

.vectiss-label-check {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 14px;
	cursor: pointer;
	line-height: 1.4;
}
.vectiss-label-check input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin-top: 2px;
	flex-shrink: 0;
	accent-color: var(--vr-primario);
	cursor: pointer;
}

/* ===== Botones ===== */
.vectiss-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 20px;
	border-radius: var(--vr-radio);
	font-size: 15px;
	font-weight: 600;
	font-family: var(--vr-fuente);
	border: none;
	cursor: pointer;
	transition: background var(--vr-transicion), transform .1s, box-shadow .15s;
	text-decoration: none;
	line-height: 1.4;
}
.vectiss-btn:hover { transform: translateY(-1px); box-shadow: var(--vr-sombra-md); }
.vectiss-btn:active { transform: none; }

.vectiss-btn-primario { background: var(--vr-primario); color: var(--vr-blanco); }
.vectiss-btn-primario:hover { background: var(--vr-primario-osc); color: var(--vr-blanco); }

.vectiss-btn-secundario {
	background: var(--vr-fondo);
	color: var(--vr-secundario);
	border: 1.5px solid var(--vr-borde);
}
.vectiss-btn-secundario:hover { background: var(--vr-borde); color: var(--vr-texto); }

.vectiss-btn-grande { padding: 14px 28px; font-size: 16px; }

.vectiss-btn-deshabilitado {
	background: var(--vr-borde);
	color: var(--vr-texto-suave);
	cursor: not-allowed;
	opacity: .7;
}
.vectiss-btn-deshabilitado:hover { transform: none; box-shadow: none; }

.vectiss-btn-atras {
	background: none;
	border: none;
	color: var(--vr-primario);
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	padding: 0;
	font-family: var(--vr-fuente);
	text-decoration: underline;
}
.vectiss-btn-atras:hover { color: var(--vr-primario-osc); }

/* ===== Acciones ===== */
.vectiss-acciones-paso {
	display: flex;
	justify-content: flex-end;
	gap: 12px;
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid var(--vr-borde);
}
.vectiss-acciones-dobles { justify-content: space-between; }

/* ===== Alertas ===== */
.vectiss-alerta {
	padding: 13px 16px;
	border-radius: var(--vr-radio);
	font-size: 14px;
	font-weight: 500;
	margin-bottom: 20px;
}
.vectiss-alerta-error    { background: #fef2f2; border: 1px solid #fca5a5; color: var(--vr-error); }
.vectiss-alerta-exito    { background: #f0fdf4; border: 1px solid #86efac; color: var(--vr-exito); }
.vectiss-alerta-info     { background: #eff6ff; border: 1px solid #93c5fd; color: var(--vr-primario); }

/* ===== Overlay carga ===== */
.vectiss-overlay-carga {
	position: fixed;
	inset: 0;
	background: rgba(255,255,255,.88);
	z-index: 99999;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
}

.vectiss-spinner {
	width: 44px;
	height: 44px;
	border: 4px solid var(--vr-borde);
	border-top-color: var(--vr-primario);
	border-radius: 50%;
	animation: vr-girar .7s linear infinite;
}
.vectiss-spinner-pequeno {
	width: 28px;
	height: 28px;
	border: 3px solid var(--vr-borde);
	border-top-color: var(--vr-primario);
	border-radius: 50%;
	animation: vr-girar .7s linear infinite;
	margin: 14px auto 0;
}
@keyframes vr-girar { to { transform: rotate(360deg); } }

.vectiss-carga-texto { font-size: 15px; color: var(--vr-texto-suave); margin: 0; font-weight: 500; }
.vectiss-cargando-texto { color: var(--vr-texto-suave); font-style: italic; text-align: center; padding: 20px 0; }

/* ===== Chip búsqueda ===== */
.vectiss-resumen-busqueda { margin-bottom: 20px; }
.vectiss-chip-busqueda { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.vectiss-chip-busqueda span {
	background: var(--vr-fondo);
	border: 1px solid var(--vr-borde);
	border-radius: 20px;
	padding: 4px 12px;
	font-size: 13px;
	color: var(--vr-texto-suave);
}

/* ===== Opciones (seguros/extras) ===== */
.vectiss-opciones-contenedor {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 24px;
	align-items: start;
}

.vectiss-lista-opciones { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }

.vectiss-opcion-item {
	border: 1.5px solid var(--vr-borde);
	border-radius: var(--vr-radio);
	overflow: hidden;
	transition: border-color var(--vr-transicion);
}
.vectiss-opcion-item:has(input:checked) { border-color: var(--vr-primario); }

.vectiss-opcion-item label {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 14px;
	cursor: pointer;
	width: 100%;
}
.vectiss-check-extra { display: flex; align-items: flex-start; gap: 12px; padding: 14px; cursor: pointer; }

.vectiss-opcion-info { flex: 1; }
.vectiss-opcion-info strong { display: block; font-size: 15px; margin-bottom: 2px; }
.vectiss-opcion-desc { font-size: 13px; color: var(--vr-texto-suave); margin: 0 0 4px; }
.vectiss-opcion-precio { font-size: 14px; font-weight: 600; color: var(--vr-primario); }
.vectiss-sin-opciones { color: var(--vr-texto-suave); font-style: italic; font-size: 14px; padding: 10px 0; }

.vectiss-cantidad-extra { padding: 8px 14px; background: var(--vr-fondo); border-top: 1px solid var(--vr-borde); }
.vectiss-cantidad-extra label { display: flex; align-items: center; gap: 8px; font-size: 13px; cursor: auto; }
.vectiss-input-cantidad { width: 72px !important; padding: 4px 8px !important; font-size: 14px !important; }

/* ===== Caja cotización ===== */
.vectiss-caja-cotizacion {
	background: var(--vr-fondo);
	border: 1.5px solid var(--vr-borde);
	border-radius: 10px;
	padding: 18px;
	position: sticky;
	top: 24px;
}

.vectiss-cotizacion-linea {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	font-size: 14px;
	padding: 6px 0;
	border-bottom: 1px solid var(--vr-borde);
}
.vectiss-cotizacion-linea:last-of-type { border-bottom: none; }
.vectiss-descuento { color: var(--vr-exito); }

.vectiss-total-linea {
	display: flex;
	justify-content: space-between;
	font-size: 17px;
	font-weight: 700;
	padding-top: 10px;
	margin-top: 6px;
	border-top: 2px solid var(--vr-texto);
}
.vectiss-precio-total { color: var(--vr-primario); }

/* ===== Preview reserva ===== */
.vectiss-preview-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.vectiss-preview-seccion {
	background: var(--vr-fondo);
	border: 1px solid var(--vr-borde);
	border-radius: var(--vr-radio);
	padding: 16px;
}
.vectiss-preview-seccion h3 {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--vr-texto-suave);
	margin: 0 0 10px;
}
.vectiss-preview-seccion p { font-size: 14px; margin: 0 0 6px; line-height: 1.5; }
.vectiss-preview-foto { width: 100%; border-radius: 6px; object-fit: cover; max-height: 120px; margin-bottom: 8px; }

/* ===== Sin resultados ===== */
.vectiss-sin-resultados { text-align: center; padding: 40px 20px; color: var(--vr-texto-suave); }

/* ===== Confirmación ===== */
.vectiss-confirmacion { text-align: center; padding: 40px 28px; }
.vectiss-icono-estado { font-size: 56px; margin-bottom: 16px; line-height: 1; }
.vectiss-icono-estado.vectiss-exito    { color: var(--vr-exito); }
.vectiss-icono-estado.vectiss-error    { color: var(--vr-error); }
.vectiss-icono-estado.vectiss-pendiente { color: var(--vr-advertencia); }

.vectiss-caja-detalle {
	background: var(--vr-fondo);
	border: 1px solid var(--vr-borde);
	border-radius: var(--vr-radio);
	padding: 20px;
	margin: 20px auto;
	max-width: 440px;
	text-align: left;
	font-size: 14px;
	line-height: 1.7;
}
