@charset "utf-8";

@import url(//use.fontawesome.com/releases/v5.0.11/css/all.css);

/*--------------------------------------------
  BASE
--------------------------------------------*/
html {
  font-size: 62.5%;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}
body {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro",
    "ヒラギノ角ゴ Pro W3", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "游ゴシック体",
    "YuGothic", Meiryo, "メイリオ", Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-weight: 400;
  font-size: 1.6rem;
  color: #222;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
input,
button,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}
img {
  vertical-align: middle;
}
table {
  width: 100%;
}
a {
  color: #333;
  text-decoration: none;
  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  -moz-transition: all 0.4s;
  transition: all 0.4s;
}

/*  BASE MD  */
@media screen and (max-width: 1199px) {
  html {
    font-size: 0.8vw;
  }
}

/*  BASE SM  */
@media screen and (max-width: 991px) {
  html {
    font-size: 1.3vw;
  }
}

/*  BASE SP  */
@media screen and (max-width: 767px) {
  html {
    font-size: 1.8vw;
  }
  body {
    line-height: 1.5;
  }
}

/*  BASE SS  */
@media screen and (max-width: 575px) {
  html {
    font-size: 2.5vw;
  }
}

/*--------------------------------------------
  WordPress Native Styles
--------------------------------------------*/
strong {
  font-weight: bold;
}
em {
  font-style: italic;
}
blockquote {
  display: block;
  -webkit-margin-before: 1em;
  -webkit-margin-after: 1em;
  -webkit-margin-start: 40px;
  -webkit-margin-end: 40px;
}
img.alignleft {
  margin: 0 auto 0 0;
}
img.aligncenter {
  display: block;
  margin: 0 auto;
}
img.alignright {
  display: block;
  margin: 0 0 0 auto;
}
img[class*="wp-image-"],
img[class*="attachment-"] {
  height: auto;
  max-width: 100%;
}

/*--------------------------------------------
  WordPress ナビゲーション
--------------------------------------------*/
.wp-pagenavi {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 4.5rem;
}
.wp-pagenavi * {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 3.5rem;
  height: 3.5rem;
}
.wp-pagenavi * + * {
  margin-left: 1.5rem;
}
.wp-pagenavi a,
.wp-pagenavi .current {
  color: #1e2480;
  font-size: 1.5rem;
  background: #fff;
  border: 1px solid #1e2480;
  padding: 0.5rem;
  line-height: 1.3;
  transition: 0.4s;
}
.wp-pagenavi a:hover,
.wp-pagenavi a:focus {
  color: #fff;
  background-color: #1e2480;
  opacity: 0.7;
}
.wp-pagenavi .current {
  color: #fff;
  background-color: #1e2480;
}
.wp-pagenavi .nextpostslink,
.wp-pagenavi .previouspostslink {
  color: #1e2480;
  font-size: 1.6rem;
  font-weight: bold;
  background: none;
  border: none;
}

/*  WordPress ナビゲーション SP  */
@media screen and (max-width: 767px) {
  .wp-pagenavi {
    margin-top: 2.5rem;
  }
  .wp-pagenavi * {
    width: 3rem;
    height: 3rem;
  }
  .wp-pagenavi * + * {
    margin-left: 1rem;
  }
}

/*-----------------------------------------------------
  Wordpress EDITOR
------------------------------------------------------*/
.wp_editor * + p,
.wp_editor * + ul,
.wp_editor * + ol,
.wp_editor * + .table_wrap {
  margin-top: 2.4rem;
}
.wp_editor * + h1,
.wp_editor * + h2,
.wp_editor * + h3,
.wp_editor * + h4,
.wp_editor * + h5,
.wp_editor * + h6 {
  margin-top: 4.5rem;
}
.wp_editor h2 {
  position: relative;
  padding: 1.6rem 2rem;
  padding-left: 4.5rem;
  background-color: #e9e9e9;
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.wp_editor h2::before {
  content: "\f111";
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  display: block;
  position: absolute;
  left: 2rem;
  font-size: 1.4rem;
  color: #1e2480;
  line-height: 1.65;
}
.wp_editor h3 {
  padding-bottom: 1rem;
  border-bottom: 1px solid #1e2480;
  font-weight: 500;
  font-size: 1.8rem;
  color: #1e2480;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.wp_editor h4 {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}

.wp_editor img {
  max-width: 100%;
  height: auto;
}

.wp_editor a {
  color: #3094b3;
  word-break: break-all;
}
.wp_editor a:hover,
.wp_editor a:focus {
  opacity: 0.7;
}

.wp_editor ul,
.wp_editor ol {
  padding-left: 3rem;
  line-height: 1.5;
}
.wp_editor ul > li:not(:first-child),
.wp_editor ol > li:not(:first-child) {
  margin-top: 1.5rem;
}
.wp_editor ul > li {
  list-style-type: disc;
}
.wp_editor ol > li {
  list-style-type: decimal;
}

.wp_editor table {
  width: 100%;
}
.wp_editor table tr > th,
.wp_editor table tr > td {
  padding: 1.5rem;
  border: 1px solid #ddd;
}
.wp_editor table tr > th {
  background-color: #a9a9a9;
}

@media screen and (max-width: 991px) {
  .wp_editor h2 {
    padding: 1.2rem 1.5rem;
    padding-left: 4rem;
    font-size: 1.6rem;
  }
  .wp_editor h2::before {
    left: 1.5rem;
    line-height: 1.65;
  }
  .wp_editor h3 {
    font-size: 1.6rem;
  }
  .wp_editor h4 {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .wp_editor * + p,
  .wp_editor * + ul,
  .wp_editor * + ol,
  .wp_editor * + .table_wrap {
    margin-top: 1.5rem;
  }
  .wp_editor * + h1,
  .wp_editor * + h2,
  .wp_editor * + h3,
  .wp_editor * + h4,
  .wp_editor * + h5,
  .wp_editor * + h6 {
    margin-top: 3rem;
  }
  .wp_editor h2 {
    padding-left: 3.6rem;
  }
  .wp_editor h3 {
    padding-bottom: 0.6rem;
  }
  .wp_editor ul > li:not(:first-child),
  .wp_editor ol > li:not(:first-child) {
    margin-top: 1rem;
  }
}

/*--------------------------------------------
  google map
--------------------------------------------*/
.ggmap {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}
.ggmap iframe,
.ggmap object,
.ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*--------------------------------------------
  GLOBAL CSS
--------------------------------------------*/
.cf:after {
  content: "";
  clear: both;
  display: block;
  height: 0;
}
:root .cf::after {
  /* IE9 */
  content: "" \9;
  clear: both\9;
  display: block\9;
  height: 0\9;
}

.over:hover,
.over:focus {
  opacity: 0.7;
}
.ios .over:hover,
.ios .over:active,
.ios .over:link,
.ios .over:visited,
.ios .over::focus {
  opacity: 1;
}
@media screen and (min-width: 992px) {
  .over_tb:hover {
    opacity: 0.7;
  }
  .ios .over_tb:hover,
  .ios .over_tb:active,
  .ios .over_tb:link,
  .ios .over_tb:visited,
  .ios .over_tb::focus {
    opacity: 1;
  }
}

.pe_none {
  pointer-events: none;
}
@media screen and (max-width: 991px) {
  .sp_event {
    color: #25b4e0;
  }
}
@media screen and (min-width: 992px) {
  .sp_event {
    pointer-events: none;
    cursor: default;
  }
}

.wrap_ofi {
  position: relative;
  padding-top: 60%;
  backface-visibility: hidden;
}
.wrap_ofi .ofi {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.ofi {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
}
.ofi.cover {
  object-fit: cover;
  object-position: center center;
  font-family: "object-fit: cover;object-position:center center;";
}
.ofi.contain {
  margin: auto;
  object-fit: contain;
  object-position: center center;
  font-family: "object-fit: contain;object-position:center center;";
}

.wrap {
  white-space: normal !important;
}
@media screen and (max-width: 991px) {
  .wrap.w50r::before,
  .wrap.w40r::before,
  .wrap.w30r::before,
  .wrap.w20r::before,
  .wrap.w10r::before,
  .wrap.w5r::before {
    content: "";
    display: block;
    top: 0;
    left: 0;
    height: 0;
  }
  .wrap.w50r::before {
    width: 50rem;
  }
  .wrap.w40r::before {
    width: 40rem;
  }
  .wrap.w30r::before {
    width: 30rem;
  }
  .wrap.w20r::before {
    width: 20rem;
  }
  .wrap.w10r::before {
    width: 10rem;
  }
  .wrap.w5r::before {
    width: 5rem;
  }
}
.nowrap {
  white-space: nowrap;
}
.table_wrap {
  min-height: 0.01%;
  overflow-x: auto;
}
@media screen and (max-width: 991px) {
  .table_wrap {
    width: 100%;
    margin-bottom: 15px;
    overflow-y: hidden;
    -ms-overflow-style: -ms-autohiding-scrollbar;
    /*border: 1px solid #ddd;*/
  }
  .table_wrap::-webkit-scrollbar {
    height: 0.3rem;
  }
  .table_wrap::-webkit-scrollbar-track {
    background: #ccc;
    border-radius: 1rem;
  }
  .table_wrap::-webkit-scrollbar-thumb {
    border-radius: 1rem;
    background: #1e2480;
  }
  .table_wrap > table {
    margin-bottom: 0;
  }
  .table_wrap > table > thead > tr > th,
  .table_wrap > table > tbody > tr > th,
  .table_wrap > table > tfoot > tr > th,
  .table_wrap > table > thead > tr > td,
  .table_wrap > table > tbody > tr > td,
  .table_wrap > table > tfoot > tr > td {
    white-space: nowrap;
  }

  .sp_table > thead > tr > th,
  .sp_table > tbody > tr > th,
  .sp_table > tfoot > tr > th,
  .sp_table > thead > tr > td,
  .sp_table > tbody > tr > td,
  .sp_table > tfoot > tr > td {
    display: block !important;
    width: 100% !important;
  }
}

.img_responsive {
  display: block;
  max-width: 100%;
  height: auto;
}
.img_full {
  display: block;
  width: 100%;
  height: auto;
}

.center_block {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

.ta_center {
  text-align: center;
}
.ta_left {
  text-align: left;
}
.ta_right {
  text-align: right;
}

.bold {
  font-weight: 700;
}
.bold500 {
  font-weight: 500;
}

.v_hidden {
  visibility: hidden;
}

.white {
  color: #fff;
}
.blue {
  color: #1e2480;
}
.red {
  color: #bc1816;
}

.hr_bl {
  margin-top: 4rem;
  margin-bottom: 4rem;
  border-top: 1px solid #1e2480;
}
.hr_bl.mg0 {
  margin: 0;
}

.bdt_gr {
  border-top: 1px solid #e6e6e6;
}
.bdb_gr {
  border-bottom: 1px solid #e6e6e6;
}

.mgt_md {
  margin-top: 3rem;
}
.mgt_sm {
  margin-top: 1.5rem;
}
.mgl_xs {
  margin-left: 0.8rem;
}
.mgr_xs {
  margin-right: 0.8rem;
}
.mgb_xs {
  margin-bottom: 0.8rem;
}

.w12r {
  width: 12rem;
}
.w14r {
  width: 14rem;
}
.w18r {
  width: 18rem;
}

.ul_deco > li {
  position: relative;
  padding-left: 3rem;
  line-height: 1.5;
}
.ul_deco > li:not(:first-child) {
  margin-top: 1.5rem;
}
.ul_deco.li_mgt_sm > li:not(:first-child) {
  margin-top: 0.5rem;
}
.ul_deco > li > span {
  position: absolute;
  left: 0;
}

.arrow_link > li {
  display: inline-block;
}
.arrow_link > li + li {
  margin-left: 1rem;
}
.arrow_link > li > a {
  position: relative;
  display: block;
  padding: 0.6rem;
  padding-left: 1.2rem;
  font-size: 1.4rem;
  line-height: 1.3;
  letter-spacing: 0.05rem;
}
.arrow_link > li > a:hover {
  text-decoration: underline;
}
.arrow_link > li > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  width: 0.6rem;
  height: 1rem;
  background: url("../Image/common/arrow_r_bl.png") center/cover;
}
.arrow_link.sm > li > a {
  font-size: 1.2rem;
}
.arrow_link > li > a::before {
  width: 0.5rem;
  height: 0.8rem;
}

.italic {
  font-style: italic;
}

.ttl_subleft {
  margin-bottom: 3.5rem;
}
.ttl_subleft > .sub {
  display: inline-block;
  font-weight: 500;
  font-family: "Roboto", sans-serif;
  font-size: 3.6rem;
  line-height: 1.1;
  letter-spacing: 0.1rem;
}
.ttl_subleft > .title {
  margin-left: 1rem;
  display: inline-block;
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
  vertical-align: 0.1rem;
}

.ttl_bg_bd {
  position: relative;
  width: 100%;
  margin-bottom: 4rem;
  padding-left: 4%;
  padding-right: 4%;
  text-align: center;
  overflow: hidden;
}
.ttl_bg_bd.mgb_sm {
  margin-bottom: 2rem;
}
.ttl_bg_bd.mgb0 {
  margin-bottom: 0;
}
.ttl_bg_bd .inr {
  position: relative;
  display: inline-block;
  min-width: 30rem;
  padding-left: 3rem;
  padding-right: 3rem;
}
.ttl_bg_bd .inr::before,
.ttl_bg_bd .inr::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 50vw;
  height: 20px;
  background: url("../Image/common/bd_pat.png");
}
.ttl_bg_bd .inr::before {
  left: 100%;
}
.ttl_bg_bd .inr::after {
  right: 100%;
}
.ttl_bg_bd.bd_none .inr::before,
.ttl_bg_bd.bd_none .inr::after {
  display: none;
}
.ttl_bg_bd .inr .title {
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.ttl_bg_bd .inr .sub {
  font-weight: 500;
  font-family: "Roboto", sans-serif;
  font-size: 4.8rem;
  line-height: 1.1;
  letter-spacing: 0.1rem;
}
.ttl_bg_bd.white .inr::before,
.ttl_bg_bd.white .inr::after {
  background: url("../Image/common/bd_pat_wh.png");
}

.ttl_bdb_ye {
  margin-bottom: 2rem;
  font-weight: 500;
  text-align: center;
  font-size: 4.8rem;
  line-height: 1.3;
  letter-spacing: 0.2rem;
}
.ttl_bdb_ye > span {
  display: inline-block;
  padding-bottom: 0.3rem;
  border-bottom: 0.6rem solid #fad216;
}

.text_catch {
  margin-bottom: 3rem;
  text-align: center;
  font-size: 2.2rem;
  letter-spacing: 0.1rem;
}
.text_catch.mgb0 {
  margin-bottom: 0;
}

.wrap_btn,
.wrap_btn_2col {
  margin-top: 4.5rem;
}
.wrap_btn.mgt_sm,
.wrap_btn_2col.mgt_sm {
  margin-top: 3rem;
}
.wrap_btn.mgt_xs,
.wrap_btn_2col.mgt_xs {
  margin-top: 1rem;
}
.btn_arrow {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 28rem;
  padding: 1.5rem 3.5rem;
  background-color: #11164c;
  text-align: center;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.btn_arrow::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 2rem;
  bottom: 0;
  margin: auto;
  width: 0.6rem;
  height: 1rem;
  background: url("../Image/common/arrow_r_wh.png") center/contain no-repeat;
}
.btn_arrow::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 0;
  background-color: rgba(255, 255, 255, 0.2);
  transition: 0.2s;
}
.btn_arrow:hover::after,
.btn_arrow:focus::after {
  width: 100%;
}
.btn_arrow.i_window {
  padding: 1.5rem 1rem;
}
.btn_arrow.i_window::before {
  display: none;
}
.btn_arrow.i_window > span {
  position: relative;
  display: inline-block;
  padding-right: 1.8rem;
}
.btn_arrow.i_window > span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 1rem;
  height: 1.1rem;
  background: url("../Image/common/icon_window.png") center/contain no-repeat;
}
.btn_clear {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 28rem;
  padding: 1.5rem 3.3rem;
  border: 2px solid #fff;
  text-align: center;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.btn_clear > span {
  position: relative;
  z-index: 1;
  transition: 0.2s;
}
.btn_clear::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  top: 0;
  right: 2rem;
  bottom: 0;
  margin: auto;
  width: 0.6rem;
  height: 1rem;
  background: url("../Image/common/arrow_r_wh.png") center/contain no-repeat;
}
.btn_clear::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 0;
  background-color: #fff;
  transition: 0.2s;
}
.btn_clear:hover::before,
.btn_clear:focus::before {
  background: url("../Image/common/arrow_r_bl.png") center/contain no-repeat;
}
.btn_clear:hover::after,
.btn_clear:focus::after {
  width: 100%;
}
.btn_clear:hover > span,
.btn_clear:focus > span {
  color: #1e2480;
}
.btn_arrow.xs,
.btn_clear.xs {
  max-width: 15rem;
  padding: 1rem 3.3rem;
}
.wrap_btn_2col .btn_arrow,
.wrap_btn_2col .btn_clear,
.btn_arrow.sm,
.btn_clear.sm {
  max-width: 25rem;
}
.wrap_btn_2col > * + * {
  margin-left: 2rem;
}
.btn_arrow.xs.i_window,
.btn_arrow.sm.i_window {
  padding-left: 1rem;
  padding-right: 1rem;
}

.link_arrow {
  position: relative;
  display: inline-block;
  padding: 0 0 0.3rem 1.5rem;
  border-bottom: 1px solid transparent;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.link_arrow::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0.6rem;
  height: 1.25em;
  background: url(../Image/common/arrow_r_bl.png) center/contain no-repeat;
}
.link_arrow:hover,
.link_arrow:focus {
  border-bottom: 1px solid #1e2480;
  opacity: 0.7;
}

.ul_pagenav {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  margin-top: -1.5rem;
  margin-left: -1rem;
  margin-right: -1rem;
}
.ul_pagenav > li {
  margin-top: 1.5rem;
  width: calc(100% / 4 - 0.05rem);
  padding-left: 1rem;
  padding-right: 1rem;
}
.ul_pagenav > li > a {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  height: 100%;
  min-height: 5rem;
  padding: 0.5rem 1.5rem;
  padding-right: 3.5rem;
  border: 1px solid #e9e9e9;
  line-height: 1.3;
}
.ul_pagenav > li > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 1.6rem;
  bottom: 0;
  margin: auto;
  width: 0.9rem;
  height: 1.5rem;
  background: url(../Image/common/arrow_r_bl.png) center/cover;
  transform: rotate(90deg);
  transition: 0.2s;
}
.ul_pagenav > li > a:hover,
.ul_pagenav > li > a:focus {
  background-color: #1e2480;
  border: 1px solid #1e2480;
  color: #fff;
}
.ul_pagenav > li > a:hover::before,
.ul_pagenav > li > a:focus::before {
  background: url(../Image/common/arrow_r_wh.png) center/cover;
}

.ul_pagelink {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  margin-top: -1.5rem;
  margin-left: -1rem;
  margin-right: -1rem;
}
.ul_pagelink > li {
  margin-top: 1.5rem;
  width: calc(100% / 3 - 0.05rem);
  padding-left: 1rem;
  padding-right: 1rem;
}
.ul_pagelink > li > a {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  height: 100%;
  padding: 1rem 1.5rem;
  padding-right: 3.5rem;
  border: 1px solid #e9e9e9;
}
.ul_pagelink > li.active > a {
  background-color: #1e2480;
  border: 1px solid #efefef;
  color: #fff;
}
.ul_pagelink > li.active > a::before,
.ul_pagelink > li.active > a::before {
  background: url(../Image/common/arrow_r_wh.png) center/cover;
}
.ul_pagelink > li > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 1.6rem;
  bottom: 0;
  margin: auto;
  width: 0.9rem;
  height: 1.5rem;
  background: url(../Image/common/arrow_r_bl.png) center/cover;
  transition: 0.2s;
}
.ul_pagelink > li > a:hover,
.ul_pagelink > li > a:focus {
  background-color: #eee;
}

