@charset "UTF-8";
:root {
  --main: #69b076;
  --lmain: #ebf7d3;
}

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

html {
  font-size: 16px;
}

body {
  font-family: "Open Sans", "微軟正黑體", 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: "Open Sans", "微軟正黑體", 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: 1400px;
  max-width: 100%;
  padding: 0 20px;
}

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

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

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

img::selection {
  background: transparent;
}

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

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

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

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

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

/* 404 */
.error-row {
  background: url(../images/404/error-background.svg) no-repeat;
  background-position: center top;
  max-width: 1400px;
  padding: 30px 25px 60px 25px;
  margin: 30px auto 0 auto;
}
.error-row .img-box {
  max-width: 440px;
  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: 80px;
  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: 30px;
  text-align: center;
}
.error-row .content .title {
  color: #222;
  font-size: 24px;
  font-weight: bold;
  margin: 0;
}
.error-row .content .des {
  margin-top: 25px;
}
.error-row .content .des p {
  color: #222;
  font-size: 17px;
  line-height: 1.6;
  margin: 0;
}
.error-row .content .des p:not(:last-child) {
  margin-bottom: 5px;
}
.error-row .btn-row {
  margin-top: 40px;
}
.error-row .btn-row .link {
  border-radius: 30px;
  background: #222;
  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(--s-color);
  color: var(--m-color);
}
@media (max-width: 1440px) {
  .error-row .img-box .error-code {
    font-size: 65px;
  }
  .error-row .btn-row {
    margin-top: 30px;
  }
}
@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 {
    max-width: 340px;
  }
  .error-row .img-box .error-code {
    font-size: 50px;
    top: 45%;
  }
  .error-row .content {
    margin-top: 30px;
  }
  .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;
}
@media (max-width: 640px) {
  .cookies-box .cookies-content {
    padding: 20px;
    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%;
  }
}

/* sitemap */
.sitemap-row {
  display: flex;
  flex-wrap: wrap;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
.sitemap-row a {
  text-decoration: inherit;
}
.sitemap-row .map-item {
  border-right: 1px solid #fff;
  box-sizing: border-box;
  margin-bottom: 30px;
  width: calc(100% / 5);
}
.sitemap-row .map-item .title-link {
  background: #555;
  color: #fff;
  display: block;
  font-size: 18px;
  line-height: 1.2;
  padding: 15px 25px 12px;
}
.sitemap-row .map-item .title-link:hover {
  font-weight: bold;
  background: var(--main);
}
.sitemap-row .map-list {
  border-left: 1px solid #ccc;
  margin-top: 15px;
  margin-bottom: 0;
  padding-left: 25px;
  padding-right: 20px;
}
.sitemap-row .map-list li {
  list-style: none;
}
.sitemap-row .map-list > li {
  padding-top: 8px;
  padding-bottom: 8px;
}
.sitemap-row .map-list .second-link {
  color: #333;
  font-size: 17px;
  line-height: 1.3;
}
.sitemap-row .map-list .second-link:hover {
  font-weight: bold;
  position: relative;
  color: var(--main);
}
.sitemap-row .map-list .second-link:hover:before {
  background: #fff;
  content: "\f105";
  color: #333;
  font-family: "Font Awesome 6 Free";
  font-weight: bold;
  font-size: 16px;
  position: absolute;
  top: -1px;
  left: -30px;
}
.sitemap-row .third-list {
  padding-left: 25px;
  margin-top: 10px;
}
.sitemap-row .third-list > li {
  padding-top: 5px;
  padding-bottom: 5px;
}
.sitemap-row .third-list .third-link {
  color: #333;
  font-size: 16px;
  line-height: 1.3;
  position: relative;
}
.sitemap-row .third-list .third-link:before {
  color: #aaa;
  content: "\f0da";
  font-family: "Font Awesome 6 Free";
  font-weight: bold;
  font-size: 14px;
  position: absolute;
  top: 1px;
  left: -15px;
}
.sitemap-row .third-list .third-link:hover {
  font-weight: bold;
}
.sitemap-row .third-list .third-link:hover:before {
  color: #333;
}

@media (max-width: 1024px) {
  .sitemap-row .map-item {
    width: calc(100% / 4);
  }
}

@media (max-width: 960px) {
  .sitemap-row .map-item {
    width: calc(100% / 3);
  }
}

@media (max-width: 768px) {
  .sitemap-row .map-item {
    width: calc(100% / 2);
  }
  .sitemap-row .map-item .title-link {
    padding: 15px;
    padding-bottom: 12px;
  }
  .sitemap-row .map-list {
    padding-left: 15px;
    padding-right: 10px;
  }
  .sitemap-row .map-list > li {
    padding-top: 6px;
    padding-bottom: 6px;
  }
  .sitemap-row .map-list .second-link:hover:before {
    left: -20px;
  }
  .sitemap-row .third-list {
    margin-top: 5px;
  }
}

/*========== basic mobile ==========*/
@media (max-width: 1440px) {
  .page-container {
    padding: 0 25px;
  }
}

/*========= form ==========*/
.form-style form {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 40px;
}

.form-style .form-box {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  transition: 0.3s;
  align-items: center;
}
.form-style .form-box .box-title {
  color: #222;
  margin-bottom: 2px;
  font-size: 1.125rem;
  position: relative;
}
.form-style .form-box .box-title .must {
  color: #e60012;
  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%;
  border: 1px solid #777777;
  padding: 8px 20px;
  font-size: 1rem;
  background: #fff;
  color: #222;
  text-align: left;
  transition: 0.3s;
  border-radius: 3px;
}
.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 #777777;
  padding: 8px 50px 8px 15px;
  font-size: 1rem;
  color: #222;
  text-align: left;
  background: #fff url(../images/select_arrow.svg) right 15px center no-repeat;
  background-size: 9px;
}
.form-style .form-box .box-content select:disabled {
  background: none;
  appearance: none;
}
.form-style .form-box .box-content select option:hover,
.form-style .form-box .box-content select option:focus,
.form-style .form-box .box-content select option:checked {
  background-color: red !important;
}
.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: 42px;
}
.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 select:focus {
  border-color: var(--green);
}
.form-style .form-box .box-content textarea {
  padding: 20px;
}
.form-style .form-box .box-content textarea:focus {
  border-color: var(--green);
}
.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: 1rem;
}
.form-style .form-box .radiobox input[type="radio"] {
  width: 18px;
  height: 18px;
  vertical-align: middle;
  transform: translateY(-3px);
}
.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% - 80px) / 3);
}
.form-style .form-box.quarter {
  width: calc((100% - 120px) / 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.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%;
  gap: 20px 40px;
}

.form-style .captcha-group {
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  align-items: flex-end;
  margin-top: 10px;
}

.form-style .form-btn-list {
  display: flex;
  column-gap: 10px;
}
.form-style .form-btn-list button {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  display: block;
  transition: 0.3s;
  color: #fff;
  background: #222;
  font-size: 1.125rem;
  height: 40px;
  width: 90px;
  font-weight: 300;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
}
.form-style .form-btn-list button.row {
  width: 100%;
}
.form-style .form-btn-list button:hover {
  background: var(--main);
}

.form-style.center {
  display: flex;
  justify-content: center;
}

.form-style.row {
  margin-top: 25px;
  width: 100%;
}

/*========== form mobile ==========*/
@media (max-width: 1280px) {
  .form-style form {
    gap: 20px;
  }
  .form-style .form-box.quarter {
    width: calc((100% - 60px) / 4);
  }
  .form-style .form-row-group {
    gap: 20px;
  }
}

@media (max-width: 960px) {
  .form-style form {
    gap: 10px;
  }
  .form-style .form-box .box-title {
    font-size: 1rem;
  }
  .form-style .form-box.quarter {
    width: 100%;
  }
  .form-style .form-row-group {
    gap: 10px;
  }
  .form-style .form-btn-list button {
    height: 35px;
    width: 80px;
    font-weight: normal;
  }
}

@media (max-width: 640px) {
  .form-style .captcha-group {
    flex-wrap: wrap;
  }
}

@media (max-width: 375px) {
  .form-style .form-box.captcha {
    justify-content: center;
  }
  .form-style .form-btn-list {
    width: 100%;
    justify-content: center;
  }
  .form-style .form-btn-list button {
    font-size: 1rem;
  }
}

/*========== header ==========*/
header {
  padding: 18px 0 19px 0;
}
header .logo {
  position: relative;
  transition: 0.3s;
}
header .logo a {
  display: block;
  width: 287px;
  height: 56px;
  background: url(../images/logo.png) no-repeat;
  background-size: contain;
  background-position: center left;
}
header .logo a img {
  display: block;
  max-width: 100%;
}
header .page-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* header-block1 */
.header-block1 {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 15px;
}

.header-other-link {
  margin-right: 20px;
}
.header-other-link ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
}
.header-other-link ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-other-link ul > li > a {
  display: block;
  color: #222;
  font-size: 1.0625rem;
}
.header-other-link ul > li > a::before {
  content: "";
  display: inline-block;
  margin-right: 5px;
  vertical-align: middle;
  transform: translateY(-2px);
}
.header-other-link ul > li > a:hover {
  text-decoration: underline;
}
.header-other-link ul > li.mainhome > a::before {
  width: 19px;
  height: 16px;
  background: url(../images/icon_heart.svg) no-repeat;
}
.header-other-link ul > li.home > a::before {
  width: 22px;
  height: 22px;
  background: url(../images/icon_home.svg) no-repeat;
}
.header-other-link ul > li.sitemap > a::before {
  width: 12px;
  height: 22px;
  background: url(../images/icon_mouse.svg) no-repeat;
}
.header-other-link ul > li.user > a::before {
  width: 15px;
  height: 19px;
  background: url(../images/icon_user.svg) no-repeat;
}
.header-other-link ul > li:not(:last-child) {
  margin-right: 20px;
}

/* header-block2 */
.header-block2 {
  display: flex;
  align-items: center;
}

.main-menu ul.layer1 {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
}
.main-menu ul.layer1 > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.main-menu ul.layer1 > li {
  position: relative;
}
.main-menu ul.layer1 > li > a {
  color: var(--main-menu);
  font-size: 1.25rem;
  font-weight: bold;
}
.main-menu ul.layer1 > li > a.phone {
  display: none;
}
.main-menu ul.layer1 > li.dropdown > a {
  position: relative;
  padding-right: 15px;
}
.main-menu ul.layer1 > li.dropdown > a::after {
  content: "";
  display: block;
  background: url(../images/icon_arrow.svg) no-repeat;
  width: 8px;
  height: 5px;
  position: absolute;
  right: 0;
  top: 50%;
}
.main-menu ul.layer1 > li.active > a {
  color: var(--main-menu-hover);
}
.main-menu ul.layer1 > li:hover > a {
  color: var(--main);
}
.main-menu ul.layer1 > li:not(:last-child) {
  margin-right: 40px;
}

.main-menu ul.layer2 {
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  z-index: 2;
  padding-top: 19px;
  left: 50%;
  transform: translateX(-50%);
  width: 160px;
  display: none;
}
.main-menu ul.layer2 > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.main-menu ul.layer2 > li > a {
  display: block;
  padding: 10px;
  background: #fafafa;
  color: #222;
  text-align: center;
}
.main-menu ul.layer2 > li:hover > a {
  background: var(--main);
  color: #fff;
}
.main-menu ul.layer2 > li:not(:last-child) {
  border-bottom: 1px solid #ddd;
}

.phone-bar {
  z-index: 1;
  display: none;
}
.phone-bar.active .bar {
  transform: rotate(-315deg);
}
.phone-bar.active .bar::before {
  opacity: 0;
}
.phone-bar.active .bar::after {
  transform: rotate(90deg) translate(-35%);
}
.phone-bar .group {
  position: relative;
  height: 30px;
  width: 30px;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 5px;
}
.phone-bar .bar {
  display: block;
  width: 25px;
  height: 3px;
  border-radius: 1px;
  transition: 800ms all;
  background: #222;
}
.phone-bar .bar::before,
.phone-bar .bar::after {
  content: "";
  display: block;
  width: 25px;
  height: 3px;
  border-radius: 1px;
  position: relative;
  transition: 400ms all;
  background: #222;
}
.phone-bar .bar::before {
  top: -8px;
}
.phone-bar .bar::after {
  bottom: -6px;
}

.main-search {
  width: 180px;
}
.main-search form {
  display: block;
  width: 100%;
  position: relative;
}
.main-search form input {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  display: block;
  width: 100%;
  padding: 5px 45px 5px 20px;
  border-radius: 25px;
  background: #eaeaea;
  height: 37px;
  font-size: 1.0625rem;
}
.main-search button {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  width: 40px;
  height: 37px;
  font-size: 0.875rem;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(calc(-50% - 2px));
}

/*========== header mobile ==========*/
@media (max-width: 1440px) {
  .main-menu ul.layer1 > li:not(:last-child) {
    margin-right: 30px;
  }
  .main-menu ul.layer1 > li > a {
    font-size: 1.125rem;
  }
}

@media (max-width: 1280px) {
  header {
    padding: 13px 0 14px 0;
  }
  header .logo a {
    width: 210px;
    height: 41px;
  }
  .main-menu {
    margin-right: 15px;
  }
  .main-menu ul.layer1 > li:not(:last-child) {
    margin-right: 20px;
  }
  .main-menu ul.layer1 > li > a {
    font-size: 1rem;
  }
  .main-menu ul.layer2 {
    left: initial;
    transform: none;
    right: 0;
  }
  .main-search form input {
    padding: 5px 30px 5px 15px;
    font-size: 1rem;
  }
  .main-search button {
    color: #222;
    top: 0;
    transform: none;
  }
}

