@charset "UTF-8";
:root {
  --dblue:#123d83;
  --lblue:#1eb8d4;
  --red:#d6141c;
  --yellow:#ffd842;
}

/* mixin */
* {
  box-sizing: border-box;
  font-family: "Mulish", "Noto Sans", "Noto Sans TC", "微軟正黑體", sans-serif;
}
*:focus {
  outline: none;
}

html {
  font-size: 16px;
  overflow-x: hidden;
}

body {
  font-family: "Mulish", "Noto Sans", "Noto Sans TC", "微軟正黑體", sans-serif;
  overflow-x: hidden;
  transition: 0.3s;
  position: relative;
  color: #222;
  line-height: 1.6;
  -webkit-text-size-adjust: 100%;
  max-width: 1920px;
  margin: auto !important;
}
body.fixed {
  height: 100vh !important;
  overflow: hidden !important;
}

a,
a:hover,
a:focus,
a:visited,
a:active {
  text-decoration: none;
  transition: 0.3s;
}

.unreset {
  padding: 1px 0;
  color: #222;
  font-family: "Mulish", "Noto Sans", "Noto Sans TC", "微軟正黑體", sans-serif;
}
.unreset:after {
  content: "";
  display: block;
  clear: both;
}
.unreset p:first-child {
  margin-top: 0;
}

.unreset img {
  max-width: 100%;
  height: auto !important;
}

.unreset iframe {
  max-width: 100%;
  display: block;
}

/* 編輯器影片RWD */
.unreset .embeddedContent {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}

.unreset .embeddedContent iframe,
.unreset .embeddedContent object,
.unreset .embeddedContent embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.page-container {
  margin: 0 auto;
  width: 1730px;
  max-width: 100%;
  padding: 0 25px;
}

.page-container1440 {
  margin: 0 auto;
  width: 1490px;
  max-width: 100%;
  padding: 0 25px;
}

sup {
  vertical-align: super;
  font-size: small;
}

sub {
  vertical-align: sub;
  font-size: smaller;
  font-weight: lighter;
}

select {
  font-family: "Mulish", "Noto Sans", "Noto Sans TC", "微軟正黑體", sans-serif;
}

img::selection {
  background: transparent;
}

img::-moz-selection {
  background: transparent;
}

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
  background: #ddd;
  border-radius: 0px;
}

::-webkit-scrollbar-track {
  -webkit-border-radius: 0px;
  border-radius: 0px;
  margin: 0 0 0 0;
  background: #ccc;
}

::-webkit-scrollbar-thumb {
  background: #333;
  border-radius: 0px;
}

::-webkit-scrollbar-thumb:horizontal {
  background: #000;
  border-radius: 0px;
}

/* 404 */
.error-row {
  background: url(../images/404/error-background.svg) no-repeat;
  background-position: center top;
  max-width: 1400px;
  padding: 60px 25px;
  margin: 40px auto 0 auto;
}
.error-row .img-box {
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  width: 100%;
}
.error-row .img-box img {
  display: block;
  width: 100%;
}
.error-row .img-box .error-code {
  color: #222;
  font-size: 120px;
  font-weight: bold;
  letter-spacing: 5px;
  line-height: 1;
  margin: 0;
  position: absolute;
  top: 42%;
  left: 50%;
  transform: translateX(-57%);
}
.error-row .content {
  margin-top: 50px;
  text-align: center;
}
.error-row .content .title {
  color: #222;
  font-size: 30px;
  font-weight: bold;
  margin: 0;
}
.error-row .content .des {
  margin-top: 25px;
}
.error-row .content .des p {
  color: #222;
  font-size: 18px;
  line-height: 1.6;
  margin: 0;
}
.error-row .content .des p:not(:last-child) {
  margin-bottom: 5px;
}
.error-row .btn-row {
  margin-top: 80px;
}
.error-row .btn-row .link {
  border-radius: 30px;
  background: var(--blue);
  color: #fff;
  display: block;
  font-size: 18px;
  padding: 12px 13px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  text-decoration: inherit;
  text-transform: uppercase;
  transition: all 0.4s;
  width: 240px;
}
.error-row .btn-row .link:hover {
  background: var(--gradient_color1);
  color: #fff;
}
@media (max-width: 1440px) {
  .error-row .img-box {
    max-width: 540px;
  }
  .error-row .img-box .error-code {
    font-size: 100px;
  }
  .error-row .btn-row {
    margin-top: 50px;
  }
}
@media (max-width: 1024px) {
  .error-row .img-box {
    max-width: 440px;
  }
  .error-row .img-box .error-code {
    font-size: 70px;
    top: 45%;
  }
  .error-row .btn-row {
    margin-top: 50px;
  }
}
@media (max-width: 640px) {
  .error-row {
    padding: 20px 25px 40px 25px;
    margin: 0 auto 20px auto;
  }
  .error-row .img-box .error-code {
    font-size: 50px;
    top: 45%;
  }
  .error-row .content {
    margin-top: 30px;
  }
  .error-row .content .title {
    font-size: 24px;
  }
  .error-row .content .des {
    margin-top: 15px;
  }
  .error-row .content .des p {
    font-size: 16px;
  }
  .error-row .btn-row {
    margin-top: 30px;
  }
  .error-row .btn-row .link {
    font-size: 17px;
    max-width: 170px;
  }
}

/* 空白狀態 */
.empty-row {
  margin-left: auto;
  margin-right: auto;
  padding: 40px 20px;
  max-width: 640px;
}
.empty-row .img-box {
  max-width: 100px;
  margin-left: auto;
  margin-right: auto;
}
.empty-row .img-box img {
  display: block;
  width: 100%;
}
.empty-row .content {
  margin-top: 40px;
  text-align: center;
}
.empty-row .content .title {
  color: #222;
  font-size: 32px;
  line-height: 1.2;
  margin: 0;
}
.empty-row .content .des {
  color: #888;
  font-size: 17px;
  line-height: 1.6;
  margin: 0;
  margin-top: 20px;
}
.empty-row .btn-row {
  margin-top: 40px;
}
.empty-row .btn-row .link {
  background: #000;
  color: #fff;
  display: block;
  font-size: 17px;
  margin-left: auto;
  margin-right: auto;
  padding: 13px;
  text-align: center;
  text-decoration: inherit;
  transition: all 0.4s;
  width: 120px;
}
.empty-row .btn-row .link:hover {
  background: #aaa;
}
@media (max-width: 640px) {
  .empty-row .content {
    margin-top: 30px;
  }
  .empty-row .content .title {
    font-size: 26px;
  }
  .empty-row .content .des {
    font-size: 16px;
    margin-top: 15px;
  }
  .empty-row .btn-row {
    margin-top: 30px;
  }
}

.cookies-box {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  transform: translateY(110%);
  transition: all 0.3s;
  z-index: 1;
}
.cookies-box.show {
  transform: translateY(0);
}
.cookies-box .cookies-content {
  align-items: center;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  padding: 15px 20px;
}
.cookies-box .cookies-content .des {
  padding-right: 20px;
  width: calc(100% - 100px);
}
.cookies-box .cookies-content .des p {
  color: #fff;
  font-size: 1rem;
  line-height: 1.5;
  margin: 0;
}
.cookies-box .cookies-content .des a {
  color: #fff;
  display: inline-block;
  font-size: 1rem;
  line-height: 1.5;
  text-decoration: underline;
}
.cookies-box .cookies-content .des a:hover {
  opacity: 0.5;
}
.cookies-box .cookies-content .btn-confirm {
  border: 1px solid white;
  background: none;
  color: white;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  display: block;
  padding: 13px 10px;
  text-align: center;
  width: 100px;
}
.cookies-box .cookies-content .btn-confirm:hover {
  background: white;
  color: #333;
}
.cookies-box .cookies-content > .page-container {
  display: flex;
  align-items: center;
}
@media (max-width: 1440px) {
  .cookies-box .cookies-content {
    padding: 15px 0;
  }
}
@media (max-width: 640px) {
  .cookies-box .cookies-content {
    display: block;
  }
  .cookies-box .cookies-content .des {
    padding-right: 0;
    margin-bottom: 10px;
    width: 100%;
  }
  .cookies-box .cookies-content .des p,
  .cookies-box .cookies-content .des a {
    font-size: 0.875rem;
  }
  .cookies-box .cookies-content .btn-confirm {
    padding: 10px 8px;
    font-size: 0.875rem;
    width: 100%;
  }
  .cookies-box .cookies-content > .page-container {
    flex-wrap: wrap;
  }
}

