:root{
  --primary:#f39c12;
  --primary-soft:#fef5e7;
  --secondary:#f1c40f;
  --bg:#fffbf0;
  --dark:#2c3e50;
  --text:#34495e;
  --accent:#e67e22;
  --accent-soft:#fdf2e9;
  --radius-lg:24px;
  --shadow-card:0 18px 45px rgba(243,156,18,.18);
  --transition:all .3s ease;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background-image: url('../assets/fondoIndex.png');
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  color:var(--text);
  line-height:1.6;
  position: relative;
  min-height: 100vh;
}
body::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-size: 400px 400px, 300px 300px, 500px 500px, 350px 350px;
  background-position: 0% 0%, 100% 100%, 50% 50%, 0% 100%;
  animation: cloudsFloat 20s ease-in-out infinite alternate;
  pointer-events: none;
  z-index: -1;
}
@keyframes cloudsFloat {
  0% { transform: translateX(0) translateY(0); }
  25% { transform: translateX(10px) translateY(-5px); }
  50% { transform: translateX(-5px) translateY(10px); }
  75% { transform: translateX(15px) translateY(5px); }
  100% { transform: translateX(0) translateY(0); }
}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}

/* Video de Bienvenida en Pantalla Completa */
.welcome-video-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: url('../assets/fondoIndex.png') center/cover no-repeat, rgba(0, 0, 0, 0.7);
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.8s ease, visibility 0.8s ease;
}

/* Mejoras responsive para video de bienvenida */
@media (max-width: 768px) {
  .welcome-video-overlay {
    background-size: cover;
    background-position: center;
  }
  #welcome-video-player {
    width: 100vw;
    height: 60vh;
    max-width: 100%;
    max-height: 60vh;
  }
  .audio-enable-button {
    top: 10px;
    right: 10px;
    padding: 8px 12px;
    font-size: 0.8rem;
  }
}

@media (max-width: 480px) {
  #welcome-video-player {
    height: 50vh;
    max-height: 50vh;
  }
  .audio-enable-button {
    top: 8px;
    right: 8px;
    padding: 6px 10px;
    font-size: 0.7rem;
  }
}

@media (max-width: 360px) {
  #welcome-video-player {
    height: 45vh;
    max-height: 45vh;
  }
  .audio-enable-button {
    top: 5px;
    right: 5px;
    padding: 4px 8px;
    font-size: 0.6rem;
  }
}

/* Mejoras responsive generales */
@media (max-width: 900px) {
  .container {
    width: calc(100% - 40px);
  }
  .section-title {
    font-size: 2rem;
  }
  .section-subtitle {
    font-size: 1rem;
  }
}

@media (max-width: 768px) {
  .container {
    width: calc(100% - 32px);
  }
  .section-title {
    font-size: 1.8rem;
  }
  .section-subtitle {
    font-size: 0.9rem;
  }
}

@media (max-width: 480px) {
  .container {
    width: calc(100% - 24px);
  }
  .section-title {
    font-size: 1.5rem;
  }
  .section-subtitle {
    font-size: 0.85rem;
  }
}

@media (max-width: 360px) {
  .container {
    width: calc(100% - 16px);
  }
  .section-title {
    font-size: 1.3rem;
  }
  .section-subtitle {
    font-size: 0.8rem;
  }
}

/* Optimización de imágenes responsive */
@media (max-width: 768px) {
  .hero-media img {
    border-radius: 12px;
  }
  .hero-floating-card {
    border-radius: 12px;
  }
}

/* Mejoras para botones responsive */
@media (max-width: 768px) {
  .btn-ghost, .btn-plans {
    padding: 12px 20px;
    font-size: 0.9rem;
  }
}

@media (max-width: 480px) {
  .btn-ghost, .btn-plans {
    padding: 10px 16px;
    font-size: 0.85rem;
  }
}

@media (max-width: 360px) {
  .btn-ghost, .btn-plans {
    padding: 8px 12px;
    font-size: 0.8rem;
  }
}

.welcome-video-overlay::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  z-index: 1;
}

.welcome-video-overlay.hidden {
  opacity: 0;
  visibility: hidden;
}

#welcome-video-player {
  width: 100vw;
  height: 100vh;
  max-width: 1920px;
  max-height: 1080px;
  object-fit: contain;
  object-position: center;
  background: transparent;
  z-index: 2;
  position: relative;
  border-radius: 0;
  box-shadow: none;
}

.audio-enable-button {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 10000;
  background: linear-gradient(135deg, #ff9800, #f57c00);
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: 25px;
  cursor: pointer;
  font-weight: bold;
  font-size: 14px;
  box-shadow: 0 4px 15px rgba(255, 152, 0, 0.3);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 8px;
}

.audio-enable-button:hover {
  background: linear-gradient(135deg, #f57c00, #e65100);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255, 152, 0, 0.4);
}

.audio-enable-button:active {
  transform: translateY(0);
  box-shadow: 0 2px 10px rgba(255, 152, 0, 0.3);
}

.audio-enable-button::before {
  content: '🔊';
  font-size: 16px;
}

/* Ocultar el contenido principal mientras el video se reproduce */
body.welcome-active {
  overflow: hidden;
}

body.welcome-active > *:not(.welcome-video-overlay) {
  opacity: 0;
  visibility: hidden;
}

body:not(.welcome-active) > *:not(.welcome-video-overlay) {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.8s ease-in, visibility 0.8s ease-in;
}

/* Layout base */
.container{width: 90%;margin:0 auto;}
header{
  position:relative; top: 24px;
  background: white;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
  z-index: 100;
  width: 90%;
  margin: 0 auto;
  backdrop-filter: blur(18px);
  border-bottom:1px solid rgba(243,156,18,.1);
  border-radius: 50px;
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 40px;
  gap: 0;
  width: 100%;
}

/* Mejoras responsive para Header y Navegación */
@media (max-width: 1200px) {
  .nav {
    padding: 12px 32px;
  }
  nav ul {
    gap: 20px;
    font-size: 0.9rem;
  }
  .btn-nav {
    padding: 8px 16px;
    font-size: 0.85rem;
  }
}

@media (max-width: 1024px) {
  .nav {
    padding: 10px 24px;
  }
  nav ul {
    gap: 16px;
    font-size: 0.85rem;
  }
  .btn-nav {
    padding: 7px 14px;
    font-size: 0.8rem;
  }
  header {
    width: 95%;
  }
}

@media (max-width: 900px) {
  header {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: none;
    border: none;
  }
  .nav {
    padding: 8px 20px;
  }
  nav ul {
    display: none;
  }
  .menu-toggle {
    display: block;
  }
  .mobile-nav {
    display: block;
  }
  .mobile-nav-overlay {
    display: block;
  }
  .logo-mark {
    width: 60px;
    height: 60px;
  }
}

@media (max-width: 768px) {
  header {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: none;
    border: none;
  }
  .nav {
    padding: 6px 16px;
  }
  .logo-mark {
    width: 55px;
    height: 55px;
  }
  .menu-toggle {
    width: 30px;
    height: 24px;
  }
  .menu-toggle span {
    height: 2px;
  }
}

@media (max-width: 640px) {
  header {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: none;
    border: none;
  }
  .nav {
    padding: 4px 12px;
  }
  .logo-mark {
    width: 50px;
    height: 50px;
  }
}

@media (max-width: 480px) {
  header {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: none;
    border: none;
  }
  .nav {
    padding: 2px 8px;
  }
  .logo-mark {
    width: 45px;
    height: 45px;
  }
}

@media (max-width: 360px) {
  header {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: none;
    border: none;
  }
  .nav {
    padding: 2px 6px;
  }
  .logo-mark {
    width: 40px;
    height: 40px;
  }
}

/* Mejoras para navegación móvil */
@media (max-width: 768px) {
  .mobile-nav {
    width: 85%;
    max-width: 320px;
  }
  .mobile-nav-header {
    padding: 16px 20px;
  }
  .mobile-nav ul {
    padding: 0 20px 20px;
  }
  .mobile-nav li {
    margin-bottom: 8px;
  }
  .mobile-nav a {
    font-size: 16px;
    padding: 12px 16px;
  }
  .mobile-nav .btn-nav {
    font-size: 14px;
    padding: 10px 16px;
    margin-top: 12px;
  }
}

@media (max-width: 480px) {
  .mobile-nav {
    width: 90%;
    max-width: 280px;
  }
  .mobile-nav-header {
    padding: 12px 16px;
  }
  .mobile-nav ul {
    padding: 0 16px 16px;
  }
  .mobile-nav a {
    font-size: 14px;
    padding: 10px 12px;
  }
  .mobile-nav .btn-nav {
    font-size: 13px;
    padding: 8px 12px;
    margin-top: 8px;
  }
}

@media (max-width: 360px) {
  .mobile-nav {
    width: 95%;
    max-width: 250px;
  }
  .mobile-nav-header {
    padding: 10px 12px;
  }
  .mobile-nav ul {
    padding: 0 12px 12px;
  }
  .mobile-nav a {
    font-size: 13px;
    padding: 8px 10px;
  }
  .mobile-nav .btn-nav {
    font-size: 12px;
    padding: 6px 10px;
    margin-top: 6px;
  }
}
.logo{
  display:flex;align-items:center;gap:8px;font-weight:700;
  color:var(--dark);letter-spacing:.03em;
}
.logo-mark{
  width:156px;height:156px;border-radius:50px;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;font-weight:700;color:white;
  flex-shrink:0;
  background: transparent;
  position: relative;
}
nav{
  padding: 12px 24px;
  border-radius: 50px;
  height: 148px;
  display: flex;
  align-items: center;
}
nav ul{
  display:flex;gap:30px;list-style:none;font-size:21px;
  align-items: center;
  height: 100%;
}
.logo-mark video{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:18px;
  background-color: transparent !important;
  background: transparent !important;
  -webkit-background-color: transparent !important;
  -moz-background-color: transparent !important;
  opacity: 1;
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
nav ul{display:flex;gap:30px;list-style:none;font-size:21px;}
nav a{
  padding:8px 10px;border-radius:999px;transition:var(--transition);
  color: #ffc612;
  text-decoration: none;
  font-weight: 900;
  position: relative;
}
nav a:hover{
  background:var(--primary-soft);
  color: #ffc612;
  transform: translateY(-2px);
}
.btn-nav{
  padding:10px 22px;border-radius:999px;
  background:var(--primary);color:white;font-weight:900;
  box-shadow:0 15px 35px rgba(243,156,18,.45);
  font-size: 21px;
  text-shadow: 0 0 15px rgba(255,255,255,0.8), 0 0 25px rgba(255,255,255,0.6);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  display: inline-block;
}

.btn-nav:hover{
  background:var(--accent);
  color: white;
  text-shadow: 0 0 20px rgba(255,255,255,1), 0 0 35px rgba(255,255,255,0.8);
  transform: translateY(-2px);
  box-shadow:0 20px 45px rgba(243,156,18,.55);
}

.btn-nav::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition: left 0.5s ease;
}

.btn-nav:hover::before {
  left: 100%;
}

/* Ajuste específico para móvil */
.mobile-nav .btn-nav {
  display: block;
  width: 100%;
  text-align: center;
  margin: 10px 0;
  padding: 12px 20px;
}

/* Hero principal (solo index) */
.hero{
  position:relative;
  width:100%;
  height: calc(100vh - 100px); /* Ajustado para responsive */
  min-height: 500px; /* Altura mínima para móvil */
  padding:60px 0 32px; /* Padding reducido */
  overflow:hidden;
  display: flex;
  align-items: center;
}
.hero-inner{
  width: 80%;
  display:grid;
  grid-template-columns: minmax(0,1.15fr) minmax(0,1fr);
  gap:96px;align-items:center;
}
.hero::before,
.hero::after{
  display:none;
}

/* Mejoras responsive para Hero */
@media (max-width: 1200px) {
  .hero-inner {
    width: 90%;
    gap: 60px;
  }
  .hero-title span {
    font-size: 2.8rem !important;
  }
}

@media (max-width: 900px) {
  .hero {
    padding: 40px 0 24px;
    height: auto;
    min-height: 400px; /* Altura mínima reducida */
  }
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 40px;
    width: 90%;
  }
  .hero-media {
    order: -1;
    margin-top: 20px;
  }
  .hero-title span {
    font-size: 2.2rem !important;
    line-height: 1.1 !important;
  }
  .hero-text {
    font-size: 0.95rem;
    margin-bottom: 20px;
  }
  .hero-features {
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 24px;
  }
  .hero-feature {
    flex: 1 1 calc(50% - 6px);
    min-width: 0;
    font-size: 0.85rem;
  }
  .hero-cta {
    flex-direction: column;
    gap: 12px;
    align-items: flex-start;
  }
  .btn-ghost, .btn-plans {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
  .hero-media-side {
    display: none;
  }
  .hero-floating-card {
    width: 90%;
    padding: 12px;
    font-size: 0.85rem;
  }
}

@media (max-width: 768px) {
  .hero {
    padding: 30px 0 20px;
    min-height: 350px; /* Altura mínima para tablets */
  }
  .hero-title span {
    font-size: 1.8rem !important;
  }
  .hero-text {
    font-size: 0.9rem;
  }
  .hero-features {
    gap: 8px;
    margin-bottom: 20px;
  }
  .hero-feature {
    flex: 1 1 100%;
    font-size: 0.8rem;
    padding: 8px;
  }
  .feature-icon {
    font-size: 1.2rem;
  }
  .hero-cta {
    margin-bottom: 20px;
  }
  .hero-floating-card {
    width: 95%;
    padding: 10px;
    font-size: 0.8rem;
  }
}

@media (max-width: 480px) {
  .hero {
    padding: 20px 0 16px;
    min-height: 300px; /* Altura mínima para móviles */
  }
  .hero-title span {
    font-size: 1.5rem !important;
  }
  .hero-text {
    font-size: 0.85rem;
  }
  .hero-feature {
    font-size: 0.75rem;
    padding: 6px;
  }
  .feature-icon {
    font-size: 1rem;
  }
  .hero-floating-card {
    width: 98%;
    padding: 8px;
    font-size: 0.75rem;
  }
}

@media (max-width: 360px) {
  .hero {
    padding: 16px 0 12px;
    min-height: 250px; /* Altura mínima para móviles pequeños */
  }
  .hero-title span {
    font-size: 1.3rem !important;
  }
  .hero-text {
    font-size: 0.8rem;
  }
  .hero-feature {
    font-size: 0.7rem;
  }
}
@keyframes floatCircle{
  0%{transform:translate3d(0,2px,0) rotate(-0.3deg);} 
  50%{transform:translate3d(0,-18px,0) rotate(0.6deg);} 
  100%{transform:translate3d(0,2px,0) rotate(-0.3deg);} 
}
@keyframes heroFloat{
  0%{transform:translate3d(0,2px,0) rotate(-0.6deg);} 
  50%{transform:translate3d(0,-18px,0) rotate(0.6deg);} 
  100%{transform:translate3d(0,2px,0) rotate(-0.3deg);} 
}
.hero-kicker{
  font-size:.8rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.14em;color:var(--primary);
}
.hero-title{
  font-size:2.7rem;font-weight:800;color:var(--dark);
  margin:22px 0 12px;
}
.hero-title span{
  text-align: left !important;
  font-size: 3.5rem !important;
}
.hero-highlight{color:var(--primary);}
.hero-text{max-width:80%;font-size:.98rem;margin-bottom:18px;font-weight: 500;margin-top:18px;}
.hero-badges{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;
}
.badge{
  background:rgba(255,255,255,0.9);color:var(--primary);
  padding:6px 12px;border-radius:999px;font-size:.75rem;
  font-weight:600;display:flex;align-items:center;gap:6px;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  border:1px solid rgba(243,156,18,0.2);
}
.hero-cta{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:18px;
}
.btn-primary{
  padding:12px 26px;border-radius:999px;
  border:none;cursor:pointer;font-weight:600;
  background:var(--primary);
  color:white;box-shadow:0 18px 45px rgba(243,156,18,.45);
  transition:var(--transition);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 22px 55px rgba(243,156,18,.55);}
.btn-ghost{
  padding:11px 20px;border-radius:999px;border:1px solid rgba(243,156,18,.3);
  background:rgba(255,255,255,.7);
  display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight: 800;
}
.hero-note{font-size:.78rem;color:#6a7a98;}
.hero-features{
  width: 76%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 24px 0;
  padding: 20px;
  background: rgba(255,255,255,0.8);
  border-radius: 16px;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  border: 1px solid rgba(243,156,18,0.1);
}
.hero-feature{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.04);
  transition: all 0.3s ease;
}
.hero-feature:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}
.feature-icon{
  font-size: 1.4rem;
  flex-shrink: 0;
}
.hero-feature span{
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--dark);
  line-height: 1.3;
}
.btn-plans{
  padding:12px 26px;border-radius:999px;
  border:none;cursor:pointer;font-weight:600;
  background: linear-gradient(135deg, #ff9800 0%, #ffc107 50%, #ff9800 100%);
  color:white;
  box-shadow:0 18px 45px rgba(255,152,0,.45);
  transition:var(--transition);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn-plans:hover{
  transform:translateY(-1px);
  box-shadow:0 22px 55px rgba(255,152,0,.55);
  background: linear-gradient(135deg, #ff9800 0%, #ffc107 50%, #ff9800 100%);
}
.hero-media{
  width:632px;position:relative;
  background:white;
  border-radius:var(--radius-lg);
  padding:18px;box-shadow:var(--shadow-card);
  overflow:hidden;animation: heroFloat 9s ease-in-out infinite alternate;
  transform-origin:center bottom;
}
.hero-media-group{
  position:relative;display:flex;justify-content:flex-end;align-items:flex-end;gap:16px;
}
.hero-media-side{
  position:absolute;width:220px;border-radius:18px;overflow:hidden;
  box-shadow:0 14px 35px rgba(243,156,18,.12);opacity:.55;background:#fef9e7;
}
.hero-media-side img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-media-side.left{left:-160px;bottom:0;transform:scale(.9);}
.hero-media-side.right{right:-143px;top:-48px;transform:scale(.85);}
.hero-video{
  position:relative;border-radius:20px;overflow:hidden;
  aspect-ratio:16/10;background:#020b1b;
}
.hero-video::after{
  display:none;
}
.hero-floating-card{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  width:82%;background:rgba(44,62,80,.93);color:white;
  border-radius:18px;padding:12px 14px;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  font-size:.78rem;backdrop-filter:blur(12px);
}
.pill{
  padding:4px 9px;border-radius:999px;
  background:rgba(243,156,18,.12);color:#f39c12;font-size:.7rem;
}

/* Sección de Beneficios con diseño de dos columnas */
.benefits-section {
  padding: 100px 0;
  background: url(../assets/fondo_seccion.png) center/cover !important;
  position: relative;
  overflow: hidden;
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.8s ease-out;
}

.benefits-section.visible {
  opacity: 1;
  transform: translateY(0);
}

.benefits-container {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 180px;
  align-items: center;
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Mejoras responsive para Benefits */
@media (max-width: 1200px) {
  .benefits-container {
    gap: 120px;
  }
}

@media (max-width: 900px) {
  .benefits-container {
    grid-template-columns: 1fr;
    gap: 60px;
    padding: 0 24px;
  }
  .benefits-content {
    width: 100%;
    margin: 0;
  }
  .benefits-image {
    order: -1;
    margin-bottom: 40px;
  }
  .benefit-card {
    min-width: 180px;
  }
}

@media (max-width: 768px) {
  .benefits-container {
    gap: 40px;
    padding: 0 20px;
  }
  .benefits-content {
    gap: 16px;
  }
  .benefit-card {
    min-width: 160px;
    padding: 16px;
  }
  .benefit-icon {
    font-size: 1rem;
  }
  .benefit-card h3 {
    font-size: 0.75rem;
  }
  .benefit-card p {
    font-size: 0.65rem;
  }
}

@media (max-width: 480px) {
  .benefits-container {
    gap: 30px;
    padding: 0 16px;
  }
  .benefits-content {
    gap: 12px;
  }
  .benefit-card {
    min-width: 140px;
    padding: 12px;
  }
  .benefit-icon {
    font-size: 0.9rem;
    margin-bottom: 4px;
  }
  .benefit-card h3 {
    font-size: 0.7rem;
    margin: 4px 0 2px;
  }
  .benefit-card p {
    font-size: 0.6rem;
  }
}

@media (max-width: 360px) {
  .benefits-container {
    gap: 20px;
    padding: 0 12px;
  }
  .benefits-content {
    gap: 10px;
  }
  .benefit-card {
    min-width: 120px;
    padding: 10px;
  }
  .benefit-icon {
    font-size: 0.8rem;
  }
  .benefit-card h3 {
    font-size: 0.65rem;
  }
  .benefit-card p {
    font-size: 0.55rem;
  }
}

.benefits-content {
  margin: 20px 0 20px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: stretch;
  width: 124%;
}

.benefits-content .section-title {
  width: 100%;
  margin-bottom: 30px;
}

.benefit-card {
  flex: 1;
  min-width: 200px;
  background: white;
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.06);
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.benefit-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 36px rgba(0,0,0,0.12);
}

.benefit-card h3 {
  font-size: 0.8rem;
  margin: 6px 0 4px;
  color: var(--dark);
}

.benefit-card p {
  font-size: 0.7rem;
  line-height: 1.3;
  color: #666;
  margin: 0;
}

.benefit-icon {
  font-size: 1.2rem;
  margin-bottom: 6px;
}

.benefits-image {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.benefits-image::before {
  content: '';
  position: absolute;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: url(../assets/beneficios.png) center/cover;
  box-shadow: 0 20px 60px rgba(243,156,18,0.3);
  animation: floatImage 6s ease-in-out infinite;
}

.benefits-image::after {
  content: '';
  position: absolute;
  width: 350px;
  height: 350px;
  border-radius: 50%;
  background: linear-gradient(45deg, rgba(255,255,255,0.9) 0%, rgba(243,156,18,0.1) 50%, rgba(255,255,255,0.9) 100%);
  top: 25px;
  left: 25px;
}

/* Círculos decorativos adicionales */
.benefits-image .circle-1 {
  position: absolute;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(243,156,18,0.3) 0%, rgba(241,196,15,0.2) 100%);
  top: -30px;
  right: 50px;
  animation: floatCircle 4s ease-in-out infinite;
}

.benefits-image .circle-2 {
  position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(231,76,60,0.2) 0%, rgba(192,57,43,0.1) 100%);
  bottom: 20px;
  left: -20px;
  animation: floatCircle 5s ease-in-out infinite reverse;
}

.benefits-image .circle-3 {
  position: absolute;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(241,196,15,0.3) 0%, rgba(243,156,18,0.2) 100%);
  top: 50px;
  left: -10px;
  animation: floatCircle 3.5s ease-in-out infinite;
}

.benefits-image .circle-4 {
  position: absolute;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(230,126,34,0.2) 0%, rgba(211,84,0,0.1) 100%);
  bottom: -20px;
  right: 30px;
  animation: floatCircle 4.5s ease-in-out infinite;
}