@media (max-width: 960px) {
  header {
    height: 70px;
    padding: 14px 0;
    position: fixed;
    width: 100%;
    top: 0;
    background: #fff;
    z-index: 15;
    border-bottom: 1px solid #eee;
  }
  .main {
    padding-top: 70px;
  }
  .phone-bar {
    display: block;
  }
  .header-block1 {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .header-block2 {
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }
  .header-right {
    position: absolute;
    height: calc(100dvh - 70px);
    width: 70%;
    min-width: 300px;
    left: -100%;
    top: 70px;
    z-index: 15;
    background: #fff;
    border-top: 1px solid #eee;
    padding: 30px 20px;
    transition: 0.3s;
    overflow-y: auto;
  }
  .header-right.active {
    left: 0;
  }
  .main-menu {
    border-top: 1px solid #e8e8e8;
    width: 100%;
    margin: 0;
  }
  .main-menu ul.layer1 {
    flex-wrap: wrap;
  }
  .main-menu ul.layer1 > li {
    width: 100%;
    border-bottom: 1px solid #e8e8e8;
  }
  .main-menu ul.layer1 > li.dropdown > a {
    padding-right: 40px;
  }
  .main-menu ul.layer1 > li.dropdown > a:after {
    content: "\f077";
    background: none;
    display: inline-block;
    font-family: "Font Awesome 6 Free";
    width: auto;
    height: auto;
    font-size: 0.75rem;
    color: #999;
    right: 15px;
    top: 18px;
    transition: 0.3s;
  }
  .main-menu ul.layer1 > .dropdown.active > a {
    background: #69b076;
    color: #fff;
  }
  .main-menu ul.layer1 > .dropdown.active > a:after {
    transform: rotate(180deg);
    color: #fff;
  }
  .main-menu ul.layer1 > li > a {
    display: block;
    padding: 12px 40px 12px 15px;
  }
  .main-menu ul.layer1 > li > a.pc {
    display: none;
  }
  .main-menu ul.layer1 > li > a.phone {
    display: block;
  }
  .main-menu ul.layer1 > li:not(:last-child) {
    margin-right: 0;
  }
  .main-menu ul.layer2 {
    position: static;
    transform: none;
    width: 100%;
    padding-top: 0;
    border-top: 1px solid #ddd;
    background: #ebf7d3;
  }
  .main-menu ul.layer2 > li > a {
    background: none;
    text-align: left;
    padding: 12px 25px 12px 30px;
  }
  .main-menu ul.layer2 > li:hover > a {
    background: none;
    color: #222;
  }
  .main-menu ul.layer2 > li:not(:last-child) {
    border-bottom: 1px solid #fff;
  }
  .main-search {
    width: 100%;
    margin-top: 10px;
  }
}

@media (max-width: 640px) {
  .header-block1 {
    margin-bottom: 20px;
  }
  .header-other-link {
    width: 100%;
    margin-right: 0;
  }
  .header-other-link ul {
    flex-wrap: wrap;
    gap: 15px 10px;
  }
  .header-other-link ul > li > a::before {
    width: 25px !important;
    background-position: center !important;
  }
  .header-other-link ul > li:not(:last-child) {
    margin-right: 0;
  }
  .main-menu ul.layer1 > li > a {
    font-size: 1.2rem;
  }
  .main-menu ul.layer2 > li > a {
    font-size: 1.2rem;
  }
}

@media (max-width: 480px) {
  .header-right {
    height: calc(100dvh - 69px);
    top: 69px;
  }
}

/*===== footer =====*/
footer {
  background: var(--main);
  padding: 50px 0 60px 0;
}
footer .page-container {
  display: flex;
  justify-content: space-between;
  position: relative;
}

.footer-block2 {
  text-align: right;
}

.copyright {
  color: #fff;
  font-size: 1.0625rem;
}

.iware {
  color: #bed2c3;
  font-weight: lighter;
  margin-top: 5px;
}
.iware a {
  color: #bed2c3;
}
.iware a:hover {
  text-decoration: underline;
}

.footer-menu .layer {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-menu .layer > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-menu .layer > li > a {
  color: #fff;
}

.footer-menu .layer1 {
  display: flex;
}
.footer-menu .layer1 > li > a {
  font-size: 1.25rem;
  font-weight: bold;
  cursor: default;
}
.footer-menu .layer1 > li > a:not([href="javascript:;"]) {
  cursor: pointer;
}
.footer-menu .layer1 > li > a:not([href="javascript:;"]):hover {
  text-decoration: underline;
}
.footer-menu .layer1 > li:not(:last-child) {
  margin-right: 30px;
}

.footer-menu .layer2 {
  margin-top: 6px;
}
.footer-menu .layer2 > li > a {
  font-size: 1.125rem;
  font-weight: lighter;
}
.footer-menu .layer2 > li > a:hover {
  text-decoration: underline;
}
.footer-menu .layer2 > li:not(:last-child) {
  margin-bottom: 2px;
}

.footer-link {
  margin-top: 15px;
}
.footer-link ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: flex-end;
}
.footer-link ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-link ul > li > a {
  font-size: 1.125rem;
  color: #b7c8d4;
  font-weight: bold;
}
.footer-link ul > li:not(:last-child) {
  margin-right: 25px;
}

.footer-sns {
  margin-bottom: 20px;
}
.footer-sns ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
.footer-sns ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-sns ul > li {
  border-radius: 3px;
}
.footer-sns ul > li > a {
  display: block;
  font-size: 1.0625rem;
  padding: 12px 20px;
  line-height: 1;
}
.footer-sns ul > li.line > a::before {
  content: "";
  display: inline-block;
  margin-right: 8px;
  position: relative;
  vertical-align: bottom;
}
.footer-sns ul > li.line {
  background: #304269;
  transition: 0.3s;
}
.footer-sns ul > li.line > a {
  color: #fff;
}
.footer-sns ul > li.line > a::before {
  width: 19px;
  height: 19px;
  background: url(../images/sns_line.svg) no-repeat;
}
.footer-sns ul > li.line:hover {
  background: #222;
}
.footer-sns ul > li.member {
  background: #fff;
  transition: 0.3s;
}
.footer-sns ul > li.member > a {
  color: #304269;
  display: flex;
  align-items: center;
}
.footer-sns ul > li.member > a .icon{
  width: 19px;
  aspect-ratio: 1 / 1;
  display: block;
  margin-right: 8px;
}
.footer-sns ul > li.member > a .icon img{
  display: block;
  max-width: 100%;
  max-height: 100%;
}
/* .footer-sns ul > li.member > a::before {
  width: 15px;
  height: 18px;
  background: url(../images/sns_member.svg) no-repeat;
} */
.footer-sns ul > li.member:hover {
  background: var(--lmain);
}

.footer-info {
  margin-top: 15px;
}
.footer-info ul {
  list-style: none;
  margin: 0;
  padding: 0;
  line-height: 1.3;
}
.footer-info ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-info ul > li {
  font-size: 1.0625rem;
  color: #fff;
}
.footer-info ul > li > a {
  color: #fff;
}
.footer-info ul > li > a:hover {
  text-decoration: underline;
}
.footer-info ul > li.email {
  display: inline-block;
}
.footer-info ul > li.line {
  display: inline-block;
  margin-left: 10px;
}
.footer-info ul > li:not(:last-child) {
  margin-bottom: 5px;
}

.fixed-sns {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 3;
}
.fixed-sns ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.fixed-sns ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.fixed-sns ul li a {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  border: 1px solid #fff;
}
.fixed-sns ul li a:hover {
  opacity: 0.65;
}
.fixed-sns ul li.top a {
  background: #444;
  color: #fff;
}
.fixed-sns ul li.reserve a {
  background: #69b076;
  color: #fff;
}
.fixed-sns ul li.line a {
  background: #69b076;
  color: #fff;
}
.fixed-sns ul li.line a img {
  display: block;
  width: 27px;
}

/*========== footer mobile ==========*/
@media (max-width: 1680px) {
  .fixed-sns {
    transform: none;
    position: fixed;
    top: inherit;
    bottom: 20px;
    right: 10px;
    z-index: 1;
  }
}

@media (max-width: 1440px) {
  .footer-menu .layer1 > li > a {
    font-size: 1.125rem;
  }
  .footer-menu .layer1 > li:not(:last-child) {
    margin-right: 20px;
  }
  .footer-menu .layer2 > li > a {
    font-size: 1rem;
  }
  .footer-menu .layer2 > li:not(:last-child) {
    margin-right: 20px;
  }
  .copyright {
    font-size: 1rem;
  }
  .footer-info {
    margin-top: 10px;
  }
  .footer-info ul > li {
    font-size: 1rem;
  }
  .footer-link {
    margin-top: 10px;
  }
  .footer-link ul > li > a {
    font-size: 1rem;
  }
  .footer-link ul > li:not(:last-child) {
    margin-right: 15px;
  }
  .footer-language {
    margin-left: 10px;
  }
}

@media (max-width: 1280px) {
  footer {
    padding: 30px 0 40px 0;
  }
  footer .page-container {
    flex-wrap: wrap;
  }
  .footer-block1 {
    width: 100%;
  }
  .footer-block2 {
    width: 100%;
    text-align: center;
    margin-top: 20px;
  }
  .footer-menu .layer1 {
    justify-content: center;
  }
  .footer-link ul {
    justify-content: center;
  }
  .footer-sns ul {
    justify-content: center;
  }
}

@media (max-width: 960px) {
  .footer-block2 {
    margin-top: 0;
  }
  .footer-menu {
    display: none;
  }
  .fixed-sns ul {
    gap: 5px;
  }
  .fixed-sns ul > li a {
    width: 50px;
    height: 50px;
    font-size: 0.875rem;
  }
  .fixed-sns ul > li.line > a img {
    width: 20px;
  }
}

@media (max-width: 480px) {
  .footer-link ul {
    flex-wrap: wrap;
  }
  .footer-link ul > li {
    width: 100%;
  }
  .footer-link ul > li:not(:last-child) {
    margin-right: 0;
    margin-bottom: 10px;
  }
}

/*========== only-support ==========*/
/*===== page main =====*/
.main.nobanner .page-banner {
  display: none;
}

.main.nobanner .breadcrumb {
  background: linear-gradient(
    to right,
    transparent 0%,
    transparent calc(560 / 1920 * 100%),
    #eee calc(560 / 1920 * 100%),
    #eee 100%
  );
}
.main.nobanner .breadcrumb ul {
  background: #eee;
}

/*===== page banner =====*/
.page-banner img,
.page-banner source {
  display: block;
  max-width: 100%;
  margin: auto;
}

/*===== breadcrumb =====*/
.breadcrumb {
  position: relative;
}
.breadcrumb .breadcrumb-title {
  color: #fff;
  font-size: 1.375rem;
  font-weight: bold;
  padding-left: 30px;
  display: flex;
  align-items: center;
  width: 300px;
  background: var(--main);
}
.breadcrumb ul {
  list-style: none;
  margin: 0;
  padding: 0;
  background: #fff;
  padding: 15px 0 0 0;
  display: flex;
  flex-wrap: wrap;
}
.breadcrumb ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.breadcrumb ul li {
  color: #666666;
  font-size: 0.9375rem;
  margin-bottom: 5px;
}
.breadcrumb ul li a {
  color: #666666;
  font-size: 0.9375rem;
}
.breadcrumb ul li a:hover {
  color: var(--main);
}
.breadcrumb ul li:not(:last-child) {
  padding-right: 20px;
  position: relative;
}
.breadcrumb ul li:not(:last-child):after {
  content: "";
  display: block;
  background: url(../images/icon_arrow_right.svg) no-repeat;
  width: 6px;
  height: 9px;
  position: absolute;
  right: 6px;
  top: 9px;
}

/*===== aside =====*/
aside {
  width: 300px;
  background: #fff;
}
aside .layer {
  list-style: none;
  margin: 0;
  padding: 0;
}
aside .layer > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
aside .layer > li > a {
  display: block;
}
aside .layer1 > li > a {
  font-size: 1.125rem;
  color: #222;
  background: #fff;
  font-weight: bold;
  padding: 8px 50px 8px 30px;
  min-height: 45px;
  position: relative;
  border-bottom: 1px solid #ececec;
}
aside .layer1 > li > a:hover {
  background: #f1f1f1;
}
aside .layer1 > li.active > a {
  color: var(--main);
  background: var(--lmain);
}
aside .layer1 > li.dropdown > a:after {
  content: "\f053";
  display: block;
  font-weight: bold;
  font-family: "Font Awesome 5 Free";
  position: absolute;
  right: 22px;
  top: 13px;
  font-size: 0.75rem;
  transition: 0.3s;
}
aside .layer1 > li.dropdown > a:hover::after {
  transform: rotate(-90deg);
}
aside .layer1 > li.dropdown.active > a::after {
  transform: rotate(-90deg);
}
aside .layer2 {
  display: none;
}
aside .layer2 > li {
  border-top: 2px solid #fff;
}
aside .layer2 > li > a {
  font-size: 1.125rem;
  color: var(--main);
  background: var(--aside-layer2-bg);
  padding: 8px 30px 8px 50px;
  min-height: 45px;
  position: relative;
}
aside .layer2 > li > a:after {
  content: "\f105";
  display: block;
  font-weight: bold;
  font-family: "Font Awesome 5 Free";
  position: absolute;
  left: 33px;
  top: 13px;
  font-size: 0.75rem;
  transition: 0.3s;
}
aside .layer2 > li > a:hover {
  color: var(--aside-layer2-hover);
}
aside .layer2 > li > a:hover:after {
  color: var(--aside-layer2-hover);
}
aside .layer2 > li.active > a {
  color: var(--aside-layer2-hover);
}
aside .layer2 > li.active > a::after {
  color: var(--aside-layer2-hover);
}
aside .layer2 > li.dropdown.active > a:after {
  transform: rotate(90deg);
}
aside .layer3 {
  display: none;
}
aside .layer3 > li > a {
  font-size: 1.125rem;
  color: var(--aside-layer3);
  padding: 8px 30px 8px 65px;
  min-height: 45px;
  position: relative;
}
aside .layer3 > li > a:after {
  content: "\f0da";
  display: block;
  font-weight: bold;
  font-family: "Font Awesome 5 Free";
  position: absolute;
  left: 53px;
  top: 14px;
  font-size: 0.625rem;
  transition: 0.3s;
  color: var(--aside-layer3);
}
aside .layer3 > li > a:hover {
  color: var(--aside-layer3-hover);
}
aside .layer3 > li:not(:first-child) {
  border-top: 1px solid #ececec;
}
aside .layer3 > li.active > a {
  color: var(--aside-layer3-hover);
}
aside .layer3 > li.dropdown.active > a:after {
  transform: rotate(90deg);
}
aside .layer4 {
  display: none;
}
aside .layer4 > li {
  border-top: 1px solid #ececec;
}
aside .layer4 > li > a {
  font-size: 1.125rem;
  color: var(--aside-layer3);
  background: #fafafa;
  padding: 8px 30px 8px 80px;
  min-height: 45px;
  position: relative;
}
aside .layer4 > li > a:after {
  content: "-";
  display: block;
  font-weight: normal;
  position: absolute;
  left: 70px;
  top: 10px;
  font-size: 1rem;
  transition: 0.3s;
  color: var(--aside-layer3);
}
aside .layer4 > li > a:hover {
  color: var(--aside-layer3-hover);
}
aside .layer4 > li.active > a {
  color: var(--aside-layer3-hover);
}

.article-content {
  background: #fff;
  padding: 30px 0 40px 0;
}

.article-unreset > .unreset {
  min-height: 60px;
}

/* 單元標題 */
.article-title {
  font-weight: bold;
  color: #222;
  font-size: 1.75rem;
  margin: 0;
  margin-bottom: 40px;
}
.article-title:after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  margin-top: 5px;
  background: #aeaeae;
  background: -webkit-linear-gradient(
    legacy-direction(to right),
    #aeaeae 0%,
    #aeaeae 65px,
    #eee 65px,
    #eee 100%
  );
  background: linear-gradient(
    to right,
    #aeaeae 0%,
    #aeaeae 65px,
    #eee 65px,
    #eee 100%
  );
}