.ul_tab {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  margin-left: -0.2rem;
  margin-right: -0.2rem;
}
.ul_tab > li {
  width: calc(100% / 3 - 0.05rem);
  padding-left: 0.2rem;
  padding-right: 0.2rem;
}
.ul_tab.col5 > li {
  width: 20%;
}
.ul_tab.col4 > li {
  width: 25%;
}
.ul_tab > li > a {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 1rem 0.5rem;
  background-color: #efefef;
  border: 1px solid #e9e9e9;
  border-radius: 0.4rem 0.4rem 0 0;
}
.ul_tab > li > a:hover,
.ul_tab > li > a:focus {
  background-color: #ccc;
}
.ul_tab > li > a.active {
  background-color: #1e2480;
  border: 1px solid #1e2480;
  color: #fff;
  pointer-events: none;
}
.ul_tab + .tab_wrap {
  padding-top: 2rem;
  border-top: 0.2rem solid #1e2480;
}

/* template */
.under_title {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  height: 26rem;
  padding: 2rem 0;
  background-color: #1e2480;
  color: #fff;
}
.under_title > .inner > .title {
  font-weight: 700;
  font-size: 3.4rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.under_title > .inner > .catch {
  margin-top: 2rem;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0.1rem;
}

.under_sec + .under_sec {
  margin-top: 5rem;
}
.box_bd_gr {
  padding: 4.5rem;
  border: 1px solid #e8e7e6;
}
.box_bd_gr.pd_sm {
  padding: 2rem 2.5rem;
}

.box_bl {
  padding: 1.5rem;
  background-color: rgba(30, 36, 128, 0.06);
}
.box_wh {
  padding: 1.5rem;
  background-color: #fff;
}

.under_mgb:not(.mgb0),
.fx_col:not(.mgb0),
.table_wrap:not(.mgb0),
.ul_deco:not(.mgb0),
.box_bd_gr:not(.mgb0) {
  margin-bottom: 3rem;
}
.under_mgb.mgb_sm,
.fx_col.mgb_sm,
.table_wrap.mgb_sm,
.ul_deco.mgb_sm,
.box_bd_gr.mgb_sm {
  margin-bottom: 1.5rem;
}
.under_mgb.mgb_xs,
.fx_col.mgb_xs,
.table_wrap.mgb_xs,
.ul_deco.mgb_xs,
.box_bd_gr.mgb_xs {
  margin-bottom: 0.8rem;
}
.under_mgb:last-child,
.fx_col:last-child,
.table_wrap:last-child,
.ul_deco:last-child,
.box_bd_gr:last-child {
  margin-bottom: 0;
}

.under_mgb a:not([class]) {
  color: #1e2480;
  text-decoration: underline;
}
.under_mgb a:not([class]):hover,
.under_mgb a:not([class]):focus {
  opacity: 0.7;
  text-decoration: none;
}

.under_ttl01 {
  display: block;
  margin-bottom: 4rem;
  padding: 1.6rem 2rem;
  background-color: #1e2480;
  font-weight: 400;
  font-size: 2.4rem;
  color: #fff;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.under_ttl02 {
  display: block;
  margin-bottom: 3rem;
  padding: 1.6rem 2rem;
  background-color: #e9e9e9;
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 768px) {
  .under_ttl02.row2 {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: center;
    min-height: 6rem;
    padding: 0.7rem 2rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .under_ttl02.row2 {
    min-height: 5.5rem;
  }
}
.under_ttl02 > .dot {
  position: relative;
  display: inline-block;
  padding-left: 2.5rem;
}
.under_ttl02 > .dot::before {
  content: "\f111";
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 1.4rem;
  color: #1e2480;
  line-height: 1.65;
}
.under_ttl02 > .arrow {
  position: relative;
  display: block;
  padding-right: 2.5rem;
  font-weight: 500;
}
.under_ttl02 > .arrow::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0.6rem;
  bottom: 0;
  margin: auto;
  width: 0.9rem;
  height: 1.5rem;
  background: url(../Image/common/arrow_r_bl.png) center/cover;
  transition: 0.2s;
}
a.under_ttl02:hover,
a.under_ttl02:focus {
  opacity: 0.7;
}
a.under_ttl02:hover > .arrow::before,
a.under_ttl02:focus > .arrow::before {
  right: 0;
}
.under_ttl03 {
  display: block;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #1e2480;
  font-weight: 500;
  font-size: 1.8rem;
  color: #1e2480;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.under_ttl04 {
  display: block;
  margin-bottom: 1rem;
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.under_ttl04.tx_lg {
  font-size: 2.4rem;
}
.under_ttl01.mgb0,
.under_ttl02.mgb0,
.under_ttl03.mgb0,
.under_ttl04.mgb0 {
  margin-bottom: 0;
}
.under_ttl03.mgb_sm {
  margin-bottom: 1rem;
}

.fx_col {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  margin-left: -1.5rem;
  margin-right: -1.5rem;
}
.fx_col > * {
  padding: 0 1.5rem;
}
.fx_col.left_img > .item:first-child {
  width: 46%;
}
.fx_col.left_img > .item:last-child {
  width: 54%;
}
.fx_col.right_img {
  flex-direction: row-reverse;
}
.fx_col.right_img > .item:first-child {
  width: 46%;
}
.fx_col.right_img > .item:last-child {
  width: 54%;
}
.fx_col.col2 > * {
  width: 50%;
}
.fx_col.col3 > * {
  width: calc(100% / 3);
}
.fx_col.col4 > * {
  width: calc(100% / 4);
}
.fx_col.btn_list > * .btn_arrow {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 100%;
  height: 100%;
}
.fx_col > .item .link_file {
  display: block;
  padding-top: 70%;
  border: 1px solid #e9e9e9;
  overflow: hidden;
}
.fx_col > .item .link_file::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.2);
  opacity: 0;
  transition: 0.4s;
}
.fx_col > .item .link_file::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  right: 1rem;
  bottom: 1rem;
  width: 3rem;
  height: 3rem;
  background: url("../Image/common/icon_scope.png") center/cover no-repeat;
}
.fx_col > .item .link_file img {
  width: calc(100% - 2rem);
  height: calc(100% - 2rem);
  backface-visibility: hidden;
  transition: 0.4s;
}
.fx_col > .item .link_file:hover::before,
.fx_col > .item .link_file:focus::before {
  opacity: 1;
}
.fx_col > .item .link_file:hover img,
.fx_col > .item .link_file:focus img {
  transform: scale(1.1);
}
.as_center {
  -ms-align-self: center;
  align-self: center;
}
.fx_col > .item .text_lg {
  font-size: 2rem;
}

