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

/* ── Tokens ──────────────────────────────────────────────── */
:root {
  --bg:          #0c0e09;
  --surface:     #141a0e;
  --card:        #1c2414;
  --border:      #2d3820;
  --muted:       #4a5c35;

  --text:        #d4d9c4;
  --subtle:      #7a8a65;
  --faint:       #3d4d2a;

  --amber:       #e8930f;
  --amber-dim:   rgba(232,147,15,0.12);
  --amber-glow:  rgba(232,147,15,0.06);

  --added:       #6db33f;
  --removed:     #cc3520;
  --modified:    #d4a820;

  --font-head:   'Rajdhani', system-ui, sans-serif;
  --font-body:   'Inter', system-ui, sans-serif;
  --font-mono:   'JetBrains Mono', 'Courier New', monospace;

  --radius:      6px;
  --radius-sm:   3px;
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { background: var(--bg); color: var(--text); font-size: 16px; }
body {
  font-family: var(--font-body);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  line-height: 1.6;
}

/* Scanline overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 3px,
    rgba(0,0,0,0.04) 3px, rgba(0,0,0,0.04) 4px
  );
  pointer-events: none;
  z-index: 9999;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { cursor: pointer; font-family: inherit; }

::selection { background: var(--amber-dim); color: var(--text); }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--surface); }
::-webkit-scrollbar-thumb { background: var(--muted); border-radius: 2px; }

/* ── Layout ──────────────────────────────────────────────── */
.container { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }
main { flex: 1; }

/* ── Nav ─────────────────────────────────────────────────── */
nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(12,14,9,0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
}

.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 52px;
  gap: 1.5rem;
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--amber);
  text-transform: uppercase;
  text-decoration: none;
}
.nav-logo .mark { font-size: 0.9rem; opacity: 0.8; }

.nav-links {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.nav-link {
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--subtle);
  padding: 0.3rem 0.75rem;
  border-radius: var(--radius-sm);
  transition: color 0.15s, background 0.15s;
}
.nav-link:hover, .nav-link.active { color: var(--text); background: var(--card); }

.nav-auth { display: flex; align-items: center; gap: 0.75rem; }

.nav-user {
  font-size: 0.8rem;
  color: var(--subtle);
  display: none;
}
@media (min-width: 600px) { .nav-user { display: block; } }

.btn-discord {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 0.35rem 0.85rem;
  border-radius: var(--radius-sm);
  background: #5865F2;
  color: #fff;
  border: none;
  transition: opacity 0.15s;
}
.btn-discord:hover { opacity: 0.85; }

.btn-signout {
  font-size: 0.75rem;
  color: var(--subtle);
  background: none;
  border: 1px solid var(--border);
  padding: 0.3rem 0.65rem;
  border-radius: var(--radius-sm);
  transition: color 0.15s, border-color 0.15s;
}
.btn-signout:hover { color: var(--text); border-color: var(--muted); }

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 1.1rem;
  border-radius: var(--radius-sm);
  border: none;
  font-family: var(--font-head);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: opacity 0.15s;
  cursor: pointer;
}
.btn:hover { opacity: 0.85; }
.btn-primary { background: var(--amber); color: #000; }
.btn-ghost {
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border);
}

/* ── Cards ───────────────────────────────────────────────── */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.card:hover {
  border-color: rgba(232,147,15,0.25);
  box-shadow: 0 0 24px var(--amber-glow);
}

/* ── Section headers ─────────────────────────────────────── */
.section-label {
  font-family: var(--font-head);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--subtle);
  margin-bottom: 0.85rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}

