.gs-coord-map,
.gs-coord-map * {
  box-sizing: border-box;
}

.gs-coord-map {
  --gs-navy: #232f3e;
  --gs-navy-soft: #314255;
  --gs-orange: #ff8400;
  --gs-orange-soft: rgba(255, 132, 0, 0.13);
  --gs-white: #ffffff;
  --gs-gray-50: #f6f8fb;
  --gs-gray-100: #eef2f6;
  --gs-gray-200: #dbe3ec;
  --gs-gray-300: #c7d2df;
  --gs-gray-500: #6b7888;
  --gs-text: #17202b;
  --gs-shadow: 0 18px 50px rgba(35, 47, 62, 0.12);
  width: 100%;
  margin: 0 auto;
  padding: 24px 0;
  color: var(--gs-text);
  font-family: inherit;
}

.gs-coord-map button,
.gs-coord-map input,
.gs-coord-map select {
  font: inherit;
}

.gs-coord-map__hero {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: stretch;
  padding: 28px;
  border-radius: 0;
  background: linear-gradient(135deg, var(--gs-navy) 0%, #16202c 100%);
  color: var(--gs-white);
  box-shadow: var(--gs-shadow);
}

.gs-coord-map__eyebrow {
  margin: 0 0 10px;
  color: var(--gs-orange);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.gs-coord-map h2,
.gs-coord-map h3,
.gs-coord-map p {
  margin-top: 0;
}

.gs-coord-map h2 {
  margin-bottom: 12px;
  font-size: clamp(28px, 4vw, 46px);
  line-height: 1.08;
  font-weight: 800;
}

.gs-coord-map h3 {
  margin-bottom: 6px;
  color: var(--gs-navy);
  font-size: 20px;
  line-height: 1.2;
}

.gs-coord-map__lead {
  max-width: 780px;
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 17px;
  line-height: 1.55;
}

.gs-coord-map__badge {
  min-width: 220px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.08);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.gs-coord-map__badge span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 13px;
}

.gs-coord-map__badge strong {
  display: block;
  margin-top: 6px;
  color: var(--gs-white);
  font-size: 22px;
  line-height: 1.2;
}

.gs-coord-map__toolbar {
  display: grid;
  grid-template-columns: minmax(420px, 1fr) minmax(210px, 0.35fr) auto;
  gap: 12px;
  align-items: end;
  margin-top: 18px;
  padding: 16px;
  background: var(--gs-white);
  border: 1px solid var(--gs-gray-200);
  box-shadow: var(--gs-shadow);
}

.gs-coord-map__select-wrap,
.gs-coord-map__mode-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.gs-coord-map label,
.gs-coord-map__group-label {
  color: var(--gs-gray-500);
  font-size: 13px;
  font-weight: 800;
}

.gs-coord-map__select {
  width: 100%;
  height: 44px;
  padding: 0 14px;
  border: 1px solid var(--gs-gray-200);
  border-radius: 0;
  background: var(--gs-gray-50);
  color: var(--gs-text);
  outline: none;
}

.gs-coord-map__select:focus {
  border-color: var(--gs-orange);
  box-shadow: 0 0 0 3px var(--gs-orange-soft);
}

.gs-coord-map__mode {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.gs-coord-map__mode-btn,
.gs-coord-map__clear,
.gs-coord-map__copy,
.gs-coord-map__region-btn,
.gs-coord-map__ghost-btn {
  min-height: 44px;
  border: 1px solid var(--gs-gray-200);
  border-radius: 0;
  background: var(--gs-white);
  color: var(--gs-navy);
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.gs-coord-map__mode-btn {
  padding: 0 14px;
  font-weight: 800;
}

.gs-coord-map__mode-btn:hover,
.gs-coord-map__clear:hover,
.gs-coord-map__copy:hover,
.gs-coord-map__region-btn:hover,
.gs-coord-map__ghost-btn:hover {
  border-color: var(--gs-orange);
  transform: translateY(-1px);
}

.gs-coord-map__mode-btn.is-active,
.gs-coord-map__clear,
.gs-coord-map__copy {
  border-color: var(--gs-orange);
  background: var(--gs-orange);
  color: var(--gs-white);
}

.gs-coord-map__clear {
  padding: 0 18px;
  font-weight: 900;
}

.gs-coord-map__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 18px;
}

.gs-coord-map__map-card,
.gs-coord-map__info,
.gs-coord-map__list-card {
  background: var(--gs-white);
  border: 1px solid var(--gs-gray-200);
  box-shadow: var(--gs-shadow);
}

.gs-coord-map__map-card,
.gs-coord-map__list-card {
  padding: 18px;
}

.gs-coord-map__map-head,
.gs-coord-map__list-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.gs-coord-map__map-head p,
.gs-coord-map__list-head p {
  margin-bottom: 0;
  color: var(--gs-gray-500);
  font-size: 14px;
  line-height: 1.45;
}

.gs-coord-map__legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  min-width: 220px;
}

.gs-coord-map__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--gs-gray-500);
  font-size: 12px;
  font-weight: 800;
}

