/* Fotospots in Island: scoped Nordic magazine styling for article content only. */
.page-primary:has(.ifg-fotospots-island) > .page-intro,
.text-card:has(> .rich-text > .ifg-fotospots-island) > h2 {
  display: none;
}

.page-content-column:has(.ifg-fotospots-island),
.page-primary:has(.ifg-fotospots-island),
.page-main:has(.ifg-fotospots-island),
.text-card:has(> .rich-text > .ifg-fotospots-island),
.rich-text:has(> .ifg-fotospots-island) {
  width: 100%;
  max-width: none;
  min-width: 0;
}

.ifg-article.ifg-fotospots-island {
  --ifg-photo-ink: #1c2930;
  --ifg-photo-heading: #10232c;
  --ifg-photo-muted: #586872;
  --ifg-photo-blue: #416c7a;
  --ifg-photo-blue-dark: #234b59;
  --ifg-photo-slate: #71818a;
  --ifg-photo-stone: #93a0a2;
  --ifg-photo-sand: #d5c6ab;
  --ifg-photo-snow: #fffdf8;
  --ifg-photo-mist: #f4f7f7;
  --ifg-photo-ice: #e9f0f1;
  --ifg-photo-line: rgba(23, 39, 49, 0.14);
  --ifg-photo-line-strong: rgba(23, 39, 49, 0.23);
  --ifg-photo-shadow: 0 18px 40px rgba(16, 32, 42, 0.065);
  --ifg-content-width: 73ch;
  --ifg-wide-width: 100%;
  --ifg-section-gap: clamp(34px, 4.9vw, 58px);
  --ifg-inner-gap: 18px;

  width: 100%;
  max-width: 100%;
  color: var(--ifg-photo-ink);
  font-size: clamp(1rem, 1.04vw, 1.075rem);
  line-height: 1.78;
}

.ifg-fotospots-island,
.ifg-fotospots-island * {
  box-sizing: border-box;
}

.ifg-fotospots-island > header,
.ifg-fotospots-island > section,
.ifg-fotospots-island > footer {
  width: 100%;
  max-width: min(100%, var(--ifg-content-width));
}

.ifg-fotospots-island > header {
  max-width: 100%;
}

.ifg-fotospots-island .ifg-article-header {
  position: relative;
  gap: clamp(16px, 2.4vw, 25px);
  overflow: hidden;
  padding: clamp(30px, 5.2vw, 54px);
  border-color: rgba(65, 108, 122, 0.18);
  background:
    radial-gradient(circle at 96% 4%, rgba(65, 108, 122, 0.13), transparent 38%),
    linear-gradient(138deg, rgba(233, 240, 241, 0.96), rgba(255, 253, 248, 0.99) 59%, rgba(244, 247, 247, 0.98));
  box-shadow: var(--ifg-photo-shadow);
}

.ifg-fotospots-island .ifg-article-header::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 6px;
  background: linear-gradient(90deg, var(--ifg-photo-blue-dark), var(--ifg-photo-blue), var(--ifg-photo-slate), var(--ifg-photo-sand));
}

.ifg-fotospots-island .ifg-article-header::after {
  content: "";
  position: absolute;
  right: clamp(20px, 4vw, 38px);
  bottom: clamp(20px, 4vw, 37px);
  width: min(200px, 32%);
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(65, 108, 122, 0.48), rgba(213, 198, 171, 0.82));
}

.ifg-fotospots-island .ifg-kicker {
  position: relative;
  z-index: 1;
  width: fit-content;
  margin: 0;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(65, 108, 122, 0.38);
  color: var(--ifg-photo-blue-dark);
  font-size: 0.76rem;
  font-weight: 850;
  letter-spacing: 0.18em;
  line-height: 1.35;
  text-transform: uppercase;
}

.ifg-fotospots-island h1,
.ifg-fotospots-island h2,
.ifg-fotospots-island h3 {
  color: var(--ifg-photo-heading);
  letter-spacing: 0;
}

.ifg-fotospots-island h1 {
  position: relative;
  z-index: 1;
  max-width: 26ch;
  font-size: clamp(2.06rem, 4.15vw, 3.38rem);
  line-height: 1.07;
}

