/**
 * Worker Hub — Filament admin & user panel theme
 * Professional sidebar + chrome for light and dark mode.
 */

/* ========== Design tokens ========== */
.fi-panel-admin {
    --wh-accent: 37 99 235; /* blue-600 */
    --wh-accent-soft: 239 246 255; /* blue-50 */
    --wh-accent-muted: 59 130 246; /* blue-500 */
}

.fi-panel-user {
    --wh-accent: 14 165 233; /* sky-500 */
    --wh-accent-soft: 240 249 255; /* sky-50 */
    --wh-accent-muted: 56 189 248; /* sky-400 */
}

/* ----- Light mode: sidebar ----- */
html:not(.dark) .fi-body.fi-panel-admin .fi-main-sidebar.fi-sidebar,
html:not(.dark) .fi-body.fi-panel-user .fi-main-sidebar.fi-sidebar {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
    border-inline-end: 1px solid #e2e8f0 !important;
    box-shadow: 1px 0 0 rgba(15, 23, 42, 0.04) !important;
}

html:not(.dark) .fi-body.fi-panel-admin .fi-main-sidebar.fi-sidebar.fi-sidebar-open,
html:not(.dark) .fi-body.fi-panel-user .fi-main-sidebar.fi-sidebar.fi-sidebar-open {
    box-shadow:
        4px 0 24px rgba(15, 23, 42, 0.06),
        1px 0 0 #e2e8f0 !important;
}

