/* EMI Index.css - Versión Responsiva Mejorada */

/* ===== RESET Y VARIABLES CSS ===== */
:root {
  /* Tamaños base responsivos */
  --h1-size: clamp(28px, 4vw, 48px);
  --h2-size: clamp(20px, 2.5vw, 32px);
  --text-large: clamp(16px, 1.4vw, 20px);
  --text-normal: clamp(14px, 1.2vw, 18px);
  --text-small: clamp(12px, 1vw, 16px);
  
  /* Espaciados responsivos */
  --spacing-xs: clamp(4px, 0.5vw, 8px);
  --spacing-sm: clamp(8px, 1vw, 16px);
  --spacing-md: clamp(16px, 2vw, 32px);
  --spacing-lg: clamp(24px, 3vw, 48px);
  --spacing-xl: clamp(32px, 4vw, 64px);
  
  /* Colores */
  --color-primary: #691B32;
  --color-secondary: #1e5b4f;
  --color-accent: #9b2247;
  --color-cream: #f8f6f1;
  --color-gray: #707070;
}

/* ===== FUENTES Y TIPOGRAFÍA ===== */
@font-face {
  font-family: 'Noto Sans Semicondensed Local';
  src: url("/static/emi/fonts/NotoSans-Bold.7c9dbd025c0b.woff") format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* Aplicar tamaños responsivos globalmente */
html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  font-size: var(--text-normal);
  line-height: 1.6;
  overflow-x: hidden;
}

.montserrat, .montserrat * {
  font-family: "Montserrat", "IBMPlexSans-Regular", Arial, sans-serif !important;
  font-size: var(--text-normal) !important;
}

.montserrat h1 {
  font-family: 'Noto Sans Semicondensed Local', 'Noto Sans', 'IBMPlexSans-Bold', 'Montserrat', Arial, sans-serif !important;
  font-weight: 700 !important;
  font-size: var(--h1-size) !important;
  line-height: 1.2 !important;
  margin: 0 !important;
}

.montserrat h2, .montserrat h3, .montserrat h4 {
  font-size: var(--h2-size) !important;
}

.montserrat p, .montserrat span {
  font-size: var(--text-normal) !important;
}

/* ===== CONTENEDOR PRINCIPAL ===== */
.container-fluid {
  max-width: 1920px;
  margin: 0 auto;
  padding-left: var(--spacing-md);
  padding-right: var(--spacing-md);
}

/* ===== UTILIDADES GENERALES ===== */
.title-separator {
  display: inline-block;
  width: 3px;
  height: clamp(40px, 5vw, 71px);
  background: #98989A;
  margin-left: var(--spacing-sm);
  margin-right: var(--spacing-lg);
  vertical-align: middle;
  border-radius: 1px;
}

.welcome-section { 
  margin-bottom: 0 !important; 
}

.welcome-row { 
  display: flex; 
  align-items: center; 
  gap: var(--spacing-md); 
}

.welcome-row h1 { 
  margin: 0; 
  line-height: 1.2; 
  padding: 0 var(--spacing-sm); 
}

.welcome-text { 
  flex: 1; 
}

.welcome-text p { 
  margin: 0; 
  font-size: var(--text-normal);
  color: #555; 
}

/* ===== HERO BANNER ===== */
.hero-banner {
  position: relative;
  background-color: #F3F3F3;
  background-image: url("/static/emi/images/BannerPrincipal.10a4becefd9c.png");
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
  overflow: visible;
  min-height: clamp(300px, 40vh, 600px);
}

.hero-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--spacing-md);
  min-height: clamp(300px, 40vh, 600px);
  padding: var(--spacing-md);
  position: relative;
  z-index: 1;
}

.hero-left { 
  display: flex; 
  align-items: center; 
  min-width: 0; 
}

.hero-left .hero-text {
  max-width: 100%;
  padding-left: var(--spacing-lg);
  width: 90%;
}

.hero-title { 
  color: var(--color-primary); 
  margin-bottom: var(--spacing-sm);
  text-align: left; 
  font-size: var(--h1-size) !important;
  padding-bottom: var(--spacing-md); 
}

#parrafo1 { 
  color: var(--color-gray); 
  line-height: 1.8; 
  text-align: justify;
  font-size: var(--text-normal) !important;
}

.hero-center {
  position: relative;
  z-index: 2;
  transition: all 0.3s ease;
}

.hero-center img {
  width: clamp(150px, 20vw, 380px);
  height: auto;
  object-fit: contain;
  display: block;
  pointer-events: none;
}

.hero-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-md);
}

.hero-cta .btn-emi {
  padding: var(--spacing-sm) var(--spacing-md) !important;
  border-radius: 999px !important;
}

