/* ===== GLOBAL ===== */
* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Segoe UI', Arial, sans-serif;
  background: #f0f2f5;
  color: #333;
  display: flex;
  flex-direction: column;
  height: 100vh;
}

/* ===== HEADER ===== */
header {
  background: #1a3a5c;
  color: #fff;
  padding: 10px 20px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  flex-shrink: 0;
}

header h1 {
  font-size: 1.1rem;
  font-weight: 600;
  flex: 1;
}

#controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

#controls label { font-size: 0.85rem; }

#controls select,
#controls button {
  padding: 5px 10px;
  border-radius: 4px;
  border: none;
  font-size: 0.85rem;
  cursor: pointer;
}

#controls button {
  background: #2ecc71;
  color: #fff;
  font-weight: bold;
}
#controls button:hover { background: #27ae60; }

/* ===== MAP + SIDEBAR ===== */
#map-container {
  display: flex;
  flex: 1;
  overflow: hidden;
}

#map {
  flex: 1;
  height: 100%;
}

#sidebar {
  width: 280px;
  background: #fff;
  padding: 16px;
  overflow-y: auto;
  border-left: 1px solid #ddd;
  flex-shrink: 0;
}

#sidebar h2 {
  font-size: 0.95rem;
  color: #1a3a5c;
  margin-bottom: 10px;
  border-bottom: 2px solid #1a3a5c;
  padding-bottom: 4px;
}

#feature-info p { font-size: 0.82rem; color: #666; }

#feature-info table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  margin-top: 6px;
}
#feature-info td {
  padding: 4px 6px;
  border-bottom: 1px solid #eee;
}
#feature-info td:first-child { font-weight: bold; color: #1a3a5c; }

/* ===== LEGEND ===== */
.legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  margin-bottom: 6px;
}
.legend-color {
  width: 18px;
  height: 18px;
  border-radius: 3px;
  border: 1px solid #aaa;
  flex-shrink: 0;
}
