
@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');


/* ═══════════════════════════════════════════════════════════════
   1. RESET & BASE
   ═══════════════════════════════════════════════════════════════ */

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."
    }

.w-fit-content {
    width: fit-content !important;
}

.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;
}


/* ═══════════════════════════════════════════════════════════════
   2. VARIABLES CSS (CUSTOM PROPERTIES)
   ═══════════════════════════════════════════════════════════════ */

:root {
    --mud-palette-action-default-hover: #DCF5F6 !important;
    --mud-default-borderradius: 17px !important;
    --colorAzulPrimary: #5BB3B7;
    --colorAzulSecondary: #B8E7E9;
    --colorAzulTerciary: #DBF0F0;
    --colorAzulTerciaryTransparent: rgb(219, 240, 240, 0.3);
    --colorGrisSecondary: #CDD0D0;
    --colorGrisTerciary: #DBDBDB;
    --colorGrisQuaternary: #6C6F74;
    --colorRojoPrimary: #B7635B;
    --colorRojoSecondary: #FFD7D7;
    --colorRojoTerciary: #FFEDED;
    --sidebar-width: 235px;
    --sidebar-collapsed-width: 54px;
    --topbar-height: 40px;
    --transition-default: 0.6s ease;
    /* Disponibilidades — alturas sticky (ajustar si no encajan) */
    --disp-meses-h: 40px;
    --disp-proveedor-h: 25px;
    --disp-familia-h: 22px;
    --disp-col-left: 170px; /* ancho columna nombres — sincronizar con grid-template-columns */
}


/* ═══════════════════════════════════════════════════════════════
   3. SCROLLBAR
   ═══════════════════════════════════════════════════════════════ */

/* 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);
    }
}


/* ═══════════════════════════════════════════════════════════════
   4. LAYOUT PRINCIPAL
   ═══════════════════════════════════════════════════════════════ */

.layout {
    display: grid;
    grid-template-areas:
        "topbar topbar"
        "sidebar content";
    grid-template-columns: var(--sidebar-width) 1fr;
    grid-template-rows: var(--topbar-height) minmax(0, 1fr);
    height: 100vh;
    transition: grid-template-columns var(--transition-default);
}

    .layout.collapsed {
        grid-template-columns: var(--sidebar-collapsed-width) 1fr;
    }

.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 {
    grid-area: sidebar;
    background-color: transparent;
    color: white;
    overflow: auto;
    transition: width var(--transition-default);
    min-height: 0;
}

    .sidebar .label {
        font-size: 0.875rem;
    }

    .sidebar .submenu .label {
        font-size: 0.75rem;
    }

.content {
    grid-area: content;
    padding: 15px;
    background-color: #F5F6F7;
    min-height: 0;
    overflow: auto;
}

    .content > div {
        height: 100%;
        width: 100%;
    }

.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) .icon-wrapper {
        border: none;
    }


/* ═══════════════════════════════════════════════════════════════
   5. MENÚ LATERAL
   ═══════════════════════════════════════════════════════════════ */

.menu {
    list-style: none;
    padding: 7px 0;
    margin-bottom: 0;
}

    .menu li {
        width: 100%;
        padding: 7px 10px;
    }

.submenu li {
    padding: 0;
}

.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;
}

    .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);
    }

.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 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);
}

.menu a:hover .icon-wrapper,
.menu-parent:hover .icon-wrapper {
    background-color: transparent;
}

/* 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 0 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;
}

.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 var(--transition-default);
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 14px 10px 0 10px;
}

    .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;
}

.label {
    text-wrap-mode: nowrap;
    font-size: 16px;
}

.submenu .label {
    font-size: 14px;
    color: var(--colorAzulPrimary);
}


/* ═══════════════════════════════════════════════════════════════
   6. DROPDOWN DE USUARIO
   ═══════════════════════════════════════════════════════════════ */

.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;
        }


/* ═══════════════════════════════════════════════════════════════
   7. HEADER PRINCIPAL (MUDBLAZOR)
   ═══════════════════════════════════════════════════════════════ */

.headerMudAppBar > div.mud-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.mudAppBarMenuIcon {
    background-color: white !important;
}

.hamburguesaIconMenu,
.hamburguesaIconMenu path {
    fill: white;
    width: 20px;
}

.loginIconMenu,
.loginIconMenu path {
    fill: white;
}

#blazor-error-ui {
    background-color: var(--colorAzulPrimary);
}


/* ═══════════════════════════════════════════════════════════════
   8. CONTENIDO PRINCIPAL (HEADER PÁGINAS)
   ═══════════════════════════════════════════════════════════════ */

.wrapperEspacios .headerMainContent {
    padding: 5px 15px 0 15px;
}

.headerMainContent {
    padding: 10px 15px 0 15px;
    width: 100%;
    height: auto;
    display: grid;
    grid-template-columns: auto auto;
}

    .headerMainContent > .containerFiltersMainContent {
        display: flex;
        gap: 10px;
        /*        align-items: end;*/
        align-items: center;
    }

        .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;
}

.indexReservas .searchFilter > * {
    width: 180px;
}


.searchFilter > .RangoFechas {
    flex: 1.5;
}

.searchFilter > .mud-select > .mud-input-control.mud-select > .mud-input-control-input-container > div.mud-input > .mud-input-adornment {
    padding: 0 !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;
    margin-top: 5px;
}

    .headerMainContent > .containerFiltersMainContent > .textFilter fieldset {
        border: 1px solid var(--colorAzulPrimary);
    }

    .headerMainContent > .containerFiltersMainContent > .textFilter .textFilterMudInput input {
        padding: 4px 0 4px 15px !important;
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
    }

.headerMainContent > .containerBtnsMainContent {
    display: flex;
    justify-content: end;
    gap: 10px;
    padding-top: 8px;
    align-items: center;
}

    .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;
        align-items: center;
        gap: 5px;
        line-height: 20px;
        transition: filter 0.15s ease, transform 0.1s ease;
        cursor: pointer;
    }

    .headerMainContent > .containerBtnsMainContent > button:hover,
    .headerMainContent > .containerBtnsMainContent > a:hover,
    .btnAddFkEntity:hover,
    .btnDeleteFilters:hover {
        filter: brightness(0.88);
    }

    .headerMainContent > .containerBtnsMainContent > button:active,
    .headerMainContent > .containerBtnsMainContent > a:active,
    .btnAddFkEntity:active,
    .btnDeleteFilters:active {
        filter: brightness(0.75);
        transform: scale(0.96);
    }

