/* ============================================================
   Oakland Geospy — Styles
   ============================================================ */

:root {
  --bg-0: #0d0f14;
  --bg-1: #161920;
  --bg-2: #1e222b;
  --bg-3: #262b36;
  --border: #2e3340;
  --accent: #f59e0b;    /* Oakland gold */
  --accent-dim: #92610a;
  --accent-glow: rgba(245, 158, 11, 0.18);
  --success: #22c55e;
  --success-dim: rgba(34, 197, 94, 0.15);
  --danger: #ef4444;
  --danger-dim: rgba(239, 68, 68, 0.15);
  --text-0: #f1f3f8;
  --text-1: #9ba3b0;
  --text-2: #5a6170;
  --header-h: 56px;
}

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

html, body {
  height: 100%;
  overflow: hidden;
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg-0);
  color: var(--text-0);
  display: flex;
  flex-direction: column;
}

/* ---- Loading ---- */
#loading-screen {
  position: fixed; inset: 0;
  background: var(--bg-0);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  transition: opacity 0.5s ease;
}
#loading-screen.fade-out { opacity: 0; pointer-events: none; }
#loading-screen.hidden { display: none; }

.loading-content { text-align: center; }

.loading-logo {
  font-size: 2.8rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1;
  margin-bottom: 0.1rem;
}
.logo-oak { color: var(--accent); }
.logo-land { color: var(--text-0); }

.loading-tagline {
  font-size: 0.7rem;
  letter-spacing: 0.35em;
  color: var(--text-1);
  margin-bottom: 2rem;
}

#loading-status {
  font-size: 0.85rem;
  color: var(--text-1);
  margin-bottom: 1.25rem;
}

.spinner {
  width: 32px; height: 32px;
  border: 2.5px solid var(--bg-3);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  margin: 0 auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ---- Header ---- */
header {
  height: var(--header-h);
  background: var(--bg-1);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
  padding: 0 1rem;
  gap: 1rem;
  flex-shrink: 0;
  z-index: 10;
}

.header-left h1 {
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--text-0);
}
.header-left h1 span { color: var(--accent); }

.header-center {
  flex: 1;
  display: flex; justify-content: center;
}

.tries-container {
  display: flex; align-items: center; gap: 0.6rem;
}
.tries-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-2);
}
.tries-dots { display: flex; gap: 5px; align-items: center; }

.try-dot {
  width: 11px; height: 11px;
  border-radius: 50%;
  transition: all 0.25s ease;
}
.try-dot.active { background: var(--accent); box-shadow: 0 0 6px var(--accent-glow); }
.try-dot.used   { background: transparent; border: 1.5px solid var(--border); }
.try-dot.wrong  { background: var(--danger); opacity: 0.7; }

.header-right { display: flex; gap: 0.5rem; }

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.38rem 0.85rem;
  border: none; border-radius: 6px;
  font-size: 0.8rem; font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, opacity 0.15s, transform 0.1s;
  white-space: nowrap;
  line-height: 1;
}
.btn:active:not(:disabled) { transform: scale(0.97); }
.btn:disabled { opacity: 0.35; cursor: not-allowed; }

.btn-primary {
  background: var(--accent);
  color: #000;
}
.btn-primary:not(:disabled):hover { background: #fbbf24; }

.btn-secondary {
  background: var(--bg-3);
  color: var(--text-0);
  border: 1px solid var(--border);
}
.btn-secondary:hover { background: #2e3444; }

.btn-outline {
  background: transparent;
  color: var(--text-1);
  border: 1px solid var(--border);
}
.btn-outline:hover { color: var(--text-0); border-color: var(--text-2); }

/* ---- Main Layout ---- */
main {
  flex: 1;
  display: flex;
  overflow: hidden;
  min-height: 0;
}

/* ---- Viewer ---- */
#viewer-container {
  flex: 6;
  position: relative;
  background: #000;
  min-width: 0;
}

#viewer {
  width: 100%; height: 100%;
}

/* Override mapillary default cursor for a cleaner look */
#viewer .mapillary-js-dom { cursor: grab; }
#viewer .mapillary-js-dom:active { cursor: grabbing; }