.gs-coord-map__legend-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1px solid rgba(35, 47, 62, 0.12);
}

.gs-coord-map__map-shell {
  position: relative;
  width: 100%;
  min-height: 560px;
  overflow: hidden;
  border: 1px solid var(--gs-gray-200);
  background: var(--gs-gray-50);
}

.gs-coord-map__leaflet {
  width: 100%;
  min-height: 560px;
  z-index: 1;
}

.gs-coord-map__loading {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(246, 248, 251, 0.92);
  color: var(--gs-navy);
  font-weight: 900;
}

.gs-coord-map__loading.is-hidden {
  display: none;
}

.gs-coord-map__map-actions {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-top: 12px;
  color: var(--gs-gray-500);
  font-size: 13px;
  font-weight: 700;
}

.gs-coord-map__ghost-btn {
  min-height: 40px;
  padding: 0 14px;
  font-weight: 800;
}

.gs-mck-marker {
  width: 38px;
  height: 38px;
  border: 2px solid var(--gs-navy);
  border-radius: 50%;
  background: var(--gs-white);
  color: var(--gs-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 7px 15px rgba(35, 47, 62, 0.2);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
}

.gs-mck-marker.is-selected,
.gs-mck-marker:hover {
  background: var(--gs-orange);
  color: var(--gs-white);
  border-color: var(--gs-navy);
}

.gs-mck-marker.is-muted {
  opacity: 0.28;
}

.gs-zone-marker {
  width: 38px;
  height: 38px;
  border: 2px solid var(--gs-navy);
  border-radius: 50%;
  background: var(--gs-white);
  color: var(--gs-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 7px 15px rgba(35, 47, 62, 0.2);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
}

.gs-zone-marker.is-selected,
.gs-zone-marker:hover {
  background: var(--gs-orange);
  color: var(--gs-white);
  border-color: var(--gs-navy);
}


.gs-zone-1,
.gs-zone-4,
.gs-zone-7,
.gs-zone-34 {
  background: #62a7ff;
  fill: #62a7ff;
}

.gs-zone-2,
.gs-zone-5,
.gs-zone-8,
.gs-zone-35 {
  background: #79c879;
  fill: #79c879;
}

.gs-zone-3,
.gs-zone-6,
.gs-zone-9,
.gs-zone-36 {
  background: #ffba5f;
  fill: #ffba5f;
}

.gs-zone-10,
.gs-zone-37 {
  background: #f06c8a;
  fill: #f06c8a;
}

.gs-zone-11 {
  background: #b68cff;
  fill: #b68cff;
}

.gs-zone-12 {
  background: #53c5c0;
  fill: #53c5c0;
}

.gs-zone-13 {
  background: #ff8a65;
  fill: #ff8a65;
}

.gs-coord-map__info {
  margin-top: 18px;
  padding: 22px;
  align-self: stretch;
}

.gs-coord-map__info-kicker {
  margin-bottom: 8px;
  color: var(--gs-orange);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.gs-coord-map__info h3 {
  margin-bottom: 12px;
  font-size: 26px;
}

.gs-coord-map__status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  padding: 8px 10px;
  background: var(--gs-orange-soft);
  color: var(--gs-navy);
  font-size: 13px;
  font-weight: 800;
}

.gs-coord-map__status::before {
  content: "";
  width: 9px;
  height: 9px;
  background: var(--gs-orange);
  border-radius: 50%;
}

.gs-coord-map__facts {
  display: grid;
  gap: 10px;
  margin: 0 0 18px;
}

.gs-coord-map__fact {
  padding: 12px;
  border-left: 4px solid var(--gs-orange);
  background: var(--gs-gray-50);
}

.gs-coord-map__fact span {
  display: block;
  margin-bottom: 3px;
  color: var(--gs-gray-500);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.gs-coord-map__fact strong {
  color: var(--gs-navy);
  font-size: 18px;
  word-break: break-word;
}

.gs-coord-map__details {
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
  color: var(--gs-gray-500);
  font-size: 14px;
  line-height: 1.55;
}

.gs-coord-map__details li + li {
  margin-top: 6px;
}

.gs-coord-map__mount-card {
  margin: 0 0 18px;
  border: 1px solid var(--gs-gray-200);
}

.gs-coord-map__mount-head {
  padding: 12px;
  background: var(--gs-navy);
  color: var(--gs-white);
}

.gs-coord-map__mount-head strong,
.gs-coord-map__mount-head span {
  display: block;
}

.gs-coord-map__mount-head strong {
  font-size: 16px;
}

.gs-coord-map__mount-head span {
  margin-top: 3px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 12px;
  font-weight: 700;
}

.gs-coord-map__mount-grid {
  display: grid;
  gap: 1px;
  background: var(--gs-gray-200);
}

.gs-coord-map__mount-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.92fr) minmax(0, 1.08fr);
  gap: 1px;
}

.gs-coord-map__mount-row span,
.gs-coord-map__mount-row strong {
  padding: 10px;
  background: var(--gs-white);
  font-size: 13px;
  line-height: 1.35;
}

.gs-coord-map__mount-row span {
  color: var(--gs-gray-500);
  font-weight: 800;
}

.gs-coord-map__mount-row strong {
  color: var(--gs-navy);
  font-weight: 900;
  word-break: break-word;
}

.gs-coord-map__copy {
  width: 100%;
  padding: 0 14px;
  font-weight: 900;
}

.gs-coord-map__copy.is-done {
  background: var(--gs-navy);
  border-color: var(--gs-navy);
}


.gs-coord-map__info .gs-coord-map__facts {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.gs-coord-map__info .gs-coord-map__mount-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.gs-coord-map__list-card {
  margin-top: 18px;
}

.gs-coord-map__region-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.gs-coord-map__region-btn {
  width: 100%;
  min-height: 70px;
  padding: 10px;
  text-align: left;
}

.gs-coord-map__region-btn strong,
.gs-coord-map__region-btn span {
  display: block;
}

.gs-coord-map__region-btn strong {
  color: var(--gs-navy);
  font-size: 14px;
  line-height: 1.25;
}

.gs-coord-map__region-btn span {
  margin-top: 5px;
  color: var(--gs-gray-500);
  font-size: 12px;
  font-weight: 700;
}

.gs-coord-map__region-btn.is-selected {
  border-color: var(--gs-orange);
  background: var(--gs-orange-soft);
}

@media (max-width: 1180px) {
  .gs-coord-map__toolbar {
    grid-template-columns: 1fr 1fr;
  }

  .gs-coord-map__layout {
    grid-template-columns: 1fr;
  }

  .gs-coord-map__info .gs-coord-map__facts,
  .gs-coord-map__info .gs-coord-map__mount-grid {
    grid-template-columns: 1fr;
  }

  .gs-coord-map__region-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .gs-coord-map {
    padding: 16px 0;
  }

  .gs-coord-map__hero,
  .gs-coord-map__map-head,
  .gs-coord-map__list-head,
  .gs-coord-map__map-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .gs-coord-map__hero {
    padding: 22px;
  }

  .gs-coord-map__badge {
    width: 100%;
    min-width: 0;
  }

  .gs-coord-map__toolbar {
    grid-template-columns: 1fr;
  }

  .gs-coord-map__mode {
    display: grid;
    grid-template-columns: 1fr;
  }

  .gs-coord-map__mode-btn,
  .gs-coord-map__clear,
  .gs-coord-map__ghost-btn {
    width: 100%;
  }

  .gs-coord-map__legend {
    justify-content: flex-start;
    min-width: 0;
  }

  .gs-coord-map__map-shell,
  .gs-coord-map__leaflet {
    min-height: 440px;
  }

  .gs-coord-map__region-list {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 520px) {
  .gs-coord-map__region-list {
    grid-template-columns: 1fr;
  }

  .gs-coord-map__mount-row {
    grid-template-columns: 1fr;
  }

  .gs-mck-marker,
  .gs-zone-marker {
    width: 34px;
    height: 34px;
    font-size: 13px;
  }
}