@keyframes floatImage {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  25% { transform: translateY(-20px) rotate(5deg); }
  50% { transform: translateY(-10px) rotate(-3deg); }
  75% { transform: translateY(-15px) rotate(2deg); }
}

@keyframes floatCircle {
  0%, 100% { transform: translateY(0) scale(1); }
  25% { transform: translateY(-10px) scale(1.05); }
  50% { transform: translateY(-5px) scale(0.95); }
  75% { transform: translateY(-8px) scale(1.02); }
}

.carousel-container {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Fondo animado de red neuronal para el container */
.carousel-container::before {
  content: '';
  position: absolute;
  top: -20px;
  left: -20px;
  right: -20px;
  bottom: -20px;
  background-image: 
    radial-gradient(circle at 20% 30%, rgba(100,100,100,0.1) 1px, transparent 1px),
    radial-gradient(circle at 40% 70%, rgba(100,100,100,0.1) 1px, transparent 1px),
    radial-gradient(circle at 60% 20%, rgba(100,100,100,0.1) 1px, transparent 1px),
    radial-gradient(circle at 80% 50%, rgba(100,100,100,0.1) 1px, transparent 1px),
    radial-gradient(circle at 30% 80%, rgba(100,100,100,0.1) 1px, transparent 1px),
    radial-gradient(circle at 70% 40%, rgba(100,100,100,0.1) 1px, transparent 1px),
    linear-gradient(45deg, transparent 48%, rgba(100,100,100,0.05) 49%, rgba(100,100,100,0.05) 51%, transparent 52%),
    linear-gradient(-45deg, transparent 48%, rgba(100,100,100,0.05) 49%, rgba(100,100,100,0.05) 51%, transparent 52%),
    linear-gradient(90deg, transparent 48%, rgba(100,100,100,0.05) 49%, rgba(100,100,100,0.05) 51%, transparent 52%),
    linear-gradient(0deg, transparent 48%, rgba(100,100,100,0.05) 49%, rgba(100,100,100,0.05) 51%, transparent 52%);
  background-size: 200px 200px, 150px 150px, 180px 180px, 220px 220px, 160px 160px, 190px 190px, 100px 100px, 100px 100px, 100px 100px, 100px 100px;
  background-position: 0% 0%, 20% 30%, 40% 60%, 60% 20%, 80% 70%, 30% 40%, 10% 10%, 90% 90%, 50% 50%, 70% 30%;
  animation: neuralNetworkPulse 8s ease-in-out infinite alternate;
  opacity: 0.3;
  z-index: 0;
  border-radius: 20px;
}

/* Efectos de conexión animados para el container */
.carousel-container::after {
  content: '';
  position: absolute;
  top: -20px;
  left: -20px;
  right: -20px;
  bottom: -20px;
  background: 
    linear-gradient(90deg, transparent 0%, rgba(150,150,150,0.1) 50%, transparent 100%),
    linear-gradient(0deg, transparent 0%, rgba(150,150,150,0.1) 50%, transparent 100%),
    linear-gradient(45deg, transparent 0%, rgba(150,150,150,0.08) 50%, transparent 100%),
    linear-gradient(-45deg, transparent 0%, rgba(150,150,150,0.08) 50%, transparent 100%);
  background-size: 300px 2px, 2px 300px, 200px 2px, 200px 2px;
  background-position: 0 50%, 50% 0, 0 0, 100% 100%;
  animation: electricFlow 4s linear infinite;
  opacity: 0.2;
  z-index: 0;
  border-radius: 20px;
}

.carousel-slides {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
}

.carousel-slide {
  display: none;
  opacity: 0;
  transform: translateX(100%);
  transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  background: white;
  border-radius: 20px;
  box-shadow: 0 20px 60px rgba(243,156,18,0.15);
  padding: 40px 0;
}

.carousel-slide.active {
  display: block;
  opacity: 1;
  transform: translateX(0);
}

.carousel-slide.prev {
  transform: translateX(-100%);
}

.section-title {
  padding-bottom: 12px; 
  text-align: center;
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--dark);
  margin-bottom: 60px;
  position: relative;
}

.section-title::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 3px;
  background: #000000;
  border-radius: 2px;
}

/* Indicadores del carrusel */
.carousel-indicators {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 30px;
}

.carousel-indicator {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid var(--primary);
  background: transparent;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
}

.carousel-indicator:hover {
  transform: scale(1.1);
}

.carousel-indicator.active {
  background: var(--primary);
  transform: scale(1.2);
}

.carousel-indicator.active::after {
  content: '';
  position: absolute;
  top: -4px;
  left: -4px;
  right: -4px;
  bottom: -4px;
  border: 2px solid var(--primary);
  border-radius: 50%;
  opacity: 0.3;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0% { transform: scale(1); opacity: 0.3; }
  50% { transform: scale(1.1); opacity: 0.1; }
  100% { transform: scale(1); opacity: 0.3; }
}

