  .econ-map {
  --em-primary: var(--wdg-color-primary, #0032A0);
  --em-secondary: var(--wdg-color-secondary, #00A9E0);
  --em-accent: var(--wdg-color-accent-dark, #002678);
  --em-bg: var(--wdg-color-white-gray, #f5f8ff);
  --em-surface: var(--wdg-color-white, #ffffff);
  --em-border: var(--wdg-color-cool-gray-light, #d7e1f5);
  --em-text: var(--wdg-color-text, #13203f);
  --em-muted: var(--wdg-color-cool-gray-xdark, #60709a);
  --em-white: var(--wdg-color-white, #ffffff);
  --em-radius: 12px;
  --em-font: var(--wdg-font-default, inherit);
  font-family: var(--em-font);
  width: 100%;
  border: 1px solid var(--em-border);
  border-radius: var(--em-radius);
  background: var(--em-bg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.econ-map *,
.econ-map *::before,
.econ-map *::after {
  box-sizing: border-box;
}

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

.econ-map .mapboxgl-ctrl-geocoder {
  min-width: 220px;
  max-width: 320px;
  font-family: var(--em-font);
  font-size: 0.85rem;
  box-shadow: 0 2px 8px rgba(19, 43, 96, 0.12);
  border-radius: 8px;
}

.econ-map .mapboxgl-ctrl-geocoder .mapboxgl-ctrl-geocoder--input {
  height: 36px;
  padding: 6px 10px 6px 34px;
  font-size: 0.85rem;
}

.econ-map .mapboxgl-ctrl-geocoder .mapboxgl-ctrl-geocoder--icon-search {
  top: 8px;
  left: 8px;
  width: 18px;
  height: 18px;
}

.econ-map__content {
  display: flex;
  flex-direction: column;
}

.econ-map__body {
  width: 100%;
  background: var(--em-bg);
  display: flex;
  flex-direction: column;
}

.econ-map__map-container {
  width: 100%;
  flex: 1 1 auto;
  display: flex;
}

.econ-map__map {
  width: 100%;
  flex: 1 1 auto;
  aspect-ratio: 4/3;
  min-height: 260px;
  max-height: 70vh;
  background: var(--em-border);
}

.econ-map__legend-control {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--em-border);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(19, 43, 96, 0.14);
  padding: 0.35rem 0.5rem 0.4rem;
  width: auto;
  min-width: 120px;
  max-width: 180px;
}

.econ-map__legend-title {
  margin: 0 0 0.3rem;
  color: var(--em-primary);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  white-space: nowrap;
}

.econ-map__legend-bar {
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, #CCD6EC 0%, #99ADD9 16.66%, #6B84C6 33.33%, #335BB3 50%, #0032A0 66.66%, #002678 83.33%, #001950 100%);
  border: 1px solid var(--em-border);
}

.econ-map__legend-scale {
  display: flex;
  justify-content: space-between;
  gap: 0.2rem;
  margin-top: 0.32rem;
  font-size: 0.62rem;
  color: var(--em-muted);
  font-weight: 600;
}

.econ-map__legend-scale span {
  flex: 1 1 0;
  min-width: 0;
}

.econ-map__legend-scale span:first-child {
  text-align: left;
}

.econ-map__legend-scale span:last-child {
  text-align: right;
}

.econ-map__legend-scale span:not(:first-child):not(:last-child) {
  text-align: center;
}

.econ-map__info-panel {
  background: var(--em-surface);
  border-top: 1px solid var(--em-border);
  padding: 0.85rem 1rem 1rem;
}

.econ-map__panel-header {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-bottom: 0.65rem;
}

.econ-map__summary-title {
  margin: 0;
  color: var(--em-text);
  font-size: 1.05rem;
  font-weight: 700;
}

.econ-map__summary-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.6rem;
}

.econ-map__metric-card {
  background: var(--em-surface);
  border: 1px solid var(--em-border);
  border-radius: 10px;
  padding: 0.55rem 0.6rem;
}

.econ-map__metric-label {
  display: block;
  color: var(--em-muted);
  font-size: 0.72rem;
  font-weight: 600;
  margin-bottom: 0.2rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.econ-map__metric-value {
  display: block;
  color: var(--em-primary);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.15;
}

.econ-map__tabs {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}

.econ-map__tab {
  border: 1px solid var(--em-border);
  background: var(--em-bg);
  color: var(--em-primary);
  border-radius: 999px;
  padding: 0.36rem 0.78rem;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.econ-map__tab:hover {
  background: var(--em-surface);
}

.econ-map__tab--active {
  background: var(--em-primary);
  border-color: var(--em-primary);
  color: var(--em-white);
}

.econ-map__tab.is-hidden {
  display: none;
}

.econ-map__tab-content {
  min-height: 152px;
}

.econ-map__panel-section {
  border: 1px solid var(--em-border);
  border-radius: 10px;
  background: var(--em-bg);
  padding: 0.65rem 0.75rem;
}

.econ-map__panel-heading {
  margin: 0 0 0.55rem;
  color: var(--em-primary);
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.econ-map__panel-grid {
  display: flex;
  flex-direction: column;
  gap: 0.42rem;
}

.econ-map__panel-row {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  align-items: baseline;
}

.econ-map__panel-label {
  display: flex;
  align-items: baseline;
  flex: 1 1 auto;
  min-width: 0;
  color: var(--em-muted);
  font-size: 0.95rem;
}

.econ-map__panel-label::after {
  content: "";
  flex: 1 1 auto;
  min-width: 1.25rem;
  margin-left: 0.4rem;
  border-bottom: 1px dotted var(--em-muted);
  opacity: 0.5;
  transform: translateY(-0.22em);
}

.econ-map__panel-value {
  flex: 0 0 auto;
  color: var(--em-text);
  font-size: 0.98rem;
  font-weight: 700;
  text-align: right;
  white-space: nowrap;
}

.econ-map__panel-divider {
  border: 0;
  border-top: 1px dashed var(--em-border);
  margin: 0.2rem 0;
}

.econ-map__panel-empty {
  margin: 0;
  border: 1px dashed var(--em-border);
  border-radius: 10px;
  background: var(--em-bg);
  color: var(--em-muted);
  padding: 0.65rem 0.75rem;
  font-size: 0.92rem;
}

.econ-map__status {
  margin: 0.55rem 0 0;
  font-size: 0.79rem;
  min-height: 1.1em;
}

.econ-map__status.is-info {
  color: var(--em-secondary);
}

.econ-map__status.is-warning {
  color: #9a6800;
}

.econ-map__status.is-error {
  color: #a71f1f;
}

.econ-map__info-actions {
  margin-top: 0.65rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.econ-map__btn {
  border: 1px solid var(--em-primary);
  background: var(--em-primary);
  color: var(--em-white);
  border-radius: 999px;
  padding: 0.36rem 0.85rem;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.2s ease, background 0.2s ease;
}

.econ-map__btn:hover,
.econ-map__btn:focus-visible {
  opacity: 0.92;
}

.econ-map__map-actions-control {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
}

.econ-map__map-action-btn {
  -webkit-appearance: none;
  appearance: none;
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--em-primary);
  background: var(--em-surface);
  color: var(--em-primary);
  border-radius: 999px;
  padding: 0.42rem 0.95rem;
  font-family: var(--em-font);
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0.01em;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(19, 43, 96, 0.16);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.econ-map__map-action-btn:hover,
.econ-map__map-action-btn:focus-visible {
  background: var(--em-primary);
  color: var(--em-white);
  box-shadow: 0 4px 12px rgba(19, 43, 96, 0.24);
}

.econ-map__map-action-btn--view-mode.is-active {
  background: var(--em-primary);
  color: var(--em-white);
  border-color: var(--em-primary);
}

.econ-map__btn--active {
  background: var(--em-accent);
  border-color: var(--em-accent);
}

.econ-map__popup .mapboxgl-popup-content {
  border-radius: 10px;
  border: 1px solid var(--em-border);
  box-shadow: 0 8px 22px rgba(19, 43, 96, 0.16);
  padding: 0.55rem 0.7rem;
  font-size: 0.78rem;
  color: var(--em-text);
}

.econ-map__popup .mapboxgl-popup-content p {
  margin: 0;
  line-height: 1.35;
}

.econ-map--editor-preview {
  border: 2px dashed var(--em-border);
  border-radius: var(--em-radius);
  background: var(--em-bg);
}

.econ-map--editor-preview .econ-map__editor-placeholder {
  text-align: center;
  padding: 2.2rem 1.2rem;
  color: var(--em-muted);
}

.econ-map--editor-preview .econ-map__editor-placeholder .dashicons {
  color: var(--em-primary);
  font-size: 42px;
  width: 42px;
  height: 42px;
}

.econ-map--editor-preview .econ-map__editor-placeholder p {
  margin: 0.45rem 0;
}

.econ-map--editor-preview .econ-map__editor-placeholder code {
  background: var(--em-surface);
  border: 1px solid var(--em-border);
  border-radius: 6px;
  padding: 0.1rem 0.3rem;
}

.econ-map--editor-preview .econ-map__editor-hint {
  color: var(--em-muted);
  font-size: 0.84rem;
}

@media (min-width: 62em) {
  .econ-map__content {
    flex-direction: row;
  }
  .econ-map__body {
    flex: 0 0 60%;
    max-width: 60%;
  }
  .econ-map__map {
    aspect-ratio: auto;
    height: 100%;
    min-height: 520px;
    max-height: none;
  }
  .econ-map__info-panel {
    flex: 0 0 40%;
    max-width: 40%;
    border-top: none;
    border-left: 1px solid var(--em-border);
    overflow-y: auto;
    max-height: 700px;
  }
}
@media (max-width: 960px) {
  .econ-map__summary-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 768px) {
  .econ-map__info-panel {
    padding: 0.75rem 0.8rem 0.85rem;
  }
  .econ-map__summary-metrics {
    grid-template-columns: 1fr;
  }
  .econ-map__tabs {
    gap: 0.35rem;
  }
  .econ-map__tab {
    font-size: 0.76rem;
    padding: 0.34rem 0.68rem;
  }
}
@media (max-width: 480px) {
  .econ-map__panel-label,
  .econ-map__panel-value {
    font-size: 0.88rem;
  }
}
/*# sourceMappingURL=econ-map.css.map */
