@charset "UTF-8";
@font-face {
  font-family: "Uniform";
  src: url(../fonts/Uniform.otf);
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "Uniform";
  src: url(../fonts/Uniform-Medium.otf);
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: "Uniform";
  src: url(../fonts/Uniform-Bold.otf);
  font-weight: 700;
  font-display: swap;
}
/**
 * * Allows you to use retina images at various pixel densities.
 * * Examples:
 * *
 * *   +retina(/images/mypic.jpg, 2);
 * *   +retina(/images/mypic.jpg, 3, 100px 100px, left top no-repeat transparent);
 * *
 * * @param  {Value}  $path               The path to the file name minus extension.
 * * @param  {Number} $cap:    2          The highest pixel density level images exist for.
 * * @param  {Value}  $size:   auto auto  The intended width of the rendered image.
 * * @param  {Value}  $extras: null       Any other `background` values to be added.
 * */
/**
 * * 往上適應
 * * 引用方式: +media-up($breakpoint-value)
 * */
/**
 * * 往上適應
 * * 引用方式: +media-up-num(自訂數值)
 * */
/**
 * * 往下適應
 * * 引用方式: +media-down($breakpoint-value)
 * */
/**
 * * 往下適應
 * * 引用方式: +media-up-num(自訂數值)
 * */
/**
 * * 範圍內適應
 * * 引用方式: +media-between($lower-breakpoint, $upper-breakpoint)
 * */
/**
 * * 引用方式: +lh(15,22) 前面放 line-height 的 px 值, 後面放 font-size 的 px 值（計算）
 * */
/**
 * * 引用方式: +ls(15,22) 前面放 letter-spacing 的 px 值, 後面放 font-size 的 px 值（計算）
 * */
/*  ===== firefox font weight bold 統一設定為 normal (firefox 在小字為粗體的時候會過粗) ===== */
/**
 * * 引用方式: +gradient(180deg,#fff,4%,#eee,92%)
 * */
/**
 * * margin
 * * 引用方式: +mb(15,22) 前面放 margin 的 px 值, 後面放 font-size 的 px 值
 * */
/**
 * * padding
 * * 引用方式: +pb(15,22) 前面放 padding 的 px 值, 後面放 font-size 的 px 值
 * */
.container-fluid {
  padding-inline-start: 20px;
  padding-inline-end: 20px;
}

.container {
  padding-inline-start: 20px;
  padding-inline-end: 20px;
}
@media (min-width: 768px) {
  .container {
    padding-inline-start: 0;
    padding-inline-end: 0;
  }
}
@media (min-width: 1400px) {
  .container {
    max-width: 100%;
    padding-inline-end: 14vw;
    padding-inline-start: 14vw;
  }
}

.row {
  margin-inline-start: -5px;
  margin-inline-end: -5px;
}
@media (min-width: 768px) {
  .row {
    margin-inline-start: -15px;
    margin-inline-end: -15px;
  }
}
.row > * {
  padding-inline-end: 5px;
  padding-inline-start: 5px;
}
@media (min-width: 768px) {
  .row > * {
    padding-inline-end: 15px;
    padding-inline-start: 15px;
  }
}

:root {
  scroll-behavior: initial;
}

*:focus, *:active, *:visited,
*::before:focus,
*::before:active,
*::before:visited,
*::after:focus,
*::after:active,
*::after:visited {
  outline: none !important;
  box-shadow: none !important;
}

noscript {
  position: absolute;
  top: 0;
  z-index: 9999;
}

body {
  color: #000000;
  line-height: normal;
  font-family: "Noto Sans TC", "Noto Serif TC", sans-serif;
  letter-spacing: 0.04em;
  overflow-x: hidden;
  word-break: break-word;
  -webkit-font-smoothing: antialiased;
  image-rendering: auto;
  touch-action: manipulation;
  -moz-osx-font-smoothing: grayscale;
}
body.is-hidden {
  overflow: hidden;
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: #1E1E1E;
  text-decoration: none;
  transition: all ease 400ms;
}
a:hover {
  color: currentColor;
}
a:active, a:hover, a:visited, a:focus {
  text-decoration: none;
  outline: 0;
  transition: all ease 400ms;
}

button {
  background-color: transparent;
  border: none;
  padding: 0;
  outline: 0;
  cursor: pointer;
  transition: all ease 400ms;
}
button:active, button:hover, button:visited, button:focus {
  outline: 0;
  transition: all ease 400ms;
}

ul, ol {
  padding: 0;
  margin-bottom: 0;
}

ul {
  list-style: none;
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
  font-size: 1rem;
  font-weight: 400;
  line-height: normal;
  margin-bottom: 0;
}

p, label {
  margin-bottom: 0;
}

textarea {
  resize: none;
}

input, select, textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
  background-color: transparent;
  border: none;
  outline: 0;
  padding: 0;
}
input:active, input:hover, input:visited, input:focus, select:active, select:hover, select:visited, select:focus, textarea:active, textarea:hover, textarea:visited, textarea:focus {
  outline: 0;
}

input[type=submit], [type=date], [type=checkbox] {
  cursor: pointer;
  transition: all ease 400ms;
}

::placeholder {
  color: #999999;
}

input[type=search]::-webkit-search-cancel-button {
  -webkit-appearance: none;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
}

input[type=number] {
  -moz-appearance: textfield;
}

.u-link-range {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.u-pointer {
  cursor: pointer;
}

.u-pointer-none {
  pointer-events: none;
}

.u-hidden {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.u-img-cover {
  object-fit: cover;
  object-position: center center;
}

.u-img-contain {
  object-fit: contain;
  object-position: center center;
}

.u-bg-cover {
  width: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.u-16x9 {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 56.25%;
}
.u-16x9 > * {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
}

.u-flex-1 {
  flex: 1;
}

.editor * {
  line-height: normal;
  font-family: "Noto Sans TC", "Noto Serif TC", sans-serif;
  letter-spacing: 0.04em;
  word-break: break-word;
  -webkit-font-smoothing: antialiased;
  image-rendering: auto;
  touch-action: manipulation;
  -moz-osx-font-smoothing: grayscale;
  padding: 0;
  margin: 0;
}
.editor h2, .editor h3, .editor h4, .editor h5, .editor h6 {
  font-weight: 700;
  margin-bottom: 10px;
}
@media (min-width: 768px) {
  .editor h2, .editor h3, .editor h4, .editor h5, .editor h6 {
    margin-bottom: 20px;
  }
}
.editor h2 {
  position: relative;
  font-family: "Noto Serif TC", sans-serif;
  font-size: 1.75rem;
  letter-spacing: 0.02em;
  line-height: 140%;
  font-weight: 700;
  text-indent: 32px;
}
.editor h2::before {
  content: "";
  position: absolute;
  top: 11.5px;
  left: 0;
  width: 16px;
  height: 16px;
  background: #c9bc9c;
  border-radius: 100%;
}
.editor h3 {
  position: relative;
  font-family: "Noto Serif TC", sans-serif;
  font-size: 1.5rem;
  letter-spacing: 0.02em;
  line-height: 160%;
  font-weight: 700;
  text-indent: 28px;
}
.editor h3::before {
  content: "";
  position: absolute;
  top: 13px;
  left: 0;
  width: 12px;
  height: 12px;
  border: 2px solid #c9bc9c;
  border-radius: 100%;
}
.editor h4 {
  position: relative;
  font-family: "Noto Serif TC", sans-serif;
  font-size: 1.25rem;
  letter-spacing: 0.02em;
  line-height: 160%;
  font-weight: 500;
  text-indent: 28px;
}
@media (max-width: 991.98px) {
  .editor h4 {
    font-size: 1rem;
  }
}
.editor h4::before {
  content: "";
  position: absolute;
  top: 15px;
  left: 0;
  width: 12px;
  height: 2px;
  background: #c9bc9c;
}
.editor h5 {
  font-family: "Noto Serif TC", sans-serif;
  font-size: 1.25rem;
  letter-spacing: 0.02em;
  line-height: 160%;
}
@media (max-width: 991.98px) {
  .editor h5 {
    font-size: 1rem;
  }
}
.editor h6 {
  font-family: "Noto Serif TC", sans-serif;
  font-size: 1.25rem;
  letter-spacing: 0.02em;
  line-height: 160%;
}
@media (max-width: 991.98px) {
  .editor h6 {
    font-size: 1rem;
  }
}
.editor p {
  font-family: "Noto Sans TC", sans-serif;
  font-size: 1rem;
  line-height: 180%;
  letter-spacing: 0.02em;
  font-weight: 400;
}
.editor a {
  color: #7F908F;
  text-decoration: underline;
}
.editor img {
  display: inline-block;
}
.editor ul, .editor ol {
  padding-inline-start: 1.5rem;
  font-family: "Noto Sans TC", sans-serif;
  font-size: 1rem;
  line-height: 180%;
  letter-spacing: 0.02em;
  font-weight: 400;
}
.editor ul {
  list-style: revert;
}
.editor table {
  caption-side: initial;
  border-collapse: initial;
}
.editor tbody, .editor td, .editor tfoot, .editor th, .editor thead, .editor tr {
  border-style: inherit;
  border-width: inherit;
}

.icon {
  display: inline-block;
  width: 24px;
  height: 24px;
  stroke-width: 0;
  stroke: currentColor;
  fill: currentColor;
  transition: all ease 400ms;
}

.swiper .swiper-button-next::after,
.swiper .swiper-button-prev::after {
  display: none;
}
.swiper .swiper-button-next:hover,
.swiper .swiper-button-prev:hover {
  transition: all ease 400ms;
}
.swiper .swiper-button-next:focus, .swiper .swiper-button-next:focus-visible,
.swiper .swiper-button-prev:focus,
.swiper .swiper-button-prev:focus-visible {
  outline: none;
  border: none;
}
.swiper .swiper-pagination-bullet:focus, .swiper .swiper-pagination-bullet:focus-visible {
  outline: none;
  border: none;
}

.c-input, .c-input-file {
  border-radius: 8px !important;
  border: 1px solid #999999;
  padding: 12px 18px;
  transition: all ease 400ms;
}
@media (hover: hover) {
  .c-input:hover, .c-input-file:hover {
    background-color: #F0F0F0;
    transition: all ease 400ms;
  }
}

.select2-container {
  width: 100% !important;
}

.select2-container--default .select2-selection--single {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  padding: 8px 16px 8px 24px;
  border-radius: 10px;
  border-color: transparent;
  background: #e7e7e7;
}

.select2-container .select2-selection--single .select2-selection__rendered {
  width: 100%;
  font-family: "Noto Sans TC", sans-serif;
  font-size: 1.125rem;
  line-height: 180%;
  letter-spacing: 0.02em;
  color: #4f4f4f;
  padding: 0 24px 0 0;
  transition: all ease 400ms;
}
.select2-container .select2-selection--single .select2-selection__rendered.is-selected {
  color: #1E1E1E;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  position: relative;
  width: auto;
  height: auto;
}
.select2-container--default .select2-selection--single .select2-selection__arrow::after {
  content: "";
  position: absolute;
  top: 4px;
  right: 0;
  width: 24px;
  height: 24px;
  background: url(../images/icon/SVG/_arrow-down.svg) no-repeat center center;
  transition: all ease 400ms;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  display: none;
}

.select2-container--open {
  z-index: 1020;
}

.select2-dropdown {
  border: 1px solid #d1d1d1 !important;
  border-radius: 10px !important;
  top: 0px;
  padding: 2px;
  background: #e7e7e7;
  box-shadow: 0px 12px 16px 0px rgba(0, 0, 0, 0.1);
}
.select2-dropdown:not(.select2-dropdown--above) {
  transform: translateY(-50px);
}
.select2-dropdown.select2-dropdown--above {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

.select2-search--dropdown {
  padding: 12px 18px;
  display: none;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
  border-color: #999999;
  border-radius: 8px;
  padding: 12px 18px;
}

.select2-results__options {
  cursor: pointer;
  max-height: 340px !important;
}
.select2-results__options::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
.select2-results__options::-webkit-scrollbar-button {
  width: 6px;
  height: 6px;
  display: none;
}
.select2-results__options::-webkit-scrollbar-track {
  background-color: #F0F0F0;
  border: 0;
  border-radius: 50px;
}
.select2-results__options::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.7);
  border: 0;
  border-radius: 50px;
  cursor: pointer;
}
.select2-results__options::-webkit-scrollbar-thumb:hover {
  background-color: rgba(0, 0, 0, 0.7);
}
@-moz-document url-prefix() {
  .select2-results__options {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.7) #F0F0F0;
  }
}

.select2-results__option {
  font-family: "Noto Sans TC", sans-serif;
  font-size: 1.125rem;
  line-height: 180%;
  letter-spacing: 0.02em;
  font-weight: 400;
  padding: 8px 24px;
  transition: all ease 400ms;
}

.select2-results__option--selectable {
  color: #1E1E1E;
}

.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
  background: #7F908F;
  color: #ffffff;
  transition: all ease 400ms;
}

