:root {
  --multimap-gap: 1rem;
  --multimap-gap-large: 1.5rem;
  --multimap-radius: 16px;
  --multimap-border-width: 1px;
  --multimap-shadow-soft: 0 8px 20px rgba(15, 23, 42, 0.08);
  --multimap-shadow-medium: 0 12px 30px rgba(15, 23, 42, 0.12);
  --multimap-shadow-strong: 0 18px 45px rgba(15, 23, 42, 0.16);
  --multimap-infocard-width: 440px;
  --multimap-transition: 180ms ease;
}

body.multimap--modal-open {
  overflow: hidden;
}

.multimap {
  position: relative;
  display: grid;
  width: 100%;
  min-height: 0;
  overflow-y: auto;
  gap: var(--multimap-gap);
  grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
  grid-template-rows: auto minmax(0, 1fr) auto;
  grid-template-areas:
    'input input'
    'map list'
    'grid grid';
  padding: var(--multimap-gap-large);
  font-family: var(--multimap-font-family);
  font-size: var(--multimap-font-size-base);
  line-height: 1.5;
  color: var(--multimap-color-secondary);
  background-color: var(--multimap-color-bg);
  border-radius: var(--multimap-radius);
  box-shadow: var(--multimap-shadow-soft);
  box-sizing: border-box;
}

.multimap--map-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    'input'
    'list'
    'grid';
}

.multimap--list-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    'input'
    'map'
    'grid';
}

.multimap--map-hidden .multimap__list,
.multimap--list-hidden .multimap__map {
  grid-column: 1 / -1;
}

.multimap--map-hidden.multimap--list-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    'input'
    'grid';
}

.multimap--grid-hidden {
  grid-template-rows: auto minmax(0, 1fr);
  grid-template-areas:
    'input input'
    'map list';
}

.multimap--grid-hidden.multimap--map-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    'input'
    'list';
}

.multimap--grid-hidden.multimap--list-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    'input'
    'map';
}

.multimap--grid-hidden.multimap--map-hidden.multimap--list-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas: 'input';
  grid-template-rows: auto;
}

.multimap--input-hidden {
  grid-template-rows: minmax(0, 1fr) auto;
  grid-template-areas:
    'map list'
    'grid grid';
}

.multimap--input-hidden.multimap--map-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    'list'
    'grid';
}

.multimap--input-hidden.multimap--list-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    'map'
    'grid';
}

.multimap--input-hidden.multimap--map-hidden.multimap--list-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr);
  grid-template-areas: 'grid';
}

.multimap--input-hidden.multimap--grid-hidden {
  grid-template-rows: minmax(0, 1fr);
  grid-template-areas: 'map list';
}

.multimap--input-hidden.multimap--grid-hidden.multimap--map-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas: 'list';
}

.multimap--input-hidden.multimap--grid-hidden.multimap--list-hidden {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas: 'map';
}

.multimap--input-hidden.multimap--grid-hidden.multimap--map-hidden.multimap--list-hidden {
  grid-template-areas: none;
}

.multimap--blocked::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(2px);
  pointer-events: none;
  opacity: 1;
}

.multimap__section--hidden {
  display: none !important;
}

.multimap__notice {
  grid-column: 1 / -1;
  margin-bottom: calc(var(--multimap-gap) / 2);
  padding: 0.75rem 1rem;
  border-radius: calc(var(--multimap-radius) / 1.5);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  background: var(--multimap-color-highlight);
  font-size: var(--multimap-font-size-small);
  color: var(--multimap-color-secondary);
}

.multimap__notice[data-type='error'] {
  border-color: var(--multimap-color-danger);
  color: var(--multimap-color-danger);
}

.multimap__map {
  grid-area: map;
  position: relative;
  min-height: var(--multimap-map-min-height);
}

.multimap__map-layout {
  position: relative;
  display: block;
  min-height: inherit;
}

.multimap__map-viewport {
  position: relative;
  min-height: var(--multimap-map-min-height);
  border-radius: var(--multimap-radius);
  overflow: hidden;
  background: var(--multimap-color-highlight);
  box-shadow: var(--multimap-shadow-soft);
}

.multimap__map-viewport .multimap__map-surface {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  border-radius: inherit;
  overflow: hidden;
}

.multimap__input {
  grid-area: input;
  align-self: start;
}