@keyframes neuralNetworkPulse {
  0% {
    background-position: 0% 0%, 20% 30%, 40% 60%, 60% 20%, 80% 70%, 30% 40%, 10% 10%, 90% 90%, 50% 50%, 70% 30%;
    opacity: 0.3;
  }
  50% {
    background-position: 10% 10%, 30% 40%, 50% 70%, 70% 30%, 90% 80%, 40% 50%, 20% 20%, 80% 80%, 60% 60%, 80% 40%;
    opacity: 0.5;
  }
  100% {
    background-position: 20% 20%, 40% 50%, 60% 80%, 80% 40%, 100% 90%, 50% 60%, 30% 30%, 70% 70%, 70% 70%, 90% 50%;
    opacity: 0.3;
  }
}

@keyframes electricFlow {
  0% {
    background-position: -300px 50%, 50% -300px, -200px 0, 300px 300px;
    opacity: 0.1;
  }
  50% {
    background-position: 300px 50%, 50% 300px, 200px 0, -300px -300px;
    opacity: 0.3;
  }
  100% {
    background-position: 600px 50%, 50% 600px, 600px 0, -600px -600px;
    opacity: 0.1;
  }
}

/* Controles del carrusel */
.carousel-control {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--primary);
  color: white;
  border: none;
  font-size: 24px;
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 25px rgba(243,156,18,0.3);
}

.carousel-control:hover {
  background: var(--accent);
  transform: translateY(-50%) scale(1.1);
  box-shadow: 0 12px 35px rgba(243,156,18,0.4);
}

.carousel-control.prev {
  left: -25px;
}

.carousel-control.next {
  right: -25px;
}

/* Sección Misión y Principios */
.mission-principles-section {
  padding: 80px 0;
  text-align: center;
}

.mission-principles-grid {
  display: flex;
  gap: 148px;
  align-items: center;
  justify-content: center;
}

.collage-section-left {
  display: flex;
  justify-content: center;
  align-items: center;
}

.mission-principles-content {
  width: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Estilos para el diseño de dos columnas */
.two-columns-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 102px;
  align-items: start;
}

.column-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.column-section .section-header {
  text-align: center;
  margin-bottom: 20px;
}

.column-section .section-header h2 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 8px;
}

.column-section .section-header p {
  color: #6a7a98;
  font-size: 0.9rem;
}

/* Estilos base para TV Cards */
.tv-card {
  background: linear-gradient(135deg, #ffffff 0%, #fef9f0 100%);
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 8px 20px rgba(243,156,18,0.12);
  transition: all 0.3s ease;
  position: relative;
  border: 2px solid transparent;
  overflow: hidden;
  text-align: center;
  aspect-ratio: 1/1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 200px;
  max-width: 200px;
}

.tv-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
  transform: scaleX(0);
  transition: transform 0.3s ease;
}

.tv-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 35px rgba(243,156,18,0.25);
  border-color: var(--primary);
}

.tv-card:hover::before {
  transform: scaleX(1);
}

.tv-card.popular-tv {
  background: linear-gradient(135deg, #fff8e1 0%, #fff3c4 100%);
  border-color: var(--primary);
  transform: scale(1.05);
  box-shadow: 0 12px 30px rgba(243,156,18,0.2);
}

.tv-card.popular-tv:hover {
  transform: scale(1.05) translateY(-5px);
  box-shadow: 0 20px 45px rgba(243,156,18,0.3);
}

.popular-badge {
  position: absolute;
  top: -8px;
  right: 12px;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: white;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 0.65rem;
  font-weight: 600;
  box-shadow: 0 3px 10px rgba(243,156,18,0.3);
  transform: rotate(3deg);
  animation: float 3s ease-in-out infinite;
  z-index: 10;
}

.tv-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(243,156,18,0.1);
}

.tv-icon {
  font-size: 1.8rem;
  margin-bottom: 4px;
  display: block;
  animation: bounce 2s infinite;
}

.channels-count {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 2px;
}

.tv-quality {
  display: inline-block;
  background: linear-gradient(135deg, var(--primary-soft), #e8f4ff);
  color: var(--primary);
  font-size: 0.7rem;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 8px;
  margin-bottom: 8px;
  border: 1px solid rgba(243,156,18,0.2);
}

.tv-price {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--primary);
  line-height: 1;
  margin-bottom: 8px;
  position: relative;
}

.tv-price span {
  font-size: 0.7rem;
  font-weight: 400;
  color: var(--text);
  opacity: 0.8;
}

.tv-features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px;
  justify-content: center;
  margin-top: 8px;
}

.tv-features span {
  display: inline-block;
  background: rgba(243,156,18,0.1);
  color: var(--primary);
  font-size: 0.6rem;
  font-weight: 600;
  padding: 2px 4px;
  border-radius: 4px;
  border: 1px solid rgba(243,156,18,0.2);
  transition: all 0.3s ease;
  text-align: center;
}

.tv-features span:hover {
  background: var(--primary);
  color: white;
  transform: translateY(-1px);
}

@keyframes bounce {
  0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
  40% { transform: translateY(-5px); }
  60% { transform: translateY(-2px); }
}

/* Centrar sección Internet + TV */
.plans-section.animate-fadeInUp.delay-2 {
  width: 90%;
  max-width: 1200px;
  margin: 18px auto;
  text-align: center;
}

.plans-section.animate-fadeInUp.delay-2 .section-header {
  text-align: center;
  margin-bottom: 30px;
}

.plans-section.animate-fadeInUp.delay-2 .plans-carousel {
  display: flex;
  justify-content: center;
  gap: 16px;
  overflow-x: auto;
  padding: 20px 10px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
}

.plans-section.animate-fadeInUp.delay-2 .plan-card {
  flex: 0 0 auto;
  scroll-snap-align: center;
}

/* Grid para TV Cards - Fila horizontal hasta límite de width */
.plans-grid-tv {
  display: grid;
  grid-template-columns: repeat(auto-fit, 200px);
  gap: 16px;
  justify-content: center;
  justify-items: center;
}
.vision-section{
  text-align: center;
}
/* Responsive para centrado */
@media (max-width: 768px) {
  .plans-section.animate-fadeInUp.delay-2 {
    width: 95%;
  }
  
  .plans-section.animate-fadeInUp.delay-2 .plans-carousel {
    gap: 12px;
    padding: 15px 5px;
  }
}

@media (max-width: 480px) {
  .plans-section.animate-fadeInUp.delay-2 {
    width: 98%;
  }
  
  .plans-section.animate-fadeInUp.delay-2 .plans-carousel {
    gap: 10px;
    padding: 10px 5px;
  }
}

/* Sección Mapa de Ubicaciones - Sin background */
.map-section {
  padding: 60px 0;
  background: none; /* Sin background */
}

.map-container {
  max-width: 1200px;
  margin: 0 auto;
}

.map-header {
  text-align: center;
  margin-bottom: 40px;
}

.map-header .section-title {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--dark);
  margin-bottom: 12px;
}

.map-header .section-subtitle {
  font-size: 1.1rem;
  color: #6a7a98;
  max-width: 600px;
  margin: 0 auto;
}

.map-wrapper {
  display: flex;
  justify-content: center;
}

.map-card {
  background: white; /* Contenedor blanco */
  border-radius: 20px;
  padding: 30px;
  box-shadow: 0 15px 50px rgba(0,0,0,0.1);
  border: 1px solid rgba(0,0,0,0.05);
  max-width: 1000px;
  width: 100%;
}

.map-placeholder {
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 30px;
  position: relative;
}

.map-placeholder iframe {
  width: 100%;
  height: 450px;
  border: none;
}

.map-legend {
  background: var(--primary-soft);
  border-radius: 12px;
  padding: 20px;
}

.map-legend h4 {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.legend-items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 12px;
}

.legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  color: var(--dark);
}

.legend-marker {
  font-size: 1.2rem;
  min-width: 20px;
}

/* Responsive para mapa */
@media (max-width: 900px) {
  .map-section {
    padding: 50px 0;
  }
  
  .map-header .section-title {
    font-size: 2.2rem;
  }
  
  .map-header .section-subtitle {
    font-size: 1rem;
  }
  
  .map-card {
    padding: 24px;
    margin: 0 20px;
  }
  
  .map-placeholder iframe {
    height: 400px;
  }
  
  .legend-items {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .map-section {
    padding: 40px 0;
  }
  
  .map-header .section-title {
    font-size: 2rem;
  }
  
  .map-header .section-subtitle {
    font-size: 0.95rem;
  }
  
  .map-card {
    padding: 20px;
    margin: 0 16px;
  }
  
  .map-placeholder iframe {
    height: 350px;
  }
  
  .map-legend {
    padding: 16px;
  }
  
  .map-legend h4 {
    font-size: 1.1rem;
  }
  
  .legend-item {
    font-size: 0.85rem;
  }
}

@media (max-width: 480px) {
  .map-section {
    padding: 30px 0;
  }
  
  .map-header .section-title {
    font-size: 1.8rem;
  }
  
  .map-header .section-subtitle {
    font-size: 0.9rem;
  }
  
  .map-card {
    padding: 16px;
    margin: 0 12px;
  }
  
  .map-placeholder iframe {
    height: 300px;
  }
  
  .map-legend {
    padding: 12px;
  }
  
  .map-legend h4 {
    font-size: 1rem;
  }
  
  .legend-item {
    font-size: 0.8rem;
    gap: 6px;
  }
  
  .legend-marker {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .plans-section.animate-fadeInUp.delay-2 {
    width: 95%;
  }
  
  .plans-section.animate-fadeInUp.delay-2 .plans-carousel {
    gap: 12px;
    padding: 15px 5px;
  }
}

@media (max-width: 480px) {
  .plans-section.animate-fadeInUp.delay-2 {
    width: 98%;
  }
  
  .plans-section.animate-fadeInUp.delay-2 .plans-carousel {
    gap: 10px;
    padding: 10px 5px;
  }
}

.collage-section {
  display: flex;
  justify-content: center;
  align-items: center;
}

.collage-container {
  max-width: 600px;
  width: 100%;
  position: relative;
}

.collage-grid-horizontal {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  position: relative;
  height: 200px;
}

.collage-item-horizontal {
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 8px 25px rgba(0,0,0,0.15);
  transition: transform 0.3s ease, box-shadow 0.3s ease, z-index 0.3s ease;
  position: relative;
  background: white;
  padding: 3px;
}

.collage-item-horizontal:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(0,0,0,0.25);
  z-index: 10;
}

.collage-item-horizontal img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 8px;
}

/* Efecto sobre montado */
.collage-item-horizontal::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 50%, rgba(0,0,0,0.1) 100%);
  pointer-events: none;
  z-index: 1;
}

.collage-item-horizontal::after {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(45deg, transparent, rgba(243,156,18,0.3), transparent);
  border-radius: 12px;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: 2;
}

.collage-item-horizontal:hover::after {
  opacity: 1;
}

/* Posiciones específicas */
.collage-item-horizontal.left {
  width: 246px;
  height: 148px;
  transform: rotate(-3deg);
  z-index: 1;
  align-self: flex-end;
}

