/* Fixes mobile layout for IA section */
@media (max-width: 900px) {
  /* IA grid en una columna para evitar corte */
  #ia .ia-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  #ia h2 {
    font-size: clamp(22px, 5vw, 28px);
  }
  #ia .feature {
    padding: 14px 16px;
  }
  #ia .feature i {
    font-size: 18px;
  }
  #ia .feature h3 {
    font-size: 16px;
  }
  #ia .feature .muted {
    font-size: 14px;
  }
  #ia aside.panel {
    width: 100%;
  }
  /* Asegurar que cualquier style inline de separación no rompa la columna */
  #ia aside.panel > div[style] { height: 10px !important; }
  #ia aside.panel .bullets {
    margin: 0;
    padding-left: 18px;
  }
  #ia aside.panel .bullets li {
    font-size: 14px;
  }
  /* Espaciado entre las features para una sola columna */
  #ia .feature + .feature { margin-top: 12px; }
  #ia .neon-btn { margin-right: 10px; }
  #ia aside.panel .mini {
    font-size: 12px;
  }
  /* Tame overly strong neon borders on mobile to avoid overflow */
  #ia .feature.neon-border {
    box-shadow: 0 0 0 1px rgba(255, 80, 80, 0.35), 0 0 22px rgba(255, 80, 80, 0.18);
  }
}
@media (max-width: 900px) {
  /* Contacto: formulario a una sola columna */
  #contacto .form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  }
  #contacto .form-row {
    display: block;
  }
  #contacto .form-row label {
    display: block;
  }
  #contacto .form-row input,
  #contacto .form-row select,
  }
  #contacto .btn.btn-primary {
    width: 100%;
  }
  #contacto .btn.btn-secondary {
    width: 100%;
  }
  /* Unificar otras secciones en una columna */
  .container.hero-grid,
  .asesorias-grid {
    display: grid;
    grid-template-columns: 1fr;
  }
  .programas-grid,
  .para-grid,
  .apr-grid,
  .problem-grid,
  .metodo-flow {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  /* Ajustes tipográficos globales en mobile */
  .section-title {
    font-size: clamp(22px, 5.5vw, 28px);
  }
  .container {
    padding-left: 14px;
/* Fixes mobile layout for IA section */
@media (max-width: 900px) {
  #ia .ia-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px;
    align-items: start;
  }

  #ia h2 {
    font-size: clamp(22px, 5vw, 28px);
    line-height: 1.15;
    margin-bottom: 12px;
  }

  #ia .feature {
    padding: 14px 16px;
    border-radius: 14px;
  }

  #ia .feature i {
    font-size: 18px;
    min-width: 22px;
    margin-right: 10px;
  }

  #ia .feature h3 {
    font-size: 16px;
    line-height: 1.2;
    margin-bottom: 6px;
  }

  #ia .feature .muted {
    font-size: 14px;
    line-height: 1.35;
    overflow-wrap: anywhere;
  }

  #ia aside.panel {
    width: 100%;
    max-width: none;
    margin-top: 12px;
    padding: 14px 16px;
    border-radius: 16px;
    display: block;
  }

  /* Asegurar que cualquier style inline de separación no rompa la columna */
  #ia aside.panel > div[style] { height: 10px !important; }

  #ia aside.panel .bullets {
    margin: 0;
    padding-left: 18px;
    list-style: disc;
  }

  #ia aside.panel .bullets li {
    font-size: 14px;
    line-height: 1.35;
    overflow-wrap: anywhere;
    margin-bottom: 8px;
  }

  /* Espaciado entre las features para una sola columna */
  #ia .feature + .feature { margin-top: 12px; }
  #ia .neon-btn { margin-right: 10px; }

  #ia aside.panel .mini {
    font-size: 12px;
    margin-top: 10px;
  }

  /* Tame overly strong neon borders on mobile to avoid overflow */
  #ia .feature.neon-border {
    box-shadow: 0 0 0 1px rgba(255, 80, 80, 0.35), 0 0 22px rgba(255, 80, 80, 0.18);
  }
    padding-right: 14px;
  }
}
:root{
  --bg:#0b0b0f;
  --bg-alt:#12121a;
  --text:#f2f2f5;
  --muted:#b7b7c2;
  --primary:#ff2d2d; /* rojo del logo */
  --primary-700:#c51f1f;
  --accent:#8a2be2; /* morado neon */
  --accent-700:#6f22b8;
  --border:#22222b;
  --gradient: radial-gradient(1200px 600px at 20% 10%, rgba(255,45,45,0.15) 0%, rgba(11,11,15,0) 60%),
              radial-gradient(800px 400px at 80% 30%, rgba(255,45,45,0.10) 0%, rgba(11,11,15,0) 60%),
              linear-gradient(180deg, #0b0b0f 0%, #12121a 100%);
  --neon:#ff3b3b;
  --neon-soft:rgba(255,59,59,0.5);
  --neon-purple:#9d4df1;
  --neon-purple-soft:rgba(157,77,241,0.5);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:var(--text);text-decoration:none}

.container{max-width:1280px;margin:0 auto;padding:0 28px}
.site-header{position:sticky;top:0;background:rgba(11,11,15,0.85);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--border);z-index:100}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;padding:6px 10px;border-radius:12px;background:rgba(255,255,255,0.06);border:1px solid var(--border)}
.logo img{height:32px}
.site-header.scrolled .logo{background:rgba(255,255,255,0.08)}
.logo:hover{background:rgba(255,255,255,0.10)}
.nav a{margin-left:18px;color:var(--muted)}
.nav .btn{margin-left:24px}

