body {
  background-color: #191919;
}

/*==========================================
  Component
==========================================*/
.en {
  font-family: "Cinzel", serif;
  font-weight: 400;
  font-family: "Cinzel", serif;
}

.ense {
  font-family: "Noto Serif JP", serif;
  font-weight: 300;
  font-family: "Noto Serif JP", serif;
}

.cnsa {
  font-family: "Noto Sans SC", sans-serif;
  font-weight: 300;
  font-family: "Noto Sans SC", sans-serif;
}

.cnse {
  font-family: "Noto Serif KR", serif;
  font-weight: 300;
  font-family: "Noto Serif SC", sans-serif;
}

.kosa {
  font-family: "Noto Sans SC", sans-serif;
  font-weight: 300;
  font-family: "Noto Sans KR", sans-serif;
}

.kose {
  font-family: "Noto Serif KR", serif;
  font-weight: 300;
  font-family: "Noto Serif KR", sans-serif;
}

.container {
  max-width: 1200px;
  padding-left: 70px;
  padding-right: 70px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}
@media (max-width: 900px) {
  .container {
    padding-left: 20px;
    padding-right: 20px;
  }
}

.row {
  display: flex;
  flex-wrap: wrap;
  box-sizing: border-box;
}

.col {
  position: relative;
  width: 100%;
  flex: 0 0 100%;
  max-width: 100%;
  min-height: 1px;
  box-sizing: border-box;
}

.en-heading {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.2em;
  color: #7a7441;
  margin: 0 0 25px 0;
  position: relative;
}
@media (max-width: 1120px) {
  .en-heading {
    font-size: 16px;
  }
}
.en-heading::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -210px;
  margin: auto;
  width: 190px;
  height: 1px;
  background-color: #7a7441;
  background-size: 100% 1px;
  background-position: bottom;
  background-repeat: no-repeat;
}
@media (max-width: 900px) {
  .en-heading {
    font-size: 12px;
    margin: 0 0 32px 0;
  }
  .en-heading::before {
    left: -20px;
    width: 14px;
  }
}

.en-t {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.2em;
  color: #7a7441;
}
@media (max-width: 1120px) {
  .en-t {
    font-size: 16px;
  }
}
@media (max-width: 900px) {
  .en-t {
    font-size: 12px;
    margin: 0 0 10px;
  }
}

.sec-heading {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: 0.25em;
  color: #cdcdcd;
  font-family: "Noto Serif JP", serif;
  font-weight: 300;
  overflow: hidden;
  margin: 0 0 40px 0;
}

.sec-heading_cn {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: 0.25em;
  color: #cdcdcd;
  font-family: "Noto Serif sc", serif;
  font-weight: 300;
  overflow: hidden;
  margin: 0 0 40px 0;
}

.sec-heading_ko {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: 0.25em;
  color: #cdcdcd;
  font-family: "Noto Serif kr", serif;
  font-weight: 300;
  overflow: hidden;
  margin: 0 0 40px 0;
}
@media (max-width: 1120px) {
  .sec-heading {
    font-size: 26px;
  }
}
.sec-heading > .inner {
  font-weight: 300;
  position: relative;
  overflow: hidden;
  display: inline-block;
}
.sec-heading > .inner::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  left: 0;
  right: 0;
  bottom: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#cdcdcd), to(#cdcdcd)) 0 100%/0 0px no-repeat;
  background: linear-gradient(#cdcdcd, #cdcdcd) 0 100%/0 0px no-repeat;
  transition: all 0.5s ease;
  opacity: 0.6;
}
.sec-heading > .inner.line_move::before {
  background-size: 100% 1px;
}
.sec-heading > .inner.line_move2::before {
  transform: translateX(150%);
}
.sec-heading > .inner > span {
  transform: translate3d(0, 100%, 0);
  opacity: 0;
  display: inline-block;
}
.sec-heading_en > .inner > span {
  transform: translate3d(0, 100%, 0);
  opacity: 0;
}
@media (max-width: 900px) {
  .sec-heading {
    font-size: 21px;
    letter-spacing: 0.15em;
    margin: 0 0 20px 0;
  }
}

.link_wrap {
  padding: 42px 0 0;
  text-align: right;
}
.link_wrap .link_button {
  font-size: 18px;
  line-height: 1.3;
  letter-spacing: 0.15em;
  color: #777;
  font-weight: 400;
  font-style: italic;
  padding-right: 19px;
  position: relative;
  display: inline-block;
  box-sizing: border-box;
}
.link_wrap .link_button::before {
  content: "";
  width: 14px;
  height: 1px;
  background-color: #eaeaea;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  transition: all 0.3s ease;
}
@media (min-width: 901px) {
  .link_wrap .link_button:hover {
    color: #fff;
  }
  .link_wrap .link_button:hover::before {
    width: 24px;
    right: -10px;
  }
}
@media (max-width: 900px) {
  .link_wrap {
    padding: 26px 0 0;
  }
  .link_wrap .link_button {
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: 0.15em;
    color: #777;
  }
  .link_wrap .link_button::before {
    width: 9px;
  }
}

.news_ul .news_li {
  border-bottom: 1px solid #343434;
  padding: 18px 14px 18px 0;
  position: relative;
  box-sizing: border-box;
}
@media (max-width: 900px) {
  .news_ul .news_li {
    padding: 12px 14px 12px 0;
  }
}
.news_ul .news_li .news_link {
  color: #cdcdcd;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
}
.news_ul .news_li .news_link:visited {
  color: #cdcdcd;
}
.news_ul .news_li .news_link .right_wrap {
  position: relative;
  padding-right: 23px;
  min-width: 115px;
}
.news_ul .news_li .news_link .right_wrap::before {
  content: "";
  width: 14px;
  height: 1px;
  background-color: #eaeaea;
  position: absolute;
  top: 16px;
  right: 0;
  margin: auto;
  transition: all 0.3s ease;
}
@media (min-width: 901px) {
  .news_ul .news_li .news_link .left_wrap {
    display: flex;
  }
  .news_ul .news_li .news_link .date {
    display: inline-block;
    margin: 0 22px 0 0;
  }
  .news_ul .news_li .news_link:hover {
    color: #fff;
  }
  .news_ul .news_li .news_link:hover .right_wrap::before {
    width: 24px;
    right: -10px;
  }
}
@media (max-width: 900px) {
  .news_ul .news_li .news_link {
    display: block;
  }
  .news_ul .news_li .news_link::before {
    content: "";
    position: absolute;
    top: 50px;
    right: 0;
    width: 6px;
    height: 11px;
    background-image: url(../images/common/arrow_w.svg);
    background-repeat: no-repeat;
    background-size: contain;
  }
  .news_ul .news_li .news_link .date {
    display: block;
    padding: 0 0 8px;
  }
  .news_ul .news_li .news_link .right_wrap {
    display: none;
  }
}