.collage-item-horizontal.center {
  width: 280px;
  height: 180px;
  transform: rotate(0deg);
  z-index: 3;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.collage-item-horizontal.right {
  width: 180px;
  height: 120px;
  transform: rotate(3deg);
  z-index: 1;
  align-self: flex-end;
}

/* Animaciones para imágenes de visión y misión */
.collage-item-horizontal img {
  transition: all 0.4s ease;
  animation: imageFloat 6s ease-in-out infinite;
}

.collage-item-horizontal.left img {
  animation-delay: 0s;
}

.collage-item-horizontal.center img {
  animation-delay: 2s;
}

.collage-item-horizontal.right img {
  animation-delay: 4s;
}

.collage-item-horizontal:hover img {
  transform: scale(1.1) rotate(2deg);
  box-shadow: 0 15px 40px rgba(243, 156, 18, 0.3);
  filter: brightness(1.1) saturate(1.2);
}

/* Animación flotante para imágenes */
@keyframes imageFloat {
  0%, 100% {
    transform: translateY(0px) rotate(0deg);
  }
  25% {
    transform: translateY(-8px) rotate(1deg);
  }
  50% {
    transform: translateY(-5px) rotate(-1deg);
  }
  75% {
    transform: translateY(-10px) rotate(0.5deg);
  }
}

/* Animación de entrada para collages */
.collage-container.animate-fadeInUp {
  animation: collageEntrance 1s ease-out;
}

@keyframes collageEntrance {
  0% {
    opacity: 0;
    transform: translateY(30px) scale(0.9);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Animación adicional para imágenes específicas */
.collage-item-horizontal.left img:hover {
  animation: bounceLeft 0.6s ease;
}

.collage-item-horizontal.center img:hover {
  animation: bounceCenter 0.6s ease;
}

.collage-item-horizontal.right img:hover {
  animation: bounceRight 0.6s ease;
}

@keyframes bounceLeft {
  0%, 100% { transform: scale(1.1) rotate(2deg); }
  50% { transform: scale(1.15) rotate(-2deg); }
}

@keyframes bounceCenter {
  0%, 100% { transform: scale(1.1) rotate(0deg); }
  50% { transform: scale(1.15) rotate(3deg); }
}

@keyframes bounceRight {
  0%, 100% { transform: scale(1.1) rotate(-2deg); }
  50% { transform: scale(1.15) rotate(2deg); }
}

/* Reset transform en hover */
.collage-item-horizontal.left:hover,
.collage-item-horizontal.right:hover {
  transform: rotate(0deg) translateY(-5px);
}

.collage-item-horizontal.center:hover {
  transform: translate(-50%, -55%) scale(1.05);
}

/* Animación de scroll para sección equipo */
.team-section {
  opacity: 0;
  transform: translateY(50px);
  transition: all 1s ease-out;
}

.team-section.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Animación escalonada para team cards en scroll */
.team-section .section-title {
  opacity: 0;
  transform: translateY(-30px) scale(0.9);
  transition: all 0.8s ease-out 0.2s;
}

.team-section.visible .section-title {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.team-section .section-subtitle {
  opacity: 0;
  transform: translateY(30px) scale(0.95);
  transition: all 0.8s ease-out 0.4s;
}

.team-section.visible .section-subtitle {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.team-card {
  opacity: 0;
  transform: translateY(50px) rotateX(15deg) scale(0.8);
  transition: all 0.8s ease-out;
  transform-style: preserve-3d;
  perspective: 1000px;
}

.team-section.visible .team-card:nth-child(1) {
  transition-delay: 0.6s;
  opacity: 1;
  transform: translateY(0) rotateX(0) scale(1);
}

.team-section.visible .team-card:nth-child(2) {
  transition-delay: 0.8s;
  opacity: 1;
  transform: translateY(0) rotateX(0) scale(1);
}

.team-section.visible .team-card:nth-child(3) {
  transition-delay: 1.0s;
  opacity: 1;
  transform: translateY(0) rotateX(0) scale(1);
}

.team-section.visible .team-card:nth-child(4) {
  transition-delay: 1.2s;
  opacity: 1;
  transform: translateY(0) rotateX(0) scale(1);
}

.team-section.visible .team-card:nth-child(5) {
  transition-delay: 1.4s;
  opacity: 1;
  transform: translateY(0) rotateX(0) scale(1);
}

.team-section.visible .team-card:nth-child(6) {
  transition-delay: 1.6s;
  opacity: 1;
  transform: translateY(0) rotateX(0) scale(1);
}

/* Animación adicional para imágenes del equipo */
.team-member-image {
  opacity: 0;
  transform: scale(0.5) rotate(180deg);
  transition: all 0.8s ease-out;
}

.team-section.visible .team-member-image {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.team-section.visible .team-card:nth-child(1) .team-member-image { transition-delay: 0.8s; }
.team-section.visible .team-card:nth-child(2) .team-member-image { transition-delay: 1.0s; }
.team-section.visible .team-card:nth-child(3) .team-member-image { transition-delay: 1.2s; }
.team-section.visible .team-card:nth-child(4) .team-member-image { transition-delay: 1.4s; }
.team-section.visible .team-card:nth-child(5) .team-member-image { transition-delay: 1.6s; }
.team-section.visible .team-card:nth-child(6) .team-member-image { transition-delay: 1.8s; }

/* Animación para texto de team cards */
.team-member-name,
.team-member-role {
  opacity: 0;
  transform: translateX(-20px);
  transition: all 0.6s ease-out;
}

.team-section.visible .team-member-name,
.team-section.visible .team-member-role {
  opacity: 1;
  transform: translateX(0);
}

.team-section.visible .team-card:nth-child(1) .team-member-name { transition-delay: 1.0s; }
.team-section.visible .team-card:nth-child(2) .team-member-name { transition-delay: 1.2s; }
.team-section.visible .team-card:nth-child(3) .team-member-name { transition-delay: 1.4s; }
.team-section.visible .team-card:nth-child(4) .team-member-name { transition-delay: 1.6s; }
.team-section.visible .team-card:nth-child(5) .team-member-name { transition-delay: 1.8s; }
.team-section.visible .team-card:nth-child(6) .team-member-name { transition-delay: 2.0s; }

.team-section.visible .team-card:nth-child(1) .team-member-role { transition-delay: 1.2s; }
.team-section.visible .team-card:nth-child(2) .team-member-role { transition-delay: 1.4s; }
.team-section.visible .team-card:nth-child(3) .team-member-role { transition-delay: 1.6s; }
.team-section.visible .team-card:nth-child(4) .team-member-role { transition-delay: 1.8s; }
.team-section.visible .team-card:nth-child(5) .team-member-role { transition-delay: 2.0s; }
.team-section.visible .team-card:nth-child(6) .team-member-role { transition-delay: 2.2s; }

/* Efecto de onda para el contenedor */
.team-grid {
  transform: scale(0.8);
  transition: all 1s ease-out 0.3s;
}

.team-section.visible .team-grid {
  transform: scale(1);
}

/* Sección Nuestro Equipo */
.team-section {
  padding: 80px 0;
  background-image: url('../assets/fondo_seccion.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  position: relative;
  overflow: hidden;
}

.team-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
}

.team-section .container {
  position: relative;
  z-index: 2;
}

.team-section .section-title {
  background: linear-gradient(135deg, #ff9800 0%, #ffc107 50%, #ff9800 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  font-size: 2.5rem;
  font-weight: 900;
  text-align: center;
  display: block;
  line-height: 1.1;
  letter-spacing: -0.02em;
  filter: drop-shadow(0 3px 6px rgba(255, 140, 0, 0.4));
}

.team-section .section-subtitle {
  color: rgba(0, 0, 0, 0.9);
  text-align: center;
  max-width: 600px;
  margin: 0 auto 50px auto;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
  filter: drop-shadow(0 2px 4px rgba(255, 165, 0, 0.3));
}

.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, 320px);
  gap: 30px;
  justify-content: center;
  justify-items: center;
}

.team-card {
  background: rgba(255, 255, 255, 0.95);
  border-radius: 20px;
  padding: 25px;
  text-align: center;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.2);
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  max-width: 320px;
}

.team-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.3);
  background: rgba(255, 255, 255, 1);
}

.team-member-image {
  width: 200px;
  height: 200px;
  margin: 0 auto 20px auto;
  border-radius: 50%;
  overflow: hidden;
  border: 5px solid rgba(243, 156, 18, 0.3);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}

.team-card:hover .team-member-image {
  border-color: var(--primary);
  transform: scale(1.08);
  box-shadow: 0 15px 40px rgba(243, 156, 18, 0.3);
}

.team-member-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.team-member-name {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 8px;
}

.team-member-role {
  font-size: 0.9rem;
  color: var(--primary);
  font-weight: 600;
  margin-bottom: 0;
}

/* Responsive para Team Section */
@media (max-width: 900px) {
  .team-section {
    padding: 60px 0;
  }
  
  .team-grid {
    grid-template-columns: repeat(auto-fit, 280px);
    gap: 25px;
  }
  
  .team-card {
    max-width: 280px;
    padding: 20px;
  }
  
  .team-member-image {
    width: 170px;
    height: 170px;
  }
  
  .team-member-name {
    font-size: 1.1rem;
  }
  
  .team-member-role {
    font-size: 0.85rem;
  }
}

@media (max-width: 768px) {
  .team-section {
    padding: 50px 0;
  }
  
  .team-grid {
    grid-template-columns: repeat(auto-fit, 250px);
    gap: 20px;
  }
  
  .team-card {
    max-width: 250px;
    padding: 18px;
  }
  
  .team-member-image {
    width: 150px;
    height: 150px;
  }
  
  .team-member-name {
    font-size: 1rem;
  }
  
  .team-member-role {
    font-size: 0.8rem;
  }
}

@media (max-width: 480px) {
  .team-section {
    padding: 40px 0;
  }
  
  .team-grid {
    grid-template-columns: repeat(auto-fit, 220px);
    gap: 15px;
  }
  
  .team-card {
    max-width: 220px;
    padding: 15px;
  }
  
  .team-member-image {
    width: 130px;
    height: 130px;
  }
  
  .team-member-name {
    font-size: 0.95rem;
  }
  
  .team-member-role {
    font-size: 0.75rem;
  }
}

@media (max-width: 360px) {
  .team-section {
    padding: 30px 0;
  }
  
  .team-grid {
    grid-template-columns: 1fr;
    gap: 15px;
    max-width: 300px;
    margin: 0 auto;
  }
  
  .team-card {
    max-width: 300px;
  }
  
  .team-member-image {
    width: 120px;
    height: 120px;
  }
}

/* Responsive para dos columnas */
@media (max-width: 900px) {
  .two-columns-container {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  
  .plans-grid-tv {
    grid-template-columns: repeat(auto-fit, 180px);
    gap: 12px;
    justify-content: center;
    justify-items: center;
  }
  
  .tv-card {
    padding: 14px;
    min-height: 180px;
    max-width: 180px;
  }
}

@media (max-width: 768px) {
  .two-columns-container {
    gap: 24px;
  }
  
  .column-section .section-header h2 {
    font-size: 1.3rem;
  }
  
  .column-section .section-header p {
    font-size: 0.85rem;
  }
  
  .plans-grid-tv {
    grid-template-columns: repeat(auto-fit, 160px);
    gap: 10px;
    justify-content: center;
    justify-items: center;
  }
  
  .tv-card {
    padding: 12px;
    min-height: 160px;
    max-width: 160px;
  }
  
  .tv-header {
    margin-bottom: 6px;
    padding-bottom: 6px;
  }
  
  .tv-icon {
    font-size: 1.5rem;
  }
  
  .channels-count {
    font-size: 0.8rem;
  }
  
  .tv-quality {
    font-size: 0.6rem;
    padding: 2px 6px;
  }
  
  .tv-price {
    font-size: 1.2rem;
  }
  
  .tv-features {
    gap: 3px;
  }
  
  .tv-features span {
    font-size: 0.55rem;
    padding: 2px 3px;
  }
}

@media (max-width: 480px) {
  .two-columns-container {
    gap: 20px;
  }
  
  .column-section .section-header h2 {
    font-size: 1.2rem;
  }
  
  .column-section .section-header p {
    font-size: 0.8rem;
  }
  
  .plans-grid-tv {
    grid-template-columns: repeat(auto-fit, 140px);
    gap: 8px;
    justify-content: center;
    justify-items: center;
  }
  
  .tv-card {
    padding: 10px;
    min-height: 140px;
    max-width: 140px;
  }
  
  .tv-price {
    font-size: 1.1rem;
  }
  
  .tv-features span {
    font-size: 0.5rem;
  }
}
.plans-carousel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
  margin-bottom: 40px;
}

/* Mejoras responsive para Plans */
@media (max-width: 1200px) {
  .plans-carousel-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
  }
  .plan-carousel-card {
    padding: 24px;
  }
}

@media (max-width: 900px) {
  .plans-carousel-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 20px;
  }
  .plan-carousel-card {
    padding: 20px;
  }
  .plan-carousel-card.featured {
    transform: scale(1.02);
  }
  .plan-header {
    margin-bottom: 16px;
  }
  .plan-name {
    font-size: 1.1rem;
  }
  .plan-price {
    font-size: 1.3rem;
  }
  .plan-features li {
    font-size: 0.85rem;
    padding: 6px 0;
  }
}

@media (max-width: 768px) {
  .plans-carousel-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 400px;
    margin: 0 auto 30px;
  }
  .plan-carousel-card {
    padding: 18px;
  }
  .plan-carousel-card.featured {
    transform: scale(1);
  }
  .plan-icon {
    font-size: 1.5rem;
  }
  .plan-name {
    font-size: 1rem;
  }
  .plan-price {
    font-size: 1.2rem;
  }
  .plan-features li {
    font-size: 0.8rem;
    padding: 5px 0;
  }
  .section-header h2 {
    font-size: 1.4rem;
  }
  .section-header p {
    font-size: 0.85rem;
  }
}

@media (max-width: 480px) {
  .plans-carousel-grid {
    gap: 12px;
    max-width: 350px;
  }
  .plan-carousel-card {
    padding: 16px;
  }
  .plan-header {
    margin-bottom: 12px;
  }
  .plan-icon {
    font-size: 1.3rem;
  }
  .plan-name {
    font-size: 0.9rem;
  }
  .plan-price {
    font-size: 1.1rem;
  }
  .plan-features li {
    font-size: 0.75rem;
    padding: 4px 0;
  }
  .section-header h2 {
    font-size: 1.2rem;
  }
  .section-header p {
    font-size: 0.8rem;
  }
}

@media (max-width: 360px) {
  .plans-carousel-grid {
    gap: 10px;
    max-width: 320px;
  }
  .plan-carousel-card {
    padding: 14px;
  }
  .plan-icon {
    font-size: 1.2rem;
  }
  .plan-name {
    font-size: 0.85rem;
  }
  .plan-price {
    font-size: 1rem;
  }
  .plan-features li {
    font-size: 0.7rem;
    padding: 3px 0;
  }
  .section-header h2 {
    font-size: 1.1rem;
  }
  .section-header p {
    font-size: 0.75rem;
  }
}

.plan-carousel-card {
  background: linear-gradient(135deg, #ffffff 0%, #fef9f0 100%);
  border-radius: 20px;
  padding: 30px;
  box-shadow: 0 10px 40px rgba(243,156,18,0.15);
  transition: all 0.3s ease;
  position: relative;
  border: 2px solid transparent;
  overflow: hidden;
}

.plan-carousel-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
  transform: scaleX(0);
  transition: transform 0.3s ease;
}

.plan-carousel-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 60px rgba(243,156,18,0.25);
  border-color: var(--primary);
}

.plan-carousel-card:hover::before {
  transform: scaleX(1);
}

.plan-carousel-card.featured {
  background: linear-gradient(135deg, #fff8e1 0%, #fff3c4 100%);
  border-color: var(--primary);
  transform: scale(1.05);
  box-shadow: 0 15px 50px rgba(243,156,18,0.3);
}

.plan-badge {
  position: absolute;
  top: -10px;
  right: 20px;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: white;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 600;
  box-shadow: 0 4px 15px rgba(243,156,18,0.3);
  transform: rotate(5deg);
  animation: float 3s ease-in-out infinite;
}

@keyframes float {
  0%, 100% { transform: rotate(5deg) translateY(0); }
  50% { transform: rotate(5deg) translateY(-5px); }
}

.plan-header {
  text-align: center;
  margin-bottom: 25px;
  padding-bottom: 20px;
  border-bottom: 2px solid rgba(243,156,18,0.1);
}

.plan-icon {
  font-size: 3rem;
  margin-bottom: 15px;
  display: block;
  animation: bounce 2s infinite;
}

@keyframes bounce {
  0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
  40% { transform: translateY(-10px); }
  60% { transform: translateY(-5px); }
}

.plan-name {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 10px;
}

.plan-price {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--primary);
  line-height: 1;
  position: relative;
}

.plan-price span {
  font-size: 1rem;
  font-weight: 400;
  color: var(--text);
  opacity: 0.8;
}

.plan-content {
  text-align: center;
}

.plan-features {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
}

.plan-features li {
  padding: 10px 0;
  border-bottom: 1px solid rgba(0,0,0,0.05);
  font-size: 0.95rem;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s ease;
}