.article-detail-title-block {
  box-shadow: #fff 0 1px 0;
  margin-bottom: 30px;
}

.article-title2 {
  color: var(--main);
  font-weight: bold;
  position: relative;
  padding-left: 25px;
  font-size: 1.25rem;
  margin-bottom: 20px;
  line-height: 1;
}
.article-title2::before {
  content: "";
  background: url(../images/title_decorate.svg) no-repeat center;
  width: 15px;
  height: 15px;
  position: absolute;
  left: 0;
  top: 1px;
}
.article-title2 span {
  display: inline-block;
  padding-left: 10px;
  color: var(--green);
}

.article-title3 {
  font-size: 1.375rem;
  color: #304269;
  margin-bottom: 20px;
}
.article-title3:after {
  content: "";
  display: inline-block;
  font-weight: bold;
  margin-left: 8px;
  width: 13px;
  height: 13px;
  background: url(../images/title3_decorate.svg) no-repeat;
}

/* 內頁標題 */
.page-detail-title {
  font-size: 1.75rem /* 28/16 */;
  font-weight: bold;
  color: #333;
  padding-bottom: 12px;
  border-bottom: 1px solid #eee;
  line-height: 1.4;
  margin: 0;
}

.page-detail-title2 {
  color: var(--main);
  font-weight: bold;
  font-size: 1.25rem;
  padding-left: 25px;
  position: relative;
  margin-bottom: 10px;
}
.page-detail-title2::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 10px;
  background: url(../images/title_decorate.svg) no-repeat;
  width: 13px;
  height: 14px;
}

.page-detail-other {
  display: flex;
}

.page-detail-info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.page-detail-info .date {
  margin-top: 10px;
  color: #fb7567;
  font-size: 1rem;
  font-family: "Poppins", sans-serif;
  font-weight: 300;
}
.page-detail-info .date span {
  color: #222;
  font-weight: bold;
  display: inline-block;
  margin-right: 5px;
}
.page-detail-info .date.gray {
  color: #999999;
}
.page-detail-info .text {
  margin-top: 10px;
  font-size: 1rem;
  font-family: "Poppins", sans-serif;
  font-weight: 300;
}
.page-detail-info .text span {
  color: #222;
  font-weight: bold;
  display: inline-block;
  margin-right: 5px;
}
.page-detail-info > div:not(:last-child) {
  margin-right: 20px;
}

.page-sort {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
}
.page-sort span {
  display: block;
  background: #333;
  color: #fff;
  padding: 2px 10px;
  border-radius: 3px;
  min-height: 30px;
  font-size: 1rem;
}
.page-sort span:not(:last-child) {
  margin-right: 10px;
}

.page-share {
  margin-top: 10px;
  margin-left: auto;
}
.page-share .a2a_kit {
  display: flex;
}
.page-share .a2a_kit a .pic {
  width: 30px;
  height: 30px;
}
.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);
}

.page-article-content-group {
  display: flex;
  padding-bottom: 70px;
}

.page-detail-tag {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding-left: 30px;
  margin-top: 30px;
}
.page-detail-tag::before {
  content: "";
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  vertical-align: middle;
  background: url(../images/icon_tag.svg) no-repeat;
  width: 20px;
  height: 20px;
  position: absolute;
  left: 0;
  top: 4px;
}
.page-detail-tag a {
  color: #fb7567;
  font-size: 1.0625rem;
}
.page-detail-tag a:not(:last-child) {
  margin-right: 8px;
}
.page-detail-tag a:hover {
  text-decoration: underline;
}

/*===== main-section-group =====*/
.aside-menu-btn {
  font-size: 1rem;
  color: #fff;
  background: #222;
  padding: 8px 20px;
  display: none;
}
.aside-menu-btn i {
  margin-right: 10px;
}

.third-menu-style {
  margin-bottom: 30px;
}
.third-menu-style ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.third-menu-style ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.third-menu-style ul li a {
  display: block;
  padding: 10px 15px;
  color: #222;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1;
  border: 1px solid #ddd;
  border-radius: 25px;
}
.third-menu-style ul li a:hover {
  background: #c6ecfa;
}
.third-menu-style ul li.active a {
  font-weight: bold;
  background: #1c4ea1;
  color: #fff;
  border-color: #1c4ea1;
}

/*===== 頁面標題 =====*/
.article-content {
  width: 100%;
}

/*===== pagination =====*/
.pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-top: 40px;
}
.pagination .page_num {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 5px;
  font-size: 1rem;
  text-decoration: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  color: #222;
  border: 1px solid transparent;
}
.pagination .page_num.active {
  color: #fff;
  background: #222;
}
.pagination .page_num:hover {
  background: var(--main);
  color: #fff;
}
.pagination .page_arrow {
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #222;
}
.pagination .page_arrow:hover {
  color: var(--main);
}
.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 #222;
  width: 50px;
  height: 30px;
  padding: 3px 5px;
  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;
}

/*===== btn-style =====*/
.page-btn-block {
  border-top: 1px solid #eee;
}

.page-btn-list {
  display: flex;
}
.page-btn-list a {
  display: block;
  line-height: 1;
  font-size: 1.125rem;
  color: #222;
  padding: 18px 20px;
}
.page-btn-list button {
  appearance: none;
  background: none;
  border: none;
  display: block;
  cursor: pointer;
}
.page-btn-list .back-home {
  display: inline-block;
}
.page-btn-list .back-home a::before {
  content: "\f060";
  display: inline-block;
  font-weight: bold;
  font-family: "Font Awesome 5 Free";
  margin-right: 10px;
}
.page-btn-list .back-home a:hover {
  background: var(--lmain);
  color: var(--main);
}
.page-btn-list.right {
  justify-content: flex-end;
}
.page-btn-list.center {
  justify-content: center;
}

.want-donate-btn {
  max-width: 100%;
}
.want-donate-btn a {
  line-height: 1;
  font-size: 1.125rem;
  color: #222;
  width: 290px;
  max-width: 100%;
  display: block;
  font-size: 1.25rem;
  padding: 20.5px 10px;
  border: 2px solid #222;
  text-align: center;
}
.want-donate-btn a:hover {
  background: #222;
  color: #fff;
}
.want-donate-btn.fundraising-project-donate {
  margin-top: 30px;
}
.want-donate-btn.fundraising-project-donate-top {
  margin-bottom: 30px;
}

/*===== pages-list-search =====*/
.page-list-search {
  margin-bottom: 30px;
}
.page-list-search form {
  display: flex;
  background: #f5f5f5;
  padding: 10px 0;
}
.page-list-search form > div {
  height: 20px;
  display: flex;
  align-items: center;
}
.page-list-search form > div:not(:last-child) {
  border-right: 1px solid #d4d4d4;
}
.page-list-search form > div:not(:first-child) {
  border-left: 2px solid #fff;
}
.page-list-search form select,
.page-list-search form input,
.page-list-search form button {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  font-size: 1rem;
  color: #333;
}
.page-list-search form select {
  background: #f5f5f5 url(../images/select_arrow.svg) right 15px center
    no-repeat;
  background-size: 9px;
  padding: 0 40px 0 20px;
  width: 100%;
}
.page-list-search form input {
  background: #f5f5f5;
  padding: 0 20px;
  width: 100%;
}
.page-list-search form button {
  width: 55px;
  background: #f5f5f5;
  text-align: center;
  display: block;
}
.page-list-search form button:hover {
  color: var(--main);
}
.page-list-search form .keyword {
  flex: 1;
}
.page-list-search form .box.department {
  width: 225px;
}
.page-list-search form .box.team {
  width: 425px;
}
.page-list-search.sort-style form {
  background: #fff;
  border: 2px solid #222;
  width: 100%;
}
.page-list-search.sort-style form .box {
  width: 100%;
}
.page-list-search.sort-style form select {
  display: block;
  width: 100%;
  background: #fff url(../images/select_arrow.svg) right 15px center no-repeat;
  background-size: 9px;
  padding: 0 40px 0 20px;
}

.page-list-search2 {
  background: url(../images/bg_gray.jpg);
  padding: 15px 30px 15px 10px;
}
.page-list-search2 form {
  display: flex;
  flex-wrap: wrap;
}
.page-list-search2 .box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 0 20px;
  position: relative;
}
.page-list-search2 .box .title {
  color: #222;
  font-size: 1.0625rem;
  padding-right: 10px;
}
.page-list-search2 .box .content {
  flex: 1;
}
.page-list-search2 .box .content input[type="text"],
.page-list-search2 .box .content input[type="password"],
.page-list-search2 .box .content input[type="email"],
.page-list-search2 .box .content input[type="date"],
.page-list-search2 .box .content input[type="number"],
.page-list-search2 .box .content input[type="tel"],
.page-list-search2 .box .content textarea {
  background: none;
  border-radius: 0;
  border: none;
  appearance: none;
  width: 100%;
  padding: 8px 20px;
  font-size: 1rem;
  background: #fff;
  color: #222;
  text-align: left;
  transition: 0.3s;
  border-radius: 3px;
}
.page-list-search2 .box .content input[type="text"]::placeholder,
.page-list-search2 .box .content input[type="password"]::placeholder,
.page-list-search2 .box .content input[type="email"]::placeholder,
.page-list-search2 .box .content input[type="date"]::placeholder,
.page-list-search2 .box .content input[type="number"]::placeholder,
.page-list-search2 .box .content input[type="tel"]::placeholder,
.page-list-search2 .box .content textarea::placeholder {
  color: #aaa;
  font-weight: 300;
}
.page-list-search2 .box .content input[type="text"]:disabled,
.page-list-search2 .box .content input[type="password"]:disabled,
.page-list-search2 .box .content input[type="email"]:disabled,
.page-list-search2 .box .content input[type="date"]:disabled,
.page-list-search2 .box .content input[type="number"]:disabled,
.page-list-search2 .box .content input[type="tel"]:disabled,
.page-list-search2 .box .content textarea:disabled {
  background: none;
}
.page-list-search2 .box .content input[type="date"] {
  position: relative;
}
.page-list-search2
  .box
  .content
  input[type="date"]::-webkit-calendar-picker-indicator {
  color: transparent;
  background: none;
  z-index: 1;
}
.page-list-search2 .box .content input[type="date"]:before {
  color: transparent;
  background: none;
  display: block;
  content: "";
  background: url(../images/icon_date.svg) no-repeat right center;
  background-size: contain;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 12px;
  right: 15px;
}
.page-list-search2 .box .content select {
  background: none;
  border-radius: 0;
  border: none;
  appearance: none;
  width: 100%;
  padding: 8px 50px 8px 15px;
  font-size: 1rem;
  color: #222;
  text-align: left;
  background: #fff url(../images/select_arrow.svg) right 15px center no-repeat;
  background-size: 9px;
}
.page-list-search2 .box .content select:disabled {
  background: none;
  appearance: none;
}
.page-list-search2 .box .content input[type="text"],
.page-list-search2 .box .content input[type="password"],
.page-list-search2 .box .content input[type="email"],
.page-list-search2 .box .content input[type="date"],
.page-list-search2 .box .content input[type="number"],
.page-list-search2 .box .content input[type="tel"],
.page-list-search2 .box .content select {
  height: 40px;
}
.page-list-search2 .box .content input[type="text"]:focus,
.page-list-search2 .box .content input[type="password"]:focus,
.page-list-search2 .box .content input[type="email"]:focus,
.page-list-search2 .box .content input[type="date"]:focus,
.page-list-search2 .box .content input[type="number"]:focus,
.page-list-search2 .box .content input[type="tel"]:focus,
.page-list-search2 .box .content select:focus {
  border-color: var(--green);
}
.page-list-search2 .box:not(.keyword):not(:last-child):after {
  content: "";
  display: block;
  width: 1px;
  height: 50%;
  background: #cfcfd0;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
.page-list-search2 .box:not(:first-child):before {
  content: "";
  display: block;
  width: 2px;
  height: 50%;
  background: #fff;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.page-list-search2 .box.sort {
  width: 20%;
}
.page-list-search2 .box.date {
  width: 40%;
}
.page-list-search2 .box.date.range .content {
  display: flex;
  align-items: center;
}
.page-list-search2 .box.date.range .content span {
  display: inline-block;
  margin: 0 5px;
}
.page-list-search2 .box.keyword {
  flex: 1;
}
.page-list-search2 .search-btn button {
  background: none;
  border: none;
  cursor: pointer;
  appearance: none;
  display: block;
  transition: 0.3s;
  color: #fff;
  background: #444444;
  font-size: 1.0625rem;
  height: 40px;
  padding: 0 19px;
  font-weight: 300;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
}
.page-list-search2 .search-btn button img {
  display: inline-block;
  margin-left: 5px;
  width: 13px;
  height: 13px;
}
.page-list-search2 .search-btn button.row {
  width: 100%;
}
.page-list-search2 .search-btn button:hover {
  background: var(--main);
}

/* table-style */
.table-style table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  border: 1px solid #e8e8e8;
}
.table-style table td {
  padding: 10px 25px;
  border-bottom: 1px solid #e8e8e8;
  font-size: 1.0625rem;
  color: #222222;
}
.table-style table td::before {
  display: none;
  content: attr(data-title);
  font-weight: bold;
  color: #fff;
  background: var(--main);
  padding: 3px;
  width: 80px;
  text-align: center;
  margin-right: 15px;
  border-radius: 3px;
  font-size: 0.9375rem;
}
.table-style table td.c {
  text-align: center;
}
.table-style table td p {
  margin: 0;
}
.table-style table .right {
  text-align: right;
}
.table-style table thead td {
  background: #666666;
  color: #fff;
  font-weight: bold;
  white-space: nowrap;
}
.table-style table thead td:not(:last-child) {
  border-right: 1px solid #fff;
}
.table-style table tbody tr:nth-child(even) td {
  background: #f8f8f8;
}
.table-style table tbody tr:last-child td {
  border-bottom: none;
}
.table-style table tbody td {
  border: 1px solid #e8e8e8;
}

