﻿/* =========================================================
   ERP-UNIV - app.css (FINAL / UNIFICADO)
   ========================================================= */

/* -----------------------------
   Variables globales
------------------------------ */
:root {
    --erp-bg0: #050a14;
    --erp-bg1: #071a33;
    --erp-stroke: rgba(255,255,255,.08);
    --erp-text: rgba(234,242,255,.88);
    --erp-muted: rgba(234,242,255,.70);
    --erp-accent: rgba(64,140,255,.22);
    --erp-accent2: rgba(64,140,255,.12);
    /* bootstrap (evitar blancos) */
    --bs-body-bg: #070B14;
    --bs-body-color: #E5E7EB;
}

/* -----------------------------
   Base: evitar “blancos” template
------------------------------ */
html, body {
    height: 100%;
    margin: 0;
    background: #070B14;
    background-image: none;
}

body, #app, .app, .page {
    background: #070B14;
    background-image: none;
}

main, article, .content, .main-content {
    background: transparent;
}

* {
    box-sizing: border-box;
}

/* -----------------------------
   Template defaults útiles
------------------------------ */
a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus,
.form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

h1:focus {
    outline: none;
}

.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;
}

/* =========================================================
   ERP-UNIV: Contenedor principal (Dashboard pages)
   ========================================================= */
.erp-dashboard {
    min-height: 100vh;
    padding: 22px 18px 42px;
    color: var(--erp-text);
    background: radial-gradient(1100px 580px at 18% 12%, rgba(59,130,246,.18), transparent 62%), radial-gradient(900px 520px at 86% 20%, rgba(14,165,233,.12), transparent 58%), linear-gradient(135deg, #070B14, #0B1222);
}

    /* contenedor ERP (no bootstrap container) */
    .erp-dashboard .erp-container {
        max-width: 1180px;
        margin: 0 auto;
        padding: 0 10px;
    }

    /* TOPBAR */
    .erp-dashboard .erp-topbar {
        border: 1px solid var(--erp-stroke);
        border-radius: 20px;
        background: linear-gradient(180deg, rgba(15,23,42,.88), rgba(15,23,42,.62));
        box-shadow: 0 18px 45px rgba(0,0,0,.45);
        backdrop-filter: blur(10px);
        padding: 16px;
    }

    .erp-dashboard .erp-topbar-inner {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        align-items: center;
    }

@media (min-width: 1024px) {
    .erp-dashboard .erp-topbar-inner {
        grid-template-columns: 420px 1fr;
        align-items: center;
    }
}

/* Brand */
.erp-dashboard .erp-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.erp-dashboard .erp-logo {
    height: 44px;
    width: auto;
    max-width: 180px;
    object-fit: contain;
    display: block;
    flex: 0 0 auto;
}

.erp-dashboard .erp-brand-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.erp-dashboard .erp-title {
    font-size: 18px;
    font-weight: 950;
    line-height: 1.1;
    margin: 0;
    color: rgba(255,255,255,.95);
}

.erp-dashboard .erp-subtitle {
    margin: 0;
    font-size: 12px;
    color: rgba(234,242,255,.70);
}

/* FILTROS (Ventas) */
.erp-dashboard .erp-filters-wrap {
    width: 100%;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(15,23,42,.55), rgba(15,23,42,.35));
    box-shadow: 0 10px 25px rgba(0,0,0,.22);
    padding: 12px;
}

.erp-dashboard .erp-filters {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    align-items: end;
}