.plan-features li:hover {
  color: var(--primary);
  transform: translateX(5px);
}

.plan-features li:last-child {
  border-bottom: none;
}

.plans-carousel-cta {
  text-align: center;
  margin-top: 40px;
}

.plans-carousel-cta .btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 16px 32px;
  font-size: 1.1rem;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  box-shadow: 0 12px 35px rgba(243,156,18,0.3);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.plans-carousel-cta .btn-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition: left 0.5s ease;
}

.plans-carousel-cta .btn-primary:hover::before {
  left: 100%;
}

.plans-carousel-cta .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 45px rgba(243,156,18,0.4);
}

/* Responsive para carrusel */
@media (max-width: 768px) {
  .carousel-control {
    width: 40px;
    height: 40px;
    font-size: 18px;
  }
  
  .carousel-control.prev {
    left: 10px;
  }
  
  .carousel-control.next {
    right: 10px;
  }
  
  .section-title {
    font-size: 2rem;
  }
  
  .plans-carousel-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .plan-carousel-card.featured {
    transform: scale(1);
  }
  
  .carousel-slide {
    padding: 30px 20px;
  }
}

/* Sección de beneficios */
.benefits-section {
  padding: 0px;
  background: rgba(243,156,18,0.05);
}

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 30px;
  margin-top: 20px;
}

.benefit-card {
  background: rgba(255,251,240,.92);
  border-radius: var(--radius-lg);
  padding: 18px;
  text-align: center;
  box-shadow: var(--shadow-card);
  transition: var(--transition);
  border: 1px solid rgba(243,156,18,0.2);
  position: relative;
  overflow: hidden;
}

.benefit-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 25px 55px rgba(243,156,18,.25);
}

.benefit-icon {
  font-size: 3rem;
  margin-bottom: 15px;
  display: block;
}

.benefit-card h3 {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 12px;
}

.benefit-card p {
  font-size: 0.95rem;
  color: var(--text);
  line-height: 1.6;
}

.benefit-card::before {
  display: none;
}

.benefit-card::after {
  display: none;
}

@keyframes marbledMove {
  0% { transform: rotate(0deg) scale(1); }
  50% { transform: rotate(180deg) scale(1.05); }
  100% { transform: rotate(360deg) scale(1); }
}

.benefit-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 25px 50px rgba(243,156,18,.25);
}
.benefit-icon{
  font-size:3rem;
  margin-bottom:15px;
  display:block;
  animation: iconFloat 3s ease-in-out infinite;
  position: relative;
  z-index: 1;
}
@keyframes iconFloat {
  0% { transform: translateY(0px) rotate(0deg); }
  25% { transform: translateY(-5px) rotate(2deg); }
  50% { transform: translateY(-8px) rotate(0deg); }
  75% { transform: translateY(-5px) rotate(-2deg); }
  100% { transform: translateY(0px) rotate(0deg); }
}
.benefit-card h3{
  color:var(--primary);
  font-size:1.3rem;
  font-weight:700;
  margin-bottom:15px;
  position: relative;
  z-index: 1;
  text-shadow: 0 1px 2px rgba(0,0,0,0.1);
}
.benefit-card p{
  color:var(--text);
  line-height:1.6;
  font-size:0.95rem;
  position: relative;
  z-index: 1;
  text-shadow: 0 1px 1px rgba(255,255,255,0.5);
}

/* Carrusel de canales mejorado */
.channels-section{
  padding:80px 0;
}
.channels-header{
  text-align:center;
  margin-bottom:40px;
}
.channels-header strong{
  font-size:3.2rem;
  
  color:#000000;
  font-weight:900;
  text-shadow: 0 2px 4px rgba(200,200,200,0.8), 0 4px 8px rgba(220,220,220,0.6), 0 0 12px rgba(240,240,240,0.4);
  display:block;
  line-height:1.2;
  letter-spacing: -0.02em;
  text-align: center;
  width: 100%;
}
.channels-strip-wrapper{
  overflow:hidden;
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,0.05);
  padding:20px;
  backdrop-filter:blur(10px);
}
.channels-strip{
  display:flex;
  gap:15px;
  animation:scrollChannels 30s linear infinite;
  width:max-content;
}
.channel-pill{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  background:var(--card-bg);
  border-radius:var(--radius-lg);
  padding:15px;
  min-width:120px;
  box-shadow:0 8px 25px rgba(243,156,18,.15);
  border:1px solid rgba(243,156,18,0.2);
  transition:var(--transition);
}
.channel-pill:hover{
  transform: translateY(-3px);
  box-shadow:0 12px 30px rgba(243,156,18,.25);
}
.channel-icon{
  width:60px;
  height:60px;
  border-radius:12px;
  overflow:hidden;
  background:rgba(255,255,255,0.1);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:5px;
}
.channel-icon img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.channel-pill span{
  font-size:0.85rem;
  font-weight:600;
  color:var(--text);
  text-align:center;
  line-height:1.2;
}

/* Carrusel de canales (index) */
.channels-section{
  padding:10px 0 36px;
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.8s ease-out;
}

.channels-section.visible {
  opacity: 1;
  transform: translateY(0);
}
.channels-header{
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;margin-bottom:10px;font-size:.85rem;color:#6a7a98;
}
.channels-header strong{
  color:var(--dark);
  font-size:1.95rem;
  padding-top: 12px;
  padding-bottom: 12px;}
.channels-strip-wrapper{
  position:relative;overflow:hidden;border-radius:999px;
  background:rgba(255,255,255,0.9);
  box-shadow:0 14px 40px rgba(243,156,18,.15);
  padding:8px 0;
  backdrop-filter: blur(8px);
}
.channels-strip{
  display:flex;gap:14px;align-items:center;
  animation: channelsScroll 26s linear infinite;will-change:transform;
}
.channel-pill{
  flex:0 0 auto;min-width:120px;padding:8px 14px;border-radius:999px;
  background:white;display:flex;align-items:center;gap:8px;
  font-size:.8rem;font-weight:600;color:var(--dark);
  box-shadow:0 8px 22px rgba(243,156,18,.18);
}
.channel-icon{
  width:42px;height:42px;border-radius:12px;overflow:hidden;
}
.channel-icon img{width:100%;height:100%;object-fit:cover;display:block;}
@keyframes channelsScroll{
  0%{transform:translateX(0);} 
  100%{transform:translateX(-50%);} 
}

/* Secciones genéricas */
section{padding:12px 0;}
.section-title{
  font-size:1.9rem;font-weight:800;color:var(--dark);margin-bottom:6px;
}
.section-subtitle{
  font-size:.9rem;color:#6a7a98;margin-bottom:20px;text-align: center;margin-top: 18px;
}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:26px;}
.card{background:white;border-radius:20px;padding:18px;box-shadow:0 10px 30px rgba(13,40,80,.08);}
.card h3{font-size:1.05rem;margin-bottom:6px;color:var(--dark);}
.chip{
  display:inline-block;margin-top:10px;font-size:.75rem;
  padding:4px 9px;border-radius:999px;
  background:rgba(224,238,255,0.9);color:#315c9c;
}

/* Planes (index, planes) */
.plans{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;}
.plan{
  background:white;border-radius:20px;padding:18px;
  box-shadow:0 14px 35px rgba(243,156,18,.12);
  display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;
}
.plan-name{font-weight:700;color:var(--dark);}
.plan-speed{font-size:1.6rem;font-weight:800;color:var(--primary);}
.plan-price{font-weight:700;}
.plan ul{list-style:none;font-size:.85rem;display:flex;flex-direction:column;gap:4px;}
.plan ul li::before{content:"• ";color:var(--primary);}
.plan-tag{
  position:absolute;top:14px;right:14px;font-size:.7rem;
  background:var(--primary);color:white;border-radius:999px;padding:3px 9px;
}
.logo-mark {
  width: 202px;
  height: 156px;
}
/* Cobertura */
.maps-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;}
.map-card iframe{width:100%;border:0;border-radius:16px;min-height:220px;}

/* Contrato */
.contract-box{
  background:white;border-radius:20px;padding:20px;
  box-shadow:0 12px 32px rgba(13,40,80,.12);
  max-height:654px;overflow:auto;font-size:1rem;
  border:1px solid rgba(9,53,120,.1);
}
.contract-box h4{margin:10px 0 6px;font-size:1.1rem;}
.contract-box h5{margin:8px 0 4px;font-size:1rem;color:var(--dark);}
.contract-meta{
  display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px;font-size:.9rem;color:#6a7a98;
}
.contract-box ul{
  list-style:none;padding-left:16px;margin:8px 0;
}
.contract-box ul li{
  margin-bottom:8px;padding-left:14px;position:relative;font-size:1rem;
}
.contract-box ul li::before{
  content:"•";position:absolute;left:0;color:var(--primary);
  font-weight:bold;
}
.contract-box p{
  margin:10px 0;line-height:1.6;font-size:1rem;
}

/* Contenido específico para páginas legales */
.contract-content{
  margin-bottom:20px;
}
.contract-content p{
  margin:12px 0;line-height:1.7;font-size:1rem;color:var(--dark);
}
.contract-content strong{
  color:var(--primary);font-weight:600;
}

/* Requisitos (si se usa) */
.requirements{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;}
.requirements ul{list-style:none;font-size:.86rem;}
.requirements li{margin-bottom:6px;}
.requirements li::before{content:"▹ ";color:var(--primary);}

/* PQRS */
.pqrs-banner{
  margin-top:10px;padding:14px 16px;border-radius:18px;
  background:var(--primary);
  color:white;display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;
  align-items:center;box-shadow:0 16px 40px rgba(9,46,102,.4);
}
.btn-pqrs{
  padding:10px 20px;border-radius:999px;border:none;
  background:white;color:var(--primary);font-weight:700;
  cursor:pointer;font-size:.9rem;box-shadow:0 10px 28px rgba(3,28,66,.45);
}
form{display:grid;gap:10px;margin-top:8px;font-size:.85rem;}
label{font-weight:600;font-size:.8rem;color:var(--dark);}
input,select,textarea{
  padding:8px 10px;border-radius:10px;border:1px solid rgba(21,56,110,.18);
  font:inherit;background:white;
}
textarea{min-height:90px;resize:vertical;}
.hint{font-size:.75rem;color:#7b8aac;}
#detalle_pqr{
  display: contents;
}
/* Footer */
footer{
  background: rgba(255, 251, 240, .92);
  border-top:1px solid rgba(167,188,226,.4);
  padding:18px 0 24px;font-size:.78rem;color:#7b8aac;
}
footer .columns{
  display:grid;grid-template-columns:1.5fr 1.2fr 1.2fr 1.2fr;gap:18px;
}

/* Mejoras responsive para Footer */
@media (max-width: 1200px) {
  footer .columns {
    grid-template-columns: 1.2fr 1fr 1fr 1fr;
    gap: 16px;
  }
}