.os-custom > .os-scrollbar-horizontal {
  height: 6px;
}

.os-custom > .os-scrollbar-vertical {
  width: 6px;
}

.os-custom > .os-scrollbar-corner {
  width: 6px;
  background-color: transparent;
}

.os-custom > .os-scrollbar > .os-scrollbar-track {
  background: transparent;
  cursor: pointer;
}

.os-custom > .os-scrollbar-horizontal > .os-scrollbar-track:before,
.os-custom > .os-scrollbar-vertical > .os-scrollbar-track:before {
  content: "";
  display: block;
  position: absolute;
  background: #F0F0F0;
  border-radius: 50px;
}

.os-custom > .os-scrollbar-horizontal > .os-scrollbar-track:before,
.os-custom > .os-scrollbar-horizontal > .os-scrollbar-track > .os-scrollbar-handle:before {
  height: 100%;
  left: 0;
  right: 0;
  top: 0;
}

.os-custom > .os-scrollbar-vertical > .os-scrollbar-track:before,
.os-custom > .os-scrollbar-vertical > .os-scrollbar-track > .os-scrollbar-handle:before {
  width: 100%;
  top: 0;
  bottom: 0;
  left: 0;
}

.os-custom > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle:before {
  content: "";
  display: block;
  position: absolute;
  background: rgba(0, 0, 0, 0.7);
  border-radius: 50px;
}

.os-custom > .os-scrollbar-horizontal > .os-scrollbar-track > .os-scrollbar-handle:hover:before,
.os-custom > .os-scrollbar-vertical > .os-scrollbar-track > .os-scrollbar-handle:hover:before {
  background: rgba(0, 0, 0, 0.7);
  cursor: pointer;
}

.os-custom > .os-scrollbar-horizontal > .os-scrollbar-track > .os-scrollbar-handle.active:before,
.os-custom > .os-scrollbar-vertical > .os-scrollbar-track > .os-scrollbar-handle.active:before {
  background: rgba(0, 0, 0, 0.7);
}

.os-custom > .os-scrollbar-horizontal > .os-scrollbar-track > .os-scrollbar-handle {
  height: 100%;
}

.os-custom > .os-scrollbar-vertical > .os-scrollbar-track > .os-scrollbar-handle {
  width: 100%;
}

.os-custom.os-host-transition > .os-scrollbar-horizontal > .os-scrollbar-track > .os-scrollbar-handle:before {
  transition: height 0.3s, margin-top 0.3s, background 0.2s;
}

.os-custom.os-host-transition > .os-scrollbar-vertical > .os-scrollbar-track > .os-scrollbar-handle:before {
  transition: width 0.3s, margin-inline-start 0.3s, background 0.2s;
}

.air-datepicker-global-container {
  z-index: 1055;
}

.air-datepicker {
  box-shadow: 0px 5px 8px rgba(0, 0, 0, 0.1);
}

.air-datepicker-nav--action path {
  stroke: #7F908F;
  stroke-width: 1px;
}

.air-datepicker-nav--action:hover {
  background-color: transparent;
}

.air-datepicker-nav--title {
  color: #7F908F;
}
.air-datepicker-nav--title i {
  color: #7F908F;
}
.air-datepicker-nav--title:hover {
  background-color: transparent;
}

.air-datepicker-body--day-names,
.air-datepicker-body--cells {
  justify-items: center;
  align-items: center;
}

.air-datepicker-body--day-name {
  color: #7F908F;
  width: 30px;
  height: 30px;
}

.air-datepicker-cell {
  transition: all ease 400ms;
}
.air-datepicker-cell.-focus- {
  transition: all ease 400ms;
}

.air-datepicker-body.-days- .air-datepicker-cell {
  width: 30px;
  height: 30px;
  border-radius: 50px;
}
.air-datepicker-body.-days- .air-datepicker-cell.-focus- {
  background-color: #7F908F;
  color: #ffffff;
}
.air-datepicker-body.-days- .air-datepicker-cell.-current- {
  color: #7F908F;
}
.air-datepicker-body.-days- .air-datepicker-cell.-current-.-focus- {
  color: #ffffff;
}
.air-datepicker-body.-days- .air-datepicker-cell.-selected- {
  background-color: #7F908F;
  color: #ffffff;
}

.air-datepicker-body--cells.-months- .air-datepicker-cell.-focus- {
  background-color: transparent;
}
.air-datepicker-body--cells.-months- .air-datepicker-cell.-current- {
  color: #7F908F;
}
.air-datepicker-body--cells.-months- .air-datepicker-cell.-selected- {
  background-color: transparent;
  color: #7F908F;
}

.air-datepicker-body--cells.-years- .air-datepicker-cell.-focus- {
  background-color: transparent;
}
.air-datepicker-body--cells.-years- .air-datepicker-cell.-current- {
  color: #7F908F;
}
.air-datepicker-body--cells.-years- .air-datepicker-cell.-selected {
  background-color: transparent;
  color: #7F908F;
}

.modal {
  overflow-y: hidden;
}

.modal-dialog {
  max-width: 100%;
}
@media (min-width: 414px) {
  .modal-dialog {
    max-width: 650px;
  }
}

.modal-dialog-scrollable .modal-content {
  overflow: initial;
}
.modal-dialog-scrollable .os-host {
  overflow: hidden !important;
}

.modal-body {
  position: relative;
}

.modal-title {
  font-size: 1.25rem;
  font-weight: 500;
  text-align: center;
}
@media (min-width: 768px) {
  .modal-title {
    font-size: 1.5rem;
  }
}

.btn-close:focus {
  box-shadow: none;
}

.c-modal {
  padding: 10px;
}
.c-modal .modal-content {
  height: 100%;
  max-height: 800px;
}

.c-spinner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  z-index: -1;
  transition: opacity 300ms;
}
.c-spinner.is-active {
  opacity: 1;
  z-index: 9999;
  transition: opacity 300ms;
}

.c-spinner-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  z-index: -1;
  transition: opacity 300ms;
}
.c-spinner-inner.is-active {
  opacity: 1;
  z-index: 9999;
  transition: opacity 300ms;
}

.accordion-button:focus {
  box-shadow: none;
  border: none;
}

.accordion-button:not(.collapsed) {
  color: currentColor;
  background-color: transparent;
  box-shadow: none;
}

.accordion-button {
  background-color: transparent;
  padding: 0;
}
.accordion-button::after {
  display: none;
}

.accordion-body {
  padding: 0;
}

.accordion-item {
  background-color: transparent;
  border: none;
}

