/* Тёмная тема в стиле реестра ОС МОЛ/НМОЛ (палитра base.html того проекта) */
:root {
  --bg: #06080c; --card: #161e2c; --line: #2a3a52; --ink: #e6edf3;
  --muted: #8b98a9; --accent: #4a9eff; --field: #0d1117;
  --grey: #8b98a9; --red: #f85149; --orange: #d29922; --blue: #4a9eff;
  --green: #3fb950; --purple: #d65d8d;
}
* { box-sizing: border-box; }
body {
  margin: 0; font: 14px/1.45 -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--bg); color: var(--ink);
}
a { color: var(--accent); }

.topbar {
  background: var(--card); border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 1000;
}
.topbar-inner {
  display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
  max-width: 1400px; margin: 0 auto; padding: 10px 16px;
}
.brand { color: var(--ink); font-weight: 700; text-decoration: none; font-size: 16px; }
.topbar nav { display: flex; gap: 6px; flex: 1; flex-wrap: wrap; }
.topbar nav a {
  color: var(--muted); text-decoration: none; font-size: 13.5px;
  padding: 6px 14px; border-radius: 8px; border: 1px solid transparent;
}
.topbar nav a:hover { color: var(--ink); background: var(--field); }
.topbar nav a.active {
  color: var(--ink); background: var(--field);
  border-color: var(--line); font-weight: 600;
}
.userbox { font-size: 13px; color: var(--muted); display: flex; gap: 10px; }
.userbox a { color: var(--ink); }

.content { max-width: 1400px; margin: 22px auto; padding: 0 16px; }
h1 { font-size: 19px; margin: 0 0 14px; }
.muted { color: var(--muted); font-size: 13px; }
.error { color: var(--red); }

.card, .metric-card, .filter-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  padding: 16px 18px; margin-bottom: 14px; overflow-x: auto;
}
.card h3, .filter-card h3 {
  margin: 0 0 10px; font-size: 13px; color: var(--muted);
  text-transform: uppercase; letter-spacing: .5px;
}

.metric-row { display: flex; gap: 12px; flex-wrap: wrap; }
.metric-row .metric-card { flex: 1; min-width: 180px; }
.metric-big { font-size: 30px; font-weight: 700; }

.map-layout { display: flex; gap: 14px; align-items: flex-start; }
.map-side { width: 330px; flex-shrink: 0; }
#map {
  flex: 1; height: calc(100vh - 110px); min-height: 420px;
  border: 1px solid var(--line); border-radius: 10px; background: var(--field);
}
@media (max-width: 800px) {
  .map-layout { flex-direction: column; }
  .map-side { width: 100%; }
  #map { width: 100%; height: 60vh; }
}

.filter-card label { display: block; margin-bottom: 8px; font-size: 13px; }
.legend { margin-top: 10px; font-size: 12px; color: var(--muted); }
.legend .dot {
  display: inline-block; width: 11px; height: 11px; border-radius: 50%;
  margin-right: 6px; vertical-align: -1px;
}
.point-list { list-style: none; padding-left: 4px; margin: 6px 0; font-size: 13px; }
.point-list li { padding: 2px 0; }
.qr-link { font-size: 12px; margin-left: 8px; }
details summary { cursor: pointer; padding: 4px 0; }

.filters-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.filters-row input[name=q] { flex: 1; min-width: 220px; }

/* Шапка страницы: заголовок слева, компактные кнопки действий справа */
.page-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin-bottom: 14px;
}
.page-head h1 { margin: 0; }
.head-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.btn-icon {
  display: inline-flex; align-items: center; gap: 7px;
  color: var(--ink); background: var(--field); border: 1px solid var(--line);
  border-radius: 8px; padding: 6px 12px; font-size: 13px; font-weight: 600;
  text-decoration: none; cursor: pointer;
}
.btn-icon:hover { border-color: var(--accent); }
.xl-badge, .pdf-badge {
  display: inline-block; font-size: 10.5px; font-weight: 700;
  padding: 1px 5px; border-radius: 4px; letter-spacing: .3px;
}
.xl-badge { background: rgba(63,185,80,.25); color: var(--green); }
.pdf-badge { background: rgba(248,81,73,.25); color: var(--red); }

/* Модальное окно (загрузка Excel) */
dialog {
  background: var(--card); color: var(--ink); border: 1px solid var(--line);
  border-radius: 10px; padding: 20px 22px; max-width: 460px;
}
dialog::backdrop { background: rgba(0, 0, 0, .65); }
dialog h3 {
  margin: 0 0 10px; font-size: 13px; color: var(--muted);
  text-transform: uppercase; letter-spacing: .5px;
}
.dialog-actions { display: flex; gap: 8px; margin-top: 14px; }
.btn-secondary {
  background: var(--field); color: var(--ink); border: 1px solid var(--line);
}

