
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap');

html, body {
    font-family: 'DM Sans', Helvetica, Arial, sans-serif;
    height: 100vh;
    width: 100%;
}

html {
    font-size: 100%;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) 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;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/*TEST*/
/*.containerLi {
    width: 100%;
    display: flex;
    justify-content: flex-start;
}

.contenedorMenuInterno {
    display: grid;
    grid-template-rows: minmax(0px, 0fr);
    overflow: hidden;
    transition: grid-template-rows 300ms ease-in-out;
}

    .contenedorMenuInterno.Colapsado {
        grid-template-rows: minmax(0px, 1fr);
        overflow: initial;
    }

.contenedorMenuInterno > div {
    display: flex;
    overflow: hidden;
}


    .contenedorMenuInterno.Colapsado > div {
        width: 100%;
        overflow-y: auto;
    }

        .contenedorMenuInterno.Colapsado > div > div {
            width: 100%;
        }

        .contenedorMenuInterno.Colapsado > div > div > div {
            position: relative;
            overscroll-behavior-y: contain;
            margin: 0px;
            list-style: none;
        }

    .contenedorMenuInterno .label, .containerLi .label {
        color: var(--colorAzulPrimary);
    }

    .contenedorMenuInterno svg, .containerLi svg {
        fill: var(--colorAzulPrimary);
    }*/


/*.contenedorMenuInterno {
    display: grid;
    grid-template-rows: minmax(0, 0fr);
    overflow: hidden;
    transition: grid-template-rows 300ms ease-in-out;
}

    .contenedorMenuInterno.Colapsado {
        grid-template-rows: minmax(0, 1fr);
    }

    .contenedorMenuInterno > div {
        overflow: hidden;
    }

    .contenedorMenuInterno.Colapsado > div {
        overflow-y: auto;
    }*/


/*TEST*/

/*Header*/
/*.headerMudAppBar > div.mud-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.mudAppBarMenuIcon {
    background-color: white !important;
}


.menuLateral {
    & > .mud-nav-item,
    & > .mud-nav-group {
        padding: 10px 10px;
    }
    & .mud-nav-link {
        border: 1px solid var(--colorAzulPrimary);
        border-radius: 100px;
        padding: 4px 5px !important;
        color: var(--colorAzulPrimary);
        font-weight: 300;
        font-size: 16px;
        background-color: transparent;

        & .mud-nav-link-text {
            text-wrap-mode: nowrap;
            font-weight: 300;
        }
    }
    & > .mud-nav-item > .mud-nav-link {
    }
    & > .mud-nav-group {
        & > .mud-nav-link {
        }
        & .mud-collapse-container .mud-collapse-wrapper {

            & .mud-navmenu .mud-nav-item {
                margin-top: 10px;

                & > .mud-nav-link {
                    background-color: transparent !important;
                    border: none !important;
                    &.active {
                        background-color: var(--mud-palette-action-default-hover) !important;
                    }
                }
            }
        }
    }
        & > .mud-nav-group > .mud-nav-link.mud-expanded {
            background-color: var(--colorAzulPrimary);
            color: white;

            & > svg {
                fill: white;
            }
        }
}

.mud-drawer--closed .menuLateral {
    & > .mud-nav-item > .mud-nav-link,
    & > .mud-nav-group > .mud-nav-link {
    }

    & > .mud-nav-group .mud-collapse-wrapper {
        padding: 0 !important;

        & .mud-nav-item > .mud-nav-link {
            border: 1px solid var(--colorAzulPrimary) !important;
        }
    }
}

.mudAppBarMenuIcon.mud-icon-button {
    &:focus-within,
    &:hover {
        background-color: white !important;
    }
}
*/



:root {
    /*    --mud-drawer-width-left: 300px !important;*/
    --mud-palette-action-default-hover: #DCF5F6 !important;
    --mud-default-borderradius: 17px !important;
    /*    --mud-appbar-height: 40px !important;*/
    /*    --mud-internal-toolbar-height: 40px !important;*/
    /**/
    --formularioBase-header-height: 55px;
    /**/
    --colorAzulPrimary: #5BB3B7;
    --colorAzulSecondary: #B8E7E9;
    --colorAzulTerciary: #DBF0F0;
    /**/
    --colorGrisPrimary: #F5F6F7;
    --colorGrisSecondary: #CDD0D0;
    --colorGrisTerciary: #DBDBDB;
    --colorGrisQuaternary: #6C6F74;
    /**/
    --colorRojoPrimary: #B7635B;
    --colorRojoSecondary: /*#FFD7D7*/ #FFD7D7;
    --colorRojoTerciary: /*#F0DBDB*/ #FFEDED;
    /**/
    --sidebar-width: 235px;
    --sidebar-collapsed-width: 54px;
    --topbar-height: 40px;
    --shadow-1: 0px 2px 1px -1px rgba(0,0,0,0.2);
    --shadow-2: 0px 1px 1px 0px rgba(0,0,0,0.14);
    --shadow-3: 0px 1px 3px 0px rgba(0,0,0,0.12);
    --transition-default: 0.6s ease;
}


