@charset "UTF-8";
:root {
  --white: #ffffff;
  --blue-700: #00698e;
  --blue-500: #5292af;
  --blue-300: #7eb7cc;
  --sky: #a1edff;
  --aqua: #4bbdc1;
  --mint: #4bc1ab;
  --green-300: #adcc7e;
  --green-500: #86af52;
  --green-700: #568e00;
  --yellow-200: #ffe2a8;
  --yellow-400: #fbd37f;
  --orange: #ef6600;
  --brown: #993e00;
  --ink: #00698e;
  --muted: #77838a;
  --page-max: 120rem;
  --container: 55rem;
}

* {
  box-sizing: border-box;
}

html {
  font-size: 100%;
  scroll-behavior: smooth;
}

html[data-font-scale=small] {
  font-size: 93.75%;
}

html[data-font-scale=large] {
  font-size: 112.5%;
}

html[lang=en] .overview-component__item h2,
html[lang=en] .overview-component__item strong,
html[lang=en-US] .overview-component__item h2,
html[lang=en-US] .overview-component__item strong {
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
}
html[lang=en] .overview-component__item--text p,
html[lang=en-US] .overview-component__item--text p {
  text-align: center;
}
html[lang=en] .benefit-card:nth-child(2) .benefit-card__body h2,
html[lang=en-US] .benefit-card:nth-child(2) .benefit-card__body h2 {
  white-space: normal;
}

html[lang=zh-hans] body {
  font-family: "Inter", "Noto Sans SC", "Microsoft YaHei", "PingFang SC", sans-serif;
}

body {
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: "Inter", "Noto Sans TC", "Microsoft JhengHei", "PingFang TC", sans-serif;
  line-height: 1.45;
}

a {
  color: inherit;
}

img {
  max-width: 100%;
}

.site-shell {
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
  overflow: clip;
  background: var(--white);
}

.site-container {
  width: min(100% - 2rem, var(--container));
  margin-inline: auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 9999;
  background: var(--white);
  box-shadow: 0 0.22rem 1.2rem rgba(0, 0, 0, 0.1);
  transition: padding-bottom 140ms ease;
}

.navbar {
  min-height: 8.9rem;
  max-height: 9.875rem;
  padding: 0;
  width: 100%;
}

.header-frame {
  display: flex;
  align-items: center;
  width: min(100% - 11.5rem, 104rem);
  min-height: 8.9rem;
  margin-inline: auto;
  padding: 0;
}

.brand-mark {
  width: 11.2rem;
  margin: 0;
  padding: 0;
}

.brand-mark img {
  display: block;
}

.header-menu {
  position: static;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 1.2rem;
  margin-left: auto;
}

.hero-background-overlay {
  position: absolute;
  bottom: 0rem;
  z-index: 125;
  width: 100%;
  height: 100vh;
  max-width: none;
  display: block;
  pointer-events: none;
  transform: translateY(25%) scale(1.2);
}

.background-title-overlay {
  position: relative;
  z-index: 130;
  margin: clamp(3.5rem, 4.8vw, 5.5rem) 0 clamp(5.75rem, 6.8vw, 7.75rem);
  color: var(--blue-700);
  font-size: clamp(2rem, 3.1vw, 2.55rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
}

.background-section {
  position: relative;
  z-index: auto;
  width: 100%;
  margin-top: -3rem;
  padding: 0 0 clamp(3.4rem, 4.8vw, 4.8rem);
  overflow: visible;
  background: var(--white);
}

.background-card {
  z-index: 126;
  width: min(45rem, calc(100% - 2rem));
  height: auto;
  min-height: max-content;
  padding: 2.35rem 2.25rem;
  border-radius: 0.28rem;
  overflow: visible;
  color: var(--blue-700);
  background: linear-gradient(120.79deg, #D0F2FF 2.1%, #CBEFFF 98.33%);
}

.background-card p {
  margin: 0;
  overflow: visible;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0;
}

.overview-section {
  --overview-bg-bottom: clamp(-30rem, -18vw, -21rem);
  --overview-machine-bg-offset: clamp(15rem, 17vw, 23rem);
  position: relative;
  z-index: 4;
  width: 100%;
  margin: 0 auto;
  padding: 0rem 1.5rem 24rem;
  overflow: visible;
  background: linear-gradient(to bottom, var(--white) 0 48%, #f5fdff 56%, #d2f7ff 72%, #bff1fb 100%);
}

.overview-section::before {
  content: "";
  display: block;
  position: absolute;
  top: clamp(-8.5rem, -8vw, -4rem);
  right: 0;
  left: 0;
  z-index: 11;
  height: clamp(18rem, 30vw, 32rem);
  background: linear-gradient(to bottom, rgba(223, 250, 255, 0.34) 0%, rgba(244, 253, 255, 0.72) 30%, rgba(255, 255, 255, 0.9) 55%, rgba(255, 255, 255, 0.56) 78%, rgba(255, 255, 255, 0) 100%);
  filter: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 14%, #000 82%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 14%, #000 82%, transparent 100%);
  pointer-events: none;
}

.overview-title {
  margin: 0 0 2.6rem;
  color: var(--blue-700);
  font-size: 2.55rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
}

.section-bg-image {
  position: absolute;
  right: 0;
  bottom: -10rem;
  left: 0;
  z-index: 0;
  display: block;
  width: 100%;
  min-width: 92rem;
  max-width: none;
  height: auto;
  margin: 0 auto;
  pointer-events: none;
}

.overview-section .section-bg-image {
  top: auto;
  bottom: var(--overview-bg-bottom);
  z-index: 10;
  width: 100%;
  min-width: 100%;
  height: auto;
  max-height: none;
  margin: 0;
  object-fit: contain;
  object-position: center bottom;
}

.overview-section .overview-bg--mobile {
  display: none;
}

.overview-content {
  z-index: 12;
  display: grid;
  justify-items: center;
  width: min(100%, 86rem);
}

.overview-map-frame {
  width: min(74rem, 100%);
  margin: 0;
}

.overview-map-image {
  height: auto;
  border-radius: 1.45rem;
  outline: 0;
  transition: filter 160ms ease, transform 160ms ease;
}

.overview-map-image:hover,
.overview-map-image:focus-visible {
  filter: saturate(1.03) brightness(1.01);
}

.overview-component {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: min(40rem, 100%);
  margin-top: 3rem;
  color: var(--blue-700);
}

.overview-component__item {
  position: relative;
  display: grid;
  min-height: 9.6rem;
  align-content: center;
  justify-items: center;
  padding: 1.05rem 1.65rem 1.25rem;
}

.overview-component__item:nth-child(odd)::before {
  content: "";
  position: absolute;
  top: 1.05rem;
  right: 0;
  bottom: 1.05rem;
  width: 0.1rem;
  background: var(--blue-700);
}

.overview-component__item:nth-child(-n+2)::after {
  content: "";
  position: absolute;
  right: 1.85rem;
  bottom: 0;
  left: 1.85rem;
  height: 0.1rem;
  background: var(--blue-700);
}

@media (min-width: 992px) {
  .overview-component__item:nth-child(1)::before {
    top: 2rem;
    bottom: clamp(2rem, 5vw, 2rem);
  }

  .overview-component__item:nth-child(3)::before {
    top: clamp(2.5rem, 5vw, 2.5rem);
    bottom: 0.6rem;
  }

  .overview-component__item:nth-child(1)::after {
    right: clamp(2rem, 5.8vw, 2rem);
    left: 0;
  }

  .overview-component__item:nth-child(2)::after {
    right: 0;
    left: clamp(2rem, 5.8vw, 2rem);
  }

  .overview-component__item:nth-child(n+3) {
    padding-top: 2rem;
  }
}
.overview-component__icon {
  width: 3.6rem;
  height: 3.6rem;
  margin-bottom: 0.65rem;
  object-fit: contain;
}

.overview-component__item h2,
.overview-component__item strong {
  margin: 0;
  color: var(--blue-700);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: 0;
}

.overview-component__item p {
  margin: 0;
  color: var(--blue-700);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0;
}

.overview-component__item--text p {
  max-height: 0;
  margin-top: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 350ms ease, margin-top 350ms ease, opacity 350ms ease;
}

.overview-component__item--text:hover p,
.overview-component__item--text:focus-visible p,
.overview-component__item--text:focus-within p {
  max-height: 12rem;
  margin-top: 0.42rem;
  opacity: 1;
}

.overview-component__item:nth-child(-n+2)::after {
  transition: bottom 350ms ease;
}

.overview-component:has(.overview-component__item--text:hover) .overview-component__item:nth-child(-n+2)::after,
.overview-component:has(.overview-component__item--text:focus-visible) .overview-component__item:nth-child(-n+2)::after,
.overview-component:has(.overview-component__item--text:focus-within) .overview-component__item:nth-child(-n+2)::after {
  bottom: -1rem;
}

.overview-component__item--stat strong {
  font-size: 2.15rem;
}

.overview-component__item--stat p:first-of-type {
  margin-top: 0.18rem;
}

.overview-machine {
  position: absolute;
  bottom: calc(var(--overview-bg-bottom) + var(--overview-machine-bg-offset));
  z-index: 11;
  display: block;
  width: clamp(8rem, 20vw, 22rem);
  max-width: none;
  pointer-events: none;
}

.overview-machine--left {
  left: clamp(2rem, 13.5%, 16rem);
}

.overview-machine--right {
  right: clamp(2rem, 13.5%, 16rem);
}

.overview-wave {
  position: absolute;
  bottom: -5%;
  left: 0;
  z-index: 30;
  width: 100%;
  height: auto;
  pointer-events: none;
}

.overview-wave img {
  display: block;
  width: 100%;
  max-width: none;
  z-index: 10;
}

.project-benefit .section-bg-image {
  top: 0;
  bottom: 0;
  z-index: 10;
  width: 100vw;
  min-width: 100%;
  max-height: 150%;
  margin: 0;
  object-fit: cover;
  object-position: center bottom;
}

/* ============================================
   PROJECT BENEFIT SECTION
   ============================================ */
.project-benefit {
  position: relative;
  z-index: auto;
  width: 100%;
  max-width: none;
  margin: 4rem 0 0;
  overflow: visible;
  padding: 10rem 0 5rem;
  background: linear-gradient(to bottom, #f2fff0 0%, #e6ffcc 100%);
}

/* White semi-transparent mask over the background photo */
.project-benefit::before {
  content: "";
  position: absolute;
  top: -12%;
  right: 0;
  bottom: -28%;
  left: 0;
  z-index: 1;
  background: rgba(255, 255, 255, 0.7);
  pointer-events: none;
}

/* Override section-bg-image — fills entire project-benefit section */
.project-benefit .section-bg-image {
  position: absolute;
  top: -12%;
  left: 0;
  right: 0;
  bottom: auto;
  width: 100%;
  height: 140%;
  min-width: 0;
  max-width: none;
  object-fit: cover;
  object-position: center top;
  transform: none;
  z-index: 0;
}

.benefit-content {
  z-index: auto;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  overflow: visible;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
}

.benefit-title {
  z-index: 3;
  padding-top: clamp(12rem, 15vw, 18rem);
  margin: 0 0 3rem;
  color: var(--blue-700);
  font-size: clamp(1.5rem, 10vw, 3.7rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 0;
  word-break: break-word;
  overflow-wrap: break-word;
  white-space: normal;
  max-width: 100vw;
  min-width: 0;
  box-sizing: border-box;
  padding-left: 2vw;
  padding-right: 2vw;
  text-align: center;
  overflow: visible;
  background: none;
  position: relative;
  min-height: 2.5em;
}

/* --- Benefit Cards --- */
.benefit-cards {
  display: flex;
  flex-direction: column;
  gap: 3.5rem;
  z-index: 3;
  width: 100%;
  position: relative;
}

.benefit-card {
  position: relative;
  display: block;
  width: min(1682px, 100%);
  height: 338px;
  aspect-ratio: auto;
  padding-block: 0;
  background: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: none;
  box-shadow: none;
  transition: none;
  overflow: visible;
}

/* Background image element — keeps the asset's natural aspect ratio */
.benefit-card__bg--desktop {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  pointer-events: none;
  z-index: 0;
}

/* Mobile bg hidden on desktop */
.benefit-card__bg--mobile {
  display: none;
}

.benefit-card:hover {
  transform: none;
  box-shadow: none;
}

/* Odd cards: white side of the asset sticks to the left */
.benefit-card:nth-child(odd) {
  margin-right: auto;
  padding: 0;
}

/* Odd desktop card needs the asset flipped so the white end starts at left */
.benefit-card:nth-child(odd) .benefit-card__bg--desktop {
  transform: scaleX(-1);
}

/* Even cards: white side sticks to the right */
.benefit-card:nth-child(even) {
  background: none;
  margin-left: auto;
  padding: 0;
}

.benefit-card:nth-child(even) .benefit-card__bg--desktop {
  transform: none;
}

.benefit-card__icon {
  position: absolute;
  top: 50%;
  left: 25%;
  transform: translate(-50%, -50%);
  z-index: 1;
  flex-shrink: 0;
  width: 18.5rem;
  height: 18.5rem;
}

.benefit-card:nth-child(even) .benefit-card__icon {
  left: 76%;
}

.benefit-card__icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.benefit-card__body {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  width: 28%;
  min-width: 0;
  text-align: center;
}

.benefit-card:nth-child(even) .benefit-card__body {
  left: 50%;
}

.benefit-card__body,
.benefit-card:nth-child(2) .benefit-card__body {
  left: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 30%;
  text-align: center;
}

.benefit-card__body h2,
.benefit-card__body p {
  text-align: center;
}

.benefit-card__body h2 {
  margin: 0 0 0.4rem;
  color: var(--blue-700);
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.22;
  letter-spacing: 0;
}

@media (min-width: 1440.98px) {
  .benefit-card:nth-child(2) .benefit-card__body h2 {
    white-space: nowrap;
  }
}
/* Paragraph hidden by default; revealed on card hover */
.benefit-card__body p {
  display: block;
  margin: 0 auto;
  color: var(--blue-700);
  width: 60%;
  font-size: 1.3rem;
  line-height: 1.6;
  font-weight: 500;
  max-height: 0;
  overflow: visible;
  opacity: 0;
  transition: max-height 350ms ease, opacity 300ms ease;
}

.benefit-card:hover .benefit-card__body p,
.benefit-card:focus-within .benefit-card__body p {
  max-height: 8rem;
  opacity: 1;
}

.benefit-card__photos {
  position: absolute;
  top: 50%;
  left: 60%;
  right: auto;
  transform: translateY(-50%);
  z-index: 1;
  flex-shrink: 0;
  width: 23%;
  height: 88%;
}

.benefit-card:nth-child(even) .benefit-card__photos {
  left: 0%;
  right: auto;
  width: 23%;
}

.benefit-card__circle {
  position: absolute;
  width: 55%;
  height: auto;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  /* box-shadow: 0 2px 10px rgba(0, 100, 50, 0.12); */
}

.benefit-card__circle:nth-child(1) {
  left: 5%;
  bottom: 6%;
  width: 42%;
  height: auto;
}

.benefit-card__circle:nth-child(2) {
  top: 0%;
  right: 2%;
  width: 55%;
  height: auto;
}

.benefit-card:nth-child(3) .benefit-card__photos {
  left: 60%;
  right: auto;
  width: 25%;
  height: 88%;
}

.benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
  left: 75%;
  top: 5%;
  width: 40%;
  height: auto;
}

.benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
  left: 110%;
  bottom: 5%;
  top: auto;
  right: auto;
  width: 40%;
  height: auto;
}

.benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
  right: -65%;
  top: -15%;
  width: 40%;
  height: auto;
}

.benefit-card:nth-child(1) .benefit-card__photos {
  left: 80%;
  width: 24%;
  height: 100%;
  overflow: visible;
}

.benefit-card:nth-child(1) .benefit-card__circle:nth-child(1) {
  left: -30%;
  right: auto;
  bottom: 15%;
  width: 55%;
  z-index: 10;
}

.benefit-card:nth-child(1) .benefit-card__circle:nth-child(2) {
  top: -10%;
  right: 5%;
  width: 80%;
  z-index: 5;
}

.benefit-card:nth-child(2) .benefit-card__photos {
  left: 0%;
  width: 24%;
  height: 100%;
  overflow: visible;
}

.benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
  left: -10%;
  bottom: 5%;
  width: 55%;
}

.benefit-card:nth-child(2) .benefit-card__circle:nth-child(2) {
  top: -10%;
  left: 40%;
  width: 70%;
}

/* Benefit: small mobile adjustments */
@media (max-width: 400px) {
  .benefit-title {
    font-size: 1.1rem;
    padding-top: 5rem;
    margin-bottom: 1.2rem;
  }

  .benefit-content {
    padding-left: 0.2rem;
    padding-right: 0.2rem;
  }
}
@media (max-width: 600px) {
  .benefit-title {
    font-size: clamp(1.2rem, 7vw, 2rem);
    padding-top: 5rem;
    margin-bottom: 2rem;
  }

  .benefit-content {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
}
/* Responsive: Benefit Card Circles for Tablet/Mobile */
@media (max-width: 900px) {
  .benefit-card:first-child .benefit-card__circle:nth-child(1) {
    left: 0;
    z-index: 2;
    /* Stick to left edge and overlap */
    transform: translateX(-8%);
  }

  .benefit-card:first-child .benefit-card__circle:nth-child(2) {
    z-index: 1;
    left: 30%;
    right: auto;
  }
}
/* --- Photo Album Slider --- */
.benefit-album {
  position: relative;
  z-index: 260;
  width: 100%;
  margin-top: 10rem;
}

.benefit-album__bar {
  display: block;
  width: 100%;
  height: auto;
}

.benefit-album__viewport {
  position: relative;
  width: 100%;
  padding: 0 4.5rem 2.75rem;
  border-radius: 0.75rem;
}

.benefit-album__track {
  align-items: center;
  transition-timing-function: linear;
}

.benefit-album .swiper-slide {
  width: auto;
  height: auto;
}

.benefit-album__item {
  position: relative;
  z-index: 260;
  display: block;
  flex-shrink: 0;
  width: clamp(20rem, 26vw, 30rem);
  height: clamp(12rem, 15vw, 17rem);
  overflow: hidden;
  cursor: pointer;
  text-decoration: none;
  transition: transform 100ms ease, box-shadow 100ms ease;
  border: 8px solid transparent;
  background: linear-gradient(#fff, #fff) padding-box, linear-gradient(90deg, #ADCC7E 0%, #86AF52 100%) border-box;
}

.benefit-album__item:hover {
  transform: scale(1.04);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}

.benefit-album__item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}

.benefit-album__pagination {
  bottom: 0 !important;
}

.benefit-album__pagination .swiper-pagination-bullet {
  width: 0.55rem;
  height: 0.55rem;
  background: var(--blue-500);
  opacity: 0.34;
}

.benefit-album__pagination .swiper-pagination-bullet-active {
  background: var(--blue-700);
  opacity: 1;
}

.is-album-modal-open {
  overflow: hidden;
}

.album-modal[hidden] {
  display: none;
}

.album-modal {
  position: fixed;
  inset: 0;
  z-index: 11000;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-items: stretch;
  justify-items: center;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  width: 100vw;
  height: 100vh;
  min-height: 100dvh;
  padding: clamp(1rem, 4vw, 2.5rem);
  box-sizing: border-box;
}

.album-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  padding: 0;
  background: rgba(0, 44, 59, 0.62);
  cursor: pointer;
}

.album-modal__close {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  justify-self: end;
  align-self: start;
  width: clamp(2.5rem, 5vw, 3.5rem);
  height: clamp(2.5rem, 5vw, 3.5rem);
  border: 0;
  border-radius: 50%;
  padding: 0;
  color: var(--white);
  background: rgba(0, 44, 59, 0.72);
  box-shadow: 0 0.2rem 0.8rem rgba(0, 0, 0, 0.22);
  cursor: pointer;
  font-size: clamp(1.65rem, 3vw, 2.45rem);
  line-height: 1;
  transition: color 160ms ease, background 160ms ease;
}

.album-modal__close:hover,
.album-modal__close:focus-visible {
  color: var(--orange);
  background: var(--white);
  outline: 0;
}

.album-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(96rem, 100%);
  max-height: 100%;
  margin: auto;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.album-modal__image-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 0;
  min-width: 0;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: zoom-out;
}