#viewer-error {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-1);
}
#viewer-error .error-content {
  display: flex; flex-direction: column; align-items: center; gap: 0.75rem;
  color: var(--text-1);
}
#viewer-error p { font-size: 0.9rem; }

/* ---- Map Panel ---- */
#map-panel {
  flex: 4;
  display: flex;
  flex-direction: column;
  border-left: 1px solid var(--border);
  min-width: 280px;
}

#map {
  flex: 1;
  position: relative;
  min-height: 0;
}

/* Current guess pin */
.guess-pin {
  width: 22px; height: 22px;
  background: var(--accent);
  border: 3px solid #fff;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  box-shadow: 0 2px 8px rgba(0,0,0,0.5);
  transition: transform 0.15s;
}

/* Past wrong-guess pins — stay on map, show popup on hover */
.wrong-pin {
  width: 14px; height: 14px;
  background: var(--danger);
  border: 2px solid rgba(255,255,255,0.75);
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0,0,0,0.45);
  cursor: pointer;
  opacity: 0.85;
  transition: opacity 0.15s, transform 0.15s;
}
.wrong-pin:hover { opacity: 1; transform: scale(1.2); }

/* Hover popup on wrong-guess pins */
.guess-popup .mapboxgl-popup-content {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.5rem 0.7rem;
  box-shadow: 0 6px 18px rgba(0,0,0,0.5);
  min-width: 110px;
}
.guess-popup .mapboxgl-popup-tip { border-top-color: var(--border) !important; }
.gp-try  { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-2); margin-bottom: 2px; }
.gp-dist { font-size: 0.9rem; font-weight: 700; color: var(--danger); line-height: 1.2; }
.gp-dir  { font-size: 0.75rem; color: var(--text-1); margin-top: 2px; }

/* ---- Feedback bar ---- */
#guess-feedback {
  padding: 0.55rem 0.9rem;
  background: var(--bg-2);
  border-top: 1px solid var(--border);
  font-size: 0.82rem;
  display: flex; align-items: center; gap: 0.45rem;
  min-height: 36px;
}
#guess-feedback.hidden { display: none; }
#guess-feedback.fb-success {
  background: var(--success-dim);
  border-color: rgba(34, 197, 94, 0.3);
  color: var(--success);
}
#guess-feedback.fb-error {
  background: var(--danger-dim);
  border-color: rgba(239, 68, 68, 0.3);
  color: #ff7070;
}
#feedback-icon { font-size: 1rem; flex-shrink: 0; }

/* ---- Map Controls ---- */
#map-controls {
  padding: 0.65rem 0.9rem;
  background: var(--bg-1);
  border-top: 1px solid var(--border);
  display: flex; align-items: center; gap: 0.75rem;
  flex-shrink: 0;
}
#map-hint {
  flex: 1;
  font-size: 0.75rem;
  color: var(--text-2);
  display: flex; align-items: center; gap: 0.3rem;
}
#map-controls .btn { flex-shrink: 0; padding: 0.45rem 1.1rem; }

/* ---- Modals ---- */
.modal {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 800;
}
.modal.hidden { display: none; }

.modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.75);
  backdrop-filter: blur(6px);
}

.modal-content {
  position: relative; /* above backdrop */
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1.5rem;
  width: min(460px, calc(100vw - 2rem));
  max-height: calc(100vh - 3rem);
  overflow-y: auto;
  box-shadow: 0 24px 60px rgba(0,0,0,0.6);
  animation: pop-in 0.2s ease;
}
.modal-wide { width: min(580px, calc(100vw - 2rem)); }

@keyframes pop-in {
  from { transform: scale(0.94); opacity: 0; }
  to   { transform: scale(1);    opacity: 1; }
}

.modal-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 1.25rem;
}
.modal-header h2 { font-size: 1rem; font-weight: 700; }
.modal-close {
  background: none; border: none;
  color: var(--text-1); font-size: 1.4rem; line-height: 1;
  cursor: pointer; transition: color 0.15s;
}
.modal-close:hover { color: var(--text-0); }

/* ---- Result Modal ---- */
#result-header { text-align: center; margin-bottom: 1.1rem; }