@media (max-width: 900px) {
  footer .columns {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  footer .columns > div:first-child {
    grid-column: span 2;
  }
}

@media (max-width: 768px) {
  footer .columns {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  footer .columns > div {
    text-align: center;
  }
  .footer-map {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  .footer-address-link {
    max-width: 300px;
  }
}

@media (max-width: 480px) {
  footer .columns {
    gap: 12px;
  }
  footer .columns > div {
    padding: 0 8px;
  }
  .footer-map {
    gap: 8px;
  }
  .footer-address-link {
    max-width: 250px;
  }
  footer .columns > div p {
    font-size: 0.8rem;
  }
  footer .columns > div strong {
    font-size: 0.9rem;
  }
}

@media (max-width: 360px) {
  footer .columns {
    gap: 10px;
  }
  footer .columns > div {
    padding: 0 4px;
  }
  .footer-address-link {
    max-width: 220px;
  }
  footer .columns > div p {
    font-size: 0.75rem;
  }
  footer .columns > div strong {
    font-size: 0.85rem;
  }
}

/* Menú hamburguesa responsive */
.menu-toggle{
  display:none;background:none;border:none;
  cursor:pointer;padding:8px;border-radius:8px;
  transition:var(--transition);
}
.menu-toggle:hover{background:var(--primary-soft);}
.menu-toggle span{
  display:block;width:24px;height:2px;
  background:var(--dark);margin:5px 0;
  transition:var(--transition);border-radius:2px;
}

/* Mejoras para menú hamburguesa en móvil */
@media (max-width: 768px) {
  .menu-toggle {
    background: rgba(243, 156, 18, 0.1); /* Fondo semi-transparente */
    border: 1px solid rgba(243, 156, 18, 0.3); /* Borde visible */
    padding: 10px;
  }
  .menu-toggle:hover {
    background: rgba(243, 156, 18, 0.2); /* Hover más visible */
  }
  .menu-toggle span {
    background: #f39c12; /* Color naranja para visibilidad */
    width: 26px; /* Un poco más grande */
    height: 3px; /* Un poco más grueso */
    margin: 4px 0;
  }
}

@media (max-width: 640px) {
  .menu-toggle {
    padding: 8px;
  }
  .menu-toggle span {
    width: 24px;
    height: 2.5px;
  }
}

@media (max-width: 480px) {
  .menu-toggle {
    padding: 6px;
  }
  .menu-toggle span {
    width: 22px;
    height: 2px;
  }
}

@media (max-width: 360px) {
  .menu-toggle {
    padding: 4px;
  }
  .menu-toggle span {
    width: 20px;
    height: 2px;
  }
}
.menu-toggle.active span:nth-child(1){
  transform:rotate(45deg) translate(5px,5px);
}
.menu-toggle.active span:nth-child(2){opacity:0;}
.menu-toggle.active span:nth-child(3){
  transform:rotate(-45deg) translate(7px,-6px);
}

/* Navegación móvil */
.mobile-nav{
  display:none;position:fixed;top:0;left:-100%;
  width:80%;max-width:300px;height:100vh;
  background:white;z-index:100;
  box-shadow:2px 0 20px rgba(0,0,0,.2);
  transition:left .3s ease;
  overflow-y:auto;
}
.mobile-nav.active{left:0;}
.mobile-nav-header{
  padding:20px;border-bottom:1px solid rgba(0,0,0,.1);
  display:flex;justify-content:space-between;align-items:center;
}
.mobile-nav-close{
  background:none;border:none;font-size:24px;
  cursor:pointer;color:var(--dark);padding:4px;
}
.mobile-nav ul{
  list-style:none;padding:20px 0;
}
.mobile-nav li{
  border-bottom:1px solid rgba(0,0,0,.05);
}
.mobile-nav a{
  display:block;padding:15px 20px;
  color:var(--dark);font-weight:500;
  text-decoration:none;transition:var(--transition);
}
.mobile-nav a:hover{
  background:var(--primary-soft);color:var(--primary);
}
.mobile-nav .btn-nav{
  margin:20px;margin-bottom:40px;
  width:calc(100% - 40px);
}

/* Overlay para móvil */
.mobile-nav-overlay{
  display:none;position:fixed;top:0;left:0;
  width:100%;height:100vh;background:rgba(0,0,0,.5);
  z-index:99;opacity:0;transition:opacity .3s ease;
}
.mobile-nav-overlay.active{display:block;opacity:1;}

/* Botón flotante WhatsApp */
.whatsapp-float{
  position:fixed;right:18px;bottom:18px;z-index:80;
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;
}
.wa-label{
  background:white;border-radius:999px;padding:6px 10px;
  font-size:.75rem;box-shadow:0 8px 22px rgba(0,0,0,.18);
}
.wa-btn{
  width:52px;height:52px;border-radius:999px;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  color:white;font-size:26px;box-shadow:0 14px 32px rgba(0,0,0,.3);
}

/* Responsivo - Index específico */

/* Tablets grandes (900px y menos) */
@media (max-width:900px){
  .hero{padding:30px 0 24px;}
  .hero-inner{grid-template-columns:1fr;gap:24px;}
  .hero-media{order:-1;margin-top:10px;}
  .hero-title{font-size:2.2rem;}
  .hero-text{max-width:100%;font-size:.95rem;}
  .hero-badges{gap:8px;}
  .hero-cta{gap:12px;}
  .btn-primary{padding:10px 22px;font-size:.9rem;}
  .btn-ghost{padding:9px 16px;font-size:.85rem;}
  .hero-media{width:100%;max-width:500px;margin:0 auto;}
  .hero-media-side{display:none;}
  .hero-floating-card{width:90%;padding:10px 12px;}
  .channels-section{padding:8px 0 24px;}
  .channels-header{font-size:.8rem;}
  .plans{grid-template-columns:repeat(2,minmax(0,1fr));}
  .maps-grid,.requirements,.grid-2,footer .columns{grid-template-columns:1fr;}
  .why-choose-grid{grid-template-columns:1fr;}
  .why-choose-inner{grid-template-columns:1fr;}
  .coverage-checker-grid{grid-template-columns:1fr;}
  .faq-hero-inner{grid-template-columns:1fr;}
  .faq-grid{grid-template-columns:1fr;}
  .neighborhoods-grid{grid-template-columns:repeat(2,1fr);}
}

/* Tablets pequeñas (768px y menos) */
@media (max-width:768px){
  .hero{padding:24px 0 20px;}
  .hero-title{font-size:2rem;}
  .hero-text{font-size:.9rem;}
  .hero-badges{flex-direction:column;gap:6px;}
  .badge{font-size:.7rem;padding:4px 8px;}
  .hero-cta{flex-direction:column;align-items:flex-start;gap:10px;}
  .btn-primary{width:100%;padding:12px 20px;text-align:center;}
  .btn-ghost{width:100%;padding:10px 16px;text-align:center;justify-content:center;}
  .hero-note{font-size:.7rem;}
  .hero-media{max-width:400px;}
  .hero-floating-card{width:95%;padding:8px 10px;}
  .hero-floating-card div{font-size:.85rem;}
  .channels-strip-wrapper{padding:6px 0;}
  .channel-pill{min-width:100px;padding:6px 10px;font-size:.7rem;}
  .channel-icon{width:20px;height:20px;}
  .plans{grid-template-columns:1fr;}
}

/* Móviles grandes (640px y menos) */
@media (max-width:640px){
  nav ul{display:none;}
  .menu-toggle{display:block;}
  .mobile-nav{display:block;}
  .mobile-nav-overlay{display:block;}
  .hero{padding:20px 0 16px;}
  .hero-title{font-size:1.8rem;line-height:1.2;}
  .hero-highlight{display:block;}
  .hero-text{font-size:.85rem;margin-bottom:16px;}
  .hero-badges{margin-bottom:16px;}
  .hero-cta{margin-bottom:16px;}
  .hero-media{max-width:350px;}
  .hero-floating-card{width:98%;padding:6px 8px;}
  .hero-floating-card div{font-size:.75rem;}
  .hero-floating-card div div{font-size:.65rem;}
  .channels-section{padding:6px 0 20px;}
  .channels-header{font-size:.75rem;}
  .channel-pill{min-width:90px;padding:4px 8px;font-size:.65rem;}
  .channel-icon{width:18px;height:18px;}
}

/* Tablets pequeñas y móviles grandes (768px y menos) */
@media (max-width:768px){
  .container{width: calc(100% - 24px);}
  .nav{padding:10px 0;}
  .logo-mark{width:40px;height:40px;}
  nav ul{gap:15px;font-size:.85rem;}
  .btn-nav{padding:6px 14px;font-size:.85rem;}
  .section-title{font-size:1.8rem;}
  .section-subtitle{font-size:.8rem;}
  .hero-title{font-size:2.2rem;}
  .hero-subtitle{font-size:.95rem;}
  .plans{grid-template-columns:1fr;gap:16px;}
  .plan{padding:20px;}
  .plan-speed{font-size:1.4rem;}
  .plan-price{font-size:1.1rem;}
  .about-grid{gap:20px;}
  .card{padding:20px;}
  .why-features{gap:12px;}
  .why-feature{gap:12px;}
  .why-feature-icon{width:40px;height:40px;font-size:1.2rem;}
  .why-feature-text h4{font-size:.9rem;}
  .why-feature-text p{font-size:.8rem;}
  .coverage-form-card{padding:20px;}
  .neighborhoods-grid{grid-template-columns:repeat(2,1fr);}
  .faq-grid{grid-template-columns:1fr;gap:12px;}
  .faq-question{padding:14px 16px;font-size:.9rem;}
  .columns{grid-template-columns:1fr;gap:20px;}
  .features-grid{gap:20px;flex-direction:column;align-items:center;}
  .feature-item{width:100%;max-width:200px;}
  .plans-grid-internet{grid-template-columns:1fr;gap:16px;}
  .plan-card{flex:0 0 220px;}
  .documents-card{padding:20px;max-width:100%;}
  .documents-list{gap:12px;}
  .document-item{padding:12px;}
  .doc-icon{width:40px;height:40px;font-size:1.3rem;}
  .document-item span{font-size:.85rem;}
  
  /* Específico para planes.html */
  .plans-section{padding:20px 0;}
  .section-header{margin-bottom:20px;}
  .section-header h2{font-size:1.4rem;}
  .section-header p{font-size:.85rem;}
  .plans-carousel{padding:15px 0;overflow-x:scroll;-webkit-overflow-scrolling:touch;}
  .plan-card{flex:0 0 220px;padding:16px;}
  .speed-badge{font-size:1.1rem;padding:8px 10px;}
  .tv-icon{font-size:2.2rem;}
  .plan-price{font-size:1.6rem;}
  .plan-period{font-size:.75rem;}
  .plan-features li{font-size:.8rem;}
  .features-section{padding:30px 0;}
  .features-grid{grid-template-columns:repeat(2,1fr);gap:20px;}
  
  /* Específico para cobertura.html */
  .coverage-checker-section{padding:20px 0;}
  .coverage-checker-grid{grid-template-columns:1fr;gap:20px;}
  .coverage-info h2{font-size:1.5rem;}
  .coverage-info p{font-size:.85rem;}
  .coverage-form-card{padding:20px;display:block;visibility:visible;}
  .coverage-form input,
  .coverage-form select{padding:10px 12px;font-size:.85rem;display:block;visibility:visible;}
  .btn-coverage{padding:12px 20px;font-size:.9rem;display:block;visibility:visible;}
  .neighborhoods-card{padding:20px;}
  .neighborhoods-card h3{font-size:1rem;}
  .neighborhoods-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
  .neighborhood-item{padding:6px 10px;font-size:.75rem;}
  
  /* Específico para nosotros.html */
  .page-hero{padding:30px 0 20px;}
  .about-grid{grid-template-columns:1fr;gap:20px;}
  .card{padding:20px;}
  .card h3{font-size:1rem;}
  .card p{font-size:.85rem;}
  .why-choose-section{padding:40px 0;}
  .why-choose-inner{grid-template-columns:1fr;gap:24px;}
  .why-choose-left h2{font-size:1.5rem;}
  .why-choose-left .kicker{font-size:.7rem;}
  .why-features{gap:16px;}
  .why-feature{gap:14px;}
  .why-feature-icon{width:44px;height:44px;font-size:1.4rem;}
  .why-feature-text h4{font-size:.95rem;}
  .why-feature-text p{font-size:.82rem;}
  .why-choose-right{padding:28px;}
  .why-choose-right h3{font-size:1.3rem;}
  .install-steps{gap:14px;}
  .install-step{gap:12px;}
  .install-step-number{width:28px;height:28px;font-size:.8rem;}
  .install-step-content h4{font-size:.9rem;}
  .install-step-content p{font-size:.8rem;}
}

/* Móviles pequeños (480px y menos) */
@media (max-width:480px){
  .container{width: calc(100% - 20px);}
  .nav{padding:8px 0;}
  .logo-mark{width:36px;height:36px;}
  .section-title{font-size:1.5rem;}
  .section-subtitle{font-size:.8rem;}
  .hero-title{font-size:1.6rem;}
  .hero-subtitle{font-size:.85rem;}
  .plan{padding:14px;}
  .plan-speed{font-size:1.2rem;}
  .plan-price{font-size:.95rem;}
  .plan ul{font-size:.75rem;}
  .card{padding:14px;}
  .why-choose-right{padding:16px;}
  .why-choose-right h3{font-size:1rem;}
  .install-steps{gap:12px;}
  .install-step{gap:8px;}
  .install-step-number{width:22px;height:22px;font-size:.7rem;}
  .install-step-content h4{font-size:.8rem;}
  .install-step-content p{font-size:.7rem;}
  .coverage-form-card{padding:14px;display:block;visibility:visible;}
  .coverage-form input,
  .coverage-form select{padding:8px 10px;font-size:.8rem;display:block;visibility:visible;}
  .btn-coverage{padding:10px 16px;font-size:.85rem;display:block;visibility:visible;}
  .neighborhoods-card{padding:16px;}
  .neighborhoods-card h3{font-size:.9rem;}
  .neighborhoods-grid{grid-template-columns:1fr;gap:6px;}
  .neighborhood-item{padding:4px 8px;font-size:.7rem;}
  .faq-question{padding:10px 12px;font-size:.8rem;}
  .faq-answer-content{padding:0 12px 12px;font-size:.75rem;}
  .columns{gap:12px;}
  .features-grid{gap:12px;}
  .feature-icon{width:45px;height:45px;font-size:1.3rem;}
  .feature-item span{font-size:.75rem;}
  .documents-card{padding:12px;}
  .documents-card h3{font-size:1rem;}
  .documents-card > p{font-size:.8rem;}
  .documents-list{gap:8px;}
  .document-item{padding:8px;gap:8px;}
  .doc-icon{width:32px;height:32px;font-size:1.1rem;}
  .document-item span{font-size:.75rem;}
  .documents-note{padding:10px;}
  .documents-note small{font-size:.65rem;}
  
  /* Específico para planes.html */
  .plans-section{padding:15px 0;}
  .section-header h2{font-size:1.2rem;}
  .section-header p{font-size:.8rem;}
  .plans-carousel{padding:10px 0;overflow-x:scroll;-webkit-overflow-scrolling:touch;}
  .plan-card{flex:0 0 200px;padding:12px 10px;}
  .speed-badge{font-size:1rem;padding:6px 8px;}
  .tv-icon{font-size:2rem;}
  .plan-price{font-size:1.4rem;}
  .plan-period{font-size:.7rem;}
  .plan-features li{font-size:.75rem;}
  .features-section{padding:20px 0;}
  .features-grid{grid-template-columns:1fr;gap:16px;}
  
  /* Específico para cobertura.html */
  .coverage-checker-section{padding:15px 0;}
  .coverage-checker-grid{gap:16px;}
  .coverage-info h2{font-size:1.3rem;}
  .coverage-info p{font-size:.8rem;}
  .coverage-form-card{padding:16px;display:block;visibility:visible;}
  .coverage-form input,
  .coverage-form select{padding:8px 10px;font-size:.8rem;display:block;visibility:visible;}
  .btn-coverage{padding:10px 16px;font-size:.85rem;display:block;visibility:visible;}
  .neighborhoods-card{padding:16px;}
  .neighborhoods-card h3{font-size:.9rem;}
  .neighborhoods-grid{grid-template-columns:1fr;gap:6px;}
  .neighborhood-item{padding:4px 8px;font-size:.7rem;}
  
  /* Específico para nosotros.html */
  .page-hero{padding:20px 0 15px;}
  .about-grid{gap:16px;}
  .card{padding:16px;}
  .card h3{font-size:.9rem;}
  .card p{font-size:.8rem;}
  .why-choose-section{padding:30px 0;}
  .why-choose-inner{gap:20px;}
  .why-choose-left h2{font-size:1.3rem;}
  .why-choose-left .kicker{font-size:.65rem;}
  .why-features{gap:14px;}
  .why-feature{gap:12px;}
  .why-feature-icon{width:40px;height:40px;font-size:1.2rem;}
  .why-feature-text h4{font-size:.9rem;}
  .why-feature-text p{font-size:.8rem;}
  .why-choose-right{padding:20px;}
  .why-choose-right h3{font-size:1rem;}
  .install-steps{gap:12px;}
  .install-step{gap:8px;}
  .install-step-number{width:24px;height:24px;font-size:.7rem;}
  .install-step-content h4{font-size:.8rem;}
  .install-step-content p{font-size:.7rem;}
}

/* Móviles muy pequeños (360px y menos) */
@media (max-width:360px){
  .container{width: calc(100% - 16px);}
  .nav{padding:6px 0;}
  .logo-mark{width:32px;height:32px;}
  .section-title{font-size:1.3rem;}
  .section-subtitle{font-size:.75rem;}
  .hero-title{font-size:1.4rem;}
  .hero-subtitle{font-size:.8rem;}
  .plan{padding:12px;}
  .plan-speed{font-size:1.1rem;}
  .plan-price{font-size:.9rem;}
  .plan ul{font-size:.7rem;}
  .card{padding:12px;}
  .why-choose-right{padding:12px;}
  .why-choose-right h3{font-size:.9rem;}
  .install-steps{gap:8px;}
  .install-step{gap:6px;}
  .install-step-number{width:18px;height:18px;font-size:.6rem;}
  .install-step-content h4{font-size:.7rem;}
  .install-step-content p{font-size:.65rem;}
  .coverage-form-card{padding:12px;}
  .coverage-form input,
  .coverage-form select{padding:6px 8px;font-size:.75rem;}
  .btn-coverage{padding:8px 12px;font-size:.8rem;}
  .neighborhoods-card{padding:12px;}
  .neighborhoods-card h3{font-size:.85rem;}
  .neighborhood-item{padding:3px 6px;font-size:.65rem;}
  .faq-question{padding:8px 10px;font-size:.75rem;}
  .faq-answer-content{padding:0 10px 10px;font-size:.7rem;}
  .columns{gap:10px;}
  .features-grid{gap:10px;}
  .feature-icon{width:40px;height:40px;font-size:1.2rem;}
  .feature-item span{font-size:.7rem;}
  .documents-card{padding:10px;}
  .documents-card h3{font-size:.9rem;}
  .documents-card > p{font-size:.75rem;}
  .documents-list{gap:6px;}
  .document-item{padding:6px;gap:6px;}
  .doc-icon{width:28px;height:28px;font-size:1rem;}
  .document-item span{font-size:.7rem;}
  .documents-note{padding:8px;}
  .documents-note small{font-size:.6rem;}
  
  /* Específico para planes.html */
  .plans-section{padding:12px 0;}
  .section-header h2{font-size:1.1rem;}
  .section-header p{font-size:.75rem;}
  .plans-carousel{padding:8px 0;}
  .plan-card{flex:0 0 160px;padding:10px 8px;}
  .speed-badge{font-size:.9rem;padding:4px 6px;}
  .tv-icon{font-size:1.8rem;}
  .plan-price{font-size:1.2rem;}
  .plan-period{font-size:.65rem;}
  .plan-features li{font-size:.7rem;}
  .features-section{padding:15px 0;}
  .features-grid{gap:12px;}
  
  /* Específico para cobertura.html */
  .coverage-checker-section{padding:12px 0;}
  .coverage-checker-grid{gap:12px;}
  .coverage-info h2{font-size:1.2rem;}
  .coverage-info p{font-size:.75rem;}
  .coverage-form-card{padding:12px;}
  .coverage-form input,
  .coverage-form select{padding:6px 8px;font-size:.75rem;}
  .btn-coverage{padding:8px 12px;font-size:.8rem;}
  .neighborhoods-card{padding:12px;}
  .neighborhoods-card h3{font-size:.85rem;}
  .neighborhood-item{padding:3px 6px;font-size:.65rem;}
  
  /* Específico para nosotros.html */
  .page-hero{padding:15px 0 12px;}
  .about-grid{gap:12px;}
  .card{padding:12px;}
  .card h3{font-size:.85rem;}
  .card p{font-size:.75rem;}
  .why-choose-section{padding:25px 0;}
  .why-choose-inner{gap:16px;}
  .why-choose-left h2{font-size:1.2rem;}
  .why-choose-left .kicker{font-size:.6rem;}
  .why-features{gap:8px;}
  .why-feature{gap:6px;}
  .why-feature-icon{width:28px;height:28px;font-size:.9rem;}
  .why-feature-text h4{font-size:.75rem;}
  .why-feature-text p{font-size:.65rem;}
  .why-choose-right{padding:12px;}
  .why-choose-right h3{font-size:.9rem;}
  .install-steps{gap:8px;}
  .install-step{gap:4px;}
  .install-step-number{width:18px;height:18px;font-size:.6rem;}
  .install-step-content h4{font-size:.7rem;}
  .install-step-content p{font-size:.6rem;}
}

/* Page Hero - Páginas de políticas y planes */
.page-hero{
  margin-top: 58px;
      padding: 45px 0;
  position:relative;
  width:100%;
  overflow:hidden;
  background:linear-gradient(135deg, var(--bg) 0%, #e8f4ff 50%, var(--bg) 100%);
}

.page-hero::before{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 1;
}

.page-hero .container {
  position: relative;
  z-index: 2;
}

.page-hero .section-title {
  background: linear-gradient(135deg, #ff9800 0%, #ffc107 50%, #ff9800 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  font-size: 2.5rem;
  font-weight: 900;
  text-align: center;
  display: block;
  line-height: 1.1;
  letter-spacing: -0.02em;
  filter: drop-shadow(0 3px 6px rgba(255, 140, 0, 0.4));
}

.page-hero .section-subtitle {
  color: rgba(0, 0, 0, 0.9);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}
.page-hero::before,
.page-hero::after{
  content:"";
  position:absolute;
  border-radius:999px;
  background:radial-gradient(circle at 30% 30%, rgba(0,194,255,.25), transparent 60%);
  filter:blur(2px);
  opacity:.7;
  pointer-events:none;
  animation: floatCircle 18s ease-in-out infinite alternate;
}
.page-hero::before{
  width:380px;height:380px;
  top:-100px;left:-120px;
}
.page-hero::after{
  width:450px;height:450px;
  bottom:-200px;right:-100px;
  background:radial-gradient(circle at 60% 40%, rgba(255,215,0,.28), transparent 65%);
  animation-duration:24s;
}
.faq-hero{
  position:relative;
  width:100%;
  padding:58px 0 32px;
  margin-top: 48px;
  overflow:hidden;
  background-image: url('../assets/fondo_seccion.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}
.faq-hero::before,
.faq-hero::after{
  content:"";
  position:absolute;
  border-radius:999px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,0,.25), transparent 60%);
  filter:blur(2px);
  opacity:.7;
  pointer-events:none;
  animation: floatCircle 18s ease-in-out infinite alternate;
}
.faq-hero::before{
  width:380px;height:380px;
  top:-100px;left:-120px;
}
.faq-hero::after{
  width:450px;height:450px;
  bottom:-200px;right:-100px;
  background:radial-gradient(circle at 60% 40%, rgba(255,215,0,.28), transparent 65%);
  background:radial-gradient(circle at 60% 40%, rgba(27,140,242,.28), transparent 65%);
  animation-duration:24s;
}
.faq-header{
  text-align:center;
  margin-bottom:30px;
}
.faq-kicker{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--primary);margin-bottom:8px;
}
.faq-title{
  font-size:2rem;font-weight:800;color:var(--dark);margin-bottom:10px;
}
.faq-subtitle{
  font-size:.9rem;color:#6a7a98;max-width:500px;margin:0 auto;
}
.faq-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start;
}
.faq-item{
  background:white;border-radius:16px;
  box-shadow:0 8px 28px rgba(13,40,80,.1);
  overflow:hidden;transition:var(--transition);
}
.faq-item:hover{box-shadow:0 12px 35px rgba(13,40,80,.15);}
.faq-question{
  width:100%;padding:16px 20px;border:none;background:white;
  display:flex;justify-content:space-between;align-items:center;
  font-size:.95rem;font-weight:600;color:var(--dark);cursor:pointer;
  text-align:left;transition:var(--transition);
}
.faq-question:hover{background:#f8fbff;}
.faq-question span{font-size:1.4rem;color:var(--primary);transition:var(--transition);}
.faq-question.active span{transform:rotate(45deg);}
.faq-answer{
  max-height:0;overflow:hidden;transition:max-height .3s ease;
  background:white;
}
.faq-answer-content{
  padding:0 20px 16px;font-size:.85rem;color:var(--text);line-height:1.6;
}
.faq-answer.active{max-height:300px;}

/* Por qué elegirnos */
.why-choose-section{
  background:linear-gradient(135deg, #e8f4ff 0%, #f0f8ff 50%, #e8f4ff 100%);
  padding:50px 0;position:relative;overflow:hidden;
}
.why-choose-section::before{
  content:"";position:absolute;
  width:300px;height:300px;border-radius:999px;
  top:-100px;right:-80px;
  background:radial-gradient(circle at 30% 30%, rgba(0,194,255,.15), transparent 60%);
  filter:blur(2px);animation: floatCircle 20s ease-in-out infinite alternate;
}
.why-choose-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;
}
.why-choose-left h2{
  font-size:1.8rem;font-weight:800;color:var(--dark);margin-bottom:10px;
}
.why-choose-left .kicker{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--primary);margin-bottom:8px;
}
.why-features{
  display:flex;flex-direction:column;gap:16px;margin-top:24px;
}
.why-feature{
  display:flex;gap:14px;align-items:flex-start;
}
.why-feature-icon{
  width:44px;height:44px;border-radius:12px;
  background:white;display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;flex-shrink:0;
  box-shadow:0 8px 20px rgba(27,140,242,.2);
}
.why-feature-text h4{
  font-size:.95rem;font-weight:700;color:var(--dark);margin-bottom:4px;
}
.why-feature-text p{
  font-size:.82rem;color:#6a7a98;line-height:1.5;
}
.why-choose-right{
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  border-radius:24px;padding:28px;color:white;
  box-shadow:0 20px 50px rgba(27,140,242,.4);
}
.why-choose-right h3{
  font-size:1.3rem;font-weight:700;margin-bottom:20px;
}
.install-steps{
  display:flex;flex-direction:column;gap:14px;
}
.install-step{
  display:flex;gap:12px;align-items:flex-start;
}
.install-step-number{
  width:28px;height:28px;border-radius:999px;
  background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:700;flex-shrink:0;
}
.install-step-content h4{
  font-size:.9rem;font-weight:600;margin-bottom:2px;
}
.install-step-content p{
  font-size:.8rem;opacity:.9;line-height:1.4;
}

/* Cobertura - Barrios y Formulario */
.coverage-checker-section{
  background:linear-gradient(135deg, var(--bg) 0%, #e8f4ff 50%, var(--bg) 100%);
  padding:4px 0 37px 0;
  position:relative;overflow:hidden;
}
.coverage-checker-section::before,
.coverage-checker-section::after{
  content:"";position:absolute;border-radius:999px;
  background:radial-gradient(circle at 30% 30%, rgba(0,194,255,.2), transparent 60%);
  filter:blur(2px);opacity:.6;pointer-events:none;
  animation: floatCircle 20s ease-in-out infinite alternate;
}
.coverage-checker-section::before{
  width:350px;height:350px;top:-120px;left:-100px;
}
.coverage-checker-section::after{
  width:400px;height:400px;bottom:-180px;right:-80px;
  animation-duration:26s;
}
.coverage-checker-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:start;
}
.coverage-info h2{
  font-size:1.8rem;font-weight:800;color:var(--dark);margin-bottom:10px;
}
.coverage-info .kicker{
  font-size:1.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--primary);margin-bottom:8px;
}
.coverage-info p{
  font-size:.9rem;color:#6a7a98;line-height:1.6;
}
.neighborhoods-card{
  background:white;border-radius:20px;padding:24px;
  box-shadow:0 14px 40px rgba(16,63,122,.12);margin-top:24px;
}
.neighborhoods-card h3{
  font-size:1.1rem;font-weight:700;color:var(--dark);margin-bottom:16px;
}
.neighborhoods-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.neighborhood-item{
  display:flex;align-items:center;gap:8px;
  font-size:.82rem;color:var(--text);padding:8px 12px;
  background:var(--primary-soft);border-radius:10px;
  transition:var(--transition);
}
.neighborhood-item:hover{
  background:var(--primary);color:white;transform:translateY(-2px);
}
.neighborhood-item::before{
  content:"✓";font-weight:700;color:var(--primary);font-size:.9rem;
}
.neighborhood-item:hover::before{color:white;}
.coverage-form-card{
  background:white;border-radius:20px;padding:28px;
  box-shadow:0 14px 40px rgba(16,63,122,.12);
}
.coverage-form-card h3{
  font-size:1.2rem;font-weight:700;color:var(--dark);margin-bottom:6px;
}
.coverage-form-card .subtitle{
  font-size:.85rem;color:#6a7a98;margin-bottom:20px;
}
.coverage-form{display:flex;flex-direction:column;gap:14px;}
.coverage-form label{
  font-size:.8rem;font-weight:600;color:var(--dark);display:block;margin-bottom:4px;
}
.coverage-form input,
.coverage-form select{
  width:100%;padding:12px 14px;border-radius:12px;
  border:1px solid rgba(21,56,110,.15);font-size:.9rem;
  background:white;transition:var(--transition);
}
.coverage-form input:focus,
.coverage-form select:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,140,242,.1);
}
.btn-coverage{
  width:100%;padding:14px 24px;border-radius:12px;border:none;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  color:white;font-weight:700;font-size:.95rem;cursor:pointer;
  box-shadow:0 10px 30px rgba(27,140,242,.35);
  transition:var(--transition);margin-top:8px;
}
.btn-coverage:hover{
  transform:translateY(-2px);box-shadow:0 14px 40px rgba(27,140,242,.45);
}
.coverage-alert{
  display:none;align-items:center;gap:10px;
  padding:12px 16px;border-radius:12px;
  background:#ffe5e5;color:#c53030;font-size:.85rem;margin-top:12px;
}
.coverage-alert.show{display:flex;}