.c-breadcrumb {
  position: relative;
  z-index: 1020;
}
.c-breadcrumb__list {
  display: flex;
}
.c-breadcrumb__list__item {
  flex: 0 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  color: rgba(0, 0, 0, 0.5);
  padding-inline-start: 8px;
}
.c-breadcrumb__list__item:first-child {
  padding-inline-start: 0;
}
.c-breadcrumb__list__item:first-child::before {
  display: none;
}
.c-breadcrumb__list__item::before {
  content: "";
  width: 32px;
  height: 1px;
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  background: #6d6d6d;
  opacity: 0.5;
  margin-inline-end: 8px;
}
.c-breadcrumb__list__item.is-active {
  flex: 0 1 auto;
  color: #000000;
}
.c-breadcrumb__list__item.is-active::before {
  flex: 0 0 auto;
  background-image: url("../images/other-icon/upload.svg");
}
.c-breadcrumb__list__item.is-active .link-text {
  word-break: break-all;
}
.c-breadcrumb__list__item .item__link {
  display: block;
  color: rgba(0, 0, 0, 0.5);
}
.c-breadcrumb__list__item .item__link:hover {
  color: black;
}
.c-breadcrumb__list__item .link-text {
  font-family: "Noto Sans TC", sans-serif;
  font-size: 0.875rem;
  line-height: 160%;
  letter-spacing: 0.02em;
  font-weight: 400;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  text-align: start;
}

.c-pagination {
  display: flex;
  justify-content: center;
  margin: 40px -5px 0 -5px;
}
@media (min-width: 992px) {
  .c-pagination {
    margin-top: 80px;
  }
}
.c-pagination .icon {
  width: 16px;
  height: 16px;
  color: #1E1E1E;
}
.c-pagination__item {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 5px;
}
.c-pagination__item.is-active .c-pagination__item__link {
  background-color: #7F908F;
  color: #ffffff;
}
.c-pagination__item__text {
  color: #1E1E1E;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (hover: hover) {
  .c-pagination__item__text:hover {
    color: #1E1E1E;
    background-color: transparent;
  }
}
.c-pagination__item__link {
  color: #1E1E1E;
  width: 30px;
  height: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
  border: none;
}
@media (hover: hover) {
  .c-pagination__item__link:hover {
    color: #1E1E1E;
    background-color: transparent;
  }
}

.c-btn-pill, .c-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 32px;
  transition: all ease-out 200ms;
  color: #162238;
  gap: 16px;
  z-index: 1;
}
.c-btn-pill::before, .c-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50px;
  background-image: linear-gradient(180deg, #c9bc9c 0%, #A59775 100%);
  z-index: -1;
  transition: inherit;
}
.c-btn-pill::after, .c-btn::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50px;
  background-image: linear-gradient(180deg, #1D2F4F 0%, #162238 100%);
  z-index: -2;
  transition: inherit;
  opacity: 0;
}
.c-btn-pill .hover-right-move, .c-btn .hover-right-move, .c-btn-pill .hover-left-move, .c-btn .hover-left-move {
  transition: inherit;
}
.c-btn-pill .hover-right-move, .c-btn .hover-right-move {
  transform: translateX(-8px);
}
.c-btn-pill .hover-left-move, .c-btn .hover-left-move {
  transform: translateX(8px);
}
.c-btn-pill .c-btn__text, .c-btn .c-btn__text {
  font-family: Marcellus;
  font-size: 1.125rem;
  line-height: 165%;
  letter-spacing: 0.03em;
  font-weight: 400;
}
.c-btn-pill .c-btn__icon .arrow path, .c-btn .c-btn__icon .arrow path {
  transition: all ease-out 200ms;
  stroke: #162238;
}
.c-btn-pill .c-btn__icon .line path, .c-btn .c-btn__icon .line path {
  transition: all ease-out 200ms;
  fill: #162238;
}
@media (hover: hover) {
  .c-btn-pill:hover, .c-btn:hover {
    color: #c9bc9c;
  }
  .c-btn-pill:hover::before, .c-btn:hover::before {
    opacity: 0;
  }
  .c-btn-pill:hover::after, .c-btn:hover::after {
    opacity: 1;
  }
  .c-btn-pill:hover .hover-right-move, .c-btn:hover .hover-right-move {
    transform: translateX(0px);
  }
  .c-btn-pill:hover .hover-left-move, .c-btn:hover .hover-left-move {
    transform: translateX(0px);
  }
  .c-btn-pill:hover .arrow path, .c-btn:hover .arrow path {
    stroke: #c9bc9c;
  }
  .c-btn-pill:hover .line path, .c-btn:hover .line path {
    fill: #c9bc9c;
  }
}

.c-btn-pill {
  border-radius: 50px;
  border: 1px solid #c9bc9c;
  min-width: 199px;
}
.c-btn-pill.-start- {
  padding-left: 40px;
  padding-right: 32px;
}
.c-btn-pill.-end- {
  justify-content: flex-end;
  padding-left: 32px;
  padding-right: 44px;
}

.c-card {
  position: relative;
  cursor: pointer;
  transition: all ease 400ms;
}
@media (hover: hover) {
  .c-card:hover {
    transition: all ease 400ms;
  }
  .c-card:hover .c-card__img img {
    transform: translate(-50%, -50%) scale(1.1);
    transition: all ease 400ms;
  }
}
.c-card__head {
  position: relative;
  overflow: hidden;
  margin-bottom: 14px;
}
@media (min-width: 768px) {
  .c-card__head {
    margin-bottom: 16px;
  }
}
.c-card__body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 1px;
}
.c-card__footer {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.c-card__img {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 56.2162162162%;
}
.c-card__img img, .c-card__img video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: all ease 400ms;
}
.c-card__img video {
  z-index: -1;
}
.c-card__title {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-align: start;
  font-weight: 700;
}
.c-card__text {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-align: start;
}

.c-field {
  display: flex;
  flex-direction: column;
  margin-bottom: 17px;
}
@media (min-width: 992px) {
  .c-field {
    flex-direction: row;
    margin-bottom: 30px;
  }
}
.c-field:last-child {
  margin-bottom: 0;
}
@media (min-width: 992px) {
  .c-field.sty-column {
    flex-direction: column;
  }
}
.c-field.sty-column .c-field__start {
  margin-bottom: 8px;
}
.c-field__start {
  width: 30%;
  margin-bottom: 8px;
}
@media (min-width: 992px) {
  .c-field__start {
    margin-bottom: 0;
  }
}
.c-field__end {
  width: 100%;
}

.c-label {
  width: 100%;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  font-weight: 500;
  line-height: 100%;
  transition: all ease 400ms;
}

.c-input-group {
  width: 100%;
  display: flex;
}
.c-input-group > * {
  width: 100%;
  display: flex;
  flex-direction: column;
  margin-inline-end: 10px;
}
.c-input-group > *:last-child {
  margin-inline-end: 0;
}

.c-input {
  width: 100%;
  display: flex;
  align-items: center;
}
.c-input input {
  width: 100%;
  transition: all ease 400ms;
}
.c-input__clear {
  width: 15px;
  height: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all ease 400ms;
}
.c-input__clear .icon {
  width: 15px;
  height: 15px;
}

.c-input-file {
  cursor: pointer;
}
.c-input-file * {
  cursor: pointer;
}
.c-input-file input[type=file] {
  width: 0;
  height: 0;
  display: inline-block;
  position: absolute;
  z-index: -1;
  opacity: 0;
}
.c-input-file .c-input-text {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-input-file .c-input-text .icon {
  width: 16px;
  height: 16px;
  border: 1px solid #1FA809;
  margin-inline-start: 8px;
}

.c-file-group {
  display: flex;
  flex-direction: column;
  margin-top: 20px;
  margin-inline-start: -20px;
  margin-inline-end: -20px;
}
.c-file-group > * {
  margin-bottom: 10px;
  padding-inline-start: 20px;
  padding-inline-end: 20px;
}
.c-file-group > *:last-child {
  margin-bottom: 0;
}
.c-file-group .icon-clear {
  cursor: pointer;
  width: 25px;
  height: 25px;
  position: absolute;
  top: -10px;
  right: -10px;
  border: 1px solid #1FA809;
}

.c-file-img {
  height: 360px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #ffffff;
  border: 1px solid #F0F0F0;
  border-radius: 8px;
  position: relative;
  padding: 30px;
}
.c-file-img img {
  width: auto;
  height: 100%;
  object-fit: contain;
  object-position: center center;
}

.c-file-text {
  position: relative;
  display: inline-flex;
  font-size: 0.875rem;
  margin-top: 4px;
}

.c-textarea {
  position: relative;
  width: 100%;
  height: 128px;
  border-radius: 8px;
  border: 1px solid #999999;
  transition: all ease 400ms;
}
.c-textarea textarea {
  width: 100%;
  height: 100%;
  padding: 12px 22px;
}
.c-textarea textarea::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
.c-textarea textarea::-webkit-scrollbar-button {
  width: 6px;
  height: 6px;
  display: none;
}
.c-textarea textarea::-webkit-scrollbar-track {
  background-color: #F0F0F0;
  border: 0;
  border-radius: 50px;
}
.c-textarea textarea::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.7);
  border: 0;
  border-radius: 50px;
  cursor: pointer;
}
.c-textarea textarea::-webkit-scrollbar-thumb:hover {
  background-color: rgba(0, 0, 0, 0.7);
}
@-moz-document url-prefix() {
  .c-textarea textarea {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.7) #F0F0F0;
  }
}

.c-checkbox-group {
  display: flex;
  flex-wrap: wrap;
  margin-inline-start: -10px;
  margin-inline-end: -10px;
  margin-bottom: -20px;
}
.c-checkbox-group > * {
  margin-inline-start: 10px;
  margin-inline-end: 10px;
  margin-bottom: 20px;
}

.c-checkbox, .c-radio {
  display: flex;
  align-items: center;
}
.c-checkbox label, .c-radio label {
  cursor: pointer;
}
.c-checkbox input[type=checkbox], .c-checkbox input[type=radio], .c-radio input[type=checkbox], .c-radio input[type=radio] {
  position: relative;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  cursor: pointer;
  margin-inline-end: 10px;
  border: 1px solid #1FA809;
}
.c-checkbox input[type=checkbox]::before, .c-checkbox input[type=radio]::before, .c-radio input[type=checkbox]::before, .c-radio input[type=radio]::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.c-checkbox input[type=checkbox]:checked::before, .c-checkbox input[type=radio]:checked::before, .c-radio input[type=checkbox]:checked::before, .c-radio input[type=radio]:checked::before {
  content: "";
}

