.fluk-regions-page {
  max-width: 1180px;
}

.fluk-real-map-section {
  margin: 1.8rem 0 2.6rem;
}

.fluk-real-map-section .section-heading {
  max-width: 820px;
  margin-bottom: 1.15rem;
}

.fluk-real-map-section .section-heading h2 {
  margin: 0 0 .55rem;
  color: #003f31;
  font-size: clamp(1.75rem, 3vw, 2.35rem);
  line-height: 1.08;
  letter-spacing: -.03em;
}

.fluk-real-map-section .section-heading p {
  margin: 0;
  color: #3a584d;
  font-size: 1.02rem;
  line-height: 1.62;
}

.fluk-real-map-card {
  overflow: hidden;
  width: min(100%, 1220px);
  margin: 0 auto;
  border: 1px solid rgba(0,104,73,.16);
  border-radius: 32px;
  background: linear-gradient(135deg, #f7fbf8 0%, #eef8f2 100%);
  box-shadow: 0 22px 54px rgba(0,64,45,.11);
}

.fluk-real-map-stage {
  position: relative;
}

.fluk-real-map-stage img {
  display: block;
  width: 100%;
  height: auto;
}

.fluk-real-map-label {
  position: absolute;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  min-height: 38px;
  padding: .46rem .8rem;
  border: 1px solid rgba(0,104,73,.20);
  border-radius: 999px;
  background: rgba(255,255,255,.96);
  color: #003f31;
  font-size: .82rem;
  font-weight: 900;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(0,64,45,.14);
  transform: translate(-50%, -50%);
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease, border-color .16s ease;
}

.fluk-real-map-label:hover,
.fluk-real-map-label:focus {
  background: #006849;
  border-color: #006849;
  color: #fff;
  text-decoration: none;
  transform: translate(-50%, -50%) scale(1.05);
  box-shadow:
    0 0 0 4px rgba(255,255,255,.90),
    0 0 0 8px rgba(0,104,73,.20),
    0 16px 30px rgba(0,64,45,.22);
}

.fluk-real-map-label:focus-visible {
  outline: 3px solid #003f31;
  outline-offset: 4px;
}

.map-scotland         { left: 45.5%; top: 22.0%; min-width: 110px; }
.map-northern-ireland { left: 24.5%; top: 42.5%; min-width: 146px; }
.map-north-east       { left: 58.8%; top: 34.0%; }
.map-north-west       { left: 48.3%; top: 42.0%; }
.map-yorkshire        { left: 59.2%; top: 48.5%; min-width: 132px; }
.map-west-midlands    { left: 49.5%; top: 59.5%; min-width: 136px; }
.map-east-midlands    { left: 60.2%; top: 59.5%; min-width: 136px; }
.map-wales            { left: 39.5%; top: 66.5%; }
.map-east-of-england  { left: 67.2%; top: 64.8%; min-width: 142px; }
.map-london           { left: 62.4%; top: 74.2%; min-width: 92px; }
.map-south-east       { left: 66.5%; top: 81.0%; min-width: 116px; }
.map-south-west       { left: 42.5%; top: 83.2%; min-width: 116px; }

.fluk-real-map-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  padding: .9rem 1.1rem;
  border-top: 1px solid rgba(0,104,73,.12);
  background: rgba(255,255,255,.78);
  color: #345348;
  font-size: .92rem;
  font-weight: 800;
}

.fluk-real-map-footer a {
  color: #006849;
  text-decoration: none;
  font-weight: 900;
}

.fluk-real-map-footer a:hover,
.fluk-real-map-footer a:focus {
  text-decoration: underline;
}

@media (max-width: 900px) {
  .fluk-real-map-label {
    min-width: 82px;
    min-height: 33px;
    padding: .35rem .56rem;
    font-size: .70rem;
  }

  .map-northern-ireland,
  .map-yorkshire,
  .map-west-midlands,
  .map-east-midlands,
  .map-east-of-england {
    min-width: 104px;
  }
}

@media (max-width: 680px) {
  .fluk-real-map-card {
    border-radius: 22px;
  }

  .fluk-real-map-label {
    min-width: 68px;
    min-height: 29px;
    padding: .28rem .44rem;
    font-size: .62rem;
  }

  .map-northern-ireland,
  .map-yorkshire,
  .map-west-midlands,
  .map-east-midlands,
  .map-east-of-england {
    min-width: 88px;
  }

  .fluk-real-map-footer {
    font-size: .84rem;
  }
}