.returnBtn {
    background-color: var(--colorGrisSecondary) !important;
}

.separadorHeaderBodyCrud {
    display: flex;
    width: 100%;
    align-items: center;
    padding: 0 15px;
    height: 15px;
}

    .separadorHeaderBodyCrud > div {
        background-color: black;
        height: 1px;
        width: 100%;
    }

.headerMainContent > .containerFiltersMainContent > .searchFilter > div.mud-select .mud-input-control.mud-input-outlined-with-label {
    margin-bottom: 0;
}


/* ═══════════════════════════════════════════════════════════════
   9. FORMULARIOBASE (CRUDS)
   ═══════════════════════════════════════════════════════════════ */

.FormularioBase {
    height: 100%;
    width: 100%;
    background-color: white;
    border-radius: 20px;
    position: relative;
}

.skPage {
    background-color: white;
    border-radius: 20px;
}

.wrapperEspacios .FormularioBase > main {
    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: 15px;
    height: calc(100% - 70px);
    overflow-y: auto;
    overflow-x: hidden;
    transition: grid-template-columns 0.35s ease;
}

    .FormularioBase > main.mainUsuarios {
        grid-template-columns: 1fr 300px;
    }

.headerFieldSet {
    display: flex;
}

.FormularioBase > main > fieldset {
    height: 100%;
}

    .FormularioBase > main > fieldset > .headerFieldSet.ayuda {
        border-bottom: 1px solid var(--colorAzulPrimary) !important;
    }

    .FormularioBase > main > fieldset > .headerFieldSet > legend,
    .legenConfiguracion {
        font-size: 14px;
        font-weight: 400;
        color: black;
    }

.filedsetHeaderDecoration {
    border-radius: 20px 20px 0 0 !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: 0 0 20px 20px;
    border: 1px solid var(--colorAzulPrimary);
}

.FormularioBase > main > fieldset:has(> .headerFieldSet.ayuda) {
    position: sticky;
    top: 0;
    align-self: start;
    height: auto;
    max-height: calc(100vh - var(--topbar-height) - 30px);
    overflow-y: auto;
    opacity: 1;
    transition: opacity 0.25s ease;
}

/* Toggle ayuda: contraer columna con transición */
.FormularioBase > main.sinAyuda {
    grid-template-columns: repeat(2, 1fr) 0px;
}

.FormularioBase > main.mainUsuarios.sinAyuda {
    grid-template-columns: 1fr 0px;
}

.wrapperEspacios .FormularioBase > main.sinAyuda {
    grid-template-columns: 2.5fr 2.5fr 0fr;
}

.FormularioBase > main.sinAyuda > fieldset:has(> .headerFieldSet.ayuda) {
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
}

.wrapperEspacios .FormularioBase > main:has(> :nth-child(4)):not(:has(> :nth-child(5))) {
    grid-template-columns: minmax(0, 0.5fr) 2.5fr 2.5fr 1fr !important;
}

.wrapperEspacios .FormularioBase > main.sinAyuda:has(> :nth-child(4)):not(:has(> :nth-child(5))) {
    grid-template-columns: minmax(0, 0.5fr) 2.5fr 2.5fr 0fr !important;
}


/* ═══════════════════════════════════════════════════════════════
   10. GRUPOS Y CAMPOS DE FORMULARIO
   ═══════════════════════════════════════════════════════════════ */

.formularioBaseGroup {
    padding: 10px 0;
    display: flex;
    flex-direction: column;
}

.formularioBaseGroupColumn,
.formularioBaseGroupColumnModal {
    padding: 10px 0;
    display: flex;
    gap: 10px;
}

    .formularioBaseGroupColumn > div,
    .formularioBaseGroupColumnModal > div {
        flex: 1;
    }

/* Label estándar de formulario */
.labelFormulario {
    color: black;
    font-size: 14px;
    font-weight: 500;
}

/* Picker con fondo blanco dentro de campos */
.bodyFieldSet .mud-picker,
.bodyFieldSet .mud-input {
    background-color: white;
    border-radius: 20px;
}

/* Spinner numérico */
.bodyFieldSet .mud-input-numeric-spin,
.modalFormularioBase .mud-input-numeric-spin {
    padding-right: 10px;
}

.bodyFieldSet div.mud-input-numeric-spin > button > span > svg {
    font-size: 1em;
}

.modalFormularioBase {
    min-width: 500px;
}


/* ═══════════════════════════════════════════════════════════════
   11. AYUDA CONTEXTUAL (CRUDs)
   ═══════════════════════════════════════════════════════════════ */

.ayudaFormularioBase {
    padding: 10px 0;
    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;
}