.c-select {
  width: 100%;
  transition: all ease 400ms;
}

.c-hint {
  font-size: 0.75rem;
  color: #999999;
  margin-top: 4px;
  transition: all ease 400ms;
}
@media (min-width: 992px) {
  .c-hint {
    font-size: 0.875rem;
  }
}
.c-hint.is-error {
  color: #FE2828;
}

[field-state] {
  transition: all ease 400ms;
}
[field-state] .c-hint.is-error {
  display: none;
}
[field-state].is-disabled {
  opacity: 0.5;
  pointer-events: none;
}
[field-state].is-hidden {
  display: none;
}
[field-state].is-error .c-label {
  color: #FE2828;
}
[field-state].is-error .c-hint.is-error {
  display: block;
}

[input-state] {
  transition: all ease 400ms;
}
[input-state].is-disabled {
  opacity: 0.5;
  pointer-events: none;
}
[input-state].is-hidden {
  display: none;
}
[input-state].is-focus .c-input {
  border-color: #7F908F;
}
[input-state].is-typing .c-input__clear {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: all ease 400ms;
}
[input-state].is-error .c-input, [input-state].is-error .c-textarea {
  border: 1px solid #FE2828;
}
[input-state].is-error .c-input__clear {
  color: #FE2828;
  transition: all ease 400ms;
}
[input-state].is-error .c-select .selectric, [input-state].is-error .c-select .select2-container--default .select2-selection--single {
  border-color: #FE2828;
}
[input-state].is-error .c-hint.is-error {
  display: block;
}

.c-toast {
  min-width: 214px;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -40%);
  border-radius: 8px;
  line-height: 145%;
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
  padding: 27px 42px;
  opacity: 0;
  pointer-events: none;
  z-index: 1080;
  transition: all ease 400ms;
}
.c-toast.is-show {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, -50%);
  transition: all ease 400ms;
}
.c-toast__icon {
  width: 56px;
  height: 56px;
  border-radius: 50px;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 8px;
}
.c-toast__icon .icon {
  width: 28px;
  height: 28px;
  color: #7F908F;
}
.c-toast__text {
  text-align: center;
}

@media (min-width: 992px) {
  .smooth-scroll-target {
    position: relative;
    overflow: visible;
    transition: all ease-out 300ms;
    transform: translate3d(0, min(0%, max(var(--smooth-scroll-progress, 0) * (-100% + var(--vh, 1vh) * 100), -100% + var(--vh, 1vh) * 100)), 0);
  }
}

@media (min-width: 992px) {
  .smooth-scroll-container {
    position: sticky;
    top: 0;
    overflow: hidden;
    height: 100vh;
  }
}

.m-editor .article-system-wrap {
  padding-bottom: 30px;
}
@media (min-width: 768px) {
  .m-editor .article-system-wrap {
    padding-top: 80px;
    padding-bottom: 100px;
  }
}
.m-editor .nsdi-article-system {
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .m-editor .nsdi-article-system {
    margin-bottom: 56px;
  }
}
.m-editor .nsdi-article-system .row {
  align-items: center;
  margin-inline-start: -20px;
  margin-inline-end: -20px;
}
.m-editor .nsdi-article-system .row > * {
  padding-inline-start: 20px;
  padding-inline-end: 20px;
}
.m-editor .nas-image-wrapper img {
  border-radius: 5px;
  border-top-right-radius: 40px;
  border-bottom-left-radius: 40px;
  overflow: hidden;
  width: 100%;
}
.m-editor .nas-article {
  margin-top: 20px;
}
@media (min-width: 768px) {
  .m-editor .nas-article {
    margin-top: 0;
  }
}
.m-editor #T6 {
  margin-bottom: -24px;
}
.m-editor #T6 .nas-image-wrapper {
  margin-bottom: 24px;
}
.m-editor > div:last-child .nsdi-article-system {
  margin-bottom: 0;
}

.m-header {
  position: relative;
  overflow: hidden;
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 29.1666666667%;
}
.m-header img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}

.m-cards {
  margin-bottom: -36px;
}
@media (min-width: 1200px) {
  .m-cards {
    margin-bottom: -96px;
  }
}
.m-cards > * {
  margin-bottom: 36px;
}
@media (min-width: 1200px) {
  .m-cards > * {
    margin-bottom: 96px;
  }
}

body {
  --nav-height: 66px;
}
@media (min-width: 992px) {
  body {
    --nav-height: 128px;
  }
}

