﻿/* Evita transición molesta al cambiar de tema ( anula todas las transiciones de la app... añadir !important si queremos mostrarlas ) */
*,
*:before,
*:after,
*::before,
*::after {
    transition: none !important;
}

:root {
    --font-size-base: 15px;
}

html, body * {
    scrollbar-color: var(--mud-palette-appbar-text) transparent !important;
    scrollbar-width: thin;
    font-size: var(--font-size-base);
}


/* SNACKBARS */
/* BG overlays según Severity */
.mud-snackbar.mud-alert-text-normal.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-outlined-normal.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-filled-normal.mud-snackbar-surface::before {
    content: "";
    position: absolute;
    inset: 0;
    /* overlay */
    background: rgba(var(--mud-palette-dark-rgb), 0.05);
    /*background: var(--mud-palette-normal);
    opacity: 0.04;*/
    pointer-events: none;
}
.mud-snackbar.mud-alert-text-info.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-outlined-info.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-filled-info.mud-snackbar-surface::before {
    content: "";
    position: absolute;
    inset: 0;
    /* overlay */
    background: rgba(var(--mud-palette-info-rgb), 0.05);
    /*background: var(--mud-palette-info);
    opacity: 0.04;*/
    pointer-events: none;
}
.mud-snackbar.mud-alert-text-success.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-outlined-success.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-filled-success.mud-snackbar-surface::before {
    content: "";
    position: absolute;
    inset: 0;
    /* overlay */
    background: rgba(var(--mud-palette-success-rgb), 0.05);
    pointer-events: none;
}
.mud-snackbar.mud-alert-text-warning.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-outlined-warning.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-filled-warning.mud-snackbar-surface::before {
    content: "";
    position: absolute;
    inset: 0;
    /* overlay */
    background: rgba(var(--mud-palette-warning-rgb), 0.05);
    pointer-events: none;
}
.mud-snackbar.mud-alert-text-error.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-outlined-error.mud-snackbar-surface::before,
.mud-snackbar.mud-alert-filled-error.mud-snackbar-surface::before {
    content: "";
    position: absolute;
    inset: 0;
    /* overlay */
    background: rgba(var(--mud-palette-error-rgb), 0.05);
    pointer-events: none;
}

/* PÁGINA LOGIN */
.login-body {
    background-color: var(--mud-palette-surface) !important;
    min-height: 100vh;
}

.mud-container.login-container {
    min-height: calc(100vh - var(--mud-appbar-height));
}

/* LOGO */
.logo-section {
    display: flex;
    padding: 10px;
    gap: 10px;
}

/* Evitar`'focus-visible' en texto 'ReciHub' al cargar la página */
.logo-text:focus-visible {
    outline: none !important;
}

.recihub-icon {
    color: var(--mud-palette-appbar-text);
}

.mud-typography.logo-text {
    color: var(--mud-palette-appbar-text);
    font-weight: 100;
    font-size: 28px;
    margin: 0;
    text-align: center;
}

/* FORM LOGIN */
#LogInForm .mud-form {
    width: 100%;
}

#LogInForm .mud-input {
    background-color: var(--mud-palette-background) !important;
    border-radius: var(--mud-default-borderradius) !important;
}


/* Sobreescribir diseño 'Variant.Outlined' para vista Login */

/* Altura input si modo: DENSE */
#LogInForm .mud-input > input.mud-input-root-outlined.mud-input-root-margin-dense,
#LogInForm div.mud-input-slot.mud-input-root-outlined.mud-input-root-margin-dense {
    padding-top: 14.5px;
    padding-bottom: 14.5px;
}

/* Quitar borde externo */
#LogInForm .mud-input.mud-input-outlined .mud-input-outlined-border {
    display: none;
}

/* Posición Label fuera (focused/shrunk), fondo transparente */
    #LogInForm .mud-shrink ~ label.mud-input-label.mud-input-label-inputcontrol.mud-input-label-outlined,
    #LogInForm .mud-shrink ~ label.mud-input-label.mud-input-label-inputcontrol.mud-input-label-outlined,
    #LogInForm .mud-input:focus-within ~ label.mud-input-label.mud-input-label-inputcontrol.mud-input-label-outlined,
    #LogInForm .mud-input:focus-within ~ label.mud-input-label.mud-input-label-inputcontrol.mud-input-label-outlined {
        transform: translate(9px, -18px) scale(0.75);
        background-color: transparent;
    }
/* Transición Label ( Focus IN ): sale fuera del campo */
#LogInForm .mud-input-label-animated {
    transition: none;
}
/* Transición Label ( Focus OUT ): vuelve dentro del campo */
#LogInForm .mud-input-label-outlined {
    background-color: var(--mud-palette-background);
    width: 92%;
    transition: none;
}

/* Tunear 'Asterisco Label' para input requerido */
#LogInForm .mud-input-control.mud-input-required > .mud-input-control-input-container > .mud-input-label::after {
    content: "";
    display: inline-block;
    background-color: var(--mud-palette-error);
    border-radius: 50%;
}
/* Tamaño asterisco cuando el label está DENTRO del campo */
#LogInForm .mud-input-label.mud-input-label-inputcontrol.mud-input-label-outlined::after {
    width: 0.375em;
    height: 0.375em;
    margin-left: 0.25em;
    margin-bottom: 0.3em;
}
/* Tamaño asterisco cuando el label está FUERA del campo */
#LogInForm .mud-shrink ~ label.mud-input-label.mud-input-label-inputcontrol.mud-input-label-outlined::after,
#LogInForm .mud-input:focus-within ~ label.mud-input-label.mud-input-label-inputcontrol.mud-input-label-outlined::after {
    width: 0.5em;
    height: 0.5em;
    margin-left: 0.25em;
    margin-bottom: 0.25em;
}