.multimap__input,
.multimap__list,
.multimap__grid {
  background: var(--multimap-color-bg);
  border-radius: var(--multimap-radius);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  box-shadow: var(--multimap-shadow-soft);
  padding: var(--multimap-gap);
  box-sizing: border-box;
}

.multimap__list,
.multimap__grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  overflow: hidden;
}

.multimap__list {
  grid-area: list;
  min-height: var(--multimap-map-height, var(--multimap-map-min-height));
  max-height: var(--multimap-map-height, var(--multimap-map-min-height));
}

.multimap__grid {
  grid-area: grid;
}

.multimap__search {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.multimap__search-input {
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: calc(var(--multimap-radius) / 1.2);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  font-size: 1rem;
  transition: border-color var(--multimap-transition), box-shadow var(--multimap-transition);
  background: var(--multimap-color-bg);
  color: var(--multimap-color-secondary);
  box-sizing: border-box;
}

.multimap__search-input:focus-visible {
  outline: none;
  border-color: var(--multimap-color-primary);
  box-shadow: 0 0 0 3px rgba(43, 125, 233, 0.15);
}

.multimap__suggestions {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 0;
  right: 0;
  list-style: none;
  margin: 0;
  padding: 0.5rem 0;
  background: var(--multimap-color-bg);
  border-radius: calc(var(--multimap-radius) / 1.2);
  box-shadow: var(--multimap-shadow-medium);
  max-height: 18rem;
  overflow-y: auto;
  z-index: 20;
}

.multimap__suggestion {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.5rem 1rem;
}

.multimap__suggestion-button {
  text-align: left;
  border: none;
  background: transparent;
  font-size: 0.95rem;
  color: var(--multimap-color-secondary);
  cursor: pointer;
  font-weight: var(--multimap-font-weight-semibold);
  transition: color var(--multimap-transition);
}

.multimap__suggestion-button:hover,
.multimap__suggestion-button:focus-visible {
  color: var(--multimap-color-primary);
  outline: none;
}

.multimap__suggestion-meta {
  font-size: 0.75rem;
  color: var(--multimap-color-muted);
}

.multimap__list-items {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

.multimap__list-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding-bottom: 0.75rem;
  border-bottom: var(--multimap-border-width) solid var(--multimap-color-border);
}

.multimap__list-item:last-child {
  border-bottom: none;
}

.multimap__list-button {
  background: none;
  border: none;
  text-align: left;
  font-size: 1rem;
  font-weight: var(--multimap-font-weight-semibold);
  color: inherit;
  cursor: pointer;
  transition: color var(--multimap-transition);
}

.multimap__list-button:hover,
.multimap__list-button:focus-visible,
.multimap__list-item--active .multimap__list-button {
  color: var(--multimap-color-primary);
  outline: none;
}

.multimap__list-meta {
    font-size: 0.85rem;
    color: var(--multimap-color-muted);
    text-transform: capitalize;
}

.multimap__grid-items {
  display: grid;
  --multimap-grid-columns-desktop: 4;
  --multimap-grid-columns-tablet: 3;
  --multimap-grid-columns-mobile: 2;
  grid-template-columns: repeat(var(--multimap-grid-columns-desktop), minmax(0, 1fr));
  gap: var(--multimap-gap);
  align-items: start;
  justify-items: stretch;
}

.multimap__card {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  background: var(--multimap-color-bg);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  border-radius: calc(var(--multimap-radius) / 1.1);
  padding: var(--multimap-gap);
  transition: transform var(--multimap-transition), box-shadow var(--multimap-transition);
}

.multimap__card-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  width: 100%;
  padding: 0;
  border: none;
  background: transparent;
  color: inherit;
  font: inherit;
  font-weight: var(--multimap-font-weight-semibold);
  text-align: left;
  cursor: pointer;
  transition: color var(--multimap-transition);
}

.multimap__card-toggle:focus-visible {
  outline: none;
  color: var(--multimap-color-primary);
}

.multimap__card-toggle:hover {
  color: var(--multimap-color-primary);
}

.multimap__card-body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  overflow: hidden;
  height: 0;
  opacity: 0;
  transition: height var(--multimap-transition) ease, opacity var(--multimap-transition) ease;
}

.multimap__card--expanded .multimap__card-body {
  opacity: 1;
}

.multimap__card-body[hidden] {
  display: none !important;
}