/* ===== ICONOS DE CARACTERÍSTICAS ===== */
.icon-feature {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  margin: var(--spacing-md) 0;
}

.feature-canvas {
  position: relative;
  width: clamp(100px, 20vw, 350px);
  aspect-ratio: 1 / 1;
  --hover-rot: -5deg;
}

.feature-bg,
.feature-fg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.feature-fg {
  transform-origin: center bottom;
  transform: translate3d(0,0,0) rotate(0);
  transition: transform 220ms cubic-bezier(.2,.7,.2,1), filter 220ms ease;
  will-change: transform;
}

.icon-feature:hover .feature-fg {
  transform: translate3d(0,-8px,0) rotate(0);
  filter: drop-shadow(0 8px 12px rgba(0,0,0,.18));
}

.feature-title { 
  margin-top: var(--spacing-sm); 
  font-size: var(--text-normal) !important; 
}

/* ===== SECCIÓN CURSOS ===== */
.desktop-margin-4rem {
  margin-left: var(--spacing-xl);
  margin-right: var(--spacing-xl);
}

/* ===== SECCIÓN RECURSOS ===== */
.fondo_verde_oscuro {
  background-color: var(--color-secondary);
}

.fondo_verde_oscuro .welcome-section {
  position: relative;
  background-image: url("/static/emi/images/pleca_recursos_4.bc9f99702e49.png");
  background-repeat: no-repeat;
  /* Alinear la imagen al lado derecho para que al hacerse más estrecha se recorte por la izquierda */
  background-position: top left;
  /* Mantener la altura fija en 260px y dejar que el ancho sea el natural de la imagen (se recorta si es mayor que el contenedor) */
  background-size: auto 260px; /* ancho auto, alto 260px */
  background-attachment: scroll;
  width: 100%;
  /* Forzar una altura visual mínima para que la imagen mantenga presencia en pantallas grandes */
  min-height: 260px; /* ajusta según prefieras (30vh, 40vh, 50vh) */
  height: 260px;
  padding: 0;
  display: block;
  overflow: hidden; /* recorta la parte izquierda de la imagen cuando el contenedor sea más pequeño */
}

.recursos-section {
  padding: 0 !important;
  background: linear-gradient(to right, 
    transparent 0%, 
    transparent 35%, 
    #e6d194 35%, 
    #e6d194 100%);
  min-height: 400px;
  position: relative;
}

.recursos-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  min-height: 260px;
  padding: 3rem 4rem;
  position: relative;
  gap: 0;
}

.recursos-title {
  position: absolute;
  top: 2rem;
  right: 3rem;
  z-index: 3;
}

.recursos-title h1 {
  margin: 0;
  line-height: 1;
  white-space: nowrap;
  color: #691B32 !important;
  font-size: clamp(28px, 4vw, 48px) !important;
  font-weight: bold;
  text-shadow: 2px 2px 4px rgba(0,0,0,0.1);
}

.recursos-separator {
  display: inline-block;
  width: 3px;
  height: clamp(40px, 5vw, 71px);
  background: var(--color-primary);
  margin-left: 0;
  margin-right: var(--spacing-md);
  vertical-align: middle;
  border-radius: 1px;
  position: absolute;
  top: 2rem;
  left: 75%;
  z-index: 3;
}

.recursos-description {
  position: absolute;
  top: 2.5rem;
  right: 8rem;
  left: 21%;
  color: #000;
  font-size: clamp(16px, 1.3vw, 20px) !important;
  line-height: 1.5;
  text-align: center;
  z-index: 2;
  padding: 0 2rem;
}

.recursos-description span {
  display: inline-block;
  font-weight: 500;
  text-align: right;
}

/* Botón ESP/ENG de recursos en la parte inferior derecha */
.recursos-esp-eng-btn {
  position: absolute;
  bottom: 1.5rem;
  right: 2.5rem;
  z-index: 10;
}

@media (max-width: 767.98px) {
  .recursos-esp-eng-btn {
    bottom: 1rem;
    right: 1rem;
  }
}

/* ===== CARRUSEL ===== */
.carousel-container {
  position: relative;
  width: 100%;
  max-width: min(1400px, 90vw);
  margin: 0 auto;
  border-radius: 15px;
  backdrop-filter: blur(10px);
  padding: var(--spacing-md);
}

.carousel-wrapper {
  overflow: hidden;
  width: 100%;
}

.carousel-track {
  display: flex;
  gap: var(--spacing-lg);
  transition: transform 0.5s ease;
  justify-content: center;
}

.carousel-card {
  flex: 0 0 calc(25% - var(--spacing-lg));
  border-radius: 30px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  cursor: pointer;
}

.carousel-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.25);
}

