/* ============================================================
   ProfitShark Dark Glassmorphism Design System
   All rules scoped to [data-theme="dark"] so light mode is
   fully unaffected.
   ============================================================ */

/* ============================================================
   CSS VARIABLE SYSTEM — dark mode depth tokens
   All per-element colors must reference these; never hardcode.
   ============================================================ */
[data-theme="dark"] {
  --color-bg-base:            #000000;
  --color-bg-raised:          #0f1117;
  --color-bg-elevated:        #1a1d27;
  --color-bg-overlay:         #22263a;

  --color-table-header-bg:    var(--color-bg-elevated);
  --color-table-row-bg:       #080808;
  --color-table-row-alt:      #0d0d0d;
  --color-table-border:       rgba(255,255,255,0.06);

  --color-checkbox-bg:        #1a1d27;

  --color-card-bg:            var(--color-bg-raised);
  --color-card-gradient-start:#1a1d27;
  --color-card-gradient-end:  #0f1117;

  --color-text-primary:       #e2e4f0;
}

/* Light mode equivalents — keeps every variable defined for both themes */
[data-theme="light"] {
  --color-bg-base:            #f5f6fa;
  --color-bg-raised:          #ffffff;
  --color-bg-elevated:        #f8f9fb;
  --color-bg-overlay:         #ffffff;

  --color-table-header-bg:    #f8f9fb;
  --color-table-row-bg:       #ffffff;
  --color-table-row-alt:      #f9fafb;
  --color-table-border:       rgba(0,0,0,0.06);

  --color-checkbox-bg:        #ffffff;

  --color-card-bg:            #ffffff;
  --color-card-gradient-start:#ffffff;
  --color-card-gradient-end:  #ffffff;

  --color-text-primary:       #111827;
}

/* ============================================================
   .ps-card — shared stat/info card with depth gradient
   Add this class to stat cards on any page; gradient flows
   from the variables so every page inherits the same treatment.
   ============================================================ */
[data-theme="dark"] .ps-card {
  background: linear-gradient(135deg, var(--color-card-gradient-start), var(--color-card-gradient-end)) !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
}

/* ============================================================
   .ps-table — shared table layering (header lighter than rows)
   ============================================================ */
[data-theme="dark"] .ps-table thead tr,
[data-theme="dark"] .ps-table thead th {
  background: var(--color-table-header-bg) !important;
}
[data-theme="dark"] .ps-table tbody td {
  background: var(--color-table-row-bg) !important;
}
[data-theme="dark"] .ps-table tbody tr:nth-child(even) td {
  background: var(--color-table-row-alt) !important;
}
[data-theme="dark"] .ps-table th.checkbox-col,
[data-theme="dark"] .ps-table td.checkbox-col,
[data-theme="dark"] .ps-table th:first-child,
[data-theme="dark"] .ps-table td:first-child {
  background: var(--color-checkbox-bg) !important;
}
[data-theme="dark"] .ps-table input[type="checkbox"] {
  accent-color: #ff9900;
}
[data-theme="light"] .ps-table thead tr,
[data-theme="light"] .ps-table thead th { background: var(--color-table-header-bg) !important; }
[data-theme="light"] .ps-table tbody td { background: var(--color-table-row-bg) !important; }

/* --- Global Reset & Typography (dark only) --- */
[data-theme="dark"] *,
[data-theme="dark"] *::before,
[data-theme="dark"] *::after {
  box-sizing: border-box;
}