.multimap__card:hover,
.multimap__card--active {
  transform: translateY(-4px);
  box-shadow: var(--multimap-shadow-medium);
}

.multimap__card-title {
  font-size: 1.1rem;
  margin: 0;
}

.multimap__card-meta,
.multimap__card-address {
  font-size: 0.9rem;
  margin: 0;
  color: var(--multimap-color-muted);
}

.multimap__card-media {
  margin: 0;
  border-radius: calc(var(--multimap-radius) / 1.5);
  overflow: hidden;
}

.multimap__card-media img {
  display: block;
  width: 100%;
  height: auto;
}

.multimap__card-actions {
  margin-top: auto;
  display: flex;
  gap: 0.5rem;
}

.multimap__card-button,
.multimap__infocard-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.6rem 1rem;
  border-radius: 999px;
  border: none;
  background: var(--multimap-color-primary);
  color: #fff;
  cursor: pointer;
  font-weight: var(--multimap-font-weight-semibold);
  transition: background-color var(--multimap-transition), transform var(--multimap-transition);
}

.multimap__card-button:hover,
.multimap__card-button:focus-visible,
.multimap__infocard-button:hover,
.multimap__infocard-button:focus-visible {
  background: #1a5cbf;
  transform: translateY(-1px);
  outline: none;
}

.multimap__empty {
  margin: 0;
  padding: var(--multimap-gap);
  background: var(--multimap-color-highlight);
  border-radius: calc(var(--multimap-radius) / 1.2);
  font-size: 0.95rem;
  color: var(--multimap-color-muted);
  text-align: center;
}

.multimap__infocard {
  position: absolute;
  inset: 0 auto 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--multimap-gap);
  width: clamp(360px, 45vw, var(--multimap-infocard-width, 440px));
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  background: var(--multimap-color-bg);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  border-radius: calc(var(--multimap-radius) * 1.05);
  transform: translateX(-100%);
  opacity: 0;
  transition: transform var(--multimap-transition), opacity var(--multimap-transition);
  z-index: 2;
  padding: var(--multimap-gap) calc(var(--multimap-gap) * 0.85);
  box-sizing: border-box;
  pointer-events: none;
}

.multimap__infocard--active {
    overflow: auto;
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}

.multimap__infocard-top {
  position: relative;
  background: var(--multimap-color-bg);
  z-index: 3;
}

.multimap__infocard-media {
  width: 100%;
  height: var(--multimap-infocard-media-height, 220px);
  border-radius: calc(var(--multimap-radius) / 1.5);
  background-color: var(--multimap-color-bg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain !important;
  overflow: hidden;
}

.multimap__infocard-top-content {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.multimap__infocard-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding: 0.15rem 0;
}

.multimap__infocard-summary-info {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
  color: var(--multimap-color-secondary);
  font-size: 0.95rem;
}

.multimap__infocard-category {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  background: var(--multimap-color-highlight);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  font-weight: var(--multimap-font-weight-semibold);
  color: var(--multimap-color-secondary);
}

.multimap__infocard-rating {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-weight: var(--multimap-font-weight-semibold);
  color: var(--multimap-color-secondary);
}

.multimap__infocard-review-count {
  color: var(--multimap-color-muted);
  font-size: 0.95rem;
}

.multimap__infocard-quick-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.multimap__infocard-action {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  background: var(--multimap-color-highlight);
  color: var(--multimap-color-secondary);
  box-shadow: var(--multimap-shadow-soft);
  transition: color var(--multimap-transition), border-color var(--multimap-transition), box-shadow var(--multimap-transition), transform var(--multimap-transition);
  text-decoration: none;
  cursor: pointer;
}

.multimap__infocard-action:hover,
.multimap__infocard-action:focus-visible {
  color: var(--multimap-color-primary);
  border-color: rgba(43, 125, 233, 0.35);
  box-shadow: var(--multimap-shadow-medium);
  transform: translateY(-1px);
  outline: none;
}

.multimap__infocard-action svg,
.multimap__infocard-action span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: inherit;
  fill: currentColor;
}

.multimap__infocard-title {
  margin: 0;
  font-size: 1.2rem;
}

