:root {
  --bg: #0b0d10;
  --panel: #12161b;
  --panel-2: #161b22;
  --text: #e6eaf0;
  --muted: #9aa6b2;
  --primary: #3b82f6;
  --primary-contrast: #ffffff;
  --danger: #ef4444;
  --ring: #93c5fd;
  --border: #243041;
  --shadow: 0 6px 24px rgba(0,0,0,0.24);
  --radius: 12px;
  /* only keep the spacing tokens we actually use */
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
}

@media (prefers-color-scheme: light) {
  :root {
    --bg: #f8fafc;
    --panel: #ffffff;
    --panel-2: #f5f7fb;
    --text: #0f172a;
    --muted: #516075;
    --border: #e5e7eb;
    --shadow: 0 6px 18px rgba(22, 27, 34, 0.08);
  }
}

/* Base */
* { box-sizing: border-box; }
html, body { height: 100%; }
body.app {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 1px, 1px); white-space: nowrap; border: 0;
}

/* Top bar */
.topbar {
  position: fixed; inset: 0 0 auto 0; min-height: 56px; z-index: 1000;
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  padding: 0 var(--space-4);
  background: var(--panel);
  border-bottom: 1px solid var(--border);
}
.topbar__primary,
.topbar__actions,
.topbar__status {
  display: flex;
  align-items: center;
}
.topbar__primary { gap: var(--space-4); min-width: 0; }
.topbar__title { font-size: 1rem; font-weight: 600; margin: 0; }
.topbar__subtitle { color: var(--muted); font-weight: 500; }
.topbar__status {
  gap: .75rem;
  margin-left: auto;
  min-width: 0;
}
.topbar__statusItem {
  display: flex;
  align-items: baseline;
  gap: .45rem;
  padding: .35rem .6rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--panel-2);
}
.topbar__statusLabel {
  color: var(--muted);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.topbar__statusValue {
  font-size: .88rem;
  white-space: nowrap;
}

/* Shell rail + panels */
.controls-shell {
  position: fixed;
  top: 56px;
  left: 72px;
  bottom: 0;
  z-index: 1099;
  width: 360px;
  background: color-mix(in srgb, var(--panel) 96%, transparent);
  box-shadow: var(--shadow);
  transform: translateX(-100%);
  transition: transform .25s ease;
  pointer-events: none;
}
body.controls-open .controls-shell {
  transform: translateX(0);
  pointer-events: auto;
}
.tool-rail {
  position: fixed;
  top: 56px;
  left: 0;
  bottom: 0;
  z-index: 1100;
  width: 72px;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  padding: .85rem .65rem;
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  border-right: 1px solid var(--border);
  backdrop-filter: blur(10px);
}
.tool-rail__button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: .7rem .45rem;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--panel-2);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  font-size: .82rem;
  font-weight: 600;
  line-height: 1.15;
  text-align: center;
}
.tool-rail__button--active,
.tool-rail__button[data-active="true"] {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--primary-contrast);
  box-shadow: 0 10px 24px rgba(59, 130, 246, 0.26);
}

.sidebar {
  position: relative;
  width: 360px;
  height: 100%;
  background: var(--panel);
  display: flex;
  flex-direction: column;
}
.sidebar__header {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  padding: .75rem var(--space-4);
  border-bottom: 1px solid var(--border);
}
.sidebar__headerMain {
  display: flex;
  flex-direction: column;
  gap: .45rem;
  min-width: 0;
}
.sidebar__headerCopy {
  min-width: 0;
}
.sidebar__eyebrow,
.workflow-help-popover .sidebar__eyebrow {
  margin: 0 0 .35rem;
  color: var(--muted);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.sidebar__title { margin: 0; font-size: 1rem; }
.sidebar__badge {
  display: inline-flex;
  width: fit-content;
  padding: .35rem .7rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--text);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
}
.sidebar__headerActions {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}
.sidebar__content {
  flex: 1 1 auto;
  min-height: 0;
  padding: var(--space-4);
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  touch-action: pan-y;
}