.tbl_gr {
  width: 100%;
}
.tbl_gr tr > th,
.tbl_gr tr > td {
  padding: 1.2rem 1.5rem;
  border: 1px solid #ddd;
  letter-spacing: 0.1rem;
  line-height: 1.5;
}
.tbl_gr tr > th {
  background-color: #f4f4f4;
  font-weight: 500;
  white-space: nowrap;
}
.tbl_gr.col3 > tbody > tr > * {
  width: calc(100% / 3);
}
@media screen and (min-width: 992px) {
  .tbl_gr.tbl_lg tr > th,
  .tbl_gr.tbl_lg tr > td {
    padding: 2rem;
  }
  .tbl_gr.tbl_lg tr > th {
    width: 24rem;
  }
}

.tbl_clear {
  width: 100%;
  letter-spacing: 0.05em;
}
.tbl_clear tr > th,
.tbl_clear tr > td {
  padding: 0.4em 0.5em;
}
.tbl_clear tr > th {
  width: 16rem;
  padding-left: 0;
  font-weight: 500;
  line-height: 1.3;
  vertical-align: top;
  white-space: nowrap;
}
.tbl_clear tr > th > span {
  display: block;
  padding: 0.4em 1em;
  background-color: rgba(30, 36, 128, 0.08);
  text-align: center;
}
.tbl_clear tr > td {
  line-height: 1.5;
}