/*TODO: Revisar porque esto no funciona*/
@supports (scrollbar-color: auto) {
    * {
        scrollbar-color: var(--colorAzulPrimary) red;
    }
}

@supports selector(::-webkit-scrollbar) {
    *::-webkit-scrollbar {
        background: red;
    }

    *::-webkit-scrollbar-thumb {
        background: var(--colorAzulPrimary);
    }
}




/* Layout */
.layout {
    display: grid;
    grid-template-areas:
        "topbar topbar"
        "sidebar content";
    grid-template-columns: var(--sidebar-width) 1fr;
    grid-template-rows: var(--topbar-height) /*1fr*/ minmax(0, 1fr);
    height: 100vh;
    transition: grid-template-columns var(--transition-default);
}

    .layout.collapsed {
        grid-template-columns: var(--sidebar-collapsed-width) 1fr;
    }

/* Topbar */
.topbar {
    grid-area: topbar;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    padding: 0 1rem;
    background-color: var(--colorAzulPrimary);
    color: white;
    z-index: 1;
}

.topbar-title {
    text-align: center;
    font-weight: 300;
    font-size: 0.875rem;
}

.topbar-btn {
    background: none;
    border: none;
    color: white;
    font-size: 1.5rem;
    cursor: pointer;
    transition: opacity var(--transition-default);
}

    .topbar-btn:hover {
        opacity: 0.8;
    }

/* Sidebar */
.sidebar {
    grid-area: sidebar;
    background-color: transparent;
    color: white;
    overflow: hidden;
    transition: width var(--transition-default);
    min-height: 0;
    overflow: auto;
}

    .sidebar .label {
        font-size: 0.875rem;
    }

    .sidebar .submenu .label {
        font-size: 0.75rem;
    }


/* Menu base */
.menu {
    list-style: none;
    padding: 7px 0;
    margin-bottom: 0px;
}

    .menu li {
        width: 100%;
        padding: 7px 10px;
    }

.submenu li {
    padding: 0px;
}

.menu a,
.menu-parent {
    display: flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    color: var(--colorAzulPrimary);
    transition: background-color var(--transition-default);
    cursor: pointer;
    border-radius: 20px;
    box-sizing: border-box;
    /*    box-shadow: inset 0 0 0 1px var(--colorAzulPrimary);*/
}

    .menu-parent > span.icon-wrapper svg,
    .menu-parent > span.icon-wrapper path {
        fill: var(--colorAzulPrimary);
        transition: fill 0.6s ease;
    }

    .menu-parent.open {
        background-color: rgba(220, 245, 246, 1);
        color: var(--colorAzulPrimary);
    }

/*ul.menu > .menu-root:has(.submenu a.active) > .menu-parent {
    background-color: var(--colorAzulPrimary) !important;
    color: white !important;
}
*/
.menu-root:has(.submenu-container .active) > .menu-parent {
    background-color: var(--colorAzulPrimary) !important;
    color: white !important;
}

ul.menu > .menu-root:has(.submenu a.active) > .menu-parent > span.icon-wrapper svg,
ul.menu > .menu-root:has(.submenu a.active) > .menu-parent > span.icon-wrapper path {
    fill: white !important;
}

.menu-parent.open > span.icon-wrapper svg,
.menu-parent.open > span.icon-wrapper path {
    fill: var(--colorAzulPrimary);
}

.collapsed .menu a, .collapsed .menu-parent {
    box-shadow: none;
}

.menu a:hover,
.menu-parent:hover {
    background-color: rgba(220, 245, 246, 1);
}

/*.menu-parent.open:hover {
    background-color: var(--colorAzulPrimary);
}*/


/* Iconos */
.icon {
    font-size: 1.2rem;
    min-width: 24px;
    text-align: center;
}

.icon-wrapper {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background-color: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background-color var(--transition-default);
}

    .icon-wrapper svg {
        width: 20px;
        height: 20px;
    }

.submenu .icon-wrapper {
    width: 30px;
    height: 30px;
}

    .submenu .icon-wrapper svg {
        width: 18px;
        height: 20px;
    }

.collapsed .submenu {
    padding: 14px 3px 0px 3px;
}

    .collapsed .submenu .icon-wrapper {
        border: none;
    }

.collapsed .active .icon-wrapper {
    border: 1px solid var(--colorAzulPrimary);
}

.collapsed .submenu .active .icon-wrapper {
    border: 1px solid var(--colorAzulPrimary);
    background-color: rgba(220, 245, 246, 1);
}

.collapsed:hover .submenu .active .icon-wrapper {
    border: none;
    background-color: transparent;
}

.menu a.active {
    background-color: var(--colorAzulPrimary);
    color: white;
}

    .menu a.active svg, .menu a.active path {
        fill: white;
    }

.menu a svg,
.menu a path {
    fill: var(--colorAzulPrimary);
}

.submenu a.active {
    background-color: rgba(220, 245, 246, 1);
}



/*.collapsed .menu-parent.open:hover .icon-wrapper {
    background-color: var(--colorAzulPrimary);
}*/

.menu a:hover .icon-wrapper,
.menu-parent:hover .icon-wrapper {
    background-color: transparent;
}

.icon-img {
    width: 27px;
    height: 27px;
}

