/* *****************************************************

    ** Custom Stylesheet **

    Any custom styling you want to apply should be
    defined here.

***************************************************** */

/* Ocultar controles de plantilla no usados */
.btn-settings,
.btn-demos,
#offcanvasRight { display: none !important; }

/* Ocultar overlay de filtro/menú que aparece superpuesto */
.cd-filter,
.cd-filter-block,
.cd-filter-content,
.cd-filter-trigger,
.cd-main-content .cd-filter,
.modal,
.modal-dialog,
.modal-content,
.modal-backdrop,
.overlay:not(.top-header),
.popup-gallery { 
  display: none !important; 
  visibility: hidden !important; 
  opacity: 0 !important; 
  z-index: -9999 !important; 
}

/* Mantener solo el overlay de top-header para páginas que lo necesiten */
.top-header.overlay {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: auto !important;
}

/* Logo uniforme */
.logo-menu, .logo-footer { height: 50px; width: auto; }

/* ===== Planes estilo Flynet (píldoras) ===== */
.flynet-plans { row-gap: 30px; }
.flynet-plan {
  position: relative;
  border-radius: 40px;
  padding: 28px 26px 18px;
  text-align: center;
  color: #fff;
  box-shadow: 0 10px 25px rgba(0,0,0,.18);
  min-height: 100%;
}
.flynet-plan .plan-name {
  font-weight: 800;
  font-size: 28px;
  letter-spacing: .5px;
  margin-bottom: 8px;
}
.flynet-plan .plan-speed {
  font-weight: 800;
  font-size: 68px;
  line-height: 1;
  margin: 6px 0 0;
}
.flynet-plan .plan-unit {
  display: block;
  margin-top: 6px;
  font-size: 28px;
  font-weight: 700;
}
.flynet-plan ul.features {
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  text-align: left;
  background: transparent !important;
}
.flynet-plan ul.features li { 
  margin: 8px 0; 
  font-weight: 600; 
  background: transparent !important;
}
.flynet-plan ul.features li i { color: #3ad46a; margin-right: 8px; }
.flynet-plan .price-label { margin-top: 12px; font-weight: 700; }
.flynet-plan .price {
  font-size: 38px;
  font-weight: 900;
}
.flynet-plan .period { font-size: 14px; font-weight: 700; margin-left: 4px; }
.flynet-plan .cta { margin-top: 16px; }

/* Variantes de color (aprox) */
.plan-rose { background: linear-gradient(180deg,#ff64c9,#ff3db6); }
.plan-ultrainstinto { background: linear-gradient(180deg,#8bb8ff,#5c79ff); }
.plan-premium { background: linear-gradient(180deg,#f7d67a,#e6b44f); color:#4a3200; }
.plan-ultimate { background: linear-gradient(180deg,#2f1638,#4a2460); }
.plan-blue { background: linear-gradient(180deg,#3aa2ff,#1f7be8); }

/* Inalámbrico */
.plan-wireless { background: linear-gradient(180deg,#2ea8ff,#1077ff); }
.plan-wireless-tv { background: linear-gradient(180deg,#2ea8ff,#1077ff); }

/* Ajustes responsive */
@media (max-width: 575.98px){
  .flynet-plan { border-radius: 32px; padding: 22px 20px; }
  .flynet-plan .plan-speed { font-size: 56px; }
}

/* Ajustes de contraste y tipografía para Ultimate */
.plan-ultimate, .plan-ultimate * { color: #C1DADF; }
.plan-ultimate .price { color: #C1DADF; }
.plan-ultimate .features i { color: #00A8CC; }

/* Fondo de sección Beneficios con paleta Flynet */
#beneficios { background: linear-gradient(180deg, #27496D, #142850); }
#beneficios .section-heading, #beneficios .section-subheading, #beneficios .service-section {
  color: #C1DADF;
}
#beneficios .service-section { background: rgba(193,218,223,0.08); border-radius: 16px; }
#beneficios .service-section .title { color: #C1DADF; }
#beneficios .service-section .subtitle { color: #C1DADF; opacity: .9; }

/* Elevate App promo */
.elevate-section { 
  background: linear-gradient(180deg, #00A8CC, #0C7B93);
  border-radius: 18px; 
  padding: 30px; 
  color: #fff;
  margin-top: 30px;
}
.elevate-section .title { font-size: 30px; font-weight: 900; margin-bottom: 6px; }
.elevate-section .subtitle { font-size: 22px; font-weight: 800; color: #C1DADF; margin-bottom: 18px; }
.elevate-brand { font-family: 'Poppins', 'Open Sans', sans-serif; font-size: 28px; font-weight: 800; color: #fff; }
.elevate-chips { display: flex; flex-wrap: wrap; gap: 10px; margin: 14px 0 8px; }
.elevate-chip { background: #C1DADF; color: #142850; border-radius: 12px; padding: 8px 12px; font-weight: 700; }
.store-badges { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 10px; }
.btn-store { background: #142850; color: #C1DADF; border-radius: 12px; padding: 8px 12px; display: inline-flex; align-items: center; gap: 8px; font-weight: 700; }
.btn-store:hover { color: #fff; filter: brightness(1.1); }
@media (max-width: 575.98px){
  .elevate-section { padding: 22px; }
  .elevate-section .title { font-size: 24px; }
}

/* Imagen ilustrativa de Elevate */
.illustration-wrap { display:flex; align-items:center; justify-content:center; }
.elevate-illustration { max-width: 520px; width: 100%; border-radius: 16px; box-shadow: 0 10px 30px rgba(0,0,0,.25); }

/* Fix para cards de beneficios en Internet Dedicado */
/* Estilos específicos para opacidad solo */
#beneficios .slick #slider .plan-container .wrapper {
  opacity: 1 !important;
}

/* Forzar que todas las slides tengan la misma opacidad */
#beneficios .slick-slide {
  opacity: 1 !important;
}

#beneficios .slick-active {
  opacity: 1 !important;
}

/* Estilos removidos - causaban problemas en Internet Residencial */

/* Uniformidad de altura SOLO para Internet Dedicado */
.internet-dedicado-page #beneficios .slick #slider .plan-container .wrapper {
  height: 650px !important;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

.internet-dedicado-page #beneficios .slick #slider .plan-container .wrapper .top-content {
  height: 300px !important;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 30px 40px 25px 40px;
  box-sizing: border-box;
  overflow: visible;
}

.internet-dedicado-page #beneficios .slick #slider .plan-container .wrapper .list-info {
  height: 350px !important;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  padding: 25px 40px 30px 40px;
  box-sizing: border-box;
  margin: 0;
}

/* Ajustes de títulos y botones SOLO para Internet Dedicado */
.internet-dedicado-page #beneficios .slick #slider .plan-container .wrapper .top-content .title {
  font-size: 22px;
  line-height: 1.3;
  min-height: 60px;
  display: flex;
  align-items: center;
  margin-bottom: 8px;
}

.internet-dedicado-page #beneficios .slick #slider .plan-container .wrapper .top-content .fromer {
  font-size: 14px;
  margin-bottom: 12px;
}

.internet-dedicado-page #beneficios .slick #slider .plan-container .wrapper .top-content .price {
  font-size: 16px;
  margin-bottom: 15px;
}

/* Asegurar que los botones tengan espacio suficiente SOLO en Internet Dedicado */
.internet-dedicado-page #beneficios .slick #slider .plan-container .wrapper .top-content .btn {
  margin-top: auto;
  margin-bottom: 10px;
}

/* Fondo optimizado para Internet Residencial - imagen nítida sin overlay */
.top-header.overlay {
  background: url('../img/flynet/internet_residencial.jpg') center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.top-header.overlay .heading {
  color: #fff;
  text-shadow: 
    0 4px 8px rgba(0,0,0,0.9), 
    0 2px 4px rgba(0,0,0,0.8),
    0 1px 2px rgba(0,0,0,0.9);
  font-weight: 700;
}

.top-header.overlay .subheading {
  color: #fff;
  text-shadow: 
    0 3px 6px rgba(0,0,0,0.8), 
    0 2px 4px rgba(0,0,0,0.7),
    0 1px 2px rgba(0,0,0,0.8);
  font-weight: 400;
}

/* Fondos SVG para secciones de Internet Dedicado - máximo ancho a la derecha */
.carousel-cell.sec-bg6.bg-colorstyle:nth-child(1) {
  background-color: #050606 !important; /* Fondo gris oscuro */
  background-image: url('../patterns/network.svg');
  background-size: auto 75%;
  background-repeat: no-repeat;
  background-position: 70% center;
  /* Filtros para cambiar colores rosados a azules */
  filter: hue-rotate(200deg) saturate(0.8) brightness(1.1);
  /* Espacio extra para animaciones */
  overflow: hidden;
}

.carousel-cell.sec-bg6.bg-colorstyle:nth-child(2) {
  background-color: #111115 !important; /* Fondo gris oscuro */
  background-image: url('../patterns/maxsecurity.svg');
  background-size: auto 55%;
  background-repeat: no-repeat;
  background-position: 85% center;
  /* Filtros para cambiar colores rosados a azules */
  filter: hue-rotate(200deg) saturate(0.8) brightness(1.1);
  /* Espacio extra para animaciones */
  overflow: hidden;
}

/* SVG de Provisioning original con filtros azules */
.provisioning-illustration {
  width: 100%;
  max-width: 400px;
  padding: 10px 20px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  height: auto;
  min-height: 250px;
  padding-top: 20px;
  margin-top: 0;
}

/* Asegurar que la columna padre tenga altura completa */
.col-md-4.d-flex {
  min-height: 400px;
}

.provisioning-svg {
  width: 100%;
  height: auto;
  max-width: 320px;
  transition: transform 0.3s ease;
  /* Filtro para cambiar colores rosados a azules */
  filter: hue-rotate(200deg) saturate(0.9) brightness(1.0) drop-shadow(0 2px 4px rgba(37, 99, 235, 0.15));
}

/* Aplicar color azul al SVG con las nuevas clases */
img[src*="provisioning.svg"] {
  filter: hue-rotate(200deg) saturate(0.9) brightness(1.0) drop-shadow(0 2px 4px rgba(37, 99, 235, 0.15));
  transition: transform 0.3s ease;
}

img[src*="provisioning.svg"]:hover {
  transform: scale(1.02);
}

.provisioning-svg:hover {
  transform: scale(1.02);
}

/* Estilos para la sección de Cualidades */
.features {
  padding: 80px 0;
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
}

.features h2 {
  font-size: 3rem;
  font-weight: 700;
  margin-bottom: 2rem;
  letter-spacing: 2px;
}

.features h3 {
  font-size: 2.2rem;
  font-weight: 600;
  margin-bottom: 2rem;
  letter-spacing: 1px;
}

.features h5 {
  font-weight: 600;
  line-height: 1.3;
}

.features h6 {
  font-weight: 500;
  font-size: 0.9rem;
  line-height: 1.4;
  margin-top: 0.5rem;
}

.features .row.mb-4:hover {
  background: rgba(255, 255, 255, 0.3);
  border-radius: 10px;
  padding: 15px;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.features i {
  transition: all 0.3s ease;
}

.features .row.mb-4:hover i {
  transform: scale(1.1);
  filter: drop-shadow(0 2px 8px rgba(37, 99, 235, 0.3));
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .features h2 {
    font-size: 2.2rem;
  }
  
  .features h3 {
    font-size: 1.8rem;
  }
  
  .features .col-2 {
    flex: 0 0 20%;
    max-width: 20%;
  }
  
  .features .col-10 {
    flex: 0 0 80%;
    max-width: 80%;
  }
}

/* Estilos para centrar la sección de Empresas que requieren estabilidad */
.casestudy .sec-main {
  text-align: center;
}

.casestudy .author {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
}

.casestudy .content-info {
  max-width: 800px;
  margin: 0 auto;
}

.casestudy .content-info p {
  font-size: 1.1rem;
  line-height: 1.6;
  margin-bottom: 2rem;
}

.casestudy .row.mt-4.mb-4 {
  text-align: left;
  max-width: 900px;
  margin: 2rem auto 2rem auto;
}

.casestudy .btn {
  margin: 0.5rem;
  padding: 12px 30px;
  font-weight: 600;
}

/* Responsive adjustments */
@media (max-width: 992px) {
  .casestudy .author {
    font-size: 2rem;
  }
  
  .casestudy .content-info p {
    font-size: 1rem;
  }
}



@media (max-width: 768px) {
  .provisioning-illustration {
    max-width: 300px;
    padding: 10px;
  }
  
  .provisioning-svg {
    max-width: 280px;
  }
}

/* Uniformidad en los elementos de lista */
#beneficios .slick #slider .plan-container .wrapper .list-info li {
  margin-bottom: 15px;
  display: flex;
  align-items: flex-start;
  min-height: 60px;
}

#beneficios .slick #slider .plan-container .wrapper .list-info li i {
  font-size: 32px !important;
  margin-right: 15px;
  margin-top: 5px;
  flex-shrink: 0;
}

#beneficios .slick #slider .plan-container .wrapper .list-info li div {
  flex: 1;
  line-height: 1.4;
}

/* Forzar alturas específicas para cada card - basado en la más alta */
.video-vigilancia-page #beneficios .plan-container:nth-child(1) .wrapper,
.video-vigilancia-page #beneficios .plan-container:nth-child(2) .wrapper,
.video-vigilancia-page #beneficios .plan-container:nth-child(3) .wrapper,
.video-vigilancia-page #beneficios .plan-container:nth-child(4) .wrapper,
.video-vigilancia-page #beneficios .plan-container:nth-child(5) .wrapper,
.video-vigilancia-page #beneficios .plan-container:nth-child(6) .wrapper {
  height: 650px !important;
  max-height: 650px !important;
  min-height: 650px !important;
}

.video-vigilancia-page #beneficios .plan-container:nth-child(1) .wrapper .top-content,
.video-vigilancia-page #beneficios .plan-container:nth-child(2) .wrapper .top-content,
.video-vigilancia-page #beneficios .plan-container:nth-child(3) .wrapper .top-content,
.video-vigilancia-page #beneficios .plan-container:nth-child(4) .wrapper .top-content,
.video-vigilancia-page #beneficios .plan-container:nth-child(5) .wrapper .top-content,
.video-vigilancia-page #beneficios .plan-container:nth-child(6) .wrapper .top-content {
  height: 300px !important;
  max-height: 300px !important;
  min-height: 300px !important;
  overflow: visible;
}

.video-vigilancia-page #beneficios .plan-container:nth-child(1) .wrapper .list-info,
.video-vigilancia-page #beneficios .plan-container:nth-child(2) .wrapper .list-info,
.video-vigilancia-page #beneficios .plan-container:nth-child(3) .wrapper .list-info,
.video-vigilancia-page #beneficios .plan-container:nth-child(4) .wrapper .list-info,
.video-vigilancia-page #beneficios .plan-container:nth-child(5) .wrapper .list-info,
.video-vigilancia-page #beneficios .plan-container:nth-child(6) .wrapper .list-info {
  height: 350px !important;
  max-height: 350px !important;
  min-height: 350px !important;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  #beneficios .slick #slider .plan-container .wrapper {
    height: auto !important;
    min-height: auto !important;
  }
  
  #beneficios .slick #slider .plan-container .wrapper .top-content {
    height: auto !important;
    min-height: auto !important;
    padding: 25px 30px 20px 30px;
  }
  
  #beneficios .slick #slider .plan-container .wrapper .list-info {
    height: auto !important;
    min-height: auto !important;
    padding: 20px 30px 25px 30px;
  }
}

/* ========== VIDEOVIGILANCIA STYLES ========== */

/* Fondos SVG para secciones hero de Video Vigilancia */
.video-vigilancia-page .video-vigilancia-hero,
.carousel-cell.video-vigilancia-hero {
  background-color: #050606 !important;
  background-image: url('/antler/assets/patterns/ciudad_vigilancia.svg?v=azul') !important;
  background-size: auto 65% !important;
  background-repeat: no-repeat !important;
  background-position: 70% center !important;
  /* SIN filtros - colores definidos directamente en el SVG */
  overflow: hidden !important;
}

/* Asegurar que no se use background de otras clases */
.video-vigilancia-page .carousel-cell.sec-bg6.bg-colorstyle.video-vigilancia-hero {
  background-color: #050606 !important;
  background-image: url('/antler/assets/patterns/ciudad_vigilancia.svg?v=azul') !important;
}

.video-vigilancia-monitoring {
  background-color: #111115 !important;
  background-image: url('/antler/assets/patterns/monitoring.svg?v=azul2024');
  background-size: auto 55%;
  background-repeat: no-repeat;
  background-position: 75% center;
  /* SIN filtros - para mantener colores originales */
  overflow: hidden;
}

/* Estilos específicos para cards de videovigilancia */
.video-vigilancia-page #beneficios .slick #slider .plan-container .wrapper {
  height: 650px !important;
  background: #fff !important;
  opacity: 1 !important;
  box-sizing: border-box;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.video-vigilancia-page #beneficios .slick #slider .plan-container .wrapper:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.15);
}

/* Iconos especiales para videovigilancia */
.video-vigilancia-page .icon-cctv::before {
  content: "\f03d";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-thermal::before {
  content: "\f2cb";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-rotation::before {
  content: "\f2f1";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-eye::before {
  content: "\f06e";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-hide::before {
  content: "\f070";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-door::before {
  content: "\f52a";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-store::before {
  content: "\f54e";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-factory::before {
  content: "\f275";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-building::before {
  content: "\f1ad";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-hospital::before {
  content: "\f0f8";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-school::before {
  content: "\f549";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-home::before {
  content: "\f015";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-automation::before {
  content: "\f085";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-warranty::before {
  content: "\f0e7";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.video-vigilancia-page .icon-upgrade::before {
  content: "\f093";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

/* Mejoras visuales para la sección de tecnología */
.video-vigilancia-page #tecnologia {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
}

.video-vigilancia-page #tecnologia .row.mb-4:hover {
  background: rgba(255,255,255,0.7);
  border-radius: 8px;
  padding: 15px;
  transition: all 0.3s ease;
}

.video-vigilancia-page #tecnologia .mergecolor {
  transition: color 0.3s ease;
}

.video-vigilancia-page #tecnologia .row.mb-4:hover .mergecolor {
  color: #007bff !important;
}

/* Estilos para la sección Flynet Security */
.flynet-security {
  background: linear-gradient(135deg, #1a202c 0%, #2d3748 100%);
  padding: 80px 0;
}

/* Título principal más visible */
.flynet-security h2.mergecolor {
  color: #63b3ed !important;
  font-weight: bold;
  text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
  font-size: 2.5rem;
}

.flynet-security h3 {
  color: #ffffff !important;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

/* Estilos para las cards de seguridad - más claras */
.security-card {
  background: rgba(255,255,255,0.25);
  border-radius: 16px;
  padding: 25px;
  height: 100%;
  transition: all 0.3s ease;
  border: 1px solid rgba(99, 179, 237, 0.4);
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.2);
}

.security-card:hover {
  background: rgba(255,255,255,0.35);
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(99, 179, 237, 0.3);
  border-color: rgba(99, 179, 237, 0.6);
}

/* Placeholder para imágenes - más claro */
.card-image-placeholder {
  background: rgba(255,255,255,0.15);
  border-radius: 12px;
  padding: 30px;
  text-align: center;
  margin-bottom: 20px;
  min-height: 150px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 2px dashed rgba(99, 179, 237, 0.5);
  transition: all 0.3s ease;
}

.security-card:hover .card-image-placeholder {
  background: rgba(255,255,255,0.25);
  border-color: rgba(99, 179, 237, 0.7);
}

.placeholder-text {
  color: #63b3ed;
  font-size: 11px;
  margin-top: 10px;
  font-style: italic;
  opacity: 0.8;
}

/* Contenido de las cards */
.card-content h4 {
  font-size: 1.2rem;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #1a202c !important;
  text-shadow: none;
}

.card-content p {
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 0;
  color: #2d3748 !important;
  font-weight: 500;
}

/* Iconos de las cards */
.security-card i {
  transition: all 0.3s ease;
}

.security-card:hover i {
  transform: scale(1.1);
  color: #63b3ed !important;
}

/* ========== BENEFIT CARDS GRID STYLES ========== */

.benefits-grid .benefit-card {
  background: #ffffff;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
  transition: all 0.3s ease;
  height: 100%;
  overflow: hidden;
}

.benefits-grid .benefit-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 35px rgba(0,0,0,0.15);
}

/* Card Header */
.benefit-card .card-header {
  background: #f8f9fa;
  padding: 20px;
  text-align: center;
  border-bottom: 1px solid #e9ecef;
}

.benefit-card h4 {
  color: #2d3748;
  font-size: 1.1rem;
  font-weight: bold;
  margin: 10px 0 5px 0;
}

.benefit-card .subtitle {
  color: #718096;
  font-size: 0.9rem;
  font-style: italic;
  margin-bottom: 10px;
}

.benefit-card .highlight {
  color: #3182ce;
  font-weight: bold;
  font-size: 0.9rem;
  margin-bottom: 15px;
}

/* Badges */
.badge-support {
  background: #2d3748;
  color: white;
  padding: 4px 12px;
  border-radius: 15px;
  font-size: 0.75rem;
  font-weight: bold;
  text-transform: uppercase;
}

.badge-prevention {
  background: #3182ce;
  color: white;
  padding: 4px 12px;
  border-radius: 15px;
  font-size: 0.75rem;
  font-weight: bold;
  text-transform: uppercase;
}

.badge-storage {
  background: #38a169;
  color: white;
  padding: 4px 12px;
  border-radius: 15px;
  font-size: 0.75rem;
  font-weight: bold;
  text-transform: uppercase;
}

.badge-access {
  background: #d69e2e;
  color: white;
  padding: 4px 12px;
  border-radius: 15px;
  font-size: 0.75rem;
  font-weight: bold;
  text-transform: uppercase;
}

/* Card Body */
.benefit-card .card-body {
  background: #3182ce;
  color: white;
  padding: 20px;
}

.benefit-card .feature-item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 15px;
  padding: 8px 0;
}

.benefit-card .feature-item:last-child {
  margin-bottom: 0;
}

.benefit-card .feature-item i {
  font-size: 1.2rem;
  margin-right: 12px;
  margin-top: 2px;
  color: #63b3ed;
  min-width: 20px;
}

.benefit-card .feature-item div {
  flex: 1;
}

.benefit-card .feature-item strong {
  font-size: 0.8rem;
  font-weight: bold;
  display: block;
  line-height: 1.2;
}

.benefit-card .feature-item span {
  font-size: 0.75rem;
  opacity: 0.9;
  line-height: 1.2;
}

/* Responsive adjustments para videovigilancia */
@media (max-width: 768px) {
  .video-vigilancia-hero,
  .video-vigilancia-monitoring {
    background-size: auto 40%;
    background-position: center right;
  }
  
  .video-vigilancia-page #beneficios .slick #slider .plan-container .wrapper {
    height: auto !important;
    min-height: 500px;
  }
  
  .video-vigilancia-page #tecnologia .row.mb-4 {
    margin-bottom: 2rem !important;
  }
  
  .flynet-security {
    padding: 60px 0;
  }
  
  .flynet-security .row {
    text-align: center;
  }
  
  .security-card {
    margin-bottom: 30px;
    height: auto;
  }
  
  .card-image-placeholder {
    min-height: 120px;
    padding: 20px;
  }
  
  .card-content h4 {
    font-size: 1.1rem;
  }
  
  .card-content p {
    font-size: 13px;
  }
  
  /* Benefit cards responsive */
  .benefits-grid .benefit-card {
    margin-bottom: 20px;
  }
  
  .benefit-card .card-header {
    padding: 15px;
  }
  
  .benefit-card .card-body {
    padding: 15px;
  }
  
  .benefit-card h4 {
    font-size: 1rem;
  }
  
  .benefit-card .feature-item {
    margin-bottom: 12px;
    padding: 6px 0;
  }
  
  .benefit-card .feature-item i {
    font-size: 1rem;
    margin-right: 10px;
  }
  
  .benefit-card .feature-item strong {
    font-size: 0.75rem;
  }
  
  .benefit-card .feature-item span {
    font-size: 0.7rem;
  }
}

/* ========== MAPA DE RED GLOBAL ========== */
.global-network {
  padding: 80px 0;
  background: linear-gradient(135deg, #0f2027 0%, #203a43 50%, #2c5364 100%);
  position: relative;
  overflow: hidden;
}

.global-network .section-heading {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.global-network .section-subheading {
  color: rgba(255, 255, 255, 0.9) !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.global-network::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at 30% 20%, rgba(23, 162, 184, 0.1) 0%, transparent 50%),
              radial-gradient(circle at 70% 80%, rgba(23, 162, 184, 0.08) 0%, transparent 50%);
  pointer-events: none;
}

.network-map-container {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  background: rgba(0, 0, 0, 0.1);
  border-radius: 20px;
  padding: 40px 20px;
  backdrop-filter: blur(10px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.base-map {
  position: relative;
  width: 100%;
  opacity: 0.4;
}

.base-network-svg {
  width: 100%;
  height: auto;
  max-height: 500px;
  border-radius: 12px;
  filter: grayscale(100%) brightness(0.7);
}

.active-points-overlay {
  position: absolute;
  top: 40px;
  left: 20px;
  right: 20px;
  bottom: 40px;
  width: calc(100% - 40px);
  height: auto;
  max-height: 500px;
  pointer-events: none;
}

.active-points-overlay .active-nodes {
  pointer-events: all;
}

/* Animación de puntos activos */
.active-nodes .node {
  cursor: pointer;
  transition: all 0.3s ease;
}

.active-nodes .node:hover {
  transform: scale(1.1);
}

/* Tooltips */
.network-tooltip {
  position: absolute;
  background: linear-gradient(135deg, #17a2b8 0%, #20c997 100%);
  color: white;
  padding: 12px 16px;
  border-radius: 8px;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
  pointer-events: none;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s ease;
  z-index: 1000;
  max-width: 280px;
  backdrop-filter: blur(10px);
}

.network-tooltip.show {
  opacity: 1;
  transform: translateY(0);
}

.network-tooltip::after {
  content: '';
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: #17a2b8;
}

.tooltip-header {
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 4px;
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.tooltip-content {
  font-size: 13px;
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.95);
}

/* Posicionamiento específico de tooltips */
#miami-tooltip {
  top: 140px;
  left: 280px;
}

#san-salvador-tooltip {
  top: 280px;
  left: 180px;
}

#san-miguel-tooltip {
  top: 300px;
  left: 320px;
}

/* Efectos adicionales para las líneas de conexión */
.active-nodes line {
  filter: drop-shadow(0 0 3px rgba(23, 162, 184, 0.6));
}

/* Responsive para mapa */
@media (max-width: 768px) {
  .global-network {
    padding: 60px 0;
  }
  
  .network-map-container {
    padding: 20px 15px;
  }
  
  .network-tooltip {
    font-size: 12px;
    padding: 8px 12px;
    max-width: 200px;
  }
  
  .tooltip-header {
    font-size: 14px;
  }
  
  .tooltip-content {
    font-size: 11px;
  }
}

/* ========== REMOVER SOMBRAS DEL MENÚ (MANTENER ESTRUCTURA ORIGINAL) ========== */
/* Quitar solo las sombras específicas sin afectar la funcionalidad del megamenú */

/* Quitar sombras de submenús normales (dropdowns) */
.menu-wrap .main-menu .sub-menu:not(.megamenu):not(.megamenu-list):not(.menu-large) {
  box-shadow: none !important;
}

/* Quitar sombras del menú fijo pero conservar funcionalidad */
.menu-wrap.fixed {
  box-shadow: none !important;
}

/* Quitar sombras específicas por tema - solo las necesarias */
[data-background="light"] .menu-wrap .main-menu .sub-menu:not(.megamenu):not(.megamenu-list):not(.menu-large) {
  box-shadow: none !important;
}

[data-background="dark"] .menu-wrap .main-menu .sub-menu:not(.megamenu):not(.megamenu-list):not(.menu-large) {
  box-shadow: none !important;
}

[data-background="dark"] .menu-wrap.fixed {
  box-shadow: none !important;
}

/* Solo quitar sombras de start-offer pero mantener estructura */
.start-offer {
  box-shadow: none !important;
}

[data-background="dark"] .start-offer {
  box-shadow: none !important;
}

/* ========== PÁGINA GPS ========== */

/* Mejora de contraste con paleta Flynet - SOLO para contenido de GPS */
/* Selectores muy específicos que no afecten el menú */

/* Contenido principal de GPS */
body.gps-page main .text-light,
body.gps-page .main-container .text-light,
body.gps-page section .text-light {
  color: #FFFFFF !important;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
}

body.gps-page main .text-muted,
body.gps-page .main-container .text-muted,
body.gps-page section .text-muted {
  color: #E8F4F6 !important;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.7);
}

/* Títulos y encabezados específicos de GPS */
body.gps-page main h1, body.gps-page main h2, body.gps-page main h3,
body.gps-page .main-container h1, body.gps-page .main-container h2, body.gps-page .main-container h3,
body.gps-page section h1, body.gps-page section h2, body.gps-page section h3 {
  color: #FFFFFF !important;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.9);
  font-weight: 600;
}

body.gps-page main h4, body.gps-page main h5, body.gps-page main h6,
body.gps-page .main-container h4, body.gps-page .main-container h5, body.gps-page .main-container h6,
body.gps-page section h4, body.gps-page section h5, body.gps-page section h6 {
  color: #00D4FF !important;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.8);
  font-weight: 600;
}

/* Párrafos específicos de GPS */
body.gps-page main p,
body.gps-page .main-container p,
body.gps-page section p {
  color: #E8F4F6 !important;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
  line-height: 1.6;
}

/* Texto destacado y enlaces */
body.gps-page main .mergecolor,
body.gps-page .main-container .mergecolor,
body.gps-page section .mergecolor {
  color: #00D4FF !important;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
}

/* Subtítulos y texto descriptivo */
body.gps-page main .lead,
body.gps-page .main-container .lead,
body.gps-page section .lead {
  color: #FFFFFF !important;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.9);
  font-weight: 500;
}

/* Listas y elementos específicos */
body.gps-page main ul li,
body.gps-page .main-container ul li,
body.gps-page section ul li,
body.gps-page main ol li,
body.gps-page .main-container ol li,
body.gps-page section ol li {
  color: #E8F4F6 !important;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
}

/* Texto de subtítulos de sección */
body.gps-page main .section-subheading,
body.gps-page .main-container .section-subheading,
body.gps-page section .section-subheading {
  color: #FFFFFF !important;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.8);
}

/* Mejorar otros elementos de texto que puedan estar oscuros */
body.gps-page main span:not(.badge),
body.gps-page .main-container span:not(.badge),
body.gps-page section span:not(.badge) {
  color: #E8F4F6 !important;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.6);
}

/* Elementos con clase específica de características */
body.gps-page .feature-list li,
body.gps-page .benefit-section p,
body.gps-page .use-case-item p,
body.gps-page .faq-item p {
  color: #E8F4F6 !important;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
}

/* Step Numbers */
.step-number {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #142850, #27496D);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #00A8CC;
  font-size: 1.5rem;
  font-weight: bold;
  margin: 0 auto 1rem;
  box-shadow: 0 5px 15px rgba(20, 40, 80, 0.4);
  border: 2px solid #00A8CC;
}

/* Illustrations */
.gps-illustration,
.platform-illustration,
.infrastructure-illustration,
.devices-illustration {
  padding: 2rem;
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.6), rgba(39, 73, 109, 0.6));
  border-radius: 15px;
  margin-bottom: 1rem;
  border: 2px solid #0C7B93;
}

.illustration-caption {
  margin-top: 1rem;
  padding: 0.5rem;
  background: rgba(25, 25, 25, 0.8);
  border-radius: 8px;
  color: #C1DADF !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.8);
}

/* Feature Blocks */
.feature-block {
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.4), rgba(39, 73, 109, 0.4));
  border-radius: 12px;
  padding: 1.5rem;
  transition: all 0.3s ease;
  border: 1px solid #0C7B93;
  height: 100%;
}

.feature-block:hover {
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.7), rgba(39, 73, 109, 0.7));
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(0, 168, 204, 0.3);
  border-color: #00A8CC;
}

.feature-block h5 {
  color: #00A8CC !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.8);
}

.feature-block p {
  color: #C1DADF !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.7);
}

/* Feature Lists */
.feature-list .feature-item,
.infrastructure-features .infra-item {
  display: flex;
  align-items: center;
  padding: 0.75rem;
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.3), rgba(39, 73, 109, 0.3));
  border-radius: 8px;
  transition: all 0.3s ease;
  margin-bottom: 0.5rem;
  border-left: 3px solid #0C7B93;
}

.feature-list .feature-item:hover,
.infrastructure-features .infra-item:hover {
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.6), rgba(39, 73, 109, 0.6));
  transform: translateX(5px);
  border-left-color: #00A8CC;
}

.feature-list .feature-item span,
.infrastructure-features .infra-item span {
  color: #C1DADF !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.8);
}

/* Benefit Sections */
.benefit-section {
  padding: 2rem 1rem;
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.4), rgba(39, 73, 109, 0.4));
  border-radius: 15px;
  transition: all 0.3s ease;
  border: 2px solid #0C7B93;
  height: 100%;
}

.benefit-section:hover {
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.7), rgba(39, 73, 109, 0.7));
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 168, 204, 0.3);
  border-color: #00A8CC;
}