.album-modal__image-button img {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

/* ============================================
   DOCUMENTS SECTION
   ============================================ */
.documents {
  position: relative;
  z-index: 160;
  width: 100%;
  margin-top: clamp(-10rem, -10vw, -3rem);
  background: transparent;
}

.documents__wave {
  position: relative;
  z-index: 100;
  width: 100%;
  margin-bottom: -1px;
  line-height: 0;
}

.documents__body {
  --documents-bg-color: #FFE5AF;
  --documents-bg-top-height: clamp(18rem, 42vw, 44rem);
  --documents-bg-bottom-height: clamp(14rem, 32vw, 36rem);
  --documents-bg-overlap: 1.5rem;
  position: relative;
  z-index: 180;
  width: 100%;
  overflow: hidden;
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
  padding: clamp(4.5rem, 7vw, 7rem) 1.5rem clamp(14rem, 20vw, 20rem);
  background: linear-gradient(var(--documents-bg-color), var(--documents-bg-color)) center calc(var(--documents-bg-top-height) - var(--documents-bg-overlap))/100% calc(100% - var(--documents-bg-top-height) - var(--documents-bg-bottom-height) + var(--documents-bg-overlap) + var(--documents-bg-overlap)) no-repeat;
}

.documents__orange-bg {
  position: absolute;
  left: 50%;
  width: 120%;
  max-width: none;
  object-fit: cover;
  pointer-events: none;
  transform: translateX(-50%);
  user-select: none;
}

.documents__orange-bg--top {
  top: 0;
  height: var(--documents-bg-top-height);
  object-position: center top;
}

.documents__orange-bg--bottom {
  bottom: 0;
  height: var(--documents-bg-bottom-height);
  object-position: center bottom;
}

.documents__decor {
  position: absolute;
  max-width: none;
  pointer-events: none;
  user-select: none;
}

.documents__decor--clip {
  top: clamp(20rem, 20vw, 20rem);
  left: 50%;
  z-index: 1;
  width: clamp(25rem, 68vw, 70rem);
  opacity: 0.34;
  transform: translateX(-60%) translateY(20%);
}

.documents__decor--orange {
  top: clamp(1rem, 1vw, 0.5rem);
  right: clamp(-3rem, -7vw, -2rem);
  z-index: 5;
  width: clamp(4rem, 10vw, 10rem);
  transform: translateY(-150%);
}

.documents__decor--white {
  top: clamp(22rem, 34vw, 42rem);
  left: clamp(2.5rem, 12vw, 17rem);
  z-index: 2;
  width: clamp(7rem, 11vw, 12.5rem);
}

.documents__content {
  position: relative;
  z-index: 3;
  display: grid;
  gap: clamp(2.3rem, 4.3vw, 2.55rem);
  width: min(100%, 37.25rem);
  margin: clamp(11rem, 17vw, 16rem) auto 0;
}

html[lang=en] .documents__content,
html[lang=en-US] .documents__content {
  width: min(100%, 42rem);
}

@media (min-width: 992px) {
  .documents__content {
    margin-top: clamp(14rem, 20vw, 19rem);
  }

  .documents__body > .documents__decor--white {
    display: none;
  }

  .documents__content > .documents__decor--orange {
    position: relative;
    top: auto;
    right: auto;
    justify-self: end;
    width: clamp(6.6rem, 8vw, 7.6rem);
    margin-right: clamp(-3rem, -3vw, -2rem);
    margin-bottom: clamp(-4.45rem, -6vw, -3.2rem);
    transform: rotate(0deg);
  }

  .document-file--dc .document-file__decor--white,
.document-file--gazette:has(#documents-dc-title) .document-file__decor--white,
.document-file--gazette .document-file__decor--orange,
.document-file--comp .document-file__decor--white {
    display: block;
  }

  .document-file--gazette:has(#documents-dc-title) .document-file__decor--white,
.document-file--dc .document-file__decor--white {
    top: 95%;
    bottom: auto;
    left: clamp(-6.5rem, -7.6vw, -4.75rem);
    width: clamp(4.4rem, 6vw, 5.8rem);
    transform: translateY(-50%) rotate(0deg);
  }

  .document-file--gazette .document-file__decor--orange {
    top: auto;
    right: clamp(-8rem, -8vw, -6.25rem);
    bottom: clamp(-4.65rem, -5.4vw, -3.55rem);
    width: clamp(5.8rem, 7vw, 6.9rem);
    transform: rotate(5deg);
  }

  .document-file--comp .document-file__decor--white {
    top: auto;
    bottom: clamp(-5.25rem, -6vw, -4rem);
    left: clamp(-6.5rem, -7.6vw, -4.75rem);
    width: clamp(4.4rem, 6vw, 5.8rem);
    transform: rotate(-10deg);
  }
}
@media (min-width: 768px) and (max-width: 1024.98px) {
  .documents__body > .documents__decor--white {
    display: none;
  }

  .document-file__decor {
    display: none;
  }

  .document-file--gazette:has(#documents-dc-title) .document-file__decor--white {
    display: block;
    top: 88%;
    bottom: auto;
    left: clamp(-7.5rem, -10vw, -5.75rem);
    z-index: 1;
    width: clamp(4.5rem, 7vw, 5.6rem);
    transform: translateY(-50%) rotate(0deg);
  }
}
@media (min-width: 768px) and (max-width: 912px) {
  .documents__content {
    padding-top: clamp(5.75rem, 11vw, 7rem);
  }

  .documents__body > .documents__decor--white {
    display: block;
    top: 5rem;
    right: clamp(10rem, 17vw, 11rem);
    left: auto;
    z-index: 4;
    width: clamp(4rem, 20vw, 8rem);
    margin-top: 4rem;
    transform: rotate(0deg);
  }

  .documents__content > .documents__decor--orange {
    position: absolute;
    top: -10rem;
    right: clamp(-3rem, 17vw, -5rem);
    justify-self: auto;
    z-index: 4;
    width: clamp(6.4rem, 23vw, 8.6rem);
    margin: 4rem 0 0;
    transform: none;
  }

  .document-file--gazette:has(#documents-dc-title) .document-file__decor--white {
    display: none;
  }

  .legal-page__title {
    font-size: 1.8rem;
  }

  .legal-page__content p {
    font-size: 1.5rem;
  }

  .legal-page__content {
    width: 100%;
    color: #00698E;
  }

  html[lang=en] .legal-page__title,
html[lang=en-US] .legal-page__title {
    font-size: 2rem;
  }
  html[lang=en] .legal-page__content p,
html[lang=en-US] .legal-page__content p {
    font-size: 1.5rem;
  }
}
.document-file {
  position: relative;
  isolation: isolate;
  width: 100%;
  color: var(--brown);
  --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H48.5 C50.1 0 50.9 1.1 51.7 2.8 L55.9 16.5 C56.3 17.8 57.8 18.2 59.8 18.2 H98 C99.2 18.2 100 19.4 100 20.9 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
  --document-content-width: min(100%, 31.5rem);
  --document-inline-padding: clamp(1rem, 3vw, 2.5rem);
  --document-title-top: clamp(1.45rem, 3vw, 1.7rem);
  --document-rule-top: clamp(6rem, 8.3vw, 6.55rem);
  --document-title-clearance: clamp(0.45rem, 1vw, 0.7rem);
  --document-list-top: calc(var(--document-rule-top) + clamp(1rem, 2vw, 1.35rem));
}

.document-file::before,
.document-file::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  -webkit-mask-image: var(--document-file-mask);
  mask-image: var(--document-file-mask);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.document-file::before {
  z-index: 1;
  background: var(--white);
}

.document-file::after {
  z-index: 0;
  background: var(--orange);
  transform: translate(clamp(0.22rem, 0.8vw, 0.34rem), clamp(0.24rem, 0.85vw, 0.38rem));
}

.document-file__decor {
  position: absolute;
  display: none;
  max-width: none;
  pointer-events: none;
  user-select: none;
}

.document-file__decor--orange {
  top: clamp(-7.6rem, -10vw, -5.2rem);
  right: clamp(-5.7rem, -8vw, -2.6rem);
  z-index: 3;
  width: clamp(6.8rem, 10vw, 9.2rem);
}

.document-file__decor--white {
  bottom: clamp(-5.9rem, -8vw, -3.6rem);
  left: clamp(-7.4rem, -8vw, -3.4rem);
  z-index: 0;
  width: clamp(5rem, 7vw, 7.2rem);
  transform: rotate(-18deg);
}

.document-file--dc {
  min-height: clamp(15.4rem, 31vw, 15.95rem);
}

.document-file--gazette {
  min-height: clamp(25rem, 59vw, 30.8rem);
  --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H60.8 C62.4 0 63.2 0.6 64 1.45 L68.2 8.55 C68.6 9.45 70.1 9.45 72.1 9.45 H98 C99.2 9.45 100 10.1 100 10.85 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
  --document-content-width: calc(100% - var(--document-inline-padding));
}
.document-file--gazette .document-file__link {
  width: 100%;
  cursor: pointer;
}
.document-file--gazette .document-content-wrapper {
  display: none;
}
.document-file--gazette .document-content-wrapper.is-open {
  display: block;
}
.document-file--gazette .document-content-wrapper .document-file__item {
  border: 0;
}
.document-file--gazette .document-content-wrapper .document-file__item::after {
  border: 0;
}
.document-file--gazette .document-content-wrapper .document-file__summary {
  padding: clamp(0.45rem, 1.65vw, 0.65rem) 0;
}
.document-file--gazette .document-content-wrapper .document-file__summary > span {
  font-size: clamp(0.95rem, 2.25vw, 1rem);
}
.document-file--gazette .document-content-wrapper .document-file__detail {
  font-size: clamp(0.85rem, 2.25vw, 0.95rem);
}
.document-file--gazette .document-content-wrapper .document-file__detail p {
  margin-bottom: 0;
  font-weight: 500;
}
.document-file--gazette .document-content-wrapper .document-file__detail a {
  font-weight: 500;
}

.document-file--gazette:has(#documents-dc-title) {
  min-height: clamp(18.75rem, 38vw, 21.75rem);
}

.document-file--gazette.document-file--tab-medium {
  --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H70 C71.6 0 72.4 0.65 73.2 1.6 L77.4 9.35 C77.8 10.3 79.3 10.3 81.3 10.3 H98 C99.2 10.3 100 11 100 11.85 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
}

.document-file--gazette.document-file--tab-long {
  --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H78 C79.6 0 80.4 0.7 81.2 1.75 L85.4 10.3 C85.8 11.35 87.3 11.35 89.3 11.35 H98 C99.2 11.35 100 12.1 100 13.05 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
}

.document-file--gazette.document-file--tab-xlong {
  --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H86 C87.6 0 88.4 0.75 89.2 1.9 L93.1 10.9 C93.5 12 94.9 12 96.5 12 H98 C99.2 12 100 12.8 100 13.8 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
}

.document-file--comp {
  min-height: clamp(17.3rem, 35vw, 18rem);
  --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H60.8 C62.4 0 63.2 1.1 64 2.8 L68.2 16.5 C68.6 17.8 70.1 18.2 72.1 18.2 H98 C99.2 18.2 100 19.4 100 20.9 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
}

.document-file__inner {
  position: relative;
  z-index: 2;
  min-height: inherit;
  min-width: 0;
  padding: 0 var(--document-inline-padding) clamp(1.85rem, 4.2vw, 2.35rem);
}

.document-file__inner::before {
  content: "";
  position: absolute;
  top: var(--document-rule-top);
  left: var(--document-inline-padding);
  width: var(--document-content-width);
  height: 0.15rem;
  background: var(--brown);
}

#document-file--gazette .document-file__inner::before {
  content: "";
  position: absolute;
  top: 5.5rem;
  left: var(--document-inline-padding);
  width: var(--document-content-width);
  height: 0.15rem;
  background: var(--brown);
}

#document-1 .document-file__inner::before {
  content: "";
  position: absolute;
  top: 8rem;
  left: var(--document-inline-padding);
  width: var(--document-content-width);
  height: 0.15rem;
  background: var(--brown);
}

.document-file--gazette .document-file__inner {
  display: flex;
  flex-direction: column;
  padding-top: var(--document-title-top);
}

.document-file--gazette .document-file__inner::before {
  display: none;
}

.document-file--gazette .document-file__title {
  position: static;
  display: block;
  width: var(--document-content-width);
  max-width: 100%;
  height: auto;
  margin: 0;
}

.document-file--gazette .document-file__title::after {
  content: "";
  display: block;
  width: 100%;
  height: 0.15rem;
  margin-top: clamp(1.05rem, 2.2vw, 1.35rem);
  background: var(--brown);
}

.document-file--gazette .document-file__list {
  width: var(--document-content-width);
  max-width: 100%;
}

.document-file--gazette .document-file__list {
  padding-top: clamp(0.85rem, 2vw, 1.15rem);
}

.document-file--gazette .document-file__item::after {
  width: 100%;
}

.document-file__title {
  position: absolute;
  top: var(--document-title-top);
  left: var(--document-inline-padding);
  display: flex;
  align-items: flex-start;
  width: var(--document-content-width);
  height: calc(var(--document-rule-top) - var(--document-title-top) - var(--document-title-clearance));
  box-sizing: border-box;
  color: var(--brown);
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: 0;
  overflow-wrap: anywhere;
  text-wrap: wrap;
  hyphens: auto;
}

#documents-dc-title {
  width: 100%;
}

