/* WorkBot Global Theme Variables
   - Unified, modern, high-contrast design tokens
  - Light and dark mode via html.dark (set by app/static/theme.js)
*/

html {
  /* Light mode */
  --bg: #ffffff;
  --bg-alt: #f7f7f7;
  --text: #1a1a1a;
  --text-muted: #555;
  --border: #e0e0e0;
  --primary: #1E90FF;
  --primary-hover: #1873CC;

  --font-monospace: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  /* Typography */
  --font-size-base: 15px;
  --font-size-small: 13px;
  --font-size-large: 18px;
  --line-height: 1.45;

  /* Spacing */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;

  /* Legacy aliases (keep existing CSS working) */
  --fg: var(--text);
  --muted: var(--text-muted);
  --accent: var(--primary);
  --card-bg: var(--bg-alt);

  /* Print tokens (stable, theme-independent) */
  --print-bg: #ffffff;
  --print-text: #000000;
  --print-border: #000000;
  --print-muted: #555555;

  /* Map Bootstrap variables onto theme variables */
  --bs-body-bg: var(--bg);
  --bs-body-color: var(--text);
  --bs-border-color: var(--border);
  --bs-secondary-color: var(--text-muted);
  --bs-primary: var(--primary);
  --bs-link-color: var(--primary);
  --bs-link-hover-color: var(--primary-hover);
  --bs-card-bg: var(--bg-alt);
  --bs-dropdown-bg: var(--bg);
}

html.dark {
  /* Dark mode */
  --bg: #0f0f0f;
  --bg-alt: #1a1a1a;
  --text: #f5f5f5;
  --text-muted: #c7c7c7;
  --border: #333;
  --primary: #6FB8FF;
  --primary-hover: #8FC7FF;

  --font-monospace: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  /* Legacy aliases */
  --fg: var(--text);
  --muted: var(--text-muted);
  --accent: var(--primary);
  --card-bg: var(--bg-alt);

  /* Bootstrap subtle backgrounds */
  --bs-tertiary-bg: #161616;
  --bs-secondary-bg: #1d1d1d;
  --bs-border-color-translucent: rgba(255, 255, 255, 0.08);
}

html, body {
  background: var(--bg) !important;
  color: var(--text) !important;
  font-size: var(--font-size-base);
  line-height: var(--line-height);
}

/* Ensure common layout wrappers inherit theme */
.content-wrapper,
.page-container,
.main-content,
.wrapper,
.body-content,
.container-fluid {
  background: var(--bg) !important;
  color: var(--text) !important;
}

/* Override Bootstrap light helpers so they don't force light mode */
.bg-light,
.bg-white {
  background-color: var(--bg-alt) !important;
  color: var(--text) !important;
}

.text-bg-light {
  background-color: var(--bg-alt) !important;
  color: var(--text) !important;
}

/* Bootstrap components often re-declare their own --bs-* vars (e.g. cards, dropdowns).
   Ensure those surfaces stay theme-aware in dark mode. */
html.dark .card {
  --bs-card-bg: var(--bg-alt);
  --bs-card-cap-bg: var(--bg-alt);
  --bs-card-color: var(--text);
  background-color: var(--bg-alt) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}

html.dark .card-header,
html.dark .card-footer {
  background-color: transparent !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}

html.dark .table {
  --bs-table-color: var(--text);
  color: var(--text) !important;
}

html.dark .dropdown-menu {
  --bs-dropdown-bg: var(--bg-alt);
  background-color: var(--bg-alt) !important;
  border-color: var(--border) !important;
}

html.dark .dropdown-item {
  color: var(--text) !important;
}

html.dark .dropdown-item:hover,
html.dark .dropdown-item:focus {
  background-color: var(--bg) !important;
  color: var(--text) !important;
}

html.dark .list-group-item {
  background-color: var(--bg-alt) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}

/* Global hover + focus states */
:where(a, button, input, select, textarea):focus-visible {
  outline: 2px solid rgba(0, 102, 204, 0.35);
  outline-offset: 2px;
}

html.dark :where(a, button, input, select, textarea):focus-visible {
  outline: 2px solid rgba(77, 163, 255, 0.45);
}

/* Subtle transitions (optional micro-animations) */
a,
button,
.btn,
.card,
.wb-nav a,
.nav-link {
  transition: 0.15s ease;
}