input, select, textarea {
  background: var(--field); color: var(--ink); border: 1px solid var(--line);
  border-radius: 8px; padding: 7px 9px; font: inherit;
}
input::placeholder, textarea::placeholder { color: #5a6678; }
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--accent);
}
input[type=file] { padding: 5px; }
textarea { width: 100%; resize: vertical; }

.data-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.data-table th, .data-table td {
  text-align: left; padding: 6px 10px; border-bottom: 1px solid var(--line);
  vertical-align: top; overflow-wrap: break-word;
}
.data-table th {
  color: var(--muted); font-weight: 600; white-space: nowrap; font-size: 12.5px;
}
.data-table tr:hover td { background: var(--field); }
.stale-row td { background: rgba(210, 153, 34, .08); }

.kv-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.kv-table td { padding: 4px 6px; border-bottom: 1px solid var(--line); vertical-align: top; }
.kv-table td:first-child { color: var(--muted); width: 40%; }

/* Статусные пилюли как в реестре ОС: полупрозрачный фон + цветной текст */
.pill {
  display: inline-block; padding: 1px 10px; border-radius: 999px;
  font-size: 12px; white-space: nowrap;
}
.pill.big { font-size: 13.5px; padding: 3px 14px; }
.pill.st-geo    { background: rgba(139,152,169,.2); color: var(--grey); }
.pill.st-resp   { background: rgba(248,81,73,.2);   color: var(--red); }
.pill.st-clean  { background: rgba(210,153,34,.2);  color: var(--orange); }
.pill.st-opis   { background: rgba(74,158,255,.2);  color: var(--blue); }
.pill.st-check  { background: rgba(214,93,141,.2);  color: var(--purple); }
.pill.st-closed { background: rgba(63,185,80,.2);   color: var(--green); }

.point-layout { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; }
@media (max-width: 800px) { .point-layout { grid-template-columns: 1fr; } }

.inline-form { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.inline-form input[name=responsible],
.inline-form input[name=lat], .inline-form input[name=lon] {
  flex: 1; min-width: 180px;
}

.help-steps { padding-left: 20px; line-height: 1.7; font-size: 14px; }
.help-steps li { margin-bottom: 8px; }

.timeline { list-style: none; padding-left: 0; font-size: 13px; margin: 0; }
.timeline li { border-left: 3px solid var(--line); padding: 4px 0 4px 10px;
               margin-bottom: 6px; }

button {
  background: var(--accent); color: #06080c; border: 0; border-radius: 8px;
  padding: 8px 16px; font-size: 14px; font-weight: 600; cursor: pointer;
}
button:disabled { background: var(--line); color: var(--muted); cursor: not-allowed; }
button:hover:not(:disabled) { filter: brightness(1.15); }
.btn-small { padding: 3px 10px; font-size: 12px; }
.btn-danger { background: rgba(248,81,73,.2); color: var(--red); }
.btn-link {
  display: inline-block; color: var(--accent); border: 1px solid var(--line);
  border-radius: 8px; padding: 6px 14px; text-decoration: none; font-size: 13.5px;
  background: var(--field);
}
.btn-link:hover { border-color: var(--accent); }
.btn-small-link { font-size: 12.5px; }

.login-body {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh; background: var(--bg); margin: 0;
  font: 14px/1.45 -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--ink);
}
.login-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  padding: 28px 32px; width: 340px;
}
.login-card h1 { font-size: 19px; margin: 0 0 4px; }
.login-card label { display: block; margin: 14px 0; font-size: 14px; }
.login-card input { width: 100%; margin-top: 4px; }
.login-card button { width: 100%; margin-top: 6px; }

.scan-card {
  max-width: 480px; margin: 0 auto; background: var(--card);
  border: 1px solid var(--line); border-radius: 10px; padding: 18px;
}
.scan-card label { display: block; margin: 14px 0; font-size: 14px; }
.scan-card fieldset { border: 1px solid var(--line); border-radius: 8px; margin: 14px 0; }
.scan-card legend { color: var(--muted); font-size: 13px; padding: 0 6px; }
.scan-card fieldset label { margin: 8px 0; }
.scan-card input[name=resp_actual] { width: 100%; }
.geo-block { margin: 14px 0; }
.geo-block span { display: block; margin-top: 8px; }
#submit-btn { width: 100%; margin-top: 10px; padding: 12px; font-size: 16px; }

.opis-form label { display: block; margin: 10px 0; font-size: 13.5px; }
.opis-form input { width: 100%; margin-top: 3px; }
.opis-form .form-row { display: flex; gap: 12px; flex-wrap: wrap; }
.opis-form .form-row label { flex: 1; min-width: 220px; }
.edit-label { display: block; margin: 10px 0; font-size: 13.5px; }
.edit-label input, .edit-label select { width: 100%; margin-top: 3px; }

.qr-img { background: #fff; border-radius: 6px; padding: 6px; }

/* Leaflet-попапы под тёмную тему */
.leaflet-popup-content-wrapper, .leaflet-popup-tip {
  background: var(--card); color: var(--ink);
}
.leaflet-popup-content a { color: var(--accent); }
