    * {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

html, body {
      font-family: 'Roboto', sans-serif;
      background-color: #f4f6f8;
      color: #333;
      width: 100%;
      max-width: 100%;
      overflow-x: hidden !important; /* Corta cualquier cosa que intente salirse por la derecha */
      margin: 0;
      padding: 0;
      position: relative;
    }

    /* ===== MENU HAMBURGUESA ===== */

    .menu-toggle {
      display: none;
      font-size: 28px;
      color: white;
      cursor: pointer;
    }

    /* Mobile */
    @media (max-width: 768px) {
      .menu-toggle {
        display: block;
      }

      .nav-menu {
        display: none;
        flex-direction: column;
        width: 100%;
        background-color: #0B1522;
        margin-top: 10px;
      }

      .nav-menu a {
        padding: 12px;
        border-top: 1px solid #1f2d40;
        margin: 0;
        text-align: center;
      }

      .nav-menu.active {
        display: flex;
      }
      
      .nav-download {
        margin: 10px 20px !important; /* Separación en el menú hamburguesa */
      }
    }


    /* HEADER */
    header {
      background-color: #0B1522;
      padding: 20px 40px;
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    header h1 {
      color: #73DF73;
      font-size: 28px;
    }

    nav a {
      color: white;
      text-decoration: none;
      margin-left: 25px;
      font-size: 16px;
    }

    nav a:hover {
      color: #73DF73;
    }
    
    /* Estilo para el botón de descarga en el Nav */
.nav-download {
  background-color: #73DF73; /* Verde para que llame la atención */
  /*color: #0B1522 !important;  Texto oscuro para contraste */
  color: #ffffff !important;
  padding: 8px 15px !important;
  border-radius: 5px;
  font-weight: bold;
  transition: all 0.3s ease;
  border: 2px solid #73DF73;    /* Borde verde para mantener la estructura */
}

.nav-download:hover {
  background-color: #ffffff;
  color: #73DF73 !important;      /* ¡Las letras cambian a verde! */
  transform: scale(1.05);
  box-shadow: 0 4px 10px rgba(0,0,0,0.1); /* Sombra suave para que resalte */
}

    /* HERO */
    .hero {
      background: linear-gradient(rgba(11, 21, 34, .8), rgba(11, 21, 34, .8)), url('https://images.unsplash.com/photo-1586773860418-d37222d8fce3') center/cover no-repeat;
      height: 90vh;
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      padding: 40px 20px; /* Más espacio interno */
      /*padding: 20px;*/
    }

    .hero h2 {
      color: white;
      font-size: 42px;
      margin-bottom: 15px;
    }

    .hero p {
      color: #ddd;
      font-size: 18px;
      margin-bottom: 30px;
    }
    
    /*----  Banner  ----*/
    .banner-app {
    max-width: 1200px;
    margin: 40px auto; /* Lo centra y le da espacio arriba/abajo */
    }
    
    /* BOTONES TURNOS */
    .acciones {
      display: flex;
      gap: 20px;
      justify-content: center;
      flex-wrap: wrap;
    }

    .acciones a {
      text-decoration: none;
      padding: 14px 26px;
      border-radius: 8px;
      font-size: 16px;
      font-weight: 600;
      color: white;
      transition: transform 0.2s ease, opacity 0.2s ease;
    }

    .btn-turno {
      background-color: #28a745;
    }

    .btn-consultar {
      background-color: #0d6efd;
    }

    .btn-cancelar {
      background-color: #dc3545;
    }

    .acciones a:hover {
      text-decoration: none;

      transform: translateY(-3px);
      opacity: 0.9;
    }



    /* nu*/
    /* .acciones {
      display: flex;
      gap: 20px;
      justify-content: center;
      flex-wrap: wrap;
    }

    .btn {
      padding: 15px 30px;
      font-size: 16px;
      border: none;
      border-radius: 8px;
      cursor: pointer;
      transition: transform .2s, box-shadow .2s;
      min-width: 220px;
    }

    .btn:hover {
      transform: translateY(-5px);
      box-shadow: 0 8px 20px rgba(0, 0, 0, .2);
    }

    .btn-turno {
      background-color: #4ada1f;
      color: #fff;
    }

    .btn-consultar {
      background-color: #0dcaf0;
      color: #fff;
    }

    .btn-cancelar {
      background-color: #dc3545;
      color: #fff;
    } */

    /* INFO */
    .info {
      padding: 60px 20px;
      text-align: center;
      background-color: #fff;
    }

    .info h3 {
      font-size: 32px;
      margin-bottom: 20px;
      color: #008b8b;
    }

    .info p {
      max-width: 700px;
      margin: auto;
      font-size: 18px;
      line-height: 1.6;
    }

    /*Acordeon Especialidades*/

    #especialidades h2 {
      /* margin-top: 5%; */
      text-align: center;
      font-family: "Roboto" sans-serif;
      font-weight: 700;
      /* Bold */
      color: #008b8b;
      font-size: 40px;

    }

    .accordion {

      /* max-width: 350px;/*ancho del acordeón*/
      max-width: 600px;
      /*ancho del acordeón*/
      margin: auto;
      margin-top: 50px;
      margin-bottom: 50px;
    }

    .accordion-item {
      margin-bottom: 10px;
    }

    /* Estilos para el acordeón y botones */
    .accordion-button {
      color: #ffffff !important;
      /* Color de texto predeterminado */
      background-color: #4ada1f !important;
      /* Color de fondo predeterminado, importante para priorizar sobre Bootstrap */
      /* border: 1px solid #dee2e6; */
      font-size: 25px;
      border-radius: 5px;
      padding: 10px 20px;
      transition: background-color 0.3s ease, color 0.3s ease;
      /* Transición suave para cambios */
    }


    .accordion-body {
      background-color: #0B1522;
      /*Color de fondo del cuerpo del acordeón*/
      /* background-color: rgba(0, 255, 34, 0.67); */
      /*color: rgb(0, 0, 0); /* Color del texto del cuerpo del acordeón */
      color: white;
      font-size: 18px;
    }

    /********* CONTACTOS/UBICACIÓN ********/
    #contactos .contenedor {
      padding: 100px 0px;
      background-color: rgba(30, 30, 30);
      color: white;
      text-align: center;
    }

    #contactos h2 {
      text-align: center;
      font-family: "Roboto" sans-serif;
      font-weight: 700;
      /* Bold */
      color: #008b8b;
      font-size: 40px;
    }

    #contactos .icono {
      font-size: 2em;
      margin-bottom: 10px;
      color: #73DF73;
    }

    #contactos p {
      color: white;
      font-size: 20px;
    }

    #contactos .row {
      display: flex;
      justify-content: center;
      align-items: center;
      flex-wrap: wrap;
    }

    #contactos .col {
      flex-basis: 45%;
      margin: 20px;
      text-align: center;
    }

    #contactos iframe {
      width: 90%;
      max-width: 800px;
      height: 450px;
      border: 0;
      margin: 20px auto;
    }

    .row {
     margin-right: 0 !important;
     margin-left: 0 !important;
     width: 100%; /* Forzamos a que no se pase del padre */
    }
    
    /* Forzamos a que todas las imágenes y iframes respeten el ancho */
    img, iframe {
     max-width: 100%;
    }


    /* FOOTER */
    footer {
      background-color: #0B1522;
      color: #aaa;
      text-align: center;
      padding: 15px;
      font-size: 14px;
    }

    /* RESPONSIVE */
    @media (max-width: 768px) {
      header {
        flex-direction: column;
        gap: 10px;
      }

      .hero h2 {
        font-size: 32px;
      }

      .acciones {
        flex-direction: column;
        align-items: stretch;
      }

      .acciones a {
        text-align: center;
        width: 100%;
      }
    }
    