.benefit-section h4 {
  color: #00A8CC !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.8);
}

.benefit-section p {
  color: #C1DADF !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.7);
}

/* Use Case Items */
.use-case-item {
  padding: 1.5rem;
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.4), rgba(39, 73, 109, 0.4));
  border-radius: 12px;
  border-left: 4px solid #0C7B93;
  transition: all 0.3s ease;
}

.use-case-item:hover {
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.7), rgba(39, 73, 109, 0.7));
  border-left-color: #00A8CC;
  transform: translateX(5px);
}

.use-case-item h5 {
  color: #00A8CC !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.8);
}

.use-case-item p {
  color: #C1DADF !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.7);
}

/* Device Brands */
.device-brands .brand-item {
  padding: 0.5rem 0;
  border-bottom: 1px solid #0C7B93;
  transition: all 0.3s ease;
  color: #C1DADF !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.7);
}

.device-brands .brand-item:hover {
  padding-left: 1rem;
  color: #00A8CC !important;
}

.device-brands .brand-item:last-child {
  border-bottom: none;
}

/* FAQ Items */
.faq-item {
  padding: 1.5rem;
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.4), rgba(39, 73, 109, 0.4));
  border-radius: 12px;
  border: 1px solid #0C7B93;
  transition: all 0.3s ease;
}

