::view-transition-group(root) {
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
}

.lazyload {
  opacity: 0;
}

.lazyloaded {
  opacity: 1;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
}

@-webkit-keyframes ani_LR {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(10px);
            transform: translateX(10px);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes ani_LR {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(10px);
            transform: translateX(10px);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes circle-draw {
  80% {
    stroke-dashoffset: 0;
  }
}
@keyframes circle-draw {
  80% {
    stroke-dashoffset: 0;
  }
}
/* Animation */
@-webkit-keyframes drawLine {
  0% {
    opacity: 1;
    top: 0;
  }
  50% {
    top: 100%;
  }
  100% {
    top: 0;
  }
}
@keyframes drawLine {
  0% {
    opacity: 1;
    top: 0;
  }
  50% {
    top: 100%;
  }
  100% {
    top: 0;
  }
}
@-webkit-keyframes gotop-ani {
  0% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
  45% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  55% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
}
@keyframes gotop-ani {
  0% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
  45% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  55% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
}
@font-face {
  font-family: "GenRyuMin";
  src: url("../fonts/GenRyuMin-Medium.woff2") format("woff2"), url("../fonts/IGenRyuMin-Medium.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Marcellus";
  src: url("../fonts/Marcellus-Regular.woff2") format("woff2"), url("../fonts/Marcellus-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NotoSansTC";
  src: url("../fonts/NotoSansTC-Regular.woff2") format("woff2"), url("../fonts/NotoSansTC-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NotoSansTC";
  src: url("../fonts/NotoSansTC-Bold.woff2") format("woff2"), url("../fonts/NotoSansTC-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
/* Reset*/
* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

.clearfix:before,
.clearfix:after {
  content: "";
  display: table;
  clear: both;
}

.disabled,
.disabled:hover {
  cursor: not-allowed;
}

html {
  font-size: 16px;
}

body {
  font-family: "Marcellus", "NotoSansTC", sans-serif;
  font-size: 16px;
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
  -ms-overflow-style: scrollbar;
  color: #333333;
}

html,
body {
  margin: 0;
}

a, a:visited, a:hover, a:focus, a:active {
  text-decoration: none;
  outline: 0;
}

img, a img {
  border: none;
  max-width: 100%;
  height: auto;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

section, article, aside, footer, header, nav, main {
  display: block;
}

p {
  line-height: inherit;
}

ol.reset, ul.reset, li.reset {
  list-style: none;
  margin: 0;
  padding: 0;
}

label {
  font-weight: inherit;
}

input, button, textarea, select, optgroup, option {
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
  outline: 0;
  border-radius: 0;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}

input, textarea, select, input[type=radio], input[type=checkbox] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

input:hover, input:active, input:hover, textarea:hover, textarea:active, textarea:hover, button:hover, button:active, button:hover, select:hover, select:active, select:hover, a:hover, a:active, a:hover {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

input:not([type=button]), input:not([type=submit]), input:not([type=reset]) {
  font-size: 16px !important;
}

textarea {
  resize: vertical;
}

select {
  color: #333;
}
select::-ms-expand {
  display: none;
}

::-webkit-input-placeholder {
  color: #888;
  font-size: 14px;
}

::-moz-placeholder {
  color: #888;
  font-size: 14px;
}

:-ms-input-placeholder, :-moz-placeholder {
  color: #888;
  font-size: 14px;
}

input:-moz-read-only {
  background: #eee;
  color: #666;
}

.input-style:-moz-read-only:focus {
  border: 1px solid #ddd;
}

.input-style:read-only:focus {
  border: 1px solid #ddd;
}

.textarea-style:-moz-read-only:focus {
  border: 1px solid #ddd;
}

.textarea-style:read-only:focus {
  border: 1px solid #ddd;
}

input:-moz-read-only {
  background: #eee;
  color: #666;
}

input:read-only {
  background: #eee;
  color: #666;
}

input::-webkit-input-placeholder,
input:-moz-placeholder,
input::-moz-placeholder,
input:-ms-input-placeholder {
  color: #ccc;
  font-size: 14px;
}

input:-internal-autofill-previewed,
input:-internal-autofill-selected,
textarea:-internal-autofill-previewed,
textarea:-internal-autofill-selected, select:-internal-autofill-previewed,
select:-internal-autofill-selected {
  background-color: #ededed !important;
  border: 1px solid #eee;
}

img,
input[type=image],
video,
embed,
iframe,
marquee,
object,
table {
  aspect-ratio: attr(width)/attr(height);
}

@media (max-width: 991px) {
  .hidden-sm {
    display: none !important;
  }
}
@media only screen and (min-width: 768px) {
  .visible-xs {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
  .visible-xs {
    display: block !important;
  }
}
/* color */
:root {
  --fluid-txt: clamp(0.9375rem, 0.9216rem + 0.0654vw, 1rem);
  --fluid-small-txt: clamp(0.8125rem, 0.7806rem + 0.1307vw, 0.9375rem);
  --fluid-margin: 1rem;
  --fluid-padding: 1rem;
  --g-line-height: 2rem;
  --g-gap: clamp(0.375rem, 0.2157rem + 0.6536vw, 1rem);
  --swiper-pagination-color: #c89b64;
  --swiper-theme-color: #c89b64;
  --ease: cubic-bezier(0.585, 0.040, 0.345, 1.015);
}

@media only screen and (max-width: 767px) {
  :root {
    --fluid-line-height: 1.5rem;
  }
}
/* Button */
/* Header */
#header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 3rem;
  padding: 0 5%;
  width: 100%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 99;
  position: fixed;
  top: 0;
  -webkit-transition: gap 0.3s ease, background 0.3s ease;
  transition: gap 0.3s ease, background 0.3s ease;
}
#header::after {
  content: "";
  left: 13%;
  right: 5%;
  height: 1px;
  background: rgba(51, 51, 51, 0.15);
  top: 100%;
  position: absolute;
}
#header .logo {
  position: absolute;
  top: 2rem;
  left: 5%;
  margin: 0;
  aspect-ratio: 200/70;
  width: 180px;
  background-image: url(../images/logo_en.svg);
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: contain;
}
#header .logo a {
  display: block;
  font-size: 0;
  width: 100%;
  height: 100%;
}
#header h2 {
  display: none;
}
#header .menu ul li a {
  display: block;
  position: relative;
}
#header .menu > ul > li {
  position: relative;
}
#header .menu > ul > li > a {
  color: #000;
  position: relative;
}
#header .menu > ul > li .sale {
  color: #cb815d;
}
#header .menu > ul > li .nav__link--text:nth-child(1) {
  text-transform: uppercase;
}
#header .menu > ul > li .nav__link--text:nth-child(2) {
  display: none;
}
#header .right-menu {
  position: relative;
  z-index: 98;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: gap 0.3s;
  transition: gap 0.3s;
}
#header .right-menu .btn-cart {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#header .right-menu .btn-cart a {
  font-size: 0;
  display: inline-block;
  height: 44px;
  padding-left: 44px;
  color: #333;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='83.377' height='73.131' xml:space='preserve'%3E%3Cpath fill='none' stroke='%23040000' stroke-width='5' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' d='M2.5 2.5h10.714l13.17 45.61s.755 5.39 5.476 5.39H64.5'/%3E%3Cpath fill='none' stroke='%23040000' stroke-width='5' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' d='M24.5 42.5h43.096l13.281-27H29.5'/%3E%3Ccircle fill='%23040000' stroke='%23040000' stroke-width='2' stroke-miterlimit='10' cx='33.023' cy='66.813' r='5.318'/%3E%3Ccircle fill='%23040000' stroke='%23040000' stroke-width='2' stroke-miterlimit='10' cx='57.417' cy='66.813' r='5.318'/%3E%3C/svg%3E ");
  background-position: 1rem center;
  background-repeat: no-repeat;
  background-size: 24px auto;
  -webkit-transition: background 0.3s, color 0.3s;
  transition: background 0.3s, color 0.3s;
}
#header .right-menu .btn-cart span {
  font-size: 0.9375rem;
  display: inline-block;
  line-height: 20px;
  border-bottom: 1px solid #333;
  padding-top: 11px;
}
#header .right-menu .btn-user {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 44px;
}
#header .right-menu .btn-user a {
  display: inline-block;
  height: 44px;
  padding-left: 44px;
  color: #333;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64.121' height='67.55' xml:space='preserve'%3E%3Cellipse fill='none' stroke='%23040000' stroke-width='5' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' cx='32.061' cy='18.725' rx='16.306' ry='16.225'/%3E%3Cpath fill='none' stroke='%23040000' stroke-width='5' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' d='M2.5 65.05c0-16.326 13.235-29.561 29.561-29.561h0c16.326 0 29.561 13.235 29.561 29.561'/%3E%3C/svg%3E%0A");
  background-position: 1rem center;
  background-repeat: no-repeat;
  background-size: 20px auto;
  -webkit-transition: background 0.3s, color 0.3s;
  transition: background 0.3s, color 0.3s;
}
#header .right-menu .btn-search {
  display: block;
  font-size: 0;
  height: 44px;
  width: 44px;
  border-radius: 50%;
  border: 0;
  vertical-align: middle;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='61.539' height='61.377' xml:space='preserve'%3E%3Cg fill='none' stroke='%23040000' stroke-width='5' stroke-linecap='round' stroke-miterlimit='10'%3E%3Ccircle cx='28.288' cy='28.288' r='25.788'/%3E%3Cpath d='m46.591 46.43 12.448 12.447'/%3E%3C/g%3E%3C/svg%3E ");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 20px auto;
  -webkit-transition: background 0.3s;
  transition: background 0.3s;
}
#header.is--scrolled {
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  background-color: rgba(255, 255, 255, 0.7);
}
#header.is--scrolled::after {
  left: 0;
  right: 0;
}
#header.is--scrolled .logo {
  background-position: center center;
  position: relative;
  left: 0;
  top: 0;
  width: 195px;
  aspect-ratio: 195/62;
  background-image: url(../images/logo_ch.svg);
  -webkit-transition: width 0s ease;
  transition: width 0s ease;
}