.inspector-panel {
  position: fixed;
  z-index: 1100;
  top: 56px;
  right: 0;
  bottom: 0;
  width: 320px;
  display: flex;
  flex-direction: column;
  background: var(--panel);
  border-left: 1px solid var(--border);
  box-shadow: -4px 0 32px rgba(0, 0, 0, 0.4);
  transform: translateX(100%);
  transition: transform .25s ease;
}
.inspector-panel[aria-hidden="false"] { transform: translateX(0); }
.inspector-panel__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: 1px solid var(--border);
}
.inspector-panel__title {
  margin: 0;
  font-size: 1rem;
}
.inspector-panel__content {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding: var(--space-4);
}
.inspector-panel__empty {
  margin-bottom: var(--space-4);
  padding: .85rem 1rem;
  border: 1px dashed var(--border);
  border-radius: 12px;
  color: var(--muted);
  background: var(--panel-2);
}
.inspector-card {
  margin-bottom: var(--space-4);
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--panel-2);
}
.inspector-card__title {
  margin: 0 0 .4rem;
  font-size: .95rem;
}
.inspector-card__body {
  margin: 0;
  color: var(--muted);
  font-size: .9rem;
}

.shell-tab-panel[hidden] { display: none; }
.shell-status-card {
  min-height: 2.75rem;
  padding: .75rem .9rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--panel);
  color: var(--muted);
}

.backdrop {
  position: fixed;
  inset: 56px 0 0 0;
  background: rgba(0,0,0,.35);
  z-index: 1050;
  touch-action: none;
}

@media (min-width: 1024px) {
  body.controls-open .map-container { left: 432px; }
}

/* Map container */
.map-container {
  position: absolute;
  inset: 56px 0 0 72px;
  z-index: 1;
  transition: left .25s ease;
}
.map { width: 100%; height: 100%; transition: opacity .2s ease; }
.map--hidden { opacity: 0; pointer-events: none; }
.map-3d {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: #0b0d10;
}
.map-3d[hidden] { display: none; }
.map-3d canvas { width: 100%; height: 100%; display: block; }
.map-3d__status {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 3;
  padding: .45rem .65rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(18, 22, 27, 0.92);
  color: var(--text);
  font-size: .85rem;
}

/* Sections & form */
.section, .subsection {
  background: var(--panel-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}
.subsection { background: transparent; }
legend { font-weight: 600; margin-bottom: var(--space-3); }

.form-row { display: flex; flex-direction: column; gap: .375rem; margin-bottom: var(--space-3); }
.form-row.align-end { align-items: flex-end; }
.form-row--inline { flex-direction: row; align-items: center; gap: var(--space-3); }

.form-grid { display: grid; gap: var(--space-3); }
.form-grid.two { grid-template-columns: 1fr 1fr; }
.form-grid.three { grid-template-columns: 1fr 1fr 1fr; }

@media (max-width: 1023.98px) {
  .topbar {
    flex-wrap: wrap;
    align-items: stretch;
    padding-top: .5rem;
    padding-bottom: .5rem;
  }
  .topbar__primary,
  .topbar__actions,
  .topbar__status {
    width: 100%;
  }
  .topbar__status {
    order: 3;
    margin-left: 0;
    flex-wrap: wrap;
  }
  .topbar__actions {
    justify-content: flex-end;
  }
  .sidebar__header {
    flex-wrap: wrap;
  }
  .controls-shell {
    top: 176px;
    left: 0;
    width: min(92vw, 360px);
  }
  .tool-rail {
    top: 120px;
    left: 0;
    right: 0;
    bottom: auto;
    width: 100%;
    height: 56px;
    flex-direction: row;
    overflow-x: auto;
    padding: .5rem .75rem;
    border-right: 0;
    border-bottom: 1px solid var(--border);
  }
  .tool-rail__button {
    min-width: 92px;
    min-height: 42px;
  }
  .sidebar {
    width: 100%;
    min-height: 0;
  }
  .inspector-panel {
    top: 176px;
    width: min(92vw, 340px);
    max-width: 100vw;
  }
  .backdrop {
    inset: 176px 0 0 0;
  }
  .map-container {
    inset: 176px 0 0 0;
  }
  body.controls-open .map-container {
    left: 0;
  }
}

@media (max-width: 680px) { .form-grid.two, .form-grid.three { grid-template-columns: 1fr; } }

label { font-size: .925rem; }
input[type="number"], input[type="text"], select, textarea {
  width: 100%; padding: .6rem .7rem; border-radius: 10px; border: 1px solid var(--border);
  background: var(--panel); color: var(--text);
}
textarea { resize: vertical; min-height: 88px; }
input:focus, select:focus, textarea:focus, button:focus { outline: 2px solid var(--ring); outline-offset: 2px; }

.checkbox, .radio { display: inline-flex; align-items: center; gap: .5rem; }
.radio-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .25rem .75rem; }