.faq-item:hover {
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.7), rgba(39, 73, 109, 0.7));
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(0, 168, 204, 0.3);
  border-color: #00A8CC;
}

.faq-item h5 {
  color: #00A8CC !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.8);
}

.faq-item p {
  color: #C1DADF !important;
  text-shadow: 1px 1px 2px rgba(25, 25, 25, 0.7);
}

/* CTA Buttons */
.cta-buttons .btn {
  padding: 12px 30px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.contact-info {
  border-top: 1px solid #0C7B93;
  padding-top: 1rem;
}



/* Mejoras específicas para las secciones con paleta Flynet */
.gps-page .sec-bg1, .nexus-page .sec-bg1 {
  background: linear-gradient(135deg, rgba(20, 40, 80, 0.95), rgba(39, 73, 109, 0.95)) !important;
}

.gps-page .sec-bg2, .nexus-page .sec-bg2 {
  background: linear-gradient(135deg, rgba(39, 73, 109, 0.95), rgba(12, 123, 147, 0.95)) !important;
}

/* Iconos con mejor visibilidad */
.gps-page i[class^="icon-"], .nexus-page i[class^="icon-"] {
  color: #00A8CC !important;
  text-shadow: 2px 2px 4px rgba(25, 25, 25, 0.8);
}

/* Lead text mejor contraste */
.gps-page .lead, .nexus-page .lead {
  color: #C1DADF !important;
  text-shadow: 2px 2px 4px rgba(25, 25, 25, 0.9);
  font-weight: 500;
}

/* Estilos para las tarjetas de funcionalidades de Nexus */
.nexus-feature-card {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 15px;
  padding: 30px 20px;
  margin-bottom: 20px;
  transition: all 0.3s ease;
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.nexus-feature-card:hover {
  transform: translateY(-5px);
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(0, 168, 204, 0.5);
  box-shadow: 0 10px 30px rgba(0, 168, 204, 0.2);
}

.nexus-feature-card .feature-icon {
  background: rgba(0, 168, 204, 0.2);
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  transition: all 0.3s ease;
}

.nexus-feature-card:hover .feature-icon {
  background: rgba(0, 168, 204, 0.3);
  transform: scale(1.1);
}

.nexus-feature-card h4 {
  font-weight: 600;
  margin-bottom: 15px;
}

.nexus-feature-card p {
  font-size: 0.95rem;
  line-height: 1.6;
  color: #C1DADF !important;
}

/* Estilos para la sección de plataforma unificada */
.unified-benefits .benefit-item {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 10px;
  padding: 15px;
  margin-bottom: 15px;
  transition: all 0.3s ease;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.unified-benefits .benefit-item:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(0, 168, 204, 0.3);
}

/* Responsive Nexus */
@media (max-width: 768px) {
  .nexus-feature-card {
    padding: 25px 15px;
    margin-bottom: 15px;
  }
  
  .nexus-feature-card .feature-icon {
    width: 60px;
    height: 60px;
    margin-bottom: 15px;
  }
  
  .nexus-feature-card h4 {
    font-size: 1.1rem;
  }
  
  .nexus-feature-card p {
    font-size: 0.9rem;
  }
  
  .unified-benefits .benefit-item {
    padding: 12px;
  }
}

/* Responsive GPS */
@media (max-width: 768px) {
  .step-number {
    width: 50px;
    height: 50px;
    font-size: 1.2rem;
  }
  
  .gps-illustration,
  .platform-illustration,
  .infrastructure-illustration,
  .devices-illustration {
    padding: 1rem;
  }
  
  .gps-illustration i,
  .platform-illustration i,
  .infrastructure-illustration i,
  .devices-illustration i {
    font-size: 4rem !important;
  }
  
  .benefit-section {
    padding: 1.5rem 1rem;
    margin-bottom: 1rem;
  }
  
  .feature-block {
    padding: 1rem;
    margin-bottom: 1rem;
  }
  
  .cta-buttons .btn {
    display: block;
    width: 100%;
    margin-bottom: 1rem;
  }
}

/* ========== PLANES HOGAR - TRIPLE PLAY ========== */
.planes-hogar {
  padding: 80px 0;
}

.triple-play-card {
  background: linear-gradient(135deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.5) 100%);
  backdrop-filter: blur(15px);
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
  overflow: hidden;
}

.card-header-triple {
  padding: 40px;
  background: linear-gradient(135deg, #17a2b8 0%, #20c997 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.card-header-triple h3 {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  font-weight: bold;
}

.card-header-triple p {
  color: #ffffff !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
  opacity: 0.95;
}

.card-body-triple {
  padding: 40px;
}

.unique-badge {
  display: inline-flex;
  align-items: center;
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: white;
  padding: 8px 16px;
  border-radius: 25px;
  font-size: 0.85rem;
  font-weight: bold;
  text-transform: uppercase;
  box-shadow: 0 4px 15px rgba(245, 158, 11, 0.3);
}

.price-container {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border-radius: 15px;
  padding: 20px;
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.price-container .currency {
  font-size: 1.5rem;
  color: #ffffff;
  vertical-align: top;
}

.price-container .price {
  font-size: 3rem;
  font-weight: bold;
  color: #ffffff;
  line-height: 1;
}

.price-container .period {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.8);
}

.price-includes {
  margin-top: 10px;
  padding: 8px 12px;
  background: linear-gradient(135deg, #f59e0b, #d97706);
  border-radius: 20px;
  color: white;
  font-size: 0.85rem;
  font-weight: bold;
  display: inline-flex;
  align-items: center;
  box-shadow: 0 4px 15px rgba(245, 158, 11, 0.3);
}

.price-includes i {
  color: #ffffff;
  font-size: 0.9rem;
}

.price-note {
  margin-top: 8px;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.8rem;
  font-style: italic;
}

/* Service Items */
.service-item {
  background: rgba(0, 0, 0, 0.4);
  border-radius: 15px;
  padding: 25px;
  text-align: center;
  transition: all 0.3s ease;
  border: 2px solid transparent;
  height: 100%;
}

.service-item.active {
  border-color: #17a2b8;
  background: rgba(23, 162, 184, 0.3);
  transform: translateY(-5px);
  box-shadow: 0 10px 25px rgba(23, 162, 184, 0.2);
}

.service-item:hover {
  transform: translateY(-3px);
  background: rgba(0, 0, 0, 0.6);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.service-icon {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, #17a2b8, #20c997);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  box-shadow: 0 8px 20px rgba(23, 162, 184, 0.3);
}

.service-icon i {
  font-size: 2.5rem;
  color: white;
}

.service-item h5 {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  font-weight: bold;
}

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

.service-features li {
  padding: 5px 0;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.9rem;
  display: flex;
  align-items: center;
}

.service-features li i {
  color: #20c997;
  margin-right: 10px;
  font-size: 0.8rem;
}

/* Differential Section */
.differential-section {
  background: rgba(0, 0, 0, 0.3);
  border-radius: 15px;
  padding: 30px;
  margin-top: 30px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.differential-section h4 {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  font-weight: bold;
}

.differential-section p {
  color: #ffffff !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.savings-badge {
  background: linear-gradient(135deg, #20c997, #17a2b8);
  border-radius: 20px;
  padding: 25px;
  color: white;
  text-align: center;
  box-shadow: 0 10px 25px rgba(32, 201, 151, 0.3);
}

.savings-text {
  font-size: 0.8rem;
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 5px;
  opacity: 0.9;
}

.savings-amount {
  font-size: 3rem;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 5px;
}

.savings-desc {
  font-size: 0.75rem;
  opacity: 0.8;
}

/* Responsive Planes Hogar */
@media (max-width: 768px) {
  .planes-hogar {
    padding: 60px 0;
  }
  
  .card-header-triple,
  .card-body-triple {
    padding: 25px;
  }
  
  .service-item {
    margin-bottom: 20px;
  }
  
  .price-container .price {
    font-size: 2.5rem;
  }
  
  .savings-amount {
    font-size: 2.5rem;
  }
  
  .differential-section {
    padding: 20px;
  }
  
  .price-includes {
    font-size: 0.75rem;
    padding: 6px 10px;
  }
  
  .price-note {
    font-size: 0.7rem;
  }
}

/* ===== Estilos específicos para Nexus - Paleta Flynet ===== */

/* Variables de colores Flynet */
:root {
  --flynet-dark: #1a1a1a;
  --flynet-navy: #1e3a8a;
  --flynet-blue: #2563eb;
  --flynet-medium: #3b82f6;
  --flynet-bright: #60a5fa;
  --flynet-teal: #0891b2;
  --flynet-cyan: #06b6d4;
  --flynet-light: #38bdf8;
  --flynet-lighter: #7dd3fc;
  --flynet-pale: #bae6fd;
  --flynet-very-light: #e0f2fe;
}

/* Hero Section */
.nexus-page .nexus-hero {
  background: linear-gradient(135deg, var(--flynet-dark), var(--flynet-navy));
  position: relative;
  overflow: hidden;
}

.nexus-page .nexus-hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: 
    radial-gradient(circle at 20% 80%, rgba(56, 189, 248, 0.15) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(6, 182, 212, 0.12) 0%, transparent 50%),
    linear-gradient(45deg, transparent 30%, rgba(6, 182, 212, 0.08) 50%, transparent 70%);
  z-index: 1;
}

.nexus-hero-image {
  position: relative;
  z-index: 10;
}

/* Sección Desafíos */
.desafios-comunes {
  background: linear-gradient(135deg, var(--flynet-navy), var(--flynet-blue)) !important;
}

.challenge-item {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(8, 145, 178, 0.1));
  backdrop-filter: blur(10px);
  border: 1px solid rgba(56, 189, 248, 0.2);
  padding: 30px;
  border-radius: 20px;
  height: 100%;
  transition: all 0.4s ease;
  position: relative;
  overflow: hidden;
}

.challenge-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(56, 189, 248, 0.1), transparent);
  transition: left 0.6s ease;
}

.challenge-item:hover::before {
  left: 100%;
}

.challenge-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(6, 182, 212, 0.3);
  border-color: var(--flynet-cyan);
}

.challenge-icon i {
  color: var(--flynet-light);
  filter: drop-shadow(0 4px 8px rgba(56, 189, 248, 0.3));
}

/* Sección Gestión Eficiente */
.gestion-eficiente {
  background: linear-gradient(135deg, var(--flynet-blue), var(--flynet-medium)) !important;
}

.functionality-item {
  display: flex;
  align-items: flex-start;
  padding: 20px;
  border-radius: 15px;
  transition: all 0.3s ease;
  border-left: 3px solid transparent;
}

.functionality-item:hover {
  background: linear-gradient(135deg, rgba(56, 189, 248, 0.1), rgba(186, 230, 253, 0.1));
  border-left-color: var(--flynet-light);
  transform: translateX(8px);
}

.functionality-item i {
  font-size: 1.8rem;
  margin-top: 5px;
  color: var(--flynet-light);
}

/* Sección Control de Acceso */
.control-acceso {
  background: linear-gradient(135deg, var(--flynet-medium), var(--flynet-bright)) !important;
}

.integration-features .feature-item {
  transition: all 0.3s ease;
  padding: 15px;
  border-radius: 12px;
}

.integration-features .feature-item:hover {
  background: linear-gradient(135deg, rgba(56, 189, 248, 0.1), rgba(96, 165, 250, 0.1));
  transform: translateX(12px);
}

.integration-features .feature-item i {
  color: var(--flynet-light);
}

/* Sección Automatización */
.automatizacion {
  background: linear-gradient(135deg, var(--flynet-bright), var(--flynet-teal)) !important;
}

.automation-benefits .benefit-item {
  background: linear-gradient(135deg, rgba(8, 145, 178, 0.1), rgba(6, 182, 212, 0.1));
  border: 1px solid rgba(56, 189, 248, 0.3);
  padding: 30px;
  border-radius: 18px;
  border-left: 5px solid var(--flynet-light);
  transition: all 0.3s ease;
}

.automation-benefits .benefit-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 30px rgba(6, 182, 212, 0.2);
  border-left-color: var(--flynet-cyan);
}

