/* /Layout/LoginLayout.razor.rz.scp.css */
.login-shell[b-xk00wngv53] {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    font-family: 'Nunito', sans-serif;
    color: #3D3D3A;
}

.brand-panel[b-xk00wngv53] {
    position: relative;
    background: radial-gradient(circle at 85% 15%, rgba(233, 133, 90, 0.18), transparent 55%), radial-gradient(circle at 15% 85%, rgba(201, 64, 112, 0.22), transparent 60%), linear-gradient(160deg, #A31040 0%, #8A0D35 100%);
    color: #fff;
    padding: 56px 64px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
}

    .brand-panel[b-xk00wngv53]::before {
        content: "";
        position: absolute;
        inset: 0;
        background-image: radial-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px);
        background-size: 24px 24px;
        pointer-events: none;
        opacity: 0.6;
    }

    .brand-panel > *[b-xk00wngv53] {
        position: relative;
        z-index: 1;
    }

.brand-logo[b-xk00wngv53] {
    display: flex;
    align-items: center;
    gap: 14px;
}

.brand-logo-mark[b-xk00wngv53] {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.2);
    display: grid;
    place-items: center;
    backdrop-filter: blur(4px);
}

    .brand-logo-mark svg[b-xk00wngv53] {
        width: 38px;
        height: 38px;
    }

.brand-logo-text[b-xk00wngv53] {
    display: flex;
    flex-direction: column;
    line-height: 1.15;
}

    .brand-logo-text .eyebrow[b-xk00wngv53] {
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 2px;
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.7);
    }

    .brand-logo-text .name[b-xk00wngv53] {
        font-size: 18px;
        font-weight: 700;
        color: #fff;
    }

.brand-message[b-xk00wngv53] {
    max-width: 460px;
}

    .brand-message .eyebrow[b-xk00wngv53] {
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 2px;
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.65);
        margin-bottom: 18px;
        display: block;
    }

    .brand-message h1[b-xk00wngv53] {
        font-size: 36px;
        line-height: 1.2;
        font-weight: 700;
        letter-spacing: -0.01em;
        margin-bottom: 16px;
        margin-top: 0;
    }

        .brand-message h1 em[b-xk00wngv53] {
            font-style: normal;
            color: #F5D0CC;
        }

    .brand-message p[b-xk00wngv53] {
        font-size: 15px;
        line-height: 1.6;
        color: rgba(255, 255, 255, 0.85);
        max-width: 420px;
        margin: 0;
    }

.brand-footer[b-xk00wngv53] {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.55);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.form-panel[b-xk00wngv53] {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 32px;
    background: #F7F5F1;
}

.form-card[b-xk00wngv53] {
    width: 100%;
    max-width: 400px;
}

@media (max-width: 960px) {
    .login-shell[b-xk00wngv53] {
        grid-template-columns: 1fr;
    }

    .brand-panel[b-xk00wngv53] {
        padding: 28px 24px 40px;
        min-height: auto;
    }

    .brand-logo[b-xk00wngv53] {
        margin-bottom: 24px;
    }

    .brand-message h1[b-xk00wngv53] {
        font-size: 24px;
        line-height: 1.25;
    }

    .brand-message p[b-xk00wngv53] {
        font-size: 14px;
    }

    .brand-footer[b-xk00wngv53] {
        display: none;
    }

    .form-panel[b-xk00wngv53] {
        padding: 32px 24px 40px;
    }
}

@media (max-width: 480px) {
    .brand-panel[b-xk00wngv53] {
        padding: 24px 20px 32px;
    }

    .brand-message h1[b-xk00wngv53] {
        font-size: 22px;
    }

    .form-panel[b-xk00wngv53] {
        padding: 24px 20px 32px;
    }
}
/* /Layout/MainLayout.razor.rz.scp.css */
[b-4t7de2sj9o] .umz-drawer {
    width: var(--sidebar-w);
    background: var(--surface);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    padding: 0;
}
    [b-4t7de2sj9o] .umz-drawer .nav-section {
        flex: 1;
    }

