/**/

body {
    font-family: "Segoe UI", sans-serif;
    font-size: 24px; /* Ajusta el tamaño según el ancho de la ventana */
    width: 100%; /* Se ajusta al ancho completo de la pantalla */
    margin: 0; /* Elimina márgenes que podrían alterar la visualización */
    padding: 0; /* Asegura que no haya espacio interno inesperado */
    padding-top: 5px; /* Evita que el contenido se solape con el nav fijo */
}


input[type="number"] {width: 50px;}

#imagen-fondo {
    width: 100%; /* Ancho dinámico (antes 1310px) */
    height: auto; /* Mantiene las proporciones (antes height: 100%;) */ 
    object-fit: cover; /*Escala la imagen proporcionalmente para cubrir toda la pantalla */
    position: fixed; /* Mantiene la imagen fija como fondo */
    top: 0;
    left: 0;
    padding-top: 30px; /* Evita que el contenido se solape con el nav fijo */
    z-index: -1; /* Asegura que la imagen esté detrás del contenido */
}

.texto-mascara {
    text-align: center; /* Centra el texto dentro del área del contenido */
    z-index: 300; /* Asegura que la imagen esté detrás del contenido */
    font-size: 2em; /* Tamaño del texto */
    font-weight: bold; /* Grosor de las letras */
    color: black; /* Color principal del texto */
    line-height: 1.2; /* Reduce el interlineado (valor ajustable) */
    text-shadow: 
        4px 4px 10px white,  /* Sombra blanca en la esquina inferior derecha */
        -4px -4px 10px white, /* Sombra blanca en la esquina superior izquierda */
        4px -4px 10px white,  /* Sombra blanca en la esquina superior derecha */
        -4px 4px 10px white;  /* Sombra blanca en la esquina inferior izquierda */
}

#nombre {
    font-style: italic; /* Asegura que el texto esté en cursiva */
    font-size: 1em; /* Tamaño del texto del nombre */
    text-align: center;
    margin: 0;
    text-shadow: 
        4px 4px 10px white,  /* Sombra blanca en la esquina inferior derecha */
        -4px -4px 10px white, /* Sombra blanca en la esquina superior izquierda */
        4px -4px 10px white,  /* Sombra blanca en la esquina superior derecha */
        -4px 4px 10px white;  /* Sombra blanca en la esquina inferior izquierda */
}

#email {
    font-style: italic; /* Asegura que el texto esté en cursiva */
    font-size: 0.8em; /* Tamaño del texto del correo */
    text-align: center;
    margin: 5px 0;
    text-shadow: 
        4px 4px 10px white,  /* Sombra blanca en la esquina inferior derecha */
        -4px -4px 10px white, /* Sombra blanca en la esquina superior izquierda */
        4px -4px 10px white,  /* Sombra blanca en la esquina superior derecha */
        -4px 4px 10px white;  /* Sombra blanca en la esquina inferior izquierda */
}

.botoninicio {
    background-color: #808080; /* Color de fondo gris */
    color: white; /* Texto blanco */
    padding: 10px 20px; /* Espaciado interno */
    border: 2px solid #696969; /* Borde gris oscuro */
    border-radius: 5px; /* Bordes redondeados */
    font-size: 0.8em; /* Tamaño del texto */
    text-decoration:  underline; /* Aplica un subrayado al texto */
    cursor: pointer; /* Cambia el cursor al pasar */
    box-shadow: 
        4px 4px 10px rgba(0, 0, 0, 0.5), /* Sombra externa */
        inset 2px 2px 5px rgba(255, 255, 255, 0.5); /* Sombra interna */
}

.botoninicio:hover {
    background-color: #A9A9A9; /* Cambiar el color de fondo al pasar el mouse */
    border: 2px solid #505050; /* Borde más oscuro al pasar el mouse */
}

.botoninicio a {
    color: white; /* Cambia el color del texto dentro del enlace a blanco */
}