@media (max-width: 520px) {
    .erp-dashboard .erp-filters {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 720px) {
    .erp-dashboard .erp-filters {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    .erp-dashboard .erp-filters {
        grid-template-columns: repeat(4, minmax(0, 1fr)) 160px;
        gap: 14px;
    }
}

.erp-dashboard .erp-field {
    display: grid;
    gap: 10px;
}

    .erp-dashboard .erp-field label {
        font-size: 11px;
        color: rgba(234,242,255,.72);
        letter-spacing: .35px;
    }

    .erp-dashboard .erp-field input {
        height: 40px;
        padding: 5px 12px;
        border-radius: 12px;
        border: 1px solid rgba(255,255,255,.10);
        background: rgba(17,24,39,.85);
        color: rgba(255,255,255,.92);
        outline: none;
        transition: .18s;
    }

        .erp-dashboard .erp-field input:focus {
            border-color: rgba(59,130,246,.55);
            box-shadow: 0 0 0 4px rgba(59,130,246,.15);
        }

.erp-dashboard .erp-btn {
    height: 40px;
    border: 0;
    border-radius: 12px;
    padding: 0 18px;
    font-weight: 950;
    color: #fff;
    cursor: pointer;
    min-width: 160px;
    background: linear-gradient(135deg, rgba(59,130,246,.95), rgba(14,165,233,.85));
    box-shadow: 0 12px 28px rgba(59,130,246,.22);
    transition: transform .12s ease, filter .12s ease;
}

    .erp-dashboard .erp-btn:hover {
        filter: brightness(1.05);
    }

    .erp-dashboard .erp-btn:active {
        transform: translateY(1px);
    }

@media (max-width: 1024px) {
    .erp-dashboard .erp-btn {
        width: 100%;
        grid-column: 1 / -1;
    }
}

/* MAIN */
.erp-dashboard .erp-main {
    margin-top: 18px;
}

/* Empty + alert */
.erp-dashboard .erp-empty {
    padding: 18px;
    border-radius: 16px;
    border: 1px dashed rgba(255,255,255,.14);
    color: rgba(229,231,235,.75);
    text-align: center;
    margin-top: 18px;
}

.erp-dashboard .erp-alert {
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(239,68,68,.35);
    background: rgba(127,29,29,.35);
    margin-top: 14px;
}

.erp-dashboard .erp-alert-title {
    font-weight: 950;
    margin-bottom: 6px;
}

.erp-dashboard .erp-alert-msg {
    color: rgba(229,231,235,.85);
}

/* RESUMEN: Cards */
.erp-kpis {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 18px;
}

@media (min-width: 720px) {
    .erp-kpis {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .erp-kpis {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

/* Card base */
.erp-card {
    padding: 18px 18px 16px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.10);
    background: linear-gradient(180deg, rgba(16,27,52,.72), rgba(10,16,34,.70));
    box-shadow: 0 18px 45px rgba(0,0,0,.40);
    position: relative;
    overflow: hidden;
    transform: translateZ(0);
}

    .erp-card::after {
        content: "";
        position: absolute;
        inset: -2px;
        background: radial-gradient(700px 180px at 20% 0%, rgba(59,130,246,.14), transparent 60%), radial-gradient(520px 140px at 90% 30%, rgba(14,165,233,.10), transparent 55%);
        pointer-events: none;
    }

    .erp-card::before {
        content: "";
        position: absolute;
        left: 14px;
        right: 14px;
        top: 10px;
        height: 2px;
        border-radius: 999px;
        background: rgba(255,255,255,.10);
        opacity: .9;
    }

    .erp-card:hover {
        border-color: rgba(59,130,246,.22);
        box-shadow: 0 22px 55px rgba(0,0,0,.50);
    }

.erp-card-label {
    font-size: 12px;
    letter-spacing: .35px;
    text-transform: uppercase;
    color: rgba(229,231,235,.70);
    position: relative;
    z-index: 1;
}

.erp-card-title {
    margin: 10px 0 6px 0;
    font-size: 18px;
    font-weight: 900;
    color: rgba(255,255,255,.94);
    position: relative;
    z-index: 1;
    padding-right: 64px;
}

.erp-card-foot {
    margin-top: 6px;
    color: rgba(229,231,235,.78);
    line-height: 1.35;
    position: relative;
    z-index: 1;
}

.erp-actions {
    margin-top: 14px;
    display: flex;
    gap: 10px;
    align-items: center;
    position: relative;
    z-index: 1;
}

.erp-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 38px;
    padding: 0 16px;
    border-radius: 12px;
    text-decoration: none;
    font-weight: 900;
    color: #fff;
    border: 1px solid rgba(255,255,255,.12);
    background: linear-gradient(135deg, rgba(59,130,246,.92), rgba(14,165,233,.78));
    box-shadow: 0 12px 26px rgba(59,130,246,.20);
}

    .erp-link:hover {
        filter: brightness(1.05);
    }

.erp-chip {
    font-size: 12px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    color: rgba(229,231,235,.88);
}

/* Variantes */
.erp-card--sales::before {
    background: linear-gradient(90deg, rgba(59,130,246,.85), rgba(14,165,233,.35));
}

.erp-card--cash::before {
    background: linear-gradient(90deg, rgba(56,189,248,.55), rgba(255,255,255,.10));
}

.erp-card--inv::before {
    background: linear-gradient(90deg, rgba(167,139,250,.55), rgba(255,255,255,.10));
}

/* Icono decorativo */
.erp-card-icon {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 46px;
    height: 46px;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
    display: grid;
    place-items: center;
    z-index: 2;
    color: rgba(255,255,255,.30);
}

    .erp-card-icon svg {
        width: 26px;
        height: 26px;
    }

.erp-card--sales .erp-card-icon {
    color: rgba(59,130,246,.45);
}

.erp-card--cash .erp-card-icon {
    color: rgba(56,189,248,.38);
}

.erp-card--inv .erp-card-icon {
    color: rgba(167,139,250,.38);
}

/* KPI cards */
.erp-card.kpi {
    position: relative;
    overflow: hidden;
}

    .erp-card.kpi::before {
        content: "";
        position: absolute;
        left: 16px;
        right: 16px;
        top: 12px;
        height: 2px;
        border-radius: 999px;
        background: rgba(255,255,255,.08);
        opacity: .95;
        pointer-events: none;
        z-index: 0;
    }

    .erp-card.kpi::after {
        content: "";
        position: absolute;
        inset: -2px;
        background: radial-gradient(760px 240px at 20% 0%, rgba(148,163,184,.10), transparent 62%), radial-gradient(520px 180px at 90% 35%, rgba(255,255,255,.04), transparent 55%);
        pointer-events: none;
        z-index: 0;
    }

    .erp-card.kpi .erp-card-inner {
        position: relative;
        z-index: 1;
    }

    .erp-card.kpi.kpi--primary {
        border-color: rgba(59,130,246,.18) !important;
    }

        .erp-card.kpi.kpi--primary::before {
            background: linear-gradient(90deg, rgba(59,130,246,.95), rgba(14,165,233,.45));
        }

        .erp-card.kpi.kpi--primary::after {
            background: radial-gradient(820px 260px at 18% 0%, rgba(59,130,246,.22), transparent 62%), radial-gradient(520px 180px at 90% 35%, rgba(14,165,233,.12), transparent 55%);
        }

    .erp-card.kpi.kpi--info {
        border-color: rgba(56,189,248,.16) !important;
    }

        .erp-card.kpi.kpi--info::before {
            background: linear-gradient(90deg, rgba(56,189,248,.85), rgba(255,255,255,.14));
        }

        .erp-card.kpi.kpi--info::after {
            background: radial-gradient(820px 260px at 18% 0%, rgba(56,189,248,.16), transparent 62%), radial-gradient(520px 180px at 90% 35%, rgba(255,255,255,.06), transparent 55%);
        }

    .erp-card.kpi.kpi--violet {
        border-color: rgba(167,139,250,.16) !important;
    }

        .erp-card.kpi.kpi--violet::before {
            background: linear-gradient(90deg, rgba(167,139,250,.80), rgba(255,255,255,.14));
        }

        .erp-card.kpi.kpi--violet::after {
            background: radial-gradient(820px 260px at 18% 0%, rgba(167,139,250,.18), transparent 62%), radial-gradient(520px 180px at 90% 35%, rgba(255,255,255,.06), transparent 55%);
        }

    .erp-card.kpi.kpi--neutral {
        border-color: rgba(255,255,255,.10) !important;
    }

        .erp-card.kpi.kpi--neutral::before {
            background: linear-gradient(90deg, rgba(148,163,184,.45), rgba(255,255,255,.10));
        }

    .erp-card.kpi:hover {
        border-color: rgba(255,255,255,.14) !important;
    }

    .erp-card.kpi.kpi--primary:hover {
        border-color: rgba(59,130,246,.28) !important;
    }

    .erp-card.kpi.kpi--info:hover {
        border-color: rgba(56,189,248,.24) !important;
    }

    .erp-card.kpi.kpi--violet:hover {
        border-color: rgba(167,139,250,.24) !important;
    }

    .erp-card.kpi:hover::after {
        filter: brightness(1.06);
    }

/* =========================================================
   AUTH (Login)
   ========================================================= */
.auth-shell {
    min-height: 100vh;
    background: radial-gradient(1200px 600px at 60% 30%, rgba(45,120,255,.20), transparent 55%), radial-gradient(900px 500px at 20% 70%, rgba(120,70,255,.18), transparent 55%), #070B14;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px 14px;
}

.auth-wrap {
    width: 100%;
    display: flex;
    justify-content: center;
}

.auth-card {
    width: min(980px, 100%);
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    border-radius: 18px;
    overflow: hidden;
    background: rgba(12, 18, 35, .75);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 24px 70px rgba(0,0,0,.55);
    backdrop-filter: blur(14px);
}

.auth-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
}

.auth-brand-center {
    width: 100%;
    padding: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
}

.auth-brand::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(600px 260px at 20% 20%, rgba(255,255,255,.14), transparent 60%);
    pointer-events: none;
}

.auth-logo {
    height: 92px;
    width: auto;
    opacity: .98;
    filter: drop-shadow(0 10px 22px rgba(0,0,0,.22));
}

.auth-form {
    padding: 38px 34px;
    background: rgba(7, 11, 20, .55);
}

    .auth-form h2 {
        margin: 0 0 6px;
        font-size: 22px;
        color: rgba(255,255,255,.95);
    }

.auth-brand-title {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: .6px;
    color: rgba(255,255,255,.95);
}

.auth-brand-tagline {
    font-size: 12px;
    letter-spacing: 1.8px;
    color: rgba(255,255,255,.70);
    margin-top: 2px;
}

.auth-brand-quote {
    margin-top: 6px;
    max-width: 360px;
    font-size: 14px;
    line-height: 1.55;
    color: rgba(255,255,255,.82);
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(0,0,0,.18);
    border: 1px solid rgba(255,255,255,.12);
}

.auth-sub {
    margin: 0 0 18px;
    color: rgba(255,255,255,.65);
    font-size: 13px;
}

.auth-form label {
    display: block;
    margin: 12px 0 6px;
    color: rgba(255,255,255,.78);
    font-size: 13px;
}

.auth-input {
    width: 100%;
    padding: 12px 12px;
    border-radius: 12px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
    color: rgba(255,255,255,.92);
    outline: none;
}

    .auth-input:focus {
        border-color: rgba(45,120,255,.55);
        box-shadow: 0 0 0 4px rgba(45,120,255,.18);
    }

.auth-btn {
    width: 100%;
    margin-top: 16px;
    padding: 12px 12px;
    border-radius: 12px;
    border: 0;
    font-weight: 600;
    color: white;
    background: linear-gradient(180deg, rgba(45,120,255,.98), rgba(45,120,255,.72));
    box-shadow: 0 14px 34px rgba(45,120,255,.20);
    cursor: pointer;
}

    .auth-btn:disabled {
        opacity: .65;
        cursor: not-allowed;
    }

.auth-btn-ghost {
    margin-top: 10px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: none;
}

.auth-error {
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    background: rgba(255, 70, 70, .12);
    border: 1px solid rgba(255, 70, 70, .22);
    color: rgba(255,255,255,.90);
    font-size: 13px;
}

@media (max-width: 880px) {
    .auth-card {
        grid-template-columns: 1fr;
    }

    .auth-brand {
        padding: 28px 22px;
    }

    .auth-form {
        padding: 28px 22px;
    }
}

/* =========================================================
   LAYOUT BASE (Autorizado / No autorizado)
   ========================================================= */
.app-shell {
    min-height: 100vh;
}

/* Desktop: sidebar + contenido */
.app-layout-auth {
    display: flex;
    min-height: 100vh;
}

/* main ocupa el resto */
.app-main {
    flex: 1 1 auto;
    min-width: 0;
}

/* Sin sesión: full */
.app-main--full {
    width: 100%;
}



/* =========================================================
   LAYOUT + SIDEBAR (FINAL)
   - Desktop: sidebar fijo
   - Mobile: drawer con overlay
   ========================================================= */

html, body {
    overflow-x: hidden;
}
/* evita “franjas” raras */

/* Layout base */
.app-shell {
    min-height: 100vh;
}

/* Auth layout */
.app-layout-auth {
    display: flex;
    min-height: 100vh;
    position: relative;
}

/* Sidebar (desktop) */
.erp-sidebar {
    width: 280px;
    flex: 0 0 280px;
    background: linear-gradient(180deg, #071a33 0%, #050a14 100%);
    border-right: 1px solid rgba(255,255,255,.08);
}

/* Main */
.app-main {
    flex: 1 1 auto;
    min-width: 0;
}

/* No sesión */
.app-main--full {
    width: 100%;
}

/* Botón hamburguesa (solo mobile) */
.erp-sidebar-btn {
    display: none;
}

/* Overlay (solo mobile) */
.erp-sidebar-overlay {
    display: none;
}

/* ===== MOBILE DRAWER ===== */
@media (max-width: 992px) {

    .app-layout-auth {
        display: block;
        min-height: 100vh;
    }

    /* Botón hamburguesa fijo arriba a la derecha */
    .erp-sidebar-btn {
        display: grid;
        place-items: center;
        position: fixed;
        top: 12px;
        right: 12px;
        z-index: 4500;
        width: 44px;
        height: 40px;
        border-radius: 12px;
        border: 1px solid rgba(255,255,255,.12);
        background: rgba(255,255,255,.06);
        color: rgba(255,255,255,.88);
        box-shadow: 0 14px 34px rgba(0,0,0,.35);
        cursor: pointer;
    }

    /* Sidebar como drawer */
    .erp-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        height: 100vh;
        z-index: 4400;
        transform: translateX(-105%);
        transition: transform .22s ease;
        box-shadow: 30px 0 60px rgba(0,0,0,.55);
        overflow: hidden;
    }

    .app-layout-auth.sidebar-open .erp-sidebar {
        transform: translateX(0);
    }

    /* Overlay */
    .erp-sidebar-overlay {
        position: fixed;
        inset: 0;
        z-index: 4300;
        background: rgba(0,0,0,.55);
        backdrop-filter: blur(2px);
        border: 0;
        padding: 0;
        margin: 0;
        display: none;
    }

    .app-layout-auth.sidebar-open .erp-sidebar-overlay {
        display: block;
    }

    .app-main {
        width: 100%;
    }
}



/* =========================================================
   FIX FINAL: botón hamburguesa del MainLayout (erp-sidebar-btn)
   ========================================================= */

/* Desktop: NO se muestra */
.erp-sidebar-btn {
    display: none;
}

.erp-sidebar-overlay {
    display: none;
}

@media (max-width: 900px) {
    .erp-sidebar-btn {
        display: grid;
        place-items: center;
        position: fixed;
        top: 12px;
        left: 12px;
        z-index: 6000;
        width: 44px;
        height: 40px;
        border-radius: 12px;
        border: 1px solid rgba(255,255,255,.12);
        background: rgba(255,255,255,.06);
        box-shadow: 0 14px 34px rgba(0,0,0,.35);
        backdrop-filter: blur(10px);
        /* MUY IMPORTANTE: si por algo hubiera texto, lo oculta */
        color: transparent;
        font-size: 0;
        line-height: 0;
        padding: 0;
        cursor: pointer;
    }

        /* Ícono hamburguesa */
        .erp-sidebar-btn::before,
        .erp-sidebar-btn::after {
            content: "";
            position: absolute;
            width: 18px;
            height: 2px;
            background: rgba(255,255,255,.78);
            border-radius: 999px;
            left: 50%;
            transform: translateX(-50%);
        }

        .erp-sidebar-btn::before {
            top: 14px;
            box-shadow: 0 6px 0 rgba(255,255,255,.78);
        }

        .erp-sidebar-btn::after {
            top: 26px;
        }

    /* Overlay sólo cuando sidebar-open */
    .app-layout-auth.sidebar-open .erp-sidebar-overlay {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 5000;
        background: rgba(0,0,0,.55);
        border: 0;
    }
}




/* =========================================================
   FIX DRAWER: abrir/cerrar sidebar con clase .sidebar-open
   (MainLayout usa _sidebarOpen => agrega "sidebar-open")
   ========================================================= */

/* Desktop */
.erp-sidebar {
    position: relative;
    transform: none;
}

.erp-sidebar-overlay {
    display: none;
}

/* Mobile */
@media (max-width: 900px) {

    .erp-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        height: 100vh;
        width: 280px;
        z-index: 7000;
        transform: translateX(-110%);
        transition: transform .22s ease;
        /* ya lo tienes, pero lo reafirmo */
        background: linear-gradient(180deg, #071a33 0%, #050a14 100%);
        border-right: 1px solid rgba(255,255,255,.08);
        box-shadow: 30px 0 60px rgba(0,0,0,.55);
        overflow: hidden;
    }

    /* cuando esté abierto */
    .app-layout-auth.sidebar-open .erp-sidebar {
        transform: translateX(0);
    }

    /* overlay */
    .app-layout-auth.sidebar-open .erp-sidebar-overlay {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 6500;
        background: rgba(0,0,0,.55);
        border: 0;
    }
}


/* ===========================
   ERP Modal (Confirm Logout)
   =========================== */
.erp-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 6000;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(2px);
    display: grid;
    place-items: center;
    padding: 18px;
}

