@charset "UTF-8";
@layer reset, base, page, custom;
:root {
  --l-H-hero: 680px;
  --l-header: 80px;
  --l-header-: -80px;
  --l-header--mobile: 56px;
  --l-header--mobile-: -56px;
  --l-services-logo: 44px;
  --l-btnH: 36px;
  --l-h-sec-footer: 150px;
  --c-text: #3F3F3F;
  --c-heading: #1e1e1e;
  --c-nav: #494949;
  --c-brand-text: #848492;
  --c-primary: #2D925B;
  --c-secondary: #1e3659;
  --c-hightlight: #ec4e00;
  --c-primary-start: #f0da98;
  --c-primary-stop: #cfab3b;
  --c-secondary-start: #ffdc23;
  --c-secondary-stop: #ffe972;
  --f-services-title: 18px;
  --f-services-title-lh: 20px;
  --f-services-title--ch: 13px;
  --f-services-title--ch-lh: 16px;
  --z-nav: 10;
  --z-hero: 8;
  --z-main: 9;
  --c-sdg1: #c74140;
  --c-sdg2: #cfa94d;
  --c-sdg3: #6b9e47;
  --c-sdg4: #aa3433;
  --c-sdg5: #df5330;
  --c-sdg6: #71b8e0;
  --c-sdg7: #edc843;
  --c-sdg8: #8d2c44;
  --c-sdg9: #df7538;
  --c-sdg10: #bf3767;
  --c-sdg11: #e6a441;
  --c-sdg12: #b28f40;
  --c-sdg13: #567c4b;
  --c-sdg14: #5794d5;
  --c-sdg15: #7fbc45;
  --c-sdg16: #3d669a;
  --c-sdg17: #2f4768;
  --c-zdg1: #a47903;
  --c-zdg2: #be9115;
  --c-zdg3: #d7aa2d;
}

:root {
  --l-inner: 1024px;
}

