/* styles-modern.css ADAPTADO PARA INICIA.STORE - VERSIÓN CON CORRECCIONES */

/* 1. Variables y Configuración Base */
:root {
    --ia-primary-color: #0A3951; 
    --ia-secondary-color: #FF7E36; 
    --ia-primary-light: #1A5978; 
    --ia-secondary-light: #FF9A62; 
  
    /* GRADIENTES */
    /* Para elementos de fondo como CTA o líneas decorativas */
    --ia-gradient-background: linear-gradient(45deg, var(--ia-primary-color), var(--ia-secondary-color)); 
    /* Para botones principales */
    --ia-gradient-button: linear-gradient(45deg, var(--ia-secondary-color), var(--ia-secondary-light)); 
  
    /* Variables genéricas (serán sobrescritas por las de Inicia Store) */
    --primary-color: var(--ia-primary-color);
    --secondary-color: var(--ia-secondary-color);
    --gradient: var(--ia-gradient-background); /* Usado por .gradient-line y .cta-modern */
    
    --text-color: #212529;
    --text-muted: #6c757d;
    --light-color: #ffffff;
    --light-subtle: #f8f9fa;
    --dark-color: var(--ia-primary-color); /* Fondo del footer será el azul primario */
    --border-color: #dee2e6;
    --border-color-translucent: rgba(0, 0, 0, 0.1);
  
    --font-family-base: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    --border-radius: 0.5rem;
    --border-radius-lg: 0.75rem;
    --border-radius-pill: 50rem;
    --shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.12);
  }
  
  /* Reset y Global */
  *, *::before, *::after { box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--font-family-base);
    color: var(--text-color);
    background-color: var(--light-color);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  
  h1, h2, h3, h4, h5, h6 { font-weight: 700; line-height: 1.3; color: var(--text-color); }
  .hero-modern h1, .hero-modern h2, .hero-modern h3 { color: var(--light-color); } /* Texto blanco en Hero */
  .cta-modern h2 { color: var(--light-color); } /* Texto blanco en CTA */
  .footer-modern h5 { color: var(--light-color); } /* Texto blanco en Footer */
  
  
  p { margin-bottom: 1rem; }
  a { color: var(--primary-color); text-decoration: none; transition: color 0.2s ease; }
  a:hover { color: var(--secondary-color); text-decoration: underline; }
  
  /* Utilidades de Texto */
  .text-highlight-orange { /* NUEVA CLASE para texto naranja sólido */
    color: var(--ia-secondary-color) !important; /* Forzar naranja */
  }
  .gradient-text { /* Mantenemos la clase por si se quiere usar en algún sitio específico, pero no en los títulos principales */
    background: var(--gradient);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    display: inline-block;
  }
  .gradient-line { /* Línea decorativa */
    height: 4px;
    background: var(--gradient); /* Usa el gradiente azul-naranja */
    border-radius: 2px;
    width: 60px;
  }
  
  .fs-sm { font-size: 0.875rem; }
  .fw-medium { font-weight: 500; }
  .fw-semibold { font-weight: 600; }
  .py-6 { padding-top: 6rem; padding-bottom: 6rem; }
  
  /* --- REGLAS PARA ICONOS FONT AWESOME (REFORZADAS) --- */
  .fas, .fa-solid {
    font-family: "Font Awesome 6 Free" !important; /* Nombre de la fuente sólida */
    font-weight: 900 !important; /* Peso para sólidos */
    font-style: normal !important;
    font-variant: normal !important;
    text-rendering: auto !important;
    display: inline-block !important;
    line-height: 1 !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    font-display: block; /* Ayuda al renderizado */
  }
  .fab, .fa-brands {
    font-family: "Font Awesome 6 Brands" !important; /* Nombre de la fuente de marcas */
    font-weight: 400 !important; /* Peso normal para marcas */
    font-style: normal !important;
    font-variant: normal !important;
    text-rendering: auto !important;
    display: inline-block !important;
    line-height: 1 !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    font-display: block;
  }
  /* Asegurar que los wrappers de iconos no interfieran */
  .feature-icon-modern i, .step-icon i, .benefit-list li i, .social-links-footer a i {
      /* No se necesitan estilos específicos aquí si las reglas de .fas/.fab son suficientemente fuertes */
  }
  /* --- FIN REGLAS ICONOS --- */
  
  
  /* 2. Navbar (Misma lógica de logos y colores que antes) */
  .navbar-modern {
    padding: 1rem 0;
    background-color: transparent; 
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: background-color 0.3s ease, box-shadow 0.3s ease, padding 0.3s ease;
    box-shadow: none;
    border-bottom: 1px solid transparent;
  }
  .navbar-modern.scrolled {
    background-color: rgba(255, 255, 255, 0.95);
    box-shadow: var(--shadow-sm);
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
  }
  .navbar-modern .navbar-brand img { height: 35px; transition: transform 0.3s ease; }
  .navbar-modern .navbar-brand .logo-main { display: block; } 
  .navbar-modern .navbar-brand .logo-scrolled { display: none; }
  .navbar-modern.scrolled .navbar-brand .logo-main { display: none; }
  .navbar-modern.scrolled .navbar-brand .logo-scrolled { display: block; }
  .navbar-modern .navbar-brand:hover img { transform: scale(1.05); }
  .navbar-modern .nav-link {
    color: var(--light-color); 
    font-weight: 500; padding: 0.5rem 1rem !important; position: relative; transition: color 0.2s ease;
  }
  .navbar-modern.scrolled .nav-link { color: var(--text-color); }
  .navbar-modern .nav-link:hover, .navbar-modern .nav-link.active { color: var(--ia-secondary-color); }
  .navbar-modern.scrolled .nav-link:hover, .navbar-modern.scrolled .nav-link.active { color: var(--ia-secondary-color); }
  .navbar-modern .navbar-toggler { border: none; font-size: 1.5rem; }
  .navbar-modern .navbar-toggler .navbar-toggler-icon { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.7%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }
  .navbar-modern.scrolled .navbar-toggler .navbar-toggler-icon { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.6%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }
  .navbar-modern .navbar-toggler:focus { box-shadow: none; }
  @media (max-width: 991.98px) {
    .navbar-modern .navbar-collapse { background-color: var(--light-color); border-radius: var(--border-radius); margin-top: 0.5rem; box-shadow: var(--shadow); padding: 1rem; border: 1px solid var(--border-color); }
    .navbar-modern .navbar-nav .nav-item { margin-bottom: 0.5rem; }
    .navbar-modern .navbar-nav .btn { width: 100%; margin-top: 0.5rem; }
    .navbar-modern.scrolled .nav-link, .navbar-modern .nav-link { color: var(--text-color) !important; }
    .navbar-modern.scrolled .nav-link:hover, .navbar-modern .nav-link:hover { color: var(--ia-secondary-color) !important; }
  }
  
  /* 3. Botones (Naranja para primario, Azul outline para secundario) */
  .btn { padding: 0.65rem 1.25rem; font-weight: 500; border-radius: var(--border-radius-pill); transition: all 0.3s ease; border: none; font-size: 0.95rem; letter-spacing: 0.5px; }
  .btn-lg { padding: 0.8rem 1.75rem; font-size: 1rem; }
  .btn-primary-gradient { background: var(--ia-gradient-button); color: white; box-shadow: 0 4px 15px rgba(255, 126, 54, 0.3); }
  .btn-primary-gradient:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(255, 126, 54, 0.35); color: white; }
  .btn-secondary-outline { background-color: transparent; color: var(--ia-primary-color); border: 2px solid var(--ia-primary-color); }
  .btn-secondary-outline:hover { background-color: var(--ia-primary-color); color: white; transform: translateY(-2px); box-shadow: 0 4px 10px rgba(10, 57, 81, 0.15); }
  /* Botón outline en Hero */
  .hero-modern .btn-secondary-outline { color: var(--light-color); border-color: var(--light-color); }
  .hero-modern .btn-secondary-outline:hover { background-color: var(--light-color); color: var(--ia-primary-color); border-color: var(--light-color); box-shadow: 0 4px 10px rgba(255, 255, 255, 0.15); }
  
  /* 4. Hero Section (Fondo Azul Oscuro) */
  .hero-modern { padding: 100px 0 80px 0; position: relative; overflow: hidden; background-color: var(--ia-primary-color); }
  .gradient-blur-circle { position: absolute; width: 500px; height: 500px; border-radius: 50%; filter: blur(100px); z-index: 0; opacity: 0.15; pointer-events: none; animation: pulse 15s infinite alternate ease-in-out; }
  .circle-1 { background-color: var(--ia-secondary-light); top: -150px; right: -100px; }
  .circle-2 { background-color: var(--ia-primary-light); bottom: -100px; left: -150px; animation-delay: 3s; }
  @keyframes pulse { 0% { transform: scale(0.9) rotate(0deg); opacity: 0.1; } 100% { transform: scale(1.1) rotate(15deg); opacity: 0.2; } }
  .hero-modern .container { position: relative; z-index: 1; }
  .hero-modern h1 { font-size: calc(1.5rem + 3vw); font-weight: 800; line-height: 1.2; letter-spacing: -1px; }
  .hero-modern .lead { font-size: 1.15rem; color: rgba(255, 255, 255, 0.75); max-width: 550px; }
  .hero-image-wrapper { position: relative; }
  .dashboard-modern { border-radius: var(--border-radius-lg); box-shadow: var(--shadow-lg); transform: perspective(1500px) rotateX(2deg) rotateY(-3deg) scale(0.98); transition: transform 0.5s ease, box-shadow 0.5s ease; }
  .dashboard-modern:hover { transform: perspective(1500px) rotateX(0deg) rotateY(0deg) scale(1); box-shadow: 0 30px 60px rgba(0, 0, 0, 0.15); }
  
  /* 5. Features Section (Iconos naranjas) */
  .feature-card-modern { background-color: var(--light-color); border: 1px solid var(--border-color-translucent); border-radius: var(--border-radius-lg); padding: 1.75rem; text-align: center; transition: all 0.3s ease; box-shadow: var(--shadow-sm); height: 100%; }
  .feature-card-modern:hover { transform: translateY(-8px); box-shadow: var(--shadow); border-color: var(--ia-primary-light); }
  .feature-icon-modern { width: 60px; height: 60px; border-radius: var(--border-radius); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem auto; background: linear-gradient(135deg, rgba(10, 57, 81, 0.05), rgba(255, 126, 54, 0.08)); /* Fondo más sutil */ }
  .feature-icon-modern i { font-size: 1.75rem; color: var(--ia-secondary-color) !important; /* Icono Naranja Sólido */ }
  .feature-card-modern h3 { font-weight: 600; font-size: 1.2rem; color: var(--ia-primary-color); }
  
  /* 6. How It Works Section / Steps (Números con gradiente azul-naranja) */
  .step-item { position: relative; background-color: var(--light-color); border-radius: var(--border-radius-lg); padding: 2rem 1.5rem 1.5rem; /* Ajuste padding superior para número */ box-shadow: var(--shadow-sm); text-align: center; height: 100%; margin-top: 25px; /* Espacio para el número */ }
  .step-item:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
  .step-number { width: 50px; height: 50px; border-radius: 50%; background: var(--gradient); color: white; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: 700; margin: 0 auto; box-shadow: 0 4px 10px rgba(10, 57, 81, 0.2); position: absolute; top: -25px; /* Mitad del alto del número */ left: 50%; transform: translateX(-50%); }
  /* Los iconos en step-item usarán el estilo de .feature-icon-modern, así que heredarán el color naranja del icono */
  .step-item h4 { color: var(--ia-primary-color); margin-top: 1rem; /* Espacio después del icono */ }
  
  
  /* 7. Benefits Section (Header destacado Naranja) */
  .benefit-card-modern { display: flex; flex-direction: column; background-color: var(--light-color); border: 1px solid var(--border-color-translucent); border-radius: var(--border-radius-lg); box-shadow: var(--shadow-sm); transition: all 0.3s ease; height: 100%; }
  .benefit-card-modern:hover { transform: translateY(-8px); box-shadow: var(--shadow); }
  .benefit-card-modern.featured { border-color: var(--ia-secondary-color); box-shadow: 0 8px 25px rgba(255, 126, 54, 0.15); }
  .benefit-card-modern.featured .benefit-header { background: var(--ia-gradient-button); color: white; }
  .benefit-card-modern.featured .benefit-header h3 { color: white; }
  .benefit-header { padding: 1.5rem; text-align: center; border-bottom: 1px solid var(--border-color-translucent); background-color: var(--light-subtle); border-top-left-radius: var(--border-radius-lg); border-top-right-radius: var(--border-radius-lg); }
  .benefit-header h3 { color: var(--ia-primary-color); }
  .benefit-body { padding: 1.75rem; flex-grow: 1; }
  .benefit-list { padding-left: 0; list-style: none; font-size: 0.95rem; }
  .benefit-list li { display: flex; align-items: flex-start; margin-bottom: 0.8rem; }
  .benefit-list li i { color: var(--ia-secondary-color) !important; /* Iconos de check Naranja Sólido */ margin-right: 0.75rem; margin-top: 0.2rem; font-size: 1rem; }
  .benefit-footer { padding: 1.5rem; border-top: 1px solid var(--border-color-translucent); }
  .benefit-card-modern .btn-secondary-outline { border-color: var(--ia-primary-color); color: var(--ia-primary-color); }
  .benefit-card-modern .btn-secondary-outline:hover { background-color: var(--ia-primary-color); color: white; box-shadow: 0 4px 10px rgba(10, 57, 81, 0.1); transform: translateY(-2px); }
  
  /* Testimonial Section (Avatares con borde naranja) */
  #testimonials .feature-card-modern:hover { /* Hereda hover de feature-card */
      border-color: var(--ia-secondary-light); /* Borde Naranja claro al hover para testimonios */
  }
  #testimonials .rounded-circle { /* El avatar en sí */
      border: 3px solid var(--ia-secondary-color) !important; /* Borde Naranja sólido */
  }
  
  /* 8. CTA Section (Fondo con gradiente azul-naranja) */
  .cta-modern { background: var(--gradient); position: relative; overflow: hidden; color: var(--light-color); padding-top: 5rem; padding-bottom: 5rem;} /* Ajustar padding */
  .cta-modern::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-image: radial-gradient(circle at top left, rgba(255,255,255,0.05) 0%, transparent 30%), radial-gradient(circle at bottom right, rgba(255,255,255,0.05) 0%, transparent 30%); opacity: 0.5; z-index: 0; }
  .cta-modern .container { position: relative; z-index: 1; }
  .cta-modern .lead { color: rgba(255, 255, 255, 0.85); max-width: 700px; margin-left: auto; margin-right: auto; }
  .cta-modern .btn-light { background-color: white; color: var(--ia-secondary-color); font-weight: 600; }
  .cta-modern .btn-light:hover { background-color: var(--light-subtle); color: var(--ia-primary-color); transform: translateY(-2px); box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); }
  
  /* 9. Footer (Fondo Azul Oscuro, acentos naranjas) */
  .footer-modern { background-color: var(--ia-primary-color); color: rgba(255, 255, 255, 0.7); padding: 4rem 0 2rem 0; font-size: 0.9rem; }
  .footer-modern .footer-tagline { color: rgba(255, 255, 255, 0.8); }
  .footer-heading::after { content: ''; position: absolute; bottom: -0.3rem; left: 0; width: 30px; height: 2px; background-color: var(--ia-secondary-color); }
  .footer-links { list-style: none; padding-left: 0; }
  .footer-links li { margin-bottom: 0.5rem; }
  .footer-links a { color: rgba(255, 255, 255, 0.7); }
  .footer-links a:hover { color: var(--ia-secondary-light); text-decoration: none; }
  .social-links-footer a { color: rgba(255, 255, 255, 0.7); font-size: 1.1rem; transition: color 0.2s ease, transform 0.2s ease; margin-right: 1rem; /* Añadido para separar iconos */ }
  .social-links-footer a:last-child { margin-right: 0; } /* Quitar margen al último icono */
  .social-links-footer a i.fab { color: rgba(255, 255, 255, 0.7) !important; } /* Forzar color inicial por si acaso */
  .social-links-footer a:hover i.fab { color: var(--ia-secondary-light) !important; /* Naranja claro al hover */ }
  .social-links-footer a:hover { color: var(--ia-secondary-light); transform: scale(1.1); }
  .footer-divider { border-top: 1px solid rgba(255, 255, 255, 0.1); margin: 2.5rem 0; }
  .footer-bottom p { font-size: 0.85rem; color: rgba(255, 255, 255, 0.5); margin-bottom: 0; }
  .footer-bottom a { color: var(--ia-secondary-light); text-decoration: none; font-weight: 500; }
  .footer-bottom a:hover { color: white; text-decoration: underline; }
  .footer-bottom i.fa-heart { color: var(--ia-secondary-color) !important; }
  
  
  /* Responsive Adjustments (finales) */
  @media (max-width: 991.98px) {
    .hero-modern h1 { font-size: calc(1.4rem + 2.5vw); }
  }
  @media (max-width: 767.98px) {
    .py-6 { padding-top: 4rem; padding-bottom: 4rem; }
    .hero-modern { padding: 80px 0 60px 0; }
    .hero-modern h1 { font-size: calc(1.3rem + 3.5vw); } /* Un poco más grande en móvil para impacto */
    .hero-modern .lead { font-size: 1rem; }
    .gradient-blur-circle { width: 80vw; height: 80vw; } /* Círculos más grandes en relación a la pantalla móvil */
    .circle-1 { top: -30vw; right: -40vw; }
    .circle-2 { bottom: -30vw; left: -40vw; }
    .cta-modern h2 { font-size: 1.8rem; }
    .step-item { margin-bottom: 2.5rem; /* Más separación en móvil para los step-items con el número arriba */ }
    .step-item:last-child { margin-bottom: 0; }
  }