html[lang=en] .document-file__title,
html[lang=en-US] .document-file__title {
  font-size: clamp(1.55rem, 3.3vw, 2.25rem);
}
html[lang=en] .document-file--comp .document-file__title,
html[lang=en-US] .document-file--comp .document-file__title {
  white-space: pre-line;
}
html[lang=en] .document-file--comp,
html[lang=en-US] .document-file--comp {
  --document-rule-top: clamp(7.35rem, 9.7vw, 7.65rem);
}

.contact-section {
  position: relative;
  z-index: 30;
  overflow: hidden;
  background: #7eb7cc;
  box-shadow: 0 clamp(-14rem, -14vw, -6rem) 0 #7eb7cc;
}

.contact-section__body {
  display: grid;
  place-items: center;
  min-height: clamp(25rem, 38vw, 34rem);
  margin-top: -1px;
  padding: clamp(10rem, 13vw, 13rem) 1.5rem clamp(4.8rem, 7vw, 6.8rem);
  background: #7eb7cc;
  color: var(--white);
}

.contact-section__inner {
  width: min(100%, 42rem);
}

.contact-section__title {
  margin: 0;
  color: var(--white);
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: 0;
}

.contact-section__rule {
  width: 100%;
  height: 0.18rem;
  margin: clamp(1.5rem, 3vw, 2.35rem) 0 clamp(1.7rem, 3vw, 2.35rem);
  background: var(--white);
}

.contact-section__details {
  display: grid;
  gap: clamp(1.25rem, 2.4vw, 1.75rem);
  margin: 0;
  font-style: normal;
  font-weight: 700;
}

.contact-section__item {
  display: grid;
  grid-template-columns: 3.3rem 1fr;
  align-items: center;
  gap: 1rem;
  width: fit-content;
  color: var(--white);
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0;
  text-decoration: none;
}

.contact-section__item:hover {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.contact-section__icon {
  width: clamp(2.3rem, 3.2vw, 3rem);
  height: clamp(2.3rem, 3.2vw, 3rem);
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.site-footer {
  display: grid;
  place-items: center;
  min-height: clamp(4.2rem, 6vw, 5.6rem);
  padding: 1rem 1.5rem;
  background: var(--white);
}

.legal-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  color: var(--ink);
  font-size: clamp(1rem, 1.4vw, 1.22rem);
  font-weight: 700;
  line-height: 1.4;
}

.legal-links a {
  color: inherit;
  text-decoration: none;
}

.legal-links a:hover {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

.legal-links a + a::before {
  content: "|";
  display: inline-block;
  margin: 0 clamp(0.9rem, 1.6vw, 1.4rem);
  color: currentColor;
}

.document-file__list {
  display: grid;
  gap: 0;
  width: var(--document-content-width);
  padding-top: var(--document-list-top);
}

.document-file__item {
  border-bottom: 0.05rem solid var(--brown);
  color: var(--brown);
}

@media (min-width: 992px) {
  .document-file__item {
    position: relative;
    border-bottom: 0;
  }

  .document-file__item::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    border-bottom: 0.05rem solid var(--brown);
    pointer-events: none;
  }
}
.document-file__item--static {
  padding: clamp(0.9rem, 1.75vw, 1.1rem) 0 clamp(0.85rem, 1.65vw, 1rem);
}

.document-file__summary {
  display: flex;
  align-items: center;
  gap: 0.46rem;
  padding: clamp(0.75rem, 1.65vw, 1rem) 0;
  color: var(--brown);
  font-size: clamp(1.08rem, 2.25vw, 1.28rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0;
  cursor: pointer;
  list-style: none;
}

.document-file__summary::-webkit-details-marker {
  display: none;
}

.document-file__summary::before {
  content: "";
  flex: 0 0 auto;
  width: 0;
  height: 0;
  margin-top: 0;
  border-top: 0.28rem solid transparent;
  border-bottom: 0.28rem solid transparent;
  border-left: 0.42rem solid currentColor;
  transition: transform 120ms ease;
}

.document-file__item[open] > .document-file__summary::before {
  transform: rotate(90deg);
}

.document-file__detail {
  padding: 0 0 clamp(0.85rem, 1.65vw, 1rem) 1.2rem;
}

.document-file__date {
  margin: 0 0 0.25rem;
  color: var(--brown);
  font-size: clamp(0.92rem, 1.8vw, 1.02rem);
  font-weight: 700;
  line-height: 1.25;
  text-decoration: underline;
}

.document-file__link {
  display: inline-block;
  max-width: 100%;
  color: var(--brown);
  font-size: clamp(0.98rem, 1.95vw, 1.2rem);
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0;
  text-decoration: underline;
  text-underline-offset: 0.16em;
  overflow-wrap: anywhere;
}

.document-file__link--strong {
  font-weight: 700;
  text-decoration: none;
}

.document-file__coins {
  position: absolute;
  right: clamp(1.45rem, 4.5vw, 2rem);
  bottom: clamp(1.45rem, 4.2vw, 1.8rem);
  z-index: 2;
  width: clamp(3.6rem, 9.2vw, 5.45rem);
  height: clamp(2rem, 5vw, 3.05rem);
  pointer-events: none;
}

.document-file__coin {
  position: absolute;
  display: block;
  width: 3.1rem;
  height: 3.1rem;
  border-radius: 50%;
  border: 0.22rem solid #f5a400;
  background: #ffd84c;
  box-shadow: 0 0.22rem 0 #a45700;
}

.document-file__coin::after {
  content: "$";
  position: absolute;
  inset: 0.32rem;
  display: grid;
  place-items: center;
  border: 0.12rem solid rgba(245, 164, 0, 0.75);
  border-radius: 50%;
  color: #f4a500;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1;
}

.document-file__coin--back {
  left: 0;
  bottom: 0.1rem;
  transform: scale(0.82) rotate(-13deg);
}

.document-file__coin--front {
  right: 0;
  bottom: 0;
  transform: rotate(15deg);
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 3.95rem;
}

.menu-item {
  position: static;
}

.nav-link {
  position: relative;
  padding: 0 0 0.35rem;
  color: var(--blue-700);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0;
}

.nav-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 0.14rem;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 160ms ease;
}

.nav-link:hover::after,
.nav-link:focus::after,
.nav-link.is-active::after,
.menu-item--has-panel:hover > .nav-link::after,
.menu-item--has-panel:focus-within > .nav-link::after {
  transform: scaleX(1);
}

.utility-tools {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  color: var(--blue-700);
  font-size: 0.95rem;
  font-weight: 700;
}

.utility-link,
.icon-button {
  border: 0;
  padding: 0;
  color: inherit;
  background: transparent;
  font: inherit;
  text-decoration: none;
}

.utility-link[aria-pressed=true],
.utility-link.current {
  color: var(--blue-700);
}

.icon-button {
  display: inline-grid;
  width: 1.65rem;
  height: 1.65rem;
  place-items: center;
}

.icon-button img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.menu-panel {
  position: absolute;
  left: 0;
  right: 0;
  top: 8.9rem;
  display: grid;
  grid-template-columns: 23rem 1fr;
  align-items: start;
  min-height: 13.7rem;
  padding: 1.55rem 11.2rem 2rem 10.2rem;
  border-top: 0.1rem solid #cfcfcf;
  border-inline: 0.08rem solid #e2e2e2;
  background: var(--white);
  box-shadow: inset 0 0.2rem 0.45rem rgba(0, 0, 0, 0.14);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-0.15rem);
  transition: opacity 140ms ease, transform 140ms ease, visibility 140ms ease;
}