/* Sección Casos de Uso */
.casos-uso {
  background: linear-gradient(135deg, var(--flynet-teal), var(--flynet-cyan)) !important;
}

.use-case-card {
  background: linear-gradient(135deg, rgba(56, 189, 248, 0.15), rgba(186, 230, 253, 0.1));
  backdrop-filter: blur(8px);
  border: 1px solid rgba(186, 230, 253, 0.3);
  padding: 35px;
  border-radius: 20px;
  height: 100%;
  text-align: center;
  transition: all 0.4s ease;
  position: relative;
  overflow: hidden;
}

.use-case-card::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: conic-gradient(from 0deg, transparent, rgba(186, 230, 253, 0.1), transparent);
  animation: rotate 10s linear infinite;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.use-case-card:hover::after {
  opacity: 1;
}

.use-case-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 25px 50px rgba(56, 189, 248, 0.25);
  border-color: var(--flynet-pale);
}

.use-case-icon i {
  color: var(--flynet-very-light);
  filter: drop-shadow(0 4px 8px rgba(186, 230, 253, 0.4));
}

@keyframes rotate {
  to { transform: rotate(360deg); }
}

/* Sección Integraciones */
.integraciones {
  background: linear-gradient(135deg, var(--flynet-cyan), var(--flynet-light)) !important;
}