.listbox select {
  width: 100%; height: 150px; border-radius: 10px; background: var(--panel); color: var(--text);
  border: 1px solid var(--border);
}

/* Buttons */
.btn {
  appearance: none;
  border: 1px solid var(--border);
  background: var(--panel);
  padding: .55rem .85rem;
  border-radius: 10px;
  color: var(--text);
  cursor: pointer;
}
.btn:hover { filter: brightness(1.05); }
.btn-primary { background: var(--primary); border-color: var(--primary); color: var(--primary-contrast); }
.btn-danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.btn-ghost { background: transparent; }
.btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: none;
  background: transparent;
  border-radius: 8px;
  color: var(--muted);
  cursor: pointer;
  flex-shrink: 0;
}
.btn-icon:hover {
  background: var(--panel-2);
  color: var(--text);
}
.btn-icon:focus {
  outline: 2px solid var(--ring);
  outline-offset: 2px;
}

.workflow-help-popover {
  position: absolute;
  top: calc(100% + 4px);
  left: var(--space-4);
  right: var(--space-4);
  z-index: 10;
  padding: var(--space-4);
  background: var(--panel-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.workflow-help-popover__title {
  margin: 0 0 .45rem;
  font-size: .98rem;
}
.workflow-help-popover__body {
  margin: 0;
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.5;
}

.chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  min-height: 2.5rem;
  padding: .4rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--panel);
}
.chip-list:empty::after {
  content: "No velocities added yet";
  color: var(--muted);
  font-size: .82rem;
  align-self: center;
  padding: 0 .25rem;
}
.chip-list__item {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .28rem .55rem .28rem .7rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--panel-2);
  font-size: .85rem;
  white-space: nowrap;
}
.chip-list__remove {
  width: 1.25rem;
  height: 1.25rem;
  padding: 0;
}

#shellPanel-fires .radio-grid {
  grid-template-columns: 1fr;
  gap: .2rem;
}

/* Loading dots */
.loader {
  display: inline-flex; gap: 4px; align-items: center; margin-left: .25rem;
}
.loader span {
  width: 6px; height: 6px; background: currentColor; border-radius: 999px;
  display: inline-block; animation: b 1s infinite ease-in-out;
}
.loader span:nth-child(2){ animation-delay: .15s; }
.loader span:nth-child(3){ animation-delay: .3s; }
@keyframes b {
  0%,80%,100%{ transform: translateY(0);}
  40%{ transform: translateY(-6px);}
}

/* Leaflet tweaks (dark mode friendly) */
.leaflet-control {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
}
.leaflet-bar a, .leaflet-bar a:hover {
  color: var(--text);
  background: var(--panel);
  border-bottom-color: var(--border);
}
.leaflet-control-layers-expanded {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
}

/* Popups */
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
  background: var(--panel);
  color: var(--text);
}

.leaflet-popup-content-wrapper {
  width: auto !important;
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow);
  max-width: min(94vw, 560px);
}

.leaflet-popup-content {
  width: auto !important;
  margin: 0;
  min-width: 0;
  max-width: min(92vw, 520px);
}

.app-popup--marker .leaflet-popup-content {
  width: min(92vw, 320px) !important;
  max-width: min(92vw, 320px) !important;
}

.app-popup--target .leaflet-popup-content {
  width: min(92vw, 392px) !important;
  max-width: min(92vw, 392px) !important;
}

.leaflet-popup-close-button {
  color: var(--muted) !important;
  padding: .55rem .7rem 0 0 !important;
  font-size: 1.25rem !important;
}

.leaflet-popup-close-button:hover {
  color: var(--text) !important;
}

.popup-card {
  font: 13px/1.45 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  width: auto;
  min-width: 0;
  max-width: 100%;
  color: var(--text);
  padding: 1rem;
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: auto;
}

.popup-card--marker {
  width: auto;
  min-width: 0;
  max-width: 100%;
  padding: .95rem 1rem 1rem;
}

.popup-card--marker-wide {
  width: auto;
}

.popup-card--compact {
  width: auto;
}

.popup-h {
  font-weight: 700;
  font-size: 1.05rem;
  margin: 0;
}

