/* ==========================================================
   Warpline Design System — Colors, Typography & Spacing
   ========================================================== */

/* --- Fonts --- */
@font-face {
  font-family: 'BR Sonoma';
  src: url('./fonts/BRSonoma-Regular.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Cerebri Sans';
  src: url('./fonts/CerebriSans-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap');

/* --- Light Mode (default) --- */
:root {
  /* Background */
  --bg:              #FAFAF7;
  --surface:         #F2F1ED;
  --surface-raised:  #EAEAE5;

  /* Border */
  --border:          #D6D5D0;
  --border-subtle:   #E5E4DF;

  /* Foreground */
  --fg1:             #0E0E0C;
  --fg2:             #6B6A65;
  --fg3:             #9B9A95;

  /* Accent */
  --accent:          #2F8F7F;
  --accent-hover:    #277A6C;
  --accent-subtle:   rgba(47, 143, 127, 0.08);

  /* Semantic */
  --success:         #3A9A5B;
  --warning:         #C08A30;
  --error:           #C0453A;

  /* Typography */
  --font-display:    'BR Sonoma', 'Cerebri Sans', system-ui, sans-serif;
  --font-body:       'Cerebri Sans', 'BR Sonoma', system-ui, sans-serif;
  --font-mono:       'JetBrains Mono', ui-monospace, 'SFMono-Regular', monospace;

  /* Type scale */
  --text-display:    40px;
  --text-h1:         32px;
  --text-h2:         24px;
  --text-h3:         18px;
  --text-body:       15px;
  --text-small:      13px;
  --text-caption:    11px;
  --text-code:       14px;

  --leading-display: 48px;
  --leading-h1:      40px;
  --leading-h2:      32px;
  --leading-h3:      24px;
  --leading-body:    24px;
  --leading-small:   20px;
  --leading-caption: 16px;
  --leading-code:    22px;

  /* Spacing */
  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  24px;
  --sp-6:  32px;
  --sp-7:  48px;
  --sp-8:  64px;
  --sp-9:  96px;

  /* Radii */
  --radius-sm:  2px;
  --radius-md:  4px;
  --radius-lg:  6px;

  /* Shadows */
  --shadow-popover: 0 4px 12px rgba(14, 14, 12, 0.08);

  /* Transitions */
  --transition: 120ms ease-out;

  /* Focus */
  --focus-ring: 0 0 0 2px var(--bg), 0 0 0 4px var(--accent);
}

/* --- Dark Mode --- */
[data-theme="dark"] {
  --bg:              #0E0E0C;
  --surface:         #1A1A18;
  --surface-raised:  #242422;
  --border:          #2E2E2B;
  --border-subtle:   #222220;
  --fg1:             #FAFAF7;
  --fg2:             #9B9A95;
  --fg3:             #6B6A65;
  --accent:          #5FB8A6;
  --accent-hover:    #72C4B4;
  --accent-subtle:   rgba(95, 184, 166, 0.08);
  --success:         #5CB87A;
  --warning:         #D4A853;
  --error:           #D4695F;
  --shadow-popover:  0 4px 12px rgba(0, 0, 0, 0.24);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bg:              #0E0E0C;
    --surface:         #1A1A18;
    --surface-raised:  #242422;
    --border:          #2E2E2B;
    --border-subtle:   #222220;
    --fg1:             #FAFAF7;
    --fg2:             #9B9A95;
    --fg3:             #6B6A65;
    --accent:          #5FB8A6;
    --accent-hover:    #72C4B4;
    --accent-subtle:   rgba(95, 184, 166, 0.08);
    --success:         #5CB87A;
    --warning:         #D4A853;
    --error:           #D4695F;
    --shadow-popover:  0 4px 12px rgba(0, 0, 0, 0.24);
  }
}

/* --- Base resets --- */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg1);
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: var(--leading-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* --- Semantic type --- */
h1, .h1 {
  font-family: var(--font-display);
  font-size: var(--text-h1);
  line-height: var(--leading-h1);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 var(--sp-4);
}

h2, .h2 {
  font-family: var(--font-display);
  font-size: var(--text-h2);
  line-height: var(--leading-h2);
  font-weight: 400;
  letter-spacing: -0.005em;
  margin: 0 0 var(--sp-3);
}

h3, .h3 {
  font-family: var(--font-body);
  font-size: var(--text-h3);
  line-height: var(--leading-h3);
  font-weight: 600;
  margin: 0 0 var(--sp-2);
}

p {
  margin: 0 0 var(--sp-4);
}

small, .small {
  font-size: var(--text-small);
  line-height: var(--leading-small);
  color: var(--fg2);
}

code, .code-inline {
  font-family: var(--font-mono);
  font-size: var(--text-code);
  background: var(--surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 1px 6px;
}

pre, .code-block {
  font-family: var(--font-mono);
  font-size: var(--text-code);
  line-height: var(--leading-code);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-4);
  overflow-x: auto;
  margin: 0 0 var(--sp-4);
}

/* --- Utility --- */
.font-display { font-family: var(--font-display); }
.font-body    { font-family: var(--font-body); }
.font-mono    { font-family: var(--font-mono); }
.fg1 { color: var(--fg1); }
.fg2 { color: var(--fg2); }
.fg3 { color: var(--fg3); }
.accent { color: var(--accent); }
