.commons-map-page {
  --commons-page-gap: clamp(0.85rem, 1.2vw, 1.15rem);
  --commons-stage-min-height: clamp(360px, var(--commons-workspace-min-height, 62vh), 820px);
  --commons-panel-max-height: var(--commons-panel-max-height-runtime, calc(var(--commons-shell-height, 100dvh) - var(--commons-header-height, 82px) - var(--commons-topbar-height, 112px) - var(--commons-footer-height, 56px) - var(--commons-page-gap)));
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: var(--commons-page-gap);
  align-content: start;
}

.commons-layout {
  display: grid;
  grid-template-areas: "filters workspace detail";
  grid-template-columns: minmax(220px, 260px) minmax(0, 1fr) minmax(260px, 320px);
  gap: 0.9rem;
  align-items: start;
  min-height: 0;
}

.commons-panel--filters {
  grid-area: filters;
}

.commons-workspace {
  grid-area: workspace;
}

.commons-panel--detail {
  grid-area: detail;
}

.commons-panel,
.commons-workspace,
.commons-workspace-main,
.commons-views,
.commons-view,
.map-panel {
  min-width: 0;
  min-height: 0;
}

.commons-panel {
  display: grid;
  gap: 1rem;
  align-content: start;
}

.commons-workspace {
  display: grid;
  grid-template-rows: minmax(var(--commons-stage-min-height), 1fr);
  gap: 0;
  min-height: var(--commons-stage-min-height);
  align-self: stretch;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.commons-workspace-main {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  min-height: var(--commons-stage-min-height);
}

.commons-views {
  position: relative;
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  min-height: var(--commons-stage-min-height);
}

.commons-view {
  display: none;
  min-height: var(--commons-stage-min-height);
}

.commons-view.is-active {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  min-height: var(--commons-stage-min-height);
}

.commons-view.is-active > * {
  min-width: 0;
  min-height: var(--commons-stage-min-height);
}

.map-panel {
  position: relative;
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  min-width: 0;
  min-height: var(--commons-stage-min-height);
}

.commons-panel--filters,
.commons-panel--detail {
  position: sticky;
  top: calc(var(--commons-header-height, 82px) + 0.9rem);
  max-height: var(--commons-panel-max-height);
  z-index: 2;
}

@media (max-width: 1180px) {
  .commons-map-page {
    --commons-stage-min-height: clamp(460px, var(--commons-workspace-min-height, 64svh), 860px);
    align-content: stretch;
  }

  .commons-layout {
    grid-template-areas:
      "workspace workspace"
      "filters detail";
    grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
    align-items: start;
  }

  .commons-workspace {
    grid-template-rows: minmax(var(--commons-stage-min-height), 1fr);
    min-height: var(--commons-stage-min-height);
  }

  .commons-workspace-main,
  .commons-views,
  .commons-view,
  .commons-view.is-active,
  .commons-view.is-active > * {
    min-height: var(--commons-stage-min-height);
    height: 100%;
  }

  .commons-panel--filters,
  .commons-panel--detail {
    position: static;
    top: auto;
    max-height: none;
    margin: 0;
    align-self: start;
  }
}

@media (max-width: 820px) {
  .commons-map-page {
    --commons-stage-min-height: clamp(470px, var(--commons-workspace-min-height, 68svh), 920px);
    --commons-mobile-overlay-inline: max(0.75rem, env(safe-area-inset-left, 0px));
    --commons-mobile-overlay-inline-end: max(0.75rem, env(safe-area-inset-right, 0px));
    --commons-mobile-overlay-bottom: calc(var(--commons-footer-height, 56px) + 0.45rem + env(safe-area-inset-bottom, 0px));
    --commons-mobile-overlay-top: calc(var(--commons-header-height, 82px) + var(--commons-topbar-height, 120px) + 0.35rem);
    min-height: calc(var(--commons-shell-height, 100dvh) - var(--commons-header-height, 82px) - var(--commons-footer-height, 56px) - 0.25rem);
    overflow: hidden;
  }

  .commons-layout {
    position: relative;
    grid-template-areas: "workspace";
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .commons-panel--filters,
  .commons-panel--detail {
    position: fixed;
    left: var(--commons-mobile-overlay-inline);
    right: var(--commons-mobile-overlay-inline-end);
    z-index: 45;
    top: auto;
    max-height: min(62dvh, 36rem);
    margin: 0;
    overflow: auto;
    opacity: 0;
    pointer-events: none;
    transition: opacity 160ms ease, transform 180ms ease;
    box-shadow: 0 24px 56px rgba(16, 22, 20, 0.16);
  }

  .commons-panel--filters {
    top: var(--commons-mobile-overlay-top);
    transform: translateY(-0.9rem);
  }

  .commons-panel--detail {
    bottom: var(--commons-mobile-overlay-bottom);
    transform: translateY(calc(100% + 1.25rem));
    max-height: min(56dvh, 34rem);
  }

  .commons-map-page.is-mobile-filters-open .commons-panel--filters,
  .commons-map-page.is-mobile-detail-open .commons-panel--detail {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
}

@media (max-width: 720px) {
  .commons-map-page {
    --commons-page-gap: 0.5rem;
    --commons-stage-min-height: clamp(500px, var(--commons-workspace-min-height, 70svh), 860px);
    --commons-mobile-overlay-inline: max(0.5rem, env(safe-area-inset-left, 0px));
    --commons-mobile-overlay-inline-end: max(0.5rem, env(safe-area-inset-right, 0px));
    --commons-mobile-overlay-top: calc(var(--commons-header-height, 82px) + var(--commons-topbar-height, 120px) + 0.15rem);
  }

  .commons-workspace {
    gap: 0;
  }

  .commons-panel--filters {
    max-height: min(60dvh, 30rem);
  }

  .commons-panel--detail {
    max-height: min(58dvh, 32rem);
  }
}