/* ── Badges ──────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.65rem;
  font-family: var(--font-head);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.15rem 0.45rem;
  border-radius: var(--radius-sm);
  border: 1px solid;
}

.badge-added    { color: var(--added);    background: rgba(109,179,63,0.1);  border-color: rgba(109,179,63,0.25); }
.badge-removed  { color: var(--removed);  background: rgba(204,53,32,0.1);   border-color: rgba(204,53,32,0.25); }
.badge-modified { color: var(--modified); background: rgba(212,168,32,0.1);  border-color: rgba(212,168,32,0.25); }

/* ── Delta pill ──────────────────────────────────────────── */
.delta {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 700;
  padding: 0.1rem 0.4rem;
  border-radius: 99px;
}
.delta-up   { color: var(--added);   background: rgba(109,179,63,0.12); }
.delta-down { color: var(--removed); background: rgba(204,53,32,0.12); }
.delta-flat { color: var(--subtle);  background: var(--surface); }

/* ── Tag chips ───────────────────────────────────────────── */
.tag {
  font-size: 0.65rem;
  font-weight: 500;
  padding: 0.1rem 0.5rem;
  border-radius: 99px;
  border: 1px solid var(--border);
  color: var(--subtle);
  background: var(--surface);
}
.tag-balance   { color: var(--modified); border-color: rgba(212,168,32,0.3); }
.tag-bug       { color: var(--removed);  border-color: rgba(204,53,32,0.3); }
.tag-qol       { color: #6090e8;         border-color: rgba(96,144,232,0.3); }
.tag-content   { color: var(--added);    border-color: rgba(109,179,63,0.3); }
.tag-ui        { color: #a87ed8;         border-color: rgba(168,126,216,0.3); }
.tag-performance { color: #3ab8d8;       border-color: rgba(58,184,216,0.3); }

/* ── Status badges ───────────────────────────────────────── */
.status { font-size: 0.6rem; font-family: var(--font-head); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; padding: 0.1rem 0.4rem; border-radius: var(--radius-sm); border: 1px solid; }
.status-open        { color: var(--added);    border-color: rgba(109,179,63,0.3);  background: rgba(109,179,63,0.08); }
.status-planned     { color: #6090e8;         border-color: rgba(96,144,232,0.3);  background: rgba(96,144,232,0.08); }
.status-in_progress { color: var(--amber);    border-color: rgba(232,147,15,0.3);  background: var(--amber-dim); }
.status-done        { color: var(--subtle);   border-color: var(--border);          background: var(--surface); }
.status-declined    { color: var(--removed);  border-color: rgba(204,53,32,0.3);   background: rgba(204,53,32,0.08); }

/* ── Forms ───────────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: 0.4rem; }
.field label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--subtle);
  letter-spacing: 0.04em;
}
.field input,
.field select,
.field textarea {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 0.875rem;
  padding: 0.5rem 0.75rem;
  outline: none;
  transition: border-color 0.15s;
}
.field input:focus,
.field select:focus,
.field textarea:focus { border-color: var(--amber); }
.field textarea { resize: vertical; min-height: 100px; }

/* ── Footer ──────────────────────────────────────────────── */
footer {
  border-top: 1px solid var(--border);
  padding: 1.5rem 0;
  text-align: center;
  font-size: 0.75rem;
  color: var(--faint);
  letter-spacing: 0.04em;
}

/* ── Utilities ───────────────────────────────────────────── */
.mono { font-family: var(--font-mono); }
.strike { text-decoration: line-through; }
.text-added    { color: var(--added); }
.text-removed  { color: var(--removed); }
.text-modified { color: var(--modified); }
.text-amber    { color: var(--amber); }
.text-subtle   { color: var(--subtle); }
.text-sm       { font-size: 0.875rem; }
.text-xs       { font-size: 0.75rem; }

/* ── Empty state ─────────────────────────────────────────── */
.empty {
  text-align: center;
  padding: 4rem 2rem;
  color: var(--subtle);
  font-size: 0.875rem;
  border: 1px dashed var(--border);
  border-radius: var(--radius);
}

/* ── Loading ─────────────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, var(--card) 25%, var(--surface) 50%, var(--card) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: var(--radius-sm);
}
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
