:root {
  --bg: #F7F8FA;
  --surface: #FFFFFF;
  --surface-2: #F3F4F6;
  --border: #E5E7EB;
  --border-strong: #D1D5DB;

  --text: #111827;
  --text-2: #6B7280;
  --text-3: #9CA3AF;
  --text-inverse: #FFFFFF;

  --primary: #2563EB;
  --primary-hover: #1D4ED8;
  --primary-soft: #DBEAFE;

  --accent: #0EA5E9;
  --accent-soft: #E0F2FE;

  --success: #16A34A;
  --success-soft: #DCFCE7;
  --warning: #F59E0B;
  --warning-soft: #FEF3C7;
  --danger: #DC2626;
  --danger-soft: #FEE2E2;

  --ring: rgba(37, 99, 235, 0.35);
  --radius: 12px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);
  --shadow-md: 0 6px 16px rgba(17, 24, 39, .10);
}

html,
body {
  background: var(--bg);
  color: var(--text);
}

body {
  line-height: 1.45;
}

:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--ring);
}

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}

.divider {
  border-color: var(--border);
}

.input {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
  border-radius: var(--radius);
}

.btn {
  min-height: 44px;
  padding: 10px 14px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background-color .15s ease, border-color .15s ease, color .15s ease;
}

.btn-primary {
  background: var(--primary);
  color: var(--text-inverse);
}

.btn-primary:hover {
  background: var(--primary-hover);
}

.btn-secondary {
  background: var(--surface);
  color: var(--text);
  border-color: var(--border-strong);
}

.btn-ghost {
  background: transparent;
  color: var(--text);
  border-color: var(--border);
}

.icon-btn {
  width: 44px;
  height: 44px;
  border-radius: var(--radius);
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.chip {
  border-radius: 999px;
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--text-2);
  padding: 6px 12px;
}

.chip-active {
  background: var(--primary-soft);
  border-color: var(--primary);
  color: var(--primary-hover);
}

.alert {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 12px;
}

.alert-success {
  background: var(--success-soft);
  border-color: var(--success);
  color: var(--success);
}

.alert-warning {
  background: var(--warning-soft);
  border-color: var(--warning);
  color: #92400E;
}

.alert-danger {
  background: var(--danger-soft);
  border-color: var(--danger);
  color: var(--danger);
}

.badge {
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
}

.badge-neutral {
  background: var(--surface-2);
  color: var(--text);
  border: 1px solid var(--border);
}

.badge-primary {
  background: var(--primary-soft);
  color: var(--primary-hover);
  border: 1px solid var(--primary);
}

.badge-success {
  background: var(--success-soft);
  color: var(--success);
  border: 1px solid var(--success);
}

.badge-warning {
  background: var(--warning-soft);
  color: #92400E;
  border: 1px solid var(--warning);
}

.badge-danger {
  background: var(--danger-soft);
  color: var(--danger);
  border: 1px solid var(--danger);
}

.text-muted {
  color: var(--text-2);
}

.text-subtle {
  color: var(--text-3);
}

.text-success {
  color: var(--success);
}

.text-warning {
  color: #92400E;
}

.text-primary {
  color: var(--primary);
}

.text-primary-strong {
  color: var(--primary-hover);
}

.text-inverse {
  color: var(--text-inverse);
}

.bg-surface {
  background: var(--surface);
}

.bg-surface-2 {
  background: var(--surface-2);
}

.bg-primary {
  background: var(--primary);
}

.bg-primary-soft {
  background: var(--primary-soft);
}

.hover-surface-2:hover {
  background: var(--surface-2);
}

.alert-info {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--text);
}

.overlay-backdrop {
  background: rgba(17, 24, 39, 0.28);
}
