html,
body,
#root {
  height: 100%;
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.app-shell {
  display: flex;
  height: 100%;
}

.sidebar {
  width: 360px;
  max-width: 40%;
  overflow-y: auto;
  border-right: 1px solid #d0d7de;
  background: #f7f7f7;
  padding: 16px;
  box-sizing: border-box;
}

.sidebar h1 {
  font-size: 1.25rem;
  margin: 0 0 8px 0;
}

.sidebar p {
  margin: 0 0 12px 0;
}

.status-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.75rem;
  margin-left: 6px;
  background: #d0d7de;
}

.status-pill.ok {
  background: #d1f2d5;
  color: #185420;
}

.status-pill.not-found,
.status-pill.rate-limited {
  background: #fce2d6;
  color: #7f1d1d;
}

.facility-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.facility-card {
  background: #fff;
  border-radius: 8px;
  padding: 12px;
  margin-bottom: 12px;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.08);
}

.facility-card h2 {
  margin: 0 0 6px 0;
  font-size: 1rem;
}

.facility-card p {
  margin: 0 0 6px 0;
  font-size: 0.875rem;
}

.facility-card ul {
  margin: 0;
  padding-left: 16px;
}

.map-container {
  flex: 1;
  position: relative;
}

#map {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

.leaflet-popup-content {
  max-height: 260px;
  overflow-y: auto;
}

.leaflet-popup-content-wrapper {
  max-width: 320px;
}

.popup-history {
  margin-top: 8px;
}

.popup-history > summary {
  cursor: pointer;
  font-weight: 600;
}

.popup-history ol {
  margin: 8px 0 0 16px;
  padding: 0;
}

.popup-history li {
  margin-bottom: 6px;
}

.search-section {
  margin: 12px 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.search-label {
  font-size: 0.875rem;
  font-weight: 600;
}

.search-input {
  padding: 8px;
  border-radius: 6px;
  border: 1px solid #cbd5e1;
  font-size: 0.9rem;
  background: #fff;
}

.search-results {
  margin-top: 12px;
}

.search-results ul {
  list-style: none;
  padding: 0;
  margin: 8px 0 0 0;
}

.search-results li {
  background: #fff;
  border-radius: 8px;
  padding: 10px;
  margin-bottom: 8px;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.08);
}

.search-results button {
  margin-top: 6px;
  padding: 6px 10px;
  border: none;
  border-radius: 4px;
  background: #2563eb;
  color: #fff;
  font-size: 0.85rem;
  cursor: pointer;
}

.search-results button:hover {
  background: #1d4ed8;
}

.search-note {
  margin-top: 6px;
  font-size: 0.8rem;
  color: #7f1d1d;
}