/* ----- Dark mode: sidebar ----- */
html.dark .fi-body.fi-panel-admin .fi-main-sidebar.fi-sidebar,
html.dark .fi-body.fi-panel-user .fi-main-sidebar.fi-sidebar {
    background: linear-gradient(180deg, #0f172a 0%, #111827 48%, #0c1222 100%) !important;
    border-inline-end: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 4px 0 32px rgba(0, 0, 0, 0.35) !important;
}

/* Sidebar header / brand */
html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-header {
    border-bottom: 1px solid #e2e8f0 !important;
    background: transparent !important;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    background: transparent !important;
}

html:not(.dark) .fi-body .fi-main-sidebar .fi-logo,
html:not(.dark) .fi-body .fi-main-sidebar .fi-logo span {
    color: #0f172a !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em;
}

html.dark .fi-body .fi-main-sidebar .fi-logo,
html.dark .fi-body .fi-main-sidebar .fi-logo span {
    color: #f8fafc !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em;
}

/* Nav group labels */
html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-group-label {
    color: #64748b !important;
    font-size: 0.6875rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-group-label {
    color: #94a3b8 !important;
    font-size: 0.6875rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

/* Nav items — base */
.fi-body .fi-main-sidebar .fi-sidebar-item-btn {
    border-radius: 0.5rem !important;
    margin-inline: 0.25rem !important;
    transition:
        background-color 0.15s ease,
        color 0.15s ease,
        box-shadow 0.15s ease !important;
}

html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item-btn {
    color: #475569 !important;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-item-btn {
    color: #cbd5e1 !important;
}

html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item-icon {
    color: #94a3b8 !important;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-item-icon {
    color: #64748b !important;
}

/* Hover */
@media (hover: hover) {
    html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-has-url > .fi-sidebar-item-btn:hover {
        background: #f1f5f9 !important;
        color: #0f172a !important;
    }

    html.dark .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-has-url > .fi-sidebar-item-btn:hover {
        background: rgba(255, 255, 255, 0.06) !important;
        color: #f1f5f9 !important;
    }

    html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-has-url:hover .fi-sidebar-item-icon {
        color: rgb(var(--wh-accent)) !important;
    }

    html.dark .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-has-url:hover .fi-sidebar-item-icon {
        color: rgb(var(--wh-accent-muted)) !important;
    }
}

/* Active item */
html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item.fi-active > .fi-sidebar-item-btn,
html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-active > .fi-sidebar-item-btn {
    background: rgb(var(--wh-accent-soft)) !important;
    color: rgb(var(--wh-accent)) !important;
    font-weight: 600 !important;
    box-shadow: inset 3px 0 0 rgb(var(--wh-accent));
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-item.fi-active > .fi-sidebar-item-btn,
html.dark .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-active > .fi-sidebar-item-btn {
    background: rgba(var(--wh-accent-muted), 0.15) !important;
    color: rgb(var(--wh-accent-muted)) !important;
    font-weight: 600 !important;
    box-shadow: inset 3px 0 0 rgb(var(--wh-accent-muted));
}

html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item.fi-active .fi-sidebar-item-icon,
html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-active .fi-sidebar-item-icon {
    color: rgb(var(--wh-accent)) !important;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-item.fi-active .fi-sidebar-item-icon,
html.dark .fi-body .fi-main-sidebar .fi-sidebar-item.fi-sidebar-item-active .fi-sidebar-item-icon {
    color: rgb(var(--wh-accent-muted)) !important;
}

html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-item.fi-active .fi-sidebar-item-label {
    color: rgb(var(--wh-accent)) !important;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-item.fi-active .fi-sidebar-item-label {
    color: rgb(var(--wh-accent-muted)) !important;
}

/* Group collapse buttons */
html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-group-dropdown-trigger-btn:hover {
    background: #f1f5f9 !important;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-group-dropdown-trigger-btn:hover {
    background: rgba(255, 255, 255, 0.06) !important;
}

/* Sidebar footer / user menu */
html:not(.dark) .fi-body .fi-main-sidebar .fi-sidebar-footer {
    border-top: 1px solid #e2e8f0;
    padding-top: 0.75rem;
}

html.dark .fi-body .fi-main-sidebar .fi-sidebar-footer {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 0.75rem;
}

html:not(.dark) .fi-body .fi-main-sidebar .fi-user-menu-trigger {
    color: #334155 !important;
    border-radius: 0.5rem !important;
}

html.dark .fi-body .fi-main-sidebar .fi-user-menu-trigger {
    color: #e2e8f0 !important;
    border-radius: 0.5rem !important;
}

html:not(.dark) .fi-body .fi-main-sidebar .fi-user-menu-trigger:hover {
    background: #f1f5f9 !important;
}

html.dark .fi-body .fi-main-sidebar .fi-user-menu-trigger:hover {
    background: rgba(255, 255, 255, 0.06) !important;
}

/* Panel badge (admin / worker) */
.wh-sidebar-panel-badge {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0.75rem 0.5rem;
    padding: 0.4rem 0.65rem;
    border-radius: 0.375rem;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

html:not(.dark) .wh-sidebar-panel-badge {
    background: #f1f5f9;
    color: #475569;
    border: 1px solid #e2e8f0;
}

html.dark .wh-sidebar-panel-badge {
    background: rgba(255, 255, 255, 0.06);
    color: #94a3b8;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.wh-sidebar-panel-badge__dot {
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 9999px;
    flex-shrink: 0;
}

html:not(.dark) .wh-sidebar-panel-badge--admin .wh-sidebar-panel-badge__dot {
    background: #2563eb;
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.25);
}

html:not(.dark) .wh-sidebar-panel-badge--worker .wh-sidebar-panel-badge__dot {
    background: #0ea5e9;
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.25);
}

html.dark .wh-sidebar-panel-badge--admin .wh-sidebar-panel-badge__dot {
    background: #60a5fa;
    box-shadow: 0 0 8px rgba(96, 165, 250, 0.45);
}

html.dark .wh-sidebar-panel-badge--worker .wh-sidebar-panel-badge__dot {
    background: #38bdf8;
    box-shadow: 0 0 8px rgba(56, 189, 248, 0.45);
}

/* ========== Top bar ========== */
html:not(.dark) .fi-topbar {
    background: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(8px);
    border-bottom: 1px solid #e2e8f0 !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
}

html.dark .fi-topbar {
    background: rgba(15, 23, 42, 0.92) !important;
    backdrop-filter: blur(8px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

/* ========== Main content area ========== */
html:not(.dark) .fi-main {
    background: #f1f5f9 !important;
}

html.dark .fi-main {
    background: #0b1120 !important;
}

/* Stat cards */
html:not(.dark) .fi-wi-stats-overview-stat {
    border-radius: 0.75rem;
    border: 1px solid #e2e8f0;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

html.dark .fi-wi-stats-overview-stat {
    border-radius: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
}

/* Section headings */
.fi-section-header-heading {
    font-weight: 600;
    letter-spacing: -0.01em;
}

/* Collapsed sidebar: keep visible bg on desktop */
@media (min-width: 1024px) {
    html:not(.dark) .fi-body.fi-panel-admin .fi-main-sidebar.fi-sidebar,
    html:not(.dark) .fi-body.fi-panel-user .fi-main-sidebar.fi-sidebar {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
    }

    html.dark .fi-body.fi-panel-admin .fi-main-sidebar.fi-sidebar,
    html.dark .fi-body.fi-panel-user .fi-main-sidebar.fi-sidebar {
        background: linear-gradient(180deg, #0f172a 0%, #111827 48%, #0c1222 100%) !important;
    }
}

/* Mobile overlay sidebar */
@media (max-width: 1023.98px) {
    html:not(.dark) .fi-body .fi-main-sidebar.fi-sidebar.fi-sidebar-open {
        box-shadow: 8px 0 40px rgba(15, 23, 42, 0.12) !important;
    }

    html.dark .fi-body .fi-main-sidebar.fi-sidebar.fi-sidebar-open {
        box-shadow: 8px 0 40px rgba(0, 0, 0, 0.5) !important;
    }
}