/* Botón y Panel - Menú Accesibilidad */
/* Esto hace que el panel aparezca cuando el padre tiene la clase acc-open */
#accessibility-menu.acc-open .acc-content { 
    display: block !important; 
}

#accessibility-menu { 
    position: fixed; 
    bottom: 90px; 
    /*right: 20px; */
    left: 20px; /* Lo movemos a la izquierda para que no choque con el chat */
    z-index: 1000; 
    font-family: sans-serif; 
    
}

/* El contenido que se esconde/muestra */
#accessibility-menu .acc-content {
    display: none; /* Oculto por defecto */
    background: white;
    padding: 15px;
    border-radius: 8px;
    border: 1px solid #ccc;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
    width: 220px;
    margin-bottom: 10px;
}
    
.acc-toggle { 
    /*background: #0056b3; */
    /*color: white; */
    /*border: none; */
    /*padding: 15px; */
    /*border-radius: 50%; */
    /*cursor: pointer; */
    /*font-size: 20px; */
    /*box-shadow: 0 4px 6px rgba(0,0,0,0.1); */
    background: #0056b3;
    color: white;
    border: none;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 24px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
    transition: all 0.3s ease; /* Transición suave */
    
}

/* EFECTO HOVER del botón principal */
.acc-toggle:hover {
    background-color: #003d80; /* Azul más oscuro */
    transform: scale(1.1); /* Se agranda un poquito */
    box-shadow: 0 6px 15px rgba(0,0,0,0.4);
}