.multimap__infocard-close {
  position: absolute;
  top: 0.65rem;
  right: 0.65rem;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid rgba(43, 125, 233, 0.28);
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.7)) padding-box,
    linear-gradient(135deg, rgba(43, 125, 233, 0.18), rgba(43, 125, 233, 0.1)) border-box;
  color: var(--multimap-color-secondary);
  backdrop-filter: blur(10px);
  cursor: pointer;
  line-height: 1;
  transition: color var(--multimap-transition), background var(--multimap-transition), transform var(--multimap-transition), border-color var(--multimap-transition);
}

.multimap__infocard-close:hover {
  color: var(--multimap-color-primary);
  border-color: rgba(43, 125, 233, 0.4);
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.78)) padding-box,
    linear-gradient(135deg, rgba(43, 125, 233, 0.24), rgba(43, 125, 233, 0.14)) border-box;
  transform: translateY(-1px) scale(1.02);
}

.multimap__infocard-close:active {
  transform: translateY(0) scale(0.97);
  color: var(--multimap-color-primary);
  border-color: rgba(43, 125, 233, 0.48);
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.76)) padding-box,
    linear-gradient(135deg, rgba(43, 125, 233, 0.28), rgba(43, 125, 233, 0.18)) border-box;
}

.multimap__infocard-close:focus-visible {
  outline: 2px solid rgba(43, 125, 233, 0.35);
  outline-offset: 2px;
}

.multimap__infocard-close-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
    color: currentColor;
    pointer-events: none;
    position: absolute;
    top: 7px;
}

.multimap__infocard-modal {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--multimap-transition);
  z-index: 9999999999;
}

.multimap__infocard-modal[hidden] {
  display: none !important;
}

.multimap__infocard-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.multimap__infocard-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.7);
  backdrop-filter: blur(2px);
  z-index: 1;
}

.multimap__infocard-modal-content {
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: auto;
  block-size: auto;
  max-inline-size: min(96vw, 1080px);
  max-block-size: 90vh;
  padding: 0.5rem;
  box-sizing: border-box;
}

.multimap__infocard-modal-image {
  display: block;
  inline-size: auto;
  block-size: auto;
  max-inline-size: 100%;
  max-block-size: 88vh;
  object-fit: contain;
  border-radius: calc(var(--multimap-radius) / 1.4);
  box-shadow: var(--multimap-shadow-strong);
}

.multimap__infocard-modal-close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: none;
  background: rgba(15, 23, 42, 0.7);
  color: #fff;
  cursor: pointer;
  transition: transform var(--multimap-transition), box-shadow var(--multimap-transition), background-color var(--multimap-transition);
  z-index: 3;
}

.multimap__infocard-modal-close:hover,
.multimap__infocard-modal-close:focus-visible {
  background: rgba(26, 92, 191, 0.95);
  transform: translateY(-1px);
  outline: none;
  box-shadow: var(--multimap-shadow-medium);
}

.multimap__infocard-modal-close:focus-visible {
  outline: 2px solid var(--multimap-color-primary);
  outline-offset: 3px;
}

.multimap__infocard-modal-close-icon {
    position: absolute;
    top: 8px;
    font-size: 1.5rem;
    line-height: 1;
}

.multimap__infocard-body {
  display: flex;
  flex-direction: column;
  gap: var(--multimap-gap);
  padding: 0 0.25rem var(--multimap-gap) 0;
  min-height: 0;
}

.multimap__infocard-content {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.multimap__infocard-meta,
.multimap__infocard-address {
    font-size: 0.95rem;
    margin: 0;
    color: var(--multimap-color-muted);
    padding: 0;
    text-transform: capitalize;
}

.multimap__infocard-gallery {
  display: grid;
  gap: 0.75rem;
}

[data-infocard-gallery][hidden],
[data-infocard-gallery][hidden] > .multimap__infocard-gallery-main,
[data-infocard-gallery][hidden] > .multimap__infocard-gallery-thumbnails {
  display: none !important;
}

.multimap__infocard-gallery-main {
  position: relative;
  width: 100%;
  max-height: 550px;
  border-radius: var(--multimap-radius);
  overflow: hidden;
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  background: var(--multimap-color-highlight);
  /*box-shadow: var(--multimap-shadow-soft);*/
    margin: auto;
}

.multimap__infocard-gallery-image {
  display: block;
  /*width: 100%;*/
  /*height: 100%;*/
  object-fit: cover;
    margin: auto;
}

.multimap__infocard-gallery-thumbnails {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: 0.5rem;
  align-items: stretch;
}

.multimap__infocard-thumbnail {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  border-radius: calc(var(--multimap-radius) / 1.6);
  background: var(--multimap-color-bg);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--multimap-transition), box-shadow var(--multimap-transition), border-color var(--multimap-transition);
}

