/* ═══════════════════════════════════════════════════════════════
   GBP Manager — Custom Styles
   Brand: #3075C2 (primary), #141414 (dark), #EDF1F7 (surface), #F9F9F9 (bg)
   Font: Montserrat (Google Fonts)
═══════════════════════════════════════════════════════════════ */

/* ── Sidebar navigation links ─────────────────────────────── */
.nav-link {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.6rem 1rem;
  border-radius: 0.75rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #6b7280;
  text-decoration: none;
  transition: background-color 0.15s, color 0.15s;
  cursor: pointer;
  background: none;
  border: none;
  width: 100%;
}
.nav-link:hover:not(.active) {
  background-color: #EDF1F7;
  color: #141414;
}
.nav-link.active {
  background-color: #3075C2;
  color: #ffffff;
}

/* ── Buttons ────────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background-color: #3075C2;
  color: #ffffff;
  font-size: 0.8125rem;
  font-weight: 700;
  padding: 0.5rem 1rem;
  border-radius: 0.75rem;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background-color 0.15s, box-shadow 0.15s;
  white-space: nowrap;
}
.btn-primary:hover {
  background-color: #235FA0;
}
.btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background-color: #ffffff;
  color: #374151;
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(0,0,0,0.08);
  cursor: pointer;
  text-decoration: none;
  transition: background-color 0.15s;
  white-space: nowrap;
}
.btn-secondary:hover {
  background-color: #EDF1F7;
}

/* ── Stat cards ─────────────────────────────────────────────── */
.stat-card {
  background-color: #ffffff;
  border-radius: 1rem;
  border: 1px solid rgba(0,0,0,0.05);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  padding: 1.25rem 1.5rem;
}

/* ── Slide-over transition ──────────────────────────────────── */
#locationDetailPanel {
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
#locationDetailPanel.open {
  transform: translateX(0);
}

/* ── Scale-in animation for modals ─────────────────────────── */
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.95); }
  to   { opacity: 1; transform: scale(1); }
}
.animate-scale-in {
  animation: scaleIn 0.18s ease-out forwards;
}

/* ── Scrollbar (WebKit) ─────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #D1D5DB; border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: #9CA3AF; }

/* ── Health score badge colours ─────────────────────────────── */
.badge-healthy  { background-color: #D1FAE5; color: #065F46; }
.badge-average  { background-color: #FEF3C7; color: #92400E; }
.badge-critical { background-color: #FEE2E2; color: #991B1B; }

/* ── Detail page tabs ───────────────────────────────────────── */
/* Visibility is driven by data-tab-active attribute, not Tailwind classes */
.tab-panel                      { display: none !important; }
.tab-panel[data-tab-active]     { display: block !important; }

.tab-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.75rem 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #6b7280;
  border: none;
  border-bottom: 2px solid transparent;
  background: none;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.tab-btn:hover {
  color: #141414;
}
.tab-btn.text-primary {
  color: #3075C2;
  border-bottom-color: #3075C2;
}

/* ── Focus ring using brand blue ────────────────────────────── */
input:focus, textarea:focus, select:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(48, 117, 194, 0.15);
}
