:root {
  --bg: #f3f6fb;
  --ink: #12223b;
  --line: #d8e0ed;
  --brand: #0c4fb5;
  --orange: #f28c18;
  --ok: #12753b;
}

* { box-sizing: border-box; }
body { margin: 0; font-family: "Segoe UI", Arial, sans-serif; background: var(--bg); color: var(--ink); }

.layout {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(280px, 420px) 1fr;
}

.panel {
  padding: 20px;
  border-right: 1px solid var(--line);
  background: #fff;
  display: grid;
  gap: 12px;
  align-content: start;
}

h1 { margin: 0; font-size: 1.2rem; }

#search-form { display: grid; grid-template-columns: 1fr auto; gap: 8px; }
input, button {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  font: inherit;
}
button {
  background: var(--brand);
  color: #fff;
  border-color: var(--brand);
  font-weight: 700;
  cursor: pointer;
}

#status {
  font-size: 0.9rem;
  font-weight: 700;
}

#status.ok { color: var(--ok); }
#status.warn { color: #b54708; }
#status.err { color: #b42318; }

#meta {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #f9fbff;
  font-size: 0.9rem;
  line-height: 1.45;
}

.map-wrap { min-height: 100vh; }
#map { height: 100%; min-height: 65vh; }

@media (max-width: 920px) {
  .layout {
    grid-template-columns: 1fr;
  }
  .map-wrap {
    min-height: 58vh;
  }
}