.erp-modal {
    width: min(520px, 100%);
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.10);
    background: linear-gradient(180deg, rgba(16,27,52,.92), rgba(10,16,34,.92));
    box-shadow: 0 28px 90px rgba(0,0,0,.65);
    overflow: hidden;
    position: relative;
}

    .erp-modal::after {
        content: "";
        position: absolute;
        inset: -2px;
        background: radial-gradient(700px 220px at 18% 0%, rgba(59,130,246,.18), transparent 62%), radial-gradient(520px 180px at 90% 35%, rgba(14,165,233,.10), transparent 55%);
        pointer-events: none;
    }

.erp-modal-head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 16px 10px;
}

.erp-modal-title {
    font-weight: 950;
    color: rgba(255,255,255,.95);
    letter-spacing: .2px;
}

.erp-modal-x {
    width: 38px;
    height: 36px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.85);
    cursor: pointer;
}

.erp-modal-body {
    position: relative;
    z-index: 1;
    padding: 0 16px 16px;
    color: rgba(229,231,235,.82);
    line-height: 1.45;
}

.erp-modal-actions {
    position: relative;
    z-index: 1;
    padding: 14px 16px 16px;
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    border-top: 1px solid rgba(255,255,255,.08);
    background: rgba(0,0,0,.10);
}