.nav-container {
      position: fixed; /* Fija el div en la parte superior */
      top: 0;
      left: 0;
      width: 1310px; 
      font-size:20px ;
      background-color: #e0e0e0; /* Fondo opcional */
      box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); /* Sombra opcional */
      z-index: 1000; /* Asegura que esté sobre otros elementos */
    }

/* Permite hover como siempre en nav-container */
.nav-container .submenu:hover .submenu-items {
    display: block; /* Mantener comportamiento original */
}

    nav {
      display: flex;
      justify-content: space-between; /* Coloca elementos a los extremos */
      align-items: center;
      padding: 1.5px; /* Ajusta este valor para reducir la altura */
    }

        .menu-izquierda, .menu-derecha {
            display: flex;
        }

    nav a {
      text-decoration: none;
      color: #222;
      line-height: 1.2; /* Reduce la altura del texto */
      padding: 2px 8px; /* Espaciado reducido */
      border-radius: 5px; /* Opcional */
      text-align: center;
      margin: 0 10px; /* Añade espacio horizontal entre los enlaces */
    }

    nav a:hover {
      background-color: #bbb;
    }

canvas {
    display: block; /* Evita que el canvas tenga espacios adicionales como si fuera inline */
    margin: 0; /* Asegura que no se añada espacio por defecto */
    padding: 0;
    border: 1px solid black; /* Mantén el borde si lo necesitas */
    box-sizing: border-box; /* Incluye borde en el tamaño total */
}


#canvasContainer {
    position: relative; /* Necesario para posicionar los elementos absolutos dentro */
    display: inline-block;
    width: 500px; /* Asegúrate de que el ancho sea el mismo que el canvas */
    height: 500px; /* Ajusta el alto para que coincida con el canvas */
}

#zoom-buttons {
    position:  absolute;
    right: 10px; /* Alinea con el borde derecho del contenedor */
    bottom: 10px; /* Alinea con el borde inferior del contenedor */
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin: 0; /* Asegúrate de que no tenga márgenes indeseados */
    padding: 0; /* Para evitar bordes internos inesperados */
    z-index: 10; /* Asegura que los botones estén visibles encima del canvas */
}


#miDiv {
      display: none; /* El div está oculto inicialmente */
      position: absolute; /* Fija el div en la pantalla */
      top: 50%; /* Centra verticalmente */
      left: 50%; /* Centra horizontalmente */
      transform: translate(-50%, -50%); /* Ajusta para centrarlo completamente */
      padding: 20px;
      background-color: #f0f0f0;
      border-radius: 10px; /* Bordes redondeados */
      border: 2px solid #007bff;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Añade un poco de sombra */
      inline-size: max-content; /* Adopta el ancho de la línea de texto más larga */
      z-index: 999; /* Siempre por encima */
    }
    #miDiv .cerrar {
      position: absolute; /* Ubicación en la esquina superior */
      top: 10px; /* Separación desde el borde superior */
      right: 10px; /* Separación desde el borde derecho */
      background-color: #ff4d4d; /* Fondo rojo */
      color: white; /* Color del texto */
      border: none;
      border-radius: 50%; /* Forma circular */
      width: 30px;
      height: 30px;
      font-size: 16px;
      font-weight: bold;
      cursor: pointer; /* Cambia el cursor al pasar el ratón */
      line-height: 30px; /* Centra el texto verticalmente */
      text-align: center;
    }

    #miDivNav {
      display: flex; /* Usamos flexbox */
      flex-direction: column; /* Organiza los elementos en columna */
      align-items: center; /* Centra los enlaces horizontalmente */
    }

    /* Para evitar comportamiento de hover en miDiv */
    #miDiv .submenu-items {
        display: none; /* Ocultar submenús por defecto */
    }

    #miDiv .submenu-items.active {
        display: block; /* Mostrar submenús si se activa */
    }

.submenu {
    position: relative;
}