@media (min-width: 992px) {
  .site-header.is-menu-open,
.site-header:has(.menu-item--has-panel:hover),
.site-header:has(.menu-item--has-panel:focus-within) {
    padding-bottom: 0;
  }

  .project-benefit {
    padding-top: 11rem;
  }
}
.menu-item--has-panel.is-hovered .menu-panel,
.menu-item--has-panel:hover .menu-panel,
.menu-item--has-panel:focus-within .menu-panel {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto;
  transform: translateY(0);
}

.menu-panel__image {
  width: 15.5rem;
  justify-self: center;
  opacity: 0.95;
}

.menu-panel__links {
  display: flex;
  flex-wrap: wrap;
  gap: 6rem;
  padding-left: 2rem;
  padding-top: 0.2rem;
}

.menu-panel__links a {
  position: relative;
  color: #8d8d8d;
  font-size: 1.05rem;
  font-weight: 700;
  text-decoration: none;
}

.menu-panel__links a::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-right: 0.55rem;
  border-top: 0.33rem solid transparent;
  border-bottom: 0.33rem solid transparent;
  border-left: 0.42rem solid currentColor;
  transform: translateY(0.02rem);
}

.menu-panel__links a:hover,
.menu-panel__links a:focus {
  color: var(--blue-700);
}

.mobile-actions {
  align-items: center;
  gap: 0.8rem;
  margin-left: auto;
}

.navbar-toggler {
  display: inline-grid;
  width: 1.7rem;
  height: 1.45rem;
  gap: 0.27rem;
  padding: 0;
  border: 0;
  border-radius: 0;
}

.navbar-toggler:focus {
  box-shadow: none;
}

.navbar-toggler span {
  display: block;
  width: 100%;
  height: 0.18rem;
  border-radius: 999px;
  background: var(--blue-700);
}

.hero-section {
  --hero-title-overlay-bottom: 25vh;
  position: relative;
  z-index: auto;
  width: 100%;
  height: 1369px;
  margin: 0 auto;
  overflow: visible;
  /* background: var(--blue-300); */
}