/* TabLangs: estados de error en pestañas */
.enlacesFieldset {
    margin: 20px 0;
}

    .enlacesFieldset .mud-toggle-item-selected {
        background-color: var(--colorAzulTerciary) !important;
    }

    .textosFieldset:has(.tab-textos.es .validation-message) .tab-error.es,
    .textosFieldset:has(.tab-textos.en .validation-message) .tab-error.en,
    .enlacesFieldset:has(.tab-enlaces.enlaceExterno .validation-message) .tab-error.enlaceExterno,
    .enlacesFieldset:has(.tab-enlaces.enlaceFacebook .validation-message) .tab-error.enlaceFacebook,
    .enlacesFieldset:has(.tab-enlaces.enlaceInstagram .validation-message) .tab-error.enlaceInstagram,
    .enlacesFieldset:has(.tab-enlaces.enlaceYoutube .validation-message) .tab-error.enlaceYoutube,
    .enlacesFieldset:has(.tab-enlaces.enlaceLinkedin .validation-message) .tab-error.enlaceLinkedin {
        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,
        .enlacesFieldset:has(.tab-enlaces.enlaceExterno .validation-message) .tab-error.enlaceExterno.mud-toggle-item-selected,
        .enlacesFieldset:has(.tab-enlaces.enlaceFacebook .validation-message) .tab-error.enlaceFacebook.mud-toggle-item-selected,
        .enlacesFieldset:has(.tab-enlaces.enlaceInstagram .validation-message) .tab-error.enlaceInstagram.mud-toggle-item-selected,
        .enlacesFieldset:has(.tab-enlaces.enlaceYoutube .validation-message) .tab-error.enlaceYoutube.mud-toggle-item-selected,
        .enlacesFieldset:has(.tab-enlaces.enlaceLinkedin .validation-message) .tab-error.enlaceLinkedin.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,
    .enlacesFieldset:has(.tab-enlaces.enlaceExterno .validation-message) .tab-enlaces.enlaceExterno.tab-visible,
    .enlacesFieldset:has(.tab-enlaces.enlaceFacebook .validation-message) .tab-enlaces.enlaceFacebook.tab-visible,
    .enlacesFieldset:has(.tab-enlaces.enlaceInstagram .validation-message) .tab-enlaces.enlaceInstagram.tab-visible,
    .enlacesFieldset:has(.tab-enlaces.enlaceYoutube .validation-message) .tab-enlaces.enlaceYoutube.tab-visible,
    .enlacesFieldset:has(.tab-enlaces.enlaceLinkedin .validation-message) .tab-enlaces.enlaceLinkedin.tab-visible {
        background-color: var(--colorRojoSecondary) !important;
    }


/* ═══════════════════════════════════════════════════════════════
   12. TABLAS DE ÍNDICE
   ═══════════════════════════════════════════════════════════════ */

.indexTableBase {
    height: 100%;
}

    .indexTableBase .mud-table-container {
        height: calc(100vh - 40px - 30px - 50px - 52px);
        border-radius: 20px;
        padding: 0 15px;
    }

    .indexTableBase .mud-table-cell {
        padding: 4px 12px !important;
        font-size: 12px;
        text-wrap-mode: nowrap;
    }

    .indexTableBase > .mud-toolbar {
        padding: 0;
        height: fit-content;
    }

.mud-table-cell {
    border: none;
}

.mud-table-head {
    border-bottom: 1px solid #000;
}

    .mud-table-head span {
        font-size: 0.875rem;
    }

/* Botones de acción en tabla */
.containerActionsIndexTable {
    display: flex;
    justify-content: end;
    align-items: center;
    column-gap: 8px;
    border-radius: 0 !important;
}

    .containerActionsIndexTable > .btnTableDefault {
        border-radius: 5px;
        background-color: var(--colorAzulPrimary);
        height: 25px;
        width: 25px;
        padding: 5px;
        display: flex;
        justify-content: center;
        align-items: center;
        color: white;
        font-size: 14px;
        transition: filter 0.15s ease, transform 0.1s ease;
        cursor: pointer;
    }

        .containerActionsIndexTable > .btnTableDefault:hover {
            filter: brightness(0.88);
        }

        .containerActionsIndexTable > .btnTableDefault:active {
            filter: brightness(0.75);
            transform: scale(0.9);
        }

        .containerActionsIndexTable > .btnTableDefault.delete {
            background-color: var(--colorRojoPrimary);
        }

        .containerActionsIndexTable > .btnTableDefault > img {
            object-fit: contain;
            fill: white;
        }

    .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;
    }

.SimpleTableCurdFk {
    border-radius: 0;
    border-top: 1px solid var(--colorAzulPrimary);
}


/* ═══════════════════════════════════════════════════════════════
   13. ARCHIVOS Y DOCUMENTOS
   ═══════════════════════════════════════════════════════════════ */

.wrapperArchivos {
    display: flex;
    background-color: white;
    border-radius: 12px;
    padding: 5px;
    position: relative;
    min-height: 110px;
    margin-top: 10px;
}

    .wrapperArchivos .containerImgs {
        display: flex;
        gap: 5px;
    }

.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;
}

.btnAddArchivos {
    margin-left: 20px;
    background-color: var(--colorAzulPrimary);
    height: 20px;
    width: 20px;
    border-radius: 50%;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translate(-50%, -50%);
}

    .btnAddArchivos svg {
        width: 100%;
        font-size: inherit !important;
        fill: white;
    }

    .btnAddArchivos:hover {
        box-shadow: 0 0 0 6px rgba(91, 179, 183, 0.4);
    }

    .btnAddArchivos:disabled {
        box-shadow: none;
        cursor: not-allowed;
    }

.imgArchivos {
    width: 100%;
    height: 60px;
    object-fit: cover;
    border-radius: 10px 10px 0 0;
}

.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: 0;
        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);
        }

        .containerBtnsArchivos button:disabled,
        .containerBtnsArchivos a:disabled {
            box-shadow: none;
            transform: 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;
    }

.containerDocumento {
    background-color: white;
    width: 100%;
    padding: 10px;
    border-radius: 10px;
    margin-top: 10px;
}

    .containerDocumento > div {
        background-color: #F4F4F4;
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        padding: 10px;
    }

.mp4,
.pdf {
    background-image: url("media/img/pdf.jpg");
    background-position: center center;
    background-size: 100%;
    background-repeat: no-repeat;
    flex-direction: column-reverse;
}


/* ═══════════════════════════════════════════════════════════════
   14. LISTA DE ELEMENTOS RELACIONADOS
   ═══════════════════════════════════════════════════════════════ */

.listaElementosRelacionados {
    background-color: white;
    width: 100%;
    padding: 10px;
    border-radius: 20px;
    margin-top: 10px;
    position: relative;
    min-height: 45px;
    display: grid;
    grid-template-columns: 150px 150px 150px;
    gap: 10px;
}

.elementoRelacionado {
    background-color: var(--colorAzulTerciary);
    border-radius: 20px;
    padding: 0 10px 0 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;
        }


/* ═══════════════════════════════════════════════════════════════
   15. MODALES — BASE
   ═══════════════════════════════════════════════════════════════ */

.btnDefault {
    padding: 5px 30px;
    color: white;
    border-radius: 20px;
    font-size: 16px;
    font-weight: 400;
}

.btnGuardar {
    flex: 1;
    background-color: var(--colorAzulPrimary);
    transition: filter 0.15s ease, transform 0.1s ease;
    cursor: pointer;
}

    .btnGuardar:hover { filter: brightness(0.88); }
    .btnGuardar:active { filter: brightness(0.75); transform: scale(0.97); }

.btCancelar {
    flex: 1;
    background-color: var(--colorGrisSecondary);
    transition: filter 0.15s ease, transform 0.1s ease;
    cursor: pointer;
}

    .btCancelar:hover { filter: brightness(0.88); }
    .btCancelar:active { filter: brightness(0.75); transform: scale(0.97); }

.modalDelete {
    height: 250px;
    width: 425px;
    padding: 20px;
}

    .modalDelete h6 {
        text-align: center;
        border-bottom: 1px solid var(--colorAzulPrimary);
        padding-bottom: 10px;
    }

/* MudBlazor: título del modal */
.mud-dialog-title {
    padding: 16px 24px 8px 24px !important;
}

    .mud-dialog-title .btnDefault {
        font-size: 14px;
        padding: 4px 20px;
        line-height: 20px;
        text-wrap-mode: nowrap;
    }