[data-theme="dark"] body {
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  background: #0a0b14 !important;
  background-image:
    radial-gradient(ellipse 80% 60% at 20% -10%, rgba(99,60,255,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 10%, rgba(0,200,140,0.10) 0%, transparent 55%),
    radial-gradient(ellipse 50% 70% at 50% 100%, rgba(30,40,120,0.25) 0%, transparent 60%) !important;
  background-attachment: fixed !important;
  color: #e2e4f0 !important;
  min-height: 100vh;
}

/* Main content area must be transparent so the body gradient shows through */
[data-theme="dark"] .main-content,
[data-theme="dark"] .content-wrapper,
[data-theme="dark"] .page-wrapper,
[data-theme="dark"] main {
  background: transparent !important;
}

[data-theme="dark"] code,
[data-theme="dark"] pre,
[data-theme="dark"] .mono,
[data-theme="dark"] .font-mono,
[data-theme="dark"] [data-mono] {
  font-family: 'JetBrains Mono', 'Fira Code', 'Courier New', monospace;
}

/* ============================================================
   Sidebar — shell
   ============================================================ */

[data-theme="dark"] .sidebar {
  width: 220px !important;
  background: var(--sidebar-bg, #111827) !important; /* solid opaque — was semi-transparent gradient */
  border-right: 1px solid rgba(255,255,255,0.07) !important;
  box-shadow: none !important;
  overflow: visible !important;
  opacity: 1 !important;
}

/* Subtle violet tint overlay */
[data-theme="dark"] .sidebar::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(99,60,255,0.06) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

/* Lift all direct children above the ::before overlay */
[data-theme="dark"] .sidebar > * {
  position: relative;
  z-index: 1;
}

/* Main content offset matches narrower sidebar */
[data-theme="dark"] .main-content {
  margin-left: 220px !important;
}

/* ============================================================
   Logo area
   ============================================================ */

[data-theme="dark"] .sidebar-header {
  padding-bottom: 28px !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  margin-bottom: 16px !important;
  border: none;
}

[data-theme="dark"] .sidebar-logo {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
  padding: 20px 16px 0 !important;
  width: 100% !important;
  text-align: left !important;
  background: transparent !important;
}

/* Icon badge */
[data-theme="dark"] .sidebar-logo-icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #6b3cff 0%, #00c88c 100%);
  box-shadow: 0 4px 16px rgba(107,60,255,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}

/* Wordmark */
[data-theme="dark"] .sidebar-logo-text {
  font-weight: 700;
  letter-spacing: 0.04em;
  font-size: 15px;
  background: linear-gradient(90deg, #fff 0%, #a78bfa 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap;
}

/* ============================================================
   Nav items
   ============================================================ */

[data-theme="dark"] .sidebar-nav {
  padding: 0 8px;
  margin-bottom: 8px;
}

[data-theme="dark"] .sidebar-nav-item {
  margin-bottom: 4px !important;
}

[data-theme="dark"] .sidebar-nav-link {
  color: rgba(226,228,240,0.55) !important;
  border-radius: 10px !important;
  padding: 9px 12px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease !important;
  position: relative;
  border: 1px solid transparent;
}

[data-theme="dark"] .sidebar-user .sidebar-nav-link {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
}
[data-theme="dark"] .sidebar-user .sidebar-nav-link:hover {
  background: rgba(255,255,255,0.08) !important;
  border: none !important;
}

[data-theme="dark"] .sidebar-nav-link:hover {
  background: rgba(255,255,255,0.06) !important;
  color: #e2e4f0 !important;
}

[data-theme="dark"] .sidebar-nav-link.active {
  background: linear-gradient(135deg, rgba(107,60,255,0.25) 0%, rgba(0,200,140,0.12) 100%) !important;
  border: 1px solid rgba(107,60,255,0.3) !important;
  box-shadow: 0 2px 12px rgba(107,60,255,0.15) !important;
  color: #fff !important;
}

/* Left accent bar on active item */
[data-theme="dark"] .sidebar-nav-link.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  bottom: 20%;
  width: 3px;
  background: linear-gradient(180deg, #6b3cff, #00c88c);
  border-radius: 0 2px 2px 0;
}

/* ============================================================
   Sidebar divider
   ============================================================ */

[data-theme="dark"] .sidebar-divider {
  background: rgba(255,255,255,0.06) !important;
  border: none !important;
  height: 1px !important;
  margin: 12px 0 !important;
}

/* ============================================================
   Bottom section — user chip + actions
   ============================================================ */

[data-theme="dark"] .sidebar-user {
  padding: 0 8px !important;
  border-top: none !important;
}

/* User chip pill */
[data-theme="dark"] .sidebar-user-chip {
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  overflow: hidden;
}

/* Avatar circle */
[data-theme="dark"] .sidebar-user-avatar {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #6b3cff, #00c88c);
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
}

[data-theme="dark"] .sidebar-user-email {
  color: rgba(226,228,240,0.55) !important;
  font-size: 11px !important;
  margin-bottom: 0 !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}

/* Sign Out link — bold orange so it's the obvious "leave the app" action
   and clearly visible against the dark sidebar. */
[data-theme="dark"] .sidebar-logout {
  color: #ff9900 !important;
  border-radius: 10px !important;
  padding: 9px 12px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  transition: background 0.18s ease, color 0.18s ease !important;
  border: 1px solid transparent;
}

[data-theme="dark"] .sidebar-logout:hover {
  background: rgba(255,153,0,0.12) !important;
  color: #ffb340 !important;
}

/* ============================================================
   Nav collapse button
   ============================================================ */

[data-theme="dark"] #nav-collapse-btn {
  color: rgba(226,228,240,0.35) !important;
  background: none !important;
  border: none;
}

[data-theme="dark"] #nav-collapse-btn:hover {
  background: rgba(255,255,255,0.06) !important;
  color: #e2e4f0 !important;
}

/* ============================================================
   Collapsed sidebar adjustments
   ============================================================ */

[data-theme="dark"] .sidebar.nav-collapsed {
  width: 54px !important;
  overflow: hidden !important;
}

[data-theme="dark"] .sidebar.nav-collapsed .sidebar-logo-text,
[data-theme="dark"] .sidebar.nav-collapsed .sidebar-user-chip,
[data-theme="dark"] .sidebar.nav-collapsed .sidebar-user-email {
  display: none !important;
}

[data-theme="dark"] .main-content.nav-collapsed {
  margin-left: 54px !important;
  max-width: calc(100vw - 54px) !important;
}

/* PS-021: center icons in collapsed mini sidebar */
[data-theme="dark"] .sidebar.nav-collapsed .sidebar-nav-link,
[data-theme="dark"] .sidebar.nav-collapsed .sidebar-logout {
  justify-content: center !important;
  padding: 10px 0 !important;
  width: 100% !important;
}
html[data-theme="light"] .sidebar.nav-collapsed .sidebar-nav-link,
html[data-theme="light"] .sidebar.nav-collapsed .sidebar-logout {
  justify-content: center !important;
  padding: 10px 0 !important;
  width: 100% !important;
}

/* ============================================================
   Mobile
   ============================================================ */

@media (max-width: 768px) {
  [data-theme="dark"] .sidebar {
    width: 80vw !important;
    max-width: 260px !important;
  }

  [data-theme="dark"] .main-content {
    margin-left: 0 !important;
  }
}

/* ============================================================
   Global card system — dark mode (all pages)
   ============================================================ */

[data-theme="dark"] .card,
[data-theme="dark"] [class*="card"]:not(.sidebar-nav-link),
[data-theme="dark"] .panel,
[data-theme="dark"] .table-card,
[data-theme="dark"] .stat-card,
[data-theme="dark"] .filters-panel,
[data-theme="dark"] #recent-scans-card,
[data-theme="dark"] #upload-card {
  background: linear-gradient(145deg, rgba(255,255,255,0.065) 0%, rgba(255,255,255,0.025) 100%) !important;
  border: 1px solid rgba(255,255,255,0.09) !important;
  border-radius: 14px !important;
  position: relative !important;
}