/* Principios regulatorios - fix */
.principles-list{
  list-style:none;margin-top:8px;
}
.principles-list li{
  font-size:.85rem;color:var(--text);padding:6px 0;
  border-bottom:1px solid rgba(21,56,110,.08);
}
.principles-list li:last-child{border-bottom:none;}
.principles-list li::before{
  content:"▹ ";color:var(--primary);font-weight:700;
}

/* Nosotros - grid ajustado */
.about-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:26px;}

/* Footer con dirección clickeable */
.footer-map{
  background:white;border-radius:12px;padding:12px;
  box-shadow:0 8px 20px rgba(13,40,80,.08);
}
.footer-map h4{
  font-size:.85rem;font-weight:700;color:var(--dark);margin-bottom:8px;
  display:flex;align-items:center;gap:6px;
}
.footer-address-link{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;color:inherit;
  padding:10px 12px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary-soft),white);
  transition:transform .3s ease,box-shadow .3s ease;
}
.footer-address-link:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 20px rgba(27,140,242,.2);
}
.footer-address-icon{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
  box-shadow:0 6px 15px rgba(27,140,242,.3);
}
.footer-address-text{
  flex:1;
}
.footer-address-text strong{
  display:block;font-size:.85rem;color:var(--dark);margin-bottom:2px;
}
.footer-address-text span{
  font-size:.75rem;color:var(--text);line-height:1.3;
}
.footer-address-arrow{
  font-size:1rem;color:var(--primary);align-self:center;
  transition:transform .3s ease;
}
.footer-address-link:hover .footer-address-arrow{
  transform:translateX(4px);
}

