:root {
  --clr-primary: #3B82F6;
  --clr-secondary: #1E293B;
  --clr-success: #10B981;
  --clr-warning: #F59E0B;
  --clr-danger: #EF4444;
}

.text-primary { color: var(--clr-primary); }
.bg-primary { background-color: var(--clr-primary); }
.border-primary { border-color: var(--clr-primary); }
.bg-primary\/10 { background-color: rgba(59, 130, 246, 0.10); }
.bg-primary\/20 { background-color: rgba(59, 130, 246, 0.20); }
.bg-primary\/90 { background-color: rgba(59, 130, 246, 0.90); }
.text-secondary { color: var(--clr-secondary); }
.bg-secondary { background-color: var(--clr-secondary); }
.text-success { color: var(--clr-success); }
.bg-success { background-color: var(--clr-success); }
.bg-success\/10 { background-color: rgba(16, 185, 129, 0.10); }
.text-warning { color: var(--clr-warning); }
.bg-warning { background-color: var(--clr-warning); }
.bg-warning\/10 { background-color: rgba(245, 158, 11, 0.10); }
.text-danger { color: var(--clr-danger); }
.bg-danger { background-color: var(--clr-danger); }
.bg-danger\/10 { background-color: rgba(239, 68, 68, 0.10); }

/* Ensure Inter is first in sans stack if loaded */
.font-sans { font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }

/* Sidebar responsive helpers */
.sidebar-toggle-wrapper {
  display: none;
}

.sidebar-close-btn {
  display: none;
}

#sidebar-scrim {
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

#sidebar-scrim:not(.sidebar-scrim-hidden) {
  display: block;
  opacity: 1;
}

body.sidebar-locked {
  overflow: hidden;
}

@media (max-width: 1125px) {
  .sidebar-toggle-wrapper {
    display: block;
    margin-bottom: 1rem;
  }

  .sidebar-close-btn {
    display: flex;
  }

  #sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    transform: translateX(-105%);
    transition: transform 0.3s ease;
    z-index: 60;
    width: min(80vw, 320px);
    max-height: 100vh;
    border-radius: 0;
    border-right-width: 1px;
    border-left: none;
    pointer-events: none;
  }

  #sidebar[data-open="true"] {
    transform: translateX(0);
    pointer-events: auto;
  }

  #sidebar-scrim {
    z-index: 50;
    pointer-events: none;
  }

  #sidebar-scrim:not(.sidebar-scrim-hidden) {
    pointer-events: auto;
  }
}