.submenu-items {
    display: none;
    position: absolute;
    background-color: #f0f0f0;
    border-radius: 10px; /* Bordes redondeados */
    border: 2px solid #007bff;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Añade un poco de sombra */  

    padding: 8px 16px;
    width: max-content;  /* Asegura que el ancho se ajuste automáticamente al texto más largo */
    white-space: nowrap; /* Evita que el texto se divida en líneas */
    text-align: left;  /* Alineación de los ítems a la derecha */
    line-height: 1; /* Reduce el interlineado (valor menor a 1.5 es más compacto) */
    z-index: 10;
}

.submenu:hover .submenu-items {
    display: block;
}

.submenu-items a {
    display: block;
    text-decoration: none;
    color: black;
    padding: 5px 10px;
    font-size: 0.9em; /* Un poco más pequeño que el texto del menú principal */
    text-align: left; /* Alinea cada enlace individual */
    font-size: 0.8em; /* Reduce el tamaño del texto */
    line-height: 1; /* Reduce el interlineado (valor menor a 1.5 es más compacto) */
}

.submenu-items a:hover {
    background-color: #bbb;  /* Color de fondo al pasar el cursor */
}

#miEnlace {
    z-index: 1000; /* Coloca el icono en un nivel superior */
}

html {
    scroll-behavior: smooth;
}

/* Aplica un margen superior al elemento con el ancla */
[id^="ancla-"] { /* Selecciona cualquier id que comience con "ancla-" */
    scroll-margin-top: 50px; /* Ajusta este valor según tu diseño */
}

     
.mi-parrafo {           /* Definición de la clase */
    font-size: 16px; /* Tamaño de letra */
    line-height: 1.5; /* Interlineado */
}

.resaltado {
            background-color: yellow; 
            font-weight: bold; 
}

.resaltado1 {
            background-color: #87CEEB; 
            font-weight: bold; 
}

.texto-con-imagen {
    position: relative;
    background-color: #B3E5FC; 
    font-weight: bold; 

  }

  .texto-con-imagen::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 323px; /* ajusta el tamaño según tu imagen */
    height: 312px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/tetractys.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen:hover::after {
    display: block;
  }

.texto-con-imagen1 {
    position: relative;
    background-color: #B3E5FC; 
    font-weight: bold; 

  }

  .texto-con-imagen1::after {
    content: "";
    z-index: 100;
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 593px; /* ajusta el tamaño según tu imagen */
    height: 334px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/Espiral-txt.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen1:hover::after {
    display: block;
  }

  .texto-con-imagen2 {
    position: relative;
    background-color: #B3E5FC; 
  }

  .texto-con-imagen2::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 290px; /* ajusta el tamaño según tu imagen */
    height: 269px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/Fraccion-continua.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen2:hover::after {
    display: block;
  }

  .texto-con-imagen3 {
    position: relative;
    background-color: #B3E5FC; 
  }

  .texto-con-imagen3::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 325px; /* ajusta el tamaño según tu imagen */
    height: 384px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/Coordenadas_polares.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen3:hover::after {
    display: block;
  }

.texto-con-imagen4 {
    position: relative;
    background-color: #B3E5FC; 
  }

  .texto-con-imagen4::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 482px; /* ajusta el tamaño según tu imagen */
    height: 318px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/geometrias-no-euclidiana.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen4:hover::after {
    display: block;
  }

.texto-con-imagen5 {
    position: relative;
    background-color: #B3E5FC; 
  }

  .texto-con-imagen5::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 1039px; /* ajusta el tamaño según tu imagen */
    height: 495px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/Kepler-leyes-del-movimiento-planetario.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen5:hover::after {
    display: block;
  }

.texto-con-imagen6 {
    position: relative;
    background-color: #B3E5FC; 
  }

  .texto-con-imagen6::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 978px; /* ajusta el tamaño según tu imagen */
    height: 332px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/Kepler-musica-de-las-esferas-intervalos.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen6:hover::after {
    display: block;
  }

.texto-con-imagen7 {
    position: relative;
    background-color:#B3E5FC; 
  }

  .texto-con-imagen7::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 683px; /* ajusta el tamaño según tu imagen */
    height: 451px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/paradoja.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen7:hover::after {
    display: block;
  }

.texto-con-imagen8 {
    position: relative;
    background-color:#B3E5FC; 
  }

  .texto-con-imagen8::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 674px; /* ajusta el tamaño según tu imagen */
    height: 469px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/ramificacion-3-Phi.jpg');
    background-size: cover;
    display: none;
  }

  .texto-con-imagen8:hover::after {
    display: block;
  }

