:root {
  --sidebar-width: 31rem;
  --layout-gap: 4rem;
  --wp--style--block-gap: clamp(3.5rem, 2.737rem + 1.404vw, 4rem);
}

@media (min-width: 1300px) {
  :root {
    --sidebar-width: 34rem;
    --layout-gap: 6rem;
  }
}
.operations {
  overflow: hidden;
}
.operations svg * {
  paint-order: fill;
}
.operations__map {
  margin-left: auto;
}
.operations__map .location-label {
  cursor: pointer;
  transition: fill 0.35s ease-in-out;
}
.operations__map .location-label.active .label path, .operations__map .location-label:hover .label path {
  fill: #B11226;
}
.operations__locations {
  margin-top: 3rem;
  padding: 20px;
}
.operations__locations .inner {
  position: relative;
}
.operations__locations .location-nav__controls {
  display: flex;
  gap: 10px;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 9;
}
.operations__locations .location-nav__controls .location-nav {
  content: "";
  display: block;
  width: 38px;
  height: 38px;
  text-indent: -999999rem;
  background-color: #B11226;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='44' height='45' fill='none'%3E%3Cpath stroke='%23B11226' d='M43.5 22C43.5 10.126 33.874.5 22 .5S.5 10.126.5 22 10.126 43.5 22 43.5 43.5 33.874 43.5 22Z'/%3E%3Cpath fill='%23372A66' d='M22.604 13.999a.75.75 0 0 1 1.06-.006l7.5 7.418a.752.752 0 0 1-.003 1.07l-7.5 7.35a.75.75 0 0 1-1.05-1.07l6.176-6.054H12.556a.75.75 0 1 1 0-1.5h16.268L22.61 15.06a.751.751 0 0 1-.007-1.06v-.001Z'/%3E%3C/svg%3E");
  mask-size: cover;
  transition: background-color 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
}
.operations__locations .location-nav__controls .location-nav.prev {
  transform: scaleX(-1);
}
.operations__locations .location-nav__controls .location-nav:hover {
  background-color: #44307C;
}
.operations__locations .location {
  padding: 0 0 70px 0;
  opacity: 0;
  transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  display: none;
  visibility: hidden;
  transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1) 0.1s, visibility 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
.operations__locations .location.active {
  display: block;
  visibility: visible;
  opacity: 1;
  z-index: 8;
}
.operations__locations .location .head {
  margin: 0 0 1.2rem 0;
}
.operations__locations .location h3 {
  font-size: var(--wp--preset--font-size--font-30);
  font-weight: 400;
  margin: 0;
  padding-right: 50px;
}
.operations__locations .location h3:after {
  content: "";
  display: block;
  width: 80px;
  height: 1px;
  margin: 0.7rem 0;
  background: #F0A540;
}
.operations__locations .location .meta {
  font-family: var(--wp--preset--font-family--secondary);
  font-size: var(--wp--preset--font-size--font-16);
  text-transform: uppercase;
  margin: 0;
  padding: 0;
  color: #372A66;
}
.operations__locations .location p:not(.meta) {
  font-size: 1.5rem;
  margin-bottom: 1ch;
}
.operations__locations .location p:not(.meta) + p {
  margin-top: 1ch !important;
}
.operations__locations .location p:not(.meta).is-style-footnote {
  font-size: 1.25rem;
}
.operations__locations .location ul {
  font-size: 1.5rem;
  margin: 0;
}
.operations__locations .location ul li {
  margin: 0 0 0.6rem 0;
  padding: 0 0 0 14px;
}
.operations__locations .location .btn {
  min-height: 34px;
  display: inline-flex;
  flex-wrap: wrap;
  align-content: center;
  font-size: var(--wp--preset--font-size--font-16);
  font-weight: 600;
  padding-left: 46px;
  color: #101010;
  position: relative;
  transition: color 0.35s ease-in-out;
  position: absolute;
  bottom: 0;
  left: 0;
}
.operations__locations .location .btn:before {
  content: "";
  display: block;
  width: 34px;
  height: 34px;
  background: #101010;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='44' height='45' fill='none'%3E%3Crect width='43' height='43' x='.5' y='.785' stroke='%23372A66' rx='21.5'/%3E%3Cpath stroke='%232E2A4D' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m23.249 30.672 8.517-8.35-8.517-8.424'/%3E%3Cpath stroke='%232E2A4D' stroke-linecap='round' stroke-width='1.5' d='M31.11 22.336H11.233'/%3E%3C/svg%3E");
  mask-size: contain;
  mask-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  transition: background 0.35s ease-in-out;
}
.operations__locations .location .btn:hover {
  color: #B11226;
}
.operations__locations .location .btn:hover:before {
  background: #44307C;
}
@media (max-width: 1023px) {
  .operations__locations {
    background: #F8F8F8;
    border-radius: 5px;
  }
}
@media (min-width: 1024px) {
  .operations {
    position: relative;
  }
  .operations__map {
    padding-left: 340px;
    position: relative;
    z-index: 5;
  }
  .operations__locations {
    width: 300px;
    margin: 0;
    padding: 0;
    border-radius: 0;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    z-index: 7;
  }
  .operations__locations .inner {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    padding: 20px;
    background: linear-gradient(120deg, #F8F8F8 35%, #E8E8E8 100%);
    border-radius: 5px;
  }
  .operations__locations .location-nav__controls {
    z-index: 9;
    top: 20px;
    right: 20px;
  }
  .operations__locations .location {
    padding-bottom: 70px;
  }
  .operations__locations .location .btn {
    bottom: 20px;
    left: 20px;
  }
}
@media (min-width: 1300px) {
  .operations {
    position: relative;
  }
  .operations__map {
    padding-left: 460px;
  }
  .operations__locations {
    width: 380px;
  }
  .operations__locations .inner {
    padding: 30px;
  }
  .operations__locations .location h3 {
    font-size: var(--wp--preset--font-size--font-36);
  }
  .operations__locations .location .meta {
    font-size: var(--wp--preset--font-size--font-21);
  }
  .operations__locations .location p:not(.meta) {
    font-size: var(--wp--preset--font-size--font-18);
  }
  .operations__locations .location .btn {
    bottom: 30px;
    lefT: 30px;
  }
}
@media (min-width: 1500px) {
  .operations {
    position: relative;
  }
  .operations__map {
    padding-left: 560px;
  }
  .operations__locations {
    width: 430px;
  }
  .operations__locations .inner {
    padding: 40px;
  }
  .operations__locations .location .head {
    margin-bottom: 2rem;
  }
  .operations__locations .location .btn {
    bottom: 40px;
    left: 40px;
  }
}

.legend-label .ll path {
  transition: fill 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
.white-circle {
  transition: stroke-width 0.55s cubic-bezier(0.4, 0, 0.2, 1), stroke-opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}

.outer-stroke,
.inner-stroke {
  transition: stroke-width 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}

.ep path,
.tgp path {
  transition: all 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}

.tgp path {
  stroke-width: 1px;
  stroke-opacity: 0;
}

.legend-on.cps .white-circle, .legend-on.gps .white-circle {
  stroke-width: 20px;
  stroke: #fff;
  stroke-opacity: 0.35;
}
.legend-on.gp .outer-stroke {
  stroke-width: 12px;
  stroke-opacity: 0.75;
}
.legend-on.gp .inner-stroke {
  stroke-width: 2px;
}
.legend-on.ep path {
  stroke-width: 1.2px;
}
.legend-on.tgp path {
  stroke-width: 4px;
  stroke-opacity: 0.25;
}