/* Animaciones creativas */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(30px);}
  to{opacity:1;transform:translateY(0);}
}
@keyframes fadeInLeft{
  from{opacity:0;transform:translateX(-30px);}
  to{opacity:1;transform:translateX(0);}
}
@keyframes fadeInRight{
  from{opacity:0;transform:translateX(30px);}
  to{opacity:1;transform:translateX(0);}
}
@keyframes scaleIn{
  from{opacity:0;transform:scale(0.9);}
  to{opacity:1;transform:scale(1);}
}
@keyframes pulse{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.05);}
}
@keyframes float{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-10px);}
}
@keyframes slideIn{
  from{opacity:0;transform:translateX(-20px);}
  to{opacity:1;transform:translateX(0);}
}
@keyframes rotateIn{
  from{opacity:0;transform:rotate(-10deg) scale(0.9);}
  to{opacity:1;transform:rotate(0) scale(1);}
}

.animate-fadeInUp{animation:fadeInUp .6s ease-out forwards;}
.animate-fadeInLeft{animation:fadeInLeft .6s ease-out forwards;}
.animate-fadeInRight{animation:fadeInRight .6s ease-out forwards;}
.animate-scaleIn{animation:scaleIn .5s ease-out forwards;}
.animate-pulse{animation:pulse 2s ease-in-out infinite;}
.animate-float{animation:float 3s ease-in-out infinite;}

/* Stagger delays para animaciones en grupo */
.delay-1{animation-delay:.1s;}
.delay-2{animation-delay:.2s;}
.delay-3{animation-delay:.3s;}
.delay-4{animation-delay:.4s;}
.delay-5{animation-delay:.5s;}
.delay-6{animation-delay:.6s;}

/* Hover animations */
.hover-lift{transition:transform .3s ease,box-shadow .3s ease;}
.hover-lift:hover{transform:translateY(-5px);box-shadow:0 15px 35px rgba(27,140,242,.25);}
.hover-scale{transition:transform .3s ease;}
.hover-scale:hover{transform:scale(1.03);}
.hover-glow{transition:box-shadow .3s ease;}
.hover-glow:hover{box-shadow:0 0 25px rgba(27,140,242,.4);}

/* Plan cards animation */
.plan{
  transition:transform .3s ease,box-shadow .3s ease;
}
.plan:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 50px rgba(27,140,242,.3);
}
.plan:hover .plan-speed{
  transform:scale(1.1);
  color:var(--secondary);
}
.plan-speed{transition:transform .3s ease,color .3s ease;}

/* Feature icons animation */
.why-feature-icon{
  transition:transform .3s ease,box-shadow .3s ease;
}
.why-feature:hover .why-feature-icon{
  transform:scale(1.1) rotate(5deg);
  box-shadow:0 12px 30px rgba(27,140,242,.3);
}

/* Neighborhood items animation */
.neighborhood-item{
  transition:all .3s ease;
}
.neighborhood-item:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 8px 20px rgba(27,140,242,.25);
}

/* Form focus animations */
.coverage-form input:focus,
.coverage-form select:focus{
  transform:translateY(-2px);
}

/* Button animations */
.btn-primary,.btn-coverage,.btn-pqrs{
  position:relative;overflow:hidden;
}
.btn-primary::after,.btn-coverage::after,.btn-pqrs::after{
  content:"";position:absolute;top:50%;left:50%;
  width:0;height:0;border-radius:50%;
  background:rgba(255,255,255,.3);transform:translate(-50%,-50%);
  transition:width .6s,height .6s;
}
.btn-primary:active::after,.btn-coverage:active::after,.btn-pqrs:active::after{
  width:300px;height:300px;
}

/* Card entrance animations */
.card{animation:fadeInUp .5s ease-out forwards;opacity:0;}
.card:nth-child(1){animation-delay:.1s;}
.card:nth-child(2){animation-delay:.2s;}
.card:nth-child(3){animation-delay:.3s;}

/* PQRS banner animation */
.pqrs-banner{
  animation:fadeInUp .6s ease-out;
}
#descrip_pqr{
  display: contents;
}
/* Contract box animation */
.contract-box{
  animation:fadeInUp .5s ease-out;
}

/* Nosotros vision illustration */
.vision-illustration{
  display:flex;justify-content:center;gap:20px;margin-top:24px;padding:20px;
  background:linear-gradient(135deg,var(--primary-soft),white);border-radius:16px;
}
.vision-emoji{
  font-size:2.5rem;animation:float 3s ease-in-out infinite;
}
.vision-emoji:nth-child(2){animation-delay:.5s;}
.vision-emoji:nth-child(3){animation-delay:1s;}
.vision-emoji:nth-child(4){animation-delay:1.5s;}

/* Step number animation */
.install-step-number{
  transition:transform .3s ease,background .3s ease;
}
.install-step:hover .install-step-number{
  transform:scale(1.2);
  background:rgba(255,255,255,.4);
}

/* FAQ animation improvements */
.faq-question span{
  transition:transform .3s ease;
}
.faq-answer{
  transition:max-height .4s ease,opacity .3s ease;
  opacity:0;
}
.faq-answer.active{
  opacity:1;
}

/* Logo animation */
.logo-mark{
  transition:transform .3s ease;
}
.logo:hover .logo-mark{
  transform:rotate(10deg) scale(1.1);
}

/* Nav link hover effect */
nav a{
  position:relative;
}
nav a::after{
  display: none;
}
nav a:hover::after{
  display: none;
}

/* Nuevo diseño de planes - Secciones creativas */
.plans-section{
  margin-top:40px;
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.8s ease-out;
}

.plans-section.visible {
  opacity: 1;
  transform: translateY(0);
}
.section-header{
  text-align:center;
  margin-bottom:30px;
}
.header-icon{
  font-size:3rem;
  margin-bottom:12px;
  display:inline-block;
  animation:float 3s ease-in-out infinite;
}
.combo-icon{animation-delay:0s;}
.internet-icon{animation-delay:.5s;}
.section-header h2{
  font-size:1.6rem;
  font-weight:800;
  color:var(--dark);
  margin-bottom:6px;
}
.section-header p{
  font-size:.9rem;
  color:#6a7a98;
}

/* Carrusel de planes combo */
.plans-carousel{
  display:flex;
  gap:16px;
  overflow-x:auto;
  padding:20px 10px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
}
.plans-carousel::-webkit-scrollbar{
  height:6px;
}
.plans-carousel::-webkit-scrollbar-track{
  background:var(--primary-soft);
  border-radius:3px;
}
.plans-carousel::-webkit-scrollbar-thumb{
  background:var(--primary);
  border-radius:3px;
}
.plan-card{
  flex:0 0 200px;
  background:white;
  border-radius:20px;
  padding:24px 20px;
  box-shadow:0 10px 30px rgba(13,40,80,.12);
  transition:transform .3s ease,box-shadow .3s ease;
  scroll-snap-align:start;
  position:relative;
  overflow:hidden;
}
.plan-card:hover{
  transform:translateY(-8px) scale(1.02);
  box-shadow:0 20px 45px rgba(27,140,242,.25);
}
.plan-card.popular{
  border:2px solid var(--primary);
  transform:scale(1.05);
}
.plan-card.popular:hover{
  transform:translateY(-8px) scale(1.07);
}
.popular-tag{
  position:absolute;
  top:12px;
  right:-30px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  color:white;
  font-size:.65rem;
  font-weight:700;
  padding:4px 30px;
  transform:rotate(45deg);
}
.plan-hero{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:20px;
}
.speed-badge{
  background:linear-gradient(135deg,var(--primary-soft),#e8f4ff);
  color:var(--dark);
  font-size:1.2rem;
  font-weight:800;
  padding:12px 16px;
  border-radius:12px;
}
.tv-icon{
  font-size:2.5rem;
  animation:pulse 2s ease-in-out infinite;
}
.plan-info{
  text-align:center;
}
.plan-price{
  font-size:1.8rem;
  font-weight:800;
  color:var(--primary);
  line-height:1;
}
.plan-period{
  font-size:.85rem;
  color:#6a7a98;
  margin-top:4px;
}

/* Grid de planes solo internet */
.plans-grid-internet{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
@media (max-width:900px){
  .plans-grid-internet{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:480px){
  .plans-grid-internet{grid-template-columns:1fr;}
}
.internet-card{
  background:linear-gradient(135deg,#f0f8ff,var(--bg));
  border-radius:20px;
  padding:28px 24px;
  text-align:center;
  position:relative;
  overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;
  border:2px solid transparent;
}
.internet-card:hover{
  transform:translateY(-6px);
  box-shadow:0 15px 40px rgba(27,140,242,.2);
  border-color:var(--primary);
}
.internet-card.popular-internet{
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  color:white;
}
.internet-card.popular-internet .internet-price,
.internet-card.popular-internet .internet-speed{
  color:white;
}
.popular-badge{
  position:absolute;
  top:12px;
  right:12px;
  background:rgba(255,255,255,.25);
  backdrop-filter:blur(4px);
  padding:4px 12px;
  border-radius:20px;
  font-size:.75rem;
  font-weight:700;
}
.wave-animation{
  display:flex;
  justify-content:center;
  gap:4px;
  margin-bottom:16px;
  height:30px;
  align-items:flex-end;
}
.wave-animation span{
  width:4px;
  background:var(--primary);
  border-radius:2px;
  animation:wave 1.2s ease-in-out infinite;
}
.wave-animation span:nth-child(1){height:8px;animation-delay:0s;}
.wave-animation span:nth-child(2){height:16px;animation-delay:.1s;}
.wave-animation span:nth-child(3){height:24px;animation-delay:.2s;}
@keyframes wave{
  0%,100%{transform:scaleY(1);}
  50%{transform:scaleY(1.3);}
}
.internet-card.popular-internet .wave-animation span{
  background:rgba(255,255,255,.8);
}
.internet-speed{
  font-size:1.5rem;
  font-weight:800;
  color:var(--dark);
  margin-bottom:8px;
}
.internet-price{
  font-size:1.4rem;
  font-weight:700;
  color:var(--primary);
}
.internet-price span{
  font-size:.75rem;
  font-weight:500;
  opacity:.7;
}

/* Sección de características */
.features-section{
  margin-top:50px;
  text-align:center;
}
.features-section h3{
  font-size:1.2rem;
  font-weight:700;
  color:var(--dark);
  margin-bottom:24px;
}
.features-grid{
  display:flex;
  justify-content:center;
  gap:40px;
  flex-wrap:wrap;
}
.feature-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}
.feature-icon{
  width:60px;
  height:60px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.8rem;
  box-shadow:0 10px 25px rgba(27,140,242,.3);
  transition:transform .3s ease;
}
.feature-item:hover .feature-icon{
  transform:scale(1.1) rotate(5deg);
}
.feature-item span{
  font-size:.85rem;
  font-weight:600;
  color:var(--dark);
}

/* Sección de documentos requeridos */
.documents-section{
  margin-top:40px;
  display:flex;
  justify-content:center;
}
.documents-card{
  background:linear-gradient(135deg, #f8fbff, white);
  border-radius:20px;
  padding:32px;
  box-shadow:0 10px 30px rgba(13,40,80,.08);
  border:1px solid rgba(27,140,242,.1);
  max-width:600px;
  width:100%;
}
.documents-card h3{
  font-size:1.3rem;
  font-weight:700;
  color:var(--dark);
  margin-bottom:16px;
  text-align:center;
}
.documents-card > p{
  font-size:.95rem;
  color:#6a7a98;
  margin-bottom:20px;
  text-align:center;
}
.documents-list{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-bottom:20px;
}
.document-item{
  display:flex;
  align-items:center;
  gap:16px;
  padding:16px;
  background:white;
  border-radius:12px;
  border:1px solid rgba(27,140,242,.08);
  transition:transform .3s ease,box-shadow .3s ease;
}
.document-item:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(27,140,242,.15);
  border-color:var(--primary);
}
.doc-icon{
  width:48px;
  height:48px;
  background:linear-gradient(135deg,var(--primary-soft),var(--primary));
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.5rem;
  flex-shrink:0;
  box-shadow:0 6px 15px rgba(27,140,242,.2);
}
.document-item span{
  font-size:.9rem;
  font-weight:600;
  color:var(--dark);
  line-height:1.4;
}
.documents-note{
  text-align:center;
  padding:16px;
  background:var(--primary-soft);
  border-radius:10px;
  margin:0;
}
.documents-note small{
  font-size:.75rem;
  color:#6a7a98;
  line-height:1.5;
}

/* Floating WhatsApp animation */
.whatsapp-float{
  animation:float 4s ease-in-out infinite;
}
.wa-btn{
  transition:transform .3s ease,box-shadow .3s ease;
}
.wa-btn:hover{
  transform:scale(1.1);
  box-shadow:0 18px 40px rgba(37,211,102,.4);
}