.popup-card--marker .popup-h {
  font-size: 1rem;
}

.popup-card--marker .popup-h.small {
  font-size: .95rem;
}

.popup-subtle { color: var(--muted); }
.kv { display: grid; grid-template-columns: 96px minmax(0, 1fr); gap: .28rem .9rem; align-items: start; }
.kv .k { color: var(--muted); }
.kv > div { min-width: 0; }
.hr { height: 1px; background: var(--border); margin: .75rem 0; }

.popup-card--marker .small {
  font-size: .83rem;
  line-height: 1.38;
}

.popup-marker-meta {
  margin-top: .45rem;
}

.popup-marker-ballistics {
  padding: .8rem .85rem;
}

.popup-card > *,
.popup-card .popup-section,
.popup-card .popup-accordion,
.popup-card .popup-actions,
.popup-card .form-row,
.popup-card .spread-grid,
.popup-card .input-row,
.popup-card .kv,
.popup-card .kv > div {
  max-width: 100%;
  min-width: 0;
}

.popup-card .kv > div:last-child {
  overflow-wrap: break-word;
  word-break: normal;
}


.popup-fieldset {
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.popup-input-row-tight {
  gap: .5rem;
}

.input-row,
.popup-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: .55rem;
  align-items: end;
}
.input-row.two,
.popup-grid.two { grid-template-columns: 1fr 1fr; }
.input-row.one,
.popup-grid.one { grid-template-columns: 1fr; }

.input-row .form,
.popup-field {
  display: flex;
  flex-direction: column;
  gap: .32rem;
}

.popup-card label,
.popup-field label,
.input-row .form label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--muted);
}

.input-row input,
.input-row select,
.input-row textarea,
.popup-field input,
.popup-field select,
.popup-field textarea {
  width: 100%;
  padding: .62rem .72rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--panel-2);
  color: var(--text);
  font: inherit;
}

.popup-field textarea {
  min-height: 92px;
  resize: vertical;
}

.popup-stack {
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.popup-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
}

.popup-actions--end { justify-content: flex-end; }
.popup-actions--split {
  justify-content: space-between;
}
.popup-actions--split .btn {
  flex: 1 1 0;
  min-width: 0;
}
.popup-actions .btn { min-width: 108px; }

.popup-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}

.popup-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 2rem;
  padding: .3rem .65rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
  font-size: .82rem;
}

.popup-chip input { width: auto; }

.popup-section {
  padding: .75rem;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255,255,255,0.02);
}

.popup-accordion {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--panel-2);
  overflow: hidden;
}

.popup-accordion + .popup-accordion { margin-top: .6rem; }

.popup-accordion > summary {
  list-style: none;
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .78rem .9rem;
  font-weight: 700;
  background: rgba(255,255,255,0.02);
}

.popup-accordion > summary::-webkit-details-marker { display: none; }
.popup-accordion > summary::after {
  content: '▸';
  color: var(--muted);
  transition: transform .15s ease;
}
.popup-accordion > summary:hover { background: rgba(255,255,255,0.04); }
.popup-accordion[open] > summary { border-bottom: 1px solid var(--border); }
.popup-accordion[open] > summary::after { transform: rotate(90deg); }
.popup-accordion__body { padding: 0 .9rem .9rem; }
.popup-accordion__body > :first-child { margin-top: 0; }
.popup-help { color: var(--muted); font-size: .85rem; }

.mission-item-popup-wrap .leaflet-popup-content-wrapper { border-radius: 18px; }
.mission-item-popup-wrap .leaflet-popup-content {
  width: min(92vw, 392px) !important;
  max-width: min(92vw, 392px) !important;
}
.mission-item-popup-wrap .popup-card {
  width: 100%;
  max-width: 100%;
}

.mission-popup__preview,
.mission-preview {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .8rem;
  align-items: center;
  min-height: 106px;
  padding: .8rem;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--panel);
}

.mission-popup__preview .mission-preview__svg,
.mission-preview__svg {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  min-height: 84px;
}

.mission-popup__preview .mission-preview__svg svg,
.mission-preview__svg svg,
.mission-popup__preview svg {
  max-width: 88px;
  max-height: 88px;
  display: block;
}

.mission-popup__meta,
.mission-preview__meta {
  font-size: .86rem;
  color: var(--muted);
}

.mission-popup__title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .7rem;
}

