/* ═══════════════════════════════════════════════════════════════
   RecoPlas ERP — Hoja de estilos principal
   Paleta: Azul industrial #1B3A6B  |  Verde marca #5CB030
   ═══════════════════════════════════════════════════════════════ */

:root {
    --rp-azul: #1B3A6B;
    --rp-azul-dark: #132B52;
    --rp-azul-light: #2550A0;
    --rp-verde: #5CB030;
    --rp-verde-dark: #46891F;
    --rp-sidebar-bg: #F5F7FA;
    --rp-sidebar-w: 260px;
    --rp-topbar-h: 64px;
    --rp-border: #DDE3ED;
    --rp-text: #1A1A2E;
    --rp-text-muted: #6B7280;
}

/* ── Base ──────────────────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box;
}

html, body {
    font-size: 14px;
    font-family: 'Roboto', sans-serif;
    color: var(--rp-text);
    background: #EEF1F6;
    margin: 0;
    padding: 0;
    height: 100%;
    overflow: hidden; /* evita scroll en body; cada zona scrollea por sí misma */
}

/* Blazor Server envuelve el árbol en <blazor-ssr> / componente custom sin height.
   Forzamos todos esos wrappers a ocupar 100% para que 100vh funcione correctamente. */
#app,
#app > *:not(#blazor-error-ui) {
    height: 100%;
}

/* ── Layout principal ──────────────────────────────────────── */
.rp-layout {
    display: flex;
    height: 100%; /* ocupa exactamente el viewport, sin crecer */
}

/* ── Sidebar ───────────────────────────────────────────────── */
.rp-sidebar {
    width: var(--rp-sidebar-w);
    height: 100vh;
    background: var(--rp-sidebar-bg);
    border-right: 2px solid var(--rp-border);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    transition: width 0.25s ease;
    overflow: hidden;
}

.rp-sidebar__logo {
    height: var(--rp-topbar-h);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    padding: 0 20px;
    background: var(--rp-azul);
    gap: 12px;
}

.rp-sidebar__logo-text {
    color: white;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.5px;
}

.rp-sidebar__logo-sub {
    color: rgba(255,255,255,0.65);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 0.3px;
}

.rp-sidebar__nav {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 12px 0;
}

.rp-nav-section {
    padding: 8px 16px 4px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--rp-text-muted);
}

.rp-nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    margin: 1px 8px;
    border-radius: 8px;
    color: var(--rp-text);
    text-decoration: none;
    font-size: 14px;
    font-weight: 400;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

    .rp-nav-item:hover {
        background: rgba(27, 58, 107, 0.08);
        color: var(--rp-azul);
    }

    .rp-nav-item.active {
        background: rgba(27, 58, 107, 0.12);
        color: var(--rp-azul);
        font-weight: 600;
    }

        .rp-nav-item.active .rp-nav-icon {
            color: var(--rp-azul);
        }

.rp-nav-icon {
    color: var(--rp-text-muted);
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: color 0.15s;
}

/* ── Main content ─────────────────────────────────────────── */
.rp-main {
    margin-left: var(--rp-sidebar-w);
    flex: 1;
    display: flex;
    flex-direction: column;
    height: 100%; /* exactamente el viewport, sin crecer */
    min-height: 0;
    overflow: hidden;
}

/* ── Topbar ───────────────────────────────────────────────── */
.rp-topbar {
    height: var(--rp-topbar-h);
    flex-shrink: 0;
    background: white;
    border-bottom: 1px solid var(--rp-border);
    display: flex;
    align-items: center;
    padding: 0 24px;
    z-index: 90;
    gap: 16px;
}

.rp-topbar__title {
    font-size: 18px;
    font-weight: 600;
    color: var(--rp-azul);
    flex: 1;
}

.rp-topbar__badge {
    background: var(--rp-verde);
    color: white;
    border-radius: 20px;
    padding: 2px 10px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.4px;
}

/* ── Page content ─────────────────────────────────────────── */
.rp-content {
    padding: 24px;
    flex: 1;
    min-height: 0;
    overflow-y: auto; /* scroll del contenido aqui, no en body */
}

/* ── Cards ────────────────────────────────────────────────── */
.rp-card {
    background: white;
    border-radius: 10px;
    border: 1px solid var(--rp-border);
    padding: 20px 24px;
    margin-bottom: 16px;
}

.rp-card__title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--rp-azul);
    border-bottom: 2px solid var(--rp-verde);
    padding-bottom: 8px;
    margin-bottom: 16px;
    display: inline-block;
}

/* ── Overrides MudBlazor ─────────────────────────────────── */
.mud-table-container {
    border-radius: 10px;
    border: 1px solid var(--rp-border);
    overflow: hidden;
}

.mud-table-head .mud-table-cell {
    background: #F0F4FA !important;
    color: var(--rp-azul) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.mud-table-row:hover td {
    background: rgba(27, 58, 107, 0.04) !important;
}

.mud-button-root.mud-button-filled-primary {
    background-color: var(--rp-azul) !important;
}

    .mud-button-root.mud-button-filled-primary:hover {
        background-color: var(--rp-azul-dark) !important;
    }

.mud-button-root.mud-button-filled-success,
.mud-fab.mud-fab-success {
    background-color: var(--rp-verde) !important;
}

.mud-chip.mud-chip-color-success {
    background-color: rgba(92, 176, 48, 0.12) !important;
    color: var(--rp-verde-dark) !important;
}

/* ── Tabs ─────────────────────────────────────────────────── */
.mud-tabs .mud-tab-active {
    color: var(--rp-azul) !important;
    font-weight: 600;
}

.mud-tabs .mud-tab-slider {
    background-color: var(--rp-azul) !important;
}

/* ── Scrollbar ────────────────────────────────────────────── */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: #C4CDD8;
    border-radius: 3px;
}

    ::-webkit-scrollbar-thumb:hover {
        background: #9AA3AF;
    }

/* ── Blazor error UI ─────────────────────────────────────── */
#blazor-error-ui {
    background: #fff3cd;
    bottom: 0;
    right: 0;
    left: 0;
    padding: 12px 20px;
    position: fixed;
    z-index: 1000;
    display: none;
    border-top: 1px solid #ffc107;
    font-size: 13px;
}

    #blazor-error-ui a {
        text-decoration: underline;
        cursor: pointer;
    }