.acc-content { 
    display: none; 
    background: white; 
    border: 1px solid #ccc; 
    padding: 15px; 
    border-radius: 8px; 
    margin-bottom: 10px; 
    box-shadow: 0 4px 10px rgba(0,0,0,0.2); 
    width: 200px; 
    
}
.acc-content h5 { 
    margin: 0 0 10px 0; 
    font-size: 16px; 
    border-bottom: 1px solid #eee; 
    padding-bottom: 5px; 
    
}
.acc-content button { 
    width: 100%; 
    margin-bottom: 5px; 
    padding: 8px; 
    cursor: pointer; 
    border: 1px solid #0056b3; 
    background: white; 
    color: #0056b3; 
    border-radius: 4px; 
    font-weight: 500;
    /*transition: 0.3s; */
    transition: all 0.2s ease; /* Transición para el hover */
    
}
.acc-content button:hover { 
    background: #0056b3; 
    color: white; 
    transform: translateX(5px); /* Se desplaza un poquito a la derecha */
    box-shadow: 2px 2px 8px rgba(0,0,0,0.1);
}


 Clase de Alto Contraste 
.high-contrast { 
    background-color: #000 !important; 
    color: #ffff00 !important; 
    
}
.high-contrast * { 
    background-color: #000 !important; 
    color: #ffff00 !important; 
    border-color: #ffff00 !important; 
    
}

 Animación de apertura 
.acc-open .acc-content { 
    display: block; 
    
}

/* --- MODO OSCURO PROFESIONAL --- */
body.dark-mode {
    background-color: #050a0f !important;
    color: #e0e0e0 !important;
}

/* Ajustamos el header y footer */
body.dark-mode header, 
body.dark-mode footer,
body.dark-mode .info,
body.dark-mode .accordion-item {
    background-color: #0b1522 !important;
    color: #ffffff !important;
    border-color: #1f2d40 !important;
}

/* Ajustamos las tarjetas y secciones blancas */
body.dark-mode section {
    background-color: #050a0f !important;
}

/* El texto de los acordeones y párrafos */
body.dark-mode .accordion-body,
body.dark-mode p,
body.dark-mode h3 {
    color: #cccccc !important;
}

/* Los botones del acordeón que eran verdes, los hacemos un verde más oscuro para que no encandilen */
body.dark-mode .accordion-button {
    background-color: #1a6314 !important;
    color: #ffffff !important;
}

/* Ajuste de enlaces en modo oscuro */
body.dark-mode nav a:hover {
    color: #73DF73;
}

/* AJUSTAMOS EL PUNTERO */
/*body.large-cursor {*/
/*    cursor: url('https://cur.cursors-4u.net/games/gam-4/gam372.cur'), auto !important;*/
/*}*/
/* O simplemente aumentar el tamaño del puntero estándar en navegadores que lo permitan */
/*body.large-cursor * {*/
/*    cursor: crosshair !important;  Cambia la forma para que sea más visible */
/*    cursor: url('https://cur.cursors-4u.net/arrow/arr-2/arr113.cur'), auto !important;*/

/*}*/

/* Flecha clásica pero en tamaño 64x64 (el doble de lo normal) */
/* Flecha clásica gigante en formato SVG (más compatible) */
body.large-cursor, 
body.large-cursor * {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 24 24'%3E%3Cpath fill='white' stroke='black' stroke-width='1' d='M5.5 2v15.27l4.5-4.47 2.32 5.59 2.1-.87-2.32-5.56h5.4L5.5 2z'/%3E%3C/svg%3E"), auto !important;
}