.mission-popup__status {
  min-height: 2.35rem;
  margin-top: .75rem;
  padding: .65rem .75rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--panel-2);
  color: var(--muted);
  font-size: .86rem;
}

.mission-popup__status[data-tone="ok"] {
  border-color: rgba(59, 130, 246, 0.45);
  color: var(--text);
}

.mission-popup__status[data-tone="error"] {
  border-color: rgba(239, 68, 68, 0.55);
  color: #fca5a5;
}

.mission-popup--readonly { opacity: .9; }

.note-blue { color: var(--primary); }
.small { font-size: .92em; }
.help { color: var(--muted); font-size: .86rem; }
.mission-sidebar-note .help { line-height: 1.45; }

@media (max-width: 540px) {
  .popup-card,
  .popup-card--marker,
  .popup-card--marker-wide,
  .popup-card--compact { min-width: 0; max-width: min(92vw, 360px); }

  .app-popup--marker .leaflet-popup-content {
    width: min(94vw, 300px) !important;
    max-width: min(94vw, 300px) !important;
  }

  .app-popup--target .leaflet-popup-content {
    width: min(94vw, 348px) !important;
    max-width: min(94vw, 348px) !important;
  }
  .input-row,
  .input-row.two,
  .popup-grid,
  .popup-grid.two,
  .mission-popup__preview,
  .mission-preview {
    grid-template-columns: 1fr;
  }
  .mission-item-popup-wrap .leaflet-popup-content {
    width: min(94vw, 340px) !important;
    max-width: min(94vw, 340px) !important;
  }
  .popup-actions .btn {
    min-width: 0;
    flex: 1 1 0;
  }
}

/* ================================
   Guns List (multi-gun UI)
   ================================ */

.guns-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.guns-empty {
  color: var(--muted);
  font-size: 0.9rem;
  padding: var(--space-2) 0;
}

.gun-row {
  background: var(--panel-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-3);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
}

.gun-label {
  font-weight: 600;
  margin-bottom: 0.2rem;
}

.gun-callsign {
  width: 100%;
  padding: .55rem .7rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
}

.gun-coords {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.gun-coords input {
  width: 100%;
  padding: .55rem .7rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
}

/* Responsive */
@media (max-width: 540px) {
  .gun-row {
    grid-template-columns: 1fr;
  }
  .gun-coords {
    grid-template-columns: 1fr;
  }
}

/* In placing mode, existing markers/shapes should not block map clicks */
.placing-mode .leaflet-marker-pane .leaflet-marker-icon,
.placing-mode .leaflet-marker-pane .leaflet-marker-shadow,
.placing-mode .leaflet-overlay-pane .leaflet-interactive {
  pointer-events: none !important;
}

/* Hide all tooltips while placing (including permanent labels) */
.placing-mode .leaflet-tooltip {
  display: none !important;
}

/* Optional but useful: tooltips should never intercept the mouse */
.leaflet-tooltip {
  pointer-events: none;
}

.spread-min { color: #1d4ed8; font-weight: 600; }   /* blue */
.spread-max { color: #b45309; font-weight: 600; }   /* amber/brown */
.spread-center { font-weight: 700; color: #111827; }

.spread-box {
  margin-top: .5rem;
  padding-top: 0;
  border-top: 0;
}

.spread-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .4rem;
  align-items: end;
}

.spread-row {
  margin: .25rem 0 .45rem;
}

.spread-k {
  color: #4b5563;
}

.spread-summary {
  margin-top: .35rem;
}

/* ==========================
   Work queue overlay (map)
   ========================== */

.work-queue-overlay {
  position: absolute;
  top: 202px;
  right: 12px;   
  left: auto;    
  z-index: 1200;
  min-width: 260px;
  max-width: 340px;
  padding: .65rem .75rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow);
  pointer-events: none;
}

.work-queue-overlay__title {
  font-weight: 600;
  font-size: .9rem;
  margin-bottom: .2rem;
}

.work-queue-overlay__meta {
  font-size: .8rem;
  color: var(--muted);
  margin-bottom: .35rem;
}

.work-queue-overlay__bar {
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: var(--panel-2);
  border: 1px solid var(--border);
  overflow: hidden;
}

.work-queue-overlay__fill {
  height: 100%;
  width: 0%;
  background: var(--primary);
  transition: width .15s ease;
}

/* TODO: Add a secondary color/state for "user-priority marker loading" vs background preload if useful. */

/* ==========================
   Home page
   ========================== */

body.home-page {
  font-family: sans-serif;
  margin: 0;
  padding: 20px;
  background-color: #f4f4f4;
  color: #333;
}

.home-page h1,
.home-page h2 {
  color: #333;
}

.home-page__container {
  max-width: 800px;
  margin: 0 auto;
  background: white;
  padding: 20px;
  border-radius: 5px;
  box-shadow: 0 0 5px rgba(0,0,0,0.1);
}

.home-page button {
  margin: 5px;
  padding: 10px 20px;
  font-size: 16px;
  cursor: pointer;
}

.home-page label {
  display: block;
  margin-top: 15px;
}

.home-page input[type="text"],
.home-page select {
  width: 100%;
  padding: 8px;
  margin-top: 5px;
  box-sizing: border-box;
}

.home-page .panel {
  margin-top: 20px;
  padding: 15px;
  border: 1px solid #ddd;
  border-radius: 5px;
  background-color: #fafafa;
}

.home-page #generatedHashLabel {
  display: inline-block;
  margin-top: 10px;
  font-weight: bold;
}

.home-page #mapImage {
  display: block;
  margin-top: 15px;
  max-width: 100%;
  height: auto;
  border: 1px solid #ddd;
  border-radius: 5px;
}