[data-theme="dark"] .card::before,
[data-theme="dark"] [class*="card"]:not(.sidebar-nav-link)::before,
[data-theme="dark"] .table-card::before,
[data-theme="dark"] .stat-card::before,
[data-theme="dark"] #recent-scans-card::before,
[data-theme="dark"] #upload-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.14), transparent);
  pointer-events: none;
}

[data-theme="dark"] .card:hover,
[data-theme="dark"] .stat-card:hover,
[data-theme="dark"] .table-card:hover {
  border-color: rgba(255,255,255,0.13) !important;
  box-shadow: 0 4px 24px rgba(107,60,255,0.12) !important;
}

/* ============================================================
   Light mode — 3D white card treatment (all pages)
   ============================================================ */

html[data-theme="light"] .stat-card,
html[data-theme="light"] .table-card,
html[data-theme="light"] #recent-scans-card,
html[data-theme="light"] #upload-card,
html[data-theme="light"] .card,
html[data-theme="light"] .metric-card,
html[data-theme="light"] [class*="card"]:not(.sidebar-nav-link),
html[data-theme="light"] [class*="panel"],
html[data-theme="light"] [id^="dm-card-"] {
  background: #ffffff !important;
  background-image: none !important;
  border: 1px solid rgba(107,60,255,0.12) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.9) inset,
    0 2px 4px rgba(0,0,0,0.06),
    0 8px 24px rgba(107,60,255,0.08),
    0 16px 40px rgba(0,0,0,0.05) !important;
  border-radius: 14px !important;
}