#search-form {
  position: fixed;
  padding: 20vh 2rem 0;
  width: 50%;
  left: 50%;
  top: 100vh;
  gap: 1rem;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 98;
  color: #fff;
  -webkit-transition: top 0.8s var(--ease);
  transition: top 0.8s var(--ease);
}
#search-form .g-title {
  margin: 0;
  color: #fff;
}
#search-form input {
  -webkit-box-shadow: none;
          box-shadow: none;
  height: 60px;
  line-height: 60px;
  padding: 20px;
  background-color: rgba(255, 255, 255, 0.1);
  border: 0;
  color: #fff;
  width: calc(100% - 2rem - 160px - 110px);
}
#search-form input:focus {
  border: 1px solid #c7b280;
}
#search-form .btn-search {
  background-image: url("../images/icon_search_w.svg");
  background-size: 20px;
  background-repeat: no-repeat;
  background-position: 1.25rem center;
  background-color: #c7b280;
  border: 0;
  padding: 0;
  font-size: 0.875rem;
  color: #fff;
  height: 45px;
  line-height: 45px;
  border-radius: 25px;
  width: 140px;
  padding-left: 20px;
}
#search-form .btn-close {
  width: 40px;
  height: 40px;
  position: absolute;
  left: 15px;
  top: 30%;
  cursor: pointer;
}
#search-form .btn-close::before, #search-form .btn-close::after {
  content: "";
  position: absolute;
  left: 20px;
  width: 2px;
  height: 15px;
  background: #fff;
  z-index: 2;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
#search-form .btn-close::after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
#search-form.is-open {
  top: 20vh;
  -webkit-transform: translate(-50%, 0%);
      -ms-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
}

.pc #header .right-menu .btn-user a:hover {
  text-decoration: underline;
}
.pc #header .right-menu .btn-search:hover {
  background-color: #c7b280;
  background-image: url("../images/icon_search_w.svg");
}
.pc #search-form .btn-close:hover {
  color: #c7b280;
}
.pc #search-form .btn-search:hover {
  background-color: #000;
}