.tab-style-btn ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
}
.tab-style-btn ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.tab-style-btn ul a {
  display: block;
  padding: 7px 30px 6px 30px;
  border: 1px solid #f1f1f1;
  color: #222;
}
.tab-style-btn ul a:hover {
  background: #eee;
}
.tab-style-btn ul li.active a {
  background: var(--aside-layer2-bg);
  border-color: var(--aside-layer2-bg);
  color: var(--main);
  font-weight: bold;
}

.downloadfile-style {
  margin: 15px 0;
}
.downloadfile-style ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.downloadfile-style ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.downloadfile-style ul li a {
  display: flex;
  flex-wrap: wrap;
  border: 1px solid #eee;
  padding: 10px 15px 10px 30px;
  align-items: baseline;
  position: relative;
  color: #222;
}
.downloadfile-style ul li a::before {
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #222;
  position: absolute;
  left: 14px;
  top: 22px;
}
.downloadfile-style ul li a:hover .download-btn {
  background: var(--main);
  color: #fff;
}
.downloadfile-style ul li .txt {
  width: calc(100% - 170px);
}
.downloadfile-style ul li .filetype {
  margin-left: auto;
  font-size: 0.875rem;
  color: #4f7db2;
}
.downloadfile-style ul li .download-btn {
  display: block;
  background: #f2f2f2;
  border-radius: 30px;
  padding: 3px 12px;
  font-size: 0.9375rem;
  margin-left: 30px;
  transition: 0.3s;
}
.downloadfile-style ul li:not(:first-child) {
  margin-top: -1px;
}

.search-keyword-block {
  margin: 20px 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  font-weight: bold;
  background: #f1f1f1;
  padding: 10px 15px;
}
.search-keyword-block .keyword-txt {
  color: var(--main);
}

/* collapsing */
.collapsing-block.btnleft {
  border-top: 1px solid #eee;
}
.collapsing-block.btnleft .collapsing-box .collapsing-title {
  padding: 10px 10px 10px 30px;
}
.collapsing-block.btnleft .collapsing-box .collapsing-title::after {
  right: initial;
  left: 0;
}
.collapsing-block.btnleft .collapsing-box .collapsing-content {
  background: #f7f7f7;
  padding: 40px;
  border-top: 1px solid #eee;
  border-bottom: 1px solid #eee;
}

.collapsing-block.health .collapsing-box {
  margin-bottom: 8px;
}
.collapsing-block.health .collapsing-box .collapsing-title {
  background: url(../images/bg_lgray.jpg);
  padding-left: 20px;
}
.collapsing-block.health .collapsing-box .collapsing-title::before {
  display: none;
}
.collapsing-block.health .collapsing-box .collapsing-title .title {
  color: #304269;
  font-weight: 500;
  display: inline-flex;
  width: 300px;
}
.collapsing-block.health .collapsing-box .collapsing-title .price {
  /* color: #9a9fa8; */
  color: #1e5ce4;
  font-size: 1.1875rem;
  /* font-weight: 300; */
  font-weight: bold;
  position: relative;
  display: inline-flex;
}
.collapsing-block.health .collapsing-box .collapsing-title .price::before {
  /* content: "$"; */
  /* display: inline-block; */
}
.collapsing-block.health .collapsing-box .collapsing-content {
  background: none;
  padding: 30px 20px;
}
.collapsing-block.health .collapsing-box .collapsing-content .unreset {
  padding: 0;
}
.collapsing-block.health .collapsing-box .collapsing-content .unreset::before {
  display: none;
}

.collapsing-box {
  border-bottom: 1px solid #eee;
  position: relative;
}
.collapsing-box::before,
.collapsing-box:after {
  content: "";
  background: #304269;
  width: 15px;
  height: 3px;
  position: absolute;
  right: 20px;
  top: 22px;
  transition: 0.3s;
  z-index: 1;
}
.collapsing-box:after {
  transform: rotate(90deg);
}
.collapsing-box .collapsing-title {
  font-size: 1.125rem;
  font-weight: bold;
  color: #222;
  padding: 10px 50px 10px 50px;
  position: relative;
  cursor: pointer;
}
.collapsing-box .collapsing-title::before {
  content: "Q";
  display: block;
  width: 50px;
  text-align: center;
  color: #fb7268;
  font-size: 1.125rem;
  font-weight: 300;
  font-family: "Poppins";
  position: absolute;
  left: 0;
  top: 10px;
}
.collapsing-box .collapsing-content {
  padding: 40px;
  display: none;
  background: #f7f7f7;
}
.collapsing-box .collapsing-content .unreset {
  position: relative;
  padding-left: 50px;
}
.collapsing-box .collapsing-content .unreset::before {
  content: "A";
  display: block;
  width: 50px;
  text-align: center;
  color: #fb7268;
  font-size: 1.125rem;
  font-weight: 300;
  font-family: "Poppins";
  position: absolute;
  left: 0;
  top: 0;
}
.collapsing-box.active {
  border-color: transparent;
}
.collapsing-box.active::after {
  transform: rotate(0deg);
}

/* team */
.team-list {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 40px 60px;
  width: 1265px;
  max-width: 100%;
  margin: auto;
}
.team-list .team-box {
  width: calc((100% - 240px) / 5);
}

.team-box a:hover figure .mask {
  opacity: 1;
  top: 0;
}