/* Anchuras mínimas por modal */
.mud-dialog.modalCaracteristica,
.mud-dialog.modalProductosRelacionados,
.mud-dialog.modalProductosEstablecimiento,
.mud-dialog.modalCrearElementos {
    min-width: min(900px, 95vw);
}

.mud-dialog.modalUsuarioProducto {
    min-width: min(600px, 95vw);
}


/* ═══════════════════════════════════════════════════════════════
   16. MODALES — AYUDA CONTEXTUAL
   ═══════════════════════════════════════════════════════════════ */

.modalConAyuda {
    border-top: 1px solid black;
    padding-top: 24px;
    position: relative;
    overflow: hidden;
    padding-right: 274px;
    transition: padding-right 0.35s ease;
}

    .modalConAyuda.sinAyuda {
        padding-right: 0;
    }

.containerDoubleColumnModal {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.modalConAyudaAyuda {
    position: absolute;
    top: 0;
    right: 0;
    width: 250px;
    height: 100%;
    overflow-y: auto;
    border-left: 1px solid #e0e0e0;
    padding-left: 20px;
    opacity: 1;
    transition: opacity 0.35s ease, transform 0.35s ease;
}

.modalConAyuda.sinAyuda .modalConAyudaAyuda {
    opacity: 0;
    pointer-events: none;
    transform: translateX(270px);
}

/* Grid interior del fieldset principal del modal */
.modalConAyuda .bodyFieldSet {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
}

/* Fieldset de configuración (columna derecha) */
.fieldSetConfiguracion {
    background-color: var(--colorAzulTerciary);
    padding: 10px;
    border: 1px solid var(--colorAzulPrimary);
    border-radius: 0 0 20px 20px;
}

/* Cabecera de ayuda */
.modalConAyuda .cabeceraAyuda {
    border-bottom: 1px solid var(--colorAzulPrimary) !important;
    margin-bottom: 15px;
}

    .modalConAyuda .cabeceraAyuda legend {
        font-size: 14px;
        font-weight: 400;
        color: black;
    }

/* Botones ES/EN del TabLangs en modales → gestionado con ::deep en TabLangs.razor.css */


/* ═══════════════════════════════════════════════════════════════
   17. DISPONIBILIDADES
   ═══════════════════════════════════════════════════════════════ */

.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 0 5.5px 10px !important;
    }

.headerDisponibilidad {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: space-between;
}

    .headerDisponibilidad > div {
        display: flex;
        gap: 10px;
        justify-content: end;
    }

.bodyDisponibilidad {
    width: 100%;
    overflow: auto;
}

.inputPositivo {
    background-color: #D1EAD6;
}

.inputNegativo {
    background-color: #FAC6C2;
}

.listaDisponibilidad {
    width: fit-content;
    display: grid;
    grid-template-columns: var(--disp-col-left) 1fr;
    position: relative;
}

    .listaDisponibilidad > :not(:first-child) {
        margin-top: 0px;
    }

.mesesHeader {
    display: flex;
    flex-direction: row;
    position: sticky;
    top: 0;
    z-index: 20;
    background-color: white;
    grid-column: 2;
    margin-top: 0 !important;
}

.headerFila {
    display: flex;
    flex-direction: column;
    background-color: white;
}

.headerMesNombre {
    text-align: center;
    font-weight: 600;
    font-size: 13px;
    padding: 2px 0;
    text-wrap-mode: nowrap;
}

.headerDias {
    display: flex;
    flex-direction: row;
}

.headerDia {
    min-width: 30px;
    text-align: center;
    font-weight: 400;
    font-size: 14px;
}

.headerFila:nth-child(odd) .headerDias {
    background-color: #C1DDDE;
}

.headerFila:nth-child(even) .headerDias {
    background-color: #DDEDEE;
}

.mesesFooter {
    display: flex;
    flex-direction: row;
    position: sticky;
    bottom: 0;
    z-index: 20;
    background-color: white;
    grid-column: 2;
    margin-bottom: 0 !important;
}

.dummy-footer {
    grid-column: 1;
    position: sticky;
    left: 0;
    bottom: 0;
    background: white;
    z-index: 99;
}

.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 0;
    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: center;
    justify-content: space-between;
    position: sticky;
    left: 0;
    background: white;
    z-index: 5;
    grid-column: 1;
    padding: 5px;
    border-bottom: 1px solid black;
}

    .nombreProducto .btnTableDefault {
        border-radius: 5px;
        background-color: var(--colorAzulPrimary);
        height: 25px;
        width: 25px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        margin-left: 4px;
    }

.dummy-header {
    grid-column: 1;
    position: sticky;
    left: 0;
    top: 0;
    background: white;
    z-index: 99;
}

/* ── Cabeceras de grupo: fila completa sticky-top + texto sticky-left ── */

.proveedorHeaderRow {
    grid-column: 1 / -1;
    position: sticky;
    top: var(--disp-meses-h);
    z-index: 9;
    background-color: var(--colorAzulPrimary);
    display: flex;
    align-items: center;
    min-height: var(--disp-proveedor-h);
}

.proveedorHeaderText {
    position: sticky;
    left: 0;
    color: white;
    font-weight: 700;
    font-size: 13px;
    padding: 4px 10px;
    white-space: nowrap;
}

.familiaHeaderRow {
    grid-column: 1 / -1;
    position: sticky;
    top: calc(var(--disp-meses-h) + var(--disp-proveedor-h));
    z-index: 8;
    background-color: var(--colorAzulSecondary);
    display: flex;
    align-items: center;
    min-height: var(--disp-familia-h);
}

.familiaHeaderText {
    position: sticky;
    left: 0;
    color: var(--colorAzulPrimary);
    font-weight: 600;
    font-size: 12px;
    padding: 3px 10px 3px 20px;
    white-space: nowrap;
}

.tipoHeaderRow {
    grid-column: 1 / -1;
    position: sticky;
    top: calc(var(--disp-meses-h) + var(--disp-proveedor-h) + var(--disp-familia-h));
    z-index: 7;
    background-color: var(--colorAzulTerciary);
    display: flex;
    align-items: center;
    min-height: 17px;
}

.tipoHeaderText {
    position: sticky;
    left: 0;
    color: var(--colorGrisQuaternary);
    font-weight: 500;
    font-size: 11px;
    padding: 3px 10px 3px 32px;
    white-space: nowrap;
}

.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;
}

