/* base — reset, custom properties, typography, layout primitives */

:root {
  --bg:      #080a0d;
  --bg2:     #0d1117;
  --bg3:     #131920;
  --bg4:     #1a2230;
  --border:  #1e2d3d;
  --border2: #283d52;
  --text:    #c4d4e8;
  --dim:     #4a6280;
  --bright:  #e8f2ff;
  --accent:  #00e5b0;
  --blue:    #3d9eff;
  --red:     #ff4d6a;
  --yellow:  #ffd166;
  --orange:  #ff8c42;
  --purple:  #a78bff;
  --syne:    'Syne', sans-serif;
  --mono:    'JetBrains Mono', monospace;
}

*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body { height: 100%; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.5;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Subtle scanline texture */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0, 0, 0, 0.02) 2px,
    rgba(0, 0, 0, 0.02) 4px
  );
  pointer-events: none;
  z-index: 9999;
}

#app { min-height: 100vh; }

/* Custom scrollbar */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--dim); }