@media (min-width: 992px) {
  #header .menu-button {
    display: none;
  }
  #header .menu {
    margin-left: auto;
    margin-right: 10%;
  }
  #header .menu > ul {
    gap: 1.5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #header .menu > ul > li > a {
    line-height: 120px;
    padding: 0 10px;
    -webkit-transition: line-height 1s ease, color 0.3s ease;
    transition: line-height 1s ease, color 0.3s ease;
  }
  #header .menu > ul > li.has-child {
    position: relative;
  }
  #header .menu > ul > li > ul {
    display: none;
    position: absolute;
    text-align: center;
    border-radius: 0;
    top: calc(100% - 1px);
    left: 50%;
    right: 0;
    width: 200px;
    border: 0;
    opacity: 0;
    background: #fff;
    -webkit-transform: translateX(-50%) scale(0);
        -ms-transform: translateX(-50%) scale(0);
            transform: translateX(-50%) scale(0);
  }
  #header .menu > ul > li > ul > li {
    position: relative;
  }
  #header .menu > ul > li > ul > li > a {
    display: block;
    padding: 12px 10px;
    text-align: center;
    font-weight: normal;
    color: #333;
  }
  #header .menu > ul > li:hover > a {
    color: #c7b280;
  }
  #header .menu > ul > li:hover .nav__link--text:nth-child(1) {
    display: none;
  }
  #header .menu > ul > li:hover .nav__link--text:nth-child(2) {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
  }
  #header .menu > ul > li:hover > ul {
    display: block;
    -webkit-transform: translateX(-50%) scale(1);
        -ms-transform: translateX(-50%) scale(1);
            transform: translateX(-50%) scale(1);
    opacity: 1;
  }
  #header .menu > ul > li:hover > ul a:hover {
    color: #fff;
    background: #c7b280;
  }
  #header .right-menu .hover-ul > li > a:hover {
    color: #c7b280;
  }
  #header .right-menu .btn-user:hover .hover-ul {
    display: block;
    -webkit-transform: translateX(-50%) scale(1);
        -ms-transform: translateX(-50%) scale(1);
            transform: translateX(-50%) scale(1);
  }
  #header .right-menu .btn-shopping:hover #hover-cart {
    -webkit-transform: translateX(0) scale(1);
        -ms-transform: translateX(0) scale(1);
            transform: translateX(0) scale(1);
  }
  #header .right-menu .btn-shopping:hover #hover-cart .pic:hover {
    opacity: 0.7;
  }
  #header .right-menu .btn-shopping:hover #hover-cart .btn-del:hover,
  #header .right-menu .btn-shopping:hover #hover-cart .pro-box .ti:hover {
    color: #d29374;
  }
  #header.is--scrolled .menu {
    margin: 0 auto;
  }
  #header.is--scrolled .menu > ul > li > a {
    line-height: 90px;
  }
  #header.is--scrolled .menu > ul > li.current > a {
    color: #c7b280 !important;
  }
  #header.is--scrolled .menu > ul > li.current > a::before {
    position: absolute;
    left: 50%;
    margin-left: -4px;
    top: -1.2rem;
    content: url(../images/icon_star.png);
  }
  #header.is--scrolled .menu > ul > li.current .nav__link--text:nth-child(1) {
    display: none;
  }
  #header.is--scrolled .menu > ul > li.current .nav__link--text:nth-child(2) {
    display: block;
  }
}
@media (max-width: 1440px) {
  #header {
    gap: 1rem;
  }
}
@media (max-width: 1366px) {
  #header {
    gap: 0.5rem;
  }
  #header .menu > ul {
    gap: 0.5rem;
  }
}
@media (max-width: 1199px) {
  #header {
    padding: 1rem 1.5rem;
    gap: 1rem;
  }
  #header .logo {
    left: 1.5rem;
  }
  #header .menu {
    margin-right: 0;
  }
  #header .menu > ul {
    gap: 0.75rem;
    font-size: 0.9375rem;
  }
  #header .menu > ul > li > a {
    padding: 0 10px;
    line-height: 60px;
  }
  #header .right-menu {
    gap: 0;
    font-size: 0.875rem;
  }
  #header .right-menu #search-form {
    gap: 0;
    width: 160px;
  }
  #header .right-menu #search-form input {
    width: calc(100% - 44px);
    padding: 0 10px;
  }
  #header.is--scrolled .menu > ul > li > a {
    line-height: 40px;
  }
  #search-form {
    width: 100%;
  }
}
@media (max-width: 991px) {
  #header {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    overflow: visible;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    gap: 2rem;
    -webkit-box-shadow: 0px 0px 60px -41px rgba(0, 0, 0, 0.53);
            box-shadow: 0px 0px 60px -41px rgba(0, 0, 0, 0.53);
  }
  #header::after {
    display: none;
    left: 2rem;
    right: 2rem;
  }
  #header .logo {
    position: relative;
    left: 0;
    top: 0;
    width: 90px;
    margin: 0 auto;
  }
  #header .menu-button {
    height: 40px;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 15px;
    border: 0;
    cursor: pointer;
    z-index: 102;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
    background: transparent;
    font-family: "Roboto";
    font-size: 0.9375rem;
  }
  #header .menu-button span {
    width: 20px;
    position: relative;
    display: block;
  }
  #header .menu-button span:before, #header .menu-button span:after {
    content: "";
    display: block;
    height: 1px;
    padding: 0;
    margin: 7px 0;
    -webkit-transform-origin: center center;
        -ms-transform-origin: center center;
            transform-origin: center center;
    background: #000;
  }
  #header .menu-button.on {
    color: #c7b280;
  }
  #header .menu-button.on span:before {
    margin: 0;
    -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
            transform: rotate(-45deg);
    background: #cab687;
  }
  #header .menu-button.on span:after {
    margin: -1px 0 0 0;
    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
    background: #cab687;
  }
  #header .menu {
    margin: 0;
    position: fixed;
    top: 100vh;
    left: 0;
    width: 100%;
    height: 100dvh;
    overflow-y: auto;
    -webkit-box-ordinal-group: 7;
        -ms-flex-order: 6;
            order: 6;
    z-index: 10;
    padding: 10vh 0;
  }
  #header .menu > ul {
    gap: 0;
  }
  #header .menu > ul > li {
    width: 100%;
  }
  #header .menu > ul > li .sale {
    color: #d79f83;
  }
  #header .menu > ul > li > a {
    padding: 0.7rem 2rem;
    color: #fff !important;
    line-height: 30px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.03);
  }
  #header .menu > ul > li > ul {
    display: none;
    background: rgba(175, 165, 141, 0.2);
    padding: 1rem;
  }
  #header .menu > ul > li > ul a {
    color: #ddd5bc;
    padding: 0.65rem 1rem;
    letter-spacing: 2px;
  }
  #header .menu > ul > li.has-child {
    position: relative;
  }
  #header .menu > ul > li.has-child:after {
    content: "";
    width: 8px;
    height: 8px;
    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
    border-top: 2px solid #c7b280;
    border-right: 2px solid #c7b280;
    position: absolute;
    color: #fff;
    right: 2rem;
    top: 25px;
    -webkit-transform-origin: center;
        -ms-transform-origin: center;
            transform-origin: center;
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
    z-index: -1;
  }
  #header .menu > ul > li.has-child.on {
    border-bottom: 0;
  }
  #header .menu > ul > li.has-child.on:after {
    border: 0;
    border-bottom: 2px solid #c7b280;
    border-right: 2px solid #c7b280;
  }
  #header .menu > ul > li.current > a {
    color: #c7b280 !important;
  }
  #header .right-menu {
    gap: 0.5rem;
  }
  #header .right-menu .btn-search {
    background-size: 17px;
  }
  #header .right-menu .btn-user a {
    font-size: 0;
    height: 40px;
    padding-left: 30px;
    background-size: 17px;
    background-position: center center;
  }
  #header .right-menu .btn-cart a {
    height: 40px;
    padding-left: 30px;
    background-size: 19px;
    background-position: 5px center;
  }
  #header.is--scrolled {
    -webkit-box-shadow: 0px 0px 60px -41px rgba(0, 0, 0, 0.53);
            box-shadow: 0px 0px 60px -41px rgba(0, 0, 0, 0.53);
  }
  #header.is--scrolled .logo {
    width: 163px;
  }
}
@media (max-width: 767px) {
  #header {
    gap: 1rem;
  }
  #header::after {
    left: 1rem;
    right: 1rem;
  }
  #header .logo {
    width: 150px;
    aspect-ratio: 195/62;
    background-image: url(../images/logo_ch.svg);
  }
  #header .menu > ul {
    padding: 10px 0;
  }
  #header .menu > ul > li .btn-user {
    padding: 1rem 0;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 10px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #header .menu > ul > li .btn-user a {
    padding: 7px 20px;
    border-radius: 20px;
    background: #c7b280;
    color: #fff !important;
  }
  #header .menu-button {
    gap: 6px;
    font-size: 0;
  }
  #header .menu-button span {
    width: 15px;
  }
  #header .right-menu {
    gap: 0;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  #header.is--scrolled {
    gap: 0;
    padding: 0.5rem 1rem;
  }
  #header.is--scrolled .logo {
    width: 125px;
  }
  #search-form {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 1.5rem;
  }
  #search-form .g-title {
    font-size: 2rem;
    margin: 0;
    line-height: 0.8;
  }
  #search-form input,
  #search-form .btn-search {
    width: 100%;
  }
}
.cover {
  background: rgba(0, 0, 0, 0.85);
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 97;
}

/* Footer */
#footer {
  background: #f9f5f1;
  padding: 4% 0;
  font-size: 0.9375rem;
  min-height: 250px;
}
#footer.mh380 {
  min-height: 380px;
}
#footer .footer-wrap {
  width: 1600px;
  max-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 2rem;
  padding: 0 2rem;
  margin: 0 auto;
}
#footer .g-social-link {
  width: 350px;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
#footer .center-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
  letter-spacing: 1px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(100% - 105px - 350px - 4rem);
          flex: 0 0 calc(100% - 105px - 350px - 4rem);
}
#footer .footer-logo {
  display: block;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 105px;
          flex: 0 0 105px;
  margin-top: 1rem;
}
#footer .ul-list {
  font-size: 0.9375rem;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: "NotoSansTC";
  gap: 2.25rem;
}
#footer .ul-list li {
  position: relative;
}
#footer .ul-list li:not(:last-child)::after {
  content: "";
  position: absolute;
  right: -1.125rem;
  top: 5px;
  width: 1px;
  height: 11px;
  background: #cccccc;
}
#footer .ul-list li a {
  display: inline-block;
  color: #333;
}
#footer .ul-list li a:hover {
  text-decoration: underline;
}
#footer .copyright {
  width: 100%;
  font-size: 0.8rem;
  color: #666666;
  font-family: "GenRyuMin";
}
#footer .copyright .copy-txt {
  display: inline-block;
}
#footer .copyright a {
  color: #666666;
}