.hero-section::after {
  content: "";
  display: none;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1.6rem;
  z-index: 81;
  height: clamp(8rem, 15vw, 18rem);
  background: linear-gradient(to bottom, rgba(222, 250, 255, 0) 0%, rgba(231, 251, 255, 0.18) 32%, rgba(255, 255, 255, 0.72) 78%, rgba(255, 255, 255, 0.92) 100%);
  backdrop-filter: blur(0.5rem);
  -webkit-backdrop-filter: blur(0.5rem);
  filter: blur(0.08rem);
  -webkit-mask-image: linear-gradient(to top, #000 0%, rgba(0, 0, 0, 0.72) 64%, transparent 100%);
  mask-image: linear-gradient(to top, #000 0%, rgba(0, 0, 0, 0.72) 64%, transparent 100%);
  pointer-events: none;
}

.hero-image {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 50%;
  filter: saturate(0.82) brightness(1.08) contrast(0.92);
}

.hero-logo {
  position: absolute;
  left: 5%;
  top: 35%;
  z-index: 4;
  width: 25rem;
  filter: drop-shadow(0 0.2rem 0.18rem rgba(0, 0, 0, 0.32));
}

.announcement-widget {
  position: absolute;
  top: 2.1rem;
  right: 2.6rem;
  z-index: 5;
  width: 14rem;
  pointer-events: none;
}

.announcement-trigger,
.announcement-card__close {
  border: 0;
  padding: 0;
  font: inherit;
  cursor: pointer;
}

.announcement-trigger {
  position: absolute;
  top: 0;
  right: -1.5rem;
  z-index: 2;
  display: block;
  width: 4rem;
  height: 4rem;
  border-radius: 999px;
  background: transparent;
  pointer-events: auto;
}

.announcement-trigger img {
  display: block;
  width: 100%;
  height: 100%;
}

.announcement-widget.is-open .announcement-trigger {
  top: 1.05rem;
  left: -1.35rem;
  right: auto;
  width: 2.75rem;
  height: 2.75rem;
}

.announcement-card {
  width: 80%;
  margin-top: 1.35rem;
  padding-bottom: 1rem;
  border-radius: 0 1rem 0 0;
  color: var(--orange);
  background: var(--white);
  box-shadow: 0 0.45rem 1.1rem rgba(0, 0, 0, 0.08);
  overflow: hidden;
  pointer-events: auto;
}

.announcement-card[hidden] {
  display: none !important;
}

.announcement-card__header {
  display: flex;
  align-items: center;
  min-height: 2.65rem;
  padding: 0.45rem 0.65rem 0.45rem 3.2rem;
  border-radius: 0 1rem 0 0;
  color: var(--white);
  background: #fbb815;
}

.announcement-card__header strong {
  flex: 1;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
}

.announcement-card__close {
  display: inline-grid;
  width: 1.25rem;
  height: 1.25rem;
  place-items: center;
  border-radius: 999px;
  color: #df7f3f;
  background: var(--white);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
}

.announcement-card p,
.announcement-card small,
.announcement-card a {
  display: block;
  margin: 0;
  padding-inline: 1.05rem;
  text-align: center;
}

.announcement-card p {
  padding-top: 0.78rem;
  color: var(--orange);
  font-size: 0.72rem;
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 0.12rem;
}

.announcement-card small {
  padding-top: 0.5rem;
  color: var(--orange);
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1.55;
}

.announcement-card a {
  width: fit-content;
  margin: 0.65rem auto 0;
  padding: 0.34rem 0.9rem;
  border-radius: 999px;
  color: var(--white);
  background: var(--orange);
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.announcement-card:not([hidden]) a::after {
  content: "↗";
  margin-left: 0.2rem;
}

/* Social Menu */
.social-menu {
  position: fixed;
  right: max(1rem, calc((100vw - 1920px) / 2 + 1rem));
  top: 70%;
  z-index: 10000;
  display: flex;
  align-items: center;
  transition: right 0.3s ease;
}

.social-menu.is-open {
  right: max(3rem, calc((100vw - 1920px) / 2 + 3rem));
}

.social-menu__toggle {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 5rem;
  height: 5rem;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  transition: transform 0.3s ease;
}

.social-menu__toggle img {
  position: absolute;
  top: 50%;
  left: 50%;
  object-fit: contain;
  transform: translate(-50%, -50%) rotate(0deg);
  will-change: transform;
}

.social-menu__icon-closed {
  width: 30%;
  height: 30%;
}

.social-menu__icon-open {
  display: none;
}

.social-menu.is-open .social-menu__icon-closed {
  transform: translate(-50%, -50%) rotate(180deg);
}

.social-menu__toggle.is-animating-open .social-menu__icon-closed {
  animation: social-toggle-open 320ms ease forwards;
}

.social-menu__toggle.is-animating-close .social-menu__icon-closed {
  animation: social-toggle-close 320ms ease forwards;
}

@keyframes social-toggle-open {
  from {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(180deg);
  }
}
@keyframes social-toggle-close {
  from {
    transform: translate(-50%, -50%) rotate(180deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(0deg);
  }
}
.social-menu__panel {
  position: absolute;
  top: 50%;
  left: 80%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 0.75rem 0.5rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.social-menu__panel:not([hidden]) {
  opacity: 1;
  visibility: visible;
}

.social-menu__link {
  display: grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: var(--white);
  color: var(--ink);
  text-decoration: none;
  box-shadow: 0 0.15rem 0.5rem rgba(0, 0, 0, 0.12);
  transition: transform 0.2s ease;
}

.social-menu__link:hover {
  transform: scale(1.1);
}

.social-menu__link svg {
  width: 1.3rem;
  height: 1.3rem;
}

@media (max-width: 1024.98px) {
  .social-menu {
    top: 50%;
    transform: translateY(-50%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .social-menu__toggle.is-animating-open .social-menu__icon-closed,
.social-menu__toggle.is-animating-close .social-menu__icon-closed {
    animation: none;
  }
}
@media (max-width: 991.98px) {
  .site-shell {
    overflow-x: clip;
    overflow-y: visible;
  }

  .hero-section {
    height: 520px;
    z-index: auto;
    overflow: visible;
  }

  .hero-section::after {
    bottom: -2.5rem;
    height: clamp(7rem, 18vw, 11rem);
    background: linear-gradient(to bottom, rgba(222, 250, 255, 0) 0%, rgba(231, 251, 255, 0.28) 34%, rgba(255, 255, 255, 0.78) 78%, rgba(255, 255, 255, 0.94) 100%);
    backdrop-filter: blur(0.58rem);
    -webkit-backdrop-filter: blur(0.58rem);
    -webkit-mask-image: linear-gradient(to top, #000 0%, rgba(0, 0, 0, 0.72) 58%, transparent 100%);
    mask-image: linear-gradient(to top, #000 0%, rgba(0, 0, 0, 0.72) 58%, transparent 100%);
  }

  .hero-background-overlay {
    top: auto;
    right: auto;
    left: 50%;
    bottom: 0;
    width: 100%;
    height: auto;
    object-fit: contain;
    object-position: center bottom;
    transform: translateX(-50%) translateY(40%) scale(1.2);
    transform-origin: center bottom;
  }

  .site-header {
    overflow: visible;
    background: transparent;
    box-shadow: none;
  }

  .site-header.is-mobile-menu-open,
.site-header:has(.header-menu.collapsing),
.site-header:has(.header-menu.show) {
    padding-bottom: 0;
  }

  .site-header.is-mobile-project-open,
.site-header:has(.menu-item:nth-of-type(2):hover),
.site-header:has(.menu-item:nth-of-type(2):focus-within),
.site-header:has(.menu-item:nth-of-type(2).is-open) {
    padding-bottom: 0;
  }

  .site-header.is-mobile-info-open,
.site-header:has(.menu-item:nth-of-type(3):hover),
.site-header:has(.menu-item:nth-of-type(3):focus-within),
.site-header:has(.menu-item:nth-of-type(3).is-open) {
    padding-bottom: 0;
  }

  .navbar {
    width: 100%;
    min-height: 5.7rem;
  }

  .header-frame {
    position: relative;
    width: 100%;
    min-height: 5.7rem;
    padding-inline: clamp(1rem, 4vw, 2rem);
    background: var(--white);
  }

  .brand-mark {
    width: 5.2rem;
  }

  .mobile-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
  }

  .mobile-actions .icon-button {
    width: 1.2rem;
    height: 1.2rem;
  }

  .navbar-toggler {
    width: 1.48rem;
    height: 1.13rem;
    gap: 0.22rem;
  }

  .navbar-toggler span {
    height: 0.15rem;
  }

  .header-menu {
    position: absolute;
    top: calc(100% - 1.5rem);
    right: 0;
    z-index: 5;
    width: 8.8rem;
    margin-left: 0;
    gap: 0;
    align-items: stretch;
    border: 0.08rem solid #ebebeb;
    background: var(--white);
    box-shadow: none;
    overflow: visible;
  }

  .header-menu.collapse:not(.show) {
    display: none;
  }

  .header-menu.collapse.show,
.header-menu.collapsing {
    display: flex;
    flex-direction: column;
    height: auto !important;
    overflow: visible;
    transition: none;
  }

  .utility-tools {
    justify-content: center;
    width: 100%;
    min-height: 2.35rem;
    padding: 0.5rem 0.44rem;
    border-bottom: 0.08rem solid #ebebeb;
    gap: 0.38rem;
    font-size: 0.76rem;
    line-height: 1;
  }

  .utility-link--font .fs-4 {
    font-size: 0.62rem !important;
  }

  .utility-link--font .fs-2 {
    font-size: 0.82rem !important;
  }

  .main-nav {
    display: block;
    width: 100%;
  }

  .menu-item {
    border-bottom: 0.08rem solid #ebebeb;
  }

  .menu-item:last-child {
    border-bottom: 0;
  }

  .nav-link {
    display: block;
    min-height: 2.23rem;
    padding: 0.58rem 0.58rem 0.52rem;
    text-align: center;
    font-size: 0.8rem;
    line-height: 1.25;
  }

  .nav-link::after {
    left: 50%;
    right: auto;
    bottom: 0.36rem;
    width: 3.35rem;
    height: 0.1rem;
    transform: translateX(-50%) scaleX(0);
  }

  .nav-link:hover::after,
.nav-link:focus::after,
.menu-item--has-panel:hover > .nav-link::after,
.menu-item--has-panel:focus-within > .nav-link::after,
.menu-item.is-open > .nav-link::after {
    background: var(--blue-700);
    transform: translateX(-50%) scaleX(1);
  }

  .menu-item--has-panel:hover > .nav-link,
.menu-item--has-panel:focus-within > .nav-link,
.menu-item.is-open > .nav-link {
    color: var(--blue-700);
  }

  .nav-link.is-active::after {
    transform: translateX(-50%) scaleX(0);
  }

  .menu-panel {
    position: static;
    display: none;
    min-height: 0;
    padding: 0 0 0.45rem;
    border: 0;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
  }

  .menu-item.is-open .menu-panel,
.menu-item--has-panel:hover .menu-panel,
.menu-item--has-panel:focus-within .menu-panel {
    display: block;
  }

  .menu-panel__image {
    display: none;
  }

  .menu-panel__links {
    display: grid;
    gap: 1rem;
    padding: 0.14rem 0 0.04rem;
  }

  .menu-panel__links a {
    display: block;
    color: #8d8d8d;
    font-size: 0.76rem;
    font-weight: 700;
    line-height: 1.25;
    text-align: center;
  }

  .menu-panel__links a::before {
    display: none;
  }

  /* --- Benefit section: tablet uses mobile card asset --- */
  .project-benefit {
    padding: 8.5rem 1rem 4rem;
  }

  .benefit-title {
    font-size: 1.8rem;
    margin-bottom: 2.5rem;
  }

  .benefit-cards {
    gap: 3.6rem;
  }

  .benefit-card,
.benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    width: 100%;
    min-height: 23rem;
    aspect-ratio: auto;
    margin: 0;
    padding: 3rem 1.5rem 6rem;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    background: transparent;
    overflow: visible;
  }

  .benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    min-height: 22rem;
    padding: 2.6rem 1.5rem 5.4rem;
  }

  .benefit-card__bg--desktop {
    display: none;
  }

  .benefit-card__bg--mobile {
    display: block;
    position: absolute;
    top: 0;
    bottom: auto;
    left: 0;
    width: 118%;
    height: calc(100% + 4rem);
    max-width: none;
    object-fit: fill;
    z-index: 0;
  }

  .benefit-card:nth-child(odd) .benefit-card__bg--mobile {
    left: 0;
    right: auto;
    transform: none;
  }

  .benefit-card:nth-child(even) .benefit-card__bg--mobile {
    left: auto;
    right: 0;
    transform: scaleX(-1);
  }

  .benefit-card__icon,
.benefit-card:nth-child(odd) .benefit-card__icon,
.benefit-card:nth-child(even) .benefit-card__icon {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    display: flex;
    width: clamp(6.5rem, 18vw, 8.5rem);
    height: clamp(6.5rem, 18vw, 8.5rem);
    margin: 0 auto 1rem;
  }

  .benefit-card__body,
.benefit-card:nth-child(odd) .benefit-card__body,
.benefit-card:nth-child(even) .benefit-card__body {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    width: auto;
    flex: 0 1 auto;
    min-width: 0;
    margin: 0 auto;
    text-align: center;
  }

  .benefit-card__body p {
    display: block;
    max-height: 0;
    opacity: 0;
  }

  .benefit-card__body h2 {
    font-size: 1.3rem;
    line-height: 1.25;
  }

  .benefit-card__photos {
    position: absolute;
    top: auto;
    left: auto;
    transform: none;
    right: 4%;
    bottom: -2.15rem;
    width: 13.2rem;
    height: 8rem;
    z-index: 2;
  }

  .benefit-card:nth-child(even) .benefit-card__photos {
    right: auto;
    left: 2.5%;
    top: auto;
    transform: none;
  }

  .benefit-card__circle {
    position: absolute;
    border-radius: 50%;
  }

  .benefit-card__circle:nth-child(1) {
    left: 0;
    bottom: 0;
    width: 5.85rem;
    height: 5.85rem;
  }

  .benefit-card__circle:nth-child(2) {
    top: 0;
    right: 0;
    width: 7rem;
    height: 7rem;
  }

  .benefit-card:nth-child(3) .benefit-card__photos {
    right: 4.5%;
    left: auto;
    top: auto;
    transform: none;
    bottom: -2.2rem;
    width: 16.2rem;
    height: 8.2rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    left: 0;
    top: 1.1rem;
    bottom: auto;
    width: 4.9rem;
    height: 4.9rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    left: 32%;
    right: auto;
    bottom: 0;
    top: auto;
    width: 5.75rem;
    height: 5.75rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    right: 0;
    top: 0;
    width: 5rem;
    height: 5rem;
  }

  #documents-dc-title {
    width: 100%;
  }

  .document-file--gazette:has(#documents-dc-title) {
    min-height: clamp(20rem, 44vw, 22rem);
  }

  #document-1 .document-file__inner::before {
    content: "";
    position: absolute;
    top: 7rem;
    left: var(--document-inline-padding);
    width: var(--document-content-width);
    height: 0.15rem;
    background: var(--brown);
  }

  #document-file--gazette .document-file__inner::before {
    content: "";
    position: absolute;
    top: 5.5rem;
    left: var(--document-inline-padding);
    width: var(--document-content-width);
    height: 0.15rem;
    background: var(--brown);
  }
}
@media (max-width: 767.98px) {
  .site-container {
    width: min(100% - 1.3rem, var(--container));
  }

  .hero-section,
.background-section,
.overview-section,
.facts-section,
.benefits-section,
.documents-section,
.site-footer,
.legal-links {
    width: 100%;
  }

  .hero-section {
    height: 388px;
    margin-top: 0;
    position: relative;
    z-index: 10;
  }

  .hero-section::after {
    bottom: -1.75rem;
    height: clamp(6rem, 24vw, 8rem);
    background: linear-gradient(to bottom, rgba(222, 250, 255, 0) 0%, rgba(231, 251, 255, 0.24) 34%, rgba(255, 255, 255, 0.78) 78%, rgba(255, 255, 255, 0.94) 100%);
    backdrop-filter: blur(0.5rem);
    -webkit-backdrop-filter: blur(0.5rem);
  }

  .hero-background-overlay {
    top: auto;
    right: auto;
    left: 50%;
    bottom: 0;
    width: 170vw;
    height: auto;
    object-fit: contain;
    object-position: center bottom;
    transform: translateX(-50%) translateY(35%) scale(1.05);
    transform-origin: center bottom;
  }

  .hero-logo {
    left: 5%;
    top: 20%;
    width: 8rem;
  }

  .background-title-overlay {
    margin: 2rem 0 5.2rem;
    font-size: 2rem;
  }

  .background-section {
    min-height: 0;
    margin-top: -2.45rem;
    padding: 0 0 3.8rem;
    background: var(--white);
  }

  .background-card {
    width: min(34rem, calc(100% - 1.5rem));
    min-height: max-content;
    padding: 2.3rem 1.5rem;
    border-radius: 0.35rem;
  }

  .background-card p {
    font-size: 0.95rem;
    line-height: 1.7;
    font-weight: 600;
  }

  .overview-section .overview-bg:not(.overview-bg--mobile) {
    display: none;
  }

  .overview-section .overview-bg--mobile {
    display: block;
    position: absolute;
    top: auto;
    left: 50%;
    bottom: var(--overview-bg-bottom);
    width: 150%;
    height: auto;
    object-fit: contain;
    transform: translateX(-50%);
  }

  .overview-section {
    --overview-bg-bottom: -6rem;
    --overview-machine-bg-offset: clamp(8rem, 24vw, 9.75rem);
    background: var(--white);
  }

  .overview-machine {
    width: clamp(8.75rem, 28vw, 13.5rem);
  }

  .overview-machine--left {
    left: clamp(1.25rem, 4vw, 2rem);
  }

  .overview-machine--right {
    right: clamp(1.5rem, 4.5vw, 2.5rem);
  }

  .overview-component {
    grid-template-columns: 1fr;
    width: min(24rem, 100%);
    margin-top: 2.4rem;
  }

  .overview-component__item {
    min-height: auto;
    padding: 1.25rem 1.2rem;
  }

  .overview-component__item:nth-child(odd)::before {
    display: none;
  }

  .overview-component__item::after {
    display: none;
  }

  .section-bg-image {
    left: 50%;
    width: 100%;
    min-width: 0;
    height: auto;
    bottom: 0;
    object-fit: contain;
    object-position: center bottom;
    transform: translateX(-50%);
  }

  /* --- Benefit section: desktop overrides --- */
  .project-benefit {
    margin-top: -10rem;
    padding: 0rem 2rem 6rem;
  }

  .project-benefit::before,
.project-benefit .section-bg-image {
    top: 0;
  }

  .project-benefit::before {
    bottom: -10rem;
  }

  .project-benefit .section-bg-image {
    height: calc(100% + 10rem);
  }

  /* The generic .section-bg-image desktop rule doesn't apply here
     because .project-benefit .section-bg-image has higher specificity */
  .benefit-title {
    margin-top: 5rem;
    font-size: 2rem;
    margin-bottom: 3rem;
  }

  .benefit-cards {
    gap: 1.5rem;
  }

  .benefit-card {
    gap: 2rem;
    padding: 1.5rem 2rem;
  }

  .benefit-card__icon {
    width: 5rem;
    height: 5rem;
  }

  .benefit-card__circle {
    width: 7rem;
    height: 7rem;
  }

  .benefit-card__body h2 {
    font-size: 2rem;
  }

  .benefit-card__body p {
    padding-top: -1rem;
    font-size: 1.05rem;
  }

  .benefit-album__item {
    width: 18rem;
    height: 12rem;
  }

  .documents__body {
    --documents-bg-top-height: clamp(17rem, 62vw, 28rem);
    --documents-bg-bottom-height: clamp(13rem, 50vw, 24rem);
    margin-top: 0;
    padding-top: 6.8rem;
  }

  #documents-dc-title {
    width: 100%;
  }

  .document-file--gazette:has(#documents-dc-title) {
    min-height: clamp(20rem, 55vw, 22rem);
  }

  #document-1 .document-file__inner::before {
    content: "";
    position: absolute;
    top: 6.5rem;
    left: var(--document-inline-padding);
    width: var(--document-content-width);
    height: 0.15rem;
    background: var(--brown);
  }

  #document-file--gazette .document-file__inner::before {
    content: "";
    position: absolute;
    top: 5rem;
    left: var(--document-inline-padding);
    width: var(--document-content-width);
    height: 0.15rem;
    background: var(--brown);
  }

  .documents__decor--clip {
    top: 4.4rem;
    width: clamp(46rem, 190vw, 66rem);
    opacity: 0.32;
  }

  .documents__decor--orange {
    top: -5rem;
    right: -0.75rem;
    z-index: 4;
    width: clamp(6.4rem, 23vw, 8.6rem);
    margin-top: 4rem;
  }

  .documents__decor--white {
    top: 3rem;
    right: clamp(8rem, 17vw, 6.1rem);
    left: auto;
    z-index: 4;
    width: clamp(4rem, 20vw, 8rem);
    margin-top: 4rem;
    transform: rotate(0deg);
  }

  .document-file {
    --document-content-width: min(100%, 17.8rem);
    --document-inline-padding: clamp(1.55rem, 7vw, 1.85rem);
    --document-title-top: clamp(1.35rem, 5.2vw, 1.55rem);
    --document-rule-top: clamp(5.95rem, 24vw, 6.2rem);
    --document-list-top: calc(var(--document-rule-top) + clamp(0.95rem, 4vw, 1.15rem));
  }

  .document-file--dc {
    --document-title-top: clamp(1rem, 4.4vw, 1.2rem);
    --document-rule-top: clamp(5.35rem, 21vw, 5.6rem);
    --document-list-top: calc(var(--document-rule-top) + clamp(0.85rem, 3.6vw, 1rem));
  }

  .document-file--comp {
    --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H78 C79.6 0 80.4 1.1 81.2 2.8 L85.4 16.5 C85.8 17.8 87.3 18.2 89.3 18.2 H98 C99.2 18.2 100 19.4 100 20.9 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
  }

  .document-file--gazette {
    --document-file-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M4.1 0 H78 C79.6 0 80.4 0.7 81.2 1.75 L85.4 10.3 C85.8 11.35 87.3 11.35 89.3 11.35 H98 C99.2 11.35 100 12.1 100 13.05 V94.9 C100 97.7 97.7 100 94.9 100 H5.1 C2.3 100 0 97.7 0 94.9 V5.1 C0 2.3 1.8 0 4.1 0 Z'/%3E%3C/svg%3E");
  }

  .document-file__decor {
    display: none;
  }

  .document-file__title {
    font-size: clamp(1.55rem, 7.5vw, 2rem);
  }

  html[lang=en] .document-file__title,
html[lang=en-US] .document-file__title {
    font-size: clamp(1.25rem, 6.4vw, 1.72rem);
  }
  html[lang=en] .document-file--comp,
html[lang=en-US] .document-file--comp {
    --document-rule-top: clamp(5.95rem, 24vw, 6.2rem);
  }

  .document-file__coins {
    position: relative;
    right: auto;
    bottom: auto;
    display: block;
    width: clamp(4rem, 31vw, 5rem);
    height: auto;
    margin: clamp(1.55rem, 6vw, 2.1rem) 0 0 auto;
  }

  .document-file__coins img {
    display: block;
    width: 100%;
    height: auto;
  }

  .announcement-widget {
    top: 0.8rem;
    right: auto;
    left: 0.75rem;
    width: min(12rem, calc(100% - 1.5rem));
  }

  .announcement-trigger {
    left: 0;
    right: auto;
    width: 2.4rem;
    height: 2.4rem;
  }

  .announcement-widget.is-open .announcement-trigger {
    top: 1.5rem;
    left: -0.3rem;
    width: 2.5rem;
    height: 2.5rem;
  }

  .announcement-card {
    margin-top: 2.2rem;
    padding-bottom: 0.85rem;
    border-radius: 0 0.9rem 0 0;
  }

  .announcement-card__header {
    min-height: 2.2rem;
    padding: 0.35rem 0.55rem 0.35rem 2.9rem;
    border-radius: 0 0.9rem 0 0;
  }

  .announcement-card__header strong {
    font-size: 0.82rem;
  }

  .announcement-card__close {
    width: 1.15rem;
    height: 1.15rem;
    font-size: 0.82rem;
  }

  .announcement-card p,
.announcement-card small,
.announcement-card a {
    padding-inline: 0.85rem;
  }

  .announcement-card p {
    padding-top: 0.7rem;
    font-size: 0.72rem;
  }

  .announcement-card small {
    padding-top: 0.5rem;
    font-size: 0.65rem;
    line-height: 1.5;
  }

  .announcement-card a {
    margin-top: 0.65rem;
    padding: 0.35rem 0.8rem;
    font-size: 0.72rem;
  }

  .contact-section__body {
    display: grid;
    place-items: center;
    min-height: 0;
    margin-top: -1px;
    padding: clamp(4rem, 13vw, 6rem) clamp(2.7rem, 13vw, 5.6rem) clamp(2.55rem, 8vw, 3.5rem);
    background: #7eb7cc;
    color: var(--white);
  }

  .contact-section__inner {
    width: 100%;
  }

  .contact-section__title {
    font-size: clamp(1.55rem, 6.8vw, 2.7rem);
    line-height: 1.15;
  }

  .contact-section__rule {
    height: 0.18rem;
    margin: clamp(1rem, 3.7vw, 1.45rem) 0 clamp(1.25rem, 4vw, 1.65rem);
  }

  .contact-section__details {
    gap: clamp(1.1rem, 4vw, 1.8rem);
  }

  .contact-section__item {
    grid-template-columns: clamp(1.8rem, 7vw, 2.9rem) 1fr;
    gap: clamp(0.9rem, 5vw, 2.1rem);
    font-size: clamp(1rem, 4.4vw, 1.75rem);
    line-height: 1.25;
  }

  .contact-section__item img {
    width: clamp(1.8rem, 7vw, 2.9rem);
    height: clamp(1.8rem, 7vw, 2.9rem);
    object-fit: contain;
  }

  .site-footer {
    min-height: clamp(2rem, 10vw, 4rem);
    padding: 0.85rem 1rem;
  }

  .legal-links {
    font-size: clamp(1rem, 4.1vw, 1.45rem);
  }

  /* hero overlays use vw units so no mobile override needed — height:26.46vw and bottom:0 already scale correctly */
  .social-menu__toggle {
    width: 5rem;
    height: 5rem;
  }

  .social-menu__panel {
    gap: 0.6rem;
    padding: 0.6rem 0.4rem;
  }

  .social-menu__link {
    width: 2rem;
    height: 2rem;
  }

  .social-menu__link svg {
    width: 1rem;
    height: 1rem;
  }

  /* --- Benefit section: mobile oval-blob design --- */
  .project-benefit {
    padding: 8.5rem 1rem 4rem;
  }

  .benefit-title {
    font-size: 1.8rem;
    margin-bottom: 2.5rem;
  }

  .benefit-cards {
    gap: 3.6rem;
  }

  /* Remove frosted-glass card on mobile; show oval blob image instead */
  .benefit-card {
    position: relative;
    width: 100%;
    aspect-ratio: auto;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: none;
    box-shadow: none;
    margin: 0;
    padding: 3rem 1.5rem 6rem;
    overflow: visible;
    min-height: 23rem;
  }

  /* Cancel the even-card row-reverse on mobile */
  .benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    flex-direction: column;
    margin: 0;
    min-height: 22rem;
    padding: 2.6rem 1.5rem 5.4rem;
  }

  .benefit-card:hover {
    transform: none;
    box-shadow: none;
  }

  /* Remove ::before blob (we use img element now) */
  .benefit-card::before {
    display: none;
  }

  /* Show mobile blob image, hide desktop card image */
  .benefit-card__bg--desktop {
    display: none;
  }

  .benefit-card__bg--mobile {
    display: block;
    position: absolute;
    top: 0;
    bottom: auto;
    left: 0;
    width: 118%;
    height: calc(100% + 4rem);
    max-width: none;
    object-fit: fill;
    z-index: 0;
  }

  /* Odd mobile cards keep the white side on the left */
  .benefit-card:nth-child(odd) .benefit-card__bg--mobile {
    left: 0;
    right: auto;
    transform: none;
  }

  /* Even mobile cards keep the white side on the right */
  .benefit-card:nth-child(even) .benefit-card__bg--mobile {
    left: auto;
    right: 0;
    transform: scaleX(-1);
  }

  .benefit-card__icon,