/* Toggle menú móvil */
.menu-toggle{display:none;background:#0e0e13;border:1px solid var(--border);color:var(--text);height:40px;width:44px;border-radius:10px;align-items:center;justify-content:center}
.menu-toggle i{font-size:18px}

/* Menú móvil fullscreen */
.mobile-menu[hidden]{display:none}
.mobile-menu{position:fixed;inset:0;background:radial-gradient(1000px 600px at 20% 10%, rgba(255,45,45,0.20) 0%, rgba(11,11,15,0) 55%), var(--bg);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s ease}
.mobile-menu.is-open{opacity:1;pointer-events:auto}
.mobile-menu-inner{height:100%;display:flex;flex-direction:column;padding:16px}
.mobile-menu-header{display:flex;align-items:center;justify-content:space-between}
.mobile-menu .logo{background:transparent;border-color:transparent;padding:6px}
.mobile-menu .logo img{height:30px}
.menu-close{background:#0e0e13;border:1px solid var(--border);color:var(--muted);height:40px;width:44px;border-radius:10px}
.mobile-menu-list{list-style:none;padding:20px 8px 8px;margin:0;display:flex;flex-direction:column;gap:16px}
.mobile-menu-list li{opacity:0;transform:translateY(12px);transition:opacity .35s ease, transform .35s ease}
.mobile-menu.is-open .mobile-menu-list li{opacity:1;transform:translateY(0);transition-delay:calc(var(--i,1) * 60ms)}
.mobile-menu-list a{display:block;font-size:22px;padding:12px 10px;border-radius:12px;color:#fff;background:transparent;border:1px solid transparent}
.mobile-menu-list a:hover{border-color:var(--accent)}
.mobile-menu-list .btn{display:inline-block;font-size:18px;padding:14px 18px}

/* Evitar scroll del body cuando está el menú */
body.no-scroll{overflow:hidden}

.btn{display:inline-block;padding:12px 18px;border-radius:12px;border:1px solid var(--border);transition:.2s ease;font-weight:600}
.btn-primary{background:linear-gradient(90deg,var(--primary),var(--accent));color:#fff;border-color:transparent;box-shadow:0 0 14px var(--neon-soft), 0 0 18px var(--neon-purple-soft)}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 0 18px var(--neon-soft), 0 0 24px var(--neon-purple-soft)}
.btn-secondary{background:#0e0e13;color:var(--text);border-color:var(--accent)}
.btn-secondary:hover{border-color:var(--primary);color:#fff;box-shadow:0 0 12px var(--neon-purple-soft)}

/* Neon accents */
.neon-btn{box-shadow:0 0 12px var(--neon-soft), inset 0 0 8px var(--neon-soft);text-shadow:0 0 6px var(--neon-soft)}
.neon-border{border-color:var(--neon);box-shadow:0 0 16px var(--neon-soft)}
.neon-glow{box-shadow:0 0 24px var(--neon-soft)}

.hero{background:var(--gradient);padding:96px 0}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero h1{font-size:52px;line-height:1.05;margin:0 0 16px}
.hero p{color:var(--muted);font-size:20px}
.hero-sub{font-size:20px;color:var(--muted);max-width:720px}
.hero-ctas{margin:20px 0;display:flex;gap:12px;flex-wrap:wrap}
.cred-section .cred-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-top:10px}
.cred-item{background:#0e0e13;border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.cred-item .badge{font-weight:600}

/* Nueva sección de credibilidad con números grandes */
.cred-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-auto-rows:1fr;gap:26px;margin-top:8px}
.cred-stat{background:#0e0e13;border:1px solid var(--border);border-radius:20px;padding:24px 22px;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden;min-height:180px;text-align:center}
.cred-stat:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(255,61,61,.12),rgba(157,77,241,.10) 50%,transparent 75%);opacity:0;transition:.4s ease}
.cred-stat:hover:before{opacity:1}
.cred-stat i{font-size:30px;margin-bottom:12px;color:var(--primary);filter:drop-shadow(0 0 8px rgba(255,61,61,.45));transition:.3s ease}
.cred-stat:hover i{transform:translateY(-4px)}
.cred-stat .stat-number{font-size:50px;font-weight:700;line-height:1;letter-spacing:.5px;margin:4px 0 10px;font-variant-numeric:tabular-nums;background:linear-gradient(90deg,#ffcb3b 0%,#ff2f5d 40%,#8a6bff 80%);background-size:160% 160%;-webkit-background-clip:text;color:transparent;animation:gradientShift 10s linear infinite;text-shadow:0 2px 12px rgba(0,0,0,.55)}
.cred-stat .stat-number.count-complete{filter:drop-shadow(0 0 12px rgba(255,61,61,.45))}
.cred-stat .stat-label{margin-top:auto;font-size:14px;color:var(--muted);max-width:95%;line-height:1.3}
.cred-stat.static .stat-static{font-size:32px;font-weight:700;line-height:1;margin:4px 0 12px;background:linear-gradient(90deg,var(--primary),var(--accent));-webkit-background-clip:text;color:transparent;letter-spacing:.5px}
.cred-stat.static i{color:var(--accent)}
@media (max-width:900px){
  .cred-stat{min-height:160px;padding:22px 20px}
  .cred-stat .stat-number{font-size:44px}
  .cred-stat.static .stat-static{font-size:30px}
}
@media (prefers-reduced-motion: reduce){
  .cred-stat .stat-number{animation:none}
}

.problema-section .problem-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:18px}
.problem-item{background:#0e0e13;border:1px solid var(--border);border-radius:16px;padding:18px}
.problem-item h3{margin:0 0 8px;font-size:18px;color:#fff}
.problem-item p{margin:0;color:var(--muted);font-size:14px}
.problem-intriga{margin-top:26px;font-size:18px;color:var(--muted)}

.metodo-section .metodo-flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:18px;position:relative}
.metodo-step{background:#0e0e13;border:1px solid var(--border);border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:10px}
.metodo-step h3{margin:0;font-size:18px;color:#fff}
.metodo-step ul{margin:0;padding-left:18px;color:var(--muted);font-size:14px}
.metodo-cierre{margin-top:28px;font-size:18px;color:var(--muted)}

.para-section .para-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.para-item{background:#0e0e13;border:1px solid var(--border);border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.icon-circle{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--accent));font-size:24px;box-shadow:0 0 10px var(--neon-soft)}
.para-item h3{margin:4px 0 0;font-size:18px;color:#fff}
.para-item p{margin:0;color:var(--muted);font-size:14px}

.aprender-section .apr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:10px}
.apr-item{background:#0e0e13;border:1px solid var(--border);border-radius:14px;padding:16px;font-size:14px;color:var(--muted);position:relative}
.apr-item:before{content:"";position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:0 0 6px var(--neon-soft)}

.resultados-section .result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:18px}
.result-item{background:#0e0e13;border:1px solid var(--border);border-radius:16px;padding:18px}
.result-item h3{margin:0 0 8px;font-size:18px;color:#fff}
.result-item p{margin:0;color:var(--muted);font-size:14px}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:30px}
.testi{background:#0e0e13;border:1px solid var(--border);border-radius:14px;padding:16px;font-size:14px;color:var(--muted);margin:0}

.programas-section .programas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:16px}
.program-card{background:#0e0e13;border:1px solid var(--border);border-radius:18px;padding:20px;transition:.25s ease}
.program-card h3{margin:0 0 10px;font-size:18px;color:#fff}
.program-card p{margin:0;color:var(--muted);font-size:14px}
.program-card:hover{box-shadow:0 0 20px var(--neon-soft);transform:translateY(-4px)}
.program-cta{margin-top:32px;text-align:center}

.bonus-section .bonus-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:16px}
.bonus-item{background:#0e0e13;border:1px solid var(--border);border-radius:18px;padding:20px}
.bonus-item h3{margin:0 0 10px;font-size:18px;color:#fff}
.bonus-item p{margin:0;font-size:14px;color:var(--muted)}

.cta-final-section{text-align:center}
.cta-final-section .cta-sub{font-size:20px;color:var(--muted);max-width:640px;margin:0 auto 24px}
.cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Equipo */
.team-section .team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:12px}
.team-card{background:#0e0e13;border:1px solid var(--border);border-radius:18px;padding:18px;text-align:center;transition:.25s ease}
.team-card:hover{box-shadow:0 0 20px var(--neon-soft);transform:translateY(-4px)}
.team-photo-wrap{display:block;margin:0 0 12px}
.team-photo{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;border-radius:14px;border:1px solid var(--border);box-shadow:0 8px 24px rgba(0,0,0,.35)}
.team-name{margin:12px 0 4px;font-size:18px;color:#fff}
.team-role{margin:0;color:var(--muted);font-size:14px}

@media (max-width:900px){
  .container{padding:0 16px}
  .hero h1{font-size:34px;line-height:1.1}
  .hero-sub{font-size:17px}
  .cta-final-section .cta-sub{font-size:17px}
  .nav{display:none}
  .menu-toggle{display:inline-flex}
  /* Hero imagen: centrar y ocupar ancho completo en móvil */
  .hero-media{display:flex;justify-content:center}
  .hero-image{max-width:100%;}
  .hero-image img{width:100%;height:auto;object-fit:contain;max-width:100%;}
  .hero-grid{grid-template-columns:1fr}
  /* IA grid en una columna para evitar corte */
  #ia .ia-grid{grid-template-columns:1fr}
  #ia .panel{margin-top:16px}
  /* Secciones: títulos más compactos */
  .section h2{font-size:28px}
  /* Credibilidad: evitar overflow horizontal */
  .cred-stats{gap:18px}
  .cred-stat .stat-label{font-size:13px}
  /* Carrusel: asegurar ajuste al viewport */
  .carousel{grid-template-columns:32px 1fr 32px}
  .carousel-track{gap:10px}
}
.hero-bullets{list-style:none;padding:0;margin:18px 0 0;color:var(--muted)}
.hero-bullets li{margin:8px 0}
.hero-bullets-source{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.hero-bullets-animated{margin:24px 0 0;font-size:18px;color:var(--muted);min-height:28px;position:relative}
.hero-bullets-animated:after{content:"";display:inline-block;width:10px;height:22px;background:linear-gradient(90deg,var(--primary),var(--accent));margin-left:6px;animation:cursorBlink 1s steps(2,start) infinite;border-radius:4px;vertical-align:middle}
@keyframes cursorBlink{0%{opacity:1}50%{opacity:0}100%{opacity:1}}
.bullet-fade{animation:bulletFade .4s ease}
@keyframes bulletFade{0%{opacity:0;transform:translateY(6px)}100%{opacity:1;transform:translateY(0)}}
.video-embed iframe{width:100%;aspect-ratio:16/9;border-radius:12px;border:1px solid var(--border)}

.section{padding:80px 0}
.section.alt{background:var(--bg-alt)}
.section h2{font-size:36px;margin:0 0 28px}
.section-title{position:relative;display:inline-block;padding-bottom:10px;letter-spacing:.2px}
.section-title:after{content:"";position:absolute;left:0;bottom:0;width:160px;height:8px;background:linear-gradient(90deg, rgba(255,61,61,0.95), rgba(157,77,241,0.95));border-radius:8px;box-shadow:0 0 16px rgba(255,61,61,.55), 0 0 20px rgba(157,77,241,.45)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{border:1px solid var(--border);border-radius:18px;padding:22px;background:#0e0e13}
.course-card{display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}
.course-card .media-wrap{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--border)}
.course-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.price-badge{position:absolute;right:10px;top:10px;background:linear-gradient(90deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;animation:gradientShift 6s ease-in-out infinite;color:#fff;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;box-shadow:0 0 10px rgba(255,59,59,.4),0 0 14px rgba(157,77,241,.4)}
.course-card .card-actions{margin-top:auto}
.course-card:hover{box-shadow:0 0 22px rgba(255,59,59,.35),0 0 30px rgba(157,77,241,.25);transform:translateY(-4px);transition:.25s ease}
.course-card h3{margin:4px 0 4px;font-size:20px}
.course-card p{font-size:14px}

/* Glow dinámico y pseudo-elemento halo */
.course-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 60% 40%,rgba(255,61,61,.12),rgba(157,77,241,.10) 40%,transparent 70%);opacity:0;transition:.35s ease;pointer-events:none}
.course-card:hover:before{opacity:1}
.course-card{will-change:transform}

@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* Animación suave de botones primarios opcional */
.btn-primary{background-size:180% 180%;animation:gradientShift 8s linear infinite}
.service-card{transition:transform .2s ease, box-shadow .2s ease}
.service-card:hover{transform:translateY(-4px);box-shadow:0 0 22px var(--neon-soft)}
.service-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.service-head i{color:var(--primary);font-size:22px;filter:drop-shadow(0 0 6px rgba(255,59,59,.35))}
.service-card:hover .service-head i{transform:scale(1.08);filter:drop-shadow(0 0 10px rgba(255,59,59,.55))}
.service-head i{transition:transform .2s ease, filter .2s ease}

/* divisores sutiles entre tarjetas */
.cards{position:relative}
.cards:before{content:"";position:absolute;left:0;right:0;top:-10px;height:1px;background:linear-gradient(90deg, rgba(255,59,59,.25), rgba(255,59,59,0) 60%)}
.card h3{margin:0 0 8px}
.card h3{font-size:22px;letter-spacing:.2px}
.card p{color:var(--muted)}
.card ul{color:var(--muted)}

.profile{display:flex;gap:24px;align-items:center}
.profile img{width:140px;height:140px;object-fit:cover;border-radius:16px;border:1px solid var(--border);box-shadow:0 8px 24px rgba(0,0,0,.35)}
.profile h3{font-size:24px;margin:0 0 6px}
.profile p{font-size:18px;color:var(--muted)}
.profile .btn{padding:14px 18px;font-weight:600}

.bullets{color:var(--muted)}
.resource-list{color:var(--muted)}

.carousel{display:grid;grid-template-columns:40px 1fr 40px;gap:12px;align-items:center}
.carousel-track{display:grid;grid-auto-flow:column;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px}
.carousel-item{scroll-snap-align:center;border:1px solid var(--border);border-radius:12px;padding:8px;}
.carousel button{background:#0e0e13;border:1px solid var(--border);color:var(--muted);height:40px;border-radius:10px}

.form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row{display:flex;flex-direction:column}
.form-row input,.form-row select,.form-row textarea{background:#0e0e13;border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px}
.form button{grid-column:1/3}
/* Armonizar campo telefónico (intl-tel-input) a ancho completo */
#contacto .iti{width:100%;}
#contacto .iti input.iti__tel-input,
#contacto .iti input.iti__tel-input[type=text],
#contacto .iti input.iti__tel-input[type=tel]{
  width:100%;
  font-size:16px;
  line-height:1.25;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#0e0e13;
  color:var(--text);
}
#contacto .iti .iti__selected-country-primary{height:100%;}
#contacto .iti .iti__selected-country{border-radius:12px 0 0 12px;}
#contacto .iti .iti__selected-dial-code{color:var(--muted);}
/* Overrides móviles sólidos para el formulario y grids en general */
@media (max-width: 900px) {
  /* Formulario: una columna sin overflow */
  #contacto .form { grid-template-columns: 1fr !important; }
  #contacto .form-row { width: 100%; }
  #contacto .form-row input,
  #contacto .form-row select,
  #contacto .form-row textarea { width: 100%; max-width: 100%; min-width: 0; }
  #contacto .form button { grid-column: 1 / 2; width: 100%; }
  #contacto .btn.btn-secondary { width: 100%; }

  /* Grids potencialmente problemáticos a una columna */
  .hero-grid { grid-template-columns: 1fr !important; }
  .asesorias-grid { grid-template-columns: 1fr !important; }
}

.site-footer{border-top:1px solid var(--border);padding:30px 0;background:#0e0e13}
.footer-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:20px}
.footer-logo{height:28px;margin-bottom:10px}
.social a{display:inline-block;margin-right:16px;color:var(--muted)}

@media (max-width:900px){
  .hero-grid,.footer-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
}

/* IA Section enhanced */
#ia .ia-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:start}
#ia .feature{display:flex;gap:16px;padding:16px 20px;background:#0e0e13;border:1px solid var(--border);border-radius:14px}
#ia .feature i{color:var(--primary);font-size:24px}
#ia .panel{padding:20px;background:#0e0e13;border:1px solid var(--border);border-radius:14px}
#ia .panel h3{margin:0 0 12px 0}
#ia .panel .mini{color:var(--muted);font-size:14px}

/* Modal */
.modal{position:fixed;inset:0;display:none}
.modal.is-open{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.modal-content{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(520px,92vw);background:#0e0e13;border:1px solid var(--border);border-radius:14px;padding:18px}
.modal-close{position:absolute;right:12px;top:10px;background:#0e0e13;border:1px solid var(--border);color:var(--muted);height:32px;width:32px;border-radius:8px}

.muted{color:var(--muted)}

/* Modal enroll ajustes ancho teléfono */
#enroll-form .form-row input#enroll-phone{width:100%}
#enroll-form .iti{width:100%}
#enroll-form .form-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(157,77,241,.4),0 0 12px rgba(255,61,61,.35)}

/* Asesorías en dos columnas con banda */
.asesorias-highlight{position:relative;background:
  radial-gradient(700px 300px at 20% 30%, rgba(255,45,45,0.12) 0%, rgba(11,11,15,0) 60%),
  var(--bg-alt);
}
.asesorias-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}
.asesorias-media img{width:100%;max-width:520px;border-radius:20px;border:1px solid var(--border);box-shadow:0 12px 36px rgba(0,0,0,.45)}
.asesorias-content h2{font-size:42px;margin:0 0 12px}
.asesorias-content .muted{font-size:18px;margin:0 0 18px}
.asesorias-ctas{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}

/* Fuerza de layout para desktop/tablet */
@media (min-width: 901px) {
  .hero-grid{grid-template-columns:1.1fr .9fr !important}
}
.microproof{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.badge{padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:#0e0e13;color:var(--muted);font-size:13px}
.badge-gold{background:linear-gradient(135deg,#c89b1e,#f8e38a,#c89b1e);color:#1a1a1a;font-weight:600;box-shadow:0 0 0 1px rgba(255,255,255,.08),0 4px 14px rgba(200,155,30,.45);border-color:#c89b1e}
@media (prefers-reduced-motion: no-preference){
  .badge-gold{animation:badgePulse 4s ease-in-out infinite}
  @keyframes badgePulse{0%{box-shadow:0 0 0 1px rgba(255,255,255,.08),0 4px 14px rgba(200,155,30,.45)}50%{box-shadow:0 0 0 1px rgba(255,255,255,.12),0 6px 18px rgba(200,155,30,.55)}100%{box-shadow:0 0 0 1px rgba(255,255,255,.08),0 4px 14px rgba(200,155,30,.45)}}
}
.hero h1 .badge{font-size:22px;position:relative;top:-4px;margin-right:8px}
.testimonials{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
.testimonial-card{background:#0e0e13;border:1px solid var(--border);border-radius:16px;padding:16px}
.testimonial-card p{margin:0 0 8px}

@media (max-width:900px){
  .asesorias-grid{grid-template-columns:1fr}
  .asesorias-content h2{font-size:32px}
  .testimonials{grid-template-columns:1fr}
}