@media only screen and (max-width: 1680px) {
  #footer .footer-wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #footer .center-box {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(100% - 2rem - 105px);
            flex: 0 0 calc(100% - 2rem - 105px);
  }
  #footer .g-social-link {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    padding-left: calc(105px + 2rem);
  }
}
@media only screen and (max-width: 1199px) {
  #footer .footer-logo {
    margin: 0;
  }
  #footer .ul-list {
    gap: 1.5rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #footer .ul-list li:not(:last-child)::after {
    right: -0.75rem;
  }
}
@media (max-width: 991px) {
  #footer {
    padding-top: 2rem;
  }
  #footer .footer-wrap {
    gap: 1.5rem;
  }
  #footer .footer-logo {
    margin: 0 auto;
  }
  #footer .center-box {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    gap: 0.5rem;
  }
  #footer .ul-list {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 1rem;
  }
  #footer .ul-list li:not(:last-child)::after {
    right: -0.5rem;
  }
  #footer .copyright {
    font-size: 0.75rem;
    text-align: center;
  }
  #footer .g-social-link {
    padding: 0;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media only screen and (max-width: 767px) {
  #footer {
    padding: 2rem 0;
  }
  #footer.mh380 {
    min-height: 400px;
  }
  #footer .center-box {
    gap: 1rem;
  }
  #footer .ul-list {
    gap: 0;
    font-size: 0.875rem;
  }
  #footer .ul-list li:not(:last-child)::after {
    display: none;
  }
  #footer .ul-list li a {
    padding: 0 5px;
  }
}
/*Top */
.fb_reset {
  z-index: 999 !important;
}

.go-top,
.go-line,
.fb-msg {
  position: fixed;
  width: 60px;
  height: 60px;
  line-height: 60px;
  color: #fff;
  text-align: center;
  border-radius: 50%;
  right: 25px;
  bottom: -5rem;
  cursor: pointer;
  z-index: 98;
  font-size: 0;
  opacity: 0;
  -webkit-transform-origin: right bottom;
      -ms-transform-origin: right bottom;
          transform-origin: right bottom;
  background-color: #333333;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 43%;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.go-top.is--scrolled,
.go-line.is--scrolled,
.fb-msg.is--scrolled {
  opacity: 1;
}

.go-top {
  font-size: 1rem;
  background-color: #333333;
  text-decoration: underline;
}
.go-top.is--scrolled {
  bottom: calc(2rem + 130px);
}

.go-line {
  background-color: #88a488;
  background-image: url(../images/icon_line_w.svg);
}
.go-line.is--scrolled {
  bottom: calc(2rem + 62px);
}
.go-line a {
  display: block;
}

.pc .go-top:hover {
  border: 0;
  width: 64px;
  height: 64px;
  background-color: #c7b280;
}
.pc .go-top:hover::before {
  background-color: rgba(15, 51, 100, 0.3);
  -webkit-animation: gotop-ani 0.8s infinite;
          animation: gotop-ani 0.8s infinite;
}

@media only screen and (max-width: 767px) {
  .go-top,
  .go-line,
  .fb-msg {
    width: 60px;
    height: 60px;
    line-height: 60px;
  }
  .go-top {
    font-size: 0.75rem;
  }
  .go-top.is--scrolled {
    bottom: calc(2rem + 130px);
  }
  .go-line.is--scrolled {
    bottom: calc(2rem + 60px);
  }
}
/* Container */
.g-wrap {
  max-width: 100vw;
  overflow-x: hidden;
}
.g-wrap.bg-style {
  background: url(../images/tree_bg_r.png) right top no-repeat;
}
.g-wrap.bg-style::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 80vh;
  z-index: -1;
  background: rgb(255, 255, 255);
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(255, 255, 255, 0)), color-stop(64%, rgb(243, 239, 235)));
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgb(243, 239, 235) 64%);
}

.container-900 {
  width: 100%;
  max-width: calc(900px + 4rem);
  margin: 0 auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.container-1200 {
  width: 100%;
  max-width: calc(1200px + 4rem);
  padding: 0 2rem;
  margin: 0 auto;
}

.container-1300 {
  width: 100%;
  max-width: calc(1300px + 4rem);
  padding: 0 2rem;
  margin: 0 auto;
}

.container-1500 {
  width: 100%;
  max-width: calc(1500px + 4rem);
  padding: 0 2rem;
  margin: 0 auto;
}

.container-1600 {
  width: 100%;
  max-width: calc(1600px + 4rem);
  padding: 0 2rem;
  margin: 0 auto;
}

.page-wrap {
  padding: 3% 0;
}

.main {
  overflow: hidden;
}

.white-bg {
  padding: 5%;
  background: #fff;
}

@media (max-width: 1700px) {
  .container-1600 {
    max-width: 100%;
  }
}
@media (max-width: 1500px) {
  .container-1500 {
    max-width: 100%;
  }
}
@media (max-width: 1366px) {
  .container-1300,
  .page-wrap {
    padding-top: 5rem;
    padding-bottom: 3rem;
  }
}
@media (max-width: 991px) {
  .container-1300 {
    max-width: 100%;
  }
  .container-900 {
    max-width: 100%;
  }
  .page-wrap {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
  .white-bg {
    padding: 2rem;
  }
  .g-wrap.bg-style {
    background-size: 50%;
  }
}
@media (max-width: 767px) {
  .page-wrap {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
  .g-wrap.bg-style {
    background-size: 40%;
  }
  .g-wrap.bg-style::before {
    height: 500px;
  }
}
.g-social-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.g-social-link ul {
  width: 100%;
  font-size: 0.9375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
}
.g-social-link ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 37px;
  line-height: 35px;
  border-radius: 17.5px;
  text-align: center;
  padding: 0 1rem;
  -webkit-transition: color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5), background-color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5);
  transition: color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5), background-color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5);
  color: #333;
  gap: 10px;
  border: 1px solid #ddd;
}
.g-social-link ul li a:before {
  content: "";
}
.g-social-link ul li .fb:before {
  font-family: "Font Awesome 5 Brands";
  content: "\f39e";
}
.g-social-link ul li .ig:before {
  font-family: "Font Awesome 5 Brands";
  content: "\f16d";
}
.g-social-link ul li .line {
  padding-left: 30px;
  background: url(../images/icon_line_b.svg) center center no-repeat;
  background-size: 17px auto;
  background-repeat: no-repeat;
  background-position: 1rem center;
}

.pc .g-social-link ul li a:hover {
  color: #fff;
}
.pc .g-social-link ul li a:hover:before {
  color: #fff;
}
.pc .g-social-link ul li .fb:hover {
  background: #0078d7;
}
.pc .g-social-link ul li .ig:hover {
  background: rgb(64, 93, 230);
  background: linear-gradient(59deg, rgb(64, 93, 230) 0%, rgb(225, 48, 108) 46%, rgb(252, 175, 69) 85%);
}
.pc .g-social-link ul li .line:hover {
  background-color: #00c300;
  background-image: url(../images/icon_line_w.svg);
}