.ifg-fotospots-island .ifg-lead {
  position: relative;
  z-index: 1;
  max-width: 68ch;
  margin: 0;
  padding: clamp(18px, 3vw, 26px);
  border: 1px solid rgba(65, 108, 122, 0.16);
  border-left: 5px solid var(--ifg-photo-blue);
  border-radius: var(--ifg-radius);
  color: #344952;
  font-size: clamp(1.08rem, 1.4vw, 1.2rem);
  line-height: 1.76;
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(244, 247, 247, 0.96));
  box-shadow: 0 12px 26px rgba(16, 32, 42, 0.05);
}

.ifg-fotospots-island > section {
  gap: 18px;
  padding-top: clamp(29px, 4.2vw, 44px);
  border-top-color: var(--ifg-photo-line);
}

.ifg-fotospots-island h2 {
  display: grid;
  gap: 11px;
  max-width: 34ch;
  font-size: clamp(1.43rem, 2.3vw, 1.96rem);
  line-height: 1.18;
}

.ifg-fotospots-island h2::after {
  content: "";
  width: min(174px, 42%);
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--ifg-photo-blue), rgba(113, 129, 138, 0.52), rgba(213, 198, 171, 0.74), transparent);
}

.ifg-fotospots-island h3 {
  margin-top: clamp(9px, 1.45vw, 14px);
  color: var(--ifg-photo-blue-dark);
  font-size: clamp(1.06rem, 1.35vw, 1.2rem);
  font-weight: 800;
  line-height: 1.32;
}

.ifg-fotospots-island h3:not(:first-of-type) {
  margin-top: clamp(17px, 2.7vw, 25px);
  padding-top: clamp(17px, 2.7vw, 24px);
  border-top: 1px solid rgba(23, 39, 49, 0.09);
}

.ifg-fotospots-island p,
.ifg-fotospots-island li {
  min-width: 0;
  max-width: var(--ifg-content-width);
  color: var(--ifg-photo-muted);
  overflow-wrap: break-word;
}

.ifg-fotospots-island p + p {
  margin-top: 2px;
}

.ifg-fotospots-island > section:nth-of-type(2) {
  max-width: 100%;
}

.ifg-fotospots-island .ifg-fotospots-figure {
  display: grid;
  gap: 0;
  width: min(100%, 980px);
  margin: clamp(13px, 2.5vw, 22px) 0 0;
  overflow: hidden;
  border: 1px solid rgba(65, 108, 122, 0.19);
  border-radius: 12px;
  background: var(--ifg-photo-snow);
  box-shadow: 0 20px 42px rgba(16, 32, 42, 0.08);
}

.ifg-fotospots-island .ifg-fotospots-zoom {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  overflow: hidden;
  border: 0;
  cursor: zoom-in;
  background: #f4f1e9;
}

.ifg-fotospots-island .ifg-fotospots-zoom img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1150 / 642;
  object-fit: contain;
  transition: transform 280ms ease, filter 280ms ease;
}

.ifg-fotospots-island .ifg-fotospots-zoom__label {
  position: absolute;
  right: clamp(12px, 2.2vw, 18px);
  bottom: clamp(12px, 2.2vw, 18px);
  display: inline-flex;
  gap: 7px;
  align-items: center;
  padding: 9px 13px;
  border-radius: 999px;
  color: #fff;
  font-size: clamp(0.76rem, 1.1vw, 0.84rem);
  font-weight: 750;
  letter-spacing: 0.02em;
  line-height: 1.2;
  background: rgba(35, 75, 89, 0.87);
  box-shadow: 0 8px 20px rgba(13, 24, 29, 0.18);
  backdrop-filter: blur(7px);
}

.ifg-fotospots-island .ifg-fotospots-zoom__label::before {
  content: "+";
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 50%;
  font-size: 0.95rem;
  line-height: 1;
}

.ifg-fotospots-island .ifg-fotospots-zoom:hover img,
.ifg-fotospots-island .ifg-fotospots-zoom:focus-visible img {
  transform: scale(1.018);
  filter: saturate(1.04);
}

.ifg-fotospots-island .ifg-fotospots-zoom:focus-visible {
  outline: 3px solid rgba(65, 108, 122, 0.46);
  outline-offset: -3px;
}

.ifg-fotospots-island .ifg-fotospots-figure figcaption {
  margin: 0;
  padding: clamp(13px, 2.2vw, 17px) clamp(15px, 2.5vw, 20px);
  border-top: 1px solid rgba(65, 108, 122, 0.14);
  color: var(--ifg-photo-muted);
  font-size: clamp(0.88rem, 1.08vw, 0.94rem);
  line-height: 1.6;
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(244, 247, 247, 0.94));
}

