/* ==========================================================================
   OVERRIDES — gana al CSS del tema y de Elementor.
   El tema aplica estilos por defecto a los <button> (borde/fondo rojo) y a
   los íconos. Aquí se fuerza el estilo correcto de la landing.
   ========================================================================== */

/* --- Fondo: foto real FONDO2.webp (degradado teal/azul/púrpura con grano)
       + degradado navy encima. La opacidad del navy la controla el slider
       de Elementor vía --utem-tint (más slider = más textura visible).
       Solo Hero y Aranceles llevan la foto; el resto queda navy liso. --- */

/* Secciones CON foto de fondo controlable (Inicio / Inversión) */
.hero,
.aranceles {
	background-color: #002855 !important;
	background-image:
		linear-gradient(160deg, rgba(0, 30, 62, var(--utem-tint, 0.82)) 0%, rgba(0, 22, 48, var(--utem-tint, 0.82)) 100%),
		url('../img/FONDO2.webp') !important;
	background-size: cover, cover !important;
	background-repeat: no-repeat, no-repeat !important;
	background-position: center, center !important;
}

/* Secciones navy sin ruido */
.programas,
.cta-final {
	background-color: #002855 !important;
	background-image: linear-gradient(160deg, #01315f 0%, #002855 55%, #001d3e 100%) !important;
	background-size: cover !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
}

/* Aranceles: degradado azul→negro más oscuro en la parte superior */
.aranceles {
	background-image:
		linear-gradient(139deg,
			rgba(0, 8, 22, 0.94) 0%,
			rgba(0, 18, 40, 0.88) 18%,
			rgba(0, 22, 48, 0.87) 42%,
			rgba(0, 22, 48, var(--utem-tint, 0.82)) 100%),
		url('../img/FONDO2.webp') !important;
}

/* Programas: separa el enlace "Ver todos los programas" de las tarjetas */
.programas .programs-link {
	display: inline-block !important;
	margin-top: 44px !important;
}

/* Los overlays translúcidos deben dejar ver el grano */
.hero-bg-pattern {
	background: rgba(0, 31, 66, 0.55) !important;
}
.cta-final .hero-bg-pattern {
	background: transparent !important;
}


/* --- Reset de apariencia de botones dentro de las secciones UTEM --- */
.lead-form button,
.custom-select button,
.cs-trigger,
.cs-opt,
.btn {
	-webkit-appearance: none !important;
	appearance: none !important;
	background-image: none !important;
	box-shadow: none;
	text-transform: none !important;
	letter-spacing: normal;
	text-decoration: none;
	line-height: normal;
}

/* --- Trigger del selector (— Elige un programa —) --- */
.cs-trigger {
	background: rgba(255, 255, 255, 0.08) !important;
	color: rgba(255, 255, 255, 0.95) !important;
	border: 1px solid rgba(255, 255, 255, 0.18) !important;
	border-radius: 8px !important;
	width: 100% !important;
	text-align: left !important;
	font-weight: 300 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
}
.cs-trigger[aria-expanded="true"] {
	border-color: var(--utem-green) !important;
	background: rgba(255, 255, 255, 0.13) !important;
}

/* --- Opciones del panel --- */
.cs-opt {
	display: block !important;
	width: 100% !important;
	text-align: left !important;
	background: transparent !important;
	color: var(--utem-navy) !important;
	border: 0 !important;
	border-radius: 0 !important;
	margin: 0 !important;
	font-weight: 400 !important;
	white-space: normal !important;
}
.cs-opt:hover,
.cs-opt:focus-visible {
	background: rgba(0, 166, 81, 0.08) !important;
	color: var(--utem-navy) !important;
	outline: none !important;
}
.cs-opt[aria-selected="true"] {
	background: rgba(0, 166, 81, 0.11) !important;
	color: var(--utem-green) !important;
	font-weight: 500 !important;
}

/* --- Panel: sin bordes/scroll horizontal raros del tema --- */
.cs-panel {
	max-width: min(520px, 92vw) !important;
	overflow-x: hidden !important;
}

/* --- Botón "Solicita orientación acá" y demás botones verdes --- */
.btn-green,
.lead-form .btn-green,
.lead-form button[type="submit"] {
	background: var(--utem-green) !important;
	color: #fff !important;
	border: 1px solid var(--utem-green) !important;
	border-radius: var(--radius-btn) !important;
}
.btn-green:hover,
.lead-form button[type="submit"]:hover {
	filter: brightness(1.1) !important;
	color: #fff !important;
}

.btn-navy {
	background: var(--utem-navy) !important;
	color: #fff !important;
	border: 1px solid var(--utem-navy) !important;
	border-radius: var(--radius-btn) !important;
}
.btn-outline {
	background: transparent !important;
	color: #fff !important;
	border: 1px solid rgba(255, 255, 255, 0.3) !important;
	border-radius: var(--radius-btn) !important;
}

/* --- Íconos de Diferenciadores: verdes en reposo, blancos en hover --- */
.feature-icon,
.feature-icon i,
.feature-icon svg {
	color: var(--utem-green) !important;
}
.feature-icon svg,
.feature-icon svg path {
	fill: var(--utem-green) !important;
	stroke: currentColor;
}
.feature-icon i {
	font-size: 34px !important;
	line-height: 1 !important;
}
.feature-icon svg {
	width: 36px !important;
	height: 36px !important;
}

/* Hover: fondo verde + ícono blanco */
.feature-card:hover .feature-icon,
.feature-card:hover .feature-icon i,
.feature-card:hover .feature-icon svg {
	color: #fff !important;
}
.feature-card:hover .feature-icon svg,
.feature-card:hover .feature-icon svg path {
	fill: #fff !important;
	filter: none !important;
}

/* --- Mensaje de éxito: texto blanco sobre el formulario oscuro --- */
.lead-form + * .success-state h3,
.hero-form-wrap .success-state h3,
.success-state h3 {
	color: #fff !important;
}
.hero-form-wrap .success-state p,
.success-state p {
	color: rgba(255, 255, 255, 0.85) !important;
}
.success-state p strong {
	color: #fff !important;
}

/* --- Campos del formulario: fondo claro translúcido, borde más redondo --- */
.lead-form .form-group input,
.lead-form .form-group textarea,
.lead-form .cs-trigger {
	background: rgba(255, 255, 255, 0.12) !important;
	border: 1px solid rgba(255, 255, 255, 0.28) !important;
	border-radius: 14px !important;
	color: #fff !important;
	width: 100% !important;
	padding: 14px 18px !important;
	font-weight: 300 !important;
}
.lead-form .form-group input::placeholder {
	color: rgba(255, 255, 255, 0.45) !important;
}
.lead-form .form-group input:focus,
.lead-form .cs-trigger:focus-visible,
.lead-form .cs-trigger[aria-expanded="true"] {
	border-color: var(--utem-green) !important;
	background: rgba(255, 255, 255, 0.16) !important;
	box-shadow: 0 0 0 3px rgba(0, 166, 81, 0.22) !important;
}

/* Textos del formulario alineados a la izquierda */
.lead-form,
.lead-form .form-eyebrow,
.lead-form .form-group > label:not(.consent-check),
.lead-form .form-disclaimer {
	text-align: left !important;
}

/* --- Botón "Solicita orientación acá" a ancho completo y centrado --- */
.lead-form .btn-full,
.lead-form button[type="submit"] {
	display: flex !important;
	width: 100% !important;
	justify-content: center !important;
	align-items: center !important;
	text-align: center !important;
	gap: 8px !important;
}

/* --- Hero: alto completo de pantalla --- */
.hero {
	min-height: 100vh !important;
	min-height: 100dvh !important;
	overflow: hidden !important; /* evita que POSTGRADO desborde a la derecha */
}

/* Palabra fantasma "POSTGRADO": escala con el ancho, no desborda en móvil */
.hero-ghost-text {
	font-size: clamp(56px, 20vw, 160px) !important;
	max-width: 100vw;
}
@media (max-width: 640px) {
	.hero-ghost-text {
		font-size: 64px !important;
		left: -4px !important;
		right: auto !important;
	}
}

/* --- Sliders (testimonios, programas): 3 visibles, flechas, loop --- */
.utem-slider {
	position: relative;
	display: block;
	margin-top: 8px;
}
.utem-slider .ts-viewport {
	overflow: hidden;
	width: 100%;
}
/* Flechas absolutas: NO ocupan espacio, no achican el viewport */
.utem-slider .ts-arrow {
	position: absolute !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	z-index: 5 !important;
}
.utem-slider .ts-prev { left: -20px !important; }
.utem-slider .ts-next { right: -20px !important; }
/* Ocultar flechas cuando no hay más tarjetas que las visibles */
.utem-slider.utem-no-arrows .ts-arrow { display: none !important; }
.utem-slider .ts-arrow:hover { transform: translateY(-50%) scale(1.05) !important; }
@media (max-width: 900px) {
	.utem-slider .ts-prev { left: 2px !important; }
	.utem-slider .ts-next { right: 2px !important; }
}
.utem-slider .ts-track {
	display: flex;
	gap: 24px;
	will-change: transform;
	align-items: stretch;
}
.utem-slider .ts-track > * {
	margin: 0 !important;
	box-sizing: border-box;
}
.ts-arrow {
	-webkit-appearance: none !important;
	appearance: none !important;
	background-image: none !important;
	flex: 0 0 auto !important;
	width: 48px !important;
	height: 48px !important;
	padding: 0 !important;
	border-radius: 50% !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	cursor: pointer !important;
	transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease !important;
	box-shadow: none !important;
}
.ts-arrow svg { width: 20px; height: 20px; }
.ts-arrow:hover {
	background: var(--utem-green) !important;
	color: #fff !important;
	border-color: var(--utem-green) !important;
	transform: translateY(-1px) !important;
}

/* Programas (fondo navy): botón glass blanco translúcido */
.programas-slider .ts-arrow {
	background: rgba(255, 255, 255, 0.10) !important;
	color: #fff !important;
	border: 1px solid rgba(255, 255, 255, 0.28) !important;
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
}

/* Testimonios (fondo claro): botón blanco con ícono navy */
.testimonios-slider .ts-arrow {
	background: rgba(255, 255, 255, 0.92) !important;
	color: var(--utem-navy) !important;
	border: 1px solid rgba(0, 40, 85, 0.14) !important;
	box-shadow: 0 6px 18px rgba(0, 40, 85, 0.12) !important;
}

@media (max-width: 640px) {
	.ts-arrow { width: 42px !important; height: 42px !important; }
}

/* --- Foto de testimonio: siempre circular --- */
.testimonio-photo {
	width: 60px !important;
	height: 60px !important;
	min-width: 60px !important;
	aspect-ratio: 1 / 1 !important;
	border-radius: 50% !important;
	object-fit: cover !important;
	object-position: center !important;
	flex-shrink: 0 !important;
}