/* Sobreescribir estilos de autofill del navegador */
#LogInForm input:-webkit-autofill,
#LogInForm input:-webkit-autofill:hover,
#LogInForm input:-webkit-autofill:focus,
#LogInForm input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px var(--mud-palette-background) inset !important;
    -webkit-text-fill-color: var(--mud-palette-text-primary) !important;
    background-color: deeppink !important;
    transition: background-color 5000s ease-in-out 0s !important;
}

#LogInForm .mud-input.mud-input-filled.mud-input-underline:before,
#LogInForm .mud-input.mud-input-filled.mud-input-underline:after {
    border-bottom: none;
}

#LogInForm .mud-input > input.mud-input-root.mud-input-root-filled:-webkit-autofill,
#LogInForm div.mud-input-slot.mud-input-root.mud-input-root-filled:-webkit-autofill {
    border-radius: var(--mud-default-borderradius);
}

#LogInForm .mud-input-control > .mud-input-control-input-container > .mud-input-label-inputcontrol, 
#LogInForm .mud-icon-button {
    color: var(--mud-palette-text-secondary) !important;
}

#LogInForm #LogInBtn .mud-button-label p {
    text-transform: uppercase;
}


.psw-recovery-caption, 
.login-footer {
    color: var(--mud-palette-appbar-text);
}
/* FIN PÁGINA LOGIN */

/* ScrollTop */
.mud-scroll-to-top.visible {
    transition: transform .5s !important;
}
.mud-scroll-to-top.hidden {
    transition: all .5s !important;
}

/* Tooltips */
.mud-popover-provider .mud-tooltip {
    text-transform: uppercase;
}

.mud-popover-provider .mud-tooltip.mud-tooltip-default {
    color: var(--mud-palette-surface) !important;
    background-color: var(--mud-palette-appbar-text);
}
.mud-popover-provider .mud-tooltip.mud-theme-primary {
    color: var(--mud-palette-background)!important;
    background-color: var(--mud-palette-primary);
}

.mud-tooltip.mud-tooltip-default.mud-tooltip-arrow::after {
    border-color: var(--mud-palette-appbar-text) rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0)!important;
}

/* BADGES */
.mud-badge {
    font-weight: 900;
}

/* DataGrids, Tables */
.mud-table-cell {
    border-bottom: none!important;
}
.mud-table-pagination-toolbar {
    border-top: 1px solid var(--mud-palette-table-lines);
}

/* MUD DIALOGS */
/* Overlay */
.blurry-bg {
    backdrop-filter: blur(5px);
}


/*** OVERRIDES CSS NAVEGADOR CHROME/EDGE ***/

/* Sobrescribir color azulado inputs autocompletados */
/* Estas reglas las detecta MudBlazor y las añade automáticamente a su clase: */
/* .mud-input>input.mud-input-root-outlined.mud-input-root:-webkit-autofill, div.mud-input-slot.mud-input-root-outlined.mud-input-root:-webkit-autofill*/
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 1000px var(--mud-palette-surface) inset !important;
    box-shadow: 0 0 0 1000px var(--mud-palette-surface) inset !important;
    -webkit-text-fill-color: var(--mud-palette-appbar-text) !important;
}

/*** FINAL OVERRIDES CSS ***/


/* Progress bar */
.mud-progress-linear-bar {
    background-color: var(--mud-palette-primary) !important;
}


/* Media query para móvil vertical ( retrato ) */
@media (max-width: 768px) and (orientation: portrait) {
    /* Aumentar padding lateral del contenedor, reduciendo ancho formulario */
    #LogInForm .mud-form {
        width: 80%;
    }

    /* Reducir tamaño del logo */
    .recihub-icon {
        width: 40px;
        height: 40px;
    }

    /* Reducir tamaño del texto ReciHub */
    .mud-typography.logo-text {
        font-size: 24px;
    }

    /* Ajustar gap del logo section */
    .logo-section {
        gap: 8px;
    }
}


/* NAV MENU ( Por 'Scope', sólo puedo definirlos aquí ) */
.mud-drawer--closed .mud-nav-link .mud-nav-link-text {
    margin-left: 0px;
}
.mud-drawer--open.mud-drawer-md.mud-drawer-clipped-docked.mud-drawer-temporary .mud-navmenu.mud-navmenu-primary .mud-nav-link .mud-nav-link-text,
.mud-drawer--open.mud-drawer-md.mud-drawer-clipped-docked.mud-drawer-temporary .mud-navmenu.mud-navmenu-primary .mud-nav-link.active:not(.mud-nav-link-disabled) .mud-nav-link-text {
    line-height: normal;
    margin-top: 4px;
}

/* DATE PICKER */
.mud-picker-calendar .mud-day.mud-selected {
    color: var(--mud-palette-surface) !important;
}