.integration-item {
  background: linear-gradient(135deg, rgba(186, 230, 253, 0.1), rgba(224, 242, 254, 0.1));
  border: 1px solid rgba(186, 230, 253, 0.4);
  padding: 30px;
  border-radius: 16px;
  height: 100%;
  transition: all 0.3s ease;
}

.integration-item:hover {
  background: linear-gradient(135deg, rgba(186, 230, 253, 0.2), rgba(224, 242, 254, 0.15));
  transform: translateY(-5px);
  box-shadow: 0 20px 40px rgba(186, 230, 253, 0.2);
}

.integration-item h4 i {
  color: var(--flynet-very-light);
}

/* Sección FAQ */
.faq {
  background: linear-gradient(135deg, var(--flynet-light), var(--flynet-lighter)) !important;
}

.faq-item {
  background: linear-gradient(135deg, rgba(224, 242, 254, 0.1), rgba(255, 255, 255, 0.05));
  border: 1px solid rgba(224, 242, 254, 0.3);
  padding: 30px;
  border-radius: 16px;
  height: 100%;
  border-left: 4px solid var(--flynet-very-light);
  transition: all 0.3s ease;
}

.faq-item:hover {
  border-left-color: var(--flynet-pale);
  transform: translateX(5px);
  box-shadow: 0 10px 25px rgba(224, 242, 254, 0.2);
}