.form-grid.align-end {
  align-items: end;
}

#rebuild3DBtn {
  width: 100%;
}


/* Sightline */
.sightline-status {
  min-height: 3.2rem;
  padding: .7rem .8rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
  font-size: .92rem;
}
.sightline-status[data-tone="info"] {
  border-color: rgba(59, 130, 246, 0.55);
}
.sightline-status[data-tone="ok"] {
  border-color: rgba(34, 197, 94, 0.55);
}
.sightline-status[data-tone="warn"] {
  border-color: rgba(245, 158, 11, 0.55);
}
.sightline-status[data-tone="error"] {
  border-color: rgba(239, 68, 68, 0.55);
}

.leaflet-container.sightline-mode {
  cursor: crosshair;
}


.mission-preview__empty {
  color: var(--muted);
  font-size: .9rem;
}
.mission-symbol-icon {
  background: transparent;
  border: 0;
}
.mission-symbol-icon__inner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.mission-symbol-icon__inner svg {
  display: block;
}

.mission-tactical-graphic-point {
  background: transparent;
  border: 0;
}
.mission-tactical-graphic-point__shape {
  width: 18px;
  height: 18px;
  box-sizing: border-box;
  border: 3px solid var(--mission-tactical-accent, #1565c0);
  background: rgba(255,255,255,0.94);
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.24);
}
.mission-tactical-graphic-point__shape--circle {
  border-radius: 999px;
}
.mission-tactical-graphic-point__shape--square {
  border-radius: 4px;
}
.mission-tactical-graphic-point__shape--diamond {
  border-radius: 4px;
  transform: rotate(45deg);
}

