html, body {
    font-family: 'Segoe UI', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    scroll-behavior: smooth;
    min-width: 1024px;
}

/* Fix para scroll en modales */
.e-scroll-disabled, .modal-open {
    overflow: auto !important;
}

a, .btn-link {
    color: #0071c1;
}

/* Botón primario con el estilo cian de site.css */
.btn-primary {
    color: #fff;
    background-color: #00C7FF;
    border-color: #1861ac;
    font-weight: bold;
    border-radius: 20px;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

/* UI de Error de Blazor (desde site.css) */
#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}
#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA9NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3LjgyOSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}
.blazor-error-boundary::after { content: "An error has occurred."; }

.darker-border-checkbox.form-check-input { border-color: #929292; }

/* Clases de Toolbar (desde site.css) */
.miToolbar {
    display: flex;
    background-color: #f8f9fa;
    border: 1px solid lightgray;
    margin-bottom: 5px;
    margin-top: 3px;
    border-radius: 3px;
    color: darkblue;
}
.tituloBarra {
    align-self: center;
    padding: 0px 20px 0px 10px;
    font-weight: bold;
    width: 30%
}
.barra { display: flex; width: 100%; justify-content: flex-end; }

/* === ESTILOS DE AUTENTICACION (RESTABLECIDOS) === */
.auth-boton-login {
    font-weight: bold; font-size: 2vh; background-color: #00c7ff; margin: 4px 2px; border-radius: 15px;
}
.auth-cuerpo {
    background-image: url('/images/fondo-inicio.png');
    background-repeat: no-repeat; background-size: cover; background-position: center;
    margin: 0px; display: grid; grid-template-columns: 2fr 4fr 2fr; height: 100vh; overflow: hidden;
}
.auth-columna-partes {
    display: grid; grid-template-rows: 1fr 4fr 20fr; text-align: center; justify-content: center; color: white;
}
.auth-bloque { text-align: center; width: 40vh; }
.auth-logo {
    margin-top: 20px; max-height: 100%; max-width: 40vh; object-fit: contain; margin-bottom: 20px; width: 100%; height: auto;
}
.auth-fila-justificada { display: flex; justify-content: space-between; align-items: center; width: 100%; }
.auth-font, .auth-bloque a { color: white; font-weight: bold; text-decoration: none; }

.form-label, .form-floating { color: #9d9d9c; font-weight: 600; }

/* Autofill fixes */
.form-floating .form-control:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px #ffffff inset !important;
    -webkit-text-fill-color: #000000 !important;
}

.auth-popup-roles, .auth-boton-logout { display: grid; place-items: center; max-height: 310px; }
.auth-boton-logout { margin-top: 6vh; }
.auth-boton-roles {
    font-weight: bold; font-size: 2vh; background-color: #00c7ff; margin: 10px 2px; width: 40vh; height: 5vh; color: white; border: 0; border-radius: 15px;
}
.auth-logo-roles { max-height: 100%; max-width: 20vh; object-fit: contain; margin-bottom: 20px; margin-top: 5vh; }


.entrada-plataforma {
    background-image: url('../images/fondo-inicio.png');
    background-size: cover; /* Ajusta la imagen para cubrir todo el div */
    background-position: center; /* Centra la imagen */
    background-repeat: no-repeat; /* Evita que la imagen se repita */
    display: grid;
    grid-template-rows: 4fr fr;
    height: 100vh;
    place-content: center;
    grid-gap: 10px;
}

.entrada-cuadro {
    width: 60%;
    height: 70vh;
    align-self: center;
    justify-self: center;
}

.entrada-cuadro-principal {
    width: 100%;
    height: 40vh;
    background-color: white;
    display: grid;
    place-content: center;
    border-radius: 15px;
    color: #3d5a80;
    align-self: center;
    justify-self: center;
    margin: 0px 2px 10px 2px;
}

.entrada-logo {
    width: 40vh;
}

.botonSalir {
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    border-style: hidden;
    color: #0a58ca;
    background-color: #50007d;
    color: white;
    margin-top: 2px;
}

    .botonSalir:hover {
        color: lightgray;
        /*background-color: #3d5a80;*/
    }

.barra {
    /*background-color: #50007c;*/
    display: flex;
    width: 100%;
    justify-content: flex-end;
    column-gap: 0.875rem;
    color: white;
    font-size: 14px;
    font-weight: bold;
    /*color: dimgray;*/
    border-radius: 3px;
    padding: 2px;
}

.barraNombre {
    display: flex;
    justify-content: flex-end;
    color: white;
    background-color: transparent;
    width: 100%;
    font-size: 14px;
}

.barraNombreNombre {
    justify-self: end;
    color: white;
    align-content: end;
    margin-bottom: 2px;
    font-size: 14px;
}


.toolbarAdmin {
    background-color: #50007d;
    min-height: 40px;
}

.e-control toolbarAdmin .e-toolbar {
    background-color: #50007d !important;
}


/* Fondo azul para el toolbar superior */
.toolbarAdmin.e-toolbar {
    background-color: #50007d; /* Azul Bootstrap, c mbialo al tono que quieras */
    color: white; /* Asegura que el texto sea legible */
}

.linkUsuario {
    color: white;
    text-decoration: none;
}

    .linkUsuario::after hover {
        background-color: grey;
        text-decoration: none;
    }

.nombreUsuarioBarra {
    color: white;
    text-decoration: none;
    align-items: end;
}

    .nombreUsuarioBarra:hover {
        color: lightgray;
        background-color: transparent;
    }


.account-layout {
    background-image: url('/images/fondo-inicio.png');
    /*grid-template-columns: 2fr 4fr 2fr;*/
    padding: 10%;
    margin: 0px;
    /*background-color: yellow;*/
    height: 100vh;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    /*text-align: center;*/
    color: white;
    justify-content: center;
}