/* SpecForge Design System — Component Library
 * Real, reusable component classes. Previews render these; the Next app mirrors
 * the same visual language in Tailwind/React.
 */

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

.ds-canvas {
  padding: var(--s-8);
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
}

.ds-section-title {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--faint);
  margin: 0 0 var(--s-3);
}

.ds-row { display: flex; flex-wrap: wrap; align-items: center; gap: var(--s-3); }
.ds-stack { display: flex; flex-direction: column; gap: var(--s-3); }

/* --- Typography --- */
.ds-h1 { font-size: var(--text-4xl); font-weight: 650; letter-spacing: -0.02em; line-height: 1.05; margin: 0; }
.ds-h2 { font-size: var(--text-2xl); font-weight: 640; letter-spacing: -0.015em; margin: 0; }
.ds-h3 { font-size: var(--text-lg); font-weight: 620; margin: 0; }
.ds-lead { font-size: var(--text-md); color: var(--muted); margin: 0; }
.ds-mono { font-family: var(--font-mono); font-size: var(--text-sm); }

/* --- Buttons --- */
.ds-btn {
  --_bg: transparent;
  --_fg: var(--fg);
  --_bd: var(--edge-strong);
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  font: inherit; font-weight: 540; font-size: var(--text-sm);
  padding: 8px 14px; border-radius: var(--r);
  background: var(--_bg); color: var(--_fg);
  border: 1px solid var(--_bd);
  cursor: pointer; white-space: nowrap;
  transition: background .15s ease, border-color .15s ease, transform .04s ease, box-shadow .15s ease;
}
.ds-btn:hover { background: var(--panel-2); }
.ds-btn:active { transform: translateY(0.5px); }
.ds-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--accent-ring); }

.ds-btn--primary { --_bg: var(--accent); --_fg: var(--accent-fg); --_bd: transparent; box-shadow: var(--shadow-1); }
.ds-btn--primary:hover { background: var(--accent-hover); }
.ds-btn--primary:active { background: var(--accent-press); }

.ds-btn--ghost { --_bd: transparent; --_fg: var(--muted); }
.ds-btn--ghost:hover { color: var(--fg); background: var(--panel); }

.ds-btn--danger { --_bg: transparent; --_fg: var(--danger); --_bd: color-mix(in srgb, var(--danger) 40%, transparent); }
.ds-btn--danger:hover { background: color-mix(in srgb, var(--danger) 12%, transparent); }

.ds-btn--sm { padding: 5px 10px; font-size: var(--text-xs); border-radius: var(--r-sm); }
.ds-btn--lg { padding: 11px 18px; font-size: var(--text-base); border-radius: var(--r-lg); }
.ds-btn[disabled] { opacity: 0.45; cursor: not-allowed; }

/* --- Inputs --- */
.ds-field { display: flex; flex-direction: column; gap: 6px; }
.ds-label { font-size: var(--text-sm); color: var(--muted); }
.ds-input, .ds-select, .ds-textarea {
  width: 100%; font: inherit; font-size: var(--text-sm);
  color: var(--fg); background: var(--panel);
  border: 1px solid var(--edge); border-radius: var(--r);
  padding: 9px 11px; transition: border-color .15s ease, box-shadow .15s ease;
}
.ds-textarea { resize: vertical; min-height: 96px; line-height: 1.5; }
.ds-input::placeholder, .ds-textarea::placeholder { color: var(--faint); }
.ds-input:focus, .ds-select:focus, .ds-textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-ring);
}
.ds-help { font-size: var(--text-xs); color: var(--faint); }

/* --- Card --- */
.ds-card {
  background: var(--bg-elev); border: 1px solid var(--edge);
  border-radius: var(--r-lg); padding: var(--s-5); box-shadow: var(--shadow-1);
}
.ds-card--soft { background: var(--panel); box-shadow: none; }
.ds-card__title { font-weight: 600; margin: 0 0 var(--s-2); }
.ds-card__body { color: var(--muted); font-size: var(--text-sm); margin: 0; }