html[data-theme="light"] .stat-card:hover,
html[data-theme="light"] .table-card:hover,
html[data-theme="light"] .metric-card:hover,
html[data-theme="light"] [id^="dm-card-"]:hover,
html[data-theme="light"] [class*="card"]:not(.sidebar-nav-link):hover {
  background: #ffffff !important;
  border-color: rgba(107,60,255,0.25) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.9) inset,
    0 4px 8px rgba(0,0,0,0.08),
    0 12px 32px rgba(107,60,255,0.14),
    0 24px 48px rgba(0,0,0,0.06) !important;
  transform: translateY(-1px) !important;
  transition: all 0.2s ease !important;
}

/* ============================================================
   Dark mode — enhanced card gradient (all pages)
   Stat cards use the opaque depth variables; other cards keep
   the translucent glassmorphism look.
   ============================================================ */

[data-theme="dark"] .stat-card {
  background: linear-gradient(135deg, var(--color-card-gradient-start), var(--color-card-gradient-end)) !important;
  border: 1px solid rgba(255,255,255,0.09) !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
}
[data-theme="dark"] .table-card,
[data-theme="dark"] #recent-scans-card,
[data-theme="dark"] #upload-card,
[data-theme="dark"] .card,
[data-theme="dark"] [class*="card"]:not(.sidebar-nav-link):not(.stat-card) {
  background: linear-gradient(145deg, rgba(255,255,255,0.065) 0%, rgba(255,255,255,0.025) 100%) !important;
  border: 1px solid rgba(255,255,255,0.09) !important;
}
[data-theme="dark"] .stat-card:hover,
[data-theme="dark"] .table-card:hover,
[data-theme="dark"] [class*="card"]:not(.sidebar-nav-link):hover {
  border-color: rgba(255,255,255,0.14) !important;
  box-shadow: 0 4px 24px rgba(107,60,255,0.15) !important;
}

/* ============================================================
   Kill the white circle/box that appears around sidebar icons
   ============================================================ */
[data-theme="dark"] .sidebar-nav-link > span:first-child,
[data-theme="dark"] .sidebar-nav-link span:first-child,
[data-theme="dark"] .sidebar-user .sidebar-nav-link span {
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  width: auto !important;
  height: auto !important;
}
html[data-theme="light"] .sidebar-nav-link span:first-child,
html[data-theme="light"] .sidebar-user .sidebar-nav-link span {
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* ── Light mode: kill border/box on non-active sidebar links ── */
html[data-theme="light"] .sidebar-nav-link:not(.active) {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}
html[data-theme="light"] .sidebar-user .sidebar-nav-link:not(.active) {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}