.l-nav {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 1040;
  transition: all ease 400ms;
}
@media (min-width: 992px) {
  .l-nav {
    margin-bottom: calc(var(--nav-height, 0px) * -1);
  }
}
@media (max-width: 991.98px) {
  .l-nav .pc-show {
    display: none;
  }
}
@media (min-width: 992px) {
  .l-nav .mobile-show {
    display: none;
  }
}
.l-nav__trigger {
  position: relative;
  top: 5px;
}
.l-nav__container {
  padding-top: 18px;
  padding-bottom: 18px;
  padding-left: 32px;
  padding-right: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (min-width: 992px) {
  .l-nav__container {
    padding-top: 28px;
    padding-bottom: 28px;
    padding-left: 72px;
    padding-right: 64px;
  }
}
.l-nav__logo {
  position: relative;
  white-space: nowrap;
  overflow: hidden;
  text-indent: 101%;
}
.l-nav__logo__img {
  display: grid;
}
.l-nav__logo__img > * {
  grid-area: 1/1;
  transition: all ease 400ms;
  transition-duration: inherit;
}
.l-nav__logo__img img {
  width: calc(214.268px * var(--nav-leave-top-logo-size, 0.75));
  transition: all ease-out 300ms;
}
@media (max-width: 991.98px) {
  .l-nav__logo__img img {
    width: 120px;
  }
}
.l-nav__logo__inner {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 1;
}
@media (min-width: 992px) {
  .l-nav__menu {
    position: relative;
    padding: 20px 48px;
  }
  .l-nav__menu::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 1000px;
    background: linear-gradient(180deg, #1D2F4F 0%, #162238 100%);
    transition: all ease-out 300ms;
    opacity: var(--nav-leave-top, 1);
  }
  .l-nav__menu .link-group {
    display: flex;
    align-items: center;
    gap: 40px;
  }
  .l-nav__menu .link-group .item-text {
    font-family: "Noto Sans TC", sans-serif;
    font-size: 1.125rem;
    line-height: 180%;
    letter-spacing: 0.02em;
    font-weight: 400;
    color: var(--nav-active-text-color, var(--nav-leave-top-text-color, #ffffff));
    transition: all ease-out 300ms;
  }
  .l-nav__menu .link-group .item {
    position: relative;
  }
  .l-nav__menu .link-group .item::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    transition: all ease-out 300ms;
    transform: scaleX(0);
    transform-origin: left;
    background: #c9bc9c;
  }
  .l-nav__menu .link-group .item:hover {
    --nav-active-text-color: #c9bc9c;
  }
  .l-nav__menu .link-group .item:hover::before {
    transform: scaleX(1);
  }
}
@media (max-width: 991.98px) {
  .l-nav__menu {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(var(--vh, 1vh) * 100);
    background-color: #ffffff;
    z-index: -1;
    transition: all ease-out 300ms;
    padding: 0 32px;
  }
  .l-nav__menu .link-group {
    padding-top: calc(var(--nav-height, 0px) + 64px);
  }
  .l-nav__menu .link-group .item-text {
    font-family: "Noto Serif TC", sans-serif;
    font-size: 1.5rem;
    letter-spacing: 0.02em;
    line-height: 160%;
    font-weight: 700;
    color: #000000;
  }
  .l-nav__menu .link-group .item {
    position: relative;
  }
  .l-nav__menu .link-group .item + .item {
    margin-top: 32px;
  }
}
.l-nav__btn-group .btn-group {
  display: flex;
  align-items: center;
  gap: 16px;
}
.l-nav__btn-group .btn-group .item {
  position: relative;
}
.l-nav__btn-group .item.-toggle-menu- {
  padding: 12px;
  background: #29416b;
  border-radius: 1000px;
}
.l-nav__btn-group .item.-toggle-menu- .btn-img {
  display: grid;
}
.l-nav__btn-group .item.-toggle-menu- .btn-img > * {
  grid-area: 1/1;
  transition: all ease 400ms;
  transition-duration: inherit;
}
.l-nav__btn-group .item.-toggle-menu- .btn-img .img-container {
  transition: all ease-out 300ms;
}
@media (max-width: 991.98px) {
  .l-nav:not(.-open-menu-) .l-nav__menu {
    opacity: 0;
    pointer-events: none;
  }
  .l-nav:not(.-open-menu-) .l-nav__btn-group .item.-toggle-menu- .-open- {
    opacity: 0;
  }
}
@media (max-width: 991.98px) {
  .l-nav.-open-menu- .l-nav__btn-group .item.-toggle-menu- .-idle- {
    opacity: 0;
  }
}
.l-nav:not(.-leave-top-) {
  --nav-leave-top: 0;
  --nav-leave-top-text-color: #000000;
  --nav-leave-top-logo-size: 1;
}
.l-nav:not(.-leave-top-).-menu-text-color-reverse- {
  --nav-leave-top-text-color: #ffffff;
}
.l-nav:not(.-logo-color-reverse-) .l-nav__logo__img .-reverse- {
  opacity: 0;
}
.l-nav.-logo-color-reverse- .l-nav__logo__img .-general- {
  opacity: 0;
}

.l-footer {
  border-top-left-radius: 40px;
  border-top-right-radius: 40px;
  background-color: #1d2f4f;
  color: #ffffff;
}
@media (max-width: 991.98px) {
  .l-footer {
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
  }
}
.l-footer__container {
  padding: 24px 120px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 991.98px) {
  .l-footer__container {
    padding: 32px;
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
  }
}
.l-footer__social .item-group {
  display: flex;
  justify-content: center;
  gap: 32px;
}
.l-footer__social .item-group .item {
  position: relative;
}
.l-footer__other .item-group {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 48px;
}
@media (max-width: 991.98px) {
  .l-footer__other .item-group {
    flex-direction: column;
    gap: 8px;
  }
}
.l-footer__other .item {
  position: relative;
}
.l-footer__other .item-text {
  font-family: "Noto Sans TC", sans-serif;
  font-size: 0.875rem;
  line-height: 160%;
  letter-spacing: 0.02em;
  font-weight: 400;
}
.l-footer__other .item + .item {
  position: relative;
}
@media (min-width: 992px) {
  .l-footer__other .item + .item::before {
    position: absolute;
    top: 0;
    left: -25px;
    display: block;
    content: "";
    width: 1px;
    height: 24px;
    background-color: rgba(176, 176, 176, 0.2);
  }
}

.l-loading {
  background-color: #ffffff;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
}
.l-loading.is-hidden {
  opacity: 0;
  z-index: -99;
  transition: all ease 400ms;
}

[data-page=index] main .page-section {
  position: relative;
}
[data-page=index] main .-kv- {
  display: grid;
  align-items: flex-start;
}
[data-page=index] main .-kv- > * {
  grid-area: 1/1;
  transition: all ease 400ms;
  transition-duration: inherit;
}
[data-page=index] main .-kv- .kv-banner {
  padding-top: 96px;
  position: relative;
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner {
    overflow: hidden;
  }
}
[data-page=index] main .-kv- .kv-banner__slider {
  position: relative;
  display: block;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100vw - 200px);
  max-width: 1380px;
  padding-left: 66px;
}
@media (max-width: 1399.98px) {
  [data-page=index] main .-kv- .kv-banner__slider {
    width: calc(100vw - 120px);
  }
}
[data-page=index] main .-kv- .kv-banner__slider .swiper {
  border-top-left-radius: 680px;
  border-top-right-radius: 680px;
  overflow: hidden;
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner__slider {
    padding-left: 0;
    width: 155vw;
  }
}
[data-page=index] main .-kv- .kv-banner__item {
  position: relative;
  aspect-ratio: 1313/920;
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner__item {
    aspect-ratio: 583/389;
  }
}
[data-page=index] main .-kv- .kv-banner__item .img-container {
  width: 100%;
  height: 100%;
}
[data-page=index] main .-kv- .kv-banner__item .img-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
[data-page=index] main .-kv- .kv-banner__slider-nav {
  position: absolute;
  left: calc(50% + 33px);
  transform: translateX(-50%);
  width: auto;
  z-index: 1;
}
@media (min-width: 992px) {
  [data-page=index] main .-kv- .kv-banner__slider-nav {
    bottom: 56px;
    --swiper-pagination-bullet-horizontal-gap: 7.65px;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner__slider-nav {
    left: 50%;
    bottom: 40px;
  }
}
[data-page=index] main .-kv- .kv-banner__slider-nav .swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.4;
}
[data-page=index] main .-kv- .kv-banner__slider-nav .swiper-pagination-bullet-active {
  background: #c9bc9c;
  opacity: 1;
}
[data-page=index] main .-kv- .kv-banner__title {
  position: absolute;
  left: 10.8333333333%;
  bottom: 150px;
  font-family: Poppins, sans-serif;
  font-size: 6.5rem;
  font-weight: 300;
  line-height: 120%;
  letter-spacing: 0.04em;
  color: #c9bc9c;
  pointer-events: none;
}
@media (max-width: 1619.98px) {
  [data-page=index] main .-kv- .kv-banner__title {
    left: 60px;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner__title {
    left: 24px;
    bottom: unset;
    top: 50.75%;
    font-size: 4.0625rem;
    font-weight: 300;
    line-height: 120%;
    letter-spacing: 0.04em;
  }
}
@media (max-width: 767.98px) {
  [data-page=index] main .-kv- .kv-banner__title {
    font-size: 2.5888125rem;
  }
}
[data-page=index] main .-kv- .kv-banner__news {
  position: absolute;
  right: 0;
  bottom: 0;
  margin-bottom: -96px;
  display: flex;
  gap: 48px;
  border-top-left-radius: 40px;
  border-bottom-left-radius: 5px;
  background: #c9bc9c;
  padding-top: 32px;
  padding-bottom: 32px;
  padding-left: 56px;
  min-width: 696px;
}
@media (max-width: 1399.98px) {
  [data-page=index] main .-kv- .kv-banner__news {
    min-width: 600px;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner__news {
    min-width: 0;
    position: relative;
    right: unset;
    left: 100%;
    transform: translateX(-100%);
    width: calc(100% - 48px);
    max-width: 330px;
    margin-top: -16px;
    margin-bottom: 0;
    border-top-left-radius: 20px;
    border-bottom-left-radius: 3px;
    padding-top: 20px;
    padding-bottom: 20px;
    padding-left: 32px;
    padding-right: 32px;
    flex-direction: column;
    gap: 8px;
  }
}
[data-page=index] main .-kv- .kv-banner__news .title {
  position: relative;
  font-family: "Noto Serif TC", serif;
}
@media (min-width: 992px) {
  [data-page=index] main .-kv- .kv-banner__news .title {
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 120%;
    letter-spacing: 0.02em;
    color: #000000;
    width: 17px;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner__news .title {
    font-size: 1rem;
    font-weight: 600;
    line-height: 120%;
    letter-spacing: 0.02em;
    color: #000000;
    width: fit-content;
    z-index: 1;
  }
  [data-page=index] main .-kv- .kv-banner__news .title::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% + 12px);
    height: 100%;
    background: #c9bc9c;
    z-index: -1;
  }
}
[data-page=index] main .-kv- .kv-banner__news .text {
  position: relative;
  font-weight: 400;
  color: #000000;
}
@media (min-width: 992px) {
  [data-page=index] main .-kv- .kv-banner__news .text {
    font-family: "Noto Sans TC", sans-serif;
    font-size: 1rem;
    line-height: 180%;
    letter-spacing: 0.02em;
  }
  [data-page=index] main .-kv- .kv-banner__news .text::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -24px;
    display: block;
    width: 1px;
    height: 100%;
    background-color: #000000;
    transform: translateY(-50%);
    opacity: 0.2;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-banner__news .text {
    font-size: 0.75rem;
    line-height: 160%;
    letter-spacing: 0.02em;
  }
  [data-page=index] main .-kv- .kv-banner__news .text::before {
    content: "";
    position: absolute;
    top: -17.5px;
    width: 100%;
    height: 1px;
    background-color: #000000;
    opacity: 0.2;
  }
}
[data-page=index] main .-kv- .kv-bg {
  position: relative;
  overflow: hidden;
  height: 1176px;
  z-index: -1;
}
@media (max-width: 1399.98px) {
  [data-page=index] main .-kv- .kv-bg {
    height: 81.6666666667vw;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-bg {
    height: 149.8714652956vw;
  }
}
@media (max-width: 575.98px) {
  [data-page=index] main .-kv- .kv-bg {
    height: calc(149.8714652956vw + 155px);
  }
}
[data-page=index] main .-kv- .kv-bg .arch {
  position: absolute;
  top: 232px;
  left: 0;
  width: 80.625vw;
}
[data-page=index] main .-kv- .kv-bg .arch svg {
  width: 100%;
  height: auto;
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-bg .arch {
    top: 23px;
    width: 132.2666666667vw;
    left: -59.2986666667vw;
  }
}
[data-page=index] main .-kv- .kv-bg .deco-rect {
  position: absolute;
  width: 800px;
  height: 304px;
}
@media (max-width: 1619.98px) {
  [data-page=index] main .-kv- .kv-bg .deco-rect {
    width: 48.4848484848vw;
  }
}
[data-page=index] main .-kv- .kv-bg .deco-rect.-left- {
  bottom: 0;
  left: -344px;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 40px;
  opacity: 0.5;
  background: #29416b;
  border-color: #c9bc9c;
  mask: linear-gradient(180deg, transparent 0%, black 100%);
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-bg .deco-rect.-left- {
    width: 98px;
    height: 304px;
    left: -8px;
  }
}
[data-page=index] main .-kv- .kv-bg .deco-rect.-right- {
  bottom: 223px;
  right: -56px;
  background: #29416b;
  border-color: #c9bc9c;
  mask: linear-gradient(0deg, transparent 0%, black 100%);
}
@media (max-width: 991.98px) {
  [data-page=index] main .-kv- .kv-bg .deco-rect.-right- {
    width: 55.7333333333vw;
    height: 294px;
    right: -70px;
    bottom: unset;
    top: 128px;
  }
}
[data-page=index] main .-intro- {
  position: relative;
  display: grid;
}
[data-page=index] main .-intro- > * {
  grid-area: 1/1;
  transition: all ease 400ms;
  transition-duration: inherit;
}
[data-page=index] main .-intro- .scroll-progress-area {
  position: absolute;
  left: 50%;
  width: 1px;
  height: 100vh;
}
@media (min-width: 992px) {
  [data-page=index] main .-intro- .scroll-progress-area {
    top: 0;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-intro- .scroll-progress-area {
    bottom: 0;
  }
}
[data-page=index] main .-intro- .intro {
  position: relative;
  z-index: 1;
  display: flex;
  padding-top: 157px;
  padding-bottom: 157px;
}
@media (max-width: 991.98px) {
  [data-page=index] main .-intro- .intro {
    flex-direction: column-reverse;
    gap: 84px;
  }
}
[data-page=index] main .-intro- .intro .start {
  position: relative;
  height: calc(min(max(250px, 0.1305555556 * 100vw + 93.3333333333px), 344px) * 480 / 344 + min(max(180px, 0.15 * 100vw + 0px), 288px));
}
@media (min-width: 992px) {
  [data-page=index] main .-intro- .intro .start {
    flex: 1 1 calc(50% + 40px);
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-intro- .intro .start {
    padding-right: 24px;
    height: calc(59.7333333333vw + min(max(168px, 0.3241491086 * 100vw + 46.4440842788px), 368px));
  }
}
[data-page=index] main .-intro- .intro .start img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
[data-page=index] main .-intro- .intro .start .hoz-img {
  position: absolute;
  left: 0;
  border-top-right-radius: 40px;
  overflow: hidden;
  width: 83.6734693878%;
  max-width: 820px;
  aspect-ratio: 820/508;
  z-index: 1;
  transition: all ease-out 0.3s;
  transform: translateY(calc(var(--intro-scroll-progress, 0) * 64px));
}
@media (max-width: 991.98px) {
  [data-page=index] main .-intro- .intro .start .hoz-img {
    border-top-right-radius: 20px;
    width: 80.5333333333%;
    aspect-ratio: 302/236;
  }
}
[data-page=index] main .-intro- .intro .start .deco-rect {
  position: absolute;
  right: 112px;
  top: min(max(220px, 0.3055555556 * 100vw + -146.6666666667px), 440px);
  width: min(max(248px, 0.3875 * 100vw + -217px), 527px);
  height: 283px;
  z-index: 2;
  background: #ffffff linear-gradient(0deg, rgba(41, 65, 107, 0) 0%, #29416b 100%);
  border-color: #c9bc9c;
  mask: linear-gradient(0deg, transparent 0%, black 50%);
  border-radius: 5px;
  border-top-left-radius: 40px;
  transition: all ease-out 0.3s;
  transform: translateY(calc(var(--intro-scroll-progress, 0) * 75px));
}
@media (max-width: 991.98px) {
  [data-page=index] main .-intro- .intro .start .deco-rect {
    top: min(max(205px, 0.4457050243 * 100vw + 37.8606158833px), 480px);
    border-radius: 2.33px;
    border-top-left-radius: 18.6px;
    height: 35.4666666667vw;
    width: 66.1333333333vw;
    right: 48px;
  }
}
[data-page=index] main .-intro- .intro .start .ver-img {
  position: absolute;
  top: min(max(180px, 0.15 * 100vw + 0px), 288px);
  right: 0;
  width: min(max(250px, 0.1305555556 * 100vw + 93.3333333333px), 344px);
  aspect-ratio: 344/480;
  border-radius: 5px;
  border-bottom-left-radius: 40px;
  overflow: hidden;
  z-index: 3;
  transition: all ease-out 0.3s;
  transform: translateY(calc(var(--intro-scroll-progress, 0) * -48px));
}
@media (max-width: 991.98px) {
  [data-page=index] main .-intro- .intro .start .ver-img {
    top: min(max(168px, 0.3241491086 * 100vw + 46.4440842788px), 368px);
    right: 24px;
    width: 42.6666666667vw;
    aspect-ratio: 160/224;
  }
}
@media (min-width: 992px) {
  [data-page=index] main .-intro- .intro .end {
    flex: 1 1 calc(50% - 40px);
    padding-top: 152px;
    padding-left: min(max(60px, 0.2263888889 * 100vw + -211.6666666667px), 223px);
  }
  [data-page=index] main .-intro- .intro .end .title {
    font-family: "Noto Serif TC", sans-serif;
    font-size: 3rem;
    letter-spacing: 0.02em;
    line-height: 140%;
    font-weight: 700;
    color: #29416b;
    margin-bottom: 56px;
  }
  [data-page=index] main .-intro- .intro .end .text {
    font-family: "Noto Sans TC", sans-serif;
    font-size: 1.125rem;
    line-height: 180%;
    letter-spacing: 0.02em;
    font-weight: 400;
    color: #000000;
    margin-bottom: 32px;
    max-width: 437px;
  }
}
@media (max-width: 991.98px) {
  [data-page=index] main .-intro- .intro .end {
    padding-left: 32px;
    padding-right: 32px;
  }
  [data-page=index] main .-intro- .intro .end .title {
    font-family: "Noto Serif TC", sans-serif;
    font-size: 1.75rem;
    letter-spacing: 0.02em;
    line-height: 140%;
    font-weight: 700;
    color: #29416b;
    margin-bottom: 24px;
  }
  [data-page=index] main .-intro- .intro .end .text {
    font-family: "Noto Sans TC", sans-serif;
    font-size: 1rem;
    line-height: 180%;
    letter-spacing: 0.02em;
    font-weight: 400;
    color: #000000;
    margin-bottom: 24px;
    max-width: 437px;
  }
  [data-page=index] main .-intro- .intro .end .c-btn-pill {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
[data-page=index] main .-intro- .intro-bg {
  position: relative;
  overflow-x: hidden;
  z-index: -1;
}
[data-page=index] main .-intro- .intro-bg .arch {
  position: absolute;
  top: 0;
  right: -21.1979166667vw;
  width: 87.1354166667vw;
  mask: linear-gradient(0deg, transparent 0%, black 80%);
  transition: all ease-out 0.3s;
  transform: translateX(calc(var(--intro-scroll-progress, 0) * -64px));
}
[data-page=index] main .-intro- .intro-bg .arch svg {
  width: 100%;
  height: auto;
}

[data-page=privacy] .page-section, [data-page=contact] .page-section, [data-page=services] .page-section, [data-page=about] .page-section, [data-page=partners__list] .page-section {
  position: relative;
  width: 100%;
  display: grid;
  justify-content: center;
  justify-items: center;
}
[data-page=privacy] .page-section > *, [data-page=contact] .page-section > *, [data-page=services] .page-section > *, [data-page=about] .page-section > *, [data-page=partners__list] .page-section > * {
  grid-area: 1/1;
  transition: all ease 400ms;
  transition-duration: inherit;
}
@media (min-width: 992px) {
  [data-page=privacy] .page-section, [data-page=contact] .page-section, [data-page=services] .page-section, [data-page=about] .page-section, [data-page=partners__list] .page-section {
    padding-top: var(--nav-height, 0px);
  }
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section, [data-page=contact] .page-section, [data-page=services] .page-section, [data-page=about] .page-section, [data-page=partners__list] .page-section {
    overflow-x: hidden;
  }
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section .-pc-show-, [data-page=contact] .page-section .-pc-show-, [data-page=services] .page-section .-pc-show-, [data-page=about] .page-section .-pc-show-, [data-page=partners__list] .page-section .-pc-show- {
    display: none;
  }
}
@media (min-width: 992px) {
  [data-page=privacy] .page-section .-mobile-show-, [data-page=contact] .page-section .-mobile-show-, [data-page=services] .page-section .-mobile-show-, [data-page=about] .page-section .-mobile-show-, [data-page=partners__list] .page-section .-mobile-show- {
    display: none;
  }
}

[data-page=privacy] .page-section__intro, [data-page=contact] .page-section__intro, [data-page=services] .page-section__intro, [data-page=about] .page-section__intro, [data-page=partners__list] .page-section__card-group {
  padding-top: 112px;
  padding-bottom: 212px;
  width: calc(100vw - 144px);
  max-width: 1520px;
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section__intro, [data-page=contact] .page-section__intro, [data-page=services] .page-section__intro, [data-page=about] .page-section__intro, [data-page=partners__list] .page-section__card-group {
    width: calc(100vw - 64px);
    padding-top: 50px;
    padding-bottom: 104px;
  }
}
[data-page=privacy] .page-section__intro > .title, [data-page=contact] .page-section__intro > .title, [data-page=services] .page-section__intro > .title, [data-page=about] .page-section__intro > .title, [data-page=partners__list] .page-section__card-group > .title {
  font-family: "Noto Serif TC", sans-serif;
  font-size: 4rem;
  letter-spacing: 0.02em;
  line-height: 120%;
  font-weight: 700;
  color: #29416b;
  margin-bottom: 24px;
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section__intro > .title, [data-page=contact] .page-section__intro > .title, [data-page=services] .page-section__intro > .title, [data-page=about] .page-section__intro > .title, [data-page=partners__list] .page-section__card-group > .title {
    font-family: "Noto Serif TC", sans-serif;
    font-size: 2.5rem;
    letter-spacing: 0.02em;
    line-height: 140%;
    margin-bottom: 16px;
  }
}

[data-page=privacy] .page-section__bg, [data-page=contact] .page-section__bg, [data-page=services] .page-section__bg, [data-page=about] .page-section__bg, [data-page=partners__list] .page-section__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 80vh;
  pointer-events: none;
  overflow: hidden;
  z-index: -1;
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section__bg, [data-page=contact] .page-section__bg, [data-page=services] .page-section__bg, [data-page=about] .page-section__bg, [data-page=partners__list] .page-section__bg {
    height: 60vh;
  }
}
[data-page=privacy] .page-section__bg .arch, [data-page=contact] .page-section__bg .arch, [data-page=services] .page-section__bg .arch, [data-page=about] .page-section__bg .arch, [data-page=partners__list] .page-section__bg .arch {
  position: absolute;
  top: 0;
  right: 0;
  width: 65.9375%;
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section__bg .arch, [data-page=contact] .page-section__bg .arch, [data-page=services] .page-section__bg .arch, [data-page=about] .page-section__bg .arch, [data-page=partners__list] .page-section__bg .arch {
    top: 168px;
    width: 76.5333333333%;
  }
}
[data-page=privacy] .page-section__bg .arch svg, [data-page=contact] .page-section__bg .arch svg, [data-page=services] .page-section__bg .arch svg, [data-page=about] .page-section__bg .arch svg, [data-page=partners__list] .page-section__bg .arch svg {
  display: block;
  width: 100%;
  height: auto;
}

[data-page=partners__list] .page-section__card-group .breadcrumb {
  margin-bottom: 93px;
}
@media (max-width: 991.98px) {
  [data-page=partners__list] .page-section__card-group .breadcrumb {
    margin-bottom: 162px;
  }
}
[data-page=partners__list] .page-section__card-group .filter {
  margin-bottom: 56px;
}
[data-page=partners__list] .page-section__card-group .filter .category-section {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 16px;
}
[data-page=partners__list] .page-section__card-group .filter .category-section .start {
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 160%;
  letter-spacing: 0.02em;
  color: #000000;
}
@media (max-width: 991.98px) {
  [data-page=partners__list] .page-section__card-group .filter .category-section .start {
    font-size: 1rem;
  }
}
[data-page=partners__list] .page-section__card-group .filter .category-section .end {
  position: relative;
  width: 240px;
}
@media (max-width: 991.98px) {
  [data-page=partners__list] .page-section__card-group .filter .category-section .end {
    width: 262px;
  }
}
[data-page=partners__list] .page-section__card-group .item-group .item {
  position: relative;
}
[data-page=partners__list] .page-section__card-group .item-group .row {
  --bs-gutter-y: 56px;
  margin-inline-start: -20px;
  margin-inline-end: -20px;
}
@media (max-width: 991.98px) {
  [data-page=partners__list] .page-section__card-group .item-group .row {
    --bs-gutter-y: 32px;
  }
}
[data-page=partners__list] .page-section__card-group .item-group .row > * {
  padding-inline-start: 20px;
  padding-inline-end: 20px;
}
[data-page=partners__list] .page-section__card-group .item-card {
  position: relative;
  width: 100%;
  transition: all ease-out 200ms;
}
[data-page=partners__list] .page-section__card-group .item-card .img-container {
  border-radius: 5px;
  border-top-right-radius: 40px;
  border-bottom-left-radius: 40px;
  overflow: hidden;
  aspect-ratio: 480/264;
}
[data-page=partners__list] .page-section__card-group .item-card .img-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
[data-page=partners__list] .page-section__card-group .item-card .content {
  margin-top: 8px;
  padding-left: 8px;
  padding-right: 8px;
  display: flex;
  align-items: center;
}
[data-page=partners__list] .page-section__card-group .item-card .content .start {
  flex: 1;
}
[data-page=partners__list] .page-section__card-group .item-card .content .end {
  flex: 0 0 20px;
}
[data-page=partners__list] .page-section__card-group .item-card .content .title {
  font-family: "Noto Serif TC", sans-serif;
  font-size: 1.25rem;
  letter-spacing: 0.02em;
  line-height: 160%;
  font-weight: 500;
  line-height: 160%;
  letter-spacing: 0.02em;
  text-align: justify;
  color: #000000;
  margin-bottom: 12px;
}
@media (max-width: 991.98px) {
  [data-page=partners__list] .page-section__card-group .item-card .content .title {
    font-size: 1rem;
  }
}
[data-page=partners__list] .page-section__card-group .item-card .content .subtitle {
  display: flex;
  align-items: center;
  gap: 16px;
}
[data-page=partners__list] .page-section__card-group .item-card .content .subtitle .tag-title {
  padding: 2px 12px;
  border-radius: 1000px;
  border: 1px solid #000000;
  font-family: "Noto Sans TC", sans-serif;
  font-size: 0.875rem;
  line-height: 160%;
  letter-spacing: 0.02em;
  font-weight: 400;
  white-space: nowrap;
  color: #000000;
}
[data-page=partners__list] .page-section__card-group .item-card .content .subtitle .text {
  font-family: Marcellus;
  font-size: 1rem;
  font-weight: 400;
  line-height: 160%;
  letter-spacing: 0.05em;
  color: #000000;
}
@media (max-width: 991.98px) {
  [data-page=partners__list] .page-section__card-group .item-card .content .subtitle .text {
    font-size: 0.875rem;
  }
}
[data-page=partners__list] .page-section__card-group .item-card:hover {
  opacity: 0.8;
}
[data-page=partners__list] .page-section__card-group .load-more {
  margin-top: 80px;
  display: grid;
}
[data-page=partners__list] .page-section__card-group .load-more > * {
  grid-area: 1/1;
  transition: all ease 400ms;
  transition-duration: inherit;
}
[data-page=partners__list] .page-section__card-group .load-more__item {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}
[data-page=partners__list] .page-section__card-group .load-more__item .start {
  font-family: Marcellus;
  font-size: 1.125rem;
  line-height: 165%;
  letter-spacing: 0.03em;
  font-weight: 400;
  color: #162238;
}
[data-page=partners__list] .page-section__card-group .load-more:not(.-loading-) .-loading- {
  opacity: 0;
}
[data-page=partners__list] .page-section__card-group .load-more.-loading- .-idle- {
  opacity: 0;
}
[data-page=partners__list] .page-section__card-group .load-more.-end- {
  display: none;
}
[data-page=partners__list] .page-section__card-group .load-more.-end- .-idle- {
  opacity: 0;
}
[data-page=partners__list] .page-section__card-group .load-more.-end- .-loading- {
  opacity: 0;
}
[data-page=partners__article] .page-section {
  position: relative;
}
[data-page=partners__article] .page-section__banner {
  position: sticky;
  top: 0;
  width: 100vw;
  max-height: calc(var(--vh, 1vh) * 100);
  z-index: -1;
}
[data-page=partners__article] .page-section__banner .slider {
  position: relative;
}
[data-page=partners__article] .page-section__banner .slider-item {
  position: relative;
}
[data-page=partners__article] .page-section__banner .slider-item .img-container {
  aspect-ratio: 375/657;
}
@media (min-width: 992px) {
  [data-page=partners__article] .page-section__banner .slider-item .img-container {
    aspect-ratio: 1920/824;
  }
}
[data-page=partners__article] .page-section__banner .slider-item .img-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
[data-page=partners__article] .page-section__banner .slider-pagination {
  position: absolute;
  left: calc(50% + 33px);
  transform: translateX(-50%);
  width: auto;
  z-index: 1;
}
@media (min-width: 992px) {
  [data-page=partners__article] .page-section__banner .slider-pagination {
    bottom: 152px;
    --swiper-pagination-bullet-horizontal-gap: 7.65px;
  }
}
@media (max-width: 991.98px) {
  [data-page=partners__article] .page-section__banner .slider-pagination {
    left: 50%;
    bottom: 85px;
  }
}
[data-page=partners__article] .page-section__banner .slider-pagination .swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.4;
}
[data-page=partners__article] .page-section__banner .slider-pagination .swiper-pagination-bullet-active {
  background: #c9bc9c;
  opacity: 1;
}
[data-page=partners__article] .page-section__article {
  position: relative;
  width: 100vw;
  padding-bottom: 3px;
  background: #d1d1d1;
}
[data-page=partners__article] .page-section__article .article-container {
  position: relative;
  margin-left: auto;
  margin-right: auto;
  transform: translateY(-104px);
  width: calc(100% - 64px);
  max-width: 1520px;
  border-radius: 5px;
  border-top-right-radius: 40px;
  border-bottom-left-radius: 40px;
  padding: 120px;
  background: #ffffff;
}
@media (max-width: 991.98px) {
  [data-page=partners__article] .page-section__article .article-container {
    width: calc(100% - 16px);
    transform: translateY(-32px);
    padding: 64px 24px;
  }
}
[data-page=partners__article] .page-section__article .article-container .slider-nav {
  position: absolute;
  right: 120px;
  top: 0;
  transform: translateY(-50%);
  display: flex;
  gap: 8px;
}
@media (max-width: 991.98px) {
  [data-page=partners__article] .page-section__article .article-container .slider-nav {
    right: 32px;
  }
}
[data-page=partners__article] .page-section__article .article-container .slider-nav__item {
  position: relative;
}
[data-page=partners__article] .page-section__article .article-container .slider-nav__item-img {
  width: 72px;
  height: 72px;
  padding: 24px;
  border-radius: 1000px;
  background: #c9bc9c;
}
[data-page=partners__article] .page-section__article .article-container .slider-nav__item-img svg {
  width: 24px;
  height: 24px;
}
@media (max-width: 991.98px) {
  [data-page=partners__article] .page-section__article .article-container .slider-nav__item-img {
    width: 56px;
    height: 56px;
    padding: 16px;
  }
}
[data-page=partners__article] .page-section__article .article-container .breadcrumb {
  position: relative;
  margin-bottom: 16px;
}
[data-page=partners__article] .page-section__article .article-container .article-title {
  font-family: "Noto Serif TC", sans-serif;
  font-size: 2.5rem;
  letter-spacing: 0.02em;
  line-height: 140%;
  font-weight: 700;
  color: #29416b;
  margin-bottom: 16px;
}
[data-page=partners__article] .page-section__article .article-container .article-subtitle {
  margin-bottom: 64px;
  display: flex;
  align-items: center;
  gap: 16px;
}
@media (max-width: 991.98px) {
  [data-page=partners__article] .page-section__article .article-container .article-subtitle {
    margin-bottom: 48px;
  }
}
[data-page=partners__article] .page-section__article .article-container .article-subtitle .tag-title {
  padding: 2px 12px;
  border-radius: 1000px;
  border: 1px solid #000000;
  font-family: "Noto Sans TC", sans-serif;
  font-size: 0.875rem;
  line-height: 160%;
  letter-spacing: 0.02em;
  font-weight: 400;
  white-space: nowrap;
  color: #000000;
}
[data-page=partners__article] .page-section__article .article-container .article-subtitle .text {
  font-family: Marcellus;
  font-size: 1rem;
  font-weight: 400;
  line-height: 160%;
  letter-spacing: 0.05em;
  color: #000000;
}
[data-page=partners__article] .page-section__article .article-container .article-content {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
  padding-top: 64px;
  padding-bottom: 64px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  margin-bottom: 64px;
}
@media (max-width: 991.98px) {
  [data-page=partners__article] .page-section__article .article-container .article-content {
    padding-top: 48px;
    padding-bottom: 48px;
    margin-bottom: 48px;
  }
}
[data-page=partners__article] .page-section__article .article-container .article-backlist {
  display: flex;
  justify-content: center;
}
[data-page=partners__article] .page-section__article .article-container .article-backlist .c-btn-pill {
  width: 200px;
}
[data-page=partners__article] .l-footer {
  position: relative;
}
[data-page=partners__article] .l-footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #d1d1d1;
  z-index: -1;
}

[data-page=about] .page-section__intro .breadcrumb {
  margin-bottom: 197px;
}
@media (max-width: 991.98px) {
  [data-page=about] .page-section__intro .breadcrumb {
    margin-bottom: 162px;
  }
}
[data-page=about] .page-section__intro .content .content-container {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 48px;
  width: 100vw;
  max-width: 1920px;
}
@media (max-width: 991.98px) {
  [data-page=about] .page-section__intro .content .content-container {
    flex-direction: column;
    gap: 72px;
  }
}
[data-page=about] .page-section__intro .content .content-container .start {
  position: relative;
}
@media (min-width: 992px) {
  [data-page=about] .page-section__intro .content .content-container .start {
    flex: 1 1 50%;
  }
}
@media (max-width: 991.98px) {
  [data-page=about] .page-section__intro .content .content-container .start {
    padding-right: 48px;
  }
}
[data-page=about] .page-section__intro .content .content-container .start .img-container {
  position: relative;
  aspect-ratio: 960/816;
}
[data-page=about] .page-section__intro .content .content-container .start .img-container img {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-top-right-radius: 40px;
  border-bottom-right-radius: 5px;
  overflow: hidden;
  z-index: 1;
}
@media (max-width: 991.98px) {
  [data-page=about] .page-section__intro .content .content-container .start .img-container img {
    border-top-right-radius: 18.2px;
    border-bottom-right-radius: 2.73px;
  }
}
[data-page=about] .page-section__intro .content .content-container .start .deco-rect {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 81.66%;
  aspect-ratio: 784/271;
  transform: translate(27.93%, 49.44%);
  background: linear-gradient(180deg, #29416B 0%, rgba(41, 65, 107, 0.5) 50%, rgba(41, 65, 107, 0) 100%);
  mask-image: linear-gradient(0deg, transparent 0%, black 50%);
  border: 1px solid #c9bc9c;
  border-top-right-radius: 40px;
  z-index: 0;
}
@media (max-width: 1399.98px) {
  [data-page=about] .page-section__intro .content .content-container .start .deco-rect {
    transform: translate(12%, 49.44%);
  }
}
@media (max-width: 991.98px) {
  [data-page=about] .page-section__intro .content .content-container .start .deco-rect {
    transform: translate(32px, 45.83px);
    width: 61.16%;
    aspect-ratio: 327/278;
    border-top-right-radius: 20px;
  }
}
@media (min-width: 992px) {
  [data-page=about] .page-section__intro .content .content-container .end {
    flex: 1 1 50%;
    padding-right: min(max(48px, 0.2111111111 * 100vw + -205.3333333333px), 200px);
  }
}
[data-page=about] .page-section__intro .content .content-container .end .text {
  font-family: "Noto Sans TC", sans-serif;
  font-size: 1.125rem;
  line-height: 180%;
  letter-spacing: 0.02em;
  font-weight: 400;
  color: #000000;
}
@media (min-width: 992px) {
  [data-page=about] .page-section__intro .content .content-container .end .text {
    padding-top: min(max(32px, 0.1826388889 * 100vw + -187.1666666667px), 163.5px);
    padding-left: min(max(12px, 0.0722222222 * 100vw + -74.6666666667px), 64px);
    padding-right: min(max(12px, 0.0722222222 * 100vw + -74.6666666667px), 64px);
  }
}
@media (max-width: 991.98px) {
  [data-page=about] .page-section__intro .content .content-container .end .text {
    padding-top: 0px;
    padding-left: 32px;
    padding-right: 32px;
    font-family: "Noto Sans TC", sans-serif;
    font-size: 1rem;
    line-height: 180%;
    letter-spacing: 0.02em;
  }
}
[data-page=services] .page-section__intro {
  padding-bottom: 197px;
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro {
    padding-bottom: calc(104px + min(max(0px, 0.0648298217 * 100vw + -24.3111831442px), 40px));
  }
}
[data-page=services] .page-section__intro .breadcrumb {
  margin-bottom: 197px;
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro .breadcrumb {
    margin-bottom: 162px;
  }
}
[data-page=services] .page-section__intro .intro-container {
  position: relative;
  width: 100%;
}
[data-page=services] .page-section__intro .intro-item .summary {
  display: flex;
}
@media (min-width: 992px) {
  [data-page=services] .page-section__intro .intro-item .summary {
    padding-bottom: 56px;
    gap: 104px;
  }
  [data-page=services] .page-section__intro .intro-item .summary > * {
    flex: 1 1 50%;
  }
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro .intro-item .summary {
    flex-direction: column;
    gap: 32px;
    padding-bottom: 48px;
  }
}
[data-page=services] .page-section__intro .intro-item .summary .title {
  font-family: "Noto Serif TC", sans-serif;
  font-size: 2.5rem;
  letter-spacing: 0.02em;
  line-height: 140%;
  font-weight: 700;
  color: #29416b;
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro .intro-item .summary .title {
    font-family: "Noto Serif TC", sans-serif;
    font-size: 1.5rem;
    letter-spacing: 0.02em;
    line-height: 160%;
  }
}
[data-page=services] .page-section__intro .intro-item .summary .text {
  font-family: "Noto Sans TC", sans-serif;
  font-size: 1rem;
  line-height: 180%;
  letter-spacing: 0.02em;
  font-weight: 400;
  color: #000000;
  margin-bottom: 32px;
}
[data-page=services] .page-section__intro .intro-item .summary .c-btn-pill {
  width: 200px;
}
[data-page=services] .page-section__intro .intro-item .img-container {
  position: relative;
  width: 100%;
  aspect-ratio: 1520/647;
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro .intro-item .img-container {
    aspect-ratio: 311/208;
  }
}
[data-page=services] .page-section__intro .intro-item .img-container img {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 5px 40px;
  overflow: hidden;
  z-index: 1;
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro .intro-item .img-container img {
    border-radius: 3px 20px;
  }
}
[data-page=services] .page-section__intro .intro-item .img-container::after {
  content: "";
  position: absolute;
  bottom: -23.4666666667%;
  right: -16.25%;
  width: 92.6973684211%;
  aspect-ratio: 1409/375;
  background: linear-gradient(180deg, #29416B 0%, rgba(41, 65, 107, 0.5) 50%, rgba(41, 65, 107, 0) 100%);
  mask-image: linear-gradient(0deg, transparent 0%, black 50%);
  border: 1px solid #c9bc9c;
  z-index: -1;
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro .intro-item .img-container::after {
    bottom: -22.5%;
    right: -17.0418006431%;
    aspect-ratio: 300/120;
  }
}
[data-page=services] .page-section__intro .intro-item + .intro-item {
  margin-top: 200px;
}
@media (max-width: 991.98px) {
  [data-page=services] .page-section__intro .intro-item + .intro-item {
    margin-top: 80px;
  }
}
[data-page=contact] .page-section__intro {
  padding-bottom: 157px;
}
@media (max-width: 991.98px) {
  [data-page=contact] .page-section__intro {
    padding-bottom: 32px;
  }
}
[data-page=contact] .page-section__intro .breadcrumb {
  margin-bottom: 197px;
}
@media (max-width: 991.98px) {
  [data-page=contact] .page-section__intro .breadcrumb {
    margin-bottom: 162px;
  }
}
[data-page=contact] .page-section__intro .info {
  display: flex;
}
@media (min-width: 992px) {
  [data-page=contact] .page-section__intro .info {
    gap: 104px;
  }
  [data-page=contact] .page-section__intro .info > * {
    flex: 1 1 50%;
  }
}
@media (max-width: 991.98px) {
  [data-page=contact] .page-section__intro .info {
    flex-direction: column;
    gap: 32px;
  }
}
[data-page=contact] .page-section__intro .info .start {
  padding-top: 48px;
}
[data-page=contact] .page-section__intro .info .start > .title {
  font-family: "Noto Serif TC", sans-serif;
  font-size: 1.75rem;
  letter-spacing: 0.02em;
  line-height: 140%;
  font-weight: 700;
  color: #000000;
  margin-bottom: 48px;
}
@media (max-width: 991.98px) {
  [data-page=contact] .page-section__intro .info .start > .title {
    font-family: "Noto Serif TC", sans-serif;
    font-size: 1.5rem;
    letter-spacing: 0.02em;
    line-height: 160%;
    margin-bottom: 32px;
  }
}
[data-page=contact] .page-section__intro .info .item-group .item + .item {
  margin-top: 8px;
}
[data-page=contact] .page-section__intro .info .item-group .item {
  position: relative;
  display: flex;
  gap: 24px;
  font-family: "Noto Sans TC", sans-serif;
  font-size: 1.125rem;
  line-height: 180%;
  letter-spacing: 0.02em;
  font-weight: 400;
  color: #000000;
}
@media (max-width: 991.98px) {
  [data-page=contact] .page-section__intro .info .item-group .item {
    font-family: "Noto Sans TC", sans-serif;
    font-size: 1rem;
    line-height: 180%;
    letter-spacing: 0.02em;
  }
}
[data-page=contact] .page-section__intro .info .item-group .item .title {
  flex: 0 0 72px;
}
[data-page=contact] .page-section__intro .info .item-group .item .text {
  flex: 1 1 auto;
}
[data-page=contact] .page-section__intro .info .line-friend {
  padding: 32px 104px 56px 104px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  border-radius: 5px 40px;
  background: #e7e7e7;
}
[data-page=contact] .page-section__intro .info .line-friend .qr-code {
  width: 200px;
  height: 200px;
}
[data-page=contact] .page-section__intro .info .line-friend .qr-code .img-container {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
}
[data-page=contact] .page-section__intro .info .line-friend .qr-code .img-container .img {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
[data-page=contact] .page-section__intro .info .line-friend .c-btn-pill {
  width: 200px;
}
[data-page=privacy] .page-section__intro {
  padding-bottom: 157px;
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section__intro {
    padding-bottom: 104px;
  }
}
[data-page=privacy] .page-section__intro .breadcrumb {
  margin-bottom: 197px;
}
@media (max-width: 991.98px) {
  [data-page=privacy] .page-section__intro .breadcrumb {
    margin-bottom: 162px;
  }
}
[data-page=privacy] .page-section__intro .info-article {
  position: relative;
}