/* CTA Final */
.cta-final {
  background: linear-gradient(135deg, var(--flynet-dark), var(--flynet-navy), var(--flynet-blue)) !important;
  position: relative;
  overflow: hidden;
}

.cta-final::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at 30% 80%, rgba(56, 189, 248, 0.15) 0%, transparent 50%),
              radial-gradient(circle at 80% 20%, rgba(186, 230, 253, 0.1) 0%, transparent 50%);
  z-index: 1;
}

.cta-final .container {
  position: relative;
  z-index: 2;
}

/* Responsive para Nexus - Paleta Flynet */
@media (max-width: 768px) {
  .challenge-item,
  .use-case-card,
  .integration-item,
  .faq-item {
    margin-bottom: 25px;
    padding: 25px;
  }
  
  .functionality-item {
    padding: 15px;
    margin-bottom: 10px;
  }
  
  .automation-benefits .benefit-item {
    padding: 25px;
    margin-bottom: 20px;
  }
  
  .challenge-icon i,
  .use-case-icon i {
    font-size: 2.5rem;
  }
  
  /* Ajustes para efectos en móvil */
  .challenge-item:hover,
  .use-case-card:hover {
    transform: translateY(-5px);
  }
  
  .functionality-item:hover,
  .integration-features .feature-item:hover {
    transform: translateX(5px);
  }
}