.carousel-image {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 30px;
  transition: transform 0.3s ease;
  display: block;
  min-height: clamp(100px, 15vw, 150px);
}

.carousel-btn {
  position: absolute;
  top: 20px;
  bottom: 20px;
  background: none;
  color: #1e5b4f;
  border: none;
  width: clamp(6px, 0.8vw, 8px);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10;
  transition: all 0.3s ease;
  box-shadow: none !important;
}

.carousel-btn:hover {
  background: none;
  background-color: transparent !important;
  background-image: none !important;
  width: clamp(10px, 1vw, 12px);
}

.carousel-btn-prev {
  left: max(-40px, -3vw);
}

.carousel-btn-next {
  right: max(-40px, -3vw);
}

/* ===== BANNER DE DESCARGA ===== */
.banner-download {
  color: #ffffff;
  font-size: var(--text-large) !important;
  margin: 0;
  line-height: 1.4;
  padding: var(--spacing-sm);
  text-align: center;
}

/* Asegurar que el contenedor del banner esté centrado */
.welcome-image {
  text-align: center !important;
  justify-content: center !important;
  align-items: center !important;
}

/* Centrar específicamente el párrafo de descarga */
#parrafo_download {
  margin-top: 8rem;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  width: 100% !important;
}

/* ===== TIRA SOCIAL ===== */
.social-strip {
  margin-top: -1px !important;
  background-color: var(--color-secondary);
}

.social-strip .container {
  padding: var(--spacing-sm) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
}

.social-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(36px, 3vw, 40px);
  height: clamp(36px, 3vw, 40px);
  background-color: #002f2a;
  color: #fff;
  text-decoration: none;
  margin: 0 var(--spacing-xs);
  transition: background-color .3s ease;
  border-radius: 8px;
}

.social-btn i {
  font-size: clamp(1.2rem, 1.5vw, 1.4rem);
  color: #fff;
}

.social-btn:hover {
  background-color: #a57f2c;
}

/* ===== BANNERS EDUCATIVOS ===== */
.fondo_crema {
  background-color: var(--color-cream);
}

.educational-banners {
  padding: 0 var(--spacing-sm);
}