.ifg-fotospots-island .ifg-fotospots-figure figcaption strong {
  color: var(--ifg-photo-blue-dark);
}

body.is-fotospots-modal-open {
  overflow: hidden;
}

.ifg-fotospots-island .ifg-fotospots-modal {
  width: min(1320px, calc(100vw - clamp(18px, 5vw, 64px)));
  max-width: none;
  max-height: calc(100dvh - clamp(18px, 5vw, 64px));
  margin: auto;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(65, 108, 122, 0.22);
  border-radius: clamp(12px, 1.5vw, 18px);
  background: var(--ifg-photo-snow);
  box-shadow: 0 36px 90px rgba(9, 19, 25, 0.45);
}

.ifg-fotospots-island .ifg-fotospots-modal::backdrop {
  background: rgba(10, 20, 26, 0.78);
  backdrop-filter: blur(7px);
}

.ifg-fotospots-island .ifg-fotospots-modal__bar {
  display: flex;
  gap: 18px;
  align-items: center;
  justify-content: space-between;
  padding: clamp(14px, 2vw, 20px) clamp(15px, 2.5vw, 24px);
  border-bottom: 1px solid rgba(65, 108, 122, 0.14);
  background: linear-gradient(120deg, var(--ifg-photo-mist), var(--ifg-photo-snow) 62%, #f6f1e7);
}

.ifg-fotospots-island .ifg-fotospots-modal__kicker {
  margin: 0 0 3px;
  color: var(--ifg-photo-blue);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  line-height: 1.3;
  text-transform: uppercase;
}

.ifg-fotospots-island .ifg-fotospots-modal__bar h2 {
  display: block;
  max-width: none;
  margin: 0;
  color: var(--ifg-photo-heading);
  font-size: clamp(1.03rem, 1.65vw, 1.32rem);
  line-height: 1.25;
}

.ifg-fotospots-island .ifg-fotospots-modal__bar h2::after {
  display: none;
}

.ifg-fotospots-island .ifg-fotospots-modal__close {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: clamp(40px, 4vw, 46px);
  height: clamp(40px, 4vw, 46px);
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  color: #fff;
  font-size: clamp(1.48rem, 2.3vw, 1.72rem);
  line-height: 1;
  background: var(--ifg-photo-blue-dark);
  transition: background-color 160ms ease, transform 160ms ease;
}

.ifg-fotospots-island .ifg-fotospots-modal__close:hover,
.ifg-fotospots-island .ifg-fotospots-modal__close:focus-visible {
  background: #173b48;
  transform: scale(1.04);
}

.ifg-fotospots-island .ifg-fotospots-modal__close:focus-visible {
  outline: 3px solid rgba(65, 108, 122, 0.36);
  outline-offset: 3px;
}

.ifg-fotospots-island .ifg-fotospots-modal__viewport {
  max-height: calc(100dvh - clamp(145px, 16vw, 174px));
  overflow: auto;
  background: #f3ede2;
  scrollbar-color: rgba(65, 108, 122, 0.65) rgba(233, 240, 241, 0.8);
  scrollbar-width: thin;
}

.ifg-fotospots-island .ifg-fotospots-modal__viewport img {
  display: block;
  width: max(100%, min(1150px, 135vw));
  max-width: none;
  height: auto;
}

.ifg-fotospots-island .ifg-fotospots-modal__hint {
  max-width: none;
  margin: 0;
  padding: 10px clamp(15px, 2.5vw, 24px) 12px;
  color: var(--ifg-photo-muted);
  font-size: 0.83rem;
  line-height: 1.4;
  background: var(--ifg-photo-snow);
}

/* Regional chapters retain a clear rhythm while leaving the supplied prose intact. */
.ifg-fotospots-island > section:nth-of-type(n + 3):nth-of-type(-n + 9) {
  position: relative;
  padding-left: clamp(17px, 2.4vw, 29px);
}

.ifg-fotospots-island > section:nth-of-type(n + 3):nth-of-type(-n + 9)::before {
  content: "";
  position: absolute;
  top: clamp(31px, 4.4vw, 47px);
  bottom: 1px;
  left: 0;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(65, 108, 122, 0.56), rgba(147, 160, 162, 0.18));
}