.benefit-card:nth-child(odd) .benefit-card__icon,
.benefit-card:nth-child(even) .benefit-card__icon {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    z-index: 1;
    display: flex;
    width: clamp(10rem, 24vw, 12rem);
    margin: 0 auto 1rem;
  }

  .benefit-card__body,
.benefit-card:nth-child(odd) .benefit-card__body,
.benefit-card:nth-child(even) .benefit-card__body {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    width: auto;
    z-index: 1;
    flex: 0 1 auto;
    min-width: 0;
    margin: 0 auto;
    text-align: center;
  }

  /* Hide description text on mobile — only title shows (no hover on touch) */
  .benefit-card__body p {
    display: block;
    max-height: 0;
    opacity: 0;
  }

  .benefit-card__body h2 {
    font-size: 1.3rem;
    line-height: 1.25;
  }

  /* Two circle photos at bottom-right (or left for even cards) */
  .benefit-card__photos {
    position: absolute;
    top: auto;
    left: auto;
    transform: none;
    bottom: -2.15rem;
    right: 4%;
    width: 13.2rem;
    height: 8rem;
    z-index: 2;
  }

  .benefit-card:nth-child(even) .benefit-card__photos {
    right: auto;
    left: 2.5%;
    top: auto;
    transform: none;
  }

  .benefit-card__circle {
    position: absolute;
    border-radius: 50%;
  }

  .benefit-card__circle:nth-child(1) {
    left: 0;
    bottom: 0;
    width: 5.85rem;
    height: 5.85rem;
  }

  .benefit-card__circle:nth-child(2) {
    top: 0;
    right: 0;
    width: 7rem;
    height: 7rem;
  }

  .benefit-card:nth-child(3) .benefit-card__photos {
    right: 4.5%;
    left: auto;
    top: auto;
    transform: none;
    bottom: -2.2rem;
    width: 16.2rem;
    height: 8.2rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    left: 0;
    top: 1.1rem;
    bottom: auto;
    width: 4.9rem;
    height: 4.9rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    left: 32%;
    right: auto;
    bottom: 0;
    top: auto;
    width: 5.75rem;
    height: 5.75rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    right: 0;
    top: 0;
    width: 5rem;
    height: 5rem;
  }

  .benefit-album {
    margin-top: 5rem;
  }

  .benefit-album__item {
    width: 25rem;
    height: 19rem;
  }
}
@media (min-width: 992px) and (max-width: 1024.98px) {
  .hero-background-overlay {
    right: auto;
    left: 50%;
    bottom: -0.5rem;
    width: 122%;
    height: auto;
    object-fit: contain;
    object-position: center bottom;
    transform: translateX(-50%) translateY(35%) scale(1.08);
    transform-origin: center bottom;
  }

  .project-benefit {
    padding: 8.5rem 1rem 4rem;
  }

  .benefit-title {
    font-size: 1.8rem;
    margin-top: 10rem;
    margin-bottom: 2.5rem;
  }

  .benefit-cards {
    gap: 3.6rem;
  }

  .benefit-card,
.benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    width: 100%;
    min-height: 22rem;
    aspect-ratio: auto;
    margin: 0;
    padding: 2.6rem 1.5rem 5.4rem;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    background: transparent;
    overflow: visible;
  }

  .benefit-card__bg--desktop {
    display: none;
  }

  .benefit-card__bg--mobile {
    display: block;
    position: absolute;
    top: 0;
    bottom: auto;
    left: 0;
    width: 118%;
    height: calc(100% + 4rem);
    max-width: none;
    object-fit: fill;
    z-index: 0;
  }

  .benefit-card:nth-child(odd) .benefit-card__bg--mobile {
    left: 0;
    right: auto;
    transform: none;
  }

  .benefit-card:nth-child(even) .benefit-card__bg--mobile {
    left: auto;
    right: 0;
    transform: scaleX(-1);
  }

  .benefit-card__icon,
.benefit-card:nth-child(odd) .benefit-card__icon,
.benefit-card:nth-child(even) .benefit-card__icon {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    z-index: 1;
    display: flex;
    width: clamp(8.4rem, 16vw, 13.5rem);
    height: clamp(8.4rem, 16vw, 13.5rem);
    margin: 0 auto 1.25rem;
  }

  .benefit-card__body,
.benefit-card:nth-child(odd) .benefit-card__body,
.benefit-card:nth-child(even) .benefit-card__body {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    width: auto;
    z-index: 1;
    flex: 0 1 auto;
    min-width: 0;
    margin: 0 auto;
    text-align: center;
  }

  .benefit-card__body p {
    display: block;
    max-height: 0;
    opacity: 0;
  }

  .benefit-card__body h2 {
    font-size: 1.3rem;
    line-height: 1.25;
  }

  .benefit-card__photos {
    position: absolute;
    top: auto;
    left: auto;
    right: 4%;
    bottom: -2.15rem;
    width: 13.2rem;
    height: 8rem;
    z-index: 2;
    transform: none;
  }

  .benefit-card:nth-child(even) .benefit-card__photos {
    right: auto;
    left: 2.5%;
    top: auto;
    transform: none;
  }

  .benefit-card__circle {
    position: absolute;
    border-radius: 50%;
  }

  .benefit-card__circle:nth-child(1) {
    left: 0;
    bottom: 0;
    width: 5.85rem;
    height: 5.85rem;
  }

  .benefit-card__circle:nth-child(2) {
    top: 0;
    right: 0;
    width: 7rem;
    height: 7rem;
  }

  .benefit-card:nth-child(3) .benefit-card__photos {
    right: 4.5%;
    left: auto;
    top: auto;
    bottom: -2.2rem;
    width: 16.2rem;
    height: 8.2rem;
    transform: none;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    left: 0;
    top: 1.1rem;
    bottom: auto;
    width: 4.9rem;
    height: 4.9rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    left: 32%;
    right: auto;
    bottom: 0;
    top: auto;
    width: 5.75rem;
    height: 5.75rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    right: 0;
    top: 0;
    width: 5rem;
    height: 5rem;
  }

  .benefit-album {
    margin-top: 10rem;
  }

  .benefit-album__item {
    width: 25rem;
    height: 19rem;
  }
}
@media (min-width: 768px) and (max-width: 1024.98px) {
  .project-benefit {
    margin-top: clamp(-5.5rem, -6vw, -3rem);
  }

  .overview-section {
    --overview-bg-bottom: clamp(-6.5rem, -6vw, -5rem);
    --overview-machine-bg-offset: clamp(8.4rem, 11vw, 9.25rem);
    padding-bottom: clamp(18rem, 31vw, 21rem);
  }
}
@media (min-width: 768px) and (max-width: 1440px) {
  .main-nav {
    gap: clamp(1.1rem, 2vw, 2.4rem);
  }

  html[lang=en] .main-nav,
html[lang=en-US] .main-nav {
    gap: clamp(0.75rem, 1.3vw, 1.65rem);
  }
  html[lang=en] .nav-link,
html[lang=en-US] .nav-link {
    font-size: 0.92rem;
  }

  .project-benefit {
    margin-top: 0rem;
    padding: 8.5rem 1rem 4rem;
  }

  .benefit-title {
    margin-top: 5rem;
    margin-bottom: 2.5rem;
    font-size: 1.8rem;
  }

  .benefit-cards {
    gap: 3.6rem;
  }

  .benefit-card,
.benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    width: 100%;
    min-height: 22rem;
    aspect-ratio: auto;
    margin: 0;
    padding: 2.6rem 1.5rem 5.4rem;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    background: transparent;
    overflow: visible;
  }

  .benefit-card__bg--desktop {
    display: none;
  }

  .benefit-card__bg--mobile {
    display: block;
    position: absolute;
    top: 0;
    bottom: auto;
    left: 0;
    width: 118%;
    height: calc(100% + 4rem);
    max-width: none;
    object-fit: fill;
    z-index: 0;
  }

  .benefit-card:nth-child(odd) .benefit-card__bg--mobile {
    left: 0;
    right: auto;
    transform: none;
  }

  .benefit-card:nth-child(even) .benefit-card__bg--mobile {
    left: auto;
    right: 0;
    transform: scaleX(-1);
  }

  .benefit-card__icon,