.term_label {
  line-height: 1;
  letter-spacing: 0.1rem;
}
.term_label > .text {
  display: inline-block;
  margin-top: 0.3rem;
  margin-bottom: 0.3rem;
  padding: 0.8rem 2rem;
  background-color: #222;
  border: 1px solid #222;
  font-size: 1.4rem;
  color: #fff;
}
.term_label > * {
  display: inline-block;
}
.term_label.c_blue > .text {
  background-color: #1e2480;
  border: 1px solid #1e2480;
}
.term_label.c_red > .text {
  background-color: #bc1816;
  border: 1px solid #bc1816;
}
.term_label.c_bd_red > .text {
  background-color: transparent;
  border: 1px solid #bc1816;
  color: #bc1816;
}
.term_label > .text.sm {
  padding: 0.6rem 1.5rem;
  font-size: 1.3rem;
}

@media screen and (max-width: 991px) {
  .tb_ta_left {
    text-align: left;
  }
  .tb_ta_center {
    text-align: center;
  }

  .ttl_bg_bd .inr .sub {
    font-size: 4rem;
  }

  .ttl_bdb_ye {
    font-size: 4rem;
    letter-spacing: 0.2rem;
  }

  .text_catch {
    font-size: 1.8rem;
  }

  .under_title > .inner > .title {
    font-size: 2.8rem;
  }
  .under_title > .inner > .catch {
    font-size: 1.6rem;
  }

  .under_sec {
    font-size: 1.4rem;
    line-height: 1.5;
  }
  .under_sec + .under_sec {
    margin-top: 4rem;
  }
  .box_bd_gr {
    padding: 3rem;
  }
  .box_bd_gr.pd_sm {
    padding: 1.5rem 2rem;
  }
  .under_mgb:not(.mgb0),
  .fx_col:not(.mgb0),
  .table_wrap:not(.mgb0),
  .ul_deco:not(.mgb0),
  .box_bd_gr:not(.mgb0) {
    margin-bottom: 2rem;
  }
  .under_mgb.mgb_sm,
  .fx_col.mgb_sm,
  .table_wrap.mgb_sm,
  .ul_deco.mgb_sm,
  .box_bd_gr.mgb_sm {
    margin-bottom: 1rem;
  }
  .under_mgb.mgb_xs,
  .fx_col.mgb_xs,
  .table_wrap.mgb_xs,
  .ul_deco.mgb_xs,
  .box_bd_gr.mgb_xs {
    margin-bottom: 0.6rem;
  }
  .under_mgb:last-child,
  .fx_col:last-child,
  .table_wrap:last-child,
  .ul_deco:last-child,
  .box_bd_gr:last-child {
    margin-bottom: 0;
  }

  .under_ttl01 {
    margin-bottom: 3rem;
    padding: 1.2rem 1.5rem;
    font-size: 2rem;
  }
  .under_ttl02 {
    margin-bottom: 2rem;
    padding: 1.2rem 1.5rem;
    font-size: 1.6rem;
  }
  .under_ttl03 {
    margin-bottom: 1.5rem;
    font-size: 1.6rem;
  }
  .under_ttl04 {
    margin-bottom: 1.5rem;
    font-size: 1.6rem;
  }
  .under_ttl04.tx_lg {
    font-size: 2rem;
  }

  .fx_col {
    margin-left: -1rem;
    margin-right: -1rem;
  }
  .fx_col > * {
    padding: 0 1rem;
  }

  .fx_col > .item .text_lg {
    font-size: 1.6rem;
  }
  .fx_col.col4 > * {
    width: calc(100% / 2);
  }
  .fx_col.col4 > .item {
    margin-top: 1.5rem;
  }
}

