.location {
  padding: var(--section-padding-y) 0 0;
  background-color: var(--bg-dark);
}

.location__grid {
  align-items: start;
}

.location__content {
  padding-left: 60px;
}

.location-slider {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  aspect-ratio: 4 / 3;
}

.location-slider__slide {
  position: absolute;
  inset: 0;
  display: none;
}

.location-slider__slide.is-active {
  display: block;
}

.location-slider__slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.location__title {
  margin-bottom: 32px;
  font-family: var(--font-heading);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-primary);
}

.location__subtitle {
  margin-bottom: 20px;
  font-family: var(--font-body);
  font-size: 32px;
  font-weight: var(--font-body-weight);
  line-height: 1.25;
  color: var(--text-primary);
}

.location__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 40px;
}

.location__list li {
  display: flex;
  gap: 12px;
  align-items: center;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: var(--font-body-weight);
  line-height: 1.5;
  color: var(--text-primary);
}

.location__list-icon {
  flex-shrink: 0;
  font-size: 22px;
  color: var(--accent);
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.location-slider__nav {
  display: flex;
  gap: 12px;
}

.location-slider__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  font-size: 18px;
  line-height: 1;
  color: var(--text-primary);
  background-color: rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-sm);
  transition: background-color var(--transition), color var(--transition);
}

.location-slider__btn:hover {
  background-color: var(--accent);
  color: var(--text-primary);
}

.location-slider__btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.location-slider__btn:disabled:hover {
  background-color: rgba(255, 255, 255, 0.12);
}

/* Подсекция 3.2: Карта */
.location-map {
  margin-top: 80px;
  padding: 0 var(--container-padding) var(--section-padding-y);
}

.location-map__canvas {
  width: 100%;
  height: 600px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background-color: #f3f2ee;
  touch-action: none;
}

.location-map__canvas [class*="ymaps-2"][class*="-ground-pane"] {
  filter: saturate(0.85) contrast(0.95);
}

.location-map__marker {
  position: relative;
  transform: translate(-50%, -100%);
  pointer-events: none;
}

.location-map__marker--main {
  position: relative;
  width: 56px;
  height: 64px;
  pointer-events: auto;
}

.location-map__pin {
  display: block;
  width: 56px;
  height: 64px;
  filter: drop-shadow(0 4px 12px rgba(239, 132, 0, 0.4));
}

.location-map__logo {
  position: absolute;
  left: calc(100% + 10px);
  top: 12px;
  display: block;
  width: 148px;
  height: 36px;
  pointer-events: none;
  background-color: var(--map-pin-main);
  -webkit-mask-image: url('../../assets/images/logo-oblaka.png');
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: left center;
  -webkit-mask-mode: luminance;
  mask-image: url('../../assets/images/logo-oblaka.png');
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: left center;
  mask-mode: luminance;
}

.location-map__marker--poi {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
  pointer-events: auto;
  cursor: default;
  transform: translate(0, 0);
}

.location-map__marker--poi .material-symbols-outlined {
  font-size: 20px;
  color: #ffffff;
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 20;
}

.location-map__marker--kindergarten {
  background-color: var(--map-poi-kindergarten);
}

.location-map__marker--school {
  background-color: var(--map-poi-school);
}

.location-map__marker--shop {
  background-color: var(--map-poi-shop);
}

.location-map__marker--mall {
  background-color: var(--map-poi-mall-bg);
}