/* Modal de disponibilidad */
.modalDisponibilidad {
    min-width: min(900px, 95vw) !important;
}

    .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;
        }

/* Filtros de fecha de disponibilidad */
.searchFilter > .FiltroFechasDisponibilidad {
    width: 300px;
}

/* Modal info producto */
.modalInfoProducto {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.infoProductoGrid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 8px 16px;
    margin-bottom: 10px;
}

.infoProductoItem {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.infoProductoLabel {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--colorGrisTerciary, #888);
    letter-spacing: 0.04em;
}

.infoProductoValor {
    font-size: 14px;
    color: var(--colorGrisPrimary, #333);
}

.infoProductoSeccion {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.infoProductoTexto {
    font-size: 14px;
    color: var(--colorGrisPrimary, #333);
    line-height: 1.5;
}

.infoProductoSubseccion {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.infoProductoTabla {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

    .infoProductoTabla th {
        background-color: var(--colorAzulSecondary, #e0f0f2);
        color: var(--colorAzulPrimary, #1a6a7a);
        font-weight: 600;
        padding: 6px 10px;
        text-align: left;
        border-bottom: 2px solid var(--colorAzulPrimary, #1a6a7a);
    }

    .infoProductoTabla td {
        padding: 5px 10px;
        border-bottom: 1px solid #e0e0e0;
        vertical-align: top;
    }

    .infoProductoTabla tr:last-child td {
        border-bottom: none;
    }

    .infoProductoTabla tr:nth-child(even) td {
        background-color: #f9f9f9;
    }

.FiltroFechasDisponibilidad {
    padding-left: 14px;
}

    .FiltroFechasDisponibilidad input.mud-input-slot.mud-input-root {
        width: 90px !important;
    }

    .FiltroFechasDisponibilidad button.mud-button-root.mud-icon-button {
        margin: 0 12px 0 0;
        padding: 0;
    }

    .FiltroFechasDisponibilidad input.FiltroFechasDisponibilidad {
        padding: 5.5px !important;
    }

    .FiltroFechasDisponibilidad .mud-input-control {
        margin-bottom: 0 !important;
    }

.searchFilter div.mud-autocomplete input.mud-select-input {
    padding: 5.5px !important;
}

.searchFilter div.mud-select:not(.mud-autocomplete) .mud-input-slot.mud-select-input {
    padding: 5.5px 14px !important;
    min-height: auto !important;
}

.datePickerRange div.mud-input {
    background-color: white;
    border-radius: 20px;
}

/*.datePickerRange > .mud-input-control.mud-input-control-margin-dense {
    margin: 0px;
}*/

.productoDestacado {
    background-color: #e8f4f5 !important;
    outline: 2px solid var(--colorAzulPrimary);
}

/* ── Opción A: vertical (activa por defecto) ── */
/*.infoProducto {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}*/

/* ── Badges en columna: nombre arriba, tipo+familia debajo en fila ── */
.infoProducto {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}

.infoProductoBadges {
    display: flex;
    flex-direction: row;
    gap: 3px;
    align-items: center;
}


.productoNombre {
    font-weight: 700;
    font-size: 14px;
    color: black;
}

.infoProductoBadge {
    font-size: 9px;
    font-weight: 500;
    border-radius: 3px;
    padding: 0px 4px;
    white-space: nowrap;
    color: white;
}

.infoBadgeTipo {
    background-color: var(--colorAzulPrimary);
}

.infoBadgeFamilia {
    background-color: #7E7E7E;
}

/* ═══════════════════════════════════════════════════════════════
   18. ESPACIOS
   ═══════════════════════════════════════════════════════════════ */
.wrapperEspacios {
    height: 100%;
    width: 100%;
    display: grid;
    grid-template-rows: 50px calc(100% - 50px);
    grid-row-gap: 10px;
}

.bodyEspacios {
    padding: 0 10px;
    background-color: transparent;
}

.contentBodyEspacios {
    background-color: white;
    border-radius: 20px;
    height: 100%;
    display: grid;
    grid-template-rows: 40px calc(100% - 40px);
    padding: 10px;
}

.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;
    }

    .cabeceraEspacios button,
    .cabeceraEspacios a {
        font-size: 14px;
        color: white;
        font-weight: 400;
        padding: 4px 20px;
        border-radius: 20px;
        display: flex;
        justify-content: center;
        gap: 5px;
        line-height: 20px;
    }

    .cabeceraEspacios button {
        background-color: var(--colorAzulPrimary);
    }

    .cabeceraEspacios a {
        background-color: #CDD0D0;
    }

.titleEspacios p {
    font-weight: 400;
    font-size: 14px;
    color: black;
    margin-bottom: 0;
}

    .titleEspacios p span {
        color: #BBBBBB;
    }

.headerBodyEspacios {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid black;
    padding-bottom: 5px;
}

    .headerBodyEspacios > div {
        display: flex;
    }

    .headerBodyEspacios a {
        background-color: var(--colorAzulPrimary);
        padding: 4px 20px;
        border-radius: 20px;
    }

        .headerBodyEspacios a span {
            font-size: 14px;
            color: white;
        }

    .headerBodyEspacios p {
        font-weight: 400;
        font-size: 14px;
        color: black;
        margin-bottom: 0;
    }

        .headerBodyEspacios p span {
            color: #BBBBBB;
        }

.bodyBodyEspacios {
    display: grid;
    grid-template-columns: 1fr 12fr;
    padding-top: 20px;
}

.listadoEspacios {
    height: 100%;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.crudEspacios {
    padding: 15px;
    background-color: var(--colorAzulPrimary);
    border-radius: 0 20px 20px 20px;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.bntLeftRight {
    background-color: var(--colorAzulPrimary);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 5px;
}

.bntLeftRight .mud-icon-root,
.bntLeftRight svg {
    width: 22px;
    height: 22px;
    font-size: 22px;
}

.cardListadoEspacios {
    display: grid;
    border: 1px solid #C8C8C8;
    border-radius: 20px 0 0 20px;
    padding: 5px 10px;
    height: auto;
}

    .cardListadoEspacios.active {
        background-color: var(--colorAzulPrimary);
        border: 1px solid var(--colorAzulPrimary);
    }

.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;
        width: 52px;
        transition: all .35s ease;
    }

        .wrapperCrudEspacios > div.active {
            flex: 1;
            overflow: hidden;
        }

        .wrapperCrudEspacios > div .plegado {
            display: flex;
        }

        .wrapperCrudEspacios > div .desplegado {
            display: none;
        }

        .wrapperCrudEspacios > div.active .plegado {
            display: none;
        }

        .wrapperCrudEspacios > div.active .desplegado {
            display: flex;
            height: 100%;
        }

.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;
}

    .tablaConfiguracionEspacios > button {
        font-weight: 300;
        font-size: 14px;
        color: black;
        cursor: pointer;
        border-radius: 8px;
        width: 100%;
        padding: 3px 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .tablaConfiguracionEspacios > *:nth-child(even) {
        background-color: #F4F4F4;
    }

    .tablaConfiguracionEspacios > button.active {
        background-color: #E6F1F1;
        border: 1px solid var(--colorAzulPrimary);
    }

/* Franjas horarias */
.FormularioBase main .bodyFieldSet .formularioBaseGroup .inputRangeFranjas input.mud-slider-input {
    padding: 0 !important;
    background-color: transparent;
}

.inputRangeFranjas {
    margin-bottom: 20px;
}

    .inputRangeFranjas p.mud-typography {
        font-size: 12px !important;
    }

.textFranja {
    font-weight: 400;
    font-size: 10px;
    color: #A2A2A2;
}

/* Botones especiales de espacios */
.btnDelete {
    text-wrap-mode: nowrap;
    background-color: var(--colorRojoPrimary) !important;
}

.btnSimularNuevo {
    background-color: var(--colorAzulPrimary);
    padding: 4px 20px;
    border-radius: 20px;
    margin-right: 10px;
}

    .btnSimularNuevo span {
        font-size: 14px;
        color: white;
        margin-left: 5px;
    }

.conf {
    background-color: var(--colorAzulSecondary) !important;
}


/* ═══════════════════════════════════════════════════════════════
   19. LOGIN
   → Todos los estilos están en Login.razor.css (scoped al componente)
   ═══════════════════════════════════════════════════════════════ */


/* ═══════════════════════════════════════════════════════════════
   20. MUDBLAZOR OVERRIDES & UTILIDADES
   ═══════════════════════════════════════════════════════════════ */

.bodyFieldSet input[type="number"],
.bodyFieldSet input[type="text"],
.bodyFieldSet input[type="email"],
.bodyFieldSet input[type="password"],
.login-box input[type="text"],
.login-box input[type= "password"] {
    background-color: white !important;
    padding: 5.5px 15px !important;
    border-radius: 20px;
}

.tab-textos input[type="text"],
.tab-textos textarea {
    padding: 0px !important;
    margin: 0px !important;
    border-radius: 0px !important;
}

.tab-textos div.mud-input.mud-input-sizing-fixed {
    background-color: white !important;
    padding: 5.5px 15px !important;
    border-radius: 20px;
}

.bodyFieldSet label {
    color: black;
    font-size: 14px;
    font-weight: 500;
}

.bodyFieldSet div.mud-select,
.bodyFieldSet div.mud-select.mud-autocomplete {
    border-radius: 20px;
    background-color: white;
}

/*.bodyFieldSet .mud-input-control.mud-input-control-margin-dense {
    margin: 0px !important;
}*/


.mud-icon-root {
    width: 0.7em;
}

.mud-input-slot::placeholder {
    font-size: 0.875rem;
    font-weight: 300;
}

.mud-popover {
    border-radius: 20px;
}

.mud-icon-button {
    padding: 3px 6px;
}

/* MudMessageBox — botones con el mismo estilo que los modales */
.mud-message-box .mud-dialog-actions .mud-button-root {
    padding: 5px 30px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    color: white !important;
    text-transform: none;
    box-shadow: none !important;
}

.mud-message-box .mud-dialog-actions .mud-button-filled-primary,
.mud-message-box .mud-dialog-actions .mud-button-text-primary {
    background-color: var(--colorAzulPrimary) !important;
}

.mud-message-box .mud-dialog-actions .mud-button-text-default,
.mud-message-box .mud-dialog-actions .mud-button-outlined-default,
.mud-message-box .mud-dialog-actions .mud-button-filled-default {
    background-color: var(--colorGrisSecondary) !important;
}

.simple-editor-container,
.ql-toolbar {
    background-color: white !important;
    margin-top: 4px;
}

.ql-toolbar {
    border-radius: 20px 20px 0 0;
}

.ql-editor {
    min-height: 6em !important;
}

.simple-editor-container {
    border-radius: 0 0 20px 20px;
}

.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;
    }

.FillWhite,
.FillWhite svg,
.FillWhite path {
    fill: white !important;
}

.borderRadius20 {
    border-radius: 20px;
}


/*.modalDisponibilidad .tab-textos {
    background-color: white !important;
}


    .modalDisponibilidad .tab-textos input,
    .modalDisponibilidad .tab-textos textarea {
        background-color: var(--colorAzulTerciary) !important;
    }
*/
.text-transform-none {
    text-transform: none;
}

/* ═══════════════════════════════════════════════════════════════
   DISPONIBILIDAD HORARIA — tablero de ocupación
   ═══════════════════════════════════════════════════════════════ */

.disponibilidadHorariaDetalleWrapper {
    display: flex;
    flex-direction: column;
    height: 100%;
    gap: 12px;
    padding: 12px;
    box-sizing: border-box;
}

.disponibilidadHorariaTablerWrapper {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    background-color: white;
    border-radius: 12px;
    overflow: hidden;
    padding: 16px;
    gap: 15px;
}

.headerDisponibilidadHoraria {
    display: flex;
    align-items: center;
    justify-content: space-between;
    /*    padding: 10px 16px;*/
    padding-bottom: 10px;
    flex-shrink: 0;
    border-bottom: 1px solid var(--colorGrisTerciary);
}

    .headerDisponibilidadHoraria h2 {
        font-size: 14px;
        font-weight: 400;
        color: black;
        line-height: 2px;
    }

.disponibilidadHorariaDetalleControls {
    display: flex;
    align-items: center;
    gap: 10px;
}

.disponibilidadHorariaEspacioPicker {
    width: 200px;
}

    .disponibilidadHorariaEspacioPicker .mud-input-control {
        margin-bottom: 0 !important;
    }

    .disponibilidadHorariaEspacioPicker div.mud-input-slot.mud-select-input {
        padding: 5.5px;
    }

.disponibilidadHorariaFechaPicker {
    width: 160px;
    padding-bottom: 4px;
}

    .disponibilidadHorariaFechaPicker .mud-input-control {
        margin-bottom: 0 !important;
    }

    .disponibilidadHorariaFechaPicker button.mud-button-root.mud-icon-button {
        margin: 0 4px 0 0;
        padding: 0;
    }

    .disponibilidadHorariaFechaPicker input {
        padding-top: 5.5px !important;
        padding-bottom: 5.5px !important;
    }

.disponibilidadHorariaTableScroll {
    flex: 1;
    overflow-x: auto;
    overflow-y: auto;
}

/* Contenedor flex de tablas por servicio */
.disponibilidadHorariaTablesContainer {
    display: flex;
    align-items: flex-start;
}

    /* Espacio entre tablas de servicio (no afecta a la tabla de elementos) */
    .disponibilidadHorariaTablesContainer .disponibilidadHorariaTable + .disponibilidadHorariaTable {
        margin-left: 40px;
    }

/* Tabla de elementos — sticky a la izquierda */
.disponibilidadHorariaTableElementos {
    position: sticky;
    left: 0;
    z-index: 2;
    background-color: white;
    border-collapse: collapse;
    white-space: nowrap;
    font-size: 12px;
    flex-shrink: 0;
}

/* ── Tabla de servicio ── */
.disponibilidadHorariaTable {
    border-collapse: collapse;
    white-space: nowrap;
    font-size: 12px;
}

/* Columna de nombres de elemento */
.thElemento,
.tdElemento {
    min-width: 250px;
    max-width: 250px;
    background-color: white;
    padding: 0 4px;
    font-size: 12px;
    vertical-align: middle;
    height: 28px;
}

.thElemento {
    background-color: white;
    font-weight: 600;
    padding: 0 8px;
}

/* Contenido interior con colores alternos y border-radius */
.tdElementoContenido {
    border-radius: 8px;
    padding: 2px 8px;
    font-weight: 300;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: flex;
    justify-content: space-between;
}

tr:nth-child(even) .tdElementoContenido {
    background-color: #F4F4F4;
}

/* Columnas alternas del tablero horario */
.disponibilidadHorariaTable col.colFranjaPar {
    background-color: #F4F4F4;
}

.disponibilidadHorariaTable col.colFranjaImpar {
    background-color: white;
}

/* Cabecera de servicio */
.thServicio {
    background-color: #D0E8E9;
    color: black;
    font-weight: 400;
    font-size: 14px;
    text-align: center;
    padding: 6px 0px;
    border-radius: 9px 9px 0px 0px;
    height: 30px;
}

/* Botones de acción inline (editar / eliminar / clonar) en elementos y servicios */
.btnAccionDisponibilidad {
    background: none;
    border: none;
    padding: 0 2px;
    cursor: pointer;
    vertical-align: middle;
    line-height: 1;
    font-size: 18px;
    opacity: 0.65;
    transition: color 0.15s ease, opacity 0.15s ease, transform 0.1s ease;
}

    .btnAccionDisponibilidad:hover {
        opacity: 1;
        color: var(--colorAzulPrimary);
    }

    .btnAccionDisponibilidad:active {
        opacity: 1;
        color: var(--colorAzulPrimary);
        transform: scale(0.82);
    }

/* Separador y botones en la columna de elementos */
.disponibilidadAcciones {
    white-space: nowrap;
    font-size: 11px;
    color: var(--colorGrisSecondary);
}

/* Cabecera de franja horaria */
.thFranja {
    background-color: #EBF4F5;
    color: #808080;
    text-align: center;
    padding: 3px 6px;
    min-width: 60px;
    font-size: 14px;
    font-weight: 400;
    height: 24px;
}

/* Filas vacías del thead de la tabla de elementos — deben coincidir con thServicio y thFranja */
.disponibilidadHorariaTableElementos thead tr:first-child th {
    height: 30px;
}

.disponibilidadHorariaTableElementos thead tr:nth-child(2) th {
    height: 24px;
}

/* Celda libre */
.tdCeldaLibre {
    min-width: 52px;
    height: 28px;
    border: none;
}

/* Contenido interior de celda ocupada */
.tdCeldaOcupadaContent {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 4px;
}

.btnInfoReserva {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: var(--colorAzulPrimary);
    line-height: 1;
    display: flex;
    align-items: center;
    opacity: 0.7;
    flex-shrink: 0;
}

    .btnInfoReserva:hover {
        opacity: 1;
    }

/* Celda ocupada */
.tdCeldaOcupada {
    background-color: var(--colorAzulSecondary);
    color: var(--colorAzulPrimary);
    font-weight: 700;
    text-align: center;
    vertical-align: middle;
    padding: 2px 6px;
    border: none;
    font-size: 12px;
    cursor: default;
    height: 28px;
}

/* Reservas fuera del planning — card separada debajo del tablero */
.disponibilidadHorariaFueraPlanning {
    background-color: white;
    border-radius: 12px;
    padding: 10px 16px;
    flex-shrink: 0;
    max-height: 120px;
    overflow-y: auto;
}

.disponibilidadHorariaFueraPlanningItems {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 6px;
}

.disponibilidadHorariaFueraPlanningItem {
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 12px;
}

/* DISPONIBILIDAD HORARIA — Bloque 3: interactividad */

.tdCeldaOcupada {
    cursor: pointer;
}

    .tdCeldaOcupada[draggable="true"] {
        cursor: grab;
    }

        .tdCeldaOcupada[draggable="true"]:active {
            cursor: grabbing;
        }

.tdDropTarget {
    background-color: var(--colorAzulTerciaryTransparent) !important;
    outline: 2px dashed var(--colorAzulPrimary);
}

/* Celda de release (tiempo de limpieza tras reserva) */
.tdCeldaRelease {
    background-color: #f0e6d3;
    border: 1px solid #d9c4a8;
    cursor: not-allowed;
}

.tdCeldaSeleccionada {
    outline: 2px solid var(--colorAzulPrimary) !important;
    opacity: 0.75;
}

.tdCeldaCompatible {
    background-color: var(--colorAzulTerciary) !important;
    cursor: pointer;
}

.disponibilidadHorariaBannerSeleccion {
    background-color: var(--colorAzulTerciary);
    color: var(--colorAzulPrimary);
    padding: 6px 16px;
    font-size: 12px;
    flex-shrink: 0;
}


.searchFilter .mud-picker .mud-input-label {
    transform: translate(14px, 9px) scale(1);
}

.searchFilter .mud-picker input {
    padding: 5.5px 5px;
}

/* Fix: label position when field is empty (no value, no focus) in compact search filter */
.searchFilter div.mud-autocomplete .mud-input:not(.mud-shrink):not(:focus-within) ~ label.mud-input-label.mud-input-label-outlined,
.searchFilter div.mud-select:not(.mud-autocomplete) .mud-input:not(.mud-shrink):not(:focus-within) ~ label.mud-input-label.mud-input-label-outlined {
    transform: translate(14px, 7px) scale(1);
}

.cabeceraDisponibilidad {
    display: grid;
    grid-template-columns: auto 350px;
}

    .cabeceraDisponibilidad .d-flex {
        gap: 10px;
        justify-content: flex-end;
    }

.modalDisponibilidad .modalConAyuda {
    min-height: 450px;
}

.w-350px {
    width: 350px;
}

.iconBgAzul {
    background-color: var(--colorAzulPrimary);
    border-radius: 4px;
    padding: 5px;
    width: 27px;
    height: 27px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PLANO DE MESAS
   ═══════════════════════════════════════════════════════════════════════════ */

.planoMesasWrapper {
    display: flex;
    flex-direction: column;
    height: 100%;
    gap: 12px;
    padding: 12px;
    box-sizing: border-box;
}

.planoMesasCard {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    background-color: white;
    border-radius: 12px;
    overflow: hidden;
    padding: 16px;
    gap: 15px;
}

.headerPlanoMesas {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    padding-bottom: 10px;
    flex-shrink: 0;
    border-bottom: 1px solid var(--colorGrisTerciary);
}

    .headerPlanoMesas h2 {
        font-size: 14px;
        font-weight: 400;
        color: black;
        margin: 0;
    }

.planoMesasControls {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.planoMesasEspacioPicker,
.planoMesasServicioPicker {
    width: 200px;
}

    .planoMesasEspacioPicker .mud-input-control,
    .planoMesasServicioPicker .mud-input-control {
        margin-bottom: 0 !important;
    }

    .planoMesasEspacioPicker div.mud-input-slot.mud-select-input,
    .planoMesasServicioPicker div.mud-input-slot.mud-select-input {
        padding: 5.5px;
    }

.planoMesasFechaPicker {
    width: 160px;
    padding-bottom: 4px;
}

    .planoMesasFechaPicker .mud-input-control {
        margin-bottom: 0 !important;
    }

    .planoMesasFechaPicker button.mud-button-root.mud-icon-button {
        margin: 0 4px 0 0;
        padding: 0;
    }

    .planoMesasFechaPicker input {
        padding-top: 5.5px !important;
        padding-bottom: 5.5px !important;
    }

.planoMesasLeyenda {
    display: flex;
    gap: 8px;
    padding: 8px 16px;
    border-bottom: 1px solid #e0e0e0;
    flex-wrap: wrap;
}

.planoMesasBody {
    display: flex;
    flex: 1;
    min-height: 0;
    gap: 12px;
    padding: 12px;
}

/* ── GRID ─────────────────────────────────────────────────────────────────── */

.planoMesasGridWrapper {
    flex: 1;
    min-width: 0;
    min-height: 0;
    overflow: auto;
    border: 1px solid #ccc;
    border-radius: 6px;
    background-color: #f5f5f5;
    position: relative;
}

.planoMesasGrid {
    display: grid;
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.planoMesaCelda {
    border: 1px dashed #d0d0d0;
    box-sizing: border-box;
}

.planoMesaCelda.tdDropTarget {
    background-color: rgba(76, 175, 80, 0.25);
    border: 2px dashed #4caf50;
}

/* ── MESA ─────────────────────────────────────────────────────────────────── */

.planoMesa {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    cursor: grab;
    padding: 4px;
    box-sizing: border-box;
    overflow: hidden;
    z-index: 2;
    margin: 3px;
    transition: opacity 0.15s;
}

    .planoMesa:active {
        cursor: grabbing;
        opacity: 0.7;
    }

    .planoMesa.mesa-libre {
        background-color: #e8f5e9;
        border: 2px solid #4caf50;
        color: #1b5e20;
    }

    .planoMesa.mesa-reservada {
        background-color: #e3f2fd;
        border: 2px solid #2196f3;
        color: #0d47a1;
    }

    .planoMesa.mesa-ocupada {
        background-color: #fff3e0;
        border: 2px solid #ff9800;
        color: #e65100;
    }

    .planoMesa.mesa-bloqueada {
        background-color: #ffebee;
        border: 2px solid #f44336;
        color: #b71c1c;
    }

.planoMesaNombre {
    font-weight: 600;
    font-size: 13px;
    text-align: center;
}

.planoMesaInfo {
    font-size: 11px;
    text-align: center;
    opacity: 0.85;
}

.planoMesaAcciones {
    position: absolute;
    top: 2px;
    right: 2px;
    display: flex;
    gap: 2px;
}

    .planoMesaAcciones button {
        background: transparent;
        border: none;
        padding: 1px;
        cursor: pointer;
        opacity: 0.7;
        line-height: 1;
    }

        .planoMesaAcciones button:hover {
            opacity: 1;
        }

/* ── SIDEBAR ──────────────────────────────────────────────────────────────── */

.planoMesasSidebar {
    width: 200px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    padding: 10px;
    background-color: #fafafa;
}

.planoMesaSinAsignarItem {
    padding: 8px 10px;
    border-radius: 6px;
    cursor: grab;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 6px;
    text-align: center;
}

    .planoMesaSinAsignarItem:active {
        cursor: grabbing;
    }

    .planoMesaSinAsignarItem.mesa-libre {
        background-color: #e8f5e9;
        border: 2px solid #4caf50;
        color: #1b5e20;
    }

    .planoMesaSinAsignarItem.mesa-reservada {
        background-color: #e3f2fd;
        border: 2px solid #2196f3;
        color: #0d47a1;
    }

    .planoMesaSinAsignarItem.mesa-ocupada {
        background-color: #fff3e0;
        border: 2px solid #ff9800;
        color: #e65100;
    }

    .planoMesaSinAsignarItem.mesa-bloqueada {
        background-color: #ffebee;
        border: 2px solid #f44336;
        color: #b71c1c;
    }


/* ── MODAL RESERVAS MESA ──────────────────────────────────────────────────── */

.modalReservasMesaTable {
    width: 100%;
}

/* ── RESPONSIVE ───────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .planoMesasBody {
        flex-direction: column;
    }

    .planoMesasSidebar {
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 6px;
        max-height: 120px;
    }

        .planoMesasSidebar > h3 {
            width: 100%;
        }

        .planoMesasSidebar > p {
            width: 100%;
        }

    .planoMesasGridWrapper {
        max-height: 50vh;
    }
}