/* Safety-sensitive regions use restrained slate notes rather than warning colors. */
.ifg-fotospots-island > section:nth-of-type(5),
.ifg-fotospots-island > section:nth-of-type(6),
.ifg-fotospots-island > section:nth-of-type(8),
.ifg-fotospots-island > section:nth-of-type(11) {
  max-width: min(100%, 78ch);
  padding: clamp(24px, 3.9vw, 36px);
  border: 1px solid rgba(65, 108, 122, 0.16);
  border-left: 5px solid rgba(65, 108, 122, 0.74);
  border-radius: 9px;
  background: linear-gradient(135deg, rgba(233, 240, 241, 0.7), rgba(255, 253, 248, 0.98) 62%);
  box-shadow: 0 14px 30px rgba(16, 32, 42, 0.045);
}

.ifg-fotospots-island > section:nth-of-type(5)::before,
.ifg-fotospots-island > section:nth-of-type(6)::before,
.ifg-fotospots-island > section:nth-of-type(8)::before,
.ifg-fotospots-island > section:nth-of-type(11)::before {
  display: none;
}

.ifg-fotospots-island > section:nth-of-type(5) h2::after,
.ifg-fotospots-island > section:nth-of-type(6) h2::after,
.ifg-fotospots-island > section:nth-of-type(8) h2::after,
.ifg-fotospots-island > section:nth-of-type(11) h2::after {
  background: linear-gradient(90deg, var(--ifg-photo-slate), rgba(65, 108, 122, 0.4), transparent);
}

.ifg-fotospots-island a {
  color: var(--ifg-photo-blue-dark);
  text-decoration-color: rgba(65, 108, 122, 0.35);
}

.ifg-fotospots-island a:hover,
.ifg-fotospots-island a:focus-visible {
  color: #173b48;
  text-decoration-color: currentColor;
}

@media (max-width: 760px) {
  .ifg-article.ifg-fotospots-island {
    --ifg-section-gap: 30px;
    line-height: 1.72;
  }

  .ifg-fotospots-island .ifg-article-header,
  .ifg-fotospots-island > section:nth-of-type(5),
  .ifg-fotospots-island > section:nth-of-type(6),
  .ifg-fotospots-island > section:nth-of-type(8),
  .ifg-fotospots-island > section:nth-of-type(11) {
    padding: 20px 16px;
  }

  .ifg-fotospots-island .ifg-article-header::before {
    height: 5px;
  }

  .ifg-fotospots-island .ifg-article-header::after {
    display: none;
  }

  .ifg-fotospots-island h1,
  .ifg-fotospots-island h2 {
    max-width: none;
  }

  .ifg-fotospots-island h1 {
    font-size: clamp(1.86rem, 8.8vw, 2.3rem);
  }

  .ifg-fotospots-island .ifg-lead {
    max-width: 100%;
    padding: 16px 14px;
    border-left-width: 4px;
  }

  .ifg-fotospots-island .ifg-fotospots-modal {
    width: calc(100vw - 14px);
    max-height: calc(100dvh - 14px);
  }

  .ifg-fotospots-island .ifg-fotospots-modal__bar {
    padding: 12px 12px 12px 15px;
  }

  .ifg-fotospots-island .ifg-fotospots-modal__viewport {
    max-height: calc(100dvh - 131px);
  }

  .ifg-fotospots-island .ifg-fotospots-modal__viewport img {
    width: max(980px, 215vw);
  }

  .ifg-fotospots-island > section:nth-of-type(n + 3):nth-of-type(-n + 9) {
    padding-left: 14px;
  }

  .ifg-fotospots-island > section:nth-of-type(5),
  .ifg-fotospots-island > section:nth-of-type(6),
  .ifg-fotospots-island > section:nth-of-type(8) {
    padding-left: 16px;
  }

  .ifg-fotospots-island p,
  .ifg-fotospots-island h1,
  .ifg-fotospots-island h2,
  .ifg-fotospots-island h3 {
    max-width: 100%;
  }
}

@media (max-width: 520px) {
  .ifg-fotospots-island .ifg-article-header {
    padding: 19px 14px;
  }

  .ifg-fotospots-island h1 {
    font-size: clamp(1.72rem, 8.6vw, 2.06rem);
    line-height: 1.1;
  }

  .ifg-fotospots-island h2 {
    font-size: clamp(1.34rem, 7vw, 1.72rem);
  }
}
