/* ── Font load ──────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700&family=Share+Tech+Mono&family=Rajdhani:wght@300;400;600&display=swap');

/* ═══════════════════════════════════════════════════════════════════════════════
   DESIGN TOKENS
   ═══════════════════════════════════════════════════════════════════════════════ */
:root {
  --color-background:      #0d0d0f;
  --color-foreground:      #1a1a2e;
  --color-surface-raised:  #1f1f35;
  --color-text-primary:    #e0e0ff;
  --color-text-secondary:  #8888aa;
  --color-text-disabled:   #444466;
  --color-text-on-accent:  #0d0d0f;
  --color-accent:          #00ffe7;
  --color-accent-hover:    #33fff0;
  --color-accent-active:   #00ccb8;
  --color-success:         #39ff14;
  --color-warning:         #ffaa00;
  --color-danger:          #ff3c5f;
  --color-info:            #3c9eff;
  --color-border:          #2a2a4a;
  --color-divider:         #1e1e38;
  --color-grid-line:       #2a2a4a;
  --color-scrollbar-thumb: #3a3a5c;
  --color-scrollbar-track: #12121e;

  --font-family-display: 'Orbitron', sans-serif;
  --font-family-body:    'Rajdhani', sans-serif;
  --font-family-mono:    'Share Tech Mono', monospace;

  --font-h1:          2.000rem;
  --font-h2:          1.600rem;
  --font-h3:          1.350rem;
  --font-h4:          1.150rem;
  --font-large:       1.300rem;
  --font-base:        1.100rem;
  --font-small:       0.950rem;
  --font-tiny:        0.800rem;
  --font-mono-offset: -0.05rem;

  --font-weight-body:    400;
  --font-weight-heading: 700;

  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;

  --radius-sm: 2px;
  --radius-md: 4px;
  --content-max: 860px;

  --transition-fast:   0.15s ease;
  --transition-normal: 0.25s ease;
  --transition-theme:  0.3s ease;

  --page-gutter: var(--space-8);
  --_swatch-chip-border: rgba(255, 255, 255, 0.08);
}

@media (max-width: 768px) { :root { --page-gutter: var(--space-5); } }
@media (max-width: 480px) { :root { --page-gutter: var(--space-4); } }