/* --- Badges / chips --- */
.ds-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--text-xs); font-weight: 540;
  padding: 3px 9px; border-radius: 999px;
  border: 1px solid var(--edge-strong); color: var(--muted); background: var(--panel);
}
.ds-badge--accent { color: var(--accent); border-color: var(--accent-ring); background: var(--accent-soft); }
.ds-badge--success { color: var(--success); border-color: color-mix(in srgb, var(--success) 40%, transparent); background: color-mix(in srgb, var(--success) 12%, transparent); }
.ds-badge--warn { color: var(--warn); border-color: color-mix(in srgb, var(--warn) 40%, transparent); background: color-mix(in srgb, var(--warn) 12%, transparent); }
.ds-badge--muted.is-off { text-decoration: line-through; color: var(--faint); }
.ds-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* --- Navbar --- */
.ds-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 18px; border: 1px solid var(--edge); border-radius: var(--r-lg);
  background: color-mix(in srgb, var(--bg-elev) 80%, transparent); backdrop-filter: blur(6px);
}
.ds-brand { font-family: var(--font-mono); font-weight: 640; letter-spacing: -0.01em; }
.ds-brand span { color: var(--accent); }
.ds-navlinks { display: flex; align-items: center; gap: 2px; }
.ds-navlink { font-size: var(--text-sm); color: var(--muted); padding: 6px 10px; border-radius: var(--r-sm); text-decoration: none; }
.ds-navlink:hover { color: var(--fg); background: var(--panel); }
.ds-navlink.is-active { color: var(--fg); background: var(--panel-2); }

/* --- File tree --- */
.ds-tree { font-family: var(--font-mono); font-size: var(--text-sm); border: 1px solid var(--edge); border-radius: var(--r-lg); background: var(--panel); overflow: hidden; }
.ds-tree__folder { color: var(--faint); padding: 5px 12px; }
.ds-tree__file { display: block; width: 100%; text-align: left; border: 0; background: transparent; color: var(--muted); padding: 5px 12px; cursor: pointer; font: inherit; }
.ds-tree__file:hover { background: var(--panel-2); color: var(--fg); }
.ds-tree__file.is-active { background: var(--accent-soft); color: var(--fg); box-shadow: inset 2px 0 0 var(--accent); }

/* --- Code block --- */
.ds-code { font-family: var(--font-mono); font-size: var(--text-sm); background: var(--panel); border: 1px solid var(--edge); border-radius: var(--r); padding: var(--s-4); overflow-x: auto; color: var(--fg); }

/* --- Alerts --- */
.ds-alert { display: flex; gap: var(--s-3); padding: 12px 14px; border-radius: var(--r); border: 1px solid var(--edge); background: var(--panel); font-size: var(--text-sm); }
.ds-alert--info { border-color: var(--accent-ring); background: var(--accent-soft); }
.ds-alert--warn { border-color: color-mix(in srgb, var(--warn) 40%, transparent); background: color-mix(in srgb, var(--warn) 10%, transparent); color: var(--warn); }
.ds-alert--danger { border-color: color-mix(in srgb, var(--danger) 40%, transparent); background: color-mix(in srgb, var(--danger) 10%, transparent); color: var(--danger); }

/* --- Misc --- */
.ds-kbd { font-family: var(--font-mono); font-size: var(--text-xs); border: 1px solid var(--edge-strong); border-bottom-width: 2px; border-radius: var(--r-sm); padding: 1px 6px; color: var(--muted); background: var(--panel); }
.ds-swatch { width: 100%; height: 56px; border-radius: var(--r); border: 1px solid var(--edge); }
.ds-swatch-label { font-size: var(--text-xs); color: var(--muted); margin-top: 6px; font-family: var(--font-mono); }
.ds-grid { display: grid; gap: var(--s-3); }