.benefit-card:nth-child(odd) .benefit-card__icon,
.benefit-card:nth-child(even) .benefit-card__icon {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    z-index: 1;
    display: flex;
    width: clamp(8.4rem, 16vw, 13.5rem);
    height: clamp(8.4rem, 16vw, 13.5rem);
    margin: 0 auto 1.25rem;
  }

  .benefit-card__body,
.benefit-card:nth-child(odd) .benefit-card__body,
.benefit-card:nth-child(even) .benefit-card__body {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    width: auto;
    z-index: 1;
    flex: 0 1 auto;
    min-width: 0;
    margin: 0 auto;
    text-align: center;
  }

  .benefit-card__body p {
    display: block;
    max-height: 0;
    opacity: 0;
  }

  .benefit-card__body h2 {
    font-size: 1.3rem;
    line-height: 1.25;
  }

  .benefit-card__photos {
    position: absolute;
    top: auto;
    left: auto;
    right: 4%;
    bottom: -2.15rem;
    width: 13.2rem;
    height: 8rem;
    z-index: 2;
    transform: none;
  }

  .benefit-card:nth-child(even) .benefit-card__photos {
    right: auto;
    left: 2.5%;
    top: auto;
    transform: none;
  }

  .benefit-card__circle {
    position: absolute;
    border-radius: 50%;
  }

  .benefit-card__circle:nth-child(1) {
    left: 0;
    bottom: 0;
    width: 5.85rem;
    height: 5.85rem;
  }

  .benefit-card__circle:nth-child(2) {
    top: 0;
    right: 0;
    width: 7rem;
    height: 7rem;
  }

  .benefit-card:nth-child(3) .benefit-card__photos {
    right: 4.5%;
    left: auto;
    top: auto;
    bottom: -2.2rem;
    width: 16.2rem;
    height: 8.2rem;
    transform: none;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    left: 0;
    top: 1.1rem;
    bottom: auto;
    width: 4.9rem;
    height: 4.9rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    left: 32%;
    right: auto;
    bottom: 0;
    top: auto;
    width: 5.75rem;
    height: 5.75rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    right: 0;
    top: 0;
    width: 5rem;
    height: 5rem;
  }
}
@media (max-width: 1024.98px) {
  .overview-section {
    background: var(--white);
  }

  .overview-section::before {
    display: none;
  }

  .benefit-album {
    padding-top: 5rem;
  }

  .benefit-album__viewport {
    padding-inline: 2.7rem;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    top: 0.2rem;
    bottom: auto;
    left: 1rem;
    z-index: 3;
    width: 5.4rem;
    height: 5.4rem;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(2) {
    top: 1.1rem;
    right: 0;
    z-index: 1;
    width: 7.6rem;
    height: 7.6rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    top: 1.75rem;
    bottom: auto;
    left: 0.4rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    top: auto;
    bottom: -0.65rem;
    left: 5.35rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    top: 0.65rem;
    right: 0.05rem;
  }
}
/* Benefit: shared responsive baseline for mobile and tablet */
@media (max-width: 1366px) {
  .project-benefit {
    margin-top: clamp(-4rem, -4vw, -1.5rem);
    padding: clamp(3.4rem, 7vw, 6.6rem) 0 clamp(8rem, 14vw, 12rem);
  }

  .project-benefit::before {
    top: 0;
    bottom: -10rem;
    background: rgba(255, 255, 255, 0.72);
  }

  .project-benefit .section-bg-image {
    top: 0;
    height: calc(100% + 10rem);
    object-position: center center;
  }

  .benefit-content {
    margin-top: 25rem;
    padding-inline: 0;
  }

  .benefit-title {
    min-height: 0;
    padding: 0 1rem;
    margin: 0 0 clamp(1.7rem, 4.6vw, 3.2rem);
    font-size: clamp(1.45rem, 4.8vw, 2.45rem);
  }

  .benefit-cards {
    gap: clamp(7rem, 18vw, 10rem);
    overflow: visible;
  }

  .benefit-card,
.benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    display: flex;
    width: min(411px, 100%);
    height: 347px;
    min-height: 0;
    margin: 0 auto;
    padding: clamp(2.35rem, 7vw, 2.85rem) 1.25rem 4.75rem;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    background: transparent;
    border: 0;
    box-shadow: none;
    overflow: visible;
    text-align: center;
  }

  .benefit-card__bg--desktop {
    display: none;
  }

  .benefit-card__bg--mobile {
    display: block;
    position: absolute;
    top: 0;
    bottom: auto;
    left: 0;
    z-index: 0;
    width: 112%;
    height: calc(100% + 1.6rem);
    max-width: none;
    object-fit: fill;
  }

  .benefit-card:nth-child(odd) .benefit-card__bg--mobile {
    right: auto;
    left: 0;
    transform: none;
  }

  .benefit-card:nth-child(even) .benefit-card__bg--mobile {
    right: 0;
    left: auto;
    transform: scaleX(-1);
  }

  .benefit-card__icon,
.benefit-card:nth-child(odd) .benefit-card__icon,
.benefit-card:nth-child(even) .benefit-card__icon {
    position: relative;
    order: 1;
    top: auto;
    left: auto;
    z-index: 1;
    width: clamp(12rem, 10vw, 12rem);
    margin-top: -2rem;
    margin-bottom: 0;
    border: 0;
    transform: none;
  }

  .benefit-card__body,
.benefit-card:nth-child(odd) .benefit-card__body,
.benefit-card:nth-child(even) .benefit-card__body,
.benefit-card:nth-child(2) .benefit-card__body {
    position: relative;
    order: 2;
    top: auto;
    left: auto;
    z-index: 1;
    display: block;
    width: min(100%, 24rem);
    margin: 0 auto;
    transform: none;
    text-align: center;
  }

  .benefit-card__body h2 {
    margin: 0;
    font-size: clamp(1.35rem, 3.4vw, 1.55rem);
    line-height: 1.22;
    white-space: normal;
    transform: none;
  }

  .benefit-card__body p {
    display: block;
    margin: 0.55rem auto 0;
    width: min(16rem, 100%);
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    font-size: clamp(0.82rem, 2.4vw, 0.95rem);
    line-height: 1.45;
    transition: max-height 350ms ease, opacity 300ms ease;
  }

  .benefit-card:hover .benefit-card__body p,
.benefit-card:focus-within .benefit-card__body p,
.benefit-card:active .benefit-card__body p {
    max-height: 7rem;
    opacity: 1;
  }

  .benefit-card__photos,
.benefit-card:nth-child(1) .benefit-card__photos {
    position: absolute;
    top: auto;
    right: clamp(0.8rem, 5vw, 1.7rem);
    bottom: clamp(-2rem, -4vw, -1.55rem);
    left: auto;
    z-index: 2;
    width: clamp(9.6rem, 44vw, 12rem);
    height: clamp(5.8rem, 25vw, 7.25rem);
    border: 0;
    overflow: visible;
    transform: none;
  }

  .benefit-card:nth-child(2) .benefit-card__photos {
    top: auto;
    right: clamp(0.8rem, 5vw, 1.7rem);
    bottom: clamp(-2rem, -4vw, -1.55rem);
    left: clamp(-0.8rem, 0.5vw, 0.25rem);
    width: clamp(10.4rem, 44vw, 12.25rem);
    height: clamp(5.7rem, 24vw, 6.65rem);
    transform: none;
  }

  .benefit-card__circle {
    position: absolute;
    border-radius: 50%;
  }

  .benefit-card__circle:nth-child(1),
.benefit-card:nth-child(1) .benefit-card__circle:nth-child(1),
.benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    top: auto;
    right: auto;
    bottom: 0;
    left: 0;
    z-index: 2;
    width: clamp(4.05rem, 14vw, 5.2rem);
    height: clamp(4.05rem, 14vw, 5.2rem);
    transform: none;
  }

  .benefit-card__circle:nth-child(2),
.benefit-card:nth-child(1) .benefit-card__circle:nth-child(2),
.benefit-card:nth-child(2) .benefit-card__circle:nth-child(2) {
    top: 0;
    right: 0;
    bottom: auto;
    left: auto;
    z-index: 1;
    width: clamp(5rem, 17vw, 6.25rem);
    height: clamp(5rem, 17vw, 6.25rem);
    transform: none;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    top: 0;
    bottom: -10%;
    left: 0;
    width: clamp(6rem, 10vw, 6rem);
    height: clamp(6rem, 10vw, 6rem);
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(2) {
    top: 10%;
    right: auto;
    bottom: 10%;
    left: 35%;
    width: clamp(7rem, 10vw, 7rem);
    height: clamp(7rem, 10vw, 7rem);
  }

  .benefit-card:nth-child(3) .benefit-card__photos {
    right: clamp(0.8rem, 5vw, 1.7rem);
    width: clamp(10.4rem, 44vw, 12.25rem);
    height: clamp(5.7rem, 24vw, 6.65rem);
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    top: clamp(0.8rem, 3vw, 1.35rem);
    bottom: -10%;
    left: 0;
    width: clamp(6rem, 10vw, 6rem);
    height: clamp(6rem, 10vw, 6rem);
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    top: auto;
    right: auto;
    bottom: 10%;
    left: 35%;
    width: clamp(4rem, 10vw, 4rem);
    height: clamp(4rem, 10vw, 4rem);
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    top: -10%;
    right: 0;
    width: clamp(6rem, 10vw, 6rem);
    height: clamp(6rem, 10vw, 6rem);
  }

  .benefit-card:not(:last-child) {
    margin-bottom: 0;
  }
}
/* Benefit: mobile adjustments */
@media (max-width: 767.98px) {
  .benefit-card,
.benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    width: 100%;
    max-width: none;
    margin-right: 0;
    margin-left: 0;
    padding: 2.85rem 1.25rem 5rem;
    justify-content: center;
    align-items: center;
  }

  .benefit-card__bg--mobile {
    height: calc(100% + 1.6rem);
  }

  .benefit-card__body,
.benefit-card:nth-child(odd) .benefit-card__body,
.benefit-card:nth-child(even) .benefit-card__body,
.benefit-card:nth-child(2) .benefit-card__body {
    margin-top: -1rem;
  }

  .benefit-card__body p {
    width: 60%;
  }

  .benefit-content {
    margin-top: 5rem;
  }

  .benefit-card__circle {
    overflow: hidden;
    background: var(--white);
    box-sizing: border-box;
  }

  .benefit-card__photos,
.benefit-card:nth-child(1) .benefit-card__photos {
    right: 0.35rem;
    bottom: -4.95rem;
    width: 12rem;
    height: 7.65rem;
  }

  .benefit-card:nth-child(2) .benefit-card__photos {
    left: -1.15rem;
    bottom: -4.85rem;
    width: 12rem;
    height: 7.65rem;
  }

  .benefit-card:nth-child(1) .benefit-card__circle:nth-child(1),
.benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    top: 3rem;
    bottom: 0rem;
    left: 0;
    width: 5.45rem;
    height: 5.45rem;
    z-index: 3;
  }

  .benefit-card:nth-child(1) .benefit-card__circle:nth-child(2),
