/* =========================================================
   Duty — Simple & Functional CSS layer
   Reemplaza al "cyberpunk" design system. Aporta:
   - Integración con var(--duty-primary) inyectado por theme-vars
     (admin Settings → Theme controla colores).
   - Toggle layout vertical (sidebar) ↔ horizontal (topnav).
   - Utilidades minimalistas: .duty-page-head, .duty-kpi, .duty-section.
   - Wallet card simplificado (sin neón).
   - Fix z-index sidenav móvil.
   Cargado AFTER Ubold/Bootstrap para ganar cascada.
   ========================================================= */

/* --- Layout toggle (vertical ↔ horizontal) -----------------
   Por defecto Ubold muestra sidenav y oculta .topnav. Con
   data-layout="topnav" invertimos: oculta sidenav y suelta
   contenido a full width. */
.topnav { display: none; }

html[data-layout="topnav"] .sidenav-menu,
html[data-layout="topnav"] .button-on-hover,
html[data-layout="topnav"] .button-close-offcanvas {
    display: none !important;
}
html[data-layout="topnav"] .topnav { display: block; }
html[data-layout="topnav"] .content-page {
    margin-inline-start: 0 !important;
    padding: 1rem 1.25rem;
}
html[data-layout="topnav"] .app-topbar {
    margin-inline-start: 0 !important;
}
html[data-layout="topnav"] .sidenav-toggle-button {
    display: none !important;
}

/* Topnav respeta theme primary en active/hover. */
html[data-layout="topnav"] .topnav .nav-link:hover,
html[data-layout="topnav"] .topnav .nav-item.active > .nav-link {
    color: var(--duty-primary, #7C5CFF) !important;
}
html[data-layout="topnav"] .topnav .nav-item.active > .nav-link {
    background: color-mix(in srgb, var(--duty-primary, #7C5CFF) 12%, transparent);
    border-radius: 8px;
}

/* --- Minimalist page header (dashboards) ------------------- */
.duty-page-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1.25rem 0 1rem;
    border-bottom: 1px solid color-mix(in srgb, var(--bs-body-color, #111) 8%, transparent);
    margin-bottom: 1.5rem;
}
.duty-page-head h1 {
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    margin: 0;
}
.duty-page-head .duty-page-sub {
    color: color-mix(in srgb, var(--bs-body-color, #111) 55%, transparent);
    font-size: 0.85rem;
    margin-top: 0.15rem;
}

/* --- Minimal KPI card --------------------------------------- */
.duty-kpi {
    background: var(--bs-body-bg, #fff);
    border: 1px solid color-mix(in srgb, var(--bs-body-color, #111) 8%, transparent);
    border-radius: 12px;
    padding: 1.1rem 1.15rem;
    transition: border-color 0.15s ease;
}
.duty-kpi:hover {
    border-color: color-mix(in srgb, var(--duty-primary, #7C5CFF) 35%, transparent);
}
.duty-kpi .label {
    color: color-mix(in srgb, var(--bs-body-color, #111) 55%, transparent);
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.35rem;
}
.duty-kpi .value {
    font-size: 1.7rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    line-height: 1.1;
    color: var(--bs-body-color, #111);
}
.duty-kpi .delta {
    font-size: 0.78rem;
    font-weight: 600;
    margin-top: 0.25rem;
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
}
.duty-kpi .delta.up   { color: var(--duty-success, #10b981); }
.duty-kpi .delta.down { color: var(--duty-danger,  #ef4444); }

/* --- Sectioned card (dashboards) --------------------------- */
.duty-section {
    background: var(--bs-body-bg, #fff);
    border: 1px solid color-mix(in srgb, var(--bs-body-color, #111) 8%, transparent);
    border-radius: 12px;
    padding: 1.15rem;
}
.duty-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
}
.duty-section-head h6 {
    font-weight: 600;
    letter-spacing: -0.005em;
    margin: 0;
}

/* --- Buttons polished (no neón, respeta theme primary) ----- */
.btn-duty {
    background-color: var(--duty-primary, #7C5CFF);
    border-color: var(--duty-primary, #7C5CFF);
    color: #fff;
    font-weight: 600;
}
.btn-duty:hover {
    filter: brightness(0.92);
    color: #fff;
}
.btn-outline-duty {
    color: var(--duty-primary, #7C5CFF);
    border: 1px solid var(--duty-primary, #7C5CFF);
    background: transparent;
    font-weight: 600;
}
.btn-outline-duty:hover {
    background: var(--duty-primary, #7C5CFF);
    color: #fff;
}

/* --- Wallet card (simplified, no neón) ---------------------- */
.wallet-card {
    background: linear-gradient(135deg,
                  var(--duty-primary, #7C5CFF) 0%,
                  color-mix(in srgb, var(--duty-primary, #7C5CFF) 60%, #000 40%) 100%);
    color: #fff;
    border-radius: 16px;
    padding: 1.5rem;
    position: relative;
    overflow: hidden;
    min-height: 180px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
}
.wallet-card__brand {
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.8;
}
.wallet-card__name {
    font-size: 1.05rem;
    font-weight: 600;
    margin-top: 0.25rem;
}
.wallet-card__label {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.65;
    margin-top: 1rem;
}
.wallet-card__amount {
    font-size: 1.9rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    margin-top: 0.15rem;
}
.wallet-card__num {
    font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
    font-size: 0.78rem;
    opacity: 0.75;
    letter-spacing: 0.08em;
    margin-top: 0.75rem;
}

/* --- Page title helper para pantallas legacy --------------- */
.page-title-head { margin-bottom: 1rem; }
.page-main-title {
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin: 0;
}

/* --- Badge live (still useful for events) ------------------ */
.badge-live {
    background: var(--duty-danger, #ef4444);
    color: #fff;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.65rem;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
}

/* --- Mobile sidebar z-index fix ----------------------------
   Default .sidenav-menu z-index is 1005; offcanvas backdrop
   uses 1040 → menu sits behind backdrop on mobile and is
   unclickable. Lift menu above backdrop when sidebar enabled. */
html.sidebar-enable .sidenav-menu {
    z-index: 1045;
}