.submenu .icon-img {
    width: 23px;
    height: 23px;
}

/* Sidebar collapsed */
.sidebar.collapsed .label,
.sidebar.collapsed .submenu li a .label,
.sidebar.collapsed .menu-parent .arrow {
    display: none;
}

/* Arrow */
.arrow {
    transition: transform var(--transition-default);
}

    .arrow.rotate {
        transform: rotate(180deg);
    }

/* Submenu */
.submenu-container {
    overflow: hidden;
    max-height: 0;
    transition: max-height var(--transition-default);
}

    .submenu-container.open {
        max-height: 1000px;
    }

.submenu {
    transform: translateY(-100%);
    opacity: 0;
    transition: transform var(--transition-default), opacity var(--transition-default);
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
    /*    padding: 14px 1px 0px 1px;*/
    padding: 14px 10px 0px 10px;
    transition: padding var(--transition-default);
}

    .submenu > li > a > span.icon-wrapper svg,
    .submenu > li > a > span.icon-wrapper path {
        fill: var(--colorAzulPrimary);
    }

.submenu-container.open .submenu {
    transform: translateY(0);
    opacity: 1;
}


/* Content */
.content {
    grid-area: content;
    padding: 15px;
    background-color: #F5F6F7;
    min-height: 0;
    overflow: auto;
}

    .content > div {
        height: 100%;
        width: 100%;
    }

/* User dropdown */
.user-menu-wrapper {
    position: relative;
}

.dropdown-menu {
    position: absolute;
    right: 0;
    top: 120%;
    background: white;
    color: black;
    min-width: 150px;
    border-radius: 6px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
    display: none;
    flex-direction: column;
    overflow: hidden;
}

    .dropdown-menu.show {
        display: flex;
    }

    .dropdown-menu a {
        padding: 0.8rem 1rem;
        text-decoration: none;
        color: black;
        display: block;
        transition: background-color var(--transition-default);
    }

        .dropdown-menu a:hover {
            background-color: #f0f0f0;
        }

.label {
    text-wrap-mode: nowrap;
    font-size: 16px;
}

.submenu .label {
    font-size: 14px;
    color: var(--colorAzulPrimary);
}


.layout.collapsed:has(.sidebar:hover) {
    grid-template-columns: var(--sidebar-width) 1fr;
}

    .layout.collapsed:has(.sidebar:hover) .sidebar .label,
    .layout.collapsed:has(.sidebar:hover) .sidebar .menu-parent .arrow {
        display: inline;
    }

    /*    .layout.collapsed:has(.sidebar:hover) .menu a,
    .layout.collapsed:has(.sidebar:hover) .menu-parent {
        box-shadow: inset 0 0 0 1px var(--colorAzulPrimary);
    }*/

    .layout.collapsed:has(.sidebar:hover) .icon-wrapper {
        border: none;
    }

.hamburguesaIconMenu,
.hamburguesaIconMenu path {
    fill: white;
    width: 20px;
}

.loginIconMenu,
.loginIconMenu path {
    fill: white;
    width: 13px;
}

/*MUD-LAYOUT*/
/*Header*/
.headerMudAppBar > div.mud-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.mudAppBarMenuIcon {
    background-color: white !important;
}





/*MUD-LAYOUT*/
#blazor-error-ui {
    background-color: var(--colorAzulPrimary);
}



/*MAIN CONTENT*/
.wrapperEspacios .headerMainContent {
    padding: 5px 15px 0px 15px;
}

.headerMainContent {
    display: flex;
    align-items: end;
    /*    padding: 10px;*/
    padding: 10px 15px 0px 15px;
    width: 100%;
    height: 100%;
    justify-content: space-between;
    /*height: 50px;*/
    height: auto;
}

    .headerMainContent > .containerFiltersMainContent {
        max-width: 70%;
        width: auto;
        display: flex;
        gap: 10px;
        align-items: end;
    }

        .headerMainContent > .containerFiltersMainContent > h2 {
            font-size: 14px;
            font-weight: 400;
            color: black;
            line-height: 2px;
        }


        .headerMainContent > .containerFiltersMainContent > .searchFilter {
            display: flex;
            gap: 10px;
            max-width: calc(100% - 250px);
            width: auto;
            flex-wrap: nowrap;
            overflow: hidden;
        }


.searchFilter > * {
    flex: 1;
    width: 200px;
}


.searchFilter > .mud-select > .mud-input-control.mud-select > .mud-input-control-input-container > div.mud-input > .mud-input-adornment {
    padding: 0px !important;
}

.headerMainContent > .containerFiltersMainContent > .searchFilter > div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input > div.mud-select-input {
    padding: 4px 4px 4px 20px;
    font-size: 14px !important;
    font-weight: 400;
    line-height: 20px;
}

.headerMainContent > .containerFiltersMainContent > .textFilter {
    width: 250px;
    padding-top: 8px;
}

    .headerMainContent > .containerFiltersMainContent > .textFilter fieldset {
        border: 1px solid var(--colorAzulPrimary);
    }


    .headerMainContent > .containerFiltersMainContent > .textFilter .textFilterMudInput input {
        padding: 4px 0px 4px 15px !important;
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
    }