[data-scheme="light"] {
  --color-grid-line: var(--color-border);
  --_swatch-chip-border: rgba(0, 0, 0, 0.12);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { width: 100%; min-height: 100%; }

/* ═══════════════════════════════════════════════════════════════════════════════
   BASE
   ═══════════════════════════════════════════════════════════════════════════════ */
body {
  background:             var(--color-background);
  color:                  var(--color-text-primary);
  font-family:            var(--font-family-body);
  font-size:              var(--font-base);
  font-weight:            var(--font-weight-body);
  line-height:            1.6;
  -webkit-font-smoothing: antialiased;
  transition: background var(--transition-theme), color var(--transition-theme);
}

h1, h2, h3, h4 {
  font-family:    var(--font-family-display);
  font-weight:    var(--font-weight-heading);
  color:          var(--color-text-primary);
  line-height:    1.2;
  letter-spacing: 0.03em;
}
h1 { font-size: var(--font-h1); }
h2 { font-size: var(--font-h2); }
h3 { font-size: var(--font-h3); }
h4 { font-size: var(--font-h4); }
p  { line-height: 1.6; }

code, pre, kbd, .mono {
  font-family: var(--font-family-mono);
  font-size:   calc(var(--font-base) + var(--font-mono-offset));
}

/* ── Utility classes ────────────────────────────────────────────────────────── */
.text-large     { font-size: var(--font-large); }
.text-base      { font-size: var(--font-base); }
.text-small     { font-size: var(--font-small); }
.text-tiny      { font-size: var(--font-tiny); }
.text-primary   { color: var(--color-text-primary); }
.text-secondary { color: var(--color-text-secondary); }
.text-disabled  { color: var(--color-text-disabled); }
.text-accent    { color: var(--color-accent); }
.text-success   { color: var(--color-success); }
.text-warning   { color: var(--color-warning); }
.text-danger    { color: var(--color-danger); }
.text-info      { color: var(--color-info); }
.font-display   { font-family: var(--font-family-display); }
.font-body      { font-family: var(--font-family-body); }
.font-mono      { font-family: var(--font-family-mono); }

.eyebrow {
  font-family:    var(--font-family-mono);
  font-size:      var(--font-tiny);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color:          var(--color-accent);
  opacity:        0.8;
  display:        block;
  margin-bottom:  var(--space-2);
}

.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── Scrollbar ──────────────────────────────────────────────────────────────── */
::-webkit-scrollbar        { width: 6px; height: 6px; }
::-webkit-scrollbar-track  { background: var(--color-scrollbar-track); }
::-webkit-scrollbar-thumb  { background: var(--color-scrollbar-thumb); }

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.btn-primary,
.btn-ghost,
.btn-primary-sm,
.btn-ghost-sm {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  font-family:     var(--font-family-body);
  font-weight:     var(--font-weight-heading);
  letter-spacing:  0.1em;
  text-transform:  uppercase;
  cursor:          pointer;
  border:          none;
  outline:         none;
  text-decoration: none;
  transition: opacity var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.btn-primary {
  font-size: var(--font-base);
  padding:   var(--space-3) var(--space-8);
  background: var(--color-accent);
  color:      var(--color-text-on-accent);
  clip-path:  polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.btn-primary:hover { opacity: 0.85; }

.btn-ghost {
  font-size:  var(--font-base);
  padding:    var(--space-3) var(--space-8);
  background: transparent;
  color:      var(--color-text-primary);
  border:     1px solid var(--color-border);
  clip-path:  polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.btn-ghost:hover { border-color: var(--color-accent); color: var(--color-accent); }

.btn-primary-sm {
  font-size:  var(--font-small);
  padding:    var(--space-2) var(--space-5);
  background: var(--color-accent);
  color:      var(--color-text-on-accent);
  clip-path:  polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}
.btn-primary-sm:hover:not(:disabled) { opacity: 0.85; }
.btn-primary-sm:disabled             { opacity: 0.35; cursor: not-allowed; }

.btn-ghost-sm {
  font-size:  var(--font-small);
  padding:    var(--space-2) var(--space-5);
  background: transparent;
  color:      var(--color-text-secondary);
  border:     1px solid var(--color-border);
  clip-path:  polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}
.btn-ghost-sm:hover:not(:disabled) { color: var(--color-text-primary); border-color: var(--color-text-primary); }

/* ── Shared primitives ──────────────────────────────────────────────────────── */
.page { min-height: 100vh; background: var(--color-background); color: var(--color-text-primary); }

.card {
  background: var(--color-surface-raised);
  border:     1px solid var(--color-border);
  padding:    var(--space-4) var(--space-5);
}

.notice {
  background:  color-mix(in srgb, var(--color-accent) 5%, transparent);
  border-left: 2px solid var(--color-accent);
  padding:     var(--space-3) var(--space-4);
  font-size:   var(--font-small);
  color:       var(--color-text-secondary);
  line-height: 1.5;
}
.notice--warning { background: color-mix(in srgb, var(--color-warning) 5%, transparent); border-left-color: var(--color-warning); color: var(--color-warning); }
.notice--danger  { background: color-mix(in srgb, var(--color-danger)  5%, transparent); border-left-color: var(--color-danger);  color: var(--color-danger); }
.notice--success { background: color-mix(in srgb, var(--color-success) 5%, transparent); border-left-color: var(--color-success); color: var(--color-success); }

.divider { width: 100%; height: 1px; background: var(--color-divider); border: none; }

/* Forms */
input, textarea, select {
  font-family: var(--font-family-body);
  font-size:   var(--font-base);
  color:       var(--color-text-primary);
  background:  var(--color-foreground);
  border:      1px solid var(--color-border);
  outline:     none;
  transition:  border-color var(--transition-fast);
}
input:focus, textarea:focus, select:focus { border-color: var(--color-accent); }
input::placeholder, textarea::placeholder { color: var(--color-text-disabled); font-style: italic; }
