/* =============================================================
   BASE + COMPONENTS
   ============================================================= */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}

h1,h2,h3,h4 { margin: 0; font-weight: var(--fw-semibold); letter-spacing: -0.02em; color: var(--text); }
h1 { font-size: var(--fs-h1); line-height: var(--lh-h1); }
h2 { font-size: var(--fs-h2); line-height: var(--lh-h2); }
h3 { font-size: var(--fs-h3); line-height: var(--lh-h3); }
p  { margin: 0; }
a  { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-hover); }
small { font-size: var(--fs-sm); }

.muted { color: var(--text-2); }
.eyebrow {
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  letter-spacing: .08em; text-transform: uppercase; color: var(--primary);
}

:focus-visible { outline: none; box-shadow: var(--ring); border-radius: var(--radius-sm); }

/* ---- Layout helpers ---- */
.container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 var(--space-5); }
.stack > * + * { margin-top: var(--space-4); }
.row { display: flex; gap: var(--space-4); }
.row.wrap { flex-wrap: wrap; }
.spread { display:flex; align-items:center; justify-content:space-between; gap: var(--space-4); }
.grid { display: grid; gap: var(--space-5); }

/* ---- Buttons ---- */
.btn {
  --_bg: var(--surface); --_fg: var(--text); --_bd: var(--border);
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: inherit; font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  padding: 10px 16px; border-radius: var(--radius-md);
  background: var(--_bg); color: var(--_fg); border: 1px solid var(--_bd);
  cursor: pointer; white-space: nowrap;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease),
              border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-primary { --_bg: var(--primary); --_fg: var(--on-primary); --_bd: var(--primary); box-shadow: var(--shadow-sm); }
.btn-primary:hover { --_bg: var(--primary-hover); --_bd: var(--primary-hover); color: var(--on-primary); }
.btn-ghost { --_bg: transparent; --_bd: transparent; }
.btn-ghost:hover { --_bg: var(--surface-hover); }
.btn-soft { --_bg: var(--primary-soft); --_fg: var(--primary); --_bd: transparent; }
.btn-danger { --_bg: var(--danger); --_fg: #fff; --_bd: var(--danger); }
.btn-lg { padding: 13px 22px; font-size: var(--fs-body); border-radius: var(--radius-lg); }
.btn-sm { padding: 7px 12px; font-size: var(--fs-xs); }
.btn-block { width: 100%; }
.btn:disabled { opacity:.55; cursor:not-allowed; transform:none; }

/* ---- Cards ---- */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-xs);
}
.card-pad { padding: var(--space-5); }
.card-hover { transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.card-hover:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); border-color: var(--border-strong); }

/* ---- Badges / pills ---- */
.badge {
  display:inline-flex; align-items:center; gap:6px;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  padding: 3px 10px; border-radius: var(--radius-full);
  background: var(--surface-2); color: var(--text-2); border:1px solid var(--border);
}
.badge .dot { width:6px; height:6px; border-radius:50%; background: currentColor; }
.badge-success { background: var(--success-soft); color: var(--success); border-color: transparent; }
.badge-warning { background: var(--warning-soft); color: var(--warning); border-color: transparent; }
.badge-danger  { background: var(--danger-soft);  color: var(--danger);  border-color: transparent; }
.badge-primary { background: var(--primary-soft); color: var(--primary); border-color: transparent; }

/* ---- Forms ---- */
.field { display:flex; flex-direction:column; gap: var(--space-2); margin-bottom: var(--space-4); }
.label { font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text); }
.input, .select, .textarea {
  width: 100%; font-family: inherit; font-size: var(--fs-sm); color: var(--text);
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: var(--radius-md); padding: 11px 13px;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.input::placeholder, .textarea::placeholder { color: var(--text-3); }
.input:focus, .select:focus, .textarea:focus { border-color: var(--primary); box-shadow: var(--ring); }
.textarea { resize: vertical; min-height: 96px; line-height: 1.5; }
.hint { font-size: var(--fs-xs); color: var(--text-2); }
.field-error .input { border-color: var(--danger); }

/* ---- Tables ---- */
.table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: var(--fs-sm); }
.table th {
  text-align: left; font-weight: var(--fw-semibold); color: var(--text-2);
  font-size: var(--fs-xs); letter-spacing: .03em; text-transform: uppercase;
  padding: 12px 16px; border-bottom: 1px solid var(--border);
}
.table td { padding: 14px 16px; border-bottom: 1px solid var(--border); color: var(--text); }
.table tr:last-child td { border-bottom: none; }
.table tbody tr { transition: background var(--dur) var(--ease); }
.table tbody tr:hover { background: var(--surface-hover); }

/* ---- Alerts (flash messages) ---- */
.alert { display:flex; gap: var(--space-3); padding: 13px 16px; border-radius: var(--radius-md);
         font-size: var(--fs-sm); border:1px solid transparent; }
.alert-success { background: var(--success-soft); color: var(--success); }
.alert-danger  { background: var(--danger-soft);  color: var(--danger); }
.alert-warning { background: var(--warning-soft); color: var(--warning); }
.alert-info    { background: var(--primary-soft); color: var(--primary); }

/* ---- Empty / skeleton states ---- */
.empty { text-align:center; padding: var(--space-8) var(--space-5); color: var(--text-2); }
.empty .empty-icon {
  width:48px; height:48px; margin: 0 auto var(--space-4); display:grid; place-items:center;
  border-radius: var(--radius-lg); background: var(--surface-2); color: var(--text-3);
}
.skeleton { background: linear-gradient(90deg, var(--surface-2) 25%, var(--surface-hover) 37%, var(--surface-2) 63%);
            background-size: 400% 100%; animation: shimmer 1.4s ease infinite; border-radius: var(--radius-sm); }
@keyframes shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* ---- Utilities ---- */
.text-center { text-align:center; }
.hide { display:none !important; }
@media (prefers-reduced-motion: reduce) { * { animation: none !important; transition: none !important; } }
