/* Copyright (c) 2026 LandmarkLouie. Unified design tokens — apply everywhere. */

:root {
  /* Core palette */
  --color-dark-1: #1a2234;
  --color-dark-2: #111827;
  --color-dark-3: #1e293b;
  --color-panel: #f8f9fb;
  --color-card: #ffffff;
  --color-card-hover: #f8f9fb;

  /* Gold system */
  --color-gold: #c9a84c;
  --color-gold-light: #e8d5a3;
  --color-gold-dark: #a67c32;
  --color-gold-bg: #fdf8ee;
  --color-gold-border: rgba(201, 168, 76, 0.25);

  /* Text */
  --color-text-primary: #1a1a2e;
  --color-text-secondary: #64748b;
  --color-text-muted: #94a3b8;
  --color-text-on-dark: #f1f0ec;
  --color-text-muted-dark: #8a9bb5;

  /* Semantic */
  --color-success: #22c55e;
  --color-success-bg: #f0fdf4;
  --color-warning: #f59e0b;
  --color-warning-bg: #fffbeb;
  --color-danger: #ef4444;
  --color-danger-bg: #fef2f2;
  --color-info: #3b82f6;
  --color-info-bg: #eff6ff;

  /* Typography */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-serif: 'Georgia', 'Times New Roman', serif;
  --font-mono: 'Fira Code', 'SF Mono', 'Courier New', monospace;

  /* Radii */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.12);
}

/* ── Shared button primitives — 3 types, max ── */
.btn-primary,
.louie-btn-primary {
  background: var(--color-gold);
  color: var(--color-dark-2);
  border: none;
  border-radius: var(--radius-md);
  padding: 10px 20px;
  font-weight: 600;
  font-family: var(--font-sans);
  cursor: pointer;
  transition: background 0.2s;
  font-size: 14px;
}
.btn-primary:hover,
.louie-btn-primary:hover { background: var(--color-gold-dark); }

.btn-secondary,
.louie-btn-secondary {
  background: transparent;
  color: var(--color-gold);
  border: 1.5px solid var(--color-gold);
  border-radius: var(--radius-md);
  padding: 10px 20px;
  font-weight: 600;
  font-family: var(--font-sans);
  cursor: pointer;
  transition: background 0.2s;
  font-size: 14px;
}
.btn-secondary:hover,
.louie-btn-secondary:hover { background: var(--color-gold-bg); }

.btn-ghost,
.louie-btn-ghost {
  background: transparent;
  color: var(--color-text-secondary);
  border: 1px solid #e2e8f0;
  border-radius: var(--radius-md);
  padding: 10px 20px;
  font-weight: 500;
  font-family: var(--font-sans);
  cursor: pointer;
  transition: background 0.2s;
  font-size: 14px;
}
.btn-ghost:hover,
.louie-btn-ghost:hover { background: var(--color-panel); }

/* ── Sidebar category badges — consistent cross-OS ── */
.sidebar-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 2px 5px;
  border-radius: 3px;
  margin-right: 8px;
  font-family: var(--font-sans);
}
.sidebar-badge.gold { background: var(--color-gold); color: var(--color-dark-2); }
.sidebar-badge.dark { background: var(--color-dark-2); color: var(--color-gold); }
.sidebar-badge.muted { background: rgba(255, 255, 255, 0.08); color: var(--color-text-muted-dark); }

/* ── Status / metric badges ── */
.status-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  font-family: var(--font-sans);
}
.status-badge.success { background: var(--color-success-bg); color: var(--color-success); }
.status-badge.warning { background: var(--color-warning-bg); color: var(--color-warning); }
.status-badge.danger  { background: var(--color-danger-bg);  color: var(--color-danger); }
.status-badge.info    { background: var(--color-info-bg);    color: var(--color-info); }

/* ── Card primitive ── */
.louie-card {
  background: var(--color-card);
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  transition: background 0.15s, box-shadow 0.15s;
}
.louie-card:hover { background: var(--color-card-hover); box-shadow: var(--shadow-md); }

/* ── Modal primitive ── */
.louie-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(15, 23, 42, 0.7);
  display: none;
  align-items: center; justify-content: center;
  z-index: 300;
  padding: 40px 20px;
}
.louie-modal-overlay.open { display: flex; }
.louie-modal {
  background: var(--color-card);
  border-radius: var(--radius-lg);
  max-width: 780px; width: 100%;
  max-height: 85vh;
  box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.louie-modal-header {
  background: var(--color-dark-1);
  color: var(--color-text-on-dark);
  padding: 18px 24px;
  border-left: 4px solid var(--color-gold);
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px;
}
.louie-modal-header .title { font-size: 16px; font-weight: 600; font-family: var(--font-sans); }
.louie-modal-header .subtitle { font-size: 12px; color: var(--color-text-muted-dark); margin-top: 2px; }
.louie-modal-header .close {
  background: none; border: none; color: var(--color-gold);
  font-size: 22px; cursor: pointer; line-height: 1; padding: 0;
}
.louie-modal-body {
  padding: 24px; overflow-y: auto; flex: 1;
  background: var(--color-card); color: var(--color-text-primary);
}
.louie-modal-footer {
  padding: 16px 24px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  display: flex; justify-content: flex-end; gap: 12px;
  background: var(--color-panel);
}