@media only screen and (max-width: 1480px) {
  .g-social-link {
    gap: 1.5rem;
  }
  .g-social-link ul {
    gap: 0.5rem;
    width: auto;
  }
}
.g-social-link {
  padding: 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (max-width: 767px) {
  .g-social-link {
    font-size: 0.75rem;
    gap: 0.5rem;
  }
  .g-social-link ul {
    font-size: 0;
    gap: 0;
  }
  .g-social-link ul li a {
    border: 0;
    gap: 0;
    width: 28px;
    padding: 0;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .g-social-link ul li a:before {
    font-size: 0.875rem;
  }
  .g-social-link ul li .line {
    padding: 0;
    background-position: center center;
  }
}
.list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.box {
  position: relative;
  color: #222222;
  display: block;
  overflow: hidden;
}
.box .tag {
  position: absolute;
}
.box__pic {
  display: block;
  position: relative;
  overflow: hidden;
}
.box__pic img {
  -webkit-transform-origin: center bottom;
      -ms-transform-origin: center bottom;
          transform-origin: center bottom;
  -webkit-transition: -webkit-transform 0.3s var(--ease);
  transition: -webkit-transform 0.3s var(--ease);
  transition: transform 0.3s var(--ease);
  transition: transform 0.3s var(--ease), -webkit-transform 0.3s var(--ease);
}
.box__txt {
  padding: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: var(--g-gap);
}
.box__txt-cat {
  padding: 0 10px;
  color: #a38556;
  font-size: var(--fluid-small-txt);
  border: 1px solid #c7b280;
}
.box__txt-h3 {
  width: 100%;
  line-height: var(--g-line-height);
  font-size: clamp(0.9375rem, 0.8897rem + 0.1961vw, 1.125rem);
  margin: 0;
  color: #333;
  -webkit-transition: color 0.3s var(--ease);
  transition: color 0.3s var(--ease);
}
.box__txt-h3 span.en {
  font-size: clamp(0.875rem, 0.9363rem + 0.2614vw, 1rem);
  display: block;
}
.box__txt-des {
  width: 100%;
  font-size: 0.9375rem;
  line-height: 1.6rem;
  max-height: 4.8rem;
  overflow: hidden;
  color: #666666;
  letter-spacing: 1px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
.box__txt-date {
  color: #a38556;
  font-size: var(--fluid-small-txt);
}
.box .btn-more {
  font-size: 0;
  position: absolute;
  right: 2rem;
  bottom: 1.5rem;
  opacity: 0;
  -webkit-transition: opacity 0.5s var(--ease) 0.1s;
  transition: opacity 0.5s var(--ease) 0.1s;
}
.box .btn-more span {
  background: #fff;
  -webkit-box-shadow: 0px 0px 2.2px rgba(0, 0, 0, 0.02), 0px 0px 5.3px rgba(0, 0, 0, 0.028), 0px 0px 10px rgba(0, 0, 0, 0.035), 0px 0px 17.9px rgba(0, 0, 0, 0.042), 0px 0px 33.4px rgba(0, 0, 0, 0.05), 0px 0px 80px rgba(0, 0, 0, 0.07);
          box-shadow: 0px 0px 2.2px rgba(0, 0, 0, 0.02), 0px 0px 5.3px rgba(0, 0, 0, 0.028), 0px 0px 10px rgba(0, 0, 0, 0.035), 0px 0px 17.9px rgba(0, 0, 0, 0.042), 0px 0px 33.4px rgba(0, 0, 0, 0.05), 0px 0px 80px rgba(0, 0, 0, 0.07);
}
.box .btn-more span::before, .box .btn-more span::after {
  background: #333;
}

.price {
  font-size: clamp(0.75rem, 0.4044rem + 0.3922vw, 0.875rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: var(--g-gap);
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.price .old {
  color: #aaaaaa;
  text-decoration: line-through;
}
.price .new {
  color: #d29374;
}

.tag {
  left: 2rem;
  color: #fff;
  font-size: 0.75rem;
  text-align: center;
  width: 50px;
  height: 20px;
  border-radius: 10px;
  line-height: 20px;
}
.tag:nth-of-type(1) {
  top: 2rem;
}
.tag:nth-of-type(2) {
  top: calc(2rem + 20px + 0.5rem);
}
.tag.is-new {
  background: #c7b280;
}
.tag.is-hot {
  background: #d29374;
}

.pc .box:hover {
  color: #333;
}
.pc .box:hover .btn-more {
  opacity: 1;
  -webkit-animation: gotop-ani 0.8s infinite;
          animation: gotop-ani 0.8s infinite;
}

@media (max-width: 991px) {
  .box .tag {
    left: 1rem;
  }
  .box .tag:nth-of-type(1) {
    top: 1rem;
  }
  .box .tag:nth-of-type(2) {
    top: calc(1rem + 20px + 0.25rem);
  }
  .box__txt-cat {
    padding: 0 0.5rem;
  }
  .box__txt-h3 {
    line-height: 1.5rem;
    max-height: 4.5rem;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
  }
  .tag {
    font-size: 0.7rem;
  }
}
@media (max-width: 767px) {
  .box__txt {
    padding: 1rem 0;
  }
}
.flex-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.flex-wrap .left-box,
.flex-wrap .right-box {
  width: 50%;
}

.event-wrap {
  width: 100%;
  font-size: clamp(0.8rem, 0.7045rem + 0.1942vw, 0.9375rem);
  color: #d29374;
  padding-left: 10px;
  line-height: 1;
  font-family: "NotoSansTC";
  border-left: 3px solid #d29374;
}
.event-wrap a {
  color: #d29374;
}

@media (max-width: 991px) {
  .event-wrap {
    border-left: 2px solid #d29374;
    padding-left: 6px;
  }
}
.register-terms {
  max-width: 1000px;
}
.register-terms .theme-wrap,
.register-terms .inner {
  height: 80vh;
}
.register-terms .white-bg {
  padding: 0;
}

@media (max-width: 1199px) {
  .register-terms {
    max-width: 100%;
  }
}
/* Title */
.g-title {
  position: relative;
  margin: 0.5rem 0 1.5rem;
  font-weight: normal;
  font-size: clamp(1.25rem, 0.9951rem + 1.0458vw, 2.25rem);
  color: #000;
}
.g-title span {
  display: inline-block;
  overflow: hidden;
}
.g-title .en {
  display: block;
}
.g-title .ch {
  font-family: GenRyuMin;
  display: block;
}
.g-title .main {
  color: #ae914d;
}
.g-title .small {
  font-size: clamp(0.875rem, 0.7794rem + 0.3922vw, 1.25rem);
}
.g-title.center-style {
  position: relative;
  text-align: center;
  display: inline-block;
  margin-bottom: 4rem;
}
.g-title.center-style .en,
.g-title.center-style .ch {
  display: inline-block;
}
.g-title.center-style::before, .g-title.center-style::after {
  content: "";
  position: absolute;
  background: #333;
  width: 50%;
  height: 1px;
}
.g-title.center-style::before {
  left: 0;
  top: -1rem;
}
.g-title.center-style::after {
  bottom: -0.5rem;
  left: 50%;
}
.g-title__big {
  font-size: clamp(1.875rem, 1.4926rem + 1.5686vw, 3.375rem);
  margin: 0.5rem 0 1.5rem;
}
.g-title__big .small {
  font-size: clamp(0.875rem, 0.7794rem + 0.3922vw, 1.25rem);
}
.g-title__big .en {
  display: block;
}
.g-title__big .ch {
  font-family: GenRyuMin;
  display: block;
}

.small-h3 {
  font-size: clamp(0.9375rem, 0.826rem + 0.4575vw, 1.375rem);
  letter-spacing: 10px;
}

.g-h3 {
  font-weight: bold;
  font-size: 1.25rem;
  margin: 0;
}

.g-h4 {
  font-size: clamp(1rem, var(--fluid-h4), 1.375rem);
}

.h3-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
  font-size: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #ccc;
  position: relative;
  gap: 1rem;
  margin-bottom: 5%;
}
.h3-box .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #c7b280;
}
.h3-box .icon {
  display: block;
  width: 30px;
  height: 30px;
  background: url(../images/icon_sort.png) center center no-repeat;
}
.h3-box::after {
  content: "";
  width: 100%;
  height: 2px;
  background: #fff;
  display: block;
  position: absolute;
  bottom: -3px;
  left: 0;
}

@media (max-width: 991px) {
  .g-title {
    margin: 0.5em 0 1rem;
  }
  .small-h3 {
    letter-spacing: 5px;
  }
  .g-h3 {
    font-size: 1.125rem;
  }
  .g-h3 img {
    width: 24px;
    margin-right: 5px;
  }
}
@media (max-width: 767px) {
  .h3-box .dot {
    width: 5px;
    height: 5px;
  }
  .g-title.center-style {
    margin-bottom: 3rem;
  }
  .g-title.center-style::before {
    top: -0.75rem;
  }
  .g-title.center-style::after {
    bottom: -0.25rem;
  }
}
.btn-main {
  color: #fff;
  background-color: #333;
  border-radius: 30px;
  height: 60px;
  line-height: 60px;
  width: 200px;
  border-style: solid;
  border-width: 1px;
  border-color: #dddddd;
  display: inline-block;
  text-align: center;
  font-size: var(--fluid-btn-txt);
  text-transform: uppercase;
  padding: 0 25px;
  -webkit-transition: 0.3s var(--ease);
  transition: 0.3s var(--ease);
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.btn-main::before {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  right: 0;
  height: 100%;
  width: 100%;
  display: block;
  background-color: #c7b280;
  -webkit-transition: top 0.4s ease, height 0.3s ease 0.1s;
  transition: top 0.4s ease, height 0.3s ease 0.1s;
  z-index: -1;
}

.btn-white {
  color: #333;
  background-color: #fff;
  border-radius: 30px;
  height: 60px;
  line-height: 60px;
  width: 200px;
  border-style: solid;
  border-width: 1px;
  border-color: #dddddd;
  display: inline-block;
  text-align: center;
  font-size: var(--fluid-btn-txt);
  text-transform: uppercase;
  padding: 0 25px;
  -webkit-transition: 0.3s var(--ease);
  transition: 0.3s var(--ease);
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.btn-white::before {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  right: 0;
  height: 100%;
  width: 100%;
  display: block;
  background-color: #333;
  -webkit-transition: top 0.4s ease, height 0.3s ease 0.1s;
  transition: top 0.4s ease, height 0.3s ease 0.1s;
  z-index: -1;
}

.btn-second {
  color: #fff;
  background-color: #c7b280;
  border-radius: 30px;
  height: 60px;
  line-height: 60px;
  width: 200px;
  border-style: solid;
  border-width: 1px;
  border-color: #cfbd92;
  display: inline-block;
  text-align: center;
  font-size: var(--fluid-btn-txt);
  text-transform: uppercase;
  padding: 0 25px;
  -webkit-transition: 0.3s var(--ease);
  transition: 0.3s var(--ease);
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.btn-second::before {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  right: 0;
  height: 100%;
  width: 100%;
  display: block;
  background-color: #333;
  -webkit-transition: top 0.4s ease, height 0.3s ease 0.1s;
  transition: top 0.4s ease, height 0.3s ease 0.1s;
  z-index: -1;
}

.btn-line {
  color: #fff;
  background-color: #00c300;
  border-radius: 0;
  height: 60px;
  line-height: 60px;
  width: 100%;
  border-style: solid;
  border-width: 1px;
  border-color: #00c300;
  display: inline-block;
  text-align: center;
  font-size: var(--fluid-btn-txt);
  text-transform: uppercase;
  padding: 0 25px;
  -webkit-transition: 0.3s var(--ease);
  transition: 0.3s var(--ease);
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.btn-line::before {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  right: 0;
  height: 100%;
  width: 100%;
  display: block;
  background-color: #009a00;
  -webkit-transition: top 0.4s ease, height 0.3s ease 0.1s;
  transition: top 0.4s ease, height 0.3s ease 0.1s;
  z-index: -1;
}

.btn-submit {
  color: #fff;
  background-color: #ba8a67;
  border-radius: 0;
  height: 60px;
  line-height: 60px;
  width: 300px;
  border-style: solid;
  border-width: 1px;
  border-color: #ba8a67;
  display: inline-block;
  text-align: center;
  font-size: var(--fluid-btn-txt);
  text-transform: uppercase;
  padding: 0 25px;
  -webkit-transition: 0.3s var(--ease);
  transition: 0.3s var(--ease);
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.btn-submit::before {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  right: 0;
  height: 100%;
  width: 100%;
  display: block;
  background-color: #a7724c;
  -webkit-transition: top 0.4s ease, height 0.3s ease 0.1s;
  transition: top 0.4s ease, height 0.3s ease 0.1s;
  z-index: -1;
}

.btn-back {
  color: #333;
  background-color: #fff;
  border-radius: 30px;
  height: 60px;
  line-height: 60px;
  width: 200px;
  border-style: solid;
  border-width: 1px;
  border-color: #dddddd;
  display: inline-block;
  text-align: center;
  font-size: var(--fluid-btn-txt);
  text-transform: uppercase;
  padding: 0 25px;
  -webkit-transition: 0.3s var(--ease);
  transition: 0.3s var(--ease);
  overflow: hidden;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: color 0.5s var(--ease);
  transition: color 0.5s var(--ease);
}
.btn-back .aw {
  display: block;
  width: 6px;
  height: 6px;
  margin-left: 1rem;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  -webkit-transition: border-color 0.5s ease;
  transition: border-color 0.5s ease;
}
.btn-back::before {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  -webkit-filter: url(#filter);
          filter: url(#filter);
  border-radius: 50%;
  z-index: 5;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  z-index: -1;
  left: -30%;
  bottom: -100%;
  background: #ddae97;
}
.btn-back + svg {
  position: absolute;
  width: 0;
  height: 0;
}
.btn-back:hover {
  color: #fff;
}
.btn-back:hover .aw {
  border-color: #fff;
}
.btn-back:hover::before {
  width: 307%;
  height: 400%;
}

.pc .btn-second:hover,
.pc .btn-main:hover,
.pc .btn-submit:hover,
.pc .btn-white:hover,
.pc .btn-line:hover {
  background-color: transparent;
  color: #fff;
}
.pc .btn-second:hover::before,
.pc .btn-main:hover::before,
.pc .btn-submit:hover::before,
.pc .btn-white:hover::before,
.pc .btn-line:hover::before {
  top: 0;
}

/* Button Wrap*/
.btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  ap: 1rem;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.btn-wrap-center {
  padding-top: 2rem;
  padding-bottom: 2rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1rem;
}

.btn-wrap-right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 1rem;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .btn-wrap,
  .btn-wrap-center,
  .btn-wrap-right {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px;
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}
.btn-more {
  display: block;
  position: relative;
  color: #000;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  text-align: center;
  font-size: 0.9375rem;
  text-transform: uppercase;
}
.btn-more span {
  position: relative;
  display: block;
  margin: 0.5rem auto;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #000;
}
.btn-more span::before, .btn-more span::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 15px;
  height: 1px;
  display: block;
  background: #f2ded0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.btn-more span::after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
      -ms-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}

.pc .btn-more:hover {
  color: #000;
}
.pc .btn-more:hover span {
  background: #c7b280;
  -webkit-animation: gotop-ani 0.8s infinite;
          animation: gotop-ani 0.8s infinite;
}
.pc .btn-more:hover span::before, .pc .btn-more:hover span::after {
  background: #Fff;
}

@media (max-width: 991px) {
  .btn-more {
    font-size: 0.75rem;
  }
  .btn-more span {
    width: 37px;
    height: 37px;
  }
  .btn-more span::before, .btn-more span::after {
    width: 10px;
  }
}
.btn-video {
  display: block;
  position: relative;
  background: #000;
  overflow: hidden;
  max-width: 900px;
  margin: 0 auto;
}
.btn-video img {
  width: 100%;
  height: auto !important;
  -webkit-filter: 0.3s ease;
          filter: 0.3s ease;
}
.btn-video::before {
  content: "";
  position: absolute;
  width: 60px;
  height: 60px;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: #0f3364;
  background: url(../images/btn_play.svg) center center no-repeat #0f3364;
  border-radius: 50%;
  -webkit-transform-origin: center center;
      -ms-transform-origin: center center;
          transform-origin: center center;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  z-index: 1;
}

.btn-discover {
  position: relative;
  display: inline-block;
  font-size: 0.9375rem;
  color: #333;
  overflow: hidden;
}
.btn-discover::after {
  content: "";
  width: 100%;
  position: absolute;
  display: block;
  left: 0;
  bottom: 0;
  height: 1px;
  background: #333;
  -webkit-transition: bottom 0.3s ease, left 0.3s ease 0.3s;
  transition: bottom 0.3s ease, left 0.3s ease 0.3s;
}

.pc .btn-discover:hover {
  color: #ae914d;
}
.pc .btn-discover:hover::after {
  left: 100%;
  background-color: #ae914d;
  bottom: 100%;
}

.read-more {
  display: block;
  position: relative;
  color: #000;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  text-align: center;
  font-size: 0.9375rem;
  text-transform: uppercase;
  width: 50px;
  margin: 8% 0;
}
.read-more span {
  position: absolute;
  display: block;
  margin: 0.5rem auto;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  border: 1px solid #ddd;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.read-more span::before, .read-more span::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 75%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 15px;
  height: 1px;
  display: block;
  background: #000;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
  -webkit-transform-origin: center center;
      -ms-transform-origin: center center;
          transform-origin: center center;
}
.read-more span::after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
      -ms-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}
.read-more:hover {
  color: #000;
}
.read-more:hover span {
  border: 1px solid #c7b280;
}
.read-more:hover span::before {
  -webkit-transform: translate(-50%, -50%) rotate(360deg);
      -ms-transform: translate(-50%, -50%) rotate(360deg);
          transform: translate(-50%, -50%) rotate(360deg);
}
.read-more:hover span::after {
  -webkit-transform: translate(-50%, -50%) rotate(450deg);
      -ms-transform: translate(-50%, -50%) rotate(450deg);
          transform: translate(-50%, -50%) rotate(450deg);
}

.system-info {
  text-align: center;
  margin: 0 auto;
  line-height: 2;
  letter-spacing: 2px;
  padding: 8vh 0;
  color: #3b3b3b;
  font-size: 0.9375rem;
}
.system-info i {
  font-size: 1.5rem;
  display: block;
  margin: 0 auto 10px;
}
.system-info .icon {
  width: 90px;
  height: 90px;
  line-height: 90px;
  margin: 0 auto 2rem;
  border-radius: 90px;
  text-align: center;
  border: 1px solid #f2f2f2;
  font-size: 4rem;
  font-weight: bold;
  color: #f2f2f2;
}

@media only screen and (max-width: 767px) {
  .system-info {
    font-size: 0.875rem;
  }
}
/* star */
.star::after {
  content: "*";
  color: #d29374;
}

/* LABEL */
.label-style {
  width: 90px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 90px;
          flex: 0 0 90px;
  margin: 0;
  line-height: 55px;
  font-weight: normal;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  -webkit-transform-origin: left top;
      -ms-transform-origin: left top;
          transform-origin: left top;
}

@media (max-width: 767px) {
  .label-style {
    line-height: 40px;
    width: 75px;
    min-width: 75px;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 75px;
            flex: 0 0 75px;
    font-size: 0.9375rem;
  }
}
/* TEXT */
.input-style {
  height: 55px;
  line-height: 55px;
  border: 0;
  border-radius: 0;
  width: calc(100% - 90px - 10px);
  background-color: transparent;
}
.input-style:focus {
  border: 0;
  width: 100%;
}

@media (max-width: 767px) {
  .input-style {
    width: calc(100% - 90px - 5px);
    height: 40px;
    line-height: 40px;
    font-size: 0.9375rem;
  }
}
/* TEXTAREA */
.textarea-style {
  background-color: #fff;
  padding: 18px 10px 5px;
  display: block;
  outline: none;
  width: calc(100% - 90px - 10px);
  border: 0;
  border-radius: 0;
  -webkit-transition: border 0.15s, height 0.15s;
  transition: border 0.15s, height 0.15s;
}
.textarea-style:focus {
  border: 0;
}

@media (max-width: 767px) {
  .textarea-style {
    font-size: 0.9375rem;
    width: calc(100% - 65px - 5px);
  }
}
.select-style {
  position: relative;
  height: 55px;
  line-height: 48px;
  width: calc(100% - 90px - 10px);
  padding: 0 45px 0 10px;
  border: 0;
  border-radius: 0;
  background: transparent;
  display: inline-block;
  background-color: transparent;
  background-image: url(../images/select_arrow.png);
  background-repeat: no-repeat;
  background-position: calc(100% - 20px) center;
}
.select-style:focus {
  border: 1px solid #c7b280;
}

@media (max-width: 767px) {
  .select-style {
    width: calc(100% - 65px - 5px);
    height: 40px;
    font-size: 0.9375rem;
    line-height: 38px;
    background-size: 12px;
    background-position: calc(100% - 7px) center;
  }
}
/* FORM - BOX */
.form-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 2rem;
}

.form-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  color: #222;
  padding: 10px 0;
  gap: 10px;
  border-bottom: 1px solid #ddd;
}
.form-box.form-half {
  width: calc((100% - 2rem) / 2);
}
.form-box.form-third {
  width: calc((100% - 4rem) / 3);
}
.form-box.is-focus {
  border-bottom: 1px solid #c7b280;
}
.form-box.is-focus .label-style {
  position: absolute;
  left: 0;
  color: #666;
  -webkit-transform: scale(0.75);
      -ms-transform: scale(0.75);
          transform: scale(0.75);
  top: 0px;
}
.form-box.is-focus .input-style {
  line-height: 25px;
  padding: 18px 10px 5px;
  width: 100%;
}
.form-box.is-focus .textarea-style {
  width: 100%;
}

@media (max-width: 1199px) {
  .form-wrap {
    gap: 1rem;
  }
  .form-box.form-half {
    width: calc((100% - 0.5rem) / 2);
  }
  .form-box.form-third {
    width: calc((100% - 1rem) / 3);
  }
}
@media (max-width: 767px) {
  .form-wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0;
  }
  .form-box {
    width: 100%;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 10px 5px;
    gap: 5px;
  }
  .form-box.form-half {
    width: 100%;
  }
  .form-box.form-third {
    width: 100%;
  }
}
/* SEX */
.form-box.form-sex {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media (max-width: 767px) {
  .form-box.form-sex .radio-style {
    margin-right: 6px;
  }
}
/* ADD */
.form-box.form-add {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.form-box.form-add .select-style,
.form-box.form-add input {
  width: calc((100% - 90px - 40px) * 0.4 / 2);
  height: 50px;
  line-height: 48px;
  border: 1px solid #dddddd;
}
.form-box.form-add input {
  width: calc((100% - 90px - 40px) * 0.6);
  padding: 0 10px;
}

@media (max-width: 991px) {
  .form-box.form-add {
    gap: 10px;
    padding-right: 0;
  }
  .form-box.form-add .select-style,
  .form-box.form-add input {
    width: calc((100% - 90px - 30px) / 3);
  }
  .form-box.form-add input:nth-of-type(2) {
    width: 100%;
  }
}
@media (max-width: 767px) {
  .form-box.form-add {
    gap: 5px;
  }
  .form-box.form-add .select-style,
  .form-box.form-add input {
    height: 40px;
    line-height: 40px;
  }
  .form-box.form-add .select-style {
    width: calc((100% - 90px - 10px) / 2);
  }
  .form-box.form-add input {
    width: 100%;
  }
  .form-box.form-add input:nth-of-type(2) {
    width: calc((100% - 5px) * 0.7);
  }
}
/* CODE */
.form-box.code .codeimg {
  position: absolute;
  right: 0;
  height: 50px;
  width: 150px;
  cursor: pointer;
  display: block;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.form-box.code .codeimg img {
  width: 100%;
  height: 100%;
}

@media (max-width: 1199px) {
  .form-box.code .codeimg {
    width: 100px;
    height: 44px;
  }
}
/* RADIO */
.radio-style {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: normal;
  margin: 0;
  cursor: pointer;
}
.radio-style input {
  outline: none;
  z-index: -100 !important;
  width: 1px !important;
  height: 1px !important;
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
  opacity: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.radio-style input + span {
  display: block;
  vertical-align: middle;
  border: 1px solid #959595;
  background: transparent;
  width: 20px;
  height: 20px;
  padding: 3px;
  border-radius: 50%;
  -webkit-transition: background 0.15s;
  transition: background 0.15s;
}
.radio-style input + span i {
  display: block;
  width: 100%;
  height: 100%;
  background: transparent;
  border-radius: 50%;
  -webkit-transition: background 0.12s;
  transition: background 0.12s;
}
.radio-style input:checked + span, .radio-style input:active + span {
  border: 1px solid #c7b280;
}
.radio-style input:checked + span i, .radio-style input:active + span i {
  background: #c7b280;
}

.pc .radio-style:hover input:not(:checked) + span i {
  background: #c7b280;
}

@media (max-width: 991px) {
  .radio-style {
    font-size: 0.875rem;
  }
  .radio-style input + span {
    width: 16px;
    height: 16px;
  }
}
/* CHECKBOX */
.checkbox-style {
  padding: 6px 0;
  display: inline-block;
  font-weight: normal;
  font-size: 1rem;
  margin-left: 1rem;
}
.checkbox-style input {
  outline: none;
  z-index: -100 !important;
  width: 1px !important;
  height: 1px !important;
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
  opacity: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.checkbox-style input + span {
  display: inline-block;
  vertical-align: middle;
  border: 1px solid #ccc;
  background: #fff;
  width: 20px;
  height: 20px;
  padding: 0;
  margin: 0 8px 3px 0;
  border-radius: 1px;
  -webkit-transition: background 0.15s;
  transition: background 0.15s;
}
.checkbox-style input + span i {
  display: inline-block;
  vertical-align: top;
  margin: 7px 0 0 7px;
  width: 15px;
  height: 8px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  -webkit-transform: scale(0) rotate(-45deg);
      -ms-transform: scale(0) rotate(-45deg);
          transform: scale(0) rotate(-45deg);
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
  -webkit-transform-origin: left bottom;
      -ms-transform-origin: left bottom;
          transform-origin: left bottom;
}
.checkbox-style input:active, .checkbox-style input:checked + span {
  border-color: #333;
  border: 1px solid #333;
}
.checkbox-style input:active i, .checkbox-style input:checked + span i {
  -webkit-transform: scale(1) rotate(-45deg);
      -ms-transform: scale(1) rotate(-45deg);
          transform: scale(1) rotate(-45deg);
  border-color: #333;
}
.checkbox-style input:hover + span {
  border-color: #333;
}

@media (max-width: 991px) {
  .checkbox-style {
    font-size: 0.875rem;
  }
  .checkbox-style input + span {
    width: 12px;
    height: 12px;
  }
  .checkbox-style input + span i {
    margin: 3px 0 0 3px;
  }
}
.g-txt {
  font-size: var(--fluid-txt);
  line-height: calc(var(--fluid-txt) * 2);
  letter-spacing: 1px;
  color: #888888;
  font-family: "NotoSansTC", sans-serif;
}

.page-share {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.page-share ul {
  width: 100%;
  font-size: 0.9375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
}
.page-share ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 37px;
  line-height: 35px;
  border-radius: 17.5px;
  text-align: center;
  padding: 0 1rem;
  -webkit-transition: color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5), background-color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5);
  transition: color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5), background-color 0.3s cubic-bezier(0.5, 0, 0.3, 0.5);
  color: #888;
  gap: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
}
.page-share ul li a:before {
  content: "";
}
.page-share ul li .fb:before {
  font-family: "Font Awesome 5 Brands";
  content: "\f39e";
}
.page-share ul li .link:before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f0c1";
}
.page-share ul li .line {
  padding-left: 30px;
  background: url(../images/icon_line_888.svg) center center no-repeat;
  background-size: 17px auto;
  background-repeat: no-repeat;
  background-position: 1rem center;
}

.pc .page-share ul li a:hover {
  color: #fff;
}
.pc .page-share ul li a:hover:before {
  color: #fff;
}
.pc .page-share ul li .fb:hover {
  background: #0078d7;
}
.pc .page-share ul li .link:hover {
  background: #888;
}
.pc .page-share ul li .line:hover {
  background-color: #00c300;
  background-image: url(../images/icon_line_w.svg);
}

@media only screen and (max-width: 1480px) {
  .page-share {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    padding-left: calc(105px + 2rem);
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1.5rem;
  }
  .page-share ul {
    gap: 0.5rem;
    width: auto;
  }
}
.page-share {
  padding: 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (max-width: 767px) {
  .page-share {
    font-size: 0.75rem;
    gap: 0.5rem;
  }
  .page-share ul {
    font-size: 0;
    gap: 0;
  }
  .page-share ul li a {
    border: 0;
    gap: 0;
    width: 28px;
    padding: 0;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .page-share ul li a:before {
    font-size: 0.875rem;
  }
  .page-share ul li .line {
    padding: 0;
    background-position: center center;
  }
}
#news-view {
  background: url(../images/tree_shadow.png) left top no-repeat;
  min-height: 40vh;
}
#news-view article .box__txt {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#news-view article .box__txt .g-title {
  font-size: clamp(1.25rem, 0.7721rem + 1.9608vw, 3.125rem);
  width: 100%;
  text-align: center;
  margin-bottom: 0;
}
#news-view .control-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  border-top: 1px solid #cccccc;
  border-bottom: 1px solid #cccccc;
  margin-bottom: 4%;
}
#news-view .control-wrap::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1px;
  height: 50px;
  background: #ccc;
}
#news-view .control-wrap > a {
  width: calc((100% - 2rem) / 2);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #fff;
  border-radius: 1rem;
  overflow: hidden;
  color: #333;
  font-weight: bold;
  -webkit-transition: background 0.3s ease-in;
  transition: background 0.3s ease-in;
}
#news-view .control-wrap > a .aw {
  position: relative;
  width: 50px;
  height: 50px;
  -webkit-transition: background 0.3s ease-in;
  transition: background 0.3s ease-in;
}
#news-view .control-wrap > a .aw::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  -webkit-transition: border 0.3s ease;
  transition: border 0.3s ease;
  border-style: solid;
  border-width: 1px;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
      -ms-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
#news-view .control-wrap > a.prev > .aw::after {
  border-color: transparent transparent #d2d2d2 #d2d2d2;
}
#news-view .control-wrap > a.prev:hover > .aw::after {
  border-color: transparent transparent #000 #000;
}
#news-view .control-wrap > a.next {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
#news-view .control-wrap > a.next > .aw {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
#news-view .control-wrap > a.next > .aw::after {
  border-color: #d2d2d2 #d2d2d2 transparent transparent;
}
#news-view .control-wrap > a.next:hover > .aw::after {
  border-color: #000 #000 transparent transparent;
}
#news-view .control-wrap > a.next .txt {
  text-align: right;
}
#news-view .control-wrap > a .txt {
  width: calc(100% - 50px);
  padding: 1.75rem 0;
}
#news-view .control-wrap > a .txt .ti {
  height: 1.5rem;
  font-size: 1.125rem;
  margin-bottom: 10px;
  font-weight: normal;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  -webkit-transition: color 0.3s var(--ease);
  transition: color 0.3s var(--ease);
}
#news-view .control-wrap > a .txt .s-ti {
  font-size: var(--g-small-txt);
}
#news-view .control-wrap > a:hover .txt .ti {
  color: #c7b280;
}
#news-view .page-share {
  padding-bottom: 4%;
}
#news-view .page-share ul {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#news-view .related-wrap {
  position: relative;
  padding: 4% 0 3%;
}
#news-view .related-wrap::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 45%;
  background: url(../images/i_pro_bg.jpg) center center;
  background-size: cover;
  z-index: -1;
}
#news-view .related-wrap .aw-box {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  top: 50%;
  margin-top: -70px;
  left: 5%;
  right: 5%;
  position: absolute;
}
#news-view .related-wrap .box__pic img {
  width: 100%;
}

@media (max-width: 767px) {
  #news-view::before, #news-view::after {
    height: 40vh;
  }
  #news-view .control-wrap {
    gap: 1rem;
  }
  #news-view .control-wrap > a {
    width: calc((100% - 1rem) / 2);
  }
  #news-view .control-wrap > a .aw {
    width: 30px;
    height: 30px;
  }
  #news-view .control-wrap > a .aw::after {
    width: 10px;
    height: 10px;
  }
  #news-view .control-wrap > a .txt {
    padding: 0.5rem 0;
    width: calc(100% - 30px);
  }
  #news-view .control-wrap > a .txt .ti {
    font-size: 0.9375rem;
  }
  #news-view .related-wrap .aw-box {
    top: 45%;
  }
}