﻿/* ----------------------
   1) Root / Reset
   ---------------------- */
html, body {
    height: 100%;
    margin: 0;
}

/* ----------------------
   2) Splash screen
   ---------------------- */
.splash-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: var(--mud-palette-background-default, linear-gradient(135deg, #667eea 0%, #764ba2 100%));
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 10000;
    animation: fadeIn 0.3s ease-in;
    transition: opacity 0.5s ease-out;
}
.mud-theme-dark .splash-screen {
    background: linear-gradient(135deg, #1e3a8a 0%, #312e81 100%);
}
.splash-content { display: flex; flex-direction: column; align-items: center; gap: 0; animation: slideUp 0.6s ease-out; }
.splash-logo { max-width: 208px; }
.splash-content .mud-progress-circular { margin-top: 2.5rem; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.splash-screen.fade-out { opacity: 0; pointer-events: none; }

/* ----------------------
   3) Layout / AppBar / Main content
   ---------------------- */
/* Ensure page layout respects appbar height */
.mud-main-content {
    padding-top: 64px;
    height: 100vh;
    min-height: 100vh;
    overflow: hidden; /* panels que necesitan scroll propio lo manejan internamente */
    box-sizing: border-box;
}

/* AppBar must be fixed and span full width; keep specificity and minimal !important to override layout offsets */
.mud-appbar {
    position: fixed;
    top: 0;
    left: 0 !important;
    right: 0 !important;
    width: auto !important;
    margin-left: 0 !important;
    transform: none !important;
    z-index: 3000;
}

/* Main content classes: applied on MudMainContent in the layout component
   Target both the utility class and the actual MudBlazor container so
   the margin updates reliably when the drawer toggles. */
.main-content,
.mud-main-content.main-content {
    transition: margin-left 0.3s ease;
    padding: 0;
    padding-top: 64px;
    display: flex;
    flex-direction: column;
    height: 100vh;
    min-height: 100vh;
    box-sizing: border-box;
}

.main-content-expanded,
.mud-main-content.main-content-expanded {
    margin-left: 256px;
}

.main-content-collapsed,
.mud-main-content.main-content-collapsed {
    margin-left: 56px;
}

/* Body content area inside main content.
   Layout estándar: scroll vertical propio.
   Layout vertical (vc-page): verticalcrudlayout.css anula overflow a hidden. */
.mainlayout-body-content {
    padding: 1rem;
    height: 100%;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    box-sizing: border-box;
}

/* ----------------------
   4) Drawer (base + states)
   ---------------------- */
/* Base: remove internal extra spacing that can push layout */
.mud-drawer { padding: 0; margin: 0; }
.mud-drawer-content { padding: 0; }

/* Drawer height & placement below the appbar */
.mud-drawer, .mainlayout-drawer { top: 64px; height: calc(100vh - 64px); }
.mud-drawer .mud-drawer-content, .mainlayout-drawer .drawer-content { height: calc(100vh - 64px); overflow-y: auto; }

/* Transition for width changes */
.mud-drawer { transition: width 0.3s cubic-bezier(0.4,0,0.2,1), min-width 0.3s cubic-bezier(0.4,0,0.2,1); will-change: width, min-width; overflow-x: hidden; }

/* Preferred state control: classes set by MainLayout.razor */
.mainlayout-drawer.collapsed { width: 56px; min-width: 56px; max-width: 56px; overflow: hidden; }
.mainlayout-drawer.expanded { width: 256px; min-width: 256px; max-width: 256px; }

/* Prevent inner content from forcing drawer wider */
.mainlayout-drawer .drawer-content, .mainlayout-drawer .mud-drawer-content { width: 100%; box-sizing: border-box; }

/* ----------------------
   5) Navigation & expansion panels
   ---------------------- */
.drawer-content { display: flex; flex-direction: column; height: 100%; }
.drawer-menu { flex: 1; overflow-y: auto; }
.drawer-footer { flex-shrink: 0; padding: 8px 16px; background: var(--mud-palette-background-default); border-top: 1px solid var(--mud-palette-divider); text-align: center; }
.drawer-footer .mud-typography-caption { font-size: 0.65rem; line-height: 1.2; }

.nav-group-header { display: flex; align-items: center; padding: 8px 16px; min-height: 48px; font-weight: 500; color: var(--mud-palette-text-primary); }
.nav-group-content { padding-left: 0; }
.nav-group-content .mud-nav-link { padding-left: 48px; }

/* Expansion panels */
.mud-nav-expansion { margin-top: 4px; }
.mud-nav-expansion .mud-expand-panel { background-color: transparent; box-shadow: none; }
.mud-nav-expansion .mud-expand-panel-header { padding: 4px 12px; min-height: 36px; display: flex; align-items: center; }
.mud-nav-expansion .mud-expand-panel-header-content { display: flex; align-items: center; flex: 1; }
.mud-nav-expansion .mud-expand-panel-content { padding: 0; }
.mud-nav-expansion .mud-nav-link { padding-left: 40px; min-height: 32px; line-height: 1; }
.nav-expansion-panel .mud-expand-panel-header .mud-expand-panel-icon { order: -1; margin-right: 0; margin-left: auto; }

/* Section title icon: consistent size, vertically centered with text */
.mud-nav-expansion .mud-expand-panel-header .d-flex.align-center { display: flex; align-items: center; gap: 8px; width: 100%; }
.mud-nav-expansion .mud-expand-panel-header .mud-icon-root { font-size: 20px !important; width: 20px !important; height: 20px !important; flex-shrink: 0; }

/* Mini mode: make every wrapper fill the full 56px width and center its content */
.mainlayout-drawer.collapsed .mud-nav-menu { padding: 0; }

/* MudTooltip and MudMenu must be block-level to fill drawer width */
.mainlayout-drawer.collapsed .mud-tooltip-root { display: block !important; width: 100%; }
.mainlayout-drawer.collapsed .mud-menu { display: block !important; width: 100%; }
.mainlayout-drawer.collapsed .mud-menu > div,
.mainlayout-drawer.collapsed .mud-menu-activator { display: block !important; width: 100%; }

/* MudNavLink in mini mode: center icon, hide text, remove all padding/margin that offset centering */
.mainlayout-drawer.collapsed .mud-nav-link {
    justify-content: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    width: 100%;
}
.mainlayout-drawer.collapsed .mud-nav-link .mud-nav-link-icon,
.mainlayout-drawer.collapsed .mud-nav-link .mud-nav-link-icon-default {
    margin-right: 0 !important;
    margin-left: 0 !important;
}
/* Ocultar SOLO el span de texto, no el slot del ícono */
.mainlayout-drawer.collapsed .mud-nav-link .mud-nav-link-text { display: none !important; }
.mainlayout-drawer.collapsed .mud-nav-link .mud-icon-root { opacity: 1; }

/* All icons in mini mode: uniform size */
.mainlayout-drawer.collapsed .mud-icon-root { font-size: 22px !important; width: 22px !important; height: 22px !important; }

/* Footer Ayuda link (expanded drawer): center icon + text */
.drawer-footer-link.mud-nav-link {
    justify-content: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.drawer-footer-link.mud-nav-link .mud-nav-link-icon,
.drawer-footer-link.mud-nav-link .mud-nav-link-icon-default {
    margin-right: 8px !important;
    margin-left: 0 !important;
}

/* ----------------------
   6) Mud Snackbar
   ---------------------- */
.mud-snackbar {
    z-index: 10001 !important;
    top: 26px !important;
}

/* Boton globalmente */
.mud-button-root.mud-button {
    padding: 5px 10px;
    min-width: unset;
    line-height: 1.4;
    font-weight:500;
}

/* Banner de ambiente de prueba: contenedor fijo full-width que centra el pill sobre el AppBar.
   Fijo al viewport → el centrado no depende del layout interno del AppBar. No bloquea clics. */
.test-env-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    z-index: 1300;
}

.test-env-banner-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 16px;
    border-radius: 6px;
    background: #d32f2f;
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .35);
}

/* En pantallas angostas el AppBar no tiene lugar para el banner centrado: se oculta
   (el chip TEST en la versión y el popup siguen indicando el ambiente). */
@media (max-width: 960px) {
    .test-env-banner {
        display: none;
    }
}