/*========== basic mobile ==========*/
/*========= form ==========*/
.form-style form {
  display: flex;
  flex-wrap: wrap;
  gap: 15px 40px;
  align-items: flex-start;
}
.form-style .form-txt {
  width: 100%;
}
.form-style .form-box {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  transition: 0.4s;
  align-items: center;
  color: #4d4d4d;
  position: relative;
}
.form-style .form-box.inline .box-title {
  width: 90px;
  position: absolute;
  left: 0;
  top: 5px;
}
.EN .form-style .form-box.inline .box-title {
  width: 100%;
  position: static;
}
.form-style .form-box.inline .box-content input[type=text],
.form-style .form-box.inline .box-content input[type=password],
.form-style .form-box.inline .box-content input[type=email],
.form-style .form-box.inline .box-content input[type=date],
.form-style .form-box.inline .box-content input[type=number],
.form-style .form-box.inline .box-content input[type=tel] {
  padding-left: 100px;
}
.EN .form-style .form-box.inline .box-content input[type=text],
.EN .form-style .form-box.inline .box-content input[type=password],
.EN .form-style .form-box.inline .box-content input[type=email],
.EN .form-style .form-box.inline .box-content input[type=date],
.EN .form-style .form-box.inline .box-content input[type=number],
.EN .form-style .form-box.inline .box-content input[type=tel] {
  padding-left: 15px;
}
.form-style .form-box .box-title {
  width: 100%;
  margin: 15px 0;
  font-size: 1.125rem;
}
.form-style .form-box .box-title .must {
  color: #e64545;
  margin-left: 3px;
  font-size: 0.9375rem;
  transform: translateY(-5px);
}
.form-style .form-box .box-content {
  width: 100%;
}
.form-style .form-box .box-content input[type=text],
.form-style .form-box .box-content input[type=password],
.form-style .form-box .box-content input[type=email],
.form-style .form-box .box-content input[type=date],
.form-style .form-box .box-content input[type=number],
.form-style .form-box .box-content input[type=tel],
.form-style .form-box .box-content textarea {
  background: none;
  border-radius: 0;
  border: none;
  appearance: none;
  width: 100%;
  padding: 8px 15px;
  font-size: 1rem;
  background: #fff;
  color: #222;
  text-align: left;
  transition: 0.3s;
}
.form-style .form-box .box-content input[type=text]:focus,
.form-style .form-box .box-content input[type=password]:focus,
.form-style .form-box .box-content input[type=email]:focus,
.form-style .form-box .box-content input[type=date]:focus,
.form-style .form-box .box-content input[type=number]:focus,
.form-style .form-box .box-content input[type=tel]:focus,
.form-style .form-box .box-content textarea:focus {
  border-color: var(--blue);
}
.form-style .form-box .box-content input[type=text]::placeholder,
.form-style .form-box .box-content input[type=password]::placeholder,
.form-style .form-box .box-content input[type=email]::placeholder,
.form-style .form-box .box-content input[type=date]::placeholder,
.form-style .form-box .box-content input[type=number]::placeholder,
.form-style .form-box .box-content input[type=tel]::placeholder,
.form-style .form-box .box-content textarea::placeholder {
  color: #aaa;
  font-weight: 300;
}
.form-style .form-box .box-content input[type=text]:disabled,
.form-style .form-box .box-content input[type=password]:disabled,
.form-style .form-box .box-content input[type=email]:disabled,
.form-style .form-box .box-content input[type=date]:disabled,
.form-style .form-box .box-content input[type=number]:disabled,
.form-style .form-box .box-content input[type=tel]:disabled,
.form-style .form-box .box-content textarea:disabled {
  background: none;
}
.form-style .form-box .box-content select {
  background: none;
  border-radius: 0;
  border: none;
  appearance: none;
  width: 100%;
  border: 1px solid #e0e0e0;
  padding: 8px 55px 8px 15px;
  font-size: 1rem;
  color: #222;
  text-align: left;
  border-radius: 3px;
  background: #fff url(../images/select_arrow.svg) right 25px center no-repeat;
  background-size: 15px;
}
.form-style .form-box .box-content select:disabled {
  background: none;
  appearance: none;
}
.form-style .form-box .box-content select:focus {
  border-color: var(--blue);
}
.form-style .form-box .box-content input[type=text],
.form-style .form-box .box-content input[type=password],
.form-style .form-box .box-content input[type=email],
.form-style .form-box .box-content input[type=date],
.form-style .form-box .box-content input[type=number],
.form-style .form-box .box-content input[type=tel] {
  border-bottom: 1px solid #e0e0e0;
}
.form-style .form-box .box-content input[type=text],
.form-style .form-box .box-content input[type=password],
.form-style .form-box .box-content input[type=email],
.form-style .form-box .box-content input[type=date],
.form-style .form-box .box-content input[type=number],
.form-style .form-box .box-content input[type=tel],
.form-style .form-box .box-content select {
  height: 65px;
}
.form-style .form-box .box-content textarea {
  padding: 15px;
  border: 1px solid #e0e0e0;
}
.form-style .form-box .box-content textarea:focus {
  border-color: var(--blue);
}
.form-style .form-box .part {
  display: inline-block;
}
.form-style .form-box .part span {
  margin-left: 5px;
}
.form-style .form-box .part span b {
  font-weight: bold;
}
.form-style .form-box .part:not(:last-child) {
  margin-right: 10px;
}
.form-style .form-box .radiobox,
.form-style .form-box .checkbox {
  font-size: 1.125rem;
}
.form-style .form-box .radiobox {
  color: #666;
}
.form-style .form-box .radiobox input[type=radio] {
  opacity: 0;
  display: none;
}
.form-style .form-box .radiobox input[type=radio] + label {
  position: relative;
  cursor: pointer;
  padding-left: 35px;
}
.form-style .form-box .radiobox input[type=radio] + label:before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: #fff;
  border: 1px solid #c9c9c9;
  position: absolute;
  left: 0;
  top: 50%;
  border-radius: 50%;
  transform: translateY(-50%);
  transition: 0.4s;
}
.form-style .form-box .radiobox input[type=radio] + label:after {
  content: "";
  width: 8px;
  height: 8px;
  background-color: transparent;
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  transition: 0.4s;
}
.form-style .form-box .radiobox input[type=radio]:checked + label::before {
  border-color: var(--blue);
}
.form-style .form-box .radiobox input[type=radio]:checked + label:after {
  background-color: var(--blue);
}
.form-style .form-box .checkbox input[type=checkbox] {
  border: 2px solid #222;
  width: 18px;
  height: 18px;
}
.form-style .form-box.half {
  width: calc((100% - 40px) / 2);
}
.form-style .form-box.one-third {
  width: calc((100% - 60px) / 3);
}
.form-style .form-box.quarter {
  width: calc((100% - 90px) / 4);
}
.form-style .form-box.short {
  width: calc((100% - 100px) / 2);
  margin-right: 50px;
}
.form-style .form-box.short .content input[type=text],
.form-style .form-box.short .content input[type=password],
.form-style .form-box.short .content input[type=email],
.form-style .form-box.short .content input[type=date],
.form-style .form-box.short .content input[type=number],
.form-style .form-box.short .content input[type=tel],
.form-style .form-box.short .content select {
  width: calc(100% - 75px);
}
.form-style .form-box.mid {
  width: calc((100% - 100px) / 2);
  margin-right: 50px;
}
.form-style .form-box.row {
  width: 100%;
}
.form-style .form-box:last-child {
  margin-right: 0;
}
.form-style .form-box.name .box-content input[type=text] {
  padding-right: 190px;
}
.form-style .form-box.name .gender {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
.form-style .form-box.suitable-contact-time .box-content {
  display: flex;
  gap: 0 40px;
}
.form-style .form-box.suitable-contact-time .box-content select {
  width: calc((100% - 40px) / 2);
}
.form-style .form-box.suitable-contact-time .box-content input[type=text] {
  width: calc((100% - 40px) / 2);
}
.form-style .form-box.captcha {
  justify-content: center;
}
.form-style .form-box.captcha .content {
  display: flex;
  align-items: center;
}
.form-style .form-box.captcha .content input {
  flex-shrink: 1;
}
.form-style .form-box.captcha .content img {
  display: inline-block;
  margin-left: 15px;
}
.form-style .form-row-group {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  column-gap: 30px;
}
.form-style .captcha-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  margin-top: 30px;
}
.form-style .captcha-group .pic a {
  display: flex;
  align-items: center;
  color: #4d4d4d;
}
.form-style .captcha-group .pic img {
  display: block;
  width: 120px;
}
.form-style .captcha-group .pic i {
  font-size: 1.25rem;
  margin-left: 15px;
}
.form-style .form-btn-list {
  display: flex;
  justify-content: center;
}
.form-style .form-btn-list button {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  display: block;
  transition: 0.3s;
  width: 300px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--blue);
  color: #fff;
  font-size: 1.125rem;
}
.form-style .form-btn-list button.row {
  width: 100%;
}
.form-style.center {
  display: flex;
  justify-content: center;
}
.form-style.row {
  margin-top: 25px;
  width: 100%;
}