.headerMainContent > .containerBtnsMainContent {
    width: 30%;
    display: flex;
    justify-content: end;
    gap: 10px;
    padding-top: 8px;
}


    .headerMainContent > .containerBtnsMainContent > button,
    .headerMainContent > .containerBtnsMainContent > a,
    .btnAddFkEntity,
    .btnDeleteFilters {
        font-size: 14px;
        color: white;
        background-color: var(--colorAzulPrimary);
        font-weight: 400;
        padding: 4px 20px;
        border-radius: 20px;
        display: flex;
        justify-content: center;
        gap: 5px;
        line-height: 20px;
    }

         a.returnBtn {
            background-color: var(--colorGrisSecondary) !important;
        }

.separadorHeaderBodyCrud {
    display: flex;
    width: 100%;
    align-items: center;
    padding: 0px 10px;
    height: 15px;
}

    .separadorHeaderBodyCrud > div {
        background-color: black;
        height: 1px;
        background-color: black;
        height: 1px;
        width: 100%;
    }

.headerMainContent > .containerFiltersMainContent > .searchFilter > div.mud-select .mud-input-control.mud-input-outlined-with-label {
    margin-bottom: 0px;
}

/*MAIN CONTENT*/
/*FORMULARIOS (CRUDS)*/
.FormularioBase {
    height: 100%;
    width: 100%;
    background-color: white;
    border-radius: 20px;
    position: relative;
}

.wrapperEspacios .FormularioBase > main {
    /*grid-template-columns: repeat(2, 1fr) 200px;*/
    grid-template-columns: 2.5fr 2.5fr 1fr;
}

.FormularioBase > main {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, 1fr) 300px;
    column-gap: 30px;
    padding: 10px;
    height: calc(100% - 70px);
    /*        height: calc(100% - var(--topbar-height) - 15px - 46px);*/
    overflow-y: auto;
}

.crudEspacios .FormularioBase > main {
    overflow-y: hidden;
    overflow-x: hidden;
}

    .FormularioBase > main > fieldset {
        height: 100%;
    }

        .FormularioBase > main > fieldset > .headerFieldSet {
            display: flex;
        }

            .FormularioBase > main > fieldset > .headerFieldSet.ayuda {
                border-bottom: 1px solid var(--colorAzulPrimary) !important;
            }

            .FormularioBase > main > fieldset > .headerFieldSet > legend {
                font-size: 14px;
                font-weight: 400;
                color: black;
            }

.filedsetHeaderDecoration {
    border-radius: 20px 20px 0px 0px !important;
    border: 1px solid var(--colorAzulPrimary) !important;
    padding: 4px 12px 5px 12px !important;
    border-bottom: none !important;
    background-color: var(--colorAzulTerciary);
    margin-bottom: -1px;
    color: var(--colorAzulPrimary);
    font-size: 14px;
    font-weight: 400;
}

.FormularioBase > main > fieldset > .bodyFieldSet {
    display: flex;
    flex-direction: column;
    background-color: var(--colorAzulTerciary);
    padding: 10px;
    border-radius: 0px 0px 20px 20px;
    border: 1px solid var(--colorAzulPrimary);
}

.modalFormularioBase {
    min-width: 500px;
}

.FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup {
    padding: 10px 0px;
    display: flex;
    flex-direction: column;
}

.FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn,
.formularioBaseGroupColumnModal {
    padding: 10px 0px;
    display: flex;
    gap: 10px;
}

    .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn > div,
    .formularioBaseGroupColumnModal > div {
        flex: 1;
    }

        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup > label,
        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn > div > label,
        .labelFormulario {
            color: black;
            font-size: 14px;
            font-weight: 500;
        }

        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup > .mud-picker,
        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn > div > .mud-picker {
            background-color: white;
            border-radius: 20px;
        }

        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup input,
        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn input,
        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup > div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input,
        .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn > div > div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input,
        .modalFormularioBase div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input,
        .modalFormularioBase input {
            font-size: 14px;
            font-weight: 500;
            background-color: white;
            border-radius: 20px;
        }

            .tab-textos input,
            .tab-textos textarea,
            .modalFormularioBase input,
            .modalFormularioBase div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input > div.mud-select-input.mud-input-slot,
            .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup input,
            .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn input,
            .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup > div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input > div.mud-select-input.mud-input-slot,
            .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn > div > div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input > div.mud-select-input.mud-input-slot {
                padding: 5.5px 10px !important;
            }

    .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup .mud-input-numeric-spin,
    .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn .mud-input-numeric-spin,
    .modalFormularioBase .mud-input-numeric-spin {
        padding-right: 10px;
    }

    .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroup div.mud-input-numeric-spin > button > span > svg,
    .FormularioBase > main > fieldset > .bodyFieldSet > .formularioBaseGroupColumn div.mud-input-numeric-spin > button > span > svg {
        font-size: 1em;
    }



.ayudaFormularioBase {
    padding: 10px 0px;
    display: flex;
    flex-direction: column;
}

    .ayudaFormularioBase > h3 {
        color: black;
        font-size: 14px;
        font-weight: 500;
    }

    .ayudaFormularioBase > p {
        font-size: 14px;
        font-weight: 300;
        color: var(--colorGrisQuaternary);
    }

