:root{
  --bg: #f6f7fb;
  --card: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --border: #e5e7eb;

  --primary: #2563eb;
  --good: #16a34a;
  --warn: #f59e0b;
  --bad:  #dc2626;

  --grid: rgba(17,24,39,0.08);
}

body.dark{
  --bg: #0b0f17;
  --card: #0f172a;
  --text: #e5e7eb;
  --muted: #a1a1aa;
  --border: #243044;

  --primary: #60a5fa;
  --good: #4ade80;
  --warn: #fbbf24;
  --bad:  #f87171;

  --grid: rgba(229,231,235,0.10);
}

html, body { height: 100%; }
body{
  background: var(--bg);
  color: var(--text);
}

.muted{ color: var(--muted); }
.mono{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }
.pill{ font-size: .85rem; }

.card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

.btn-primary{
  background: var(--primary);
  border-color: var(--primary);
}
.btn-outline-secondary{
  border-color: var(--border);
  color: var(--text);
}
.btn-outline-secondary:hover,
.btn-outline-secondary:focus{
  background: color-mix(in srgb, var(--card) 75%, var(--text));
  color: var(--text);
}

.form-control{
  background: color-mix(in srgb, var(--card) 92%, #0000);
  color: var(--text);
  border-color: var(--border);
}
.form-select{
  background-color: color-mix(in srgb, var(--card) 92%, #0000);
  color: var(--text);
  border-color: var(--border);
}
.form-control:focus{
  box-shadow: 0 0 0 0.25rem rgba(96,165,250,0.25);
  border-color: color-mix(in srgb, var(--primary) 65%, var(--border));
}

.alert-secondary{
  background: color-mix(in srgb, var(--card) 92%, #000);
  color: var(--muted);
  border-color: var(--border);
}

.taken{
  border-left: 6px solid var(--good);
}
.missed{
  border-left: 6px solid var(--bad);
}

.navbar{
  background: var(--card) !important;
  border-color: var(--border) !important;
}
.navbar .navbar-brand{
  color: var(--text);
}
.navbar .navbar-brand:hover{
  color: var(--text);
}
.navbar .btn{
  white-space: nowrap;
}

.modal-content{
  background: var(--card);
  color: var(--text);
  border-color: var(--border);
}
.modal-header,
.modal-footer{
  border-color: var(--border);
}

/* Small polish */
h5{ letter-spacing: .2px; }
canvas{ max-width: 100%; }

@media (max-width: 768px){
  .navbar .container{
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  .navbar .btn{
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
  }
  .navbar-brand{
    margin-right: auto;
  }
  .container{
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }
  .card{
    border-radius: 12px;
  }
}