@keyframes slide-f-right {
  from {
    opacity: 0;
    transform: translate3d(100%, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes slide-f-left {
  from {
    opacity: 0;
    transform: translate3d(-100%, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes slide-f-top {
  from {
    opacity: 0;
    transform: translate3d(0, -50px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes reveal-up-20 {
  from {
    opacity: 0;
    transform: translate3d(0, 20px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@scope (.article-page) {
  :scope:has(.image-block) .header + .content .content-aside {
    padding-top: 0;
    margin-top: -40px;
  }
  :scope:has(.image-block) .header + .content .content-aside_inner:before {
    inset: 10px 0 10px -40px;
  }
  .section-related {
    padding-top: 40px;
  }
  .content-header .title {
    margin-block-end: 0.625rem;
    margin-inline: 20px;
    font-size: 1.625rem;
    text-align: left;
  }
  @media only screen and (max-width: 860px) {
    .content-header .title {
      font-size: 1.25rem;
    }
  }
  .content-header > .l-flex {
    padding-inline: 20px;
    margin-block-end: 0.75rem;
    align-items: center;
    gap: 6px;
  }
  .content-header > .l-flex:empty {
    display: none;
  }
  .content-header:has(.image-block) .title {
    border-bottom: none;
    margin-block: 30px 0;
  }
  .content:after {
    display: none;
  }
  .info-label {
    font-size: 0.875rem;
    color: #8e7e47;
    margin-top: 6px;
    display: block;
  }
  .info-value {
    font-size: 1rem;
    color: #1e3659;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
  }
  .btn__pin {
    display: none;
    font-size: 10px;
    color: transparent;
    width: 20px;
    height: 20px;
    background: url(../images/icon-pin.svg) no-repeat center/contain;
    margin-inline-start: 5px;
  }
  .event-register {
    display: inline-block;
    margin-block: 20px;
    padding: 12px 32px;
    background: linear-gradient(40deg, #ec4e00 0, #fe9500 100%);
    font-size: 1rem;
    box-shadow: 0 5px 16px rgba(236, 78, 0, 0.5);
    color: #fff;
    border-radius: 5px;
    overflow: clip;
    position: relative;
    transition: 0.4s;
  }
  .event-register:hover {
    box-shadow: 0 10px 22px rgba(236, 78, 0, 0.7);
  }
  .event-register:hover:before {
    transform: translate3d(22px, -15px, 0) scale(0.7);
    opacity: 0.2;
  }
  .event-register span {
    display: inline-block;
    position: relative;
    z-index: 9;
  }
  .event-register:before {
    content: "";
    position: absolute;
    inset: 0;
    background: #ffdc23;
    border-radius: 50px;
    filter: blur(20px);
    transform: translate3d(22px, -10px, 0) scale(0.8);
    z-index: 2;
    opacity: 0.6;
    transition: 0.3s;
  }
  .sdg,
  .zdg {
    gap: 6px;
  }
  .sq-item {
    aspect-ratio: 1/1;
    flex: 0 1 auto;
    width: 50px;
    font-size: 1px;
    color: transparent;
    text-align: center;
    position: relative;
  }
  @media only screen and (max-width: 860px) {
    .sq-item {
      width: 40px;
    }
  }
  .sq-item.--tips:hover:before, .sq-item.--tips:hover:after {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
  .sq-item.--tips:before {
    content: attr(data-tips);
    position: absolute;
    inset: auto auto calc(100% + 5px) 0;
    font-size: 0.625rem;
    background: rgba(0, 0, 0, 0.7);
    padding: 3px 10px;
    transform: translate3d(0, -5px, 0);
    white-space: nowrap;
    color: #fff;
    border-radius: 4px;
    opacity: 0;
    transition: 0.3s;
  }
  .sq-item.--tips:after {
    content: "";
    position: absolute;
    inset: auto auto 100% 6px;
    transform: translate3d(0, -5px, 0);
    opacity: 0;
    transition: 0.3s;
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 6px 3.5px 0 3.5px;
    border-color: rgba(0, 0, 0, 0.7) transparent transparent transparent;
  }
  .zdg .sq-item {
    color: #fff;
    font-size: 0.875rem;
    display: flex;
    place-content: center;
    align-items: center;
  }
}
.tatb:has(#has-map) .btn__pin {
  display: inline-block;
}

.album-section .gallery-items {
  --gap: 16px;
}

/* ============================================================
   原本： @scope (.article-page)
   Safari / Firefox / iOS 全相容版本
============================================================ */
.article-page {
  /* ---------------------- :scope:has(.image-block) ---------------------- */
  /* ---------------------- section-related ---------------------- */
  /* ---------------------- content-header → title ---------------------- */
  /* ---------------------- content-header ---------------------- */
  /* ---------------------- content ---------------------- */
  /* ---------------------- info label/value ---------------------- */
  /* ---------------------- pin button ---------------------- */
  /* ---------------------- event-register ---------------------- */
  /* ---------------------- sdg / zdg ---------------------- */
}
.article-page:has(.image-block) .header + .content .content-aside {
  padding-top: 0;
  margin-top: -40px;
}
.article-page:has(.image-block) .header + .content .content-aside_inner:before {
  inset: 10px 0 10px -40px;
}
.article-page .section-related {
  padding-top: 40px;
}
.article-page .content-header .title {
  margin-block-end: 0.625rem;
  margin-inline: 20px;
  font-size: 1.625rem;
  text-align: left;
}
@media only screen and (max-width: 860px) {
  .article-page .content-header .title {
    font-size: 1.25rem;
  }
}
.article-page .content-header > .l-flex {
  padding-inline: 20px;
  margin-block-end: 0.75rem;
  align-items: center;
  gap: 6px;
}
.article-page .content-header > .l-flex:empty {
  display: none;
}
.article-page .content-header:has(.image-block) .title {
  border-bottom: none;
  margin-block: 30px 0;
}
.article-page .content:after {
  display: none;
}
.article-page .info-label {
  font-size: 0.875rem;
  color: #8e7e47;
  margin-top: 6px;
  display: block;
}
.article-page .info-value {
  font-size: 1rem;
  color: #1e3659;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
}
.article-page .btn__pin {
  display: none;
  font-size: 10px;
  color: transparent;
  width: 20px;
  height: 20px;
  background: url(../images/icon-pin.svg) no-repeat center/contain;
  margin-inline-start: 5px;
}
.article-page .event-register {
  display: inline-block;
  margin-block: 20px;
  padding: 12px 32px;
  background: linear-gradient(40deg, #ec4e00 0, #fe9500 100%);
  font-size: 1rem;
  box-shadow: 0 5px 16px rgba(236, 78, 0, 0.5);
  color: #fff;
  border-radius: 5px;
  overflow: clip;
  position: relative;
  transition: 0.4s;
}
.article-page .event-register:hover {
  box-shadow: 0 10px 22px rgba(236, 78, 0, 0.7);
}
.article-page .event-register:hover:before {
  transform: translate3d(22px, -15px, 0) scale(0.7);
  opacity: 0.2;
}
.article-page .event-register span {
  display: inline-block;
  position: relative;
  z-index: 9;
}
.article-page .event-register:before {
  content: "";
  position: absolute;
  inset: 0;
  background: #ffdc23;
  border-radius: 50px;
  filter: blur(20px);
  transform: translate3d(22px, -10px, 0) scale(0.8);
  z-index: 2;
  opacity: 0.6;
  transition: 0.3s;
}
.article-page .sdg,
.article-page .zdg {
  gap: 6px;
}
.article-page .sq-item {
  aspect-ratio: 1/1;
  flex: 0 1 auto;
  width: 50px;
  font-size: 1px;
  color: transparent;
  text-align: center;
  position: relative;
}
@media only screen and (max-width: 860px) {
  .article-page .sq-item {
    width: 40px;
  }
}
.article-page .sq-item.--tips:hover:before, .article-page .sq-item.--tips:hover:after {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}
.article-page .sq-item.--tips:before {
  content: attr(data-tips);
  position: absolute;
  inset: auto auto calc(100% + 5px) 0;
  font-size: 0.625rem;
  background: rgba(0, 0, 0, 0.7);
  padding: 3px 10px;
  transform: translate3d(0, -5px, 0);
  white-space: nowrap;
  color: #fff;
  border-radius: 4px;
  opacity: 0;
  transition: 0.3s;
}
.article-page .sq-item.--tips:after {
  content: "";
  position: absolute;
  inset: auto auto 100% 6px;
  transform: translate3d(0, -5px, 0);
  opacity: 0;
  transition: 0.3s;
  width: 0px;
  height: 0px;
  border-style: solid;
  border-width: 6px 3.5px 0 3.5px;
  border-color: rgba(0, 0, 0, 0.7) transparent transparent transparent;
}
.zdg .article-page .sq-item {
  color: #fff;
  font-size: 0.875rem;
  display: flex;
  place-content: center;
  align-items: center;
}

/* ============================================================
   tatb:has(#has-map) → show pin
============================================================ */
.tatb:has(#has-map) .btn__pin {
  display: inline-block;
}

/* ============================================================
   album-section
============================================================ */
.album-section .gallery-items {
  --gap: 16px;
}

/*# sourceMappingURL=article.css.map */
