/**
 * Generated from Hashnode — DESIGN.md
 * https://www.webdesignhot.com/design.md/
 */
:root {
  /* role tokens (resolved) */
  --bg: #0f1117;
  --surface: #161a23;
  --surface-alt: #161a23;
  --text: #ffffff;
  --text-dim: #ffffff;
  --text-faint: #4b5563;
  --brand: #2962ff;
  --on-brand: #ffffff;
  --border: rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.15);
  --success: #10b981;
  --warning: #f59e0b;
  --danger: #ef4444;

  /* full color palette */
  --color-bg: #0f1117;
  --color-bg-soft: #0a0c12;
  --color-bg-elev-1: #161a23;
  --color-bg-elev-2: #1f2937;
  --color-bg-elev-3: #252b3a;
  --color-surface: #161a23;
  --color-surface-light: #ffffff;
  --color-text: #ffffff;
  --color-text-strong: #ffffff;
  --color-text-body: #e5e7eb;
  --color-text-soft: #a8b1bf;
  --color-text-muted: #6b7280;
  --color-text-faint: #4b5563;
  --color-brand: #2962ff;
  --color-brand-hover: #1d4ed8;
  --color-brand-deep: #1e40af;
  --color-brand-soft: rgba(41, 98, 255, 0.12);
  --color-brand-glow: rgba(41, 98, 255, 0.32);
  --color-brand-tint: rgba(41, 98, 255, 0.08);
  --color-on-brand: #ffffff;
  --color-link: #2962ff;
  --color-link-hover: #3b82f6;
  --color-cta-bg: #2962ff;
  --color-cta-text: #ffffff;
  --color-selected: #2962ff;
  --color-border: rgba(255, 255, 255, 0.08);
  --color-border-soft: rgba(255, 255, 255, 0.04);
  --color-border-strong: rgba(255, 255, 255, 0.15);
  --color-border-brand: rgba(41, 98, 255, 0.40);
  --color-shadow-soft: rgba(0, 0, 0, 0.20);
  --color-shadow-elev: rgba(0, 0, 0, 0.40);
  --color-shadow-deep: rgba(0, 0, 0, 0.60);
  --color-shadow-glow: rgba(41, 98, 255, 0.15);
  --color-scrim: rgba(15, 17, 23, 0.80);
  --color-success: #10b981;
  --color-success-soft: rgba(16, 185, 129, 0.12);
  --color-warning: #f59e0b;
  --color-warning-soft: rgba(245, 158, 11, 0.12);
  --color-danger: #ef4444;
  --color-danger-soft: rgba(239, 68, 68, 0.12);
  --color-info: #2962ff;
  --color-info-soft: rgba(41, 98, 255, 0.12);
  --color-syntax-keyword: #c084fc;
  --color-syntax-string: #86efac;
  --color-syntax-number: #fbbf24;
  --color-syntax-comment: #6b7280;
  --color-syntax-fn: #60a5fa;

  /* type */
  --display-size: 72px;
  --h1-size: 40px;
  --h2-size: 32px;
  --body-size: 16px;
  --label-size: 12px;
  --body-line-height: 1.6;
  --display-tracking: -0.03em;

  /* shape */
  --radius-button: 8px;
  --radius-card: 12px;
  --radius-pill: 9999px;

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

  /* fonts */
  --font-display: 'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-body:    'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;
}
