
html, body {
  height: 100%;
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

#app {
  display: grid;
  grid-template-columns: 1fr 380px;
  grid-template-rows: 56px auto;
  grid-template-areas:
    "header header"
    "map sidebar";
  height: 100%;
}

header {
  grid-area: header;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 16px;
  border-bottom: 1px solid #ddd;
}

header h1 {
  font-size: 18px;
  margin: 0;
}

#progress {
  font-size: 12px;
  color: #555;
}

#map { grid-area: map; height: calc(100% - 0px); }

aside {
  grid-area: sidebar;
  border-left: 1px solid #ddd;
  padding: 10px;
  overflow: auto;
}

.controls {
  position: sticky;
  top: 0;
  background: #fff;
  padding-bottom: 8px;
  border-bottom: 1px solid #eee;
  z-index: 2;
}

.search-row input {
  width: 100%;
  padding: 8px;
  border: 1px solid #ccc;
  border-radius: 6px;
}

.filters {
  display: flex;
  gap: 12px;
  margin: 8px 0 8px 0;
  font-size: 14px;
}

ul#camera-list {
  list-style: none;
  padding: 0;
  margin: 10px 0 100px 0;
}

.camera-item {
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 10px;
  margin-bottom: 8px;
  display: grid;
  grid-template-columns: 48px 1fr auto;
  grid-template-areas:
    "cid cdesc ctag"
    "cid caddr ctag";
  gap: 4px 8px;
}

.camera-item .cid { grid-area: cid; font-weight: 600; color: #555; }
.camera-item .cdesc { grid-area: cdesc; font-size: 14px; }
.camera-item .caddr { grid-area: caddr; font-size: 12px; color: #666; }
.camera-item .ctag { grid-area: ctag; text-transform: capitalize; padding: 2px 6px; border-radius: 10px; font-size: 12px; align-self: start; }

.ctag.school_zone { background: #f0f7ff; border: 1px solid #cfe3ff; }
.ctag.intersection { background: #f9f9f9; border: 1px solid #e6e6e6; }

.popup { font-size: 14px; }
.popup .pid { font-weight: 700; margin-bottom: 4px; }
.popup .paddr { color: #666; font-size: 12px; margin-top: 4px; }
.popup .ptag { margin-top: 6px; display: inline-block; padding: 2px 6px; border-radius: 10px; border: 1px solid #ddd; text-transform: capitalize; }

/* Leaflet CSS overrides */
.leaflet-container { background: #fafafa; }

/* Responsive */
@media (max-width: 1000px){
  #app {
    grid-template-columns: 1fr;
    grid-template-rows: 56px 50vh auto;
    grid-template-areas:
      "header"
      "map"
      "sidebar";
  }
  aside { border-left: none; border-top: 1px solid #ddd; }
}