.benefit-card:nth-child(2) .benefit-card__circle:nth-child(2) {
    top: 1rem;
    right: 0;
    width: 6.95rem;
    height: 6.95rem;
    z-index: 2;
  }

  .benefit-card:nth-child(2) .benefit-card__photos {
    right: 0.15rem;
    bottom: -5rem;
    width: 13.35rem;
    height: 7.8rem;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    top: 0rem;
    bottom: auto;
    left: 1rem;
    width: 5.25rem;
    height: 5.25rem;
    z-index: 3;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(2) {
    top: 2.85rem;
    bottom: 0;
    left: 4rem;
    width: 6rem;
    height: 6rem;
    z-index: 2;
  }

  .benefit-card:nth-child(3) .benefit-card__photos {
    right: 0.15rem;
    bottom: -5rem;
    width: 13.35rem;
    height: 7.8rem;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    top: 2rem;
    bottom: auto;
    left: 0;
    width: 5.25rem;
    height: 5.25rem;
    z-index: 2;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    top: auto;
    bottom: 0;
    left: 4.4rem;
    width: 5.75rem;
    height: 5.75rem;
    z-index: 3;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    top: 0;
    right: 0;
    width: 5.1rem;
    height: 5.1rem;
    z-index: 4;
  }
}
/* Benefit: responsive tablet adjustments */
@media (min-width: 768px) and (max-width: 1366px) {
  .benefit-cards {
    gap: clamp(12rem, 19vw, 17rem);
  }

  .benefit-card,
.benefit-card:nth-child(odd),
.benefit-card:nth-child(even) {
    --benefit-tablet-card-width: min(88vw, 720px);
    width: var(--benefit-tablet-card-width);
    height: calc(var(--benefit-tablet-card-width) * 0.8443);
    padding: clamp(3rem, 5vw, 4.2rem) clamp(1.5rem, 4vw, 2.5rem);
    justify-content: center;
  }

  .benefit-card:nth-child(odd) {
    margin-right: auto;
    margin-left: 0;
  }

  .benefit-card:nth-child(even) {
    margin-right: 0;
    margin-left: auto;
  }

  .benefit-card__bg--mobile {
    width: 115%;
    height: calc(100% + clamp(1.4rem, 3vw, 2.4rem));
  }

  .benefit-card__icon,
.benefit-card:nth-child(odd) .benefit-card__icon,
.benefit-card:nth-child(even) .benefit-card__icon {
    width: clamp(20rem, 12vw, 20rem);
    height: clamp(20rem, 12vw, 20rem);
    margin-top: 0;
    margin-bottom: 0;
  }

  .benefit-card__body,
.benefit-card:nth-child(odd) .benefit-card__body,
.benefit-card:nth-child(even) .benefit-card__body,
.benefit-card:nth-child(2) .benefit-card__body {
    margin-top: -2.4rem;
  }

  .benefit-card__body h2 {
    font-size: clamp(2rem, 3vw, 2.5rem);
    margin-top: 0;
  }

  .benefit-card__body p {
    font-size: clamp(1.5rem, 1.9vw, 1.7rem);
    width: min(19rem, 100%);
  }

  .benefit-content {
    margin-top: 5rem;
  }

  .benefit-card__circle {
    overflow: hidden;
    background: var(--white);
    box-sizing: border-box;
  }

  .benefit-card__photos,
.benefit-card:nth-child(1) .benefit-card__photos {
    right: clamp(1.1rem, 3.6vw, 2.8rem);
    bottom: clamp(-2.8rem, -3.7vw, -2.05rem);
    width: clamp(13.5rem, 29vw, 18rem);
    height: clamp(8rem, 17vw, 10.65rem);
  }

  .benefit-card:nth-child(1) .benefit-card__circle:nth-child(1) {
    top: auto;
    bottom: -3rem;
    left: clamp(-3.2rem, -3.8vw, -1.4rem);
    width: clamp(7rem, 12vw, 7rem);
    height: clamp(7rem, 12vw, 7rem);
    z-index: 2;
  }

  .benefit-card:nth-child(1) .benefit-card__circle:nth-child(2) {
    top: clamp(-0.4rem, -0.8vw, 0rem);
    right: clamp(-4.5rem, -6vw, -2.25rem);
    width: clamp(12rem, 14vw, 12rem);
    height: clamp(12rem, 14vw, 12rem);
    z-index: 1;
    overflow: visible;
  }

  .benefit-card:nth-child(2) .benefit-card__photos {
    left: clamp(-0.45rem, 1.5vw, 1.5rem);
    right: clamp(1rem, 3.5vw, 2.6rem);
    bottom: clamp(-2.85rem, -3.8vw, -2.1rem);
    width: clamp(15.25rem, 31vw, 19.5rem);
    height: clamp(8.35rem, 17vw, 10.6rem);
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    top: 2rem;
    bottom: auto;
    left: 5%;
    width: clamp(7rem, 11vw, 7rem);
    height: clamp(7rem, 11vw, 7rem);
    z-index: 2;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(2) {
    top: 5rem;
    bottom: 0;
    left: 35%;
    width: clamp(12rem, 12vw, 12rem);
    height: clamp(12rem, 12vw, 12rem);
    z-index: 1;
  }

  .benefit-card:nth-child(3) .benefit-card__photos {
    right: clamp(1rem, 3.5vw, 2.6rem);
    bottom: clamp(-2.85rem, -3.8vw, -2.1rem);
    width: clamp(15.25rem, 31vw, 19.5rem);
    height: clamp(8.35rem, 17vw, 10.6rem);
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    top: 6rem;
    bottom: auto;
    left: 0;
    width: clamp(5.4rem, 11vw, 6.9rem);
    height: clamp(5.4rem, 11vw, 6.9rem);
    z-index: 2;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    top: 5rem;
    bottom: 0;
    left: 35%;
    width: clamp(7rem, 12vw, 7.5rem);
    height: clamp(7rem, 12vw, 7.5rem);
    z-index: 1;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    top: 1rem;
    right: -3rem;
    width: clamp(7rem, 11vw, 7rem);
    height: clamp(7rem, 11vw, 7.05rem);
    z-index: 3;
  }

  .benefit-card:nth-child(odd):not(:last-child) {
    margin-right: auto;
    margin-left: 0;
  }

  .benefit-card:nth-child(even):not(:last-child) {
    margin-right: 0;
    margin-left: auto;
  }
}
@media (min-width: 768px) and (max-width: 1366px) and (min-width: 900px) and (max-width: 991.98px) and (orientation: portrait) {
  .benefit-card:nth-child(1) .benefit-card__circle:nth-child(1) {
    left: 18%;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    left: 9%;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    top: 65%;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    top: 82%;
    bottom: auto;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    top: 32%;
    right: 2%;
  }
}
@media (min-width: 768px) and (max-width: 1366px) and (min-width: 992px) and (max-width: 1024.98px) and (orientation: portrait) {
  .benefit-card:nth-child(1) .benefit-card__circle:nth-child(1) {
    left: 30%;
  }

  .benefit-card:nth-child(2) .benefit-card__circle:nth-child(1) {
    left: 13%;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(1) {
    top: 80%;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(2) {
    top: 100%;
    bottom: auto;
  }

  .benefit-card:nth-child(3) .benefit-card__circle:nth-child(3) {
    top: 45%;
    right: 5%;
  }
}
body:has(.legal-page-shell) {
  background: var(--white);
  overflow-x: hidden;
}

.site-shell:has(.legal-page-shell) {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.legal-page-shell {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: transparent;
}

.legal-page {
  position: relative;
  flex: 1;
  overflow: hidden;
  padding-bottom: 15%;
  background-image: url("../designMaterials/FooterBg.png");
  background-position: bottom center;
  background-repeat: no-repeat;
  background-size: cover;
}

.legal-page__inner {
  position: relative;
  z-index: 1;
  width: min(100%, 92rem);
  margin: 0 auto;
}

.legal-page__panel {
  display: none;
  min-height: clamp(32rem, 47vw, 42rem);
  padding: clamp(3rem, 5vw, 4.4rem) clamp(1.5rem, 4vw, 5rem) clamp(12rem, 18vw, 14rem);
  align-content: start;
  justify-items: center;
  text-align: center;
  scroll-margin-top: 9rem;
}

.legal-page__panel--copyright {
  display: grid;
}

.legal-page:has(.legal-page__panel:target) .legal-page__panel {
  display: none;
}

.legal-page:has(#copyright:target) .legal-page__panel--copyright,
.legal-page:has(#disclaimer:target) .legal-page__panel--disclaimer,
.legal-page:has(#privacy:target) .legal-page__panel--privacy {
  display: grid;
}

.legal-page__locale {
  width: min(100%, 58rem);
}

html[data-lang=zh-Hant] .legal-page__locale[data-legal-locale=zh-Hant],
html[data-lang=zh-Hans] .legal-page__locale[data-legal-locale=zh-Hans],
html[data-lang=en] .legal-page__locale[data-legal-locale=en] {
  display: block;
}

.legal-page__title {
  margin: 0 0 clamp(2rem, 4vw, 3.2rem);
  color: #00698E;
  font-size: 3.75rem;
  font-weight: 700;
  line-height: 1.12;
  overflow-wrap: break-word;
  word-break: break-word;
}

.legal-page__content {
  width: 100%;
  color: #00698E;
}

.legal-page__content p {
  margin: 0 0 1.35rem;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.82;
  overflow-wrap: break-word;
  word-break: break-word;
}

.legal-page__content p:last-child {
  margin-bottom: 0;
}

.legal-page__skyline {
  display: none;
}

.legal-page-footer {
  min-height: clamp(4.2rem, 6vw, 5.6rem);
}

.legal-links--page a.is-active {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

html[lang=en] .legal-page__title,
html[lang=en-US] .legal-page__title {
  font-size: 3.75rem;
  color: #00698E;
}
html[lang=en] .legal-page__content,
html[lang=en-US] .legal-page__content {
  width: 100%;
}
html[lang=en] .legal-page__content p,
html[lang=en-US] .legal-page__content p {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.72;
  color: #00698E;
}

@media (max-width: 991.98px) {
  .legal-page {
    background-image: url("../designMaterials/MobileBgFooter.png");
    background-position: bottom center;
    background-size: cover;
  }

  .legal-page__panel {
    min-height: 0;
    width: 100%;
    padding: clamp(2.2rem, 7vw, 3rem) clamp(0.6rem, 3vw, 1.2rem) clamp(8.5rem, 22vw, 11rem);
  }

  .legal-page__title {
    margin-bottom: clamp(1.5rem, 5vw, 2rem);
    font-size: 1.5rem;
    color: #00698E;
  }

  .legal-page__content {
    width: 100%;
  }

  .legal-page__content p {
    font-size: 0.7rem;
    line-height: 1.72;
    font-weight: 500;
    color: #00698E;
  }

  html[lang=en] .legal-page__title,
html[lang=en-US] .legal-page__title {
    font-size: 1.5rem;
    color: #00698E;
  }
  html[lang=en] .legal-page__content,
html[lang=en-US] .legal-page__content {
    width: 100%;
  }
  html[lang=en] .legal-page__content p,
html[lang=en-US] .legal-page__content p {
    font-size: 0.7rem;
    font-weight: 500;
    line-height: 1.72;
    color: #00698E;
  }
}
@media (max-width: 767.98px) {
  .legal-page {
    background-image: url("../designMaterials/MobileBgFooter.png");
    background-position: bottom center;
    background-size: cover;
  }

  .legal-page__panel {
    padding-bottom: clamp(15rem, 44vw, 17rem);
  }
}
/* WordPress-safe document titles: wrap DOM-rendered title text before the card tab. */
.document-file {
  --document-title-tab-space: clamp(7rem, 20vw, 11rem);
  --document-title-line-width: min(100%, 28.25rem);
  max-width: 100%;
  overflow: visible;
}

.document-file__inner {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: var(--document-title-top) var(--document-inline-padding) clamp(1.85rem, 4.2vw, 2.35rem);
}

.document-file__inner::before,
#document-1 .document-file__inner::before,
#document-file--gazette .document-file__inner::before {
  display: none;
}

.document-file__title,
.document-file--gazette .document-file__title,
#documents-dc-title,
#documents-gazette-title,
#documents-comp-title {
  position: relative;
  top: auto;
  left: auto;
  display: block;
  width: var(--document-content-width);
  max-width: 100%;
  height: auto;
  min-height: 0;
  margin: 0;
  padding: 0 clamp(2rem, 6vw, 1.5rem) clamp(1.5rem, 2.2vw, 1.7rem) 0;
  box-sizing: border-box;
  font-size: clamp(1.65rem, 4vw, 2.5rem);
  line-height: 1.12;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
  text-wrap: balance;
  overflow: visible;
}

.document-file__title::after,
.document-file--gazette .document-file__title::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  display: block;
  width: var(--document-title-line-width);
  height: 0.15rem;
  margin: 0;
  background: var(--brown);
}

.document-file__list,
.document-file--gazette .document-file__list {
  width: var(--document-content-width);
  max-width: 100%;
  padding-top: clamp(0.85rem, 2vw, 1.15rem);
}

.document-file--comp .document-file__title,
html[lang=en] .document-file--comp .document-file__title,
html[lang=en-US] .document-file--comp .document-file__title {
  white-space: normal;
}

@media (min-width: 1025px) {
  .document-file__title,
.document-file--gazette .document-file__title,
#documents-dc-title,
#documents-gazette-title,
#documents-comp-title {
    padding-right: min(calc(var(--document-title-tab-space) + 1rem), 42%);
  }
}
@media (min-width: 768px) and (max-width: 1024.98px) {
  .document-file {
    --document-title-tab-space: clamp(7rem, 22vw, 10rem);
    --document-title-line-width: min(100%, 28.25rem);
  }

  .document-file__title,
.document-file--gazette .document-file__title,
#documents-dc-title,
#documents-gazette-title,
#documents-comp-title {
    padding-right: min(calc(var(--document-title-tab-space) + 1.5rem), 45%);
  }
}
@media (max-width: 767.98px) {
  .documents__content {
    width: min(calc(100% - 0.75rem), 37.25rem);
  }

  .document-file {
    --document-title-tab-space: clamp(2rem, 25vw, 3rem);
    --document-title-line-width: min(100%, 15.8rem);
  }

  .document-file__title,
.document-file--gazette .document-file__title,
#documents-dc-title,
#documents-gazette-title,
#documents-comp-title {
    font-size: clamp(1.35rem, 7vw, 2rem);
  }
}