h1:focus {
    outline: none;
}

#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

/* Footer fixo: sempre visível na parte inferior da viewport. Respeita a largura da sidebar
   em telas grandes; em mobile (sidebar offcanvas) ocupa toda a largura.
   O .page-content recebe padding-bottom para que o conteúdo nunca fique escondido atrás. */
.content-page > .footer {
    position: fixed;
    bottom: 0;
    left: var(--ins-sidenav-width-md, 240px);
    right: 0;
    z-index: 100;
}

.content-page > .page-content {
    padding-bottom: 60px;
}

@media (max-width: 1140px) {
    .content-page > .footer {
        left: var(--ins-sidenav-width-sm, 70px);
    }
}

/* Em <= lg (991.98), o sidenav fica em offcanvas overlay — footer ocupa toda largura. */
@media (max-width: 991.98px) {
    .content-page > .footer {
        left: 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;
}

/* Mobile (<= 575.98px): reduzir gutter horizontal para ganhar largura útil,
   evitando que tabelas e formulários colem nas bordas. O Bootstrap usa
   --bs-gutter-x:1.5rem por default no .container-fluid; reduzimos a metade. */
@media (max-width: 575.98px) {
    .container-fluid,
    .container-sm {
        --bs-gutter-x: 0.75rem;
    }

    .page-content {
        padding-left: 0.25rem;
        padding-right: 0.25rem;
    }

    .card-body {
        padding: 1rem;
    }

    .card-header {
        padding: 0.75rem 1rem;
    }

    /* Tabelas em mobile: hidden em xs (substituídas por cards stack via markup) */
    .table-mobile-hidden {
        display: none;
    }
}

/* Cards stack (substituto de tabelas em mobile) — visível só em xs */
.card-stack-mobile {
    display: none;
}

@media (max-width: 575.98px) {
    .card-stack-mobile {
        display: block;
    }
}

/* ============================================================
   Sidenav layout por viewport (fallback robusto)
   ------------------------------------------------------------
   O template Inspinia usa `html[data-sidenav-size=...]` como
   fonte de verdade do layout. Em SPA do Blazor, o enhanced
   navigation reverte esse atributo a cada navegação para o
   valor estático de App.razor ("default"). O JS corrige logo
   depois, mas o paint intermediário causa flash em mobile e
   sobreposição em 1024px.

   Aqui forçamos o layout correto por media query, vencendo
   a especificidade das regras `html[data-sidenav-size=...]`
   via `html .seletor` + `!important` quando necessário.
   O JS (zen-inspinia-bridge.js) continua mantendo o atributo
   coerente para que o app.js do Inspinia gerencie o estado
   de abrir/fechar overlay (.sidebar-enable).
   ============================================================ */

/* Faixa A — ≤ 991.98px: sempre offcanvas */
@media (max-width: 991.98px) {
    html .app-topbar,
    html .content-page {
        margin-left: 0 !important;
    }

    html .sidenav-menu {
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        width: var(--ins-sidenav-width);
        margin-left: calc(var(--ins-sidenav-width) * -1) !important;
        opacity: 0;
        transition: margin-left .25s ease-in-out, opacity .25s ease-in-out;
        z-index: 1055;
    }

    html.sidebar-enable .sidenav-menu {
        margin-left: 0 !important;
        opacity: 1;
    }

    html .button-close-offcanvas {
        display: block;
    }
}

/* Faixa B — 992px a 1140px: on-hover (ícones por padrão, expande no hover)
   Conteúdo principal sempre com margin-left de 75px (área cheia).
   No hover/focus o sidenav cresce para 235px e sobrepõe via z-index — assim o
   usuário lê os rótulos sem precisar redimensionar o conteúdo. */
@media (min-width: 992px) and (max-width: 1140px) {
    html .app-topbar,
    html .content-page {
        margin-left: var(--ins-sidenav-width-sm) !important;
    }

    html .sidenav-menu {
        position: fixed;
        width: var(--ins-sidenav-width-sm);
        overflow: hidden;
        transition: width .25s ease-in-out;
    }

    /* Hover / focus-within (keyboard) expande para largura cheia, sobrepondo o conteúdo */
    html .sidenav-menu:hover,
    html .sidenav-menu:focus-within {
        width: var(--ins-sidenav-width) !important;
        overflow: visible;
        z-index: 1045;
        box-shadow: var(--ins-box-shadow);
    }

    /* Estado "colapsado" (sem hover): esconder textos/títulos/user e centralizar ícone.
       O markup do Zen-Obra usa <span>Texto</span> direto, sem .menu-text — usar > span. */
    html .sidenav-menu:not(:hover):not(:focus-within) .side-nav-title,
    html .sidenav-menu:not(:hover):not(:focus-within) .sidenav-user,
    html .sidenav-menu:not(:hover):not(:focus-within) .side-nav-link > span {
        display: none !important;
    }

    html .sidenav-menu:not(:hover):not(:focus-within) .logo .logo-lg { display: none; }
    html .sidenav-menu:not(:hover):not(:focus-within) .logo .logo-sm { display: inline-block; }

    html .sidenav-menu:not(:hover):not(:focus-within) .side-nav-link {
        justify-content: center;
        text-align: center;
    }
    html .sidenav-menu:not(:hover):not(:focus-within) .side-nav-link > i {
        margin: 0 !important;
    }

    /* Hambúrguer no topbar fica oculto nessa faixa — interação é por hover/focus */
    html .sidenav-toggle-button { display: none; }

    /* O Inspinia em condensed define width: calc(235px + 75px*.35) ≈ 261px no
       hover do item, fazendo o link individual extrapolar o menu. Anular aqui. */
    html[data-sidenav-size=condensed] .sidenav-menu .side-nav > .side-nav-item:hover > .side-nav-link,
    html .sidenav-menu .side-nav > .side-nav-item:hover > .side-nav-link {
        width: auto !important;
    }
}

/* Utility responsiva ausente no Bootstrap 5.3 (só existem w-25/50/75/100/auto, sem variantes
   por breakpoint). Útil para containers que precisam ocupar w-100 em xs/sm e tamanho natural em md+. */
@media (min-width: 768px) {
    .w-md-auto { width: auto !important; }
}

/* ============================================================
   Sidebar de progresso do RDO
   ============================================================ */

/* Margem de scroll para compensar o topbar fixo (~60px) + folga */
.rdo-section-anchor {
    scroll-margin-top: 75px;
}

/* Sidebar sticky no desktop */
.rdo-sidebar {
    position: sticky;
    top: 75px;
    max-height: calc(100vh - 90px);
    overflow-y: auto;
}

/* ============================================================
   ZenSelect — Bottom Sheet (mobile ≤575px)
   Em viewports pequenos, o dropdown do Choices.js é fixado no
   rodapé como bottom sheet, com backdrop e touch targets maiores.
   ============================================================ */
@media (max-width: 575.98px) {
    .zen-select-backdrop {
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.45);
        z-index: 9998;
        animation: zenBackdropIn 0.15s ease;
    }

    @keyframes zenBackdropIn {
        from { opacity: 0; }
        to   { opacity: 1; }
    }

    .choices.is-open .choices__list--dropdown,
    .choices.is-open .choices__list[aria-expanded] {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        top: auto !important;
        max-height: 55vh;
        border-radius: 16px 16px 0 0;
        border: none;
        box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.18);
        z-index: 9999;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Handle visual no topo do sheet */
    .choices.is-open .choices__list--dropdown::before,
    .choices.is-open .choices__list[aria-expanded]::before {
        content: '';
        display: block;
        width: 36px;
        height: 4px;
        background: #ced4da;
        border-radius: 2px;
        margin: 10px auto 6px;
    }

    /* Neutralizar "flipped" (dropdown abre pra cima) — no mobile sempre vai pro rodapé */
    .choices.is-flipped.is-open .choices__list--dropdown {
        top: auto !important;
        bottom: 0 !important;
    }

    /* font-size 16px no input evita zoom automático no iOS/Android */
    .choices__input {
        font-size: 16px !important;
        padding: 10px 14px !important;
    }

    /* Touch targets maiores */
    .choices__list--dropdown .choices__item,
    .choices__list[aria-expanded] .choices__item {
        padding: 14px 16px !important;
        font-size: 16px;
        line-height: 1.4;
    }
}