.multimap__infocard-thumbnail img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.multimap__infocard-thumbnail:hover,
.multimap__infocard-thumbnail:focus-visible {
  border-color: var(--multimap-color-primary);
  box-shadow: var(--multimap-shadow-soft);
  transform: translateY(-1px);
  outline: none;
}

.multimap__infocard-thumbnail.is-active {
  border-color: var(--multimap-color-primary);
  box-shadow: var(--multimap-shadow-medium);
}

.multimap__infocard-reviews {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: var(--multimap-font-weight-semibold);
  color: var(--multimap-color-secondary);
}

[data-infocard-reviews][hidden] {
  display: none !important;
}

[data-infocard-reviews][hidden]::before {
  content: none;
}

.multimap__infocard-reviews a {
  color: inherit;
  text-decoration: none;
}

.multimap__infocard-reviews a:focus-visible {
  outline: 2px solid var(--multimap-color-primary);
  outline-offset: 2px;
  border-radius: 4px;
}

.multimap__infocard-reviews::before {
  content: "★";
  color: #f4b400;
  font-size: 0.95rem;
  line-height: 1;
}

.multimap__infocard-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.multimap__infocard-extra {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.multimap__infocard-extra > * {
  margin: 0;
}

.multimap__hero {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: var(--multimap-gap);
  padding: calc(var(--multimap-gap) * 1.1);
  background: linear-gradient(135deg, rgba(43, 125, 233, 0.08), rgba(43, 125, 233, 0));
  border-radius: calc(var(--multimap-radius) * 1.1);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  box-shadow: var(--multimap-shadow-soft);
}

.multimap__hero-media {
  width: 88px;
  height: 88px;
  border-radius: calc(var(--multimap-radius) / 1.1);
  overflow: hidden;
  background: var(--multimap-color-highlight);
  box-shadow: var(--multimap-shadow-medium);
}

.multimap__hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.multimap__hero-content {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.multimap__hero-title {
  margin: 0;
  font-size: 1.1rem;
  color: var(--multimap-color-secondary);
}

.multimap__hero-subtitle {
  margin: 0;
  color: var(--multimap-color-muted);
  font-size: 0.95rem;
}

.multimap__infocard-tabs {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  background: var(--multimap-color-bg);
  border-radius: calc(var(--multimap-radius) / 1.05);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  padding: 0.25rem;
}

.multimap__infocard-tablist {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: center;
  gap: 0.2rem;
  border-bottom: var(--multimap-border-width) solid var(--multimap-color-border);
  padding: 0.25rem 0.25rem 0.35rem;
}

.multimap__infocard-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  width: 100%;
  min-width: 0;
  padding: 0.55rem 0.5rem;
  background: transparent;
  border: none;
  color: var(--multimap-color-secondary);
  font-weight: var(--multimap-font-weight-semibold);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  text-align: center;
  line-height: 1.2;
  word-break: break-word;
  transition: color var(--multimap-transition), border-color var(--multimap-transition);
}

.multimap__infocard-tab:hover,
.multimap__infocard-tab:focus-visible {
  color: var(--multimap-color-primary);
  border-color: var(--multimap-color-border);
  outline: none;
}

.multimap__infocard-tab.is-active {
  color: var(--multimap-color-primary);
  border-color: var(--multimap-color-primary);
}

.multimap__infocard-tab.is-active::after {
  display: none;
}

@media (max-width: 768px) {
  .multimap__infocard {
    top: auto;
    inset: auto 0 0 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-width: none;
    height: clamp(18rem, 85vh, 85vh);
    max-height: 85vh;
    transform: translateY(100%);
    box-shadow: 0 -12px 35px rgba(15, 23, 42, 0.12);
  }

  .multimap__infocard--active {
    transform: none;
    opacity: 1;
    pointer-events: auto;
  }
}

.multimap__infocard-panels {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.multimap__infocard-panel {
  background: #fff;
  border: none;
  border-radius: 0;
  /*box-shadow: var(--multimap-shadow-soft);*/
  padding: 15px;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-height: 100px;
  transition: box-shadow var(--multimap-transition), transform var(--multimap-transition);
}

.multimap__infocard-panel:not(.is-active) {
  display: none;
}

.multimap__infocard-panel.is-active {
  transform: translateY(-1px);
  /*box-shadow: var(--multimap-shadow-medium);*/
}

.multimap__infocard-overview {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.multimap__infocard-contact {
  margin: 0;
  padding: 0 !important;
  list-style: none !important;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  width: 100%;
  align-self: stretch;
  border-radius: calc(var(--multimap-radius) / 1.3);
  background: #f8f9fa;
  /*box-shadow: var(--multimap-shadow-soft);*/
}

.multimap__infocard-contact-item,
.multimap__infocard-contact-link {
  display: flex;
  grid-template-columns: 1.75rem 1fr;
  align-items: center;
  column-gap: 0.65rem;
  padding: 0.45rem 0.55rem;
  border-radius: calc(var(--multimap-radius) / 1.7);
  width: 100%;
  color: inherit;
  font-weight: var(--multimap-font-weight-regular, 400);
  transition: background-color var(--multimap-transition), color var(--multimap-transition);
}

.multimap__infocard-contact > li + li {
  border-top: 1px solid #e5e7eb;
}

.multimap__infocard-contact a {
  color: var(--multimap-color-secondary);
  text-decoration: none;
  transition: color var(--multimap-transition);
}

.multimap__infocard-contact-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.35rem;
  height: 1.35rem;
  min-width: 1.35rem;
  line-height: 1;
  justify-self: center;
}

.multimap__infocard-contact-icon svg {
  display: block;
  width: 1.05rem;
  height: 1.05rem;
  flex-shrink: 0;
  fill: currentColor;
}

.multimap__infocard-contact a:hover,
.multimap__infocard-contact a:focus-visible {
  background: #eceff1;
  outline: none;
}

.multimap__infocard-contact-item:hover,
.multimap__infocard-contact-item:focus-visible {
  background: #eceff1;
  outline: none;
}

.multimap__infocard-schedule,
.multimap__infocard-services {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.multimap__infocard-schedule-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.75rem;
  row-gap: 0.35rem;
  padding: 0.35rem 0.25rem;
}

.multimap__infocard-schedule-grid dt,
.multimap__infocard-schedule-grid dd {
  margin: 0;
  padding: 0.45rem 0;
  border-bottom: var(--multimap-border-width) solid var(--multimap-color-border);
}

.multimap__infocard-schedule-grid dt:last-of-type,
.multimap__infocard-schedule-grid dd:last-of-type {
  border-bottom: none;
}

.multimap__infocard-schedule-grid dt {
  font-weight: var(--multimap-font-weight-semibold);
  color: var(--multimap-color-secondary);
}

.multimap__infocard-schedule-grid dd {
  color: var(--multimap-color-muted);
}

.multimap__infocard-services-list {
  margin: 0;
  padding: 0 !important;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.multimap__infocard-services-list li {
  margin: 0;
  padding-left: 0;
  list-style: none;
  padding: 0.55rem 0.75rem;
  border-radius: calc(var(--multimap-radius) / 1.3);
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  background: var(--multimap-color-highlight);
  color: var(--multimap-color-secondary);
  /*box-shadow: var(--multimap-shadow-soft);*/
}

.multimap__infocard-social {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  padding-bottom: 1rem;
  background: var(--multimap-color-bg);
  border-radius: calc(var(--multimap-radius) / 1.05);
  /*border: var(--multimap-border-width) solid var(--multimap-color-border);*/
  /*box-shadow: var(--multimap-shadow-soft);*/
}

.multimap__infocard-social-link {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: var(--multimap-border-width) solid var(--multimap-color-border);
  background: var(--multimap-color-highlight);
  color: var(--multimap-color-secondary);
  /*box-shadow: var(--multimap-shadow-soft);*/
  transition: color var(--multimap-transition), border-color var(--multimap-transition), box-shadow var(--multimap-transition), transform var(--multimap-transition);
}

.multimap__infocard-social-link:hover,
.multimap__infocard-social-link:focus-visible {
  color: var(--multimap-color-primary);
  border-color: rgba(43, 125, 233, 0.35);
  /*box-shadow: var(--multimap-shadow-medium);*/
  transform: translateY(-1px);
  outline: none;
}

.multimap__infocard-social-link svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
