/* ================================================================
   1. DESIGN TOKENS
   ================================================================ */

:root {
    /* ── Brand ── */
    --brand-primary: #FF6600;
    --brand-primary-dark: #E55A00;
    --brand-primary-light: #FF8533;
    --brand-primary-rgb: 255, 102, 0;

    /* ── Neutrals ── */
    --color-text: #2d2d2d;
    --color-text-muted: #6c757d;
    --color-text-inverse: #ffffff;
    --color-surface: #ffffff;

    /* ── Interactive States ── */
    --hover-overlay: rgba(45, 45, 45, 0.08);
    --active-overlay: rgba(45, 45, 45, 0.10);
    --focus-ring: 0 0 0 0.2rem rgba(var(--brand-primary-rgb), 0.25);
    --inverse-hover: rgba(255, 255, 255, 0.18);
    --inverse-active: rgba(255, 255, 255, 0.26);

    /* ── Gradients ── */
    --gradient-header: linear-gradient(135deg, #FF6600 0%, #FF8533 100%);
    --gradient-sidebar: linear-gradient(180deg, #ff6600 0%, #ff6600 5.5%, #ff8f3d 8%, #ffd4ad 12%, #fff0de 20%, #ffffff 28%);

    /* ── Shadows ── */
    --shadow-header: 0 2px 8px rgba(0, 0, 0, 0.18);
    --shadow-sidebar: 2px 0 12px rgba(0, 0, 0, 0.06);
    --shadow-dropdown: 0 4px 16px rgba(0, 0, 0, 0.12);

    /* ── Spacing Scale ── */
    --sp-2xs: 0.125rem;
    --sp-xs: 0.25rem;
    --sp-sm: 0.5rem;
    --sp-md: 0.75rem;
    --sp-base: 1rem;
    --sp-lg: 1.5rem;
    --sp-xl: 2rem;

    /* ── Radii ── */
    --radius-sm: 0.375rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;

    /* ── Transitions ── */
    --ease-out: cubic-bezier(0.33, 1, 0.68, 1);
    --duration-fast: 150ms;
    --duration-normal: 250ms;

    /* ── Typography ── */
    --font-family: 'Titillium Web', system-ui, -apple-system, sans-serif;
    --font-weight-normal: 400;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;

    /* ── Z-Index Scale ── */
    --z-header: 1030;
    --z-sidebar: 1020;
    --z-dropdown: 1050;
    --z-error: 1000;
}


/* ================================================================
   2. FUENTES — Titillium Web
   ================================================================ */

@font-face {
    font-family: 'Titillium Web';
    src: url('fonts/TitilliumWeb-ExtraLight.ttf') format('truetype');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Titillium Web';
    src: url('fonts/TitilliumWeb-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Titillium Web';
    src: url('fonts/TitilliumWeb-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Titillium Web';
    src: url('fonts/TitilliumWeb-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Titillium Web';
    src: url('fonts/TitilliumWeb-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Titillium Web';
    src: url('fonts/TitilliumWeb-Black.ttf') format('truetype');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

html,
body {
    font-family: var(--font-family) !important;
}


/* ================================================================
   3. TEMA ORANGE — BootstrapBlazor Layout
   ================================================================ */

/* ── 3a. Header ── */

.layout.layout-orange .layout-header,
.bb-layout.layout-orange .layout-header {
    background: var(--gradient-header) !important;
    box-shadow: var(--shadow-header);
    border-bottom: 2px solid rgba(15, 14, 13, 0.3) !important;
}

.layout.layout-orange .layout-header .navbar,
.bb-layout.layout-orange .layout-header .navbar {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 0 !important;
}

.layout.layout-orange .layout-header .navbar-brand,
.layout.layout-orange .layout-header .nav-link,
.layout.layout-orange .layout-header .btn-link {
    color: var(--color-text-inverse) !important;
}


/* ================================================================
   3-GRID. HEADER — Grid de 3 columnas
   ================================================================
   
   DOM de BootstrapBlazor:
   
   <header class="layout-header is-fixed">
       <div class="layout-header-bar">≡</div>
       <div class="header-grid">          ← flex:1 para crecer
           ├── .header-col-start          ← 1fr (vacío, simetría)
           ├── .header-col-center         ← auto (logo + título)
           └── .header-col-end            ← 1fr (usuario)
       </div>
   </header>
   ================================================================ */

.layout-header .header-grid {
    flex: 1 1 0%;
    min-width: 0;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    height: 100%;
    padding: 0 1rem;
    margin: 0;
}

.layout-header .header-col-start {
    min-width: 0;
}

.layout-header .header-col-center {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    white-space: nowrap;
    margin: 0;
    padding: 0;
}

/* Quitar TODOS los márgenes internos del centro */
.layout-header .header-col-center * {
    margin: 0;
    padding: 0;
}

.layout-header .header-col-center a {
    display: flex;
    align-items: center;
}

.layout-header .header-col-end {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    min-width: 0;
}

/* ── Logo ── */

.layout-header .brand-logo {
    height: 32px;
    width: auto;
    object-fit: contain;
    flex-shrink: 0;
    display: block;
}

/* ── Título ── */

.layout-header .brand-title {
    white-space: nowrap;
    line-height: 1;
    margin: 0 !important;
    padding: 0 !important;
}


/* ── 3b. Botón colapsar/expandir (header-bar) ── */

.layout.layout-orange,
.bb-layout.layout-orange {
    --bb-layout-headerbar-background: rgba(255, 255, 255, 0.14);
    --bb-layout-headerbar-border-color: rgba(255, 255, 255, 0.35);
    --bb-layout-headerbar-color: var(--color-text-inverse);
    --bb-split-bar-body-hover-bg: var(--inverse-hover);
    --bb-split-bar-body-drag-hover-bg: var(--inverse-active);
}

.layout.layout-orange .layout-header .layout-header-bar,
.bb-layout.layout-orange .layout-header .layout-header-bar {
    background-color: rgba(255, 255, 255, 0.14) !important;
    border-color: rgba(255, 255, 255, 0.35) !important;
    color: var(--color-text-inverse) !important;
    margin-left: var(--sp-base) !important;
    transition: background-color var(--duration-fast) var(--ease-out);
}

.layout.layout-orange .layout-header .layout-header-bar:hover,
.bb-layout.layout-orange .layout-header .layout-header-bar:hover {
    background-color: var(--inverse-hover) !important;
}

.layout.layout-orange .layout-header .layout-header-bar:focus-visible {
    background-color: var(--inverse-hover) !important;
    outline: 2px solid var(--color-text-inverse);
    outline-offset: 2px;
}

.layout.layout-orange .layout-header .layout-header-bar:active,
.bb-layout.layout-orange .layout-header .layout-header-bar:active {
    background-color: var(--inverse-active) !important;
}


/* ── 3c. Sidebar ── */

.layout.layout-orange .layout-side,
.bb-layout.layout-orange .layout-side {
    background: var(--gradient-sidebar) !important;
    box-shadow: var(--shadow-sidebar);
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    height: 100% !important;
}

/* Centrado vertical del menú — hijos Y nietos */
.layout.layout-orange .layout-side>*,
.bb-layout.layout-orange .layout-side>*,
.layout.layout-orange .layout-side>*>*,
.bb-layout.layout-orange .layout-side>*>* {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    flex: 1 1 auto !important;
}

.layout.layout-orange .layout-side .menu,
.bb-layout.layout-orange .layout-side .menu {
    margin-block: auto !important;
    flex: 0 0 auto !important;
}


/* ── 3d. Menú Vertical — Colores ── */

.layout.layout-orange .layout-side .menu,
.bb-layout.layout-orange .layout-side .menu {
    --bb-menu-item-hover-bg: var(--hover-overlay) !important;
    --bb-menu-item-hover-color: var(--color-text) !important;
    --bb-menu-active-color: var(--color-text) !important;
    --bb-menu-bar-bg: var(--color-text) !important;
    --bs-nav-link-color: var(--color-text) !important;
}

.layout.layout-orange .layout-side .menu .nav-link {
    color: var(--color-text) !important;
    padding: 0.6rem 0.85rem;
    border-radius: var(--radius-md);
    font-size: 0.95rem;
    font-weight: var(--font-weight-semibold);
    display: flex;
    align-items: center;
    transition: background-color var(--duration-normal) var(--ease-out),
        color var(--duration-normal) var(--ease-out);
}

.layout.layout-orange .layout-side .menu .nav-link:not(.disabled):hover {
    background-color: var(--hover-overlay) !important;
    color: var(--color-text) !important;
}

.layout.layout-orange .layout-side .menu .nav-link.active {
    background-color: var(--active-overlay) !important;
    color: var(--color-text) !important;
    font-weight: var(--font-weight-bold);
}

.layout.layout-orange .layout-side .menu .nav-link:focus-visible {
    background-color: var(--hover-overlay) !important;
    outline: 2px solid var(--brand-primary);
    outline-offset: -2px;
}

/* Submenús */
.layout.layout-orange .layout-side .menu .submenu .nav-link,
.layout.layout-orange .layout-side .menu .dropdown-menu .nav-link {
    color: var(--color-text) !important;
}

.layout.layout-orange .layout-side .menu .submenu .nav-link:not(.disabled):hover,
.layout.layout-orange .layout-side .menu .submenu .nav-link.active,
.layout.layout-orange .layout-side .menu .dropdown-menu .nav-link:not(.disabled):hover,
.layout.layout-orange .layout-side .menu .dropdown-menu .nav-link.active {
    background-color: var(--hover-overlay) !important;
    color: var(--color-text) !important;
}

/* Iconos y flechas del menú */
.layout.layout-orange .layout-side .menu .nav-link i,
.layout.layout-orange .layout-side .menu .nav-link .fa,
.layout.layout-orange .layout-side .menu .nav-link .fas,
.layout.layout-orange .layout-side .menu .arrow,
.layout.layout-orange .layout-side .menu .nav-link-right {
    color: var(--color-text) !important;
}


/* ── 3e. Sidebar Colapsado ── */

.layout.is-collapsed .layout-side:not(:hover) .menu.is-vertical .badge,
.layout.is-collapsed .layout-side:not(:hover) .menu.is-vertical .nav-link-right,
.layout.is-collapsed .layout-side:not(:hover) .menu.is-vertical .has-leaf>.nav-link-right,
.layout.is-collapsed .layout-side:not(:hover) .menu.is-vertical .dropdown-toggle::after {
    display: none !important;
    opacity: 0;
    visibility: hidden;
}

.layout.is-collapsed .menu.is-vertical .arrow,
.layout.is-collapsed .menu.is-vertical .dropdown-menu-arrow {
    display: none !important;
    width: 0;
    height: 0;
    margin: 0;
}


/* ================================================================
   4. BOOTSTRAP OVERRIDES
   ================================================================ */

/* ── Botones ── */

.btn-primary {
    background-color: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    color: var(--color-text-inverse) !important;
}

.btn-primary:hover {
    background-color: var(--brand-primary-dark) !important;
    border-color: var(--brand-primary-dark) !important;
}

.btn:focus-visible {
    box-shadow: var(--focus-ring) !important;
}

.btn-outline-primary.custom-hover:hover {
    background-color: var(--brand-primary-light) !important;
    border-color: var(--brand-primary-light) !important;
    color: var(--color-text-inverse) !important;
}

.btn-outline-light.custom-hover:hover {
    background-color: #f8f9fa !important;
    border-color: #f8f9fa !important;
    color: #212529 !important;
}

/* ── Formularios ── */

.form-control:focus {
    border-color: var(--brand-primary) !important;
    box-shadow: var(--focus-ring) !important;
}

.form-control,
.btn {
    transition: all var(--duration-normal) var(--ease-out);
}

/* ── Links ── */

a:not(.nav-link):not(.dropdown-item):not(.btn),
.btn-link {
    color: var(--brand-primary) !important;
}

a:not(.nav-link):not(.dropdown-item):not(.btn):hover,
.btn-link:hover {
    color: var(--brand-primary-dark) !important;
}


/* ================================================================
   5. DROPDOWNS
   ================================================================ */

.dropdown-menu-orange {
    border: 2px solid var(--brand-primary);
    box-shadow: var(--shadow-dropdown);
}

.dropdown-menu-orange .dropdown-item {
    transition: background-color var(--duration-fast) var(--ease-out);
}

.dropdown-menu-orange .dropdown-item:hover {
    background-color: rgba(var(--brand-primary-rgb), 0.08);
}

.dropdown-item.custom-hover:hover {
    background-color: rgba(var(--brand-primary-rgb), 0.08) !important;
    color: var(--brand-primary) !important;
}

/* Dropdown de notificaciones (MainLayout) */
.layout-notification-widget .dropdown-menu,
.layout-notification-widget.widget .dropdown-menu {
    width: min(22rem, 96vw) !important;
    min-width: 22rem !important;
    max-width: 96vw !important;
}

.layout-notification-widget .dropdown-body {
    max-height: 30rem !important;
}

@media (max-width: 991.98px) {

    .layout-notification-widget .dropdown-menu,
    .layout-notification-widget.widget .dropdown-menu {
        width: min(20rem, 96vw) !important;
        min-width: 0 !important;
        max-width: 96vw !important;
    }

    .layout-notification-widget .dropdown-body {
        max-height: 24rem !important;
    }
}

.dropdown-item.custom-hover:active,
.dropdown-item.custom-hover:focus,
.dropdown-item.custom-hover:focus-visible {
    background-color: transparent !important;
    color: var(--brand-primary) !important;
    box-shadow: none !important;
    outline: none !important;
}

button.dropdown-item:active,
button.dropdown-item:focus {
    background-color: transparent !important;
    box-shadow: none !important;
}

button.dropdown-item.text-danger:active,
button.dropdown-item.text-danger:focus {
    background-color: rgba(220, 53, 69, 0.08) !important;
    color: #dc3545 !important;
}


/* ================================================================
   6. UTILIDADES
   ================================================================ */

.text-orange {
    color: var(--brand-primary) !important;
}

.bg-orange-primary {
    background-color: var(--brand-primary) !important;
}

.border-orange {
    border-color: var(--brand-primary) !important;
}


/* ================================================================
   7. VALIDACIÓN
   ================================================================ */

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
    font-size: 0.85rem;
    margin-top: var(--sp-xs);
}


/* ================================================================
   8. ERROR BOUNDARY
   ================================================================ */

.blazor-error-boundary {
    background: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgb3ZlcmZsb3c9ImhpZGRlbiI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyNTkuNDczIDUzLjYyOTQgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWiIgZmlsbD0iI0ZGRTUwMCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTIzNSAtNTEpIi8+PC9zdmc+") no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}


/* ================================================================
   9. FONT AWESOME — Fix de renderizado
   ================================================================ */

.fas,
.far,
.fab,
.fa {
    font-family: "Font Awesome 5 Free", "Font Awesome 5 Brands" !important;
    font-style: normal;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}


/* ================================================================
  10. CLASES DE PESO TIPOGRÁFICO
   ================================================================ */

.titillium-web-extralight {
    font-weight: 200;
}

.titillium-web-light {
    font-weight: 300;
}

.titillium-web-regular {
    font-weight: 400;
}

.titillium-web-semibold {
    font-weight: 600;
}

.titillium-web-bold {
    font-weight: 700;
}

.titillium-web-black {
    font-weight: 900;
}

[class^="titillium-web-"] {
    font-family: var(--font-family);
    font-style: normal;
}


/* ================================================================
  11. ACCESIBILIDAD
   ================================================================ */

@media (prefers-reduced-motion: reduce) {

    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

:focus-visible {
    outline: 2px solid var(--brand-primary);
    outline-offset: 2px;
}

@media (hover: none) and (pointer: coarse) {
    .layout.layout-orange .layout-side .menu .nav-link:hover {
        background-color: transparent !important;
    }
}


/* ================================================================
  12. RESPONSIVE
   ================================================================ */

/* ── Header grid — Tablets ── */
@media (max-width: 768.98px) {
    .layout-header .header-grid {
        padding: 0 0.75rem;
    }

    .layout-header .brand-title {
        font-size: 1.25rem;
    }

    .layout-header .brand-logo {
        height: 28px;
    }

    .layout.layout-orange .layout-side {
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
    }

    .layout.layout-orange .layout-side .menu .nav-link {
        min-height: 44px;
        border-radius: var(--radius-lg);
        font-size: 1rem;
        padding: var(--sp-md) var(--sp-base);
    }

    .layout.layout-orange .layout-side .menu .nav-link:active {
        background-color: var(--active-overlay) !important;
        transform: translateY(1px);
    }
}

/* ── Header grid — Móviles ── */
@media (max-width: 575.98px) {
    .layout-header .header-grid {
        padding: 0 0.5rem;
        gap: 0.25rem;
    }

    .layout-header .brand-title {
        max-width: 120px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}

/* ── Header grid — Móviles muy pequeños ── */
@media (max-width: 375px) {
    .layout-header .brand-title {
        display: none;
    }

    .layout-header .brand-logo {
        height: 24px;
    }

    .layout-header .header-grid {
        grid-template-columns: 0 auto 1fr;
    }

    .layout-header .header-col-start {
        display: none;
    }
}

/* ================================================================
  13. RANKINGS POR MES
   ================================================================ */

.rankings-mensuales-title {
    color: var(--brand-primary) !important;
    font-weight: var(--font-weight-bold);
}

.table-ranking-mensual .table-primary {
    --bs-table-bg: rgba(var(--brand-primary-rgb), 0.1) !important;
    --bs-table-border-color: var(--brand-primary-light) !important;
}

.comercial-row {
    border-left: 5px solid #ffdb97 !important;
    background-color: #fdfdfd !important;
}

.comercial-row:hover {
    background-color: #f8f9fa !important;
}

.badge-ranking-top {
    background-color: #FFCC00 !important;
    /* Dorado */
    color: #000 !important;
}

.badge-ranking-other {
    background-color: var(--color-text-muted) !important;
    color: white !important;
}