[b-4t7de2sj9o] .umz-appbar {
    height: var(--topbar-h);
    border-bottom: 1px solid var(--border);
    padding: 0 24px;
}

[b-4t7de2sj9o] .nav-item .mud-icon-root {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}
/* /Pages/Login/Index.razor.rz.scp.css */
.form-header[b-gg48g3yqyo] {
    margin-bottom: 36px;
}

    .form-header .eyebrow[b-gg48g3yqyo] {
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 2px;
        text-transform: uppercase;
        color: var(--vinho);
        margin-bottom: 12px;
        display: block;
    }

    .form-header h2[b-gg48g3yqyo] {
        font-size: 26px;
        font-weight: 700;
        color: #1A1A1A;
        line-height: 1.2;
        margin-bottom: 8px;
        margin-top: 0;
        letter-spacing: -0.01em;
    }

    .form-header p[b-gg48g3yqyo] {
        font-size: 14px;
        color: #6B6B6B;
        line-height: 1.5;
        margin: 0;
    }

/* ─── Alerta de erro ─── */
.alert-error[b-gg48g3yqyo] {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 8px;
    background: rgba(204, 16, 48, 0.08);
    border: 1px solid rgba(204, 16, 48, 0.2);
    color: var(--vinho-dark);
    margin-bottom: 20px;
    font-size: 13px;
    line-height: 1.4;
}

    .alert-error svg[b-gg48g3yqyo] {
        flex-shrink: 0;
        width: 18px;
        height: 18px;
        margin-top: 1px;
    }

    .alert-error strong[b-gg48g3yqyo] {
        display: block;
        font-weight: 600;
        margin-bottom: 2px;
        color: var(--vinho-darker);
    }

/* ─── Formulário ─── */
.form-group[b-gg48g3yqyo] {
    margin-bottom: 18px;
}

.form-label[b-gg48g3yqyo] {
    display: block;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: #3D3D3A;
    margin-bottom: 8px;
}

.form-input-wrapper[b-gg48g3yqyo] {
    position: relative;
}

.form-input[b-gg48g3yqyo] {
    width: 100%;
    height: 48px;
    padding: 0 16px;
    border: 1px solid #E8E2DA;
    border-radius: 8px;
    background: #FFFFFF;
    font-family: 'Nunito', sans-serif;
    font-size: 14px;
    color: #1A1A1A;
    transition: border-color 0.2s, box-shadow 0.2s;
}

    .form-input[b-gg48g3yqyo]::placeholder {
        color: #9E9E9E;
    }

    .form-input:hover[b-gg48g3yqyo] {
        border-color: #D0C8BC;
    }

    .form-input:focus[b-gg48g3yqyo] {
        outline: none;
        border-color: var(--vinho);
        box-shadow: 0 0 0 3px var(--vinho-light);
    }

    .form-input.has-toggle[b-gg48g3yqyo] {
        padding-right: 46px;
    }

    .form-input.is-invalid[b-gg48g3yqyo] {
        border-color: var(--vermelho);
        background: rgba(204, 16, 48, 0.02);
    }

        .form-input.is-invalid:focus[b-gg48g3yqyo] {
            box-shadow: 0 0 0 3px rgba(204, 16, 48, 0.1);
        }

    .form-input:disabled[b-gg48g3yqyo] {
        opacity: 0.6;
        cursor: not-allowed;
    }

.toggle-password[b-gg48g3yqyo] {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    height: 36px;
    width: 36px;
    border: none;
    background: transparent;
    border-radius: 8px;
    display: grid;
    place-items: center;
    cursor: pointer;
    color: #6B6B6B;
    transition: color 0.15s, background 0.15s;
}

    .toggle-password:hover:not(:disabled)[b-gg48g3yqyo] {
        color: var(--vinho);
        background: var(--vinho-light);
    }

    .toggle-password:disabled[b-gg48g3yqyo] {
        cursor: not-allowed;
        opacity: 0.5;
    }

    .toggle-password svg[b-gg48g3yqyo] {
        width: 18px;
        height: 18px;
    }