/*========== form mobile ==========*/
/*========== header ==========*/
:root {
  --header_h: 120px;
}

header {
  position: relative;
  z-index: 999;
  display: flex;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  background: #fff;
  height: var(--header_h);
  padding-left: 30px;
  align-items: center;
  gap: 0 30px;
}
header .logo {
  position: relative;
  transition: 0.3s;
  padding: 17px 0;
}
header .logo a {
  display: block;
  width: 304px;
  background: url(../images/logo.svg) no-repeat;
  background-size: contain;
  background-position: center left;
  aspect-ratio: 304/80;
}
header .logo a img {
  display: block;
  max-width: 100%;
}
header .page-container {
  display: flex;
  align-items: center;
}
header .right-block {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0 30px;
}
header.scroll {
  box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.65);
}

.main {
  margin-top: var(--header_h);
}

/*==== header-menublock ===*/
.header-menu-language-search {
  display: flex;
  margin-left: auto;
}

.header-menu {
  display: flex;
  align-items: center;
  position: relative;
}
.header-menu ul.layer1 {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 10px 40px;
}
.header-menu ul.layer1 > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-menu ul.layer1 > li > a {
  font-size: 1.25rem;
  color: #222;
  position: relative;
}
.header-menu ul.layer1 > li > a::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: -15px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  background: var(--lblue);
  border-radius: 50%;
  transition: 0.4s;
}
.header-menu ul.layer1 > li.active > a {
  color: var(--dblue);
  font-weight: bold;
}
.header-menu ul.layer1 > li.hover > a::before {
  width: 8px;
  height: 8px;
}
.header-menu ul.layer1 > li.phoneonly {
  display: none;
}
.header-menu ul.layer2 {
  list-style: none;
  margin: 0;
  padding: 0;
  display: none;
  width: 100%;
  min-width: max-content;
  background: #fff;
  position: absolute;
  top: 40px;
  left: 0;
  padding: 0 10px;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}
.header-menu ul.layer2 > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-menu ul.layer2 > li:not(:last-child) {
  border-bottom: 1px solid #eee;
}
.header-menu ul.layer2 > li > a {
  display: block;
  padding: 10px 25px 10px 10px;
  color: #4d4d4d;
  position: relative;
}
.header-menu ul.layer2 > li > a::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  position: absolute;
  left: 10px;
  top: 20px;
  background: transparent0;
  transition: 0.4s;
}
.header-menu ul.layer2 > li > a:hover {
  color: var(--blue);
  padding: 10px 10px 10px 25px;
}
.header-menu ul.layer2 > li > a:hover::before {
  background: var(--blue);
}
.header-menu:after {
  content: "";
  display: inline-block;
  margin: 0 30px;
  width: 1px;
  height: 20px;
  vertical-align: middle;
  background: #ccc;
}

.header-mega-menu {
  width: 1000px;
  background: #fff;
  border-radius: 10px;
  position: absolute;
  left: 0;
  top: 40px;
  padding: 30px 40px 40px 40px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
  display: none;
}
.header-mega-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 20px 40px;
}
.header-mega-menu ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-mega-menu li {
  width: calc((100% - 80px) / 3);
}
.header-mega-menu li a {
  display: block;
  padding: 10px 0;
  color: #222;
  position: relative;
  border-bottom: 1px solid #eee;
  font-size: 1.125rem;
}
.header-mega-menu li a::before {
  content: "";
  width: 0;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  background: var(--lblue);
  transition: 0.4s;
}
.header-mega-menu li a:after {
  content: "\f061";
  display: block;
  font-family: "Font Awesome 6 Free";
  position: absolute;
  right: 10px;
  top: 10px;
  font-weight: bold;
}
.header-mega-menu li a:hover {
  color: var(--lblue);
}
.header-mega-menu li a:hover::before {
  width: 100%;
}

.header-language-search {
  display: flex;
  align-items: center;
}

.header-language {
  display: flex;
  align-items: center;
  position: relative;
}
.header-language .icon {
  color: var(--dblue);
  margin-right: 12px;
}
.header-language ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 10px;
  align-items: center;
}
.header-language ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-language ul li a {
  color: #222;
  font-size: 1.125rem;
  position: relative;
}
.header-language ul li a:after {
  content: "";
  display: block;
  width: 0;
  height: 2px;
  position: absolute;
  left: 50%;
  transform: translate(-50%);
  bottom: -8px;
  transition: 0.3s;
}
.header-language ul li.active a, .header-language ul li:hover a {
  color: var(--lblue);
}
.header-language ul li.active a:after, .header-language ul li:hover a:after {
  width: 100%;
  background: var(--lblue);
}
.header-language ul li:not(:last-child):after {
  content: "/";
  color: #ccc;
  font-size: 1rem;
  display: inline-block;
  margin: 0 4px 0 10px;
}
.header-language ul li.en a {
  font-weight: 500;
}
.header-language:after {
  content: "";
  display: inline-block;
  margin: 0 30px;
  width: 1px;
  height: 20px;
  vertical-align: middle;
  background: #ccc;
}

/* header-search */
.header-search {
  position: relative;
}
.header-search a {
  color: var(--dblue);
  font-size: 1.125rem;
}