.educational-banners .col-md-3 {
  padding: 0 var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

.educational-banners img {
  max-width: 85% !important;
  width: 85% !important;
  height: auto !important;
  margin: 0 auto !important;
  display: block !important;
  border-radius: clamp(20px, 3vw, 30px) !important;
  transition: transform 0.3s ease !important;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.educational-banners img:hover {
  transform: scale(1.03) !important;
  box-shadow: 0 6px 12px rgba(0,0,0,0.15);
}

/* ===== FOOTER EMI ===== */
.footerEMI-section {
  background-color: #fff;
  padding: var(--spacing-md) 0;
}

.footerEMI-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

.footerEMI-btn,
.footerEMI-buttons .footerEMI-btn,
a.footerEMI-btn {
  background: transparent !important;
  border: none !important;
  color: #000 !important;
  padding: var(--spacing-xs) var(--spacing-sm);
  font-family: 'Montserrat', sans-serif;
  font-size: var(--text-small) !important;
  font-weight: 400;
  text-decoration: none !important;
  cursor: pointer;
}

.footerEMI-btn:hover,
.footerEMI-buttons .footerEMI-btn:hover,
a.footerEMI-btn:hover {
  color: #000 !important;
  text-decoration: underline !important;
  background: transparent !important;
}

.footerEMI-logo img {
  max-width: min(447px, 80vw);
  height: auto;
}

.footerEMI-copyright {
  color: #666;
  font-size: var(--text-small) !important;
  margin: 0;
}

/* ===== BOTONES EMI ===== */
.btn-emi {
  background: var(--color-accent) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: none !important;
  padding: calc(var(--spacing-xs) / 2) var(--spacing-xs) !important;
  border-radius: 10px !important;
  font-size: var(--text-small) !important;
  line-height: 1.2 !important;
  vertical-align: middle;
}

.btn-emi:hover {
  background: var(--color-secondary) !important;
  color: #fff !important;
}

/* ===== RESPONSIVE DESIGN ===== */

/* Pantallas grandes (1400px+) */
@media (min-width: 1400px) {
  :root {
    --h1-size: 45px;
    --h2-size: 28px;
    --text-large: 20px;
    --text-normal: 18px;
    --text-small: 14px;
  }
}

/* Desktop mediano (1200px - 1399px) */
@media (min-width: 1200px) and (max-width: 1399.98px) {
  :root {
    --h1-size: 42px;
    --h2-size: 26px;
  }
  
  .carousel-card {
    flex: 0 0 calc(25% - 30px);
  }
}

/* Desktop pequeño (992px - 1199px) */
@media (min-width: 992px) and (max-width: 1199.98px) {
  :root {
    --h1-size: 38px;
    --h2-size: 24px;
    --text-large: 17px;
    --text-normal: 15px;
  }
  
  .carousel-card {
    flex: 0 0 calc(33.333% - 20px);
  }
  
  .hero-center img {
    width: clamp(200px, 22vw, 320px);
  }
}

/* Tablet grande (768px - 991px) */
@media (min-width: 768px) and (max-width: 991.98px) {
  :root {
    --h1-size: 35px;
    --h2-size: 22px;
    --text-large: 16px;
    --text-normal: 14px;
    --text-small: 12px;
  }
  
  .hero-inner {
    grid-template-columns: 1fr auto 0.5fr;
  }
  
  .hero-center img {
    width: clamp(180px, 20vw, 280px);
  }
  
  .carousel-card {
    flex: 0 0 calc(50% - 15px);
  }
  
  .recursos-row {
    padding: var(--spacing-md);
  }
  
  .recursos-title h1 {
    font-size: 32px !important;
  }
}

/* Tablet y móvil (máx 767px) */
@media (max-width: 767.98px) {
  :root {
    --h1-size: 30px;
    --h2-size: 20px;
    --text-large: 15px;
    --text-normal: 14px;
    --text-small: 12px;
    --spacing-xl: 24px;
    --spacing-lg: 20px;
    --spacing-md: 16px;
  }
  
  .title-separator {
    display: none !important;
  }
  
  .welcome-row {
    flex-direction: column;
    align-items: stretch;
  }
  
  .hero-inner {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: var(--spacing-md);
  }
  
  .hero-center {
    display: none;
  }
  
  .hero-left .hero-text {
    padding-left: var(--spacing-sm);
    padding-right: var(--spacing-sm);
    width: 100%;
  }
  
  .hero-title {
    text-align: center;
    font-size: 28px !important;
  }
  
  .desktop-margin-4rem {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  /* Regla específica para el elemento con margin-left: 6rem */
  .row .col-md-3.text-center.ms-3.desktop-margin-4rem[style*="margin-left: 6rem"] {
    margin-left: 0 !important;
  }
  .carousel-card {
    flex: 0 0 calc(100% - 20px);
    max-width: 280px;
  }
  
  .carousel-track {
    gap: var(--spacing-md);
  }
  
  .recursos-description,
  .recursos-title {
    position: static;
    margin-bottom: var(--spacing-sm);
  }
  
  .recursos-separator {
    position: static;
    display: inline-block;
    margin-bottom: var(--spacing-sm);
    margin-right: var(--spacing-sm);
  }
  
  .fondo_verde_oscuro .welcome-section {
    min-height: 260px;
    height: 260px;
    padding: var(--spacing-md);
    position: relative;
    background-image: 
      linear-gradient(rgba(237, 216, 153, 0.9), rgba(237, 216, 153, 0.9)),
      url("/static/emi/images/pleca_recursos_4.bc9f99702e49.png");
    background-repeat: no-repeat;
    background-position: top left;
    background-size: auto 260px;
  }
  
  .social-strip .container {
    flex-direction: column !important;
    gap: var(--spacing-sm) !important;
    text-align: center !important;
  }
  
  .educational-banners .col-md-3 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
  
  .footerEMI-buttons {
    flex-direction: column;
    align-items: center;
  }
}

/* Ajustes para prevenir zoom en móviles */
@media (max-width: 480px) {
  html {
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
  }
  
  input, select, textarea {
    font-size: 16px !important; /* Previene zoom en iOS */
  }

  .hero-banner {
    background-image: none;
  }
  
  .carousel-container {
    padding: var(--spacing-sm);
  }
  
  .carousel-btn-prev {
    left: -15px;
  }
  
  .carousel-btn-next {
    right: -15px;
  }
  
  .footerEMI-logo img {
    max-width: 200px;
  }
}

/* Preferencias de movimiento reducido */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* Ajustes para pantallas de alta densidad de píxeles */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .hero-banner {
    background-size: contain;
  }
}

/* Override específico para botones del footer - mayor especificidad */
.footerEMI-section .footerEMI-buttons .footerEMI-btn:hover,
.footerEMI-section .footerEMI-buttons .footerEMI-btn:focus,
.footerEMI-section .footerEMI-buttons a.footerEMI-btn:hover,
.footerEMI-section .footerEMI-buttons a.footerEMI-btn:focus,
.footerEMI-section a.footerEMI-btn:hover,
.footerEMI-section a.footerEMI-btn:focus {
  color: #000 !important;
  text-decoration: underline !important;
  background: transparent !important;
}