#result-icon-wrap {
  width: 52px; height: 52px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  margin: 0 auto 0.65rem;
}
#result-icon-wrap.win {
  background: var(--success-dim);
  border: 1px solid rgba(34, 197, 94, 0.4);
}
#result-icon-wrap.loss {
  background: var(--danger-dim);
  border: 1px solid rgba(239, 68, 68, 0.3);
}

#result-title {
  font-size: 1.3rem; font-weight: 800;
  margin-bottom: 0.3rem;
}
#result-title.win  { color: var(--success); }
#result-title.loss { color: var(--danger); }

#result-subtitle { font-size: 0.85rem; color: var(--text-1); }

#result-map {
  height: 200px;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 1rem;
  border: 1px solid var(--border);
}

#result-stats-row {
  display: flex; gap: 0.6rem;
  margin-bottom: 1.25rem;
}
.result-stat {
  flex: 1;
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.65rem 0.75rem;
  text-align: center;
}
.result-stat .stat-label {
  display: block;
  font-size: 0.65rem;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 0.2rem;
}
.result-stat .stat-value {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-0);
}

#next-round-btn { width: 100%; padding: 0.6rem; font-size: 0.9rem; }

/* ---- Stats Modal ---- */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.65rem;
  margin-bottom: 1.5rem;
}
.stat-card {
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.9rem;
  text-align: center;
}
.stat-card .stat-number {
  display: block;
  font-size: 2rem; font-weight: 800;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 0.25rem;
}
.stat-card .stat-label {
  font-size: 0.65rem;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.section-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-2);
  margin-bottom: 0.65rem;
}

/* Tries distribution bars */
#tries-distribution { margin-bottom: 1.5rem; }
#tries-bars { display: flex; flex-direction: column; gap: 4px; }
.tries-bar-row {
  display: flex; align-items: center; gap: 0.6rem;
  font-size: 0.75rem;
}
.tries-bar-label { width: 14px; text-align: right; color: var(--text-1); flex-shrink: 0; }
.tries-bar-track {
  flex: 1; height: 14px;
  background: var(--bg-3);
  border-radius: 4px;
  overflow: hidden;
}
.tries-bar-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 4px;
  transition: width 0.6s ease;
  min-width: 0;
}
.tries-bar-count { width: 24px; text-align: left; color: var(--text-1); font-size: 0.7rem; }

/* Games list */
#recent-games { margin-top: 0; }
.game-row {
  display: flex; align-items: center; gap: 0.65rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.82rem;
}
.game-row:last-child { border-bottom: none; }

.game-dot {
  width: 8px; height: 8px;
  border-radius: 50%; flex-shrink: 0;
}
.game-dot.win  { background: var(--success); }
.game-dot.loss { background: var(--danger); }
.game-dot.skip { background: var(--text-2); }

.game-date   { color: var(--text-2); font-size: 0.72rem; min-width: 64px; }
.game-label  { flex: 1; color: var(--text-0); }
.game-meta   { color: var(--text-2); font-size: 0.72rem; }

.no-games {
  text-align: center;
  padding: 2rem 0;
  color: var(--text-2);
  font-size: 0.85rem;
}

/* ---- Utilities ---- */
.hidden { display: none !important; }

/* ---- Scrollbar ---- */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* ---- Responsive ---- */
@media (max-width: 680px) {
  /* Shrink header to reclaim vertical space */
  header { height: 44px; padding: 0 0.75rem; }
  :root { --header-h: 44px; }
  .header-left h1 { font-size: 0.8rem; }
  .tries-dots .try-dot { width: 9px; height: 9px; }
  .btn { padding: 0.32rem 0.7rem; font-size: 0.75rem; }

  /* Stack viewer above map */
  main { flex-direction: column; overflow: hidden; }

  /* Use flex ratios so they always add up to exactly the remaining height */
  #viewer-container { flex: 4; min-height: 0; }
  #map-panel {
    flex: 6;
    min-height: 0;
    border-left: none;
    border-top: 1px solid var(--border);
  }

  /* Keep controls bar pinned and never clipped */
  #map-controls { flex-shrink: 0; }
  #guess-feedback { flex-shrink: 0; }
}