@media screen and (max-width: 767px) {
  .ul_deco > li {
    padding-left: 2.2rem;
  }
  .ul_deco > li:not(:first-child) {
    margin-top: 1rem;
  }
  .ul_deco > li > span {
    position: absolute;
    left: 0;
  }

  .sp_ta_left {
    text-align: left;
  }
  .sp_ta_center {
    text-align: center;
  }

  .ttl_subleft {
    margin-bottom: 2rem;
  }

  .ttl_bg_bd {
    margin-bottom: 2rem;
  }
  .ttl_bg_bd .inr {
    min-width: 22rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  .ttl_bg_bd .inr::before,
  .ttl_bg_bd .inr::after {
    height: 15px;
  }
  .ttl_bg_bd .inr .title {
    font-size: 1.4rem;
  }
  .ttl_bg_bd .inr .sub {
    font-size: 4rem;
  }

  .wrap_btn,
  .wrap_btn_2col {
    margin-top: 3rem;
  }
  .wrap_btn.mgt_sm,
  .wrap_btn_2col.mgt_sm {
    margin-top: 2rem;
  }
  .btn_arrow,
  .btn_clear {
    max-width: 25rem;
    padding: 1.2rem 2.2rem;
    font-size: 1.3rem;
  }
  .btn_arrow::before,
  .btn_clear::before {
    right: 1rem;
  }

  .btn_arrow.xs,
  .btn_clear.xs {
    padding: 1rem 2.2rem;
  }
  .wrap_btn_2col .btn_arrow,
  .wrap_btn_2col .btn_clear,
  .btn_arrow.sm,
  .btn_clear.sm {
    max-width: 21rem;
  }
  .wrap_btn_2col > * + * {
    margin-left: 1rem;
  }

  .ul_pagenav {
    margin-left: -0.5rem;
    margin-right: -0.5rem;
  }
  .ul_pagenav > li {
    width: calc(100% / 2);
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .ul_pagenav > li > a {
    min-height: 4.2rem;
  }
  .ul_pagenav > li > a::before {
    width: 0.7rem;
    height: 1.2rem;
  }

  .ul_pagelink {
    margin-left: -0.5rem;
    margin-right: -0.5rem;
  }
  .ul_pagelink > li {
    width: calc(100% / 2);
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .ul_pagelink > li > a {
    padding-right: 2.5rem;
  }
  .ul_pagelink > li > a::before {
    right: 1rem;
    width: 0.7rem;
    height: 1.2rem;
  }

  .ul_tab {
    margin-left: -0.1rem;
    margin-right: -0.1rem;
  }
  .ul_tab > li {
    padding-left: 0.1rem;
    padding-right: 0.1rem;
  }
  .ul_tab > li > a {
    padding: 1rem 0.5rem 0.8rem;
  }
  .ul_tab + .tab_wrap {
    padding-top: 1.5rem;
  }

  .under_title {
    height: 20rem;
  }
  .under_title > .inner > .title {
    font-size: 2.4rem;
  }
  .under_title > .inner > .catch {
    margin-top: 1rem;
    font-size: 1.4rem;
  }

  .box_bd_gr {
    padding: 6% 5% 7%;
  }
  .box_bd_gr.pd_sm {
    padding: 5%;
  }

  .under_ttl02 > .dot {
    padding-left: 2rem;
  }
  .under_ttl03 {
    padding-bottom: 0.6rem;
  }

  .fx_col.left_img > .item:first-child,
  .fx_col.left_img > .item:last-child,
  .fx_col.right_img > .item:first-child,
  .fx_col.right_img > .item:last-child,
  .fx_col.col2 > *,
  .fx_col.col3 > *,
  .fx_col.col4 > * {
    width: 100%;
  }
  .fx_col > .item + .item {
    margin-top: 2.5rem;
  }
  .fx_col.left_img > .item:last-child {
    margin-top: 1.5rem;
  }

  .tbl_gr tr > th,
  .tbl_gr tr > td {
    padding: 1rem;
  }

  .tbl_clear tr > th,
  .tbl_clear tr > td {
    display: block;
    width: 100%;
    padding: 0.4em 0;
  }
  .tbl_clear tr > th {
    padding-bottom: 0;
  }
}

@media screen and (max-width: 575px) {
  .ss_ta_left {
    text-align: left;
  }
  .ss_ta_center {
    text-align: center;
  }

  .ttl_bdb_ye {
    font-size: 2.8rem;
    letter-spacing: 0.1rem;
  }

  .wrap_btn_2col .btn_arrow,
  .wrap_btn_2col .btn_clear,
  .btn_arrow.sm,
  .btn_clear.sm {
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
  .wrap_btn_2col > * + * {
    margin-top: 1.5rem;
    margin-left: 0;
  }

  .under_ttl02 > .arrow::before {
    width: 0.7rem;
    height: 1.2rem;
  }
}

/*--------------------------------------------
  CONTENTS BOX
--------------------------------------------*/
@media screen and (max-width: 991px) {
  .inner {
    width: 92%;
    margin-left: auto;
    margin-right: auto;
  }

  .box_pd {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .box_pd_sm {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
  .box_pdt0 {
    padding-top: 0;
  }
  .box_pdb0 {
    padding-bottom: 0;
  }

  .under_wrap {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}
@media screen and (min-width: 992px) {
  .inner {
    width: 100%;
    max-width: 1300px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 5rem;
    padding-right: 5rem;
  }
  .inner.lg {
    max-width: 1600px;
  }
  .inner.full {
    max-width: 100%;
  }

  .box_pd {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
  .box_pd_sm {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .box_pdt0 {
    padding-top: 0;
  }
  .box_pdb0 {
    padding-bottom: 0;
  }

  .under_wrap {
    padding-top: 5rem;
    padding-bottom: 8rem;
  }
}

/*--------------------------------------------
  HEADER
--------------------------------------------*/
.header {
  padding-top: 1.5rem;
  padding-bottom: 2.5rem;
}
.header .fx_header {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
}
.header .fx_header .hdr_logo {
  padding-right: 2rem;
  flex-basis: auto;
  width: 100%;
  -ms-flex: 0 1 auto;
}
.header .fx_header .hdr_logo > a {
  display: inline-block;
  padding: 1rem;
  vertical-align: top;
}
.header .fx_header .hdr_logo > a:hover,
.header .fx_header .hdr_logo > a:focus {
  opacity: 0.7;
}
.header .fx_header .hdr_logo > a > img {
  width: 20rem;
  height: auto;
}
.header .fx_header .hdr_link {
  padding-right: 3rem;
  white-space: nowrap;
}
.header .fx_header .hdr_link .arrow_link {
  margin-bottom: 0.5rem;
}
.header .fx_header .hdr_link .icon_link > li {
  display: inline-block;
  font-size: 1.4rem;
}
.header .fx_header .hdr_link .icon_link > li > a {
  position: relative;
  display: block;
  padding: 1rem 3rem 1rem 5rem;
  background-color: #11164c;
  color: #fff;
  letter-spacing: 0.05rem;
  line-height: 1.1;
}
.header .fx_header .hdr_link .icon_link > li > a::before,
.header .fx_header .hdr_link .icon_link > li > button::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 2rem;
  bottom: 0;
  margin: auto;
  width: 2rem;
  height: 2rem;
}
.header .fx_header .hdr_link .icon_link > li:nth-child(1) > a::before {
  background: url("../Image/common/icon_book.png") center/cover;
}
.header .fx_header .hdr_link .icon_link > li:nth-child(2) > a::before {
  background: url("../Image/common/icon_pen.png") center/cover;
}
.header .fx_header .hdr_link .icon_link > li:nth-child(3) > a::before {
  background: url("../Image/common/icon_man.png") center/cover;
}
.header .fx_header .hdr_link .icon_link > li:nth-child(2) {
  position: relative;
  z-index: 1;
  margin-left: -1.3rem;
  margin-right: -0.6rem;
  border-left: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: skewX(-15deg);
  transform: skewX(-15deg);
  -webkit-transform-origin: bottom left;
  transform-origin: bottom left;
}
.header .fx_header .hdr_link .icon_link > li:nth-child(2) > a > span,
.header .fx_header .hdr_link .icon_link > li:nth-child(2) > a::before {
  display: block;
  -webkit-transform: skewX(15deg);
  transform: skewX(15deg);
  -webkit-transform-origin: bottom left;
  transform-origin: bottom left;
}
.header .fx_header .hdr_link .icon_link > li > button {
  position: relative;
  display: block;
  margin-left: -0.1rem;
  padding: 1rem 3rem 1rem 5rem;
  outline: none;
  border: none;
  background-color: #222;
  color: #fff;
  line-height: 1.1;
  letter-spacing: 0.05rem;
}
.header .fx_header .hdr_link .icon_link > li > button::before {
  background: url("../Image/common/icon_search.png") center/cover;
}
.header .fx_header .hdr_link .icon_link > li > button.open::before {
  background: url("../Image/common/icon_close.png") center/cover;
}
.header .fx_header .hdr_link .icon_link > li > a::after,
.header .fx_header .hdr_link .icon_link > li > button::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 0;
  background-color: rgba(255, 255, 255, 0.2);
  transition: 0.2s;
}
.header .fx_header .hdr_link .icon_link > li > a:hover::after,
.header .fx_header .hdr_link .icon_link > li > button:hover::after {
  width: 100%;
}
.header .fx_header .hdr_link .icon_link > li > .box_search {
  display: none;
}
.header .fx_header .hdr_link .icon_link > li > .box_search {
  position: absolute;
  left: 0;
  right: 0;
  padding: 2rem 0 3rem;
  background-color: #f5f5f5;
}
.header .fx_header .hdr_link .icon_link > li > .box_search .form_search {
  margin-left: auto;
}
.form_search {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 35rem;
  border-bottom: 1px solid #cccccc;
}
.form_search > p:first-child {
  width: 100%;
}
.form_search > p:first-child > input {
  border: none;
  outline: none;
  background-color: transparent;
}
.form_search > p:last-child > button {
  padding: 1rem 1.5rem;
  border: none;
  background: none;
  line-height: 1;
}
.form_search > p:last-child > button:hover,
.form_search > p:last-child > button:focus {
  opacity: 0.7;
}
.header .fx_header .hdr_menubtn {
  position: relative;
}
.header .fx_header .hdr_menubtn::before {
  content: "";
  display: block;
  width: 6.5rem;
  height: 0;
}
.header .fx_header .hdr_menubtn .drawer-hamburger {
  position: relative;
  top: auto;
  right: 0;
  z-index: 6;
  box-sizing: border-box;
  width: 6.5rem;
  padding: 2rem 1.8rem 3rem;
  transition: right 0.4s;
}
.drawer-open .header .fx_header .hdr_menubtn .drawer-hamburger {
  position: fixed;
  top: 3rem;
  right: 3rem;
  background-color: #fff;
}
.drawer-hamburger-icon,
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
  background-color: #1e2480;
}
.drawer-hamburger-icon:before {
  top: -0.9rem;
}
.drawer-hamburger-icon:after {
  top: 0.9rem;
}
.drawer-overlay {
  z-index: 2;
}
.drawer-nav {
  z-index: 5;
  width: 50rem;
  background-color: #1e2480;
}
.drawer--right .drawer-nav {
  right: -50rem;
}
.drawer-nav .drawer-menu {
  position: relative;
  padding: 12rem 2rem 6rem;
}
.drawer-nav .drawer-menu .sp_menu {
  opacity: 0;
}
.drawer-open .drawer-nav .drawer-menu .sp_menu {
  opacity: 1;
  transition: 0.4s;
  transition-delay: 0.2s;
}
.drawer-nav .drawer-menu .ul_drawer > li {
  opacity: 0;
  transform: translateX(20px);
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li {
  opacity: 1;
  transform: translateX(0);
  transition: 0.4s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(1) {
  transition-delay: 0.4s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(2) {
  transition-delay: 0.5s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(3) {
  transition-delay: 0.6s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(4) {
  transition-delay: 0.7s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(5) {
  transition-delay: 0.8s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(6) {
  transition-delay: 0.9s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(7) {
  transition-delay: 1s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(8) {
  transition-delay: 1.1s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(9) {
  transition-delay: 1.2s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(10) {
  transition-delay: 1.3s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(11) {
  transition-delay: 1.4s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(12) {
  transition-delay: 1.5s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(13) {
  transition-delay: 1.6s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(14) {
  transition-delay: 1.7s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(15) {
  transition-delay: 1.8s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(16) {
  transition-delay: 1.9s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(17) {
  transition-delay: 2s;
}
.drawer-open .drawer-nav .drawer-menu .ul_drawer > li:nth-child(18) {
  transition-delay: 2.1s;
}
.drawer-nav .drawer-menu .ul_drawer > li + li {
  margin-top: 1rem;
}
.drawer-nav .drawer-menu .ul_drawer > li > a {
  display: block;
  padding: 0.5rem;
  font-weight: 400;
  color: #fff;
  line-height: 1.5;
  letter-spacing: 0.1rem;
}
.drawer-nav .drawer-menu .ul_drawer > li > a:hover,
.drawer-nav .drawer-menu .ul_drawer > li > a:focus {
  text-decoration: underline;
}

.header {
  position: relative;
  z-index: 3;
  margin-right: -2rem;
  padding-right: 2rem;
  background-color: #fff;
}
.mmenu {
  overflow: hidden;
}
body:not(.mm-wrapper_blocking) .mmenu {
  padding-right: 0 !important;
}
.header .fx_header .hdr_menubtn > a {
  display: block;
  position: relative;
  z-index: 6;
  width: 6.5rem;
  padding: 2.5rem 1.8rem;
  transition: right 0.4s;
}
/*.mm-wrapper_opening .header .fx_header .hdr_menubtn > a {
  position: fixed;
  top: 1.5rem;
  right: 3rem;
  background-color: #fff;
}*/
.header .hdr_menubtn > a .b1,
.header .hdr_menubtn > a .b2,
.header .hdr_menubtn > a .b3 {
  width: 100%;
  height: 2px;
  margin: 0 auto;
  -webkit-transition-timing-function: ease-in-out;
  -moz-transition-timing-function: ease-in-out;
  transition-timing-function: ease-in-out;
  -webkit-transition-duration: 0.3s;
  -moz-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: all;
  -moz-transition-property: all;
  transition-property: all;
  background-color: #11164c;
}
.header .hdr_menubtn > a .b2,
.header .hdr_menubtn > a .b3 {
  margin: 6px auto 0;
}
.mm-wrapper_opening .header .hdr_menubtn > a .b1 {
  -webkit-transform: rotate(225deg) translate3d(-4px, -4px, 0);
  -moz-transform: rotate(225deg) translate3d(-4px, -4px, 0);
  -ms-transform: rotate(225deg) translate3d(-4px, -4px, 0);
  transform: rotate(225deg) translate3d(-4px, -4px, 0);
}
.mm-wrapper_opening .header .hdr_menubtn > a .b2 {
  opacity: 0;
  -moz-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "alpha(opacity=0)";
}
.mm-wrapper_opening .header .hdr_menubtn > a .b3 {
  -webkit-transform: rotate(-225deg) translate3d(-7px, 7px, 0);
  -moz-transform: rotate(-225deg) translate3d(-7px, 7px, 0);
  -ms-transform: rotate(-225deg) translate3d(-7px, 7px, 0);
  transform: rotate(-225deg) translate3d(-7px, 7px, 0);
}
.mm-menu_position-bottom.mm-menu_opened ~ .mm-slideout,
.mm-menu_position-front.mm-menu_opened ~ .mm-slideout,
.mm-menu_position-top.mm-menu_opened ~ .mm-slideout {
  z-index: auto;
}
.mm-menu_position-bottom.mm-menu_opened,
.mm-menu_position-front.mm-menu_opened,
.mm-menu_position-top.mm-menu_opened {
  z-index: 3;
}
.mm-menu_position-bottom.mm-menu_opened ~ .mm-wrapper__blocker,
.mm-menu_position-front.mm-menu_opened ~ .mm-wrapper__blocker,
.mm-menu_position-top.mm-menu_opened ~ .mm-wrapper__blocker {
  z-index: 2;
}
#sp_menu {
  display: none;
}
.mm-wrapper #sp_menu {
  display: block;
  padding-top: 12rem;
}
.mm-wrapper #sp_menu .mm-panels {
  height: calc(100% - 5rem);
}
.mm-wrapper #sp_menu .mm-panels .mm-panel {
  padding: 0 1.5rem 2rem;
}
.mm-wrapper #sp_menu,
.mm-wrapper #sp_menu .mm-navbar,
.mm-wrapper #sp_menu .mm-panel,
.mm-wrapper #sp_menu .mm-panels,
.mm-wrapper #sp_menu .mm-listitem {
  background-color: #11164c;
  border-color: #fff;
  color: #fff;
}
.mm-wrapper #sp_menu .mm-btn_next:after,
.mm-wrapper #sp_menu .mm-btn_prev:before {
  border-color: #fff;
}
.mm-wrapper #sp_menu .mm-navbars_top {
  border-bottom: none;
}
.mm-wrapper #sp_menu .mm-panels {
  border-top: 1px solid #fff;
}
.mm-menu .mm-navbar__title {
  display: block;
  padding: 0 4rem;
  text-align: center;
  line-height: 44px;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}
.mm-wrapper #sp_menu .mm-listitem__text {
  padding: 1.8rem;
  line-height: 1;
}
.mm-listitem_selected > .mm-listitem__text {
  background: initial;
}
.mm-wrapper #sp_menu .mm-listitem a:hover,
.mm-wrapper #sp_menu .mm-listitem a:focus {
  opacity: 0.7;
}
.mm-wrapper #sp_menu .mm-navbars_top .mm-navbar:nth-child(1),
.mm-wrapper #sp_menu .mm-navbars_top .mm-navbar:nth-child(2),
.mm-wrapper #sp_menu .mm-panels {
  opacity: 0;
  min-height: 0;
}

.sp_formbtn {
  padding: 0 0 1rem;
  /*border-top: 1px solid #eee;*/
}
.sp_formbtn .inner > ul {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
}
.sp_formbtn .inner > ul > li {
  width: calc((100% - 2px) / 3);
  text-align: center;
}
.sp_formbtn .inner > ul > li > a {
  display: block;
  padding: 1rem;
  background-color: #1e2480;
  color: #fff;
  line-height: 1;
  letter-spacing: 0.1rem;
}
.sp_formbtn .inner > ul > li:last-child > a {
  background-color: #222;
}
.sp_formbtn .inner > ul > li > a > span {
  position: relative;
  display: inline-block;
  padding-left: 2.2rem;
}
.sp_formbtn .inner > ul > li > a > span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  width: 2rem;
  height: 2rem;
}
.sp_formbtn .inner > ul > li:nth-child(1) > a > span::before {
  background: url(../Image/common/icon_book.png) center/cover;
}
.sp_formbtn .inner > ul > li:nth-child(2) > a > span::before {
  background: url(../Image/common/icon_pen.png) center/cover;
}
.sp_formbtn .inner > ul > li:nth-child(3) > a > span::before {
  background: url(../Image/common/icon_man.png) center/cover;
}

@media screen and (min-width: 992px) {
  .mm-menu_fullscreen {
    width: 50rem;
  }
  .mm-wrapper_opening.mm-wrapper #sp_menu .mm-navbars_top .mm-navbar:nth-child(2) {
    opacity: 1;
    transition: 0.4s;
    transition-delay: 0.3s;
  }
  .mm-wrapper_opening.mm-wrapper #sp_menu .mm-panels {
    opacity: 1;
    transition: 0.4s;
    transition-delay: 0.6s;
  }
}
@media screen and (max-width: 991px) {
  .header {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }
  .header .fx_header .hdr_link {
    display: none;
  }
  .header .fx_header .hdr_menubtn::before {
    width: 4.8rem;
  }
  .header .fx_header .hdr_menubtn .drawer-hamburger {
    width: 4.8rem;
    padding: 1rem 1rem 2rem;
  }
  .drawer-open .header .fx_header .hdr_menubtn .drawer-hamburger {
    top: 1rem;
    right: 1.5rem;
  }
  .drawer-nav {
    width: 50%;
  }
  .drawer--right .drawer-nav {
    right: -50%;
  }
  .drawer-nav .drawer-menu {
    padding: 8rem 2rem 6rem;
  }
  .drawer-nav .drawer-menu .form_search {
    margin-bottom: 4rem;
    max-width: 100%;
    background-color: #fff;
  }
  .drawer-nav .drawer-menu .icon_btn {
    margin-bottom: 4rem;
  }
  .drawer-nav .drawer-menu .icon_btn > li + li {
    margin-top: 1rem;
  }
  .drawer-nav .drawer-menu .icon_btn > li > a {
    position: relative;
    display: block;
    padding: 1.2rem 3rem 1.2rem 5rem;
    border: 0.1rem solid #fff;
    background-color: #1e2480;
    color: #fff;
    letter-spacing: 0.05rem;
    line-height: 1.1;
  }
  .drawer-nav .drawer-menu .icon_btn > li > a:hover,
  .drawer-nav .drawer-menu .icon_btn > li > a:focus {
    background-color: rgba(255, 255, 255, 0.2);
  }
  .drawer-nav .drawer-menu .icon_btn > li > a::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 2rem;
    bottom: 0;
    margin: auto;
    width: 2rem;
    height: 2rem;
  }
  .drawer-nav .drawer-menu .icon_btn > li:nth-child(1) > a::before {
    background: url("../Image/common/icon_book.png") center/cover;
  }
  .drawer-nav .drawer-menu .icon_btn > li:nth-child(2) > a::before {
    background: url("../Image/common/icon_pen.png") center/cover;
  }
  .drawer-nav .drawer-menu .icon_btn > li:nth-child(3) > a::before {
    background: url("../Image/common/icon_man.png") center/cover;
  }

  .header .fx_header .hdr_menubtn > a::before {
    width: 4.8rem;
  }
  .header .fx_header .hdr_menubtn > a {
    width: 4.8rem;
    padding: 1.5rem 1rem 1.5rem;
  }

  .mm-menu_fullscreen {
    width: 100%;
    max-width: 50rem;
  }
  .mm-wrapper #sp_menu {
    padding-top: 6.5rem;
  }
  .mm-navbars_top .tb_menu {
    width: 100%;
    padding: 1.5rem;
  }
  .mm-navbars_top .tb_menu .form_search {
    max-width: 100%;
    /*margin-bottom: 1.5rem;*/
    background-color: #fff;
  }
  .mm-navbars_top .tb_menu .icon_btn {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
  }
  .mm-navbars_top .tb_menu .icon_btn > li {
    width: calc((100% - 2rem) / 3);
  }
  .mm-navbars_top .tb_menu .icon_btn > li > a {
    position: relative;
    display: block;
    height: 100%;
    padding: 3rem 0.5rem 1rem;
    border: 0.1rem solid #fff;
    background-color: #1e2480;
    text-align: center;
    font-size: 1.4rem;
    color: #fff;
    letter-spacing: 0.05rem;
    line-height: 1.1;
  }
  .mm-navbars_top .tb_menu .icon_btn > li > a:hover,
  .mm-navbars_top .tb_menu .icon_btn > li > a:focus {
    background-color: rgba(255, 255, 255, 0.2);
  }
  .mm-navbars_top .tb_menu .icon_btn > li > a::before {
    content: "";
    display: block;
    position: absolute;
    top: 0.8rem;
    left: 0;
    right: 0;
    margin: auto;
    width: 2rem;
    height: 2rem;
  }
  .mm-navbars_top .tb_menu .icon_btn > li:nth-child(1) > a::before {
    background: url("../Image/common/icon_book.png") center/cover;
  }
  .mm-navbars_top .tb_menu .icon_btn > li:nth-child(2) > a::before {
    background: url("../Image/common/icon_pen.png") center/cover;
  }
  .mm-navbars_top .tb_menu .icon_btn > li:nth-child(3) > a::before {
    background: url("../Image/common/icon_man.png") center/cover;
  }
  .mm-wrapper #sp_menu .mm-panels {
    height: calc(100% - 12rem);
  }
  .mm-wrapper_opening.mm-wrapper #sp_menu .mm-navbars_top .mm-navbar:nth-child(1) {
    opacity: 1;
    transition: 0.4s;
    transition-delay: 0.3s;
  }
  .mm-wrapper_opening.mm-wrapper #sp_menu .mm-navbars_top .mm-navbar:nth-child(2) {
    opacity: 1;
    transition: 0.4s;
    transition-delay: 0.6s;
  }
  .mm-wrapper_opening.mm-wrapper #sp_menu .mm-panels {
    opacity: 1;
    transition: 0.4s;
    transition-delay: 1s;
  }
}

@media screen and (max-width: 767px) {
  .drawer-nav {
    width: 100%;
  }
  .drawer--right .drawer-nav {
    right: -100%;
  }

  .mm-menu_fullscreen {
    width: 85%;
  }
}

@media screen and (max-width: 575px) {
  .sp_formbtn .inner > ul > li > a {
    padding: 0.8rem 0.5rem;
    font-size: 1.4rem;
    letter-spacing: 0;
  }
  .sp_formbtn .inner > ul > li > a > span {
    padding-left: 1.7rem;
  }
  .sp_formbtn .inner > ul > li > a > span::before {
    width: 1.5rem;
    height: 1.5rem;
  }
}

/*--------------------------------------------
  FOOTER
--------------------------------------------*/
.footer .ftr_row01 .catch {
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.footer .ftr_row01 .logo {
  margin-top: 3rem;
  margin-bottom: 2rem;
  text-align: center;
}
.footer .ftr_row01 .logo > a {
  display: inline-block;
  padding: 0.5rem;
}
.footer .ftr_row01 .logo > a:hover,
.footer .ftr_row01 .logo > a:focus {
  opacity: 0.7;
}
.footer .ftr_row01 .logo > a > img {
  width: 20rem;
  height: auto;
}
.footer .ftr_row01 .arrow_link {
  margin-top: 1rem;
  max-width: 72rem;
  margin-left: auto;
  margin-right: auto;
}
.footer .ftr_row01 .arrow_link + .arrow_link {
  margin-top: 2rem;
}
.footer .ftr_row01 .arrow_link > li + li {
  margin-left: 1.5rem;
}
.footer .ftr_row02 {
  background-color: #1e2480;
}
.footer .ftr_row02 .fx_foot {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.footer .ftr_row02 .fx_foot .conts {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: calc(100% - 5rem);
  padding: 0.8rem 5rem 0.8rem 0;
}
.footer .ftr_row02 .fx_foot .conts .link > li {
  display: inline-block;
}
.footer .ftr_row02 .fx_foot .conts .link > li + li {
  margin-left: 2rem;
}
.footer .ftr_row02 .fx_foot .conts .link > li > a {
  display: block;
  font-weight: 400;
  font-size: 1.4rem;
  color: #fff;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.footer .ftr_row02 .fx_foot .conts .link > li > a:hover {
  text-decoration: underline;
}
.footer .ftr_row02 .fx_foot .conts .copyright {
  font-weight: 400;
  font-family: "Roboto", sans-serif;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1.3;
  letter-spacing: 0.1rem;
}
.footer .ftr_row02 .fx_foot .pagetop {
  width: 5rem;
}
.footer .ftr_row02 .fx_foot .pagetop > a {
  position: relative;
  display: block;
  height: 100%;
  min-height: 4rem;
  background-color: #fff;
}
.footer .ftr_row02 .fx_foot .pagetop > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 1.2rem;
  height: 0.8rem;
  background: url("../Image/common/arrow_t_bl.png") center/1.2rem 0.8rem no-repeat;
  transition: 0.4s;
}
.footer .ftr_row02 .fx_foot .pagetop > a:hover,
.footer .ftr_row02 .fx_foot .pagetop > a:focus {
  background-color: #fad216;
}

@media screen and (max-width: 991px) {
  .footer .ftr_row02 .fx_foot .conts {
    display: block;
  }
  .footer .ftr_row02 .fx_foot .conts .link {
    margin-bottom: 0.5rem;
  }
}

@media screen and (max-width: 767px) {
  .footer .ftr_row02 .fx_foot {
    align-items: center;
  }
  .footer .ftr_row02 .fx_foot .conts {
    padding-right: 2rem;
  }
  .footer .ftr_row02 .fx_foot .conts .link {
    display: none;
  }
  .footer .ftr_row02 .fx_foot .conts .copyright {
    font-size: 1.2rem;
    letter-spacing: 0;
  }
}
@media screen and (max-width: 575px) {
  .footer .ftr_row01 .catch {
    font-size: 2.6rem;
  }
}

/*--------------------------------------------
  breadcrumbs
--------------------------------------------*/
.wrap_breadcrumbs {
  padding: 0.5rem 0;
  border-bottom: 1px solid #e6e6e6;
}
.wrap_breadcrumbs .breadcrumbs {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  padding: 0.7rem 0;
}
.wrap_breadcrumbs .breadcrumbs > li {
  position: relative;
}
.wrap_breadcrumbs .breadcrumbs > li > a,
.wrap_breadcrumbs .breadcrumbs > li > span {
  display: block;
  padding: 0.5rem 1.5rem;
  font-size: 1.4rem;
  line-height: 1.3;
}
.wrap_breadcrumbs .breadcrumbs > li:first-child > * {
  padding-left: 0;
}
.wrap_breadcrumbs .breadcrumbs > li + li::before {
  content: "\03e";
  display: block;
  position: absolute;
  top: 0;
  left: -0.2em;
  bottom: 0;
  margin: auto;
}
.wrap_breadcrumbs .breadcrumbs > li > a {
  color: #1e2480;
  text-decoration: underline;
}
.wrap_breadcrumbs .breadcrumbs > li > a:hover,
.wrap_breadcrumbs .breadcrumbs > li > a:focus {
  color: #11164c;
  text-decoration: none;
}
.wrap_breadcrumbs .breadcrumbs > li:last-child > a {
  color: #222;
  text-decoration: none;
  pointer-events: none;
}

.wrap_breadcrumbs .breadcrumbs {
  min-height: 0.01%;
  overflow-x: auto;
}
@media screen and (max-width: 991px) {
  .wrap_breadcrumbs .breadcrumbs {
    flex-wrap: nowrap;
    width: 100%;
    overflow-y: hidden;
    -ms-overflow-style: -ms-autohiding-scrollbar;
    white-space: nowrap;
  }
  .wrap_breadcrumbs .breadcrumbs::-webkit-scrollbar {
    height: 0.6rem;
  }
  .wrap_breadcrumbs .breadcrumbs::-webkit-scrollbar-track {
    background: #ccc;
    border-radius: 1em;
  }
  .wrap_breadcrumbs .breadcrumbs::-webkit-scrollbar-thumb {
    border-radius: 1em;
    background: #1e2480;
  }
}

/*--------------------------------------------
  ANIMATION
--------------------------------------------*/
.show_left {
  position: relative;
  transform: scaleX(0);
  transition: transform 0.4s cubic-bezier(0.77, 0, 0.175, 1) 0.2s;
  transform-origin: left center;
  backface-visibility: hidden;
}
.show_left.p_ab {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.show_left::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 2;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  background-color: #11164c;
  transition: width 0.6s cubic-bezier(0.77, 0, 0.175, 1) 0.6s;
  backface-visibility: hidden;
}
.show_left.black::before {
  background-color: #222;
}
.show_left.scrolled {
  transform: scaleX(1);
}
.show_left.scrolled::before {
  width: 0%;
}

.fade_left {
  transform: translateX(-5rem);
  transition: 0.8s ease-out;
  opacity: 0;
}
.fade_right {
  transform: translateX(5rem);
  transition: 0.8s ease-out;
  opacity: 0;
}
.fade_left.scrolled,
.fade_right.scrolled {
  transform: translateX(0);
  opacity: 1;
}

.fade_bottom {
  transform: translateY(5rem);
  transition: 0.8s ease-out;
  opacity: 0;
}
.fade_bottom.scrolled {
  transform: translateY(0);
  opacity: 1;
}

.highlight {
  display: inline-block;
  position: relative;
  z-index: 1;
}
.highlight::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 20%;
  background-color: #fad216;
}
.highlight.js_show::before {
  width: 0;
  transition: width 0.8s ease-in-out 0.2s;
}
.highlight.js_show.scrolled::before {
  width: 100%;
}

.bg_ye {
  padding: 0 0.3rem;
  background-color: #fad216;
}
.bg_ye.js_show {
  padding: 0 0.3rem;
  background-color: transparent;
  background-image: -webkit-linear-gradient(left, transparent 50%, #fad216 50%);
  background-image: -moz-linear-gradient(left, transparent 50%, #fad216 50%);
  background-image: -ms-linear-gradient(left, transparent 50%, #fad216 50%);
  background-image: -o-linear-gradient(left, transparent 50%, #fad216 50%);
  background-image: linear-gradient(left, transparent 50%, #fad216 50%);
  background-repeat: repeat-x;
  background-size: 200% 100%;
  background-position: 0;
  transition: 0.8s ease-in 0.2s;
}
.bg_ye.js_show.scrolled {
  background-position: -100% 0;
}