/* Botones del modal */
.erp-btn-ghost {
    height: 40px;
    padding: 0 14px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.88);
    font-weight: 900;
    cursor: pointer;
}

.erp-btn-danger {
    height: 40px;
    padding: 0 14px;
    border-radius: 12px;
    border: 1px solid rgba(239,68,68,.28);
    background: linear-gradient(180deg, rgba(239,68,68,.92), rgba(220,38,38,.78));
    color: #fff;
    font-weight: 950;
    cursor: pointer;
    box-shadow: 0 14px 34px rgba(239,68,68,.18);
}



/* =========================================================
   ERP-UNIV - Select Premium (.erp-select)
   ========================================================= */

.erp-select {
    /* Reset look nativo */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    min-height: 44px;
    padding: 10px 42px 10px 12px; /* espacio para flecha */
    border-radius: 12px;
    color: var(--erp-text);
    background: rgba(255,255,255,.03);
    border: 1px solid var(--erp-stroke);
    outline: none;
    box-shadow: 0 0 0 1px rgba(255,255,255,.02) inset, 0 10px 30px rgba(0,0,0,.20);
    font-size: 14px;
    line-height: 1.2;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease, transform .12s ease;
}

    /* Hover */
    .erp-select:hover {
        background: rgba(255,255,255,.04);
        border-color: rgba(255,255,255,.14);
    }

    /* Focus (glow premium ERP-UNIV) */
    .erp-select:focus {
        border-color: rgba(64,140,255,.55);
        box-shadow: 0 0 0 3px rgba(64,140,255,.18), 0 0 0 1px rgba(255,255,255,.02) inset, 0 12px 34px rgba(0,0,0,.26);
    }

    /* Disabled */
    .erp-select:disabled {
        opacity: .55;
        cursor: not-allowed;
        background: rgba(255,255,255,.02);
    }

/* =========================================================
   Flecha custom (solo para erp-select)
   ========================================================= */

.erp-field {
    position: relative;
}

    /* Flecha */
    .erp-field .erp-select::after {
        content: "";
    }

    /* Flecha real */
    .erp-field:has(.erp-select)::after {
        content: "";
        position: absolute;
        right: 14px;
        top: 50%;
        width: 10px;
        height: 10px;
        transform: translateY(-35%) rotate(45deg);
        border-right: 2px solid rgba(234,242,255,.65);
        border-bottom: 2px solid rgba(234,242,255,.65);
        pointer-events: none;
        opacity: .85;
    }

    /* Flecha disabled */
    .erp-field:has(.erp-select:disabled)::after {
        opacity: .45;
    }

/* =========================================================
   Opciones (dropdown)
   ========================================================= */

.erp-select option {
    background: #070B14;
    color: rgba(234,242,255,.92);
}