.header-search-form {
  background: #e6f0f7;
  border-radius: 10px;
  padding: 15px;
  width: 450px;
  position: absolute;
  top: 40px;
  right: -30px;
  display: none;
}
.header-search-form form {
  width: 100%;
  display: flex;
  gap: 0 15px;
}
.header-search-form button {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  display: block;
  background: var(--dblue);
  color: #fff;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  border-radius: 5px;
}
.header-search-form .input-box {
  display: flex;
  background: #fff;
  border-radius: 5px;
  padding: 10px 20px;
  flex: 1;
  align-items: baseline;
}
.header-search-form .input-box .title {
  width: 100px;
  color: var(--dblue);
  font-size: 1.125rem;
  font-weight: 500;
  position: relative;
}
.header-search-form .input-box .title:after {
  content: "";
  width: 1px;
  height: 60%;
  background: #ccc;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
.header-search-form .input-box .content input {
  border: none;
  box-shadow: none;
  height: 30px;
  display: block;
  width: 100%;
  padding-left: 20px;
  font-size: 1rem;
}

/* header-other */
.header-link {
  display: flex;
}
.header-link .link a {
  width: var(--header_h);
  aspect-ratio: 1/1;
  color: #fff;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.header-link .link a i {
  display: block;
  font-size: 1.875rem;
}
.header-link .link a span {
  font-size: 1.125rem;
  display: block;
  margin-top: 12px;
  line-height: 1;
}
.header-link .sitemap a {
  background: var(--lblue);
}
.header-link .sitemap a:hover {
  background: #222;
  color: #fff;
}
.header-link .contact a {
  background: var(--dblue);
}
.header-link .contact a:hover {
  background: #222;
  color: #fff;
}

.header-link-small {
  display: none;
  margin-left: 20px;
  gap: 10px;
}
.header-link-small .link a {
  display: flex;
  align-items: center;
  font-size: 1rem;
  color: #fff;
  padding: 5px 12px;
  border-radius: 5px;
}
.header-link-small .link a i {
  margin-right: 15px;
}
.header-link-small .sitemap a {
  background: var(--lblue);
}
.header-link-small .sitemap a:hover {
  background: #222;
}
.header-link-small .contact a {
  background: var(--dblue);
}
.header-link-small .contact a:hover {
  background: #222;
}

/* 選單效果 */
.phone-bar {
  z-index: 1;
  display: none;
}
.phone-bar.active .bar {
  transform: rotate(-315deg);
  background: #fff;
}
.phone-bar.active .bar::before, .phone-bar.active .bar::after {
  background: #fff;
}
.phone-bar.active .bar::before {
  opacity: 0;
}
.phone-bar.active .bar::after {
  transform: rotate(90deg) translate(-35%);
}
.phone-bar .group {
  position: relative;
  height: 35px;
  width: 35px;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 5px;
  background: var(--dblue);
}
.phone-bar .bar {
  display: block;
  width: 22px;
  height: 2px;
  border-radius: 1px;
  transition: 800ms all;
  background: #fff;
}
.phone-bar .bar::before, .phone-bar .bar::after {
  content: "";
  display: block;
  width: 22px;
  height: 2px;
  border-radius: 1px;
  position: relative;
  transition: 400ms all;
  background: #fff;
}
.phone-bar .bar::before {
  top: -8px;
}
.phone-bar .bar::after {
  bottom: -6px;
}

.header-link-phone {
  display: none;
}
.header-link-phone ul.link li.client a {
  background: var(--yellow);
  color: #222;
}
.header-link-phone ul.link li.client a:hover {
  background: #222;
  color: #fff;
}
.header-link-phone ul.link li.staff a {
  background: var(--dblue);
  color: #fff;
}
.header-link-phone ul.link li.staff a:hover {
  background: #222;
  color: #fff;
}

/*========== header mobile ==========*/
@media (max-width: 1680px) {
  :root {
    --header_h: 110px;
  }
  header .logo a {
    width: 280px;
  }
  header .right-block {
    gap: 0 20px;
  }
  .header-menu ul.layer {
    gap: 10px 30px;
  }
  .header-menu ul.layer > li > a {
    font-size: 1.125rem;
  }
  .header-menu:after {
    margin-left: 20px;
  }
  .header-language:after {
    margin: 0 20px;
  }
  .header-link .link a i {
    font-size: 1.5rem;
  }
  .header-link .link a span {
    font-size: 1.0625rem;
  }
}
@media (max-width: 1440px) {
  .header-menu-language-search {
    flex-wrap: wrap;
    flex-direction: column;
    align-items: end;
    gap: 15px;
  }
  .header-language-search {
    order: 1;
  }
  .header-menu {
    order: 2;
  }
  .header-menu ul.layer {
    gap: 10px 20px;
  }
  .header-menu:after {
    display: none;
  }
}
@media (max-width: 1280px) {
  header {
    padding: 0 25px;
  }
  header .logo a {
    width: 240px;
  }
  .header-link {
    display: none;
  }
  .header-link-small {
    display: flex;
  }
}
@media (max-width: 960px) {
  :root {
    --header_h: 90px;
  }
  .phone-bar {
    display: block;
  }
  header {
    justify-content: space-between;
  }
  header .right-block {
    width: 100%;
    background: #fff;
    position: absolute;
    top: var(--header_h);
    left: 0;
    padding: 20px 25px;
    border-top: 1px solid #eee;
    height: calc(100dvh - var(--header_h));
    display: block;
    overflow-y: auto;
    display: none;
  }
  .header-menu-language-search {
    align-items: self-start;
  }
  .header-language-search {
    display: block;
    width: 100%;
  }
  .header-language {
    justify-content: center;
  }
  .header-language:after {
    display: none;
  }
  .header-language .icon {
    display: none;
  }
  .header-language ul li {
    width: 120px;
  }
  .header-language ul li a {
    display: block;
    width: 100%;
    border-radius: 5px;
    background: #eee;
    padding: 6px 20px;
    text-align: center;
  }
  .header-language ul li.active a, .header-language ul li:hover a {
    background: var(--lblue);
    color: #fff;
  }
  .header-language ul li.active a::after, .header-language ul li:hover a::after {
    display: none;
  }
  .header-language ul li:not(:last-child)::after {
    display: none;
  }
  .header-search {
    margin-top: 20px;
  }
  .header-search a {
    display: none;
  }
  .header-search-form {
    display: block;
    position: static;
    width: 100%;
  }
  .header-link-small {
    display: none;
  }
  .header-menu {
    display: block;
    width: 100%;
  }
  .header-menu ul.layer1 {
    display: block;
  }
  .header-menu ul.layer1 > li > a,
  .header-menu ul.layer1 > li > span {
    display: block;
    padding: 10px 40px 10px 10px;
    position: relative;
    font-size: 1.0625rem;
    cursor: pointer;
  }
  .header-menu ul.layer1 > li > a::before,
  .header-menu ul.layer1 > li > span::before {
    display: none;
  }
  .header-menu ul.layer1 > li.dropdown > a:after,
  .header-menu ul.layer1 > li.dropdown > span:after {
    content: "\f061";
    display: block;
    font-family: "Font Awesome 6 Free";
    position: absolute;
    right: 12px;
    top: 12px;
    font-weight: bold;
    transition: 0.4s;
  }
  .header-menu ul.layer1 > li.hover {
    border-bottom: none !important;
  }
  .header-menu ul.layer1 > li.hover > a,
  .header-menu ul.layer1 > li.hover > span {
    color: var(--dblue);
    font-weight: bold;
  }
  .header-menu ul.layer1 > li.hover > a:after,
  .header-menu ul.layer1 > li.hover > span:after {
    transform: rotate(90deg);
  }
  .header-menu ul.layer1 > li.phoneonly {
    display: block;
  }
  .header-menu ul.layer1 > li:not(:last-child) {
    border-bottom: 1px solid #eee;
  }
  .header-mega-menu {
    width: 100%;
    display: block;
    position: static;
    padding: 0;
    box-shadow: none;
    background: #e8f7ff;
    padding: 10px 20px;
    display: none;
  }
  .header-mega-menu ul {
    display: block;
  }
  .header-mega-menu ul li {
    width: 100%;
  }
  .header-mega-menu ul li a {
    padding: 8px;
    font-size: 1.0625rem;
    border: none;
  }
  .header-mega-menu ul li a:before, .header-mega-menu ul li a:after {
    display: none;
  }
  .header-link-phone {
    display: flex;
    width: 100%;
    overflow: hidden;
    margin-top: 10px;
    gap: 10px;
    flex-direction: column;
  }
  .header-link-phone .link {
    flex: 1;
  }
  .header-link-phone .link a {
    padding: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
    border-radius: 5px;
  }
  .header-link-phone .link.client a {
    background: var(--yellow);
    color: #222;
  }
  .header-link-phone .link.client a:hover {
    background: #222;
    color: #fff;
  }
  .header-link-phone .link.staff a {
    background: var(--dblue);
    color: #fff;
  }
  .header-link-phone .link.staff a:hover {
    background: #222;
    color: #fff;
  }
}
@media (max-width: 640px) {
  :root {
    --header_h: 70px;
  }
  header .logo {
    padding: 0;
  }
  header .logo a {
    width: 200px;
  }
}
@media (max-width: 480px) {
  .header-language ul li {
    width: 80px;
  }
  .header-language ul li a {
    font-size: 1rem;
  }
  .header-search-form {
    padding: 10px;
  }
  .header-search-form form {
    gap: 0 10px;
  }
  .header-search-form button {
    width: 40px;
    height: 40px;
  }
  .header-search-form .input-box {
    padding: 5px 15px;
  }
  .header-search-form .input-box .title {
    display: none;
  }
  .header-search-form .input-box .content input {
    padding-left: 0;
  }
}
@media (max-width: 320px) {
  .header-language ul li {
    width: 80px;
  }
  .header-language ul li a {
    font-size: 1rem;
  }
}
/*===== footer =====*/
.footer-s1 {
  padding: 60px 0 80px 0;
  background: var(--dblue) url(../images/footer_bg1.png) right bottom no-repeat;
}
.footer-s1 .page-container {
  display: flex;
}

.footer-s2 {
  background: #001d49;
  padding: 24px 0;
}
.footer-s2 .page-container {
  display: flex;
  align-items: center;
}
.footer-s2 .page-container .box {
  flex: 1;
}
.footer-s2 .box3 {
  text-align: right;
}

.copyright {
  color: #fff;
}

.footer-visitors {
  color: #fff;
  display: flex;
  justify-content: flex-end;
}

.footer-latest-update {
  color: #fff;
  margin-top: 2px;
}

.iware {
  color: #fff;
  margin-top: 2px;
}
.iware a {
  color: #fff;
}
.iware a:hover {
  text-decoration: underline;
}

.footer-menu {
  position: relative;
  display: flex;
  padding-right: 80px;
  flex: 1;
}
.footer-menu ul.layer1 {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  width: 100%;
  justify-content: space-between;
  gap: 20px;
}
.footer-menu ul.layer1 > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-menu ul.layer1 > li > a {
  display: block;
  position: relative;
  color: #fff;
  font-size: 1.25rem;
  font-weight: 500;
}
.footer-menu ul.layer2 {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-top: 30px;
}
.footer-menu ul.layer2 > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-menu ul.layer2 > li > a {
  display: block;
  position: relative;
  color: #fff;
}
.footer-menu ul.layer2 > li > a:hover {
  color: var(--lblue);
  text-decoration: underline;
  text-underline-offset: 6px;
}
.footer-menu ul.layer2 > li:not(:last-child) {
  margin-bottom: 10px;
}

.footer-other-info {
  width: 360px;
  background: var(--lblue);
  border-radius: 0 0 15px 15px;
  padding: 60px 60px 40px 60px;
  margin-top: -60px;
}
.footer-other-info .phone {
  color: #fff;
  font-size: 1.875rem;
  font-weight: 500;
  text-align: center;
  line-height: 1.2;
  letter-spacing: 1.5px;
}
.footer-other-info .phone .num {
  font-weight: 100;
  letter-spacing: 1px;
}
.footer-other-info ul.link {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-top: 20px;
}
.footer-other-info ul.link > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-other-info ul.link li a {
  display: block;
  text-align: center;
  padding: 14px 10px;
  font-size: 1.25rem;
  border-radius: 5px;
}
.footer-other-info ul.link li a i {
  margin-right: 5px;
}
.footer-other-info ul.link li:not(:last-child) {
  margin-bottom: 15px;
}
.footer-other-info ul.link li.client a {
  background: var(--yellow);
  color: #222;
}
.footer-other-info ul.link li.client a:hover {
  background: #222;
  color: #fff;
}
.footer-other-info ul.link li.staff a {
  background: var(--dblue);
  color: #fff;
}
.footer-other-info ul.link li.staff a:hover {
  background: #222;
  color: #fff;
}

.footer-sns {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: 10px;
}
.footer-sns > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-sns li a {
  display: block;
  border-radius: 5px;
  overflow: hidden;
}
.footer-sns li a img {
  display: block;
  width: 30px;
  height: 30px;
}
.footer-sns li a:hover {
  transform: scale(1.2);
}

.fixed-link {
  position: fixed;
  right: 0;
  bottom: 10vw;
  z-index: 2;
  display: none;
  background: #333333;
  padding: 10px;
  border-radius: 10px 0 0 10px;
}
.fixed-link > div:not(:last-child) {
  margin-bottom: 10px;
}
.fixed-link > div a {
  width: 50px;
  height: 50px;
  background: rgba(255, 255, 255, 0);
  border-radius: 5px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.fixed-link > div a:hover {
  background: rgba(255, 255, 255, 0.3);
}
.fixed-link > div .icon {
  font-size: 1.125rem;
  text-align: center;
  color: #fff;
  line-height: 1;
}
.fixed-link > div .text {
  font-size: 0.75rem;
  text-align: center;
  color: #fff;
  margin-top: 8px;
  line-height: 1;
}
.fixed-link .line .icon {
  margin: 0 auto;
}
.fixed-link .line .icon img {
  margin: auto;
  display: block;
  aspect-ratio: 1/1;
  width: 20px;
}
/*========== footer mobile ==========*/
@media (max-width: 1366px) {
  .footer-menu {
    padding-right: 60px;
  }
  .footer-menu ul.layer1 {
    flex-wrap: wrap;
    gap: 40px 60px;
    justify-content: flex-start;
  }
  .footer-menu ul.layer1 > li {
    width: calc((100% - 180px) / 4);
  }
  .footer-s1 .page-container {
    align-items: flex-start;
  }
}
@media (max-width: 1280px) {
  .footer-s1 {
    padding: 40px 0 60px 0;
  }
  .footer-other-info {
    padding: 40px;
    margin-top: -40px;
  }
  .footer-menu {
    padding-right: 40px;
  }
  .footer-menu ul.layer1 {
    gap: 40px;
  }
  .footer-menu ul.layer1 > li {
    width: calc((100% - 120px) / 4);
  }
}
@media (max-width: 960px) {
  .footer-s1 {
    padding: 40px 0;
  }
  .footer-s1 .page-container {
    flex-wrap: wrap;
  }
  .footer-menu {
    width: 100%;
    padding-right: 0;
  }
  .footer-menu ul.layer1 {
    gap: 10px;
  }
  .footer-menu ul.layer1 > li {
    width: 100%;
  }
  .footer-menu ul.layer1 > li > a {
    border-bottom: 1px solid #fff;
    padding: 5px 40px 5px 0;
    font-size: 1.125rem;
    position: relative;
  }
  .footer-menu ul.layer1 > li > a:after {
    content: "\f107";
    display: block;
    font-family: "Font Awesome 6 Free";
    position: absolute;
    right: 10px;
    top: 5px;
    font-weight: bold;
    transition: 0.4s;
  }
  .footer-menu ul.layer1 > li.active > a:after {
    transform: rotate(180deg);
  }
  .footer-menu ul.layer2 {
    margin-top: 10px;
    display: none;
    padding: 10px;
  }
  .footer-other-info {
    width: 100%;
    margin-top: 40px;
    border-radius: 15px;
  }
  .footer-other-info .phone {
    font-size: 1.5rem;
  }
  .footer-other-info ul.link {
    display: flex;
    gap: 20px;
  }
  .footer-other-info ul.link li {
    flex: 1;
  }
  .footer-other-info ul.link li a {
    font-size: 1.125rem;
  }
  .footer-other-info ul.link li:not(:last-child) {
    margin-bottom: 0;
  }
  .footer-s2 .page-container {
    flex-wrap: wrap;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }
  .footer-s2 .box1 {
    order: 3;
  }
  .footer-s2 .box2 {
    order: 1;
  }
  .footer-s2 .box3 {
    order: 2;
    text-align: left;
  }
  .footer-visitors {
    justify-content: flex-start;
  }
}
@media (max-width: 480px) {
  .footer-s1 {
    padding: 30px 0;
  }
  .footer-other-info {
    padding: 20px;
  }
  .footer-other-info .phone {
    font-size: 1.25rem;
  }
  .footer-other-info ul.link {
    flex-wrap: wrap;
    gap: 10px;
  }
  .footer-other-info ul.link li {
    width: 100%;
    flex: auto;
  }
  .footer-other-info ul.link li a {
    padding: 10px;
    font-size: 1rem;
  }
  .footer-menu ul.layer1 > li > a {
    font-size: 1.0625rem;
  }
  .fixed-link {
    padding: 5px;
  }
  .fixed-link > div a {
    width: 40px;
    height: 40px;
  }
  .fixed-link > div .icon {
    font-size: 1rem;
  }
  .fixed-link > div .text {
    font-size: 0.6875rem;
    margin-top: 5px;
  }
  .fixed-link .line .icon img {
    width: 18px;
  }
}
/*===== page main =====*/
/*===== page banner =====*/
.page-banner {
  position: relative;
  padding-left: 60px;
}
.page-banner .pic {
  border-radius: 15px 0 0 15px;
  overflow: hidden;
}
.page-banner .word {
  position: absolute;
  left: 10%;
  top: 50%;
  transform: translateY(-50%);
  color: #fff;
}
.page-banner .word .en {
  font-size: 3.75rem;
  font-weight: 100;
  line-height: 1;
}
.page-banner .word .tw {
  font-size: 2.25rem;
  margin-top: 10px;
}
.page-banner img,
.page-banner source {
  display: block;
  width: 100%;
}
.page-banner h2 {
  margin: 0;
}

.EN .page-banner .word .tw {
  display: none;
}

/*===== breadcrumb =====*/
.breadcrumb {
  background: var(--dblue);
  padding-top: 80px;
  margin-top: -80px;
}
.breadcrumb ul {
  list-style: none;
  margin: 0;
  padding: 0;
  padding: 16px 0 11px 0;
  display: flex;
  flex-wrap: wrap;
}
.breadcrumb ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.breadcrumb ul li {
  font-size: 1.125rem;
  margin-bottom: 5px;
  color: #fff;
}
.breadcrumb ul li a {
  color: #fff;
}
.breadcrumb ul li a:hover {
  color: #ffd842;
}
.breadcrumb ul li:not(:last-child) {
  position: relative;
}
.breadcrumb ul li:not(:last-child):after {
  content: "-";
  display: inline-block;
  margin: 0 10px;
  color: #bfbfbf;
}
.breadcrumb ul li.home a {
  position: relative;
}
.breadcrumb ul li.home a::before {
  display: inline-block;
  content: "\f005";
  font-family: "Font Awesome 6 Free";
  font-weight: bold;
  margin-right: 10px;
  color: #ffd842;
  font-size: 0.9375rem;
  transition: 0.4s;
}

/*===== aside =====*/
.aside-menu-btn {
  display: none;
  background: var(--dblue);
  padding-bottom: 20px;
  transition: 0.4s;
}
.aside-menu-btn a {
  display: block;
  width: 100%;
  margin: auto;
  background: var(--lblue);
  border-radius: 5px;
  padding: 10px;
  text-align: center;
  color: #fff;
}
.aside-menu-btn i {
  margin-left: 10px;
}
.aside-menu-btn.active {
  padding-bottom: 10px;
}

aside {
  position: relative;
}
aside::before {
  content: "";
  display: block;
  background: #e8f7ff;
  height: 100%;
  width: 1680px;
  max-width: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 15px 15px 0 0;
}
aside .page-menu {
  position: relative;
  padding: 15px 0;
}
aside .layer {
  list-style: none;
  margin: 0;
  padding: 0;
}
aside .layer > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
aside ul.layer1 {
  display: flex;
  flex-wrap: wrap;
}
aside ul.layer1 > li {
  position: relative;
  padding: 15px 20px;
}
aside ul.layer1 > li > a {
  display: block;
  color: #222;
  font-size: 1.25rem;
  line-height: 1;
  position: relative;
}
aside ul.layer1 > li > a::after {
  content: "";
  display: block;
  width: 100%;
  height: 0;
  background: var(--lblue);
  position: absolute;
  bottom: -12px;
  left: 0;
  transition: 0.4s;
}
aside ul.layer1 > li:not(:last-child):after {
  content: "";
  display: block;
  width: 1px;
  height: 35%;
  background: #cccccc;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
aside ul.layer1 > li:first-child {
  padding-left: 0;
}
aside ul.layer1 > li.active > a, aside ul.layer1 > li:hover > a {
  color: var(--lblue);
}
aside ul.layer1 > li.active > a:after, aside ul.layer1 > li:hover > a:after {
  height: 3px;
}

.page-article-content {
  min-height: 190px;
  position: relative;
}
.page-article-content .page-container1440 {
  position: relative;
  margin-top: -1px;
}
.page-article-content::before {
  content: "";
  display: block;
  background: #fff;
  height: 100%;
  width: 1680px;
  max-width: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.page-article-title {
  padding: 40px 0 60px 0;
  position: relative;
}
.page-article-title:after {
  content: "";
  display: block;
  width: 100%;
  height: 8px;
  background: url(../images/title_line.png) no-repeat center;
  margin-top: 10px;
}
.page-article-title .text {
  width: calc(100% - 140px);
  padding-right: 20px;
}
.page-article-title .en {
  color: var(--lblue);
  padding-left: 15px;
  position: relative;
  font-weight: bold;
}
.page-article-title .en::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  background: var(--lblue);
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 10px;
}
.page-article-title .tw {
  font-size: 2.25rem;
}
.page-article-title .pic {
  position: absolute;
  right: 0;
  bottom: 40px;
  width: 140px;
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-article-title .pic img {
  display: block;
  max-width: 100%;
  max-height: 100%;
}
.page-article-title .date {
  color: var(--lblue);
  padding-left: 15px;
  position: relative;
  font-weight: bold;
}
.page-article-title .date::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  background: var(--lblue);
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 10px;
}
.page-article-title .title {
  font-size: 2.25rem;
}

.EN .page-article-title .en {
  padding-left: 0;
  color: #222;
  font-size: 2.25rem;
}
.EN .page-article-title .en::before {
  display: none;
}
.EN .page-article-title .tw {
  display: none;
}

.page-article {
  max-width: 100%;
  background: #fff;
  margin: auto;
  padding-bottom: 100px;
  background-image: linear-gradient(to bottom, var(--dblue) 0%, var(--dblue) 250px, #fff 250px, #fff 100%);
}

/* 單元標題 */
.page-detail-title {
  margin-bottom: 60px;
  display: flex;
  color: #4d4d4d;
  justify-content: space-between;
  align-items: flex-end;
  gap: 5px 40px;
  text-align: center;
  border-bottom: 1px solid #4d4d4d;
  padding: 0 5.5% 20px 5.5%;
}
.page-detail-title .date {
  font-weight: 300;
}
.page-detail-title .title {
  font-size: 2.5rem;
}
.page-detail-title .sort {
  font-size: 0.875rem;
  border: 1px solid #4d4d4d;
  padding: 0 6px;
  width: fit-content;
}
.page-detail-title .link a {
  display: block;
  color: var(--blue);
  font-size: 1.125rem;
  padding: 15px 40px;
  line-height: 1;
  position: relative;
  box-shadow: 0 0 0 1px var(--blue) inset;
}
.page-detail-title .link a:after {
  display: inline-block;
  content: "\f054";
  font-family: "Font Awesome 6 Free";
  font-weight: bold;
  margin-left: 10px;
  z-index: 1;
  position: relative;
}
.page-detail-title .link a:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 100%;
  transition: 0.4s;
}
.page-detail-title .link a:hover {
  box-shadow: 0 0 0 0 #fff inset;
  color: #fff;
}
.page-detail-title .link a:hover:before {
  width: 100%;
  color: #fff;
}
.page-detail-title .link a span {
  position: relative;
  z-index: 1;
}
.page-detail-title + .article-unreset {
  padding: 0 5.5%;
}

/*===== 頁面標題 =====*/
.page-detail-info {
  background: #e6f0f7;
  border-radius: 5px;
  padding: 16px 20px;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px 30px;
  margin-bottom: 40px;
}
.page-detail-info .text {
  font-size: 1.125rem;
  position: relative;
}
.page-detail-info .text i {
  margin-right: 10px;
  color: var(--dblue);
}

.page-share {
  display: flex;
}
.page-share .a2a_kit {
  display: flex;
}
.page-share .a2a_kit .a2a_button_facebook {
  color: #406bc3;
}
.page-share .a2a_kit .a2a_button_facebook:hover {
  color: var(--green);
}
.page-share .a2a_kit .a2a_button_line {
  color: #07b53b;
}
.page-share .a2a_kit .a2a_button_line:hover {
  color: var(--green);
}
.page-share .a2a_kit .a2a_button_copy_link {
  color: #1b365d;
}
.page-share .a2a_kit .a2a_button_copy_link:hover {
  color: var(--green);
}
.page-share .a2a_kit .a2a_button_x {
  color: #000000;
}
.page-share .a2a_kit .a2a_button_x:hover {
  color: var(--green);
}
.page-share .a2a_kit a .pic {
  width: 25px;
  height: 25px;
}
.page-share .a2a_kit a .pic img {
  display: block;
  max-width: 100%;
  transition: 0.3s;
}
.page-share .a2a_kit a:not(:last-child) {
  margin-right: 10px;
}
.page-share .a2a_kit a:hover .pic img {
  transform: scale(1.2);
}

.clicks-number {
  display: flex;
}
.clicks-number .num {
  font-size: 1.125rem;
}

/*===== pagination =====*/
.pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-top: 70px;
}
.pagination .page_num {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 5px;
  font-size: 0.9375rem;
  text-decoration: none;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  color: #555;
  border: 1px solid transparent;
}
.pagination .page_num.active {
  background: var(--lblue);
  color: #fff;
}
.pagination .page_num:not(.active):hover {
  background: var(--dblue);
  color: #fff;
}
.pagination .page_arrow {
  font-size: 0.9375rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #555;
}
.pagination .page_arrow:hover {
  color: var(--yellow);
}
.pagination .page_arrow.prev {
  margin-right: 20px;
}
.pagination .page_arrow.next {
  margin-left: 20px;
}
.pagination .page_dot {
  display: inline-block;
  padding: 10px;
  text-align: center;
  margin: 0 3px;
}
.pagination .page_select {
  display: inline-block;
  margin-left: 30px;
}
.pagination .page_select .num_input {
  background: none;
  border-radius: 0;
  border: none;
  appearance: none;
  font-size: 0.9375rem;
  background: #fff;
  border: 1px solid #d2d2d2;
  width: 40px;
  height: 30px;
  padding: 3px 5px;
  border-radius: 3px;
  text-align: center;
  /* 隱藏箭頭 */
  /* Chrome, Safari, Edge, Opera */
  /* Firefox */
  -moz-appearance: textfield;
}
.pagination .page_select .num_input::-webkit-outer-spin-button, .pagination .page_select .num_input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.pagination .page_select .txt {
  display: inline-block;
  margin-left: 5px;
  color: #bfbfbf;
}
.pagination.right {
  justify-content: right;
}

/*===== btn-style =====*/
.page-btn-list {
  margin-top: 60px;
  text-align: center;
}
.page-btn-list button {
  appearance: none;
  background: none;
  border: none;
  display: block;
  cursor: pointer;
}
.page-btn-list .btn-style a,
.page-btn-list .btn-style div {
  background: var(--dblue);
  color: #fff;
  border-radius: 5px;
  padding: 15px 60px;
  line-height: 1;
}
.page-btn-list .btn-style a:hover,
.page-btn-list .btn-style div:hover {
  background: var(--lblue);
}
.page-btn-list.right {
  justify-content: flex-end;
}
.page-btn-list.center {
  justify-content: center;
}

.attachment-file-block {
  margin-top: 60px;
}

.attachment-pic {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
}
.attachment-pic .pic {
  display: block;
  width: calc((100% - 60px) / 6);
  position: relative;
  border-radius: 10px;
  overflow: hidden;
}
.attachment-pic .pic:after {
  display: inline-block;
  content: "\f302";
  font-family: "Font Awesome 6 Free";
  color: #fff;
  font-size: 2.125rem;
  font-weight: bold;
  display: block;
  width: 0;
  height: 0;
  background: rgba(30, 184, 212, 0.8);
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: 0.4s;
}
.attachment-pic .pic img {
  display: block;
  aspect-ratio: 1/1;
  width: 100%;
  object-fit: cover;
}
.attachment-pic .pic:hover:after {
  opacity: 1;
  width: 100%;
  height: 100%;
}

.attachment-file {
  margin-top: 40px;
}
.attachment-file .title {
  font-size: 1.25rem;
  font-weight: bold;
  border-bottom: 3px solid #f1f1f1;
  padding-bottom: 10px;
}
.attachment-file .title i {
  margin-right: 10px;
  color: var(--dblue);
}
.attachment-file .list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}
.attachment-file .list a {
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ade3ef;
  border-radius: 50%;
}
.attachment-file .list a img {
  display: block;
  max-width: 60%;
  max-height: 60%;
}
.attachment-file .list a:hover {
  background: var(--yellow);
}

/* search */
.page-search-form {
  background: #e6f0f7;
  border-radius: 10px;
  padding: 15px;
  width: 100%;
  margin-bottom: 60px;
}
.page-search-form form {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  gap: 15px;
}
.page-search-form button {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  display: block;
  background: var(--dblue);
  color: #fff;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  border-radius: 5px;
}
.page-search-form .input-box {
  display: flex;
  background: #fff;
  border-radius: 5px;
  padding: 10px 20px;
  align-items: baseline;
  width: 450px;
}
.page-search-form .input-box .title {
  width: 100px;
  color: var(--dblue);
  font-size: 1.125rem;
  font-weight: 500;
  position: relative;
}
.page-search-form .input-box .title:after {
  content: "";
  width: 1px;
  height: 60%;
  background: #ccc;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
.page-search-form .input-box .content {
  width: calc(100% - 100px);
}
.page-search-form .input-box .content input {
  border: none;
  box-shadow: none;
  height: 30px;
  display: block;
  width: 100%;
  padding-left: 20px;
  font-size: 1rem;
}
.page-search-form .input-box.date-range {
  width: 540px;
}
.page-search-form .input-box.date-range .content {
  display: flex;
}
.page-search-form .input-box.date-range .content input[type=date] {
  width: 200px;
  position: relative;
  background: url(../images/icon_date.svg) right 5px center no-repeat;
  background-size: 16px;
}
.page-search-form .input-box.date-range .content input[type=date]::-webkit-calendar-picker-indicator {
  color: transparent;
  background: none;
  z-index: 1;
}
.page-search-form .input-box.date-range .content span.to {
  display: inline-block;
  margin-left: 10px;
  font-size: 1.125rem;
}

/*========== pageBasic mobile ==========*/
@media (max-width: 1440px) {
  .page-banner .word {
    left: 10%;
  }
  .page-banner .word .en {
    font-size: 2.8125rem;
  }
  .page-banner .word .tw {
    font-size: 1.875rem;
  }
}
@media (max-width: 1280px) {
  .page-banner {
    padding-left: 40px;
  }
  .page-banner .word {
    left: 10%;
  }
  .page-banner .word .en {
    font-size: 2.5rem;
  }
  .page-banner .word .tw {
    font-size: 1.5rem;
    margin-top: 5px;
  }
  .breadcrumb ul {
    padding: 14px 0 9px 0;
  }
  .breadcrumb ul li {
    font-size: 1rem;
  }
  aside .page-menu {
    padding: 10px 0;
  }
  aside ul.layer1 > li {
    padding: 10px 15px;
  }
  aside ul.layer1 > li > a {
    font-size: 1.125rem;
  }
  .page-article-title .tw {
    font-size: 1.875rem;
  }
  .page-article-title .pic {
    width: 120px;
  }
  .page-article-title .title {
    font-size: 1.875rem;
  }
  .EN .page-article-title .en {
    font-size: 1.875rem;
  }
  .page-search-form form {
    flex-wrap: wrap;
  }
  .page-search-form .input-box {
    width: 320px;
  }
  .page-search-form .input-box.date-range {
    width: 460px;
  }
  .page-search-form .input-box.date-range .content input[type=date] {
    width: 160px;
  }
  .attachment-pic .pic:after {
    font-size: 1.75rem;
  }
  .attachment-file-block {
    margin-top: 40px;
  }
}
@media (max-width: 960px) {
  .page-banner {
    padding-left: 25px;
  }
  .page-banner .word {
    left: 10%;
  }
  .page-banner .word .en {
    font-size: 2.125rem;
  }
  .page-banner .word .tw {
    font-size: 1.25rem;
  }
  .page-banner img,
  .page-banner source {
    display: block;
    object-fit: cover;
    height: 100%;
    width: 100%;
  }
  .aside-menu-btn {
    display: block;
  }
  aside {
    display: none;
    background: var(--dblue);
    padding-bottom: 20px;
  }
  aside::before {
    display: none;
  }
  aside .page-menu {
    background: #e8f7ff;
    padding: 10px 20px;
    border-radius: 5px;
  }
  aside ul.layer1 {
    display: block;
  }
  aside ul.layer1 > li {
    padding: 2px 0;
  }
  aside ul.layer1 > li > a {
    font-size: 1.125rem;
    padding: 10px 0;
  }
  aside ul.layer1 > li > a:after {
    display: none;
  }
  aside ul.layer1 > li:not(:last-child):after {
    display: none;
  }
  aside ul.layer1 > li.active > a, aside ul.layer1 > li:hover > a {
    color: #222;
  }
  .page-article {
    background: none;
    padding-bottom: 60px;
  }
  .page-article-title {
    padding: 40px 0 40px 0;
  }
  .page-article-title .tw {
    font-size: 1.625rem;
  }
  .page-article-title .text {
    width: calc(100% - 120px);
  }
  .page-article-title .pic {
    width: 100px;
    bottom: 20px;
  }
  .page-article-title .title {
    font-size: 1.625rem;
  }
  .EN .page-article-title .en {
    font-size: 1.625rem;
  }
  .page-search-form form {
    gap: 10px;
  }
  .page-search-form button {
    width: 100%;
  }
  .page-search-form .input-box {
    width: 100%;
  }
  .page-search-form .input-box.date-range {
    width: 100%;
  }
  .page-search-form .input-box.date-range .content input[type=date] {
    width: calc((100% - 30px) / 2);
  }
  .attachment-pic .pic {
    width: calc((100% - 36px) / 3);
  }
  .attachment-file .title {
    font-size: 1.125rem;
  }
}
@media (max-width: 768px) {
  .page-banner {
    padding-left: 0;
  }
  .page-banner .pic {
    border-radius: 0;
  }
  .page-banner .word {
    left: 50px;
  }
  .page-banner .word .en {
    font-size: 1.875rem;
  }
  .page-banner .word .tw {
    font-size: 1.125rem;
  }
}
@media (max-width: 640px) {
  .page-banner .pic {
    height: 150px;
  }
  .page-article-title .text {
    width: calc(100% - 80px);
  }
  .page-article-title .pic {
    width: 80px;
  }
  .page-search-form .input-box {
    flex-wrap: wrap;
  }
  .page-search-form .input-box.date-range .content {
    flex-wrap: wrap;
  }
  .page-search-form .input-box.date-range .content input[type=date] {
    width: calc(100% - 25px);
    height: 35px;
  }
  .page-search-form .input-box.date-range .content input[type=date]:first-child {
    margin-bottom: 5px;
  }
  .pagination {
    margin-top: 40px;
  }
  .pagination .page_num {
    width: 25px;
    height: 25px;
  }
  .pagination .page_select {
    display: block;
    margin-top: 15px;
    width: 100%;
    text-align: center;
  }
  .attachment-pic .pic {
    width: calc((100% - 24px) / 3);
  }
  .page-detail-info {
    padding: 10px 15px;
    gap: 10px 20px;
    margin-bottom: 20px;
  }
  .page-detail-info .text {
    font-size: 1rem;
  }
  .attachment-file-block {
    margin-top: 20px;
  }
}
@media (max-width: 480px) {
  .page-banner .word {
    left: 25px;
  }
  .page-article-title {
    padding: 30px 0 20px 0;
  }
  .page-article-title .tw {
    font-size: 1.5rem;
  }
  .page-article-title .title {
    font-size: 1.5rem;
  }
  .EN .page-article-title .en {
    font-size: 1.5rem;
    font-weight: normal;
  }
  .page-search-form {
    padding: 10px;
  }
  .page-search-form .input-box {
    display: block;
    padding: 10px 15px;
  }
  .page-search-form .input-box .title {
    width: 100%;
    border-bottom: 1px solid #eee;
    margin-bottom: 5px;
    padding-bottom: 5px;
  }
  .page-search-form .input-box .title:after {
    display: none;
  }
  .page-search-form .input-box .content {
    width: 100%;
  }
  .page-search-form .input-box .content input {
    padding-left: 0;
  }
  .attachment-pic .pic {
    width: calc((100% - 12px) / 2);
  }
}