@charset "UTF-8";

/*------------------------------ Frontpage Component classes --------------------------------------------*/

/* Contenedor principal: Grid para simetría perfecta */
.badges-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 30px;
    padding: 20px;
    justify-items: center; /* Centra las placas si el grid es ancho */
  }
  
  /* La Placa / Certificación */
  .badges-list img {
    width: 200px;  /* Mantenemos tu ancho */
    height: 112px; /* Mantenemos tu alto */
    object-fit: contain; /* Asegura que el logo no se deforme */
    padding: 15px;
    
    /* Efecto Glassmorphism */
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    
    /* Borde sutil y esquinas elegantes */
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    
    /* Sombra suave para dar profundidad */
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    
    /* Transición suave para el hover */
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    
    /* Reflejo inicial (opcional, sutil) */
    filter: brightness(0.9) grayscale(0.2);
  }
  
  /* Efecto Hover: La placa "se ilumina y se acerca" */
  .badges-list img:hover {
    transform: translateY(-8px) scale(1.03);
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 204, 0, 0.3); /* Un toque de tu Cyber Yellow */
    
    /* Iluminación */
    filter: brightness(1.1) grayscale(0);
    
    /* Sombra más proyectada */
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.5), 0 0 15px rgba(255, 204, 0, 0.1);
  }
  
  /*---------------------------------- Component classes --------------------------------------------------*/
  
  .site-header {
    background: #ffffff;
    border-bottom: 4px solid #004685;
    padding: 2rem 1rem;
    text-align: center;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  }
  
  .site-header h1 a {
    color: inherit;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 2px;
  }
  
  .container {
    max-width: 1000px;
    margin: 3rem auto;
    padding: 0 20px;
  }
  
  article {
    background: var(--background-secondary-color-alpha-50);
    padding: 0px 2.5rem;
    border-radius: 10px;
    border-left: 8px solid var(--foreground-tertiary-color);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    font-size: 1em;
    max-height: var(--max-container-height);
    overflow-x: hidden;
    overflow-y: auto;
  }
  
  article h2 a {
    color: inherit;
    text-decoration: none;
  }
  
  .topup {
      position: relative; /* CRUCIAL para que funcione el z-index */
      z-index: 1000;      /* Mayor que el del canvas */
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      height: 100vh;      /* Centra el texto en toda la pantalla */
      text-align: center;
      pointer-events: none; /* Permite que el ratón siga interactuando con el 3D si quieres */
  }
  
  .topup h1, .topup h2 {
      margin: 10px;
      font-family: sans-serif; /* O la de tu tema */
      text-shadow: 0 2px 10px rgba(0,0,0,0.5); /* Sombra para que se lea mejor sobre el 3D */
        color: white;
  }
  
  .floating-lines-container {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
  }
  
  /*------------------------------------ navbar ------------------------------------*/
  /* --- Capas de Fondo --- */
  .navbar-wrapper .nav-overlay {
    position: absolute;
    inset: 0;
    background: transparent;
    opacity: 0.80;
    pointer-events: none;
  }
  
  /* --- Contenedores Flex --- */
  .navbar-wrapper .content .navmenu,
  .navbar-wrapper .content .navmenu .nubol-menu-container,
  .navbar-wrapper .content .navmenu .nubol-menu {
    display: flex;
    flex-direction: row;
    align-items: center;
    height: 100%;
  }
  
  .navbar-wrapper .content .navmenu { font-size: 1.15rem; gap: 10px; }
  .navbar-wrapper .content .navmenu .nubol-menu-container { width: 100%; justify-content: flex-end; }
  .navbar-wrapper .content .navmenu .nubol-menu { gap: 10px; justify-content: flex-end; }
  
  /* --- Items de Menú (Padres y Sub-ítems) --- */
  /* Agrupamos estilos comunes para reducir código */
  .navbar-wrapper .nubol-menu .menu-item {
    color: var(--navbar-foreground-color);
    background-color: var(--navbar-background-color);
    cursor: pointer;
    overflow: visible;
    background-image: linear-gradient(to bottom, transparent 50%, var(--navbar-emphasis-color) 50%);
    background-size: 100% 200%;
    background-position: top;
    transition: background-position 0.5s ease-out, color 1s ease-out;
  }
  
  /* Items Nivel Superior */
  .navbar-wrapper .nubol-menu > .menu-item {
    justify-content: center;
    height: 100%;
    position: relative;
  }
  
  /* Hovers y Estados Activos (Agrupados) */
  .navbar-wrapper .nubol-menu .current-menu-item,
  .navbar-wrapper .nubol-menu .current-menu-ancestor,
  .navbar-wrapper .nubol-menu .menu-item:hover {
      background-position: bottom;
      background-color: var(--navbar-item-hover-background-color); 
      color: var(--navbar-item-hover-foreground-color); 
  }
  
  /* Enlaces (<a>) */
  .navbar-wrapper .nubol-menu .menu-item a {
    color: inherit;
    text-decoration: none;
    display: flex;
    align-items: center;
    padding: 0 15px; /* El padding ahora está en el link para que todo sea cliqueable */
    height: 100%;
    width: 100%;
  }
  
  /* --- Sub-menús --- */
  .navbar-wrapper .nubol-menu .sub-menu {
    flex-direction: column;
    margin: 0;
    padding: 10px 0;
    gap: 0;
    top: 98%;
    background-color: var(--navbar-background-color);
    z-index: 1010;
    box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
    min-width: 300px;
  }
  
  /* Lógica de despliegue */
  .navbar-wrapper .nubol-menu .menu-item-has-children:hover > .sub-menu {
    display: flex;
  }
  
  /* Ítems del sub-menú */
  .navbar-wrapper .sub-menu .menu-item {
    height: 48px;
    width: 100%;
    justify-content: flex-start;
    border-bottom: var(--navbar-background-divider-style);
  }
  
  .navbar-wrapper .sub-menu .menu-item:first-child { border-top: var(--navbar-background-divider-style); }
  
  /* --- Tipografía y Spans --- */
  .navbar-wrapper .menu-item span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  
  .navbar-wrapper .nubol-menu > .menu-item span { font-weight: 600; text-align: center; width: 100%; }
  .navbar-wrapper .sub-menu .menu-item span { font-weight: 200; text-align: left; padding-left: 5px; }
  
  .navbar-brand {
    position: relative !important;
    z-index: 9999 !important;
    cursor: pointer !important;
    display: inline-block !important;
    pointer-events: auto !important; /* Asegura que acepte eventos de mouse */
  }
  
  /*-----------------------------------------------------------------------------------------------------------------*/
  
  article,
  article .has-text-align-left  {
    text-align: justify;
  }
  
  /*----------------------- Headers ---------------------------------*/
  h1, h2, h3 {
    color: var(--foreground-tertiary-color);
  }
  
  h4, h5, h6 {
    color: var(--foreground-secondary-color);
  }
  
  /*----------------------- scrollbars ------------------------------*/
  /* --- Estilo Profesional para Scrollbars (Webkit: Chrome, Safari, Edge) --- */
  
  /* 1. Tamaño del scrollbar */
  ::-webkit-scrollbar {
    width: 8px;  /* Ancho para scroll vertical */
    height: 8px; /* Alto para scroll horizontal */
  }
  
  /* 2. El carril (Track) - Fondo del scroll */
  ::-webkit-scrollbar-track {
    background: var(--background-secondary-color);
    border-radius: 10px;
  }
  
  /* 3. La barra que se mueve (Thumb) */
  ::-webkit-scrollbar-thumb {
    background: #333; /* Un gris oscuro sutil por defecto */
    border-radius: 10px;
    border: 2px solid var(--background-secondary-color); /* Crea un efecto de separación */
    transition: background 0.3s ease;
  }
  
  /* 4. Efecto Hover - Se ilumina con el Dorado de Núbol al pasar el mouse */
  ::-webkit-scrollbar-thumb:hover {
    background: var(--foreground-tertiary-color); 
  }
  
  /* --- Soporte para Firefox --- */
  * {
    scrollbar-width: thin;
    scrollbar-color: #333 var(--background-secondary-color);
  }
  
  /* --- Estilo específico para tus artículos (el contenedor con scroll) --- */
  article::-webkit-scrollbar-thumb {
    background: rgba(252, 194, 1, 0.3); /* Dorado con transparencia para no distraer */
  }
  
  article::-webkit-scrollbar-thumb:hover {
    background: var(--foreground-tertiary-color); /* Dorado sólido al interactuar */
  }
  
  .service-card {
    background: inherit;
  }
  
  .no-scroll-y {
      overflow-y: hidden !important;
  }
  

/* ==========================================================================
A.- Ultra-Wide (2560px +)
========================================================================== */
@media screen and (min-width: 2500px) {
    /* Aquí optimizas para el espacio extra lateral */
}

/* ==========================================================================
   B.- Desktop Wide (1920px) - TU ESTÁNDAR 
   ========================================================================== */
/* No suele requerir media query si es tu base, pero el rango sería: */
@media screen and (min-width: 1800px) and (max-width: 2499px) {
    /* Ajustes específicos para el lienzo de 1920 */
}

/* ==========================================================================
   C.- Desktop Laptop (1440px / 1366px)
   ========================================================================== */
@media screen and (max-width: 1799px) {
    /* Aquí el diseño empieza a "encogerse". 
       Ajusta el .container o baja el font-size base. */
}

/* ==========================================================================
   E.- Tablet (1024px)
   ========================================================================== */
@media screen and (max-width: 1299px) {
    /* Cambio de comportamiento: menús más simples, 
       columnas de grid que pasan de 4 a 2. */
}

/* ==========================================================================
   F.- Mobile (Hasta 767px)
   ========================================================================== */
@media screen and (max-width: 767px) {
    /* Layout totalmente vertical. 
       Aquí ocultas elementos pesados de escritorio. */
}