.field-error[b-gg48g3yqyo] {
    display: none;
    font-size: 12px;
    color: var(--vermelho);
    margin-top: 6px;
    line-height: 1.4;
}

    .field-error.is-visible[b-gg48g3yqyo] {
        display: block;
    }

/* ─── Botão primário ─── */
.btn-primary[b-gg48g3yqyo] {
    width: 100%;
    height: 48px;
    border: none;
    border-radius: 10px;
    background: var(--vinho);
    color: #fff;
    font-family: 'Nunito', sans-serif;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.3px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background 0.15s, transform 0.1s;
    margin-top: 8px;
}

    .btn-primary:hover:not(:disabled)[b-gg48g3yqyo] {
        background: var(--vinho-hover);
    }

    .btn-primary:active:not(:disabled)[b-gg48g3yqyo] {
        transform: scale(0.99);
    }

    .btn-primary:disabled[b-gg48g3yqyo] {
        opacity: 0.6;
        cursor: wait;
    }

.spinner[b-gg48g3yqyo] {
    display: inline-block;
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin-b-gg48g3yqyo 0.7s linear infinite;
}

.btn-primary.is-loading .btn-label[b-gg48g3yqyo] {
    opacity: 0.8;
}

@keyframes spin-b-gg48g3yqyo {
    to {
        transform: rotate(360deg);
    }
}

/* ─── Bloco de ajuda ─── */
.form-help[b-gg48g3yqyo] {
    margin-top: 32px;
    padding: 14px 16px;
    background: var(--vinho-light);
    border-radius: 8px;
    border-left: 3px solid var(--vinho);
}

    .form-help p[b-gg48g3yqyo] {
        font-size: 12px;
        color: #3D3D3A;
        line-height: 1.5;
        margin: 0;
    }

    .form-help strong[b-gg48g3yqyo] {
        color: var(--vinho);
        font-weight: 600;
    }

*:focus-visible[b-gg48g3yqyo] {
    outline: 2px solid var(--vinho);
    outline-offset: 2px;
}

.toggle-password:focus-visible[b-gg48g3yqyo] {
    outline-offset: -2px;
}
/* /Pages/Usuarios/Lista.razor.rz.scp.css */
/* Skin do MudDataGrid para casar com a .data-table do design system */
[b-sxedhr5ucl] .umz-grid .mud-table-root {
    border-collapse: collapse;
}

[b-sxedhr5ucl] .umz-grid > .mud-table {
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--surface);
    box-shadow: none;
}

/* Cabeçalho da tabela */
[b-sxedhr5ucl] .umz-grid .mud-table-head .mud-table-cell {
    background: var(--bg);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
}

/* Células do corpo */
[b-sxedhr5ucl] .umz-grid .mud-table-body .mud-table-cell {
    font-size: 14px;
    color: var(--text-body);
    border-bottom: 1px solid var(--border-soft);
}

/* Hover e linha inativa */
[b-sxedhr5ucl] .umz-grid .mud-table-body .mud-table-row:hover {
    background: var(--vinho-soft) !important;
}

[b-sxedhr5ucl] .umz-grid .mud-table-body .mud-table-row.is-inactive {
    opacity: 0.62;
}

/* Botões de ação mais compactos */
[b-sxedhr5ucl] .umz-grid .row-actions .mud-icon-button {
    width: 32px;
    height: 32px;
}

/* Mobile: o MudDataGrid não vira cards (as media queries data-label do
   design system valem só pra .data-table em HTML puro). Aqui garantimos
   rolagem horizontal suave dentro do cartão, sem estourar a viewport. */
@media (max-width: 960px) {
    [b-sxedhr5ucl] .umz-grid .mud-table-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}