/* Efectos adicionales para mejorar la experiencia */


/* Botones con paleta Flynet */
.nexus-page .btn-default-yellow-fill {
  background: linear-gradient(135deg, var(--flynet-light), var(--flynet-cyan));
  border: none;
  color: var(--flynet-dark);
  font-weight: 600;
  box-shadow: 0 8px 20px rgba(56, 189, 248, 0.3);
  transition: all 0.3s ease;
}

.nexus-page .btn-default-yellow-fill:hover {
  background: linear-gradient(135deg, var(--flynet-cyan), var(--flynet-light));
  transform: translateY(-2px);
  box-shadow: 0 12px 25px rgba(56, 189, 248, 0.4);
}

.nexus-page .btn-default-pink-fill {
  background: linear-gradient(135deg, var(--flynet-teal), var(--flynet-cyan));
  border: none;
  color: white;
  font-weight: 600;
  box-shadow: 0 8px 20px rgba(8, 145, 178, 0.3);
}

.nexus-page .btn-default-pink-fill:hover {
  background: linear-gradient(135deg, var(--flynet-cyan), var(--flynet-teal));
  transform: translateY(-2px);
  box-shadow: 0 12px 25px rgba(8, 145, 178, 0.4);
}

.nexus-page .btn-outline-primary {
  border: 2px solid var(--flynet-light);
  color: var(--flynet-light);
  background: transparent;
  font-weight: 600;
  transition: all 0.3s ease;
}

.nexus-page .btn-outline-primary:hover {
  background: var(--flynet-light);
  color: var(--flynet-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(56, 189, 248, 0.3);
}