.containerErrors ul {
    padding-left: 1rem;
}
/*.tab-error {
    border: 1px solid red !important;
    color: red !important;
}
*/
/*FORMULARIOS (CRUDS)*/
/*INDEX BASE MUDTABLE*/
.indexTableBase {
    height: 100%;
}

    .indexTableBase .mud-table-container {
        height: calc(100vh - 40px - 30px - 50px - 52px);
        border-radius: 20px;
        padding: 0px 10px 10px 10px;
    }

    .indexTableBase .mud-table-cell {
        padding: 4px 12px !important;
        font-size: 12px;
        text-wrap-mode: nowrap;
    }

    .indexTableBase > .mud-toolbar {
        padding: 0px;
        height: fit-content;
    }

.modalDelete {
    height: 250px;
    width: 425px;
    padding: 20px 20px;
}

    .modalDelete h6 {
        text-align: center;
        border-bottom: 1px solid var(--colorAzulPrimary);
        padding-bottom: 10px;
    }
/*INDEX BASE MUDTABLE*/




.spinnerComponent {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
    background-color: var(--colorAzulPrimary);
}


    .spinnerComponent > h1 {
        color: white;
    }

    .spinnerComponent svg {
        fill: white !important;
    }
/*TabLangErrors*/

.textosFieldset:has(.tab-textos.es .validation-message) .tab-error.es,
.textosFieldset:has(.tab-textos.en .validation-message) .tab-error.en {
    background-color: var(--colorRojoTerciary) !important;
}


    .textosFieldset:has(.tab-textos.es .validation-message) .tab-error.es.mud-toggle-item-selected,
    .textosFieldset:has(.tab-textos.en .validation-message) .tab-error.en.mud-toggle-item-selected {
        background-color: var(--colorRojoSecondary) !important;
    }


.textosFieldset:has(.tab-textos.es .validation-message) .tab-textos.es.tab-visible,
.textosFieldset:has(.tab-textos.en .validation-message) .tab-textos.en.tab-visible {
    background-color: var(--colorRojoSecondary) !important;
}
/*Archivos*/

.wrapperArchivos {
    display: flex;
    background-color: white;
    border-radius: 12px;
    padding: 5px;
    position: relative;
    min-height: 110px;
    margin-top: 10px;
}

.containerArchivo {
    font-size: 20px;
    display: flex;
    flex-direction: column;
    border: 1px solid #dbdbdb;
    border-radius: 10px;
    background: #f9f9f9;
    padding: 0;
    width: 80px;
    align-items: center;
    position: relative;
    border-radius: 10px;
}

.btnAddArchivos {
    margin-left: 20px;
    background-color: var(--colorAzulPrimary);
    height: 20px;
    width: 20px;
    border-radius: 50%;
    position: absolute;
    right: 0px;
    top: 50%;
    transform: translate(-50%, -50%);
}


    .btnAddArchivos svg {
        width: 100%;
        font-size: inherit !important;
        fill: white;
    }


.imgArchivos {
    width: 100%;
    height: 60px;
    object-fit: cover;
    border-radius: 10px 10px 0px 0px;
}

.bytesArchivo {
    font-size: 10px;
    text-align: center;
}