.team-box figure {
  margin: 0;
  padding: 0;
  position: relative;
}
.team-box figure .pic {
  position: relative;
  padding-bottom: calc(300 / 235 * 100%);
  text-align: center;
  overflow: hidden;
  height: 0;
}
.team-box figure .pic img {
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.team-box figure .pic iframe,
.team-box figure .pic object,
.team-box figure .pic embed {
  position: absolute;
  display: block;
  margin: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.team-box figure .mask {
  background: rgba(161, 218, 154, 0.8);
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 50%;
  opacity: 0;
  transition: 0.3s;
}
.team-box figure .mask:after {
  content: "";
  display: block;
  background: url(../images/team_hover.svg);
  width: 45px;
  height: 45px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.team-box .content {
  margin-top: 15px;
  text-align: center;
}
.team-box .content .name {
  color: #333;
  font-size: 1.125rem;
  font-weight: bold;
}
.team-box .content .name span.en {
  font-weight: 300;
  display: block;
}
.team-box .content .job-department {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 10px;
  gap: 5px;
}
.team-box .content .job-department span {
  display: block;
  background: #f7f7f7;
  display: inline-block;
  border-radius: 25px;
  padding: 8px 15px;
  font-size: 0.875rem;
  font-weight: bold;
  line-height: 1;
  color: #66b878;
}

.team-detail-group {
  display: flex;
  flex-wrap: wrap;
}

.team-detail-pic {
  width: calc(235 / 1360 * 100%);
}
.team-detail-pic figure {
  margin: 0;
  padding: 0;
  position: relative;
  position: relative;
  padding-bottom: calc(300 / 235 * 100%);
  text-align: center;
  overflow: hidden;
  height: 0;
}
.team-detail-pic figure img {
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.team-detail-pic figure iframe,
.team-detail-pic figure object,
.team-detail-pic figure embed {
  position: absolute;
  display: block;
  margin: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}

.team-detail-info {
  width: calc(1125 / 1360 * 100%);
  padding: 0 50px;
}
.team-detail-info .name {
  font-weight: bold;
  font-size: 1.375rem;
  color: #333;
}
.team-detail-info .name .en {
  font-weight: 300;
  display: inline-block;
  padding-left: 10px;
}
.team-detail-info .job-department {
  display: flex;
  flex-wrap: wrap;
  margin-top: 15px;
  gap: 10px;
}
.team-detail-info .job-department a {
  display: block;
  background: #f7f7f7;
  display: inline-block;
  border-radius: 25px;
  padding: 7px 20px;
  font-weight: bold;
  line-height: 1;
  color: #66b878;
}
.team-detail-info .job-department a:hover {
  background: #66b878;
  color: #fff;
}
.team-detail-info .medical-group {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.team-detail-info .medical-group a {
  display: block;
  background: #fff;
  display: inline-block;
  border-radius: 25px;
  padding: 7px 15px;
  font-weight: bold;
  line-height: 1;
  color: #666;
  border: 1px solid #ddd;
}
.team-detail-info .medical-group a:hover {
  background: #666;
  color: #fff;
}
.team-detail-info .physician-profile,
.team-detail-info .current-position {
  margin-top: 20px;
  color: #333;
  font-size: 1.125rem;
}
.team-detail-info .physician-profile .title,
.team-detail-info .current-position .title {
  font-weight: bold;
}
.team-detail-info .physician-profile .txt,
.team-detail-info .current-position .txt {
  font-weight: 300;
  margin-top: 5px;
}

.team-detail-tab {
  margin-top: 70px;
  width: 100%;
}
.team-detail-tab .tabs ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
}
.team-detail-tab .tabs ul > li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.team-detail-tab .tabs ul li {
  margin-bottom: -1px;
}
.team-detail-tab .tabs ul li a {
  display: block;
  color: #333333;
  font-size: 1.125rem;
  font-weight: bold;
  padding: 10px 20px;
  border: 1px solid #f0f1f2;
  line-height: 1;
}
.team-detail-tab .tabs ul li:not(:first-child) {
  margin-left: -1px;
}
.team-detail-tab .tabs ul li.active a {
  background: #f5f5f5;
  border-color: #f5f5f5;
}
.team-detail-tab .tabs-show {
  background: #f5f5f5;
  padding: 30px 20px;
}

/* article */
.article-list {
  display: flex;
  flex-wrap: wrap;
  gap: 40px 66px;
}
.article-list.style2 .title {
  -webkit-line-clamp: 1;
  margin-top: 10px;
}

.article-box {
  width: calc((100% - 132px) / 3);
}
.article-box a:hover .title {
  color: #608cb2;
}
.article-box figure {
  margin: 0;
  padding: 0;
  position: relative;
}
.article-box figure .pic {
  position: relative;
  padding-bottom: calc(150 / 290 * 100%);
  text-align: center;
  overflow: hidden;
  height: 0;
}
.article-box figure .pic img {
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.article-box figure .pic iframe,
.article-box figure .pic object,
.article-box figure .pic embed {
  position: absolute;
  display: block;
  margin: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.article-box .title {
  font-weight: bold;
  font-size: 1.125rem;
  color: #333;
  margin-top: 20px;
  transition: 0.3s;
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.article-box .txt {
  font-size: 1.0625rem;
  color: #333;
  padding-right: 40px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin-top: 5px;
}
.article-box .row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
}
.article-box .sort {
  margin-top: 5px;
  font-size: 0.875rem;
  color: #222;
  border: 1px solid #ccc;
  border-radius: 3px;
  padding: 7px 15px;
  line-height: 1;
  display: inline-block;
}
.article-box .date {
  margin-top: 5px;
  color: #fb7268;
  font-size: 0.9375rem;
  font-family: "Poppins", sans-serif;
  font-weight: 300;
}

.article-list2 {
  display: flex;
  flex-wrap: wrap;
  gap: 50px 75px;
}

.article-box2 {
  width: calc((100% - 75px) / 2);
}
.article-box2 a {
  display: flex;
}
.article-box2 a:hover .title {
  color: #608cb2;
}
.article-box2 figure {
  margin: 0;
  padding: 0;
  position: relative;
  width: 140px;
}
.article-box2 figure .pic {
  position: relative;
  padding-bottom: calc(600 / 480 * 100%);
  text-align: center;
  overflow: hidden;
  height: 0;
}
.article-box2 figure .pic img {
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.article-box2 figure .pic iframe,
.article-box2 figure .pic object,
.article-box2 figure .pic embed {
  position: absolute;
  display: block;
  margin: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.article-box2 .content {
  flex: 1;
  padding-left: 25px;
}
.article-box2 .title {
  font-weight: bold;
  font-size: 1.125rem;
  color: #333;
  margin-top: 10px;
  transition: 0.3s;
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}
.article-box2 .txt {
  font-size: 1.0625rem;
  color: #333;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  margin-top: 5px;
}
.article-box2 .row {
  display: flex;
  align-items: center;
}
.article-box2 .sort {
  margin-top: 5px;
  font-size: 0.875rem;
  color: #222;
  border: 1px solid #ccc;
  border-radius: 3px;
  padding: 7px 15px;
  line-height: 1;
  display: inline-block;
}
.article-box2 .date {
  margin-top: 5px;
  color: #fb7268;
  font-size: 0.9375rem;
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  margin-left: 10px;
}

/* download-file */
.download-file-box a {
  display: flex;
  flex-wrap: wrap;
  border-bottom: 1px solid #eee;
  padding: 18px 20px;
  align-items: center;
  position: relative;
  color: #222;
  line-height: 1;
  gap: 30px;
}
.download-file-box a:hover {
  background: #f7f7f7;
}
.download-file-box a:hover .download-btn {
  opacity: 1;
}

.download-file-box .txt {
  flex: 1;
  font-weight: bold;
  font-size: 1.125rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.download-file-box .filetype {
  font-size: 0.875rem;
  width: 40px;
  text-align: center;
}
.download-file-box .filetype.pdf {
  color: #d93737;
}
.download-file-box .filetype.doc {
  color: #4f7db2;
}
.download-file-box .filetype.xml {
  color: #529f4c;
}

.download-file-box .download-btn {
  display: block;
  text-indent: -999999px;
  width: 32px;
  height: 23px;
  background: url(../images/icon_download.svg) no-repeat center;
  transition: 0.4s;
  opacity: 0.25;
}

.download-file-box:not(:first-child) {
  margin-top: -1px;
}

/* page-sort-select*/
.page-sort-select {
  max-width: 100%;
  margin-bottom: 20px;
}
.page-sort-select .form-box .box-content {
  text-align: right;
}
.page-sort-select .form-box .box-content select {
  width: auto;
  max-width: 100%;
}

/*========== pageBasic mobile ==========*/
@media (max-width: 1440px) {
  aside + .article-content {
    padding-left: 40px;
  }
  .page-article-content-group {
    padding-bottom: 50px;
  }
}

@media (max-width: 1366px) {
  .team-list {
    margin-top: 20px;
    gap: 40px;
  }
  .team-list .team-box {
    width: calc((100% - 120px) / 4);
  }
}

@media (max-width: 1280px) {
  .breadcrumb .breadcrumb-title {
    font-size: 1.25rem;
    width: 250px;
  }
  .breadcrumb ul {
    width: calc(100% - 250px);
  }
  aside {
    width: 250px;
  }
  aside .layer1 > li > a {
    padding: 8px 30px 8px 20px;
    font-size: 1.0625rem;
  }
  aside .layer1 > li.dropdown > a:after {
    right: 13px;
    top: 11px;
  }
  aside .layer2 > li > a {
    padding: 8px 20px 8px 30px;
    font-size: 1.0625rem;
  }
  aside .layer2 > li > a:after {
    left: 15px;
  }
  aside .layer3 > li > a {
    padding: 8px 20px 8px 30px;
    font-size: 1.0625rem;
  }
  aside .layer3 > li > a:after {
    left: 15px;
  }
  aside .layer4 > li > a {
    padding: 8px 20px 8px 30px;
    font-size: 1.0625rem;
  }
  aside .layer4 > li > a:after {
    left: 15px;
  }
  aside + .article-content {
    width: calc(100% - 250px);
    padding-left: 30px;
  }
  .article-title {
    margin-bottom: 20px;
  }
  .page-article-content-group {
    padding-bottom: 40px;
  }
  .page-btn-list a {
    font-size: 1rem;
    padding: 15px 17px;
  }
  .want-donate-btn a {
    font-size: 1rem;
    padding: 15px 10px;
  }
  .team-list {
    margin-top: 10px;
    gap: 30px;
  }
  .team-list .team-box {
    width: calc((100% - 90px) / 4);
  }
  .team-detail-pic {
    width: 27%;
  }
  .team-detail-info {
    width: 73%;
    padding: 0 30px;
  }
  .article-list {
    gap: 40px;
  }
  .article-box {
    width: calc((100% - 80px) / 3);
  }
  .article-list2 {
    gap: 40px 30px;
  }
  .article-box2 {
    width: calc((100% - 40px) / 2);
  }
  .article-box2 figure {
    width: 120px;
  }
  .article-box2 .content {
    padding-left: 15px;
  }
  .page-list-search2 {
    padding: 10px 15px 10px 0;
  }
  .page-list-search2 form {
    align-items: end;
  }
  .page-list-search2 .box .title {
    width: 100%;
  }
  .page-list-search2 .box .content {
    margin-top: 2px;
  }
}

@media (max-width: 1024px) {
  .article-list {
    gap: 20px;
  }
  .article-box {
    width: calc((100% - 40px) / 3);
  }
  .article-list2 {
    gap: 30px 0;
  }
  .article-box2 {
    width: 100%;
  }
  .article-box2 .content {
    padding-left: 20px;
  }
  .page-list-search2 .box:not(.keyword):not(:last-child):after {
    display: none;
  }
  .page-list-search2 .box:not(:first-child):before {
    display: none;
  }
}

@media (max-width: 960px) {
  .main.nobanner .breadcrumb {
    background: #fff;
  }
  .main.nobanner .breadcrumb ul {
    background: #fff;
  }
  aside {
    width: 100%;
  }
  aside + .article-content {
    width: 100%;
    padding-left: 0;
  }
  aside .layer1 {
    display: none;
  }
  .article-content {
    padding: 20px 0 0 0;
  }
  .aside-menu-btn {
    display: block;
  }
  .breadcrumb:after {
    display: none;
  }
  .breadcrumb .page-container {
    flex-wrap: wrap;
    padding: 0;
  }
  .breadcrumb .breadcrumb-title {
    width: 100%;
    padding: 10px 15px;
  }
  .breadcrumb ul {
    width: 100%;
    padding: 10px 25px 5px 25px;
    justify-content: flex-start;
    border-bottom: none;
  }
  .page-article {
    background: none;
  }
  .page-article-content-group {
    flex-wrap: wrap;
  }
  .pagination .page_num {
    width: 30px;
    height: 30px;
    font-size: 0.9375rem;
  }
  .pagination .page_arrow.prev {
    margin-right: 10px;
  }
  .pagination .page_arrow.next {
    margin-left: 10px;
  }
  .pagination .page_select {
    margin-left: 0;
    margin-top: 20px;
    display: block;
    width: 100%;
    text-align: center;
  }
  .table-style table td {
    padding: 5px 15px;
    font-size: 1rem;
  }
  .team-detail-info {
    padding: 0 0 0 30px;
  }
  .team-detail-info .name {
    font-size: 1.25rem;
  }
  .team-detail-info .job-department {
    margin-top: 10px;
  }
  .team-detail-info .job-department span {
    padding: 7px 15px;
  }
  .team-detail-info .medical-group .group {
    padding: 7px 15px;
    margin-bottom: 5px;
  }
  .team-detail-info .medical-group .group:not(:last-child) {
    margin-right: 10px;
  }
  .team-detail-info .physician-profile,
  .team-detail-info .current-position {
    margin-top: 15px;
    font-size: 1rem;
  }
  .team-detail-info .physician-profile .txt,
  .team-detail-info .current-position .txt {
    font-weight: normal;
  }
  .team-detail-tab {
    margin-top: 50px;
  }
  .article-box .title {
    font-size: 1rem;
  }
  .article-box .txt {
    padding-right: 0;
    font-size: 0.9375rem;
  }
  .article-box .sort {
    padding: 7px 10px;
  }
  .article-box2 {
    width: 100%;
  }
  .article-box2 .title {
    font-size: 1.0625rem;
  }
  .article-box2 .txt {
    font-size: 1rem;
  }
  .page-list-search2 {
    padding: 10px 15px;
  }
  .page-list-search2 .box {
    padding: 0;
    margin-bottom: 10px;
  }
  .page-list-search2 .box.sort {
    width: 100%;
  }
  .page-list-search2 .box.date {
    width: 100%;
  }
  .page-list-search2 .box.keyword {
    width: 100%;
  }
  .page-list-search2 .search-btn {
    width: 100%;
  }
  .page-list-search2 .search-btn button {
    width: 100%;
  }
  .collapsing-box .collapsing-content {
    padding: 20px;
  }
}

@media (max-width: 768px) {
  .team-list .team-box {
    width: calc((100% - 60px) / 3);
  }
}

@media (max-width: 640px) {
  .article-title3 {
    font-size: 1.25rem;
  }
  .page-detail-info .date {
    width: 100%;
  }
  .third-menu-style ul {
    gap: 8px;
  }
  .third-menu-style ul li a {
    padding: 8px 12px;
    font-size: 1.125rem;
    font-weight: normal;
  }
  .breadcrumb ul li {
    font-size: 1.1rem;
  }
  .breadcrumb ul li a {
    font-size: 1.1rem;
  }
  .team-box .content .job-department span {
    font-size: 1.0625rem;
  }
  .page-list-search2 .box .title {
    font-size: 1.125rem;
  }
  .page-btn-list a {
    font-size: 1.125rem;
  }
  .page-share {
    margin-left: 0;
  }
  .page-detail-title {
    font-size: 1.375rem /* 22/16 */;
  }
  .table-style.has-rwd table {
    min-width: initial !important;
    border: none;
  }
  .table-style.has-rwd table td {
    width: 100%;
  }
  .table-style.has-rwd table thead {
    display: none;
  }
  .table-style.has-rwd table thead td:not(:last-child) {
    border: none;
  }
  .table-style.has-rwd table tbody tr {
    display: block;
    margin: 15px 0;
  }
  .table-style.has-rwd table tbody tr:last-child td {
    border-bottom: 1px solid #e8e8e8;
  }
  .table-style.has-rwd table tbody td {
    display: flex;
    align-items: baseline;
    width: 100%;
    padding: 10px;
  }
  .table-style.has-rwd table tbody td::before {
    display: block;
  }
  .table-style.has-rwd table tbody td.c {
    text-align: left;
  }
  .table-style.has-rwd table tbody td p {
    width: calc(100% - 70px);
  }
  .table-style.has-rwd table tbody td span {
    flex: 1;
  }
  .table-style.has-rwd table tbody td:not(:last-child) {
    border-bottom: none;
  }
  .table-style.has-rwd table .right {
    text-align: left;
  }
  .table-style.has-rwd table .center {
    text-align: left;
  }
  .downloadfile-style ul li .txt {
    width: 100%;
    margin-bottom: 5px;
  }
  .downloadfile-style ul li .filetype {
    margin: initial;
  }
  .team-list {
    gap: 20px;
  }
  .team-list .team-box {
    width: calc((100% - 20px) / 2);
  }
  .team-detail-pic {
    width: 235px;
    margin: auto;
  }
  .team-detail-info {
    width: 100%;
    padding: 0;
    margin-top: 20px;
  }
  .team-detail-tab {
    margin-top: 40px;
  }
  .team-detail-tab .tabs ul li a {
    padding: 10px 15px;
    font-size: 1rem;
  }
  .article-box {
    width: calc((100% - 20px) / 2);
  }
  .article-box .title {
    margin-top: 10px;
  }
  .download-file-box a {
    padding: 12px 10px 12px 10px;
    gap: 15px;
  }
  .download-file-box .txt {
    font-size: 1rem;
    line-height: 1.5;
    white-space: normal;
  }
  .page-sort-select .form-box .box-content select {
    width: 100%;
  }
  .collapsing-box .collapsing-content {
    padding: 15px 15px 15px 0;
  }
  .page-list-search2 .search-btn button {
    font-weight: 400;
    font-size: 1.125rem;
  }
  .search-keyword-block {
    font-size: 1.125rem;
  }
}

@media (max-width: 480px) {
  .team-detail-info .name .en {
    display: block;
    padding-left: 0;
  }
  .article-list {
    gap: 10px;
  }
  .article-box {
    width: calc((100% - 10px) / 2);
  }
  .article-list2 {
    gap: 20px 0;
  }
  .article-box2 figure {
    width: 100px;
  }
  .article-box2 .content {
    padding-left: 15px;
  }
  .page-btn-list.right {
    justify-content: center;
  }
  .page-list-search2 {
    padding: 15px;
  }
  .page-list-search2 .box.date.range .content {
    flex-wrap: wrap;
  }
  .page-list-search2 .box.date.range .content input {
    width: 100%;
  }
  .page-list-search2 .box.date.range .content input:first-child {
    margin-bottom: 10px;
  }
  .page-list-search2 .box.date.range .content span {
    display: none;
  }
}

@media (max-width: 375px) {
  .article-list {
    margin: 0;
  }
  .article-box {
    padding: 0;
    width: 100%;
    max-width: 100%;
  }
  .article-box .sort {
    font-size: 0.9375rem;
    margin-top: 0;
  }
  .collapsing-box .collapsing-title {
    padding: 10px 50px 10px 40px;
  }
  .collapsing-box .collapsing-title::before {
    width: 40px;
  }
  .collapsing-box .collapsing-content .unreset {
    padding-left: 40px;
  }
  .collapsing-box .collapsing-content .unreset::before {
    width: 40px;
  }
}

@media (max-width: 320px) {
  .team-list {
    margin-top: 10px;
  }
  .team-list .team-box {
    width: 235px;
    margin: auto;
  }
  .download-file-box .txt {
    width: 100%;
    flex: auto;
  }
}

/*========= index ==========*/
.index-container {
  margin: 0 auto;
  width: 1400px;
  max-width: 100%;
  padding: 0 20px;
}

.index-section-title {
  color: #292c33;
  font-size: 2.25rem;
  margin-bottom: 30px;
}
.index-section-title.c {
  text-align: center;
}

/*========== index-banner ==========*/
.index-banner {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.index-banner .swiper-slide figure {
  display: block;
  margin: 0;
  padding: 0;
  height: calc(500 / 1920 * 100%);
  height: 500px;
}
.index-banner .swiper-slide figure img {
  display: block;
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.index-banner .swiper-button-next,
.index-banner .swiper-button-prev {
  --swiper-navigation-size: 20px;
  color: #292c33;
  font-weight: bold;
  transition: 0.3s;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.75);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  width: 45px;
  height: 45px;
}
.index-banner .swiper-button-next:hover,
.index-banner .swiper-button-prev:hover {
  background: var(--main);
  color: #fff;
}
.index-banner .swiper-button-next {
  right: 5%;
}
.index-banner .swiper-button-next:after {
  transform: translateX(1px);
}
.index-banner .swiper-button-prev {
  left: 5%;
}
.index-banner .swiper-button-prev:after {
  transform: translateX(-1px);
}
.index-banner .swiper-pagination{
}
.index-banner .swiper-pagination-bullet{
  background: #eee;
  opacity: .8;
}
.index-banner .swiper-pagination-bullet-active{
  background: var(--main);
  opacity: 1;
}
.index-banner  .swiper-pagination.swiper-pagination-lock {
  display: block !important;
} 
/*========== index-link ==========*/
.index-section-link {
  /* padding-top: 90px; */
  padding: 45px 0;
  background: url(../images/bg_gray.jpg);
}

.index-link-list {
  display: flex;
  gap: 55px;
  width: 1345px;
  max-width: 100%;
  margin: auto;
}

.index-link-box {
  width: calc((100% - 165px) / 4);
  text-align: center;
}
.index-link-box a {
  display: block;
  position: relative;
}
.index-link-box a:hover figure::before {
  transform: translateX(100%);
}
.index-link-box a:after {
  content: "";
  display: block;
  background: url(../images/index_link_shadow.png) no-repeat;
  width: 15px;
  height: 100%;
  position: absolute;
  right: -15px;
  top: 0;
  background-size: contain;
}
.index-link-box figure {
  margin: 0;
  padding: 0;
  position: relative;
  border-radius: 10px;
  overflow: hidden;
}
.index-link-box figure::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.2) 50%,
    rgba(255, 255, 255, 0) 100%
  );
  transform: translateX(-100%);
  transition: transform 0.8s ease;
  z-index: 1;
}
.index-link-box figure .pic {
  position: relative;
  padding-bottom: calc(180 / 295 * 100%);
  text-align: center;
  overflow: hidden;
  height: 0;
}
.index-link-box figure .pic img {
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.index-link-box figure .pic iframe,
.index-link-box figure .pic object,
.index-link-box figure .pic embed {
  position: absolute;
  display: block;
  margin: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.index-link-box .content {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: all 0.4s ease;
}
.index-link-box .content .icon {
  width: 42px;
  height: 42px;
}
.index-link-box .content .icon img {
  display: block;
  max-width: 100%;
  max-height: 100%;
  margin: auto;
}
.index-link-box .content .title {
  color: #fff;
  font-size: 1.375rem;
  font-weight: bold;
  text-align: center;
  transition: all 0.4s ease;
  margin-top: 12px;
}
.index-link-box .more {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.125rem;
  width: 170px;
  max-width: 100%;
  height: 40px;
  background: #444444;
  transition: 0.3s;
  border-radius: 50px;
  margin: 20px auto 0 auto;
}

/*========== index-news ==========*/
.index-section-news {
  padding: 90px 0 120px 0;
}

/*========== index-about ==========*/
.index-section-about {
  background: url(../images/bg_gray.jpg);
  padding: 80px 0 90px 0;
}
.index-section-about .index-container {
  align-items: flex-start;
  display: flex;
}
.index-section-about .index-section-title {
  font-weight: bold;
  margin-bottom: 15px;
}

.index-about-pic {
  width: calc(740 / 1360 * 100%);
  position: relative;
}
.index-about-pic .shadow {
  display: block;
  width: 92%;
  height: 92%;
  position: absolute;
  z-index: 0;
  background: transparent;
  right: 0;
  bottom: 0;
  transition: 0.4s;
  border-radius: 5px;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.75);
}
.index-about-pic .pic {
  position: relative;
}
.index-about-pic .pic img {
  display: block;
  max-width: 100%;
}

.index-about-content {
  width: calc(620 / 1360 * 100%);
  padding-left: calc(60 / 1360 * 100%);
  padding-right: calc(60 / 1360 * 100%);
  padding-top: 10px;
}
.index-about-content .txt {
  color: #222222;
  font-weight: 300;
  font-size: 1.2rem;
}
.index-about-content .txt span {
  display: block;
}
.index-about-content .more {
  margin-top: 30px;
}
.index-about-content .more a {
  display: inline-block;
  background: #fff;
  background: #fff;
  font-weight: bold;
  padding: 8px 15px;
  border-radius: 50px;
  border: 1px solid #ddd;
  font-size: 1.0625rem;
  font-weight: 300;
  color: #222;
}
.index-about-content .more a:hover {
  border-color: #69b076;
  background: #69b076;
  color: #fff;
}

/*========== index-link2 ==========*/
.index-link2-container {
  width: 1460px;
  max-width: 100%;
  margin: auto;
}

.index-section-link2 {
  padding: 100px 0 130px 0;
}
.index-section-link2 .swiper-button-next,
.index-section-link2 .swiper-button-prev {
  --swiper-navigation-size: 18px;
  color: #292c33;
  font-weight: bold;
  transition: 0.3s;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.75);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  width: 40px;
  height: 40px;
}
.index-section-link2 .swiper-button-next:hover,
.index-section-link2 .swiper-button-prev:hover {
  background: var(--main);
  color: #fff;
}
.index-section-link2 .swiper-button-next {
  right: 0;
}
.index-section-link2 .swiper-button-next:after {
  transform: translateX(1px);
}
.index-section-link2 .swiper-button-prev {
  left: 0;
}
.index-section-link2 .swiper-button-prev:after {
  transform: translateX(-1px);
}

.index-link2-block {
  padding: 0 50px;
}

.index-link2-box a:hover figure:after {
  opacity: 1;
}

.index-link2-box a:hover .title {
  color: var(--main);
}

.index-link2-box figure {
  margin: 0;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}
.index-link2-box figure .pic {
  /* position: relative; */
  /* padding-bottom: calc(170 / 300 * 100%); */
  /* text-align: center; */
  /* overflow: hidden; */
  /* height: 0; */
  width: 100%;
  aspect-ratio: 300 / 170;
}
.index-link2-box figure .pic img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
 /*  max-width: 100%;
  max-height: 100%;
  position: absolute;
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0; */
}
.index-link2-box figure .pic iframe,
.index-link2-box figure .pic object,
.index-link2-box figure .pic embed {
  position: absolute;
  display: block;
  margin: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.index-link2-box figure:after {
  content: "";
  display: block;
  background: rgba(105, 176, 118, 0.4);
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: all 0.4s;
}

.index-link2-box .title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #222;
  font-size: 1.25rem;
  font-weight: bold;
  margin-top: 15px;
  transition: all 0.4s;
}

.index-link2-box .txt {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  color: #666666;
  font-size: 1rem;
  font-weight: 300;
  margin-top: 10px;
}

/*========== index mobile ==========*/
@media (max-width: 1440px) {
  .index-container {
    padding: 0 25px;
  }
  .index-section-news {
    padding: 80px 0 90px 0;
  }
  .index-section-link2 {
    padding: 80px 0 90px 0;
  }
}

@media (max-width: 1280px) {
  .index-banner .swiper-slide figure {
    height: 350px;
  }
  .index-section-title {
    margin-bottom: 20px;
    font-size: 1.875rem;
  }
  .index-link-list {
    gap: 40px;
  }
  .index-link-box {
    width: calc((100% - 120px) / 4);
  }
  .index-link-box .content .icon {
    width: 38px;
    height: 38px;
    top: 25%;
  }
  .index-link-box .content .title {
    font-size: 1.25rem;
  }
  .index-section-news {
    padding: 60px 0 70px 0;
  }
  .index-section-link2 {
    padding: 60px 0 70px 0;
  }
}

@media (max-width: 960px) {
  .index-section-title {
    font-size: 1.625rem;
  }
  .index-banner .swiper-button-next,
  .index-banner .swiper-button-prev {
    width: 35px;
    height: 35px;
  }
  .index-banner .swiper-button-next:after,
  .index-banner .swiper-button-prev:after {
    font-size: 0.875rem;
    font-weight: bold;
  }
  .index-section-link {
    /* padding-top: 60px; */
    /* padding-top: 40px; */
  }
  .index-link-list {
    gap: 20px;
  }
  .index-link-box {
    width: calc((100% - 60px) / 4);
  }
  .index-link-box .content .icon {
    width: 35px;
    height: 35px;
    top: 25%;
  }
  .index-link-box .content .title {
    font-size: 1.125rem;
  }
  .index-section-about .index-container {
    flex-wrap: wrap;
  }
  .index-section-about {
    padding: 60px 0;
  }
  .index-about-pic {
    width: 740px;
    max-width: 100%;
    margin: auto;
  }
  .index-about-content {
    width: 740px;
    max-width: 100%;
    padding: 0;
    margin: auto;
    margin-top: 20px;
  }
}

@media (max-width: 768px) {
  .index-link-list {
    flex-wrap: wrap;
    justify-content: center;
  }
  .index-link-list {
    gap: 30px 20px;
  }
  .index-link-box {
    width: 280px;
  }
  .index-link-box .content .icon {
    width: 45px;
    height: 45px;
  }
}

@media (max-width: 640px) {
  .index-banner .swiper-slide figure {
    height: 300px;
  }
  .index-banner .swiper-button-next,
  .index-banner .swiper-button-prev {
    top: 60%;
    width: 30px;
    height: 30px;
  }
  .index-banner .swiper-button-next:after,
  .index-banner .swiper-button-prev:after {
    font-size: 0.8125rem;
  }
  .index-section-news {
    padding: 40px 0 60px 0;
  }
  .index-link-list {
    gap: 30px 20px;
  }
  .index-link-box {
    width: calc((100% - 40px) / 2);
  }
  .index-link-box .content .icon {
    width: 38px;
    height: 38px;
  }
  .index-section-about {
    padding: 50px 0;
  }
  .index-about-content .txt {
    font-weight: normal;
  }
  .index-about-content .more a {
    font-weight: normal;
  }
  .index-section-link2 {
    padding: 40px 0 60px 0;
  }
  .index-about-content .txt span {
    display: inline;
  }
  .index-link2-box .txt {
    font-size: 1.125rem;
  }
}

@media (max-width: 480px) {
  .index-section-link {
    padding: 40px 0;
  }
  .index-link-list {
    gap: 20px;
  }
  .index-link-box {
    width: calc((100% - 20px) / 2);
  }
  .index-link-box a:hover .content .title {
    transform: translateY(25px);
  }
  .index-link-box .content .icon {
    width: 30px;
    height: 30px;
    top: 22%;
  }
  .index-link-box .content .title {
    margin-top: 8px;
  }
}

@media (max-width: 375px) {
  .index-section-link {
    padding-top: 30px;
  }
  .index-link-list {
    gap: 10px;
  }
}

@media (max-width: 320px) {
  .index-link-box a:hover .content .title {
    transform: translateY(20px);
  }
  .index-link-box .content .icon {
    width: 25px;
    height: 25px;
    top: 20%;
  }
  .index-link-box .content .title {
    font-size: 0.9375rem;
  }
}

/*========= page ==========*/
.members-list-table {
  overflow: auto;
}
.members-list-table table {
  min-width: 800px;
  text-align: center;
}
.members-list-table table thead td {
  background: #f8f8f8;
  color: #222222;
  border: 1px solid #e8e8e8;
}
.members-list-table table thead td:not(:last-child) {
  border-right: 1px solid #e8e8e8;
}
.members-list-table table tbody tr:nth-child(even) td {
  background: #fff;
}
.members-list-table table tbody td {
  background: #fff;
}
.members-list-table table tfoot td {
  background: #666666;
  color: #fff;
}
.members-list-table table tfoot td:not(:last-child) {
  border-right: 1px solid #fff;
}

.members-list-downloadfile-style {
  margin: 40px 0 0 0;
}

.announcements-list {
  padding-top: 10px;
}

.announcements-box a {
  background: #f8f8f8;
  display: block;
  padding: 15px 30px;
}
.announcements-box a:hover .title {
  color: var(--main);
}

.announcements-box .title {
  color: #222;
  font-weight: bold;
  padding-right: 80px;
  font-size: 1.125rem;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  transition: 0.3s;
}

.announcements-box .content {
  display: flex;
  align-items: center;
  padding-top: 15px;
  margin-top: 10px;
  border-top: 2px solid #fff;
  box-shadow: 0 -1px 0 0 #e5e5e5;
}

.announcements-box .date {
  color: #999999;
  font-size: 0.9375rem;
}

.announcements-box .sort {
  padding: 10px 20px;
  color: #222;
  background: #fff;
  border-radius: 50px;
  border: 1px solid #ccc;
  margin-left: 10px;
  line-height: 1;
}

.announcements-box:not(:last-child) {
  margin-bottom: 25px;
}

.unreset-contact-block {
  display: flex;
  flex-wrap: wrap;
}

.unreset-contact-left {
  width: 520px;
}
.unreset-contact-left iframe {
  width: 100%;
  display: block;
}

.unreset-contact-right {
  flex: 1;
  padding-left: 60px;
}

/*========== page mobile ==========*/
@media (max-width: 960px) {
  .patient-consultation-form {
    margin-top: 20px;
  }
  .patient-consultation-txt {
    font-size: 1.0625rem;
    padding: 20px;
  }
  .case-inquiry-form {
    padding: 20px;
  }
  .case-inquiry-form .form-box.using-drugs {
    width: 100%;
  }
  .announcements-box .title {
    padding-right: 0;
  }
  .unreset-contact-block {
    display: block;
  }
  .unreset-contact-left {
    width: 100%;
  }
  .unreset-contact-left iframe {
    height: 300px;
  }
  .unreset-contact-right {
    padding-left: 0;
    margin-top: 20px;
  }
}

@media (max-width: 768px) {
  .submission-process-block {
    flex-wrap: wrap;
  }
  .submission-process-block .list-arrow {
    width: 100%;
    margin: 20px 0;
  }
  .submission-process-block .list-arrow .pic {
    background: #444;
    padding: 5px;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: auto;
    border-radius: 50%;
  }
  .submission-process-block .list-arrow img {
    transform: rotate(90deg);
    margin: auto;
  }
  .submission-process-list.list1 {
    width: 100%;
  }
  .submission-process-list.list2 {
    width: 100%;
  }
  .submission-process-list.list3 {
    width: 100%;
  }
  .submission-process-list.list4 {
    width: 100%;
  }
  .submission-process-box .group {
    padding: 15px 16px;
  }
}

@media (max-width: 640px) {
  .members-list-table table tbody tr:nth-child(even) td {
    background: #f8f8f8;
  }
  .members-list-table table tbody td {
    background: #fff;
  }
  .members-list-downloadfile-style {
    margin: 30px 0 0 0;
  }
  .announcements-list {
    padding-top: 0;
  }
  .announcements-box a {
    padding: 15px 20px;
  }
}

@media (max-width: 480px) {
  .announcements-box:not(:last-child) {
    margin-bottom: 20px;
  }
  .announcements-box a {
    padding: 10px 15px;
  }
  .announcements-box .title {
    font-size: 1rem;
  }
  .announcements-box .content {
    padding-top: 10px;
    margin-top: 5px;
  }
  .announcements-box .sort {
    padding: 10px 15px;
    font-size: 0.9375rem;
  }
}

/*========= about ==========*/
.about-table-style {
  width: 100%;
  overflow: auto;
}
.about-table-style table {
  width: 100%;
  border: 1px solid #e8e8e8;
  border-collapse: collapse;
}
.about-table-style td {
  border: 1px solid #e8e8e8;
  padding: 10px 15px;
}
.about-table-style .c {
  text-align: center;
}
.about-table-style .bg-d1 {
  background: #666666;
  color: #fff;
  font-size: 1.0625rem;
}
.about-table-style .bg-d2 {
  background: #999999;
  color: #fff;
  font-size: 1.0625rem;
}
.about-table-style .bg-g {
  background: #f8f8f8;
}

/*========== about mobile ==========*/
/*========= clinic ==========*/
.service-plan-introduction-unreset {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 30px;
}
.service-plan-introduction-txt {
  width: 100%;
  margin-bottom: 30px;
}
.service-plan-introduction-txt.c {
  text-align: center;
}
.service-plan-introduction-txt .txt1 {
  font-size: 1.625rem;
  color: #222222;
  letter-spacing: 2px;
  font-weight: bold;
  margin: 5px 0;
}
.service-plan-introduction-txt .txt2 {
  font-size: 1.125rem;
  color: #222;
  font-weight: 200;
  font-family: "Poppins", "Open Sans", "微軟正黑體", sans-serif;
}
.service-plan-introduction-btn-list {
  display: flex;
  justify-content: center;
  gap: 10px;
  width: 100%;
}

.service-plan-introduction-btn-list .health-btn-style a {
  width: 165px;
  text-align: center;
}

.service-plan-introduction-box {
  display: flex;
  flex-wrap: wrap;
}
.service-plan-introduction-box:not(:last-child) {
  margin-bottom: 10px;
}
.service-plan-introduction-box figure {
  width: 280px;
  margin: 0;
}
.service-plan-introduction-box figure .pic img {
  display: block;
  max-width: 100%;
  margin: auto;
}
.service-plan-introduction-box .content {
  width: calc(100% - 280px);
  background: url(../images/bg_lgreen_slash.jpg);
  padding: 25px 40px 20px 40px;
}
.service-plan-introduction-box .info {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  font-size: 1.0625rem;
  padding: 10px 0;
  gap: 10px 40px;
}
.service-plan-introduction-box .info .box {
  display: flex;
}
.service-plan-introduction-box .info .t1 {
  color: #1c4ea1;
}

.service-plan-introduction .news-box a {
  padding: 12.5px 15px;
}

.service-plan-introduction-title {
  font-size: 1.625rem;
  text-align: center;
  margin: 60px 0 30px 0;
  letter-spacing: 2px;
  color: #222222;
  font-weight: bold;
}

.service-introduction-unreset {
  margin-bottom: 30px;
}

/*========== clinic mobile ==========*/
@media (max-width: 1280px) {
  .service-plan-introduction-unreset .unreset {
    padding-right: 40px;
  }
}

@media (max-width: 960px) {
  .service-plan-introduction-unreset .unreset {
    width: 100%;
    padding-right: 0;
  }
  .service-plan-introduction-btn-list {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }
  .service-plan-introduction-btn-list .health-btn-style:not(:last-child) {
    margin-bottom: 0;
  }
}

@media (max-width: 768px) {
  .service-plan-introduction-box .content {
    width: 100%;
  }
  .service-plan-introduction-title {
    margin: 30px 0 20px 0;
  }
}

@media (max-width: 480px) {
  .service-plan-introduction-txt .txt2 {
    font-weight: normal;
  }
  .service-plan-introduction-box figure {
    width: 100%;
    display: none;
  }
  .service-plan-introduction-box .content {
    padding: 20px;
  }
}

/*========= health ==========*/
.health-list {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 30px 60px;
  margin-top: 40px;
}

.health-box {
  width: calc((100% - 180px) / 4);
}
.health-box a {
  display: block;
  border: 1px solid #ddd;
}
.health-box a:hover {
  border-color: #304269;
}
.health-box figure {
  margin: 0;
  padding: 0;
  position: relative;
}
.health-box figure .pic {
  position: relative;
  /* padding-bottom: calc(150 / 295 * 100%); */
  /* text-align: center; */
  /* overflow: hidden; */
  /* height: 0; */
  width: 100%;
  aspect-ratio: 295 / 150;
}
.health-box figure .pic img {
  /* max-width: 100%;
  max-height: 100%;
  position: absolute;
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0; */
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.health-box figure .pic iframe,
.health-box figure .pic object,
.health-box figure .pic embed {
  position: absolute;
  display: block;
  margin: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.health-box .content {
  padding: 20px 25px;
}
.health-box .sort {
  display: inline-block;
  background: #fff;
  font-weight: bold;
  padding: 4px 15px;
  border-radius: 50px;
  border: 1px solid #ddd;
}
.health-box .title {
  color: #333;
  font-weight: bold;
  font-size: 1.125rem;
  /* overflow: hidden; */
  /* text-overflow: ellipsis; */
  /* white-space: nowrap; */
  margin-top: 12px;

  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  line-height: 1.6;
  height: calc(1.125rem * 1.6 * 2);
}
.health-box .date {
  display: block;
  transition: 0.3s;
  font-weight: 300;
  color: #666;
  margin-top: 12px;
}

/*========== health mobile ==========*/
@media (max-width: 1440px) {
  .health-list {
    gap: 30px 40px;
  }
  .health-box {
    width: calc((100% - 120px) / 4);
  }
}

@media (max-width: 1280px) {
  .health-list {
    gap: 20px 20px;
  }
  .health-box {
    width: calc((100% - 60px) / 4);
  }
  .health-box .title {
    font-size: 1rem;
    margin-top: 8px;
  }
  .health-box .date {
    margin-top: 8px;
  }
}

@media (max-width: 1024px) {
  .health-box {
    width: calc((100% - 40px) / 3);
  }
}

@media (max-width: 960px) {
  .health-box .content {
    padding: 15px 15px;
  }
}

@media (max-width: 768px) {
  .health-list {
    gap: 30px 10px;
  }
  .health-box {
    width: calc((100% - 30px) / 3);
  }
}

@media (max-width: 640px) {
  .health-box {
    width: calc((100% - 20px) / 2);
  }
  .health-box .title {
    font-size: 1.125rem;
  }
  .health-box .content {
    padding: 12px;
  }
  .health-box .sort {
    padding: 4px 10px;
    font-size: 1.0625rem;
  }
}

@media (max-width: 480px) {
  .health-box {
    width: 295px;
    margin: auto;
    max-width: 100%;
  }
  .health-box a {
    border: 1px solid #eee;
  }
  .health-box .content {
    padding: 15px;
  }
  .health-box .sort {
    padding: 5px 12px;
  }
}

/*========= healthplan ==========*/
/* 預約方式 */
.reservation-method-list {
  display: flex;
  flex-wrap: wrap;
  gap: 40px 80px;
  justify-content: center;
}

.health-process-list .reservation-method-box {
  position: relative;
}
.health-process-list .reservation-method-box:not(:last-child):after {
  content: "\f105";
  display: inline-block;
  font-weight: bold;
  font-family: "Font Awesome 6 Free";
  position: absolute;
  right: -50px;
  top: 50%;
  transform: translateY(-50%);
  color: #222;
  font-size: 1.875rem;
}

.reservation-method-box {
  width: calc((100% - 160px) / 3);
  position: relative;
}
.reservation-method-box:hover .shadow {
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.75);
}
.reservation-method-box .shadow {
  display: block;
  width: 92%;
  height: 92%;
  position: absolute;
  z-index: 0;
  background: #eee;
  right: 0;
  bottom: 0;
  transition: 0.4s;
}
.reservation-method-box .group {
  display: block;
  background: url(../images/bg_gray_slash.jpg);
  padding: 60px 35px 130px 35px;
  position: relative;
  height: 100%;
}
.reservation-method-box figure {
  margin: 0;
}
.reservation-method-box figure .pic {
  width: 56px;
  height: 56px;
  margin: auto;
}
.reservation-method-box figure .pic img {
  display: block;
  max-width: 100%;
  max-height: 100%;
}
.reservation-method-box .title {
  text-align: center;
  color: #222;
  font-weight: bold;
  font-size: 1.25rem;
  margin-top: 30px;
  padding-bottom: 20px;
  border-bottom: 1px solid #ddd;
}
.reservation-method-box .content {
  padding-top: 20px;
  border-top: 2px solid #fff;
}
.reservation-method-box .txt {
  color: #222;
  font-size: 1.0625rem;
  font-weight: 300;
}
.reservation-method-box .more {
  text-align: center;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 60px;
}
.reservation-method-box .more a {
  display: inline-block;
  background: #1c4ea1;
  border-radius: 50px;
  color: #fff;
  padding: 11px 20px;
  font-size: 1.125rem;
  line-height: 1;
}
.reservation-method-box .more a:hover {
  background: var(--main);
}
.reservation-method-box.no-content .group {
  padding: 60px 35px;
}
.reservation-method-box.no-content .title {
  border: none;
  padding-bottom: 0;
}

.reservation-method-txt {
  margin-top: 40px;
}
.reservation-method-txt .txt1 {
  font-size: 1.125rem;
  font-weight: bold;
  color: #222;
}
.reservation-method-txt .txt2 {
  font-size: 1.125rem;
  color: #222222;
  font-weight: 300;
  padding-left: 20px;
  position: relative;
}
.reservation-method-txt .txt2::before {
  content: "\f105";
  display: inline-block;
  font-weight: bold;
  font-family: "Font Awesome 6 Free";
  position: absolute;
  left: 0;
  top: 3px;
  color: #ec6c5f;
  font-size: 0.875rem;
}

/* 健檢繳費 */
.payment-method-box {
  display: flex;
  border-bottom: 2px solid #e8e8e8;
}
.payment-method-box:not(:last-child) {
  margin-bottom: 25px;
}
.payment-method-box .title {
  width: 160px;
  background: url(../images/bg_gray_slash.jpg);
  color: #222222;
  font-weight: bold;
  font-size: 1.0625rem;
  padding: 20px;
  display: flex;
  align-items: center;
}
.payment-method-box .content {
  flex: 1;
  padding: 30px;
}
.payment-method-box .txt {
  color: #222;
  font-size: 1.0625rem;
  font-weight: 300;
}
.payment-method-box .txt.r {
  color: #fe5f48;
}
.payment-method-box .link {
  margin-top: 10px;
}
.payment-method-box .link a {
  display: inline-block;
  background: #1c4ea1;
  border-radius: 50px;
  padding: 11px 25px;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1;
}
.payment-method-box .link a:hover {
  background: var(--main);
}


.payment-method-txt {
  margin-top: 40px;
}
.payment-method-txt .txt1 {
  font-size: 1.125rem;
  font-weight: bold;
  color: #222;
}
.payment-method-txt .txt2 {
  font-size: 1.125rem;
  color: #222222;
  font-weight: 300;
  padding-left: 20px;
  position: relative;
}
.payment-method-txt .txt2::before {
  content: "\f105";
  display: inline-block;
  font-weight: bold;
  font-family: "Font Awesome 6 Free";
  position: absolute;
  left: 0;
  top: 3px;
  color: #ec6c5f;
  font-size: 0.875rem;
}

.health-btn-style a {
  display: inline-block;
  border-radius: 50px;
  padding: 11px 25px;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1;
}

.health-btn-style.blue-btn a {
  background: #1c4ea1;
}
.health-btn-style.blue-btn a:hover {
  background: var(--main);
}

.health-btn-style.black-btn a {
  background: #444;
}
.health-btn-style.black-btn a:hover {
  background: var(--main);
}

.payment-method-btn {
  margin-top: 40px;
  text-align: center;
}

/* 健檢方案 */
.health-plan-list {
  display: flex;
  flex-wrap: wrap;
  gap: 50px 80px;
  margin-top: 30px;
}

.health-plan-box {
  width: calc((100% - 160px) / 3);
  position: relative;
}
.health-plan-box:hover .shadow {
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.75);
}
.health-plan-box:hover figure .pic img {
  display: none;
}
.health-plan-box:hover figure .pic img.gif {
  display: block;
}
.health-plan-box .shadow {
  display: block;
  width: 92%;
  height: 92%;
  position: absolute;
  z-index: 0;
  right: 0;
  bottom: 0;
  transition: 0.4s;
  border-radius: 15px;
}
.health-plan-box .group {
  display: block;
  background: url(../images/bg_green_slash.jpg);
  position: relative;
  height: 100%;
  border-radius: 15px;
  padding: 45px 20px;
  height: 290px;
}
.health-plan-box.blue .group{
  background: url(../images/bg_blue_slash.jpg);
}
.health-plan-box.yellow .group{
  background: url(../images/bg_yellow_slash.jpg);
  height: 250px;
}
.health-plan-box figure {
  margin: 0;
  width: 100px;
  height: 100px;
  margin: auto;
  background: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.health-plan-box figure .pic {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;

  width: 70px;
  height: 70px;
  overflow: hidden;
}
.health-plan-box figure .pic img {
  display: block;
  /* width: 70%; */
  /* width: 70px; */
  /* height: 70%; */
  /* height: 70px; */
  width: 100%;
  max-width: 100%;
  max-height: 100%;
}
.health-plan-box figure .pic img.gif {
  display: none;
}
.health-plan-box .content {
  color: #222;
  text-align: center;
}
.health-plan-box .content .title {
  font-weight: bold;
  font-size: 1.25rem;
  margin-top: 20px;
}
.health-plan-box .content .txt {
  margin-top: 10px;
  font-weight: 300;
  font-size: 1.0625rem;
}

.health_plan_detail_info {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
}
.health_plan_detail_info .txt {
  font-size: 1.125rem;
  color: #222222;
  font-weight: bold;
}

.health-plan-detail-unreset {
  margin: 30px 0;
}

.health-plan-detail-table {
  width: 100%;
  overflow-x: auto;
}
.health-plan-detail-table table {
  width: 1000px;
  border-collapse: collapse;
}
.health-plan-detail-table td {
  padding: 10px 8px;
}
.health-plan-detail-table td:first-child {
  padding: 8px 8px 8px 25px;
}
.health-plan-detail-table .sex {
  width: 70px;
}
.health-plan-detail-table .c {
  text-align: center;
}
.health-plan-detail-table .bg-g {
  background: #f8f8f8;
}
.health-plan-detail-table thead td {
  background: #666666;
  color: #fff;
  font-size: 1.0625rem;
  font-weight: bold;
  border: 1px solid #fff;
}
.health-plan-detail-table tbody .circle {
  margin: auto;
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #666666;
}
.health-plan-detail-table tbody .title-style td {
  background: var(--lmain);
  color: var(--main);
  font-weight: bold;
  font-size: 1.0625rem;
  border: 1px solid var(--lmain);
}
.health-plan-detail-table tbody .content-style td {
  border: 1px solid #e8e8e8;
  border-right: none;
}
.health-plan-detail-table tbody .content-style td.nob {
  border-left: none;
}
.health-plan-detail-table tbody .content-style td:last-child {
  border-right: 1px solid #e8e8e8;
}

.health-plan-detail-table .table {
  width: 1000px;
  max-width: 100%;
}

.health-plan-detail-table .tr .td:first-child {
  padding-left: 25px;
}

.health-plan-detail-table .tr-title {
  display: flex;
  font-weight: bold;
  font-size: 1.0625rem;
}
.health-plan-detail-table .tr-title.black .td {
  background: #666666;
  color: #fff;
}
.health-plan-detail-table .tr-title.green .td {
  background: var(--lmain);
  color: var(--main);
}

.health-plan-detail-table .tr-title.green .td .text-flex{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: space-between;
}
.health-plan-detail-table .tr-title.green .td .text-flex .left{
  /* width: calc((100% - 10px) / 2 ); */
  /* min-width: 400px; */
  flex: 1;
}
.health-plan-detail-table .tr-title.green .td .text-flex .right{
  /* width: calc((100% - 10px) / 2 ); */
  /* min-width: 400px; */
  text-align: right;
  flex: 1;
}

.health-plan-detail-table .tr-title.green ~ .tr-content .td:first-child{
  padding-left: 60px;
}

@media (max-width: 640px) {
 .health-plan-detail-table .tr-title.green ~ .tr-content .td:first-child{
    padding-left: 50px;
  } 
}


.health-plan-detail-table .tr-title .sex {
  text-align: center;
  border-left: 1px solid #fff;
}

.health-plan-detail-table .tr-content {
  display: flex;
  border: 1px solid #e8e8e8;
}
.health-plan-detail-table .tr-content .sex {
  background: #f8f8f8;
  display: flex;
  align-items: center;
  justify-content: center;
  border-left: 1px solid #e8e8e8;
}
.health-plan-detail-table .tr-content .circle {
  margin: auto;
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #666666;
}

.health-plan-detail-table .td {
  padding: 10px;
}

.health-plan-detail-table .row {
  width: 100%;
  padding: 10px 25px;
}

.health-plan-detail-table .long {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  flex: 1;
  width: calc(100% - (70px * 2));
}
.health-plan-detail-table .long .en {
  /* width: 45%; */
  width: 20%;
  font-weight: bold;
}
.health-plan-detail-table .long .en:only-child {
    flex: 1;
}

.health-plan-detail-table .long .en + .tw{
  width: calc(80% - 20px);
  flex: auto;
}
.health-plan-detail-table .long .tw {
  /* width: 55%; */
  flex: 1;
}

.health-plan-detail-table .short {
  width: 70px;
}

.health-process-detail-group {
  position: relative;
}
.health-process-detail-group .line {
  width: calc(100% - ((100% - 150px) / 4));
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  height: 1px;
  background: #dedede;
  display: none;
}
.health-process-detail-group .line::before,
.health-process-detail-group .line::after {
  content: "";
  display: block;
  position: absolute;
  height: 25px;
  width: 1px;
  background: #dedede;
}
.health-process-detail-group .line::before {
  right: 0;
  top: -25px;
}
.health-process-detail-group .line::after {
  left: 0;
  bottom: -25px;
}
.health-process-detail-group .line.line1 {
  top: 50%;
  display: block;
}

.health-process-detail-list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 50px;
  gap: 50px;
  margin-top: 40px;
  position: relative;
}

.health-process-detail-box {
  /* width: calc((100% - 200px) / 5); */
  width: calc((100% - 150px) / 4);
  /* color: #fff; */
  font-size: 1.125rem;
  font-weight: bold;
  position: relative;
}
.health-process-detail-box:before {
  content: "\f107";
  font-weight: bold;
  font-family: "Font Awesome 6 Free";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -18px;
  color: #222;
  display: none;
}
.health-process-detail-box:after {
  content: "\f105";
  display: block;
  font-weight: bold;
  font-family: "Font Awesome 6 Free";
  position: absolute;
  right: -30px;
  top: 50%;
  transform: translateY(-50%);
  color: #222;
  font-size: 1.125rem;
}
.health-process-detail-box:nth-child(4):after {
  display: none;
}
.health-process-detail-box:nth-child(5)::before {
  display: block;
}
.health-process-detail-box:last-child::after {
  display: none;
}
.health-process-detail-box:hover .shadow {
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.75);
}
.health-process-detail-box:hover .group {
  background: #304269;
  background: -webkit-linear-gradient(
    legacy-direction(to bottom),
    #304269,
    #1b2f5a
  );
  background: linear-gradient(to bottom, #304269, #1b2f5a);
}
.health-process-detail-box .shadow {
  display: block;
  width: 92%;
  height: 92%;
  position: absolute;
  z-index: 0;
  background: #fff;
  right: 0;
  bottom: 0;
  transition: 0.4s;
  border-radius: 5px;
}
.health-process-detail-box .group {
  border-radius: 5px;
  position: relative;
  background: #74c4cf;
  display: flex;
  padding: 16px 25px;
  background: #82cad4;
  color: #fff;
  background: -webkit-linear-gradient(
    legacy-direction(to bottom),
    #82cad4,
    #67bfcb
  );
  background: linear-gradient(to bottom, #82cad4, #67bfcb);
}
.health-process-detail-box .num {
  font-family: "Poppins", "Open Sans", "微軟正黑體", sans-serif;
  margin-right: 15px;
}

/*========== healthplan mobile ==========*/
@media (max-width: 1440px) {
  .reservation-method-list {
    gap: 40px;
  }
  .reservation-method-box {
    width: calc((100% - 80px) / 3);
  }
  .health-plan-list {
    gap: 50px 60px;
  }
  .health-plan-box {
    width: calc((100% - 120px) / 3);
  }
  .health-process-list .reservation-method-box:not(:last-child):after {
    right: -25px;
    font-size: 1.375rem;
  }
}

@media (max-width: 1280px) {
  .health-process-detail-box .group{
    padding: 16px 15px;
  }
  .health-process-detail-group .line {
    width: calc(100% - ((100% - 100px) / 3));
  }
  .health-process-detail-group .line.line1 {
    top: 30%;
    display: block;
  }
  .health-process-detail-group .line.line2 {
    top: 70%;
    display: block;
  }
  .health-process-detail-box {
    width: calc((100% - 100px) / 3);
  }
  .health-process-detail-box:nth-child(3):after,
  .health-process-detail-box:nth-child(6):after {
    display: none;
  }
  .health-process-detail-box:nth-child(4):after {
    display: block;
  }
  .health-process-detail-box:nth-child(5):before {
    display: none;
  }
  .health-process-detail-box:nth-child(4):before,
  .health-process-detail-box:nth-child(7):before {
    display: block;
  }
}

@media (max-width: 1024px) {
  .health-plan-list {
    gap: 30px 30px;
  }
  .health-plan-box {
    width: calc((100% - 60px) / 3);
  }
}

@media (max-width: 960px) {
  .reservation-method-list {
    gap: 20px;
  }
  .reservation-method-box {
    width: calc((100% - 20px) / 2);
  }
  .reservation-method-box .group {
    padding: 20px 20px 90px 20px;
  }
  .reservation-method-box .content {
    text-align: center;
  }
  .reservation-method-box .more {
    bottom: 30px;
  }
  .health-plan-box {
    width: calc((100% - 30px) / 2);
  }
  .health-plan-box .group {
    padding: 30px 15px;
  }
  .health-process-list .reservation-method-box {
    width: calc((100% - 40px) / 3);
  }
  .health-process-list .reservation-method-box:not(:last-child):after {
    right: -15px;
    font-size: 1.125rem;
  }
  .reservation-method-box.no-content .group {
    padding: 30px 20px;
  }
  .health-process-detail-list {
    gap: 30px;
  }
  .health-process-detail-group .line {
    display: none;
  }
  .health-process-detail-group .line.line1 {
    display: none;
  }
  .health-process-detail-group .line.line2 {
    display: none;
  }
  .health-process-detail-box {
    width: calc((100% - 60px) / 2);
  }
  .health-process-detail-box:nth-child(3):after,
  .health-process-detail-box:nth-child(6):after {
    display: block;
  }
  .health-process-detail-box:nth-child(4):before,
  .health-process-detail-box:nth-child(7):before {
    display: none;
  }
  .health-process-detail-box:after {
    right: -20px;
  }
}

@media (max-width: 640px) {
  .reservation-method-box {
    width: 100%;
  }
  .reservation-method-box .group {
    padding-inline: 15px;
  }
  .reservation-method-box .txt {
    font-size: 1.125rem;
  }
  .payment-method-box {
    flex-wrap: wrap;
  }
  .payment-method-box .title {
    width: 100%;
    padding: 15px 20px;
  }
  .payment-method-box .content {
    width: 100%;
    padding: 20px;
  }
  .health-plan-list {
    gap: 15px 15px;
  }
  .health-plan-box {
    width: calc((100% - 15px) / 2);
  }
  .health-plan-box .group {
    height: 240px;
  }
  .health-plan-box.yellow .group{
    height: 200px;
  }
  .health-plan-box figure {
    width: 85px;
    height: 85px;
  }
  .health-plan-box .content .title {
    font-size: 1.125rem;
  }
  .health-plan-box .content .txt {
    font-size: 1.125rem;
  }
  .health-process-list {
    gap: 40px;
  }
  .health-process-list .reservation-method-box {
    width: 100%;
  }
  .health-process-list .reservation-method-box:not(:last-child):after {
    content: "\f107";
    font-size: 1.25rem;
    right: initial;
    top: initial;
    left: 50%;
    bottom: -37px;
    height: auto;
    transform: translateX(-50%);
  }
  .health-process-detail-list {
    gap: 20px 30px;
  }
  .health-process-detail-box {
   
  }
  .health-process-detail-box:after {
    font-size: 1rem;
  }
  .health-process-detail-box .group {
    padding: 12px 15px;
    height: 100%;
  }
  .health-process-detail-box .num {
    margin-right: 10px;
  }
  .health-plan-detail-table .long{
    gap: 10px;
  }
  .health-plan-detail-table .tr .td:first-child {
    padding-left: 15px;
  }
  .health-plan-detail-table .long {
    flex-wrap: wrap;
  }
  .health-plan-detail-table .long .en {
    width: 100%;
  }
  .health-plan-detail-table .long .en + .tw{
    width: 100%;
  }
  .health-plan-detail-table .long .tw {
    width: 100%;
    padding-top: 5px;
  }
  .health-plan-detail-table .long {
    width: calc(100% - (60px * 2));
  }
  .health-plan-detail-table .short {
    width: 60px;
  }
}

@media (max-width: 480px) {
  .reservation-method-box .title {
    margin-top: 20px;
  }
  .reservation-method-box .txt {
    font-weight: normal;
  }
  .reservation-method-box .more {
    margin-top: 20px;
  }
  .reservation-method-box .more a {
    font-weight: normal;
  }
  .payment-method-box .txt {
    font-weight: normal;
  }
  .payment-method-box .link a {
    font-weight: normal;
  }
  .health-plan-list {
    gap: 10px;
  }
  .health-plan-box {
    width: calc((100% - 10px) / 2);
  }
  .health-plan-box .group {
    padding: 20px 10px;
  }
  .health-plan-box .content .title {
    margin-top: 10px;
  }
  .health-plan-box .content .txt {
    font-weight: normal;
    margin-top: 0;
  }
}

@media (max-width: 375px) {
  .health-plan-list {
    gap: 20px;
  }
  .health-plan-box {
    width: 100%;
  }
  .health-plan-box .group {
    height: auto;
  }
  .health-plan-box.yellow .group{
    height: auto;
  }
  .health-process-detail-box:after {
    top: 25px;
  }
}

/*========= news ==========*/
.news-box a {
  display: flex;
  flex-wrap: wrap;
  padding: 20.5px 15px;
  align-items: baseline;
  position: relative;
  color: #222;
  line-height: 1;
  border-bottom: 1px solid #eee;
}
.news-box a:hover {
  background: #f7f7f7;
}
.news-box a:hover .txt {
  font-weight: bold;
}

.news-box .sort {
  display: block;
  background: #fff;
  font-weight: bold;
  padding: 8px 15px;
  border-radius: 50px;
  border: 1px solid #ddd;
}

.news-box .txt {
  flex: 1;
  font-size: 1.125rem;
  padding-right: 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-left: 20px;
}

.news-box .date {
  display: block;
  transition: 0.3s;
  font-weight: 300;
  color: #666;
}

.news-box:not(:first-child) {
  margin-top: -1px;
}

/*========== news mobile ==========*/
@media (max-width: 1280px) {
  .news-box .date {
    font-size: 0.9375rem;
  }
}

@media (max-width: 960px) {
  .news-box .sort {
    margin-bottom: 15px;
  }
  .news-box a {
    padding: 16px 10px;
    flex-wrap: wrap;
  }
  .news-box .txt {
    width: calc(100% - 80px);
    margin-left: 0;
    flex: auto;
  }
}

@media (max-width: 480px) {
  .news-box .sort {
    order: 1;
    font-size: 0.9375rem;
    padding: 6px 12px;
    margin-bottom: 10px;
  }
  .news-box .txt {
    order: 3;
    width: 100%;
  }
  .news-box .date {
    order: 2;
    margin-left: 10px;
  }
}