.texto-con-imagen9 {
    position: relative;
    background-color:#B3E5FC; 
  }

  .texto-con-imagen9::after {
    content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 270px; /* ajusta el tamaño según tu imagen */
    height: 293px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/Romboedro.jpg');
    background-size: cover;
    display: none;
     z-index: 999;
  }

  .texto-con-imagen9:hover::after {
    display: block;
}

.texto-con-imagen10 {
    position: relative;
    background-color:#B3E5FC; 
  }

  .texto-con-imagen10::after {
        content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 240px; /* ajusta el tamaño según tu imagen */
    height: 240px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/icosaedro.gif');
    background-size: cover;
    display: none;
  }

.texto-con-imagen10:hover::after {
    display: block;
}

.texto-con-imagen11 {
    position: relative;
    background-color:#B3E5FC; 
  }

  .texto-con-imagen11::after {
        content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 701px; /* ajusta el tamaño según tu imagen */
    height: 387px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/Euclides-numeros-primos-infinitos.jpg');
    background-size: cover;
    display: none;
  }

.texto-con-imagen11:hover::after {
    display: block;
}

.texto-con-imagen12 {
    position: relative;
    background-color:#B3E5FC; 
  }

  .texto-con-imagen12::after {
        content: "";
    position: absolute;
    top: 100%; /* justo debajo del texto */
    left: 0;
    width: 540px; /* ajusta el tamaño según tu imagen */
    height: 424px; /* ajusta el tamaño según tu imagen */
    background-image: url('images/JavaScript-funcion-primo.jpg');
    background-size: cover;
    display: none;
  }

.texto-con-imagen12:hover::after {
    display: block;
}

.mensaje {
    display: none;
    color: red;
    font-style: italic;
}

h1 {
    font-size:150%;
    font-weight:bold;
}

#contenido {
    transition: margin-left .4s;
    padding: 1rem;
}

td {
  vertical-align: top;
}

img {
    display: block; /* Asegura que no haya espacio extra debajo de la imagen */
    padding: 0;
    margin: 0; /* Elimina márgenes externos */
    margin-left: 0;
    margin-top: 0; /* Elimina o reduce el margen superior */
    margin-bottom: 0; /* Reduce el margen inferior de la imagen */
    line-height: 0; /* Ajusta la altura de línea para mayor precisión */
}
  
figcaption {
    margin: 0; /* Elimina márgenes predeterminados */
    margin-top: 0; /* Elimina o reduce el margen superior */
    margin-left: 0;
    vertical-align: top; /* Alinea mejor al contenido superior */
    padding: 0; /* Asegúrate de eliminar cualquier espacio interno */
    line-height: 1; /* Ajusta la altura de línea para mayor precisión */
}

/* Estilos para pantallas pequeñas */
@media screen and (max-width: 768px) {
    body {
        width: 100%; /* Adapta el ancho a la pantalla */
        font-size: 16px; /* Reduce el tamaño del texto */
        padding: 10px; /* Añade espacio interno */
    }

    #imagen-fondo {
        width: 100%; /* Ajusta el ancho de la imagen */
        height: auto; /* Mantén la proporción de la imagen */
    }

    .texto-mascara {
        font-size: 1.5em; /* Reduce el tamaño del texto */
    }

    .botoninicio {
        padding: 8px 16px; /* Reduce el tamaño del botón */
        font-size: 0.8em; /* Ajusta el tamaño del texto dentro del botón */
    }
}

/* Estilos para pantallas grandes */
@media (min-width: 1500px) {
    body {
        width: 1310px !important; /* Sobrescribe cualquier otro estilo */
        /*margin: 0 auto !important;*/
    }
    #imagen-fondo {
        width: 1310px !important; /* Sobrescribe cualquier otro estilo */
    }
}