.nombreArchivo {
    font-size: 10px;
    text-align: center;
    color: #B7AFAF;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}


.containerInfoArchivo {
    display: flex;
    flex-direction: column;
    padding: 5px;
}

.containerBtnsArchivos {
    width: 100%;
    display: flex;
    justify-content: end;
    position: absolute;
    top: 5px;
    right: 5px;
    gap: 5px;
}

    .containerBtnsArchivos button {
        background-color: var(--colorRojoPrimary);
    }

    .containerBtnsArchivos a {
        background-color: var(--colorAzulPrimary);
    }

    .containerBtnsArchivos button,
    .containerBtnsArchivos a {
        padding: 0px;
        border-radius: 5px;
        width: fit-content;
        height: auto;
    }

        .containerBtnsArchivos button:hover,
        .containerBtnsArchivos a:hover {
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
            transform: translateY(-2px);
        }

.btnAddArchivos:hover {
    box-shadow: 0 0 0 6px rgba(91, 179, 183, 0.4);
}

.containerBtnsArchivos button:disabled,
.containerBtnsArchivos a:disabled {
    box-shadow: none;
    transform: none;
    cursor: not-allowed;
}

.btnAddArchivos:disabled {
    box-shadow: none;
    cursor: not-allowed;
}

.containerBtnsArchivos button svg,
.containerBtnsArchivos a svg,
.containerBtnsArchivos button svg path,
.containerBtnsArchivos a svg path {
    fill: white;
}

.containerBtnsArchivos svg {
    height: 20px;
    width: 24px;
}

.wrapperArchivos .containerImgs {
    display: flex;
    gap: 5px;
}
/* Tocar tablas de mud */

.mud-table-cell {
    border: none;
}

.mud-table-head {
    border-bottom: 1px solid #000;
}

    .mud-table-head span {
        font-size: 0.875rem;
    }
/*FIN Tocar tablas de mud */
/* Controlar paddings de los cruds y maestros */

.indexTableBase .mud-table-container {
    padding: 0px 15px 0px 15px;
}

.separadorHeaderBodyCrud {
    padding: 0px 15px;
}



.FormularioBase > main {
    padding: 15px;
}
/* Iconos botones */
.mud-icon-root {
    width: 0.7em;
}
/* FIN Iconos botones */

.mud-input-slot::placeholder {
    font-size: 0.875rem;
    font-weight: 300;
}

.simple-editor-container,
.ql-toolbar {
    background-color: white !important;
    margin-top: 4px;
}

.ql-toolbar {
    border-radius: 20px 20px 0px 0px;
}

.ql-editor {
    min-height: 6em !important;
}

.simple-editor-container {
    border-radius: 0px 0px 20px 20px;
}
/* Contenedor que ocupa toda la pantalla */
/*LOGIN*/
.login-box label {
    font-weight: 500;
    font-size: 14px;
    color: black;
    padding-bottom: 7px;
}

.login-box input {
    padding: 7px 15px !important;
}
/*LOGIN*/



.btnDefault {
    padding: 5px 30px;
    color: white;
    border-radius: 20px;
    font-size: 16px;
    font-weight: 400;
}

.btnGuardar {
    flex: 1;
    background-color: var(--colorAzulPrimary);
}

.btCancelar {
    flex: 1;
    background-color: var(--colorGrisSecondary);
}



.mp4 {
    background-image: url("media/img/pdf.jpg");
    background-position: center center;
    background-size: 100%;
    background-repeat: no-repeat;
    flex-direction: column-reverse;
}

.pdf {
    background-image: url("media/img/pdf.jpg");
    background-position: center center;
    background-size: 100%;
    background-repeat: no-repeat;
    flex-direction: column-reverse;
}

.SimpleTableCurdFk {
    border-radius: 0px;
    border-top: 1px solid var(--colorAzulPrimary);
}

.containerActionsIndexTable {
    display: flex;
    justify-content: end;
    align-items: center;
    column-gap: 8px;
    border-radius: 0px !important;
}

    .containerActionsIndexTable > button > img {
        background-color: var(--colorAzulPrimary);
        border-radius: 5px;
        fill: white;
        padding: 5px;
        height: 25px;
        width: 25px;
    }

    .containerActionsIndexTable > button.delete > img {
        background-color: var(--colorRojoPrimary);
        border-radius: 5px;
        fill: white;
        padding: 5px;
        height: 25px;
        width: 25px;
    }
/*Lista Elementos Relacionados con boton Añadir*/
.FillWhite,
.FillWhite svg,
.FillWhite path {
    fill: white !important;
}


.listaElementosRelacionados {
    background-color: white;
    width: 100%;
    padding: 10px 10px;
    border-radius: 20px;
    margin-top: 10px;
    position: relative;
    min-height: 45px;
    display: grid;
    grid-template-columns: 150px 150px 150px 150px;
    gap: 10px;
}

.elementoRelacionado {
    background-color: var(--colorAzulTerciary);
    border-radius: 20px;
    padding: 0px 10px 0px 20px;
    text-align: center;
    font-size: 16px;
    font-weight: 400;
    color: #6C6F74;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

    .elementoRelacionado > .textRelacionado {
        flex: 3;
        cursor: pointer;
    }

    .elementoRelacionado > button {
        flex: 1;
    }

        .elementoRelacionado > button > path,
        .elementoRelacionado > button > svg {
            fill: #6C6F74 !important;
        }
/*Lista Elementos Relacionados con boton Añadir*/


.disponibilidadWrapper {
    height: 100%;
    width: 100%;
    background-color: white;
    border-radius: 20px;
    padding: 15px;
    display: grid;
    grid-auto-rows: auto 1fr;
}

    .disponibilidadWrapper .headerDisponibilidad input,
    .disponibilidadWrapper .headerDisponibilidad div.mud-select > div.mud-select > div.mud-input-control-input-container > div.mud-select-input > div.mud-select-input.mud-input-slot {
        padding: 5.5px 0px 5.5px 10px !important;
    }

.headerDisponibilidad {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: space-between;
}

    .headerDisponibilidad > div {
        /*        flex: 1;*/
        display: flex;
        gap: 10px;
        justify-content: end;
    }

.FiltroFechasDisponibilidad input.mud-input-slot.mud-input-root {
    width: 90px !important;
}

.FiltroFechasDisponibilidad button.mud-button-root.mud-icon-button {
    margin: 0px 12px 0px 0px;
    padding: 0px;
}


.bodyDisponibilidad {
    width: 100%;
    overflow-x: auto;
    overflow-y: auto;
}
/*.listaDisponibilidad {
    width: fit-content;
    display: grid;
    grid-template-columns: auto 1fr;
    row-gap: 20px;
}


.disponibilidadCantidadFecha {
    display: flex;
}

.disponibilidadCantidadFecha > div{
    display: flex;
    flex-direction:column;
}

    .disponibilidadCantidadFecha > div:nth-child(odd) {
        background-color: #C1DDDE;
    }

    .disponibilidadCantidadFecha > div:nth-child(even) {
        background-color: #DDEDEE;
    }

.headerFila {
    text-align: center;
    background-color: white;
}

.bodyFila {
    display: flex;
}

.dia {
    display: flex;
    flex-direction: column;
    padding: 3px 6px;
    min-width: 50px;
}

.nombreProducto {
    font-weight: 700;
    font-size: 15px;
    color: black;
    display: flex;
    align-items: end;
    justify-content: start;
    padding: 10px 5px;
    position: sticky;
    left: 0;
    background: white;
    z-index: 2;
}

.disponibilidadCantidadFecha .fecha {
    font-weight: 400;
    font-size: 18px;
    color: black;
    text-align: center;
}

.inputDisponibilidad {
    width: 26px;
    height: 26px;
    text-align: center;
    border-radius: 4px;
    border: 1px solid #7E7E7E;
    font-size: 16px;
    color: black;
    font-weight: 400;
}

input.inputDisponibilidad[type="number"]::-webkit-outer-spin-button,
input.inputDisponibilidad[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: unset !important;
}
input.inputDisponibilidad[type="number"] {
    -moz-appearance: textfield !important;
}*/

.inputPositivo {
    background-color: #D1EAD6;
}

.inputNegativo {
    background-color: #FAC6C2;
}

.listaDisponibilidad {
    width: fit-content;
    display: grid;
    grid-template-columns: auto 1fr;
    position: relative;
}

    .listaDisponibilidad > :not(:first-child) {
        margin-top: 20px;
    }

.mesesHeader {
    display: flex;
    flex-direction: row;
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: white;
    grid-column: 2;
    margin-top: 0px !important;
}

.headerFila {
    text-align: center;
    background-color: white;
    font-weight: 400;
    font-size: 16px;
    position: sticky;
    top: 0;
    z-index: 11;
    min-width: 50px;
}

.disponibilidadCantidadFecha {
    display: flex;
    flex-direction: row;
    grid-column: 2;
    border-bottom: 1px solid black;
}

.fechasColor {
    display: flex;
    flex-direction: row;
}

.bodyFila {
    display: flex;
    flex-direction: row
}

.dia {
    display: flex;
    flex-direction: column;
    padding: 3px 0px;
    min-width: 30px;
    text-align: center;
    align-items: center;
}

    .dia > div {
        width: fit-content;
    }


.disponibilidadCantidadFecha > .fechasColor:nth-child(odd) {
    background-color: #C1DDDE;
}

.disponibilidadCantidadFecha > .fechasColor:nth-child(even) {
    background-color: #DDEDEE;
}


.nombreProducto {
    font-weight: 700;
    font-size: 15px;
    color: black;
    display: flex;
    align-items: end;
    justify-content: start;
    position: sticky;
    left: 0;
    background: white;
    z-index: 5;
    grid-column: 1;
    padding: 5px;
}

.dummy-header {
    background: transparent;
    z-index: 1;
}

.listaDisponibilidad > .nombreProducto:not(.dummy-header) {
    border-bottom: 1px solid black;
}

.fecha {
    font-weight: 400;
    font-size: 18px;
    color: black;
}

.inputDisponibilidad {
    width: 26px;
    height: 26px;
    text-align: center;
    border-radius: 4px;
    border: 1px solid #7E7E7E;
    font-size: 16px;
    color: black;
    font-weight: 400;
}

input.inputDisponibilidad[type="number"]::-webkit-outer-spin-button,
input.inputDisponibilidad[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: unset !important;
}

input.inputDisponibilidad[type="number"] {
    -moz-appearance: textfield !important;
}

.mudSelectDisponibilidad {
    width: 200px;
}

.modalDisponibilidad {
    min-width: 600px;
}

    .modalDisponibilidad div.mud-input > .mud-select-input {
        padding: 5px 10px !important;
    }

    .modalDisponibilidad input {
        padding: 5px 10px !important;
    }


        .modalDisponibilidad input div.mud-input-numeric-spin > button > span > svg {
            font-size: 1em !important;
        }


.wrapperEspacios {
    height: 100%;
    width: 100%;
    display: grid;
    /*    grid-template-rows: auto 1fr;*/
    grid-template-rows: 50px calc(100% - 50px);
    grid-row-gap: 10px;
    overflow-x: hidden;
}

.bodyEspacios {
    background-color: white;
    border-radius: 20px;
    padding: 10px 0px;
}

.cabeceraEspacios {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: white;
    padding: 10px;
    border-radius: 20px;
}

    .cabeceraEspacios > div {
        display: flex;
        gap: 10px;
        align-items: center;
    }

.titleEspacios p {
    font-weight: 400;
    font-size: 14px;
    color: black;
    margin-bottom: 0px;
}

    .titleEspacios p span {
        color: #BBBBBB;
    }

.cabeceraEspacios button {
    font-size: 14px;
    color: white;
    background-color: var(--colorAzulPrimary);
    font-weight: 400;
    padding: 4px 20px;
    border-radius: 20px;
    display: flex;
    justify-content: center;
    gap: 5px;
    line-height: 20px;
}

.headerBodyEspacios > div {
    display: flex;
}

.headerBodyEspacios a {
    background-color: var(--colorAzulPrimary);
    padding: 4px 20px;
    border-radius: 20px;
}

    .headerBodyEspacios a span {
        font-size: 14px;
        color: white;
    }


.cabeceraEspacios a {
    font-size: 14px;
    color: white;
    background-color: #CDD0D0;
    font-weight: 400;
    padding: 4px 20px;
    border-radius: 20px;
    display: flex;
    justify-content: center;
    gap: 5px;
    line-height: 20px;
}

.bodyEspacios {
    display: grid;
    /*    grid-template-rows: auto 1fr;*/
    grid-template-rows: 40px calc(100% - 40px);
    padding: 10px;
}

.headerBodyEspacios {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid black;
    padding-bottom: 5px;
}

.bodyBodyEspacios {
    display: grid;
    grid-template-columns: 1fr 4.5fr;
    padding-top:20px;
}

.listadoEspacios {
    height: 100%;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow-y:auto;
}

.crudEspacios {
    padding: 15px;
    background-color: var(--colorAzulPrimary);
    border-radius: 0px 20px 20px 20px;
}


.headerBodyEspacios p {
    font-weight: 400;
    font-size: 14px;
    color: black;
    margin-bottom: 0px;
}

    .headerBodyEspacios p span {
        color: #BBBBBB;
    }

.bntLeftRight {
    background-color: var(--colorAzulPrimary);
    border-radius: 50%;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 5px;
}


.cardListadoEspacios {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    border: 1px solid #C8C8C8;
    border-radius: 20px;
    padding: 10px;
    gap:10px;
    height:140px;
}

    .cardListadoEspacios.active{
        background-color:var(--colorAzulPrimary);
        border-radius: 20px 0px 0px 20px;
        border:none;
    }

.active .cardEspaciosDatas {
    border:none;
}
.cardListadoEspacios > div {
    min-height: 0;
    overflow: hidden;
}


.cardListadoEspacios > div > img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    border-radius: 12px;
}

.cardEspaciosDatas {
    display: flex;
    flex-direction: column;
    column-gap: 10px;
}

    .cardEspaciosDatas span {
        font-size: 14px;
        color: #6C6F74;
        font-weight:300;
    }
    .cardEspaciosDatas span.label {
        font-size: 14px;
        color: black;
        font-weight: 500;
    }
.active .cardEspaciosDatas span.label,
.active .cardEspaciosDatas span {
    color: white;
}

        .wrapperCrudEspacios {
            display: flex;
            gap: 20px;
            height: 100%;
            background-color: var(--colorAzulPrimary);
        }

    .wrapperCrudEspacios > div {
        background-color: white;
        border-radius: 20px;
    }

    .wrapperCrudEspacios > div {
        width: 52px;
        transition: all .35s ease;
    }

        .wrapperCrudEspacios > div.active {
            flex: 1;
        }

        .wrapperCrudEspacios > div .plegado {
            display: flex;
        }

        .wrapperCrudEspacios > div .desplegado {
            display: none;
        }

        .wrapperCrudEspacios > div.active .plegado {
            display: none;
        }

        .wrapperCrudEspacios > div.active .desplegado {
            display: flex;
            height:100%;
        }

/*            .wrapperCrudEspacios > div.active .desplegado:has(> :nth-child(2)):not(:has(> :nth-child(3))) {
                display: grid;
                height: 100%;
                grid-template-columns: auto 1fr;
            }*/

.plegado > span {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    color: var(--colorAzulPrimary);
    font-weight: 400;
    font-size: 14px;
}

.plegado {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    height: 100%;
    padding: 20px 10px;
    position: relative;
    cursor: pointer;
}

.iconEspacioTab {
    position: absolute;
    top: 20px;
}

.tablaConfiguracionEspacios {
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.tablaConfiguracionEspacios > button {
    font-weight:300;
    font-size:14px;
    color:black;
    cursor:pointer;
    border-radius: 8px;
    width:100%;
    padding:3px 0px;
}

    .tablaConfiguracionEspacios > *:nth-child(even) {
        background-color: #F4F4F4;
    }

    .tablaConfiguracionEspacios > button.active {
        background-color: #E6F1F1;
        border: 1px solid var(--colorAzulPrimary);
    }

.tablaConfiguracionEspacios {
    height: 100%;
}

.wrapperEspacios .FormularioBase > main:has(> :nth-child(4)):not(:has(> :nth-child(5))) {
    grid-template-columns: 0.5fr 2.5fr 2.5fr 1fr !important;
}

.FormularioBase main .bodyFieldSet .formularioBaseGroup .inputRangeFranjas input.mud-slider-input {
    padding: 0px !important;
    background-color: transparent;
}


.inputRangeFranjas p.mud-typography {
    font-size:12px !important;
}

.btnDelete {
    text-wrap-mode: nowrap;
    background-color: var(--colorRojoPrimary) !important;
}

.btnSimularNuevo {
    background-color: var(--colorAzulPrimary);
    padding: 4px 20px;
    border-radius: 20px;
}

    .btnSimularNuevo span {
        font-size: 14px;
        color: white;
        margin-left:5px;
    }


.textFranja {
    font-weight:400;
    font-size: 10px;
    color: #A2A2A2;
}