.mission-tactical-label {
  background: transparent;
  border: 0;
}
.mission-tactical-label,
.mission-tactical-label * {
  pointer-events: none !important;
}
.mission-tactical-label__inner {
  position: relative;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 2px solid var(--mission-tactical-accent, #1565c0);
  background: rgba(15, 23, 42, 0.88);
  color: #f8fafc;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.32);
}
.mission-tactical-label--point .mission-tactical-label__inner {
  transform: translate(-50%, -100%);
}
.mission-tactical-label--route .mission-tactical-label__inner,
.mission-tactical-label--phase-line .mission-tactical-label__inner,
.mission-tactical-label--boundary .mission-tactical-label__inner {
  min-height: 32px;
  padding-inline: 16px;
}
.mission-tactical-label--objective .mission-tactical-label__inner,
.mission-tactical-label--engagement-area .mission-tactical-label__inner,
.mission-tactical-label--no-fire-area .mission-tactical-label__inner {
  border-radius: 14px;
}
.mission-tactical-label--no-fire-area .mission-tactical-label__inner {
  background: rgba(127, 29, 29, 0.92);
  border-color: rgba(252, 165, 165, 0.92);
}


/* Rangie assistant */
.rangie-assistant {
  position: fixed;
  right: 16px;
  bottom: 14px;
  z-index: 700;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  pointer-events: none;
}
.rangie-assistant--quiet {
  opacity: 0.72;
}
.rangie-assistant__bubble {
  position: relative;
  width: min(388px, calc(100vw - 28px));
  min-height: 140px;
  margin-right: -6px;
  padding: 20px 36px 52px 30px;
  background: url('/static/images/rangie/rangie_speech_bubble.svg') center / 100% 100% no-repeat;
  color: #1a1c1a;
  font-size: 0.92rem;
  line-height: 1.28;
  pointer-events: auto;
  transform-origin: 85% 100%;
  transition: transform .18s ease, opacity .18s ease;
}
.rangie-assistant__bubble[hidden] {
  display: none;
}
.rangie-assistant__bubbleText {
  max-width: 300px;
  font-weight: 600;
  text-wrap: balance;
}
.rangie-assistant__mute {
  position: absolute;
  top: 12px;
  right: 16px;
  width: 24px;
  height: 24px;
  border: 0;
  background: rgba(26, 28, 26, 0.08);
  color: #1a1c1a;
  border-radius: 999px;
  font: inherit;
  line-height: 1;
  cursor: pointer;
}
.rangie-assistant__mute:hover {
  background: rgba(26, 28, 26, 0.16);
}
.rangie-assistant__button {
  width: 156px;
  height: 156px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  pointer-events: auto;
  transition: transform .14s ease;
}
.rangie-assistant__button:hover {
  transform: translateY(-2px) scale(1.02);
}
.rangie-assistant__button:active {
  transform: translateY(1px) scale(0.98);
}
.rangie-assistant__pose {
  width: 100%;
  height: 100%;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
  filter: drop-shadow(0 10px 22px rgba(0, 0, 0, 0.24));
  animation: rangieBob 3.8s ease-in-out infinite;
}
.rangie-assistant--angry .rangie-assistant__pose {
  animation-duration: 1.2s;
}
.rangie-assistant--crashed .rangie-assistant__pose {
  animation: rangieGlitch 1.1s steps(2, end) infinite;
}
.rangie-assistant__button:focus-visible {
  outline: 2px solid var(--ring);
  outline-offset: 4px;
  border-radius: 24px;
}
@keyframes rangieBob {
  0%, 100% { transform: translateY(0px) rotate(-1.2deg); }
  50% { transform: translateY(-5px) rotate(1.4deg); }
}
@keyframes rangieGlitch {
  0%, 100% { transform: translate(0, 0) rotate(-1deg); filter: drop-shadow(0 10px 22px rgba(0, 0, 0, 0.24)); }
  35% { transform: translate(-2px, 1px) rotate(0.8deg); filter: drop-shadow(2px 0 0 rgba(95, 127, 166, 0.45)); }
  65% { transform: translate(2px, -1px) rotate(-0.8deg); filter: drop-shadow(-2px 0 0 rgba(127, 48, 38, 0.4)); }
}
@media (max-width: 680px) {
  .rangie-assistant {
    right: 8px;
    bottom: 8px;
  }
  .rangie-assistant__button {
    width: 112px;
    height: 112px;
  }
  .rangie-assistant__bubble {
    width: min(312px, calc(100vw - 12px));
    min-height: 118px;
    margin-right: -4px;
    padding: 16px 30px 42px 24px;
    font-size: 0.84rem;
  }
  .rangie-assistant__bubbleText {
    max-width: 232px;
  }
}

@media (max-width: 520px) {
  .leaflet-popup-content-wrapper {
    max-width: min(96vw, 420px);
  }

  .leaflet-popup-content {
    max-width: min(94vw, 400px);
  }

  .popup-card,
  .popup-card--marker,
  .popup-card--marker-wide,
  .popup-card--compact {
    width: auto;
    padding: .9rem;
  }

  .app-popup--marker .leaflet-popup-content {
    width: min(95vw, 290px) !important;
    max-width: min(95vw, 290px) !important;
  }

  .app-popup--target .leaflet-popup-content {
    width: min(95vw, 332px) !important;
    max-width: min(95vw, 332px) !important;
  }

  .mission-item-popup-wrap .leaflet-popup-content {
    width: min(95vw, 324px) !important;
    max-width: min(95vw, 324px) !important;
  }

  .kv {
    grid-template-columns: 88px minmax(0, 1fr);
    gap: .28rem .75rem;
  }
}