/* Guía de lectura: una barra sutil que sigue al mouse */
/*#reading-guide {*/
/*    display: none;*/
/*    position: fixed;*/
/*    width: 100%;*/
/*    height: 12px;*/
/*    background: rgba(115, 223, 115, 0.4);  Verde sutil como tu marca 
/*    z-index: 9998;*/
/*    pointer-events: none; /* Para que no interfiera con los clics */
/*    border-top: 2px solid #73DF73;*/
/*    border-bottom: 2px solid #73DF73;*/
/*}*/

/* Clase para resaltar enlaces */
/*.underline-links a {*/
/*    text-decoration: underline !important;*/
/*    font-weight: bold !important;*/
/*}*/

/* ASISTENTE VIRTUAL */
/* Contenedor principal */
#asistente-container {
    position: fixed;
    bottom: 20px; /* Un poco más arriba que el de accesibilidad */
    right: 20px;
    z-index: 999;
    font-family: 'Roboto', sans-serif;
}

/* Botón de abrir/cerrar */
.chat-toggle {
    /*background: #2e8b57;*/
    /*color: white;*/
    /*border: none;*/
    /*padding: 12px 20px;*/
    /*border-radius: 30px;*/
    /*cursor: pointer;*/
    /*font-weight: bold;*/
    /*box-shadow: 0 4px 15px rgba(0,0,0,0.2);*/
    /*transition: 0.3s;*/
    
    /*position: fixed;*/
    /*bottom: 20px;*/
    /*right: 20px;*/
    /*z-index: 2000;*/
    /*padding: 10px 20px;*/
    /*border-radius: 25px;*/
    /*background-color: #28a745;*/
    /*color: white;*/
    /*border: none;*/
    /*cursor: pointer;*/
    
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 3000;
    padding: 12px 20px;
    background-color: #28a745;
    color: white;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    font-weight: bold;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}

.chat-toggle:hover { transform: scale(1.05); background: #28a745; }

/* Ventana de Chat */
#chat-window {
    /*width: 300px;*/
    /*background: white;*/
    /*border-radius: 15px;*/
    /*overflow: hidden;*/
    /*box-shadow: 0 5px 25px rgba(0,0,0,0.3);*/
    /*margin-bottom: 15px;*/
    /*display: none; Se activa con JS */
    display: none; /* Empieza oculto */
    position: fixed;
    height: 450px; /* Dale un alto fijo razonable */
    bottom: 90px;
    right: 20px;
    width: 320px;
    max-height: 400px;
    background: white;
    border-radius: 10px;
    box-shadow: 0 5px 25px rgba(0,0,0,0.2);
    z-index: 3000;
    overflow: hidden;
    flex-direction: column;
}

#chat-content {
    flex-grow: 1; /* Hace que el cuerpo use todo el espacio disponible */
    overflow-y: auto; /* ¡ESTA ES LA CLAVE! Crea el scroll si el texto es largo */
    padding: 15px;
    max-height: 350px; /* Limita el área del texto */
    background-color: #ffffff;
}

.chat-header {
    background: #0B1522;
    color: #73DF73;
    padding: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: bold;
}

.chat-header button {
    background: none;
    border: none;
    color: white;
    font-size: 20px;
    cursor: pointer;
}

.chat-body { padding: 15px; font-size: 14px; max-height: 400px; overflow-y: auto; }

/* Botones de opciones dentro del chat */
.chat-options { 
    display: flex; 
    flex-direction: column; 
    gap: 8px; 
    margin-top: 10px; 
    
}

.chat-options button {
    background: #f8f9fa;
    border: 1px solid #28a745;
    color: #28a745;
    padding: 8px;
    border-radius: 5px;
    cursor: pointer;
    text-align: left;
    transition: 0.3s;
}

.chat-options button:hover { 
    background: #28a745; 
    /*border-color: #2e8b57; */
    color: white;
    
}

/* Adaptación a Modo Oscuro (Opcional) */
body.dark-mode #chat-window { background: #1f2d40; color: white; }
body.dark-mode .chat-options button { background: #0B1522; color: white; border-color: #444; }