body {
    background-image: url('../img/01.png');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    min-height: 100vh;
    margin: 0;
}

.menu {
    display: flex;
    justify-content: center;
    align-items: center;

    margin: 0px auto;
    max-width: 810px;

    border: 0px solid rgba(255, 255, 255, 0.6);
    border-radius: 6px;

    background: rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(6px);

    overflow-x: auto;
    white-space: nowrap;
}

.menu a {
    padding: 12px 12px;

    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1px;

    font-size: 12px;
    color: white;

    border-right: 1px solid rgba(255, 255, 255, 0.4);

    transition: background 0.3s ease, color 0.3s ease;
}

.menu a:last-child {
    border-right: none;
}

.menu a:hover {
    background: rgba(255, 255, 255, 0.15);
}

.tituloArqui {
    margin: 30px;
    color: white;
    text-align: center;
}

.mapaArquitectura {
    text-align: center;
    gap: 30px;
    margin: 50px;
}

.imagenMapa {
    max-width: 700px;
    height: auto;
}

.contenedor1 {
    display: flex;
    justify-content: left;
    align-items: left;
    gap: 30px;
    margin-top: 30px;
}

.imagenIzq {
    max-width: 500px;
    height: auto;
}

.textoDer {
    color: white;
    font-size: 32px;
}

.logoSanatFijo {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1000;
}

table {
  border-collapse: collapse;
  width: 40%;
  font-family: Arial, sans-serif;
  margin-left: auto;
  margin-right: auto;
}

caption {
    color: white;
}

th, td {
  text-align: left;
  padding: 14px;
}

th {
  color: white;
}

tr:hover {
  background-color: #0E0814;
}

iframe {
    display: block;
    margin: 10px auto;
    width: 60%;
    height: 500px;
}

.supComp {
    display: flex;
    max-width: 550px;
    height: auto;
    margin: 10px auto;
    justify-content: center;
    align-items: center;
}
