@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Raleway:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500&display=swap");
body.drawer-active,
body.no-scroll {
  overflow: hidden;
}

.pc {display: block;}
.sp {display: none;}
.br-pc {display:block;}
.br-sp {display:none;}

@media (max-width: 768px) {
  .pc {display: none;}
  .sp {display: block;}
  .br-pc {display:none;}
  .br-sp {display:block;}
}

.bt {
  display: block;
  text-align: center;
  position: relative;
  z-index: 1;
}


.bt a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent: -999px;
  z-index: 2;
}

.bt a:hover {
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
  -moz-opacity: 0.7;
  -khtml-opacity: 0.7;
  opacity: 0.7;
  zoom: 1;
  transition: all .9s;
}

#site-header {
  position: relative;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 9999;
  width: 100%;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  height: 120px;
  background-color: #fff;
  padding-left: 37px;
  overflow: hidden;
  /*============================
  #drawer_nav
  ============================*/
}
@media screen and (max-width: 768px) {
  #site-header {
    padding-left: 20px;
    height: 60px;
    overflow: visible;
  }
}
#site-header .header-wrap {
  width: 100%;
  margin: auto;
  position: relative;
  z-index: -10;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  /*============================
  .header-menu
  ============================*/
}
@media screen and (max-width: 768px) {
  #site-header .header-wrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
#site-header .header-wrap #site-logo {
  width: 172px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 172px;
          flex: 0 0 172px;
  margin-top: 19px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  #site-header .header-wrap #site-logo {
    width: auto;
    height: 60px;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 152px;
            flex: 0 0 152px;
    margin-top: 0;
    padding-top: 5px;
  }
  #site-header .header-wrap #site-logo img {
    display: block;
    width: auto;
    height: 50px;
  }
}
#site-header .header-wrap .header-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding-right: 22px;
  margin-top: 9px;
  /*============================
  #global_nav
  ============================*/
}
#site-header .header-wrap .header-menu #global_nav {
  margin-right: 90px;
  position: relative;
}
@media screen and (max-width: 1200px) {
  #site-header .header-wrap .header-menu #global_nav {
    margin-right: 2em;
  }
}
@media screen and (max-width: 970px) {
  #site-header .header-wrap .header-menu #global_nav {
    display: none !important;
  }
}
#site-header .header-wrap .header-menu #global_nav > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2em;
}
#site-header .header-wrap .header-menu #global_nav > ul > li {
  white-space: nowrap;
  font-size: 14px;
  letter-spacing: 0.06em;
  line-height: 1.3;
  color: #0a0a0a;
  position: relative;
  z-index: 999;
}
#site-header .header-wrap .header-menu #global_nav > ul > li > a {
  color: #0A0A0A;
  text-decoration: none;
  display: block;
}
#site-header .header-wrap .header-menu #global_nav > ul .drop {
  cursor: pointer;
}
#site-header .header-wrap .header-menu #global_nav > ul .active a {
  color: #cc0000 !important;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub {
  display: none;
  background: #fff;
  width: 100%;
  position: fixed;
  z-index: -10;
  left: 0;
  top: 120px;
  color: #0A0A0A;
  padding: 45px 30px 30px;
  max-height: 100vh;
  overflow-y: scroll;
  /*IE, Edge*/
  -ms-overflow-style: none;
  /*Firefox*/
  scrollbar-width: none;
  /*Chrome, Safari*/
}
#site-header .header-wrap .header-menu #global_nav > ul .sub::-webkit-scrollbar {
  display: none;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub a {
  color: #0A0A0A;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 3.33%;
  max-width: 846px;
  margin: auto;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li {
  width: 30%;
  margin-bottom: 30px;
  font-size: 14px;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li a {
  color: #0A0A0A;
  text-decoration: none;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li a figure {
  padding-top: 1em;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li a figure img {
  border-radius: 5px;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li a.button {
  background: #FAE1CD;
  color: #000;
  text-align: center;
  padding: 10px;
  border-radius: 4px;
  display: block;
  letter-spacing: 0.04em;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li a.button--outgoing {
  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;
  padding-left: 1em;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li a.button--outgoing:after {
  content: "";
  width: 1em;
  height: 1em;
  background: url(../img/common/icon-outgoing.svg) center center/contain no-repeat;
  margin-left: 0.5em;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li.jus {
  width: 63.33%;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li.jus ul {
  gap: 5%;
}
#site-header .header-wrap .header-menu #global_nav > ul .sub ul li.jus ul li {
  width: 45%;
  margin-bottom: 30px;
}
#site-header .header-wrap .header-menu .entry_btn {
  margin-right: 37px;
}
@media screen and (max-width: 970px) {
  #site-header .header-wrap .header-menu .entry_btn {
    display: none;
  }
}
#site-header .header-wrap .header-menu .entry_btn ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 320px;
  /* gap: 4px; */
}
#site-header .header-wrap .header-menu .entry_btn ul li {
  /* font-family: "Raleway", sans-serif !important; */
  font-weight: 400;
  font-size: 14px;
  /* letter-spacing: 0.06em; */
  line-height: 1;
  flex-basis: 159px;
  margin-bottom: 2px;
}
#site-header .header-wrap .header-menu .entry_btn ul li a {
  display: block;
  padding: 0 1em;
  background-color: #cc0000;
  color: #fff;
  text-decoration: none;
  text-align: center;
  height: 50px;
  border-radius: 0;
  padding: 20px 0 0 0;
}
#site-header .header-wrap .header-menu .entry_btn ul li:nth-of-type(2) a {
  background: #C30110;
}

#site-header .header-wrap .header-menu .entry_btn ul li:nth-of-type(3) {
  margin-bottom: 0;
}

#site-header .header-wrap .header-menu .entry_btn ul li:nth-of-type(4) {
  margin-bottom: 0;
  line-height: 1.2;
}
#site-header .header-wrap .header-menu .entry_btn ul li:last-child a{
  padding: 10px 0 0 0;
}

#site-header #drawer_nav {
  display: block;
  position: fixed;
  width: 100%;
  height: 100%;
  right: -100%;
  top: 0;
  -webkit-transition: 0.5s cubic-bezier(0.32, 0, 0.67, 0);
  transition: 0.5s cubic-bezier(0.32, 0, 0.67, 0);
  background: #FFF8F2;
  overflow-y: scroll;
  /*IE, Edge*/
  -ms-overflow-style: none;
  /*Firefox*/
  scrollbar-width: none;
  /*Chrome, Safari*/
}
#site-header #drawer_nav::-webkit-scrollbar {
  display: none;
}
@media screen and (max-width: 768px) {
  #site-header #drawer_nav {
    display: block;
  }
}
#site-header #drawer_nav.open {
  display: block;
  right: 0;
}
#site-header #drawer_nav .drawer_nav_wrap {
  max-width: 1640px;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
  padding: 180px 30px 30px;
}

#site-header #drawer_nav .drawer_nav_entry {
  margin: 80px auto 20px;
  max-width: 1280px;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
  padding: 100px 30px 30px;
}
#site-header #drawer_nav .drawer_nav_entry ul {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin: 0 auto;
}
#site-header #drawer_nav .drawer_nav_entry ul li {
    /* flex-basis: 24%; */
  border-radius: 2px;
  padding: 15px 20px;
  font-size: 14px;
  font-weight: 400;
  color: #0A0A0A;
  background-color: #FAE1CD;
  white-space: nowrap;
}
#site-header #drawer_nav .drawer_nav_entry ul li a {
  display: block;
  height: 100%;
  width: 100%
}
@media screen and (max-width: 768px) {
  #site-header #drawer_nav .drawer_nav_wrap {
    display: block;
    padding: 20vw 30px 5vw;
  }

  #site-header #drawer_nav .drawer_nav_entry {
    margin: 0 auto 4vw;
    max-width: 80vw;
    margin: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 0;
    padding: 0 0 10vw;
  }
  #site-header #drawer_nav .drawer_nav_entry ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
    margin: 0 auto;
  }
  #site-header #drawer_nav .drawer_nav_entry ul li {
    flex-basis: 80vw;
    border-radius: 2px;
    padding: 15px 20px;
    font-size: 14px;
    font-weight: 400;
    color: #0A0A0A;
    background-color: #FAE1CD;
    white-space: nowrap;
    margin-bottom: 1.5vw;
  }
  #site-header #drawer_nav .drawer_nav_entry ul li a {
    display: block;
    height: 100%;
    width: 100%
  }

}
#site-header #drawer_nav .drawer_nav_wrap > div {
  color: #0a0a0a;
}
@media screen and (max-width: 768px) {
  #site-header #drawer_nav .drawer_nav_wrap > div {
    margin-bottom: 2em;
  }
}
#site-header #drawer_nav .drawer_nav_wrap > div h2 {
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.4444444444;
  text-align: left;
  color: #cc0000;
  border-bottom: 1px solid #cc0000;
  padding-bottom: 9px;
  margin-bottom: 1em;
}
#site-header #drawer_nav .drawer_nav_wrap > div ul li {
  font-size: 14px;
  letter-spacing: 0.02em;
  line-height: 2.3;
}
#site-header #drawer_nav .drawer_nav_wrap > div ul li a {
  color: #0a0a0a;
  text-decoration: none;
}
#site-header #drawer_nav .drawer_nav_wrap > div ul li a.outgoing {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#site-header #drawer_nav .drawer_nav_wrap > div ul li a.outgoing:after {
  content: "";
  width: 1em;
  height: 1em;
  margin-left: 0.5em;
  background: url(../img/common/icon-outgoing.svg) center center/contain no-repeat;
}
#site-header #drawer_nav .drawer_nav_wrap > div hr {
  border: none;
  border-top: 1px solid #6C6966;
  margin: 1.5em 0;
  height: 1px;
}
#site-header #drawer_nav .drawer_nav_wrap > div h3 {
  font-size: 12px;
  font-weight: normal;
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-bottom: 1em;
}
#site-header #drawer_nav .drawer_nav_wrap > div h3 + ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#site-header #drawer_nav .drawer_nav_wrap > div h3 + ul li {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 50%;
          flex: 0 0 50%;
  padding-left: 1em;
}
#site-header #drawer_nav .drawer_nav_wrap > div:nth-of-type(1) {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 16%;
          flex: 0 0 16%;
}
#site-header #drawer_nav .drawer_nav_wrap > div:nth-of-type(2) {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 20%;
          flex: 0 0 20%;
}
#site-header #drawer_nav .drawer_nav_wrap > div:nth-of-type(3) {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 16%;
          flex: 0 0 16%;
}
#site-header #drawer_nav .drawer_nav_wrap > div:nth-of-type(4) {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 20%;
          flex: 0 0 20%;
}
#site-header #drawer_nav .drawer_nav_wrap > div:nth-of-type(5) {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 16%;
          flex: 0 0 16%;
}
#site-header #drawer_nav .entry_btn ul {
  display: block;
  position: absolute;
  right: 30px;
  bottom: 40px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  #site-header #drawer_nav .entry_btn ul {
    top: 90px;
    left: 0;
    right: 0;
    bottom: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 10px;
    margin-bottom: 20px;
  }
}
#site-header #drawer_nav .entry_btn ul li {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0.06em;
  line-height: 1;
  margin-top: 12px;
}
#site-header #drawer_nav .entry_btn ul li a {
  display: block;
  line-height: 42px;
  padding: 0 1em;
  background-color: red;
  color: #fff;
  text-decoration: none;
  text-align: center;
  width: 96px;
  height: 40px;
  border-radius: 2px;
  background: #e60012;
}
#site-header #drawer_nav .entry_btn ul li:nth-of-type(2) a {
  background: #C30110;
}
#site-header .menu-btn {
  margin: 0;
  padding: 0;
  position: relative;
  width: 40px;
  height: 40px;
  text-align: center;
  cursor: pointer;
  z-index: 9;
}
@media screen and (max-width: 768px) {
  #site-header .menu-btn {
    top: 0;
  }
}
#site-header .menu-btn div {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 35px;
  height: 16px;
}
#site-header .menu-btn div i {
  display: block;
  width: 100%;
  height: 1px;
  background-color: #000;
  position: absolute;
  left: 0;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
#site-header .menu-btn div i:nth-of-type(1) {
  top: 0;
}
#site-header .menu-btn div i:nth-of-type(2) {
  top: calc(50% - .5px);
}
#site-header .menu-btn div i:nth-of-type(3) {
  bottom: 0;
}
#site-header .menu-btn.active div i {
  top: 50% !important;
  left: 50% !important;
  background-color: #000;
}
#site-header .menu-btn.active div i:nth-of-type(1) {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
#site-header .menu-btn.active div i:nth-of-type(3) {
  -webkit-transform: scale(0);
          transform: scale(0);
}
#site-header .menu-btn.active div i:nth-of-type(2) {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}

#site-header.active #global_nav ul li a {
  color: #0A0A0A !important;
  z-index: 1;
}
#site-header.active .menu-btn i {
  background-color: #0A0A0A !important;
}

body.drawer-active #global_nav ul li a {
  display: none;
}
body.drawer-active .menu-btn i {
  background-color: #0A0A0A !important;
}

/*============================
#site-footer
============================*/
#site-footer {
  position: relative;
  z-index: 99;
  padding: 70px 0 0;
  background-color: #5C5C5C;
  /*============================
  #joinus
  ============================*/
}
#site-footer #joinus {
  text-align: center;
  color: #fff;
  padding: 130px 0 44px;
  overflow: hidden;
  position: relative;
  margin-bottom: 60px;
  background: url(../img/common/jus_bg.jpg) no-repeat center center;
  background-size: cover;
}
#site-footer #joinus h2 {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-weight: 300;
  font-size: 57px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #fff;
  margin-bottom: 44px;
  position: relative;
}
#site-footer #joinus ul {
  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;
  gap: 10px;
  position: relative;
}
@media screen and (max-width: 768px) {

  #site-footer #joinus ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;

    gap: 0;
    margin: 0 auto;
  }

  #site-footer #joinus ul li a {
    flex-basis: 60vw!important;
    color: #fff;
    text-decoration: none;
    width: 60vw!important;
    padding: 0 1.5vw;
    height: 5vw;
    font-size: 3.33vw!important;
    margin-bottom: 2.5vw;
    line-height: 46px;
    border-radius: 23px;
    background: #e60012;
    text-align: center;
  }

}

#site-footer #joinus ul li a {
  display: block;
  color: #fff;
  text-decoration: none;
  width: auto;
  padding: 0 20px;
  height: 46px;
  font-size: 14px;
  line-height: 46px;
  border-radius: 23px;
  background: #e60012;
}
#site-footer footer {
  background-color: #535353;
}
#site-footer footer .footer_menu {
  color: #fff;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  background-color: #555;
  padding: 50px 20px 70px;
}
@media screen and (max-width: 768px) {
  #site-footer footer .footer_menu {
    padding: 30px 20px 30px;
  }
}
#site-footer footer .footer_menu a {
  color: #fff;
  text-decoration: none;
}
#site-footer footer .footer_menu .fotter_menu_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 40px;
  max-width: 1280px;
  margin: auto;
}
#site-footer footer .footer_menu .footer_entry {
  margin: 80px auto 20px;
  width: 100%;
}
#site-footer footer .footer_menu .footer_entry ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
#site-footer footer .footer_menu .footer_entry ul li {
  border: 1px solid #fff;
  border-radius: 2px;
  padding: 15px 20px;
  font-size: 14px;
  font-weight: 400;
  color: #fff;
}
#site-footer footer .footer_menu .footer_entry ul li a {
  display: block;
  height: 100%;
  width: 100%
}

@media (hover: hover) and (pointer: fine)  {

  #site-footer footer .footer_menu .footer_entry ul li:hover {
    border: 1px solid #fff;
    border-radius: 2px;
    padding: 15px 20px;
    font-size: 14px;
    font-weight: 400;
    color: #fff;
    background-color: #e60012;
  }


}

@media screen and (max-width: 768px) {
  #site-footer footer .footer_menu .fotter_menu_wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 2%;
  }

  #site-footer footer .footer_menu .footer_entry {
    margin: 5vw auto 3vw;
    width: 80vw;
    margin: 0 auto;
  }
  #site-footer footer .footer_menu .footer_entry ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
  }
  #site-footer footer .footer_menu .footer_entry ul li {
    border: 1px solid #fff;
    border-radius: 2px;
    padding: 15px 20px;
    font-size: 3.1vw;;
    font-weight: 400;
    color: #fff;
    flex-basis: 80vw;
    margin-bottom: 2vw;
  }
  #site-footer footer .footer_menu .footer_entry ul li a {
    display: block;
    height: 100%;
    width: 100%
  }

}
@media screen and (max-width: 768px) {
  #site-footer footer .footer_menu .fotter_menu_wrap > div {
    margin-bottom: 2em;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 48%;
            flex: 0 0 48%;
  }
}
#site-footer footer .footer_menu .fotter_menu_wrap > div ul li {
  font-size: 12px;
  letter-spacing: 0.02em;
  line-height: 2;
  text-align: left;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  #site-footer footer .footer_menu .fotter_menu_wrap > div ul li {
    font-size: 11px;
  }
}
#site-footer footer .footer_menu .fotter_menu_wrap > div ul li a.outgoing {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#site-footer footer .footer_menu .fotter_menu_wrap > div ul li a.outgoing:after {
  content: "";
  width: 1em;
  height: 1em;
  background: url(../img/common/icon-outgoing-wh.svg) center center/contain no-repeat;
  margin-left: 0.5em;
}
#site-footer footer .footer_menu .fotter_menu_wrap > div dl dt {
  font-size: 14px;
  letter-spacing: 0.02em;
  line-height: 1;
  margin-bottom: 20px;
}
@media screen and (max-width: 1024px) {
  #site-footer footer .footer_menu .fotter_menu_wrap > div dl dt {
    font-size: 13px;
  }
}
#site-footer footer .footer_menu .fotter_menu_wrap > div ul.entry-menu {
  margin-top: 60px;
}
#site-footer footer .footer_menu .fotter_menu_wrap > div ul.entry-menu li {
  margin-bottom: 10px;
}
#site-footer footer .footer_menu .fotter_menu_wrap > div ul.entry-menu li a {
  display: block;
  border: 1px solid rgba(255, 255, 255, 0.2);
  text-align: center;
  width: 98px;
  height: 46px;
  line-height: 46px;
  border-radius: 2px;
  font-size: 13px;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
}
#site-footer footer .footer_bottom {
  color: #fff;
  padding: 30px 20px;
}
#site-footer footer .footer_bottom .flex {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 1280px;
  margin: auto;
}
#site-footer footer .footer_bottom .flex p.cp {
  font-family: "Noto Sans JP Regular";
  font-weight: normal;
  font-size: 11px;
  letter-spacing: 0.02em;
  line-height: 23px;
  text-align: left;
  color: #fff;
}
#site-footer footer .footer_bottom .flex a.ptop {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 23px;
  cursor: pointer;
  font-size: 11px;
  letter-spacing: 0.02em;
  line-height: 1;
  color: #fff;
  text-decoration: none;
}
#site-footer footer .footer_bottom .flex a.ptop i {
  display: block;
  width: 54px;
  height: 54px;
  background: url(../img/common/icon_ptop.svg);
  background-size: cover;
}

/*============================
#pagettl
============================*/
#pagettl {
  position: relative;
}
#pagettl h1 {
  position: absolute;
  left: 0;
  bottom: 13.515625vw;
  z-index: 1;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-weight: 500;
  font-size: 60px;
  letter-spacing: 0.08em;
  line-height: 1.3;
  color: #fff;
  width: 100%;
  padding-left: 11.71875vw;
}
@media screen and (max-width: 1100px) {
  #pagettl h1 {
    padding-left: 2.34375vw;
  }
}
@media screen and (max-width: 768px) {
  #pagettl h1 {
    font-size: 6.6666666667vw;
    bottom: 23%;
  }
}
#pagettl h1 small {
  display: block;
  font-family: "Noto Sans JP", sans-serif !important;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 768px) {
  #pagettl h1 small {
    font-size: 3.4666666667vw;
  }
}
#pagettl figure {
  position: relative;
}
@media screen and (max-width: 768px) {
  #pagettl figure {
    height: 66.6666666667vw;
  }
}
#pagettl figure img {
  position: relative;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  #pagettl figure img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
  }
}
#pagettl figure::before {
  content: "";
  display: block;
  width: 100%;
  height: 9.375vw;
  position: absolute;
  left: 0;
  bottom: 0;
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  background-color: rgba(255, 255, 255, 0.15);
}
@media screen and (max-width: 768px) {
  #pagettl figure::before {
    height: 20%;
  }
}
#pagettl figure::after {
  content: "";
  display: block;
  width: 100%;
  height: 37.5vw;
  position: absolute;
  left: 0;
  top: 0;
  background: #d3d3d3;
  -webkit-mix-blend-mode: multiply;
  mix-blend-mode: multiply;
}
@media screen and (max-width: 768px) {
  #pagettl figure::after {
    height: 80%;
  }
}

@-webkit-keyframes slide-show {
  0% {
    height: 0;
  }
  100% {
    height: 100%;
  }
}

@keyframes slide-show {
  0% {
    height: 0;
  }
  100% {
    height: 100%;
  }
}
@-webkit-keyframes slide-zoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@keyframes slide-zoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.btn {
  cursor: pointer;
}

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  list-style: none;
}

body,
html {
  height: 100%;
}

body {
  font-family: "Noto Sans JP", sans-serif !important;
  font-weight: 400;
  color: #242424;
}

img {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

/*============================
UIkit overwrite
============================*/
.uk-card-media-top img {
  width: 100%;
  height: auto;
}

/*============================
commingsoon
============================*/
.comingsoon {
  opacity: 0.3;
  pointer-events: none;
}

/*============================
main
============================*/
main {
  overflow: hidden;
}

/*============================
Responsive
============================*/
.sp {
  display: none !important;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block !important;
  }
}

@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

/*============================
BOX Models
============================*/
.w1000 {
  max-width: 1000px;
  margin: auto;
}

.w780 {
  max-width: 780px;
  margin: auto;
}

/*============================
.flex
============================*/
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

/*============================
.sec
============================*/
/*============================
a
============================*/
a {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

a:hover {
  opacity: 0.85;
}

a[href*="tel:"] {
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  a[href*="tel:"] {
    pointer-events: auto;
  }
}

/*============================
table
============================*/
/*============================
Headlines
============================*/
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #0A0A0A;
}

/*============================
list
============================*/
.maruList,
.komeList {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.maruList *,
.komeList * {
  margin: 0;
  padding: 0;
}
.maruList li,
.komeList li {
  margin-left: 1em;
  list-style: none !important;
}
.maruList li::before,
.komeList li::before {
  content: "●";
  margin-left: -1em;
}

.maruList li::before {
  content: "●";
}

.komeList li::before {
  content: "※";
}

.jisageList li {
  text-indent: -1em;
  margin-left: 1em;
}

/*============================
margin
============================*/
.mt0 {
  margin-top: 0px !important;
}

.mb0 {
  margin-bottom: 0px !important;
}

.mr0 {
  margin-right: 0px !important;
}

.ml0 {
  margin-left: 0px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mr60 {
  margin-right: 60px !important;
}

.ml60 {
  margin-left: 60px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mr70 {
  margin-right: 70px !important;
}

.ml70 {
  margin-left: 70px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mr80 {
  margin-right: 80px !important;
}

.ml80 {
  margin-left: 80px !important;
}

.mt90 {
  margin-top: 90px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.mr90 {
  margin-right: 90px !important;
}

.ml90 {
  margin-left: 90px !important;
}

.mt100 {
  margin-top: 100px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mr100 {
  margin-right: 100px !important;
}

.ml100 {
  margin-left: 100px !important;
}

.mt110 {
  margin-top: 110px !important;
}

.mb110 {
  margin-bottom: 110px !important;
}

.mr110 {
  margin-right: 110px !important;
}

.ml110 {
  margin-left: 110px !important;
}

.mt120 {
  margin-top: 120px !important;
}

.mb120 {
  margin-bottom: 120px !important;
}

.mr120 {
  margin-right: 120px !important;
}

.ml120 {
  margin-left: 120px !important;
}

.mt130 {
  margin-top: 130px !important;
}

.mb130 {
  margin-bottom: 130px !important;
}

.mr130 {
  margin-right: 130px !important;
}

.ml130 {
  margin-left: 130px !important;
}

.mt140 {
  margin-top: 140px !important;
}

.mb140 {
  margin-bottom: 140px !important;
}

.mr140 {
  margin-right: 140px !important;
}

.ml140 {
  margin-left: 140px !important;
}

.mt150 {
  margin-top: 150px !important;
}

.mb150 {
  margin-bottom: 150px !important;
}

.mr150 {
  margin-right: 150px !important;
}

.ml150 {
  margin-left: 150px !important;
}

.mt160 {
  margin-top: 160px !important;
}

.mb160 {
  margin-bottom: 160px !important;
}

.mr160 {
  margin-right: 160px !important;
}

.ml160 {
  margin-left: 160px !important;
}

.mt170 {
  margin-top: 170px !important;
}

.mb170 {
  margin-bottom: 170px !important;
}

.mr170 {
  margin-right: 170px !important;
}

.ml170 {
  margin-left: 170px !important;
}

.mt180 {
  margin-top: 180px !important;
}

.mb180 {
  margin-bottom: 180px !important;
}

.mr180 {
  margin-right: 180px !important;
}

.ml180 {
  margin-left: 180px !important;
}

.mt190 {
  margin-top: 190px !important;
}

.mb190 {
  margin-bottom: 190px !important;
}

.mr190 {
  margin-right: 190px !important;
}

.ml190 {
  margin-left: 190px !important;
}

.mt200 {
  margin-top: 200px !important;
}

.mb200 {
  margin-bottom: 200px !important;
}

.mr200 {
  margin-right: 200px !important;
}

.ml200 {
  margin-left: 200px !important;
}

@media screen and (max-width: 428px) {
  .mt0 {
    margin-top: 0vw !important;
  }

  .mb0 {
    margin-bottom: 0vw !important;
  }

  .mr0 {
    margin-right: 0vw !important;
  }

  .ml0 {
    margin-left: 0vw !important;
  }

  .mt10 {
    margin-top: 1vw !important;
  }

  .mb10 {
    margin-bottom: 1vw !important;
  }

  .mr10 {
    margin-right: 1vw !important;
  }

  .ml10 {
    margin-left: 1vw !important;
  }

  .mt20 {
    margin-top: 2vw !important;
  }

  .mb20 {
    margin-bottom: 2vw !important;
  }

  .mr20 {
    margin-right: 2vw !important;
  }

  .ml20 {
    margin-left: 2vw !important;
  }

  .mt30 {
    margin-top: 3vw !important;
  }

  .mb30 {
    margin-bottom: 3vw !important;
  }

  .mr30 {
    margin-right: 3vw !important;
  }

  .ml30 {
    margin-left: 3vw !important;
  }

  .mt40 {
    margin-top: 4vw !important;
  }

  .mb40 {
    margin-bottom: 4vw !important;
  }

  .mr40 {
    margin-right: 4vw !important;
  }

  .ml40 {
    margin-left: 4vw !important;
  }

  .mt50 {
    margin-top: 5vw !important;
  }

  .mb50 {
    margin-bottom: 5vw !important;
  }

  .mr50 {
    margin-right: 5vw !important;
  }

  .ml50 {
    margin-left: 5vw !important;
  }

  .mt60 {
    margin-top: 6vw !important;
  }

  .mb60 {
    margin-bottom: 6vw !important;
  }

  .mr60 {
    margin-right: 6vw !important;
  }

  .ml60 {
    margin-left: 6vw !important;
  }

  .mt70 {
    margin-top: 7vw !important;
  }

  .mb70 {
    margin-bottom: 7vw !important;
  }

  .mr70 {
    margin-right: 7vw !important;
  }

  .ml70 {
    margin-left: 7vw !important;
  }

  .mt80 {
    margin-top: 8vw !important;
  }

  .mb80 {
    margin-bottom: 8vw !important;
  }

  .mr80 {
    margin-right: 8vw !important;
  }

  .ml80 {
    margin-left: 8vw !important;
  }

  .mt90 {
    margin-top: 9vw !important;
  }

  .mb90 {
    margin-bottom: 9vw !important;
  }

  .mr90 {
    margin-right: 9vw !important;
  }

  .ml90 {
    margin-left: 9vw !important;
  }

  .mt100 {
    margin-top: 10vw !important;
  }

  .mb100 {
    margin-bottom: 10vw !important;
  }

  .mr100 {
    margin-right: 10vw !important;
  }

  .ml100 {
    margin-left: 10vw !important;
  }

  .mt110 {
    margin-top: 11vw !important;
  }

  .mb110 {
    margin-bottom: 11vw !important;
  }

  .mr110 {
    margin-right: 11vw !important;
  }

  .ml110 {
    margin-left: 11vw !important;
  }

  .mt120 {
    margin-top: 12vw !important;
  }

  .mb120 {
    margin-bottom: 12vw !important;
  }

  .mr120 {
    margin-right: 12vw !important;
  }

  .ml120 {
    margin-left: 12vw !important;
  }

  .mt130 {
    margin-top: 13vw !important;
  }

  .mb130 {
    margin-bottom: 13vw !important;
  }

  .mr130 {
    margin-right: 13vw !important;
  }

  .ml130 {
    margin-left: 13vw !important;
  }

  .mt140 {
    margin-top: 14vw !important;
  }

  .mb140 {
    margin-bottom: 14vw !important;
  }

  .mr140 {
    margin-right: 14vw !important;
  }

  .ml140 {
    margin-left: 14vw !important;
  }

  .mt150 {
    margin-top: 15vw !important;
  }

  .mb150 {
    margin-bottom: 15vw !important;
  }

  .mr150 {
    margin-right: 15vw !important;
  }

  .ml150 {
    margin-left: 15vw !important;
  }

  .mt160 {
    margin-top: 16vw !important;
  }

  .mb160 {
    margin-bottom: 16vw !important;
  }

  .mr160 {
    margin-right: 16vw !important;
  }

  .ml160 {
    margin-left: 16vw !important;
  }

  .mt170 {
    margin-top: 17vw !important;
  }

  .mb170 {
    margin-bottom: 17vw !important;
  }

  .mr170 {
    margin-right: 17vw !important;
  }

  .ml170 {
    margin-left: 17vw !important;
  }

  .mt180 {
    margin-top: 18vw !important;
  }

  .mb180 {
    margin-bottom: 18vw !important;
  }

  .mr180 {
    margin-right: 18vw !important;
  }

  .ml180 {
    margin-left: 18vw !important;
  }

  .mt190 {
    margin-top: 19vw !important;
  }

  .mb190 {
    margin-bottom: 19vw !important;
  }

  .mr190 {
    margin-right: 19vw !important;
  }

  .ml190 {
    margin-left: 19vw !important;
  }

  .mt200 {
    margin-top: 20vw !important;
  }

  .mb200 {
    margin-bottom: 20vw !important;
  }

  .mr200 {
    margin-right: 20vw !important;
  }

  .ml200 {
    margin-left: 20vw !important;
  }
}
/*============================
padding
============================*/
.pt0 {
  padding-top: 0px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.pr0 {
  padding-right: 0px !important;
}

.pl0 {
  padding-left: 0px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.pr60 {
  padding-right: 60px !important;
}

.pl60 {
  padding-left: 60px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.pr70 {
  padding-right: 70px !important;
}

.pl70 {
  padding-left: 70px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pb80 {
  padding-bottom: 80px !important;
}

.pr80 {
  padding-right: 80px !important;
}

.pl80 {
  padding-left: 80px !important;
}

.pt90 {
  padding-top: 90px !important;
}

.pb90 {
  padding-bottom: 90px !important;
}

.pr90 {
  padding-right: 90px !important;
}

.pl90 {
  padding-left: 90px !important;
}

.pt100 {
  padding-top: 100px !important;
}

.pb100 {
  padding-bottom: 100px !important;
}

.pr100 {
  padding-right: 100px !important;
}

.pl100 {
  padding-left: 100px !important;
}

.pt110 {
  padding-top: 110px !important;
}

.pb110 {
  padding-bottom: 110px !important;
}

.pr110 {
  padding-right: 110px !important;
}

.pl110 {
  padding-left: 110px !important;
}

.pt120 {
  padding-top: 120px !important;
}

.pb120 {
  padding-bottom: 120px !important;
}

.pr120 {
  padding-right: 120px !important;
}

.pl120 {
  padding-left: 120px !important;
}

.pt130 {
  padding-top: 130px !important;
}

.pb130 {
  padding-bottom: 130px !important;
}

.pr130 {
  padding-right: 130px !important;
}

.pl130 {
  padding-left: 130px !important;
}

.pt140 {
  padding-top: 140px !important;
}

.pb140 {
  padding-bottom: 140px !important;
}

.pr140 {
  padding-right: 140px !important;
}

.pl140 {
  padding-left: 140px !important;
}

.pt150 {
  padding-top: 150px !important;
}

.pb150 {
  padding-bottom: 150px !important;
}

.pr150 {
  padding-right: 150px !important;
}

.pl150 {
  padding-left: 150px !important;
}

.pt160 {
  padding-top: 160px !important;
}

.pb160 {
  padding-bottom: 160px !important;
}

.pr160 {
  padding-right: 160px !important;
}

.pl160 {
  padding-left: 160px !important;
}

.pt170 {
  padding-top: 170px !important;
}

.pb170 {
  padding-bottom: 170px !important;
}

.pr170 {
  padding-right: 170px !important;
}

.pl170 {
  padding-left: 170px !important;
}

.pt180 {
  padding-top: 180px !important;
}

.pb180 {
  padding-bottom: 180px !important;
}

.pr180 {
  padding-right: 180px !important;
}

.pl180 {
  padding-left: 180px !important;
}

.pt190 {
  padding-top: 190px !important;
}

.pb190 {
  padding-bottom: 190px !important;
}

.pr190 {
  padding-right: 190px !important;
}

.pl190 {
  padding-left: 190px !important;
}

.pt200 {
  padding-top: 200px !important;
}

.pb200 {
  padding-bottom: 200px !important;
}

.pr200 {
  padding-right: 200px !important;
}

.pl200 {
  padding-left: 200px !important;
}

@media screen and (max-width: 428px) {
  .pt0 {
    padding-top: 0vw !important;
  }

  .pb0 {
    padding-bottom: 0vw !important;
  }

  .pr0 {
    padding-right: 0vw !important;
  }

  .pl0 {
    padding-left: 0vw !important;
  }

  .pt10 {
    padding-top: 1vw !important;
  }

  .pb10 {
    padding-bottom: 1vw !important;
  }

  .pr10 {
    padding-right: 1vw !important;
  }

  .pl10 {
    padding-left: 1vw !important;
  }

  .pt20 {
    padding-top: 2vw !important;
  }

  .pb20 {
    padding-bottom: 2vw !important;
  }

  .pr20 {
    padding-right: 2vw !important;
  }

  .pl20 {
    padding-left: 2vw !important;
  }

  .pt30 {
    padding-top: 3vw !important;
  }

  .pb30 {
    padding-bottom: 3vw !important;
  }

  .pr30 {
    padding-right: 3vw !important;
  }

  .pl30 {
    padding-left: 3vw !important;
  }

  .pt40 {
    padding-top: 4vw !important;
  }

  .pb40 {
    padding-bottom: 4vw !important;
  }

  .pr40 {
    padding-right: 4vw !important;
  }

  .pl40 {
    padding-left: 4vw !important;
  }

  .pt50 {
    padding-top: 5vw !important;
  }

  .pb50 {
    padding-bottom: 5vw !important;
  }

  .pr50 {
    padding-right: 5vw !important;
  }

  .pl50 {
    padding-left: 5vw !important;
  }

  .pt60 {
    padding-top: 6vw !important;
  }

  .pb60 {
    padding-bottom: 6vw !important;
  }

  .pr60 {
    padding-right: 6vw !important;
  }

  .pl60 {
    padding-left: 6vw !important;
  }

  .pt70 {
    padding-top: 7vw !important;
  }

  .pb70 {
    padding-bottom: 7vw !important;
  }

  .pr70 {
    padding-right: 7vw !important;
  }

  .pl70 {
    padding-left: 7vw !important;
  }

  .pt80 {
    padding-top: 8vw !important;
  }

  .pb80 {
    padding-bottom: 8vw !important;
  }

  .pr80 {
    padding-right: 8vw !important;
  }

  .pl80 {
    padding-left: 8vw !important;
  }

  .pt90 {
    padding-top: 9vw !important;
  }

  .pb90 {
    padding-bottom: 9vw !important;
  }

  .pr90 {
    padding-right: 9vw !important;
  }

  .pl90 {
    padding-left: 9vw !important;
  }

  .pt100 {
    padding-top: 10vw !important;
  }

  .pb100 {
    padding-bottom: 10vw !important;
  }

  .pr100 {
    padding-right: 10vw !important;
  }

  .pl100 {
    padding-left: 10vw !important;
  }

  .pt110 {
    padding-top: 11vw !important;
  }

  .pb110 {
    padding-bottom: 11vw !important;
  }

  .pr110 {
    padding-right: 11vw !important;
  }

  .pl110 {
    padding-left: 11vw !important;
  }

  .pt120 {
    padding-top: 12vw !important;
  }

  .pb120 {
    padding-bottom: 12vw !important;
  }

  .pr120 {
    padding-right: 12vw !important;
  }

  .pl120 {
    padding-left: 12vw !important;
  }

  .pt130 {
    padding-top: 13vw !important;
  }

  .pb130 {
    padding-bottom: 13vw !important;
  }

  .pr130 {
    padding-right: 13vw !important;
  }

  .pl130 {
    padding-left: 13vw !important;
  }

  .pt140 {
    padding-top: 14vw !important;
  }

  .pb140 {
    padding-bottom: 14vw !important;
  }

  .pr140 {
    padding-right: 14vw !important;
  }

  .pl140 {
    padding-left: 14vw !important;
  }

  .pt150 {
    padding-top: 15vw !important;
  }

  .pb150 {
    padding-bottom: 15vw !important;
  }

  .pr150 {
    padding-right: 15vw !important;
  }

  .pl150 {
    padding-left: 15vw !important;
  }

  .pt160 {
    padding-top: 16vw !important;
  }

  .pb160 {
    padding-bottom: 16vw !important;
  }

  .pr160 {
    padding-right: 16vw !important;
  }

  .pl160 {
    padding-left: 16vw !important;
  }

  .pt170 {
    padding-top: 17vw !important;
  }

  .pb170 {
    padding-bottom: 17vw !important;
  }

  .pr170 {
    padding-right: 17vw !important;
  }

  .pl170 {
    padding-left: 17vw !important;
  }

  .pt180 {
    padding-top: 18vw !important;
  }

  .pb180 {
    padding-bottom: 18vw !important;
  }

  .pr180 {
    padding-right: 18vw !important;
  }

  .pl180 {
    padding-left: 18vw !important;
  }

  .pt190 {
    padding-top: 19vw !important;
  }

  .pb190 {
    padding-bottom: 19vw !important;
  }

  .pr190 {
    padding-right: 19vw !important;
  }

  .pl190 {
    padding-left: 19vw !important;
  }

  .pt200 {
    padding-top: 20vw !important;
  }

  .pb200 {
    padding-bottom: 20vw !important;
  }

  .pr200 {
    padding-right: 20vw !important;
  }

  .pl200 {
    padding-left: 20vw !important;
  }
}
/*============================
Swiper button
============================*/
/*============================
Text
============================*/
.tLeft {
  text-align: left;
}

.tCenter {
  text-align: center;
}

.tRight {
  text-align: right;
}

.lh2 {
  line-height: 2;
}

.lh1_5 {
  line-height: 1.5;
}

.lh1 {
  line-height: 1;
}

.ls8 {
  letter-spacing: 0.08em;
}

.ls4 {
  letter-spacing: 0.04em;
}

.ls2 {
  letter-spacing: 0.02em;
}

.fz10 {
  font-size: 10px;
}

.fz11 {
  font-size: 11px;
}

.fz12 {
  font-size: 12px;
}

.fz13 {
  font-size: 13px;
}

.fz14 {
  font-size: 14px;
}

.fz15 {
  font-size: 15px;
}

.fz16 {
  font-size: 16px;
}

.fz17 {
  font-size: 17px;
}

.fz18 {
  font-size: 18px;
}

.fz19 {
  font-size: 19px;
}

.fz20 {
  font-size: 20px;
}

.fz21 {
  font-size: 21px;
}

.fz22 {
  font-size: 22px;
}

.fz23 {
  font-size: 23px;
}

.fz24 {
  font-size: 24px;
}

.fz25 {
  font-size: 25px;
}

.fz26 {
  font-size: 26px;
}

.fz27 {
  font-size: 27px;
}

.fz28 {
  font-size: 28px;
}

.fz29 {
  font-size: 29px;
}

.fz30 {
  font-size: 30px;
}

.fz32 {
  font-size: 32px;
}

.fz36 {
  font-size: 36px;
}

.fz40 {
  font-size: 40px;
}

@media screen and (max-width: 428px) {
  .fz10 {
    font-size: 12px;
  }

  .fz11 {
    font-size: 12px;
  }

  .fz12 {
    font-size: 12px;
  }

  .fz13 {
    font-size: 12px;
  }

  .fz14 {
    font-size: 13px;
  }

  .fz15 {
    font-size: 13px;
  }

  .fz16 {
    font-size: 14px;
  }

  .fz17 {
    font-size: 14px;
  }

  .fz18 {
    font-size: 14px;
  }

  .fz19 {
    font-size: 14px;
  }

  .fz20 {
    font-size: 14px;
  }

  .fz21 {
    font-size: 16px;
  }

  .fz22 {
    font-size: 16px;
  }

  .fz23 {
    font-size: 16px;
  }

  .fz24 {
    font-size: 16px;
  }

  .fz25 {
    font-size: 18px;
  }

  .fz26 {
    font-size: 18px;
  }

  .fz27 {
    font-size: 18px;
  }

  .fz28 {
    font-size: 18px;
  }

  .fz29 {
    font-size: 18px;
  }

  .fz30 {
    font-size: 18px;
  }

  .fz32,
.fz36 {
    font-size: 18px;
  }

  .fz40 {
    font-size: 20px;
  }
}
.fw400 {
  font-weight: 400 !important;
}

.fw500 {
  font-weight: 500 !important;
}

.fw700 {
  font-weight: 700 !important;
}

.cWhite {
  color: #fff;
}

.cRed {
  color: #E60012;
}

.grid780 {
  max-width: 820px;
  padding: 0 20px;
  margin: 0 auto;
}

.grid820 {
  max-width: 860px;
  padding: 0 20px;
  margin: 0 auto;
}

.grid880 {
  max-width: 920px;
  padding: 0 20px;
  margin: 0 auto;
}

.grid980 {
  max-width: 1020px;
  padding: 0 20px;
  margin: 0 auto;
}

.grid1080 {
  max-width: 1120px;
  padding: 0 20px;
  margin: 0 auto;
}

.grid1180 {
  max-width: 1220px;
  padding: 0 20px;
  margin: 0 auto;
}

@media screen and (max-width: 428px) {
  .grid820 {
    padding: 0 3vw;
  }

  .grid980 {
    padding: 0 3vw;
  }

  .grid1080 {
    padding: 0 3vw;
  }

  .grid1180 {
    padding: 0 3vw;
  }
}
.bg-lightgray {
  background: #fff8f2;
}

.r10 {
  overflow: hidden;
  border-radius: 10px;
}

.r20 {
  overflow: hidden;
  border-radius: 20px;
}

.anchor {
  margin-top: -120px;
  padding-top: 120px;
}
@media screen and (max-width: 428px) {
  .anchor {
    margin-top: -600px;
    padding-top: 600px;
  }
}

.bordertop {
  border-top: 1px solid #E5E5E5;
}

.lead {
  font-size: 28px;
  font-weight: 500;
  line-height: 2;
  margin: 100px 0 60px 0;
  letter-spacing: 0.04em;
}
.lead--2 {
  font-size: 24px;
}
@media screen and (max-width: 428px) {
  .lead {
    font-size: 16px;
    margin: 10vw 0 5vw 0;
  }
  .lead--2 {
    font-size: 16px;
  }
}

main {
  position: relative;
}
main p {
  letter-spacing: 0.02em;
  line-height: 2;
}
@media screen and (max-width: 428px) {
  main p {
    font-size: min(2.6vw,12px);
  }
}

@-webkit-keyframes mvIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes mvIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes mvH1In {
  0% {
    opacity: 0;
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
@keyframes mvH1In {
  0% {
    opacity: 0;
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
.commonMv {
  padding-top: 120px;
  position: relative;
  z-index: 0;
}
.commonMv__bg {
  position: relative;
  -webkit-animation: 0.3s mvIn ease-out both;
          animation: 0.3s mvIn ease-out both;
}
.commonMv__bg img {
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1280/600;
  -o-object-position: center center;
     object-position: center center;
}
.commonMv .image {
  position: absolute;
  top: 120px;
  left: 0;
  -webkit-animation: 0.5s 0.3s mvIn ease-in both;
          animation: 0.5s 0.3s mvIn ease-in both;
}
.commonMv .entry_btn {
  width: 100%;
  height: 140px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  bottom: 0;
  left: 50%;
  ransform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.commonMv .entry_btn ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
.commonMv .entry_btn ul li {
  border: 1px solid #fff;
  border-radius: 2px;
  padding: 15px 20px;
  font-size: 14px;
  font-weight: 400;
  color: #fff;
}

.commonMv .entry_btn ul li a {
  display: block;
  height: 100%;
  width: 100%
}

@media (hover: hover) and (pointer: fine)  {

  .commonMv .entry_btn ul li:hover {
    border: 1px solid #fff;
    border-radius: 2px;
    padding: 15px 20px;
    font-size: 14px;
    font-weight: 400;
    color: #fff;
    background-color: #e60012;
  }

}
.commonMv .commonH1 {
  z-index: 2;
  position: absolute;
  bottom: 4vw;
  left: 11vw;
  color: #fff;
  font-size: 18px;
  font-size: 1.40625vw;
  letter-spacing: 0.06em;
  font-weight: 400;
  -webkit-animation: 1s 0.8s mvH1In ease-out both;
          animation: 1s 0.8s mvH1In ease-out both;
}
.commonMv .commonH1:before {
  display: block;
  content: attr(data-en);
  text-transform: uppercase;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 60px;
  font-size: 4.6875vw;
  letter-spacing: 0.08em;
  margin-bottom: 10px;
  font-weight: 500;
  white-space: pre;
}
.commonMv .commonH1--rde:before {
  content: "Research \a development \a Engineering";
}
.commonMv--career .image {
  position: relative;
  top: 0;
}
.commonMv--career .commonH1 {
  top: 4vw;
  bottom: auto;
}
.commonMv--career .commonH1:before {
  display: block;
  content: attr(data-en);
  text-transform: uppercase;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 60px;
  font-size: 4.6875vw;
  letter-spacing: 0.08em;
  margin-bottom: 10px;
  font-weight: 500;
  white-space: pre;
}
.commonMv--career .commonH1--rde:before {
  content: "Research \a development \a Engineering";
}
@media screen and (max-width: 428px) {
  .commonMv {
    padding-top: 60px;
  }
  .commonMv__bg {
    position: relative;
    -webkit-animation: 0.3s mvIn ease-out both;
            animation: 0.3s mvIn ease-out both;
  }
  .commonMv__bg img {
    aspect-ratio: 1280/700;
  }
  .commonMv .image {
    top: 60px;
  }
  .commonMv .image img {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center center;
       object-position: center center;
    aspect-ratio: 1280/600;
  }
  .commonMv .commonH1 {
    bottom: 3vw;
    left: 3vw;
    font-size: 14px;
  }
  .commonMv .commonH1:before {
    font-size: 28px;
    margin-bottom: 3px;
  }
  .commonMv .commonH1--rde:before {
    content: "Research \a development \a Engineering";
  }
  .commonMv--career .image {
    position: relative;
    top: 0;
  }
  .commonMv--career .commonH1 {
    top: 3vw;
    bottom: auto;
  }
  .commonMv--career .commonH1:before {
    font-size: 28px;
    margin-bottom: 3px;
  }
}

.fadeupin {
  opacity: 0;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  -webkit-transition: opacity 1s, -webkit-transform 1s;
  transition: opacity 1s, -webkit-transform 1s;
  transition: transform 1s, opacity 1s;
  transition: transform 1s, opacity 1s, -webkit-transform 1s;
}
.fadeupin.on {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
@media screen and (max-width: 428px) {
  .fadeupin {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
    -webkit-transition: opacity 1s, -webkit-transform 1s;
    transition: opacity 1s, -webkit-transform 1s;
    transition: opacity 1s, transform 1s;
    transition: opacity 1s, transform 1s, -webkit-transform 1s;
  }
  .fadeupin.on {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@media screen and (max-width: 428px) {
  .sp-pad {
    padding: 0 5vw;
  }
}
/*============================
ABOUT
============================*/
.aboutBlock {
  margin-bottom: 90px;
}
.aboutBlock--2 {
  background: url(../img/about/about-sairo-bg.jpg) center bottom/contain no-repeat;
  padding-bottom: 14vw;
}
.aboutBlockHead {
  position: relative;
}
.aboutBlockHead__inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  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;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.aboutBlock__text {
  background: rgba(255, 248, 242, 0.8);
  border-radius: 20px;
  margin-top: -50px;
  position: relative;
  z-index: 1;
  padding: 50px 50px;
}
.aboutBlockRinen {
  padding: 200px 0 300px;
}
.aboutBlockRinen__year {
  margin-bottom: 70px;
  line-height: 1;
}
.aboutBlockRinen__year .rinen-1 {
  font-size: 117px;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  color: #E60012;
  letter-spacing: 0.04em;
  font-weight: 700 !important;
}
.aboutBlockRinen__year .rinen-2 {
  font-weight: 700 !important;
  font-size: 30px;
  color: #E60012;
}
.aboutBlockRinen__profile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 15px;
  max-width: 564px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 75px auto 0;
}
.aboutBlockRinen__profile .image {
  max-width: 163px;
  -ms-flex-preferred-size: 163px;
      flex-basis: 163px;
  margin-right: 20px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.aboutBlockRinen__image {
  position: absolute;
}
.aboutBlockRinen__image--1 {
  max-width: 294px;
  top: 192px;
  left: 76px;
}
.aboutBlockRinen__image--2 {
  max-width: 342px;
  bottom: 45px;
  left: 117px;
}
.aboutBlockRinen__image--3 {
  max-width: 334px;
  bottom: 92px;
  right: 77px;
}
.aboutBlockMessage {
  padding-top: 120px;
}
.aboutBlockMessage-1:after {
  content: "";
  border-left: 4px dotted #000;
  height: 60px;
  width: 1px;
  display: block;
  margin: 30px auto;
}
.aboutBlockMessage__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: -250px;
}
.aboutBlockMessage__list--2 {
  margin-bottom: 0;
}
.aboutBlockMessage__list > * {
  padding: 0 30px;
  max-width: 360px;
  -ms-flex-preferred-size: 360px;
      flex-basis: 360px;
}
.aboutBlockMessage__list > * h3 {
  line-height: 2;
  height: 80px;
  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;
  text-align: center;
}
.aboutBlockMessage__list > * .image {
  max-width: 300px;
  border-radius: 10px;
  overflow: hidden;
}
.aboutBlockMessage__list > * .image img {
  display: block;
}
.aboutBlockMessage__list > * p {
  line-height: 2;
  margin-top: 15px;
}
.aboutBlockMessage__bottom {
  color: #fff;
  max-width: 1020px;
  width: 100%;
  margin: 10px auto 0;
  font-size: 15px;
}
.aboutBlockCheck {
  background: rgba(255, 248, 242, 0.8);
  position: relative;
  z-index: 1;
  padding: 50px 50px;
  margin-top: 350px;
}
.aboutBlockCheck h3 {
  margin-bottom: 35px;
}
.aboutBlockOnlyone {
  margin-top: 110px;
  margin-bottom: 80px;
  position: relative;
}
.aboutBlockOnlyone h3 {
  border-radius: 10px;
  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;
  max-width: 382px;
  width: 100%;
  height: 72px;
  color: #E60012;
  font-size: 20px;
  font-weight: 500;
  background: #FFF9F4;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.aboutBlockOnlyone__image {
  border-radius: 20px;
  overflow: hidden;
}
.aboutBlockOnlyone__image img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}
.aboutBlockOnlyone__inner {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  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;
  color: #fff;
}
.aboutBlockOnlyone__text {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.aboutBlockOnlyone__text span {
  font-size: 36px;
  display: block;
}
.aboutBlockOnlyone__text--2 {
  font-size: 28px;
}
.aboutBlockOnlyone__text--2 p {
  line-height: 1.5;
}
.aboutBlockOnlyone__text--2 .lg {
  font-size: 60px;
}
.aboutGrain {
  background: rgba(255, 237, 186, 0.9);
  border-radius: 20px;
  padding: 40px 0 70px;
  margin: 70px auto;
}
.aboutGrain h3 {
  font-size: 16px;
  font-weight: 400px;
  margin-bottom: 40px;
}
.aboutGrain ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.aboutGrain ul li {
  padding: 0 38px;
  text-align: center;
}
.aboutGrain ul li img {
  margin-top: 20px;
  display: block;
  max-width: 144px;
}
.aboutCM {
  background: #FFF9F4;
  padding: 70px 0 50px;
}
.aboutCM .kigyocm {
  max-width: 648px;
  margin: 40px auto 80px;
  display: block;
}
.aboutCM .other a {
  display: block;
  color: #fff;
  text-decoration: none;
  width: 249px;
  height: 46px;
  line-height: 46px;
  border-radius: 23px;
  background: #e60012;
  margin: 0 auto;
  text-align: center;
}
@media screen and (max-width: 428px) {
  .aboutBlock {
    margin-bottom: 15vw;
  }
  .aboutBlock--2 {
    padding-bottom: 40vw;
  }
  .aboutBlockHead .image img {
    -o-object-fit: cover;
       object-fit: cover;
    aspect-ratio: 10/5;
  }
  .aboutBlock__text {
    border-radius: 10px;
    margin-top: -8vw;
    padding: 5vw 5vw;
  }
  .aboutBlock__lead {
    padding: 0 2vw;
  }
  .aboutBlockRinen {
    padding: 50vw 0 45vw;
  }
  .aboutBlockRinen__year {
    margin-bottom: 5vw;
  }
  .aboutBlockRinen__year .rinen-1 {
    font-size: 10vw;
  }
  .aboutBlockRinen__year .rinen-2 {
    font-size: 5vw;
  }
  .aboutBlockRinen__profile {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-size: 4vw;
    margin: 5vw -5vw 0 3vw;
  }
  .aboutBlockRinen__profile .image {
    max-width: 30vw;
    -ms-flex-preferred-size: 30vw;
        flex-basis: 30vw;
    margin-right: 10px;
    font-size: 3vw;
  }
  .aboutBlockRinen__profile .image p {
    padding-right: 0;
  }
  .aboutBlockRinen__profile p {
    padding-right: 5vw;
  }
  .aboutBlockRinen__image {
    position: absolute;
  }
  .aboutBlockRinen__image--1 {
    max-width: 60vw;
    width: 100%;
    top: 5vw;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .aboutBlockRinen__image--2 {
    max-width: 50vw;
    bottom: -5vw;
    left: -4vw;
  }
  .aboutBlockRinen__image--3 {
    max-width: 50vw;
    bottom: 8vw;
    right: -4vw;
  }
  .aboutBlockMessage {
    padding-top: 10vw;
  }
  .aboutBlockMessage-1:after {
    border-left: 3px dotted #000;
    height: 30px;
    margin: 20px auto;
  }
  .aboutBlockMessage__list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-bottom: 0vw;
  }
  .aboutBlockMessage__list--2 {
    margin-bottom: 0;
  }
  .aboutBlockMessage__list > * {
    padding: 0 10vw;
    max-width: 80vw;
    -ms-flex-preferred-size: 80vw;
        flex-basis: 80vw;
    margin-bottom: 10vw;
  }
  .aboutBlockMessage__list > * h3 {
    height: auto;
    font-size: 5vw;
    line-height: 1.6;
    margin: 0 -10vw;
  }
  .aboutBlockMessage__list > * .image {
    max-width: 300px;
    border-radius: 10px;
    overflow: hidden;
  }
  .aboutBlockMessage__list > * .image img {
    display: block;
  }
  .aboutBlockMessage__list > * p {
    line-height: 2;
    margin-top: 15px;
  }
  .aboutBlockMessage__list--3 {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
  .aboutBlockMessage__list--3 > * {
    padding: 0 1vw;
    max-width: 33vw;
    -ms-flex-preferred-size: 33vw;
        flex-basis: 33vw;
    margin-bottom: 3vw;
  }
  .aboutBlockMessage__bottom {
    color: #000;
    font-size: 3.5vw;
    line-height: 1.5;
  }
  .aboutBlockCheck {
    padding: 5vw;
    margin-top: 5vw;
  }
  .aboutBlockCheck h3 {
    margin-bottom: 5vw;
  }
  .aboutBlockOnlyone {
    margin-top: 15vw;
    margin-bottom: 5vw;
  }
  .aboutBlockOnlyone--2 {
    margin-top: 5vw;
  }
  .aboutBlockOnlyone h3 {
    border-radius: 5px;
    height: 12vw;
    font-size: 4.5vw;
    max-width: 80vw;
  }
  .aboutBlockOnlyone__image {
    border-radius: 10px;
    overflow: hidden;
  }
  .aboutBlockOnlyone__image img {
    aspect-ratio: 10/5;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .aboutBlockOnlyone__text {
    font-size: 3.5vw;
  }
  .aboutBlockOnlyone__text span {
    font-size: 5vw;
    display: block;
  }
  .aboutBlockOnlyone__text--2 {
    font-size: 4vw;
  }
  .aboutBlockOnlyone__text--2 p {
    line-height: 1.5;
  }
  .aboutBlockOnlyone__text--2 .lg {
    font-size: 8vw;
  }
  .aboutGrain {
    border-radius: 10px;
    padding: 20px 0 20px;
    margin: 5vw -6vw;
  }
  .aboutGrain h3 {
    font-size: 3.5vw;
    margin-bottom: 5vw;
  }
  .aboutGrain ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .aboutGrain ul li {
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
    max-width: 25%;
    padding: 0 5px;
    font-size: 3vw;
    font-size: 2.4vw;
  }
  .aboutGrain ul li img {
    margin-top: 1vw;
  }
  .aboutGrain--2 {
    margin: 5vw 0;
  }
  .aboutCM {
    padding: 10vw 0 10vw;
  }
  .aboutCM .kigyocm {
    margin: 5vw 5vw 5vw;
    display: block;
  }
  .aboutCM .other a {
    font-size: 3.5vw;
  }
}

.businessSynergy {
  position: relative;
  padding: 135px 0 70px;
  border-radius: 20px;
  background: #fff;
}
.businessSynergy h3 {
  border-radius: 10px;
  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;
  max-width: 382px;
  width: 100%;
  height: 72px;
  font-size: 20px;
  font-weight: 500;
  background: #F9DADD;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.businessSynergy__wrapper {
  background: url(../img/about/business-img1.jpg) center bottom/contain no-repeat;
}
.businessSynergy__bottom {
  color: #fff;
  font-size: 18px;
  padding-bottom: 100px;
}
.businessSynergy__bottom .text1 .lg {
  font-size: 32px;
}
.businessSynergy__bottom .text1 .lg span {
  font-size: 90px;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  letter-spacing: 0.06em;
  display: inline-block;
}
.business__imagetitle {
  position: relative;
}
.business__imagetitle h3.title {
  position: absolute;
  top: 0;
  left: 0;
  padding-bottom: 100px;
  width: 100%;
  height: 100%;
  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: 1;
}
.businessBlock {
  background: #fff;
  overflow: hidden;
  border-radius: 20px;
  margin-top: 80px;
}
.businessBlock--1 {
  margin-top: -100px;
  position: relative;
  z-index: 1;
}
.businessBlock--food h4 {
  background: #E5C78E;
}
.businessBlock--food .businessBlock__genre {
  color: #A7720E;
}
.businessBlock--siryo .businessBlock__genre {
  color: #4F8DAC;
}
.businessBlock--other h4 {
  background: #9BAD60;
}
.businessBlock h4 {
  height: 60px;
  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;
}
.businessBlock__text {
  padding: 50px 10% 80px;
}
.businessBlock__image {
  margin: 50px auto;
}
.businessBlock__image--1 {
  max-width: 578px;
}
.businessBlock__image--2 {
  max-width: 466px;
}
.businessBlock__image--3 {
  max-width: 504px;
}
.businessBlock__image--4 {
  max-width: 456px;
}
.businessBlock__image--5 {
  max-width: 220px;
}
.businessBlock p {
  font-size: 15px;
  letter-spacing: 0.02em;
  line-height: 2;
}
.businessBlock__genre {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.businessBlock__genre dt {
  padding-right: 5em;
}
.businessBlock__genre dd ul li {
  display: inline-block;
  padding-right: 2em;
}
@media screen and (max-width: 428px) {
  .businessSynergy {
    padding: 10vw 0 5vw;
    border-radius: 10px;
  }
  .businessSynergy h3 {
    border-radius: 5px;
    max-width: 80vw;
    height: 12vw;
    font-size: 4vw;
  }
  .businessSynergy__wrapper {
    background: url(../img/about/business-img1.jpg) center bottom/200% auto no-repeat;
  }
  .businessSynergy__bottom {
    color: #fff;
    font-size: 4vw;
    padding-bottom: 15vw;
  }
  .businessSynergy__bottom .text1 .lg {
    font-size: 4vw;
  }
  .businessSynergy__bottom .text1 .lg span {
    font-size: 12vw;
  }
  .business__imagetitle h3.title {
    padding-bottom: 10vw;
  }
  .business__imagetitle .image img {
    -o-object-fit: cover;
       object-fit: cover;
    aspect-ratio: 2/1;
  }
  .businessBlock {
    border-radius: 10px;
    margin-top: 10vw;
  }
  .businessBlock--1 {
    margin-top: -10vw;
  }
  .businessBlock h4 {
    height: 12vw;
    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;
  }
  .businessBlock__text {
    padding: 10vw 5vw 10vw;
  }
  .businessBlock__image {
    margin: 3vw auto;
  }
  .businessBlock p {
    font-size: 13px;
  }
  .businessBlock__genre {
    display: block;
  }
  .businessBlock__genre dt {
    padding-right: 0;
    margin-bottom: 0.5em;
  }
  .businessBlock__genre dd ul li {
    display: inline-block;
    padding-right: 2em;
  }
}

.message-sign {
  position: absolute;
  top: 50%;
  right: 11vw;
  width: 16.17vw;
  aspect-ratio: 207/93;
  mix-blend-mode: multiply;
}
.messageProfile {
  padding-top: 80px;
  max-width: 390px;
  width: 100%;
  margin: 0 0 0 auto;
}
.messageProfile h3 {
  font-size: 24px;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  margin-bottom: 30px;
}
@media screen and (max-width: 428px) {
  .message-sign {
    right: 7vw;
    width: 20vw;
  }
  .messageProfile {
    padding-top: 5vw;
  }
  .messageProfile h3 {
    font-size: 15px;
    margin-bottom: 5px;
  }
}

.img-out1 {
  margin-top: 250px;
  margin-bottom: -250px;
}
.img-out1 img {
  -webkit-transform: translateY(-250px);
          transform: translateY(-250px);
}
@media screen and (max-width: 428px) {
  .img-out1 {
    margin-top: 20vw;
    margin-bottom: -20vw;
  }
  .img-out1 img {
    -webkit-transform: translateY(-20vw);
            transform: translateY(-20vw);
  }
}

.movieMain {
  overflow: inherit;
}
.movieMV {
  background: #C30110;
  width: 100%;
  aspect-ratio: 1280/420;
  padding-bottom: 60px;
  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;
}
.movieMV .commonH1 {
  position: static;
  color: #fff;
  text-align: center;
}
.movieMV .commonH1:before {
  text-align: center;
}
.movieArea {
  border-radius: 20px;
  -webkit-transform: translateY(-60px);
          transform: translateY(-60px);
  padding: 100px;
}
.movieArea__wrapper {
  max-width: 1246px;
  width: 100%;
  padding: 0 20px;
  margin: 0 auto;
  position: relative;
  z-index: 100;
}
.movieArea__list {
  max-width: 900px;
  width: 100%;
  margin: 90px auto 0;
}
.movieArea__list > ul {
  margin: 0 -50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.movieArea__list > ul > li {
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
  padding: 40px 50px;
  text-align: center;
}
.movieArea__list > ul > li a {
  margin-top: 10px;
  display: block;
}
@media screen and (max-width: 428px) {
  .movieMV {
    aspect-ratio: 1280/800;
    padding-bottom: 10vw;
  }
  .movieArea {
    border-radius: 10px;
    -webkit-transform: translateY(-10vw);
            transform: translateY(-10vw);
    padding: 10vw 5vw;
  }
  .movieArea__wrapper {
    width: 100%;
    padding: 0 5vw;
  }
  .movieArea__list {
    margin: 10vw auto 0;
  }
  .movieArea__list > ul {
    margin: 0 -8vw;
  }
  .movieArea__list > ul > li {
    padding: 10px 5px;
    text-align: center;
  }
  .movieArea__list > ul > li p {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    height: 3em;
    line-height: 1.5;
  }
  .movieArea__list > ul > li a {
    margin-top: 10px;
    display: block;
  }
}

.keywordMain {
  overflow: inherit;
}
.keywordMV {
  background: #C30110;
  width: 100%;
  aspect-ratio: 1280/420;
  padding-bottom: 60px;
  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;
}
.keywordMV .commonH1 {
  position: static;
  color: #fff;
  text-align: center;
}
.keywordMV .commonH1:before {
  text-align: center;
}
.keywordArea {
  border-radius: 20px;
  -webkit-transform: translateY(-60px);
          transform: translateY(-60px);
  padding: 90px;
}
.keywordArea__wrapper {
  max-width: 1246px;
  width: 100%;
  padding: 0 20px;
  margin: 0 auto;
  position: relative;
  z-index: 100;
}
.keywordArea__list {
  margin-top: 60px;
}
.keywordArea__list > ul {
  margin: 0 -40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;

  /* 20251219追加 */
  align-items: stretch;
}
.keywordArea__list > ul > li {
  -ms-flex-preferred-size: 33.3%;
      flex-basis: 33.3%;
  max-width: 33.3%;
  padding: 40px 40px;

  /* 20251219追加 */
  display: flex;
  flex-direction: column;
}
.keywordArea__list > ul > li h3 {
  font-size: 24px;
  color: #fff;
  min-height: 4em;
  margin-bottom: 10px;
}
.keywordArea__list > ul > li h3 span {
  background: #E60012;
  line-height: 2;
  padding: 0 0.5em;
}
.keywordArea__list > ul > li p {
  min-height: 13em;
  margin-bottom: 5px;
}

/* 20251219追加 */
.keywordArea__list > ul > li img{
    margin-top: auto;
}
@media screen and (max-width: 428px) {
  .keywordMV {
    aspect-ratio: 1280/800;
    padding-bottom: 10vw;
  }
  .keywordArea {
    border-radius: 10px;
    -webkit-transform: translateY(-10vw);
            transform: translateY(-10vw);
    padding: 5vw;
  }
  .keywordArea__wrapper {
    width: 100%;
    padding: 0 5vw;
  }
  .keywordArea__list {
    margin-top: 60px;
  }
  .keywordArea__list > ul {
    margin: 0;
    display: block;
  }
  .keywordArea__list > ul > li {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
    padding: 20px 0px;
  }
  .keywordArea__list > ul > li h3 {
    font-size: 17px;
    color: #fff;
    min-height: auto;
    margin-bottom: 10px;
  }
  .keywordArea__list > ul > li h3 span {
    background: #E60012;
    line-height: 2;
    padding: 0 0.5em;
  }
  .keywordArea__list > ul > li p {
    min-height: 0;
    margin-bottom: 15px;
  }
  .keywordArea__list > ul > li img {
    max-width: 80%;
    margin: 0 auto;
    display: block;
  }
}

/*============================
JOBS
============================*/
.jobs__navi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.jobs__navi > * {
  max-width: 50%;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
}
.jobs__navi > * a {
  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;
  color: #fff;
  height: 100px;
  text-decoration: none;
}
.jobs__navi .navi-technical {
  background: #9BAD60;
}
.jobs__navi .navi-office {
  background: #6FA9C3;
}
.jobsHead {
  position: relative;
}
.jobsHead__inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  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;
  padding-bottom: 100px;
}
.jobs__inner {
  margin-top: -90px;
  position: relative;
  z-index: 1;
}
.jobs__inner > ul {
  padding: 0 -17px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.jobs__inner > ul > * {
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
  padding: 0 17px 34px;
}
.jobs__inner > ul > * > dl {
  background: #fff;
  overflow: hidden;
  border-radius: 10px;
}
.jobs__inner > ul > * > dl > dt {
  padding: 10px;
  color: #fff;
  margin-bottom: 35px;
}
.jobs__inner > ul > * > dl > dd {
  padding: 0 35px 35px;
}
.jobs__inner > ul > * > dl > dd .haizoku {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 15px;
  align-items: flex-start;
}
.jobs__inner > ul > * > dl > dd .haizoku dt {
  color: #fff;
  border-radius: 10em;
  margin-right: 1em;
  padding: .5em 1em;
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  line-height: 1.5;
}
.jobs__inner > ul > * > dl > dd .haizoku dd {
  font-size: 15px;
  padding: .5em 0;
  line-height: 1.5;
}
.jobs__inner > ul > * > dl .image {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  justify-content: flex-start;
}
.jobs__inner > ul > * > dl .image p {
  line-height: 1.5;
}
.jobs__inner > ul > * > dl .image a {
  text-decoration: none;
  color: #000;
}
.jobs__inner > ul > * > dl .image > * {
  -ms-flex-preferred-size: 33.3%;
      flex-basis: 33.3%;
  max-width: 33.3%;
  padding: 0 10px 20px;
}
.jobs__inner > ul > * > dl .image img {
  margin-bottom: 10px;
}
.jobs__inner > ul > *.tec > dl > dt {
  background: #9BAD60;
}
.jobs__inner > ul > *.tec .haizoku dt {
  background: #9BAD60;
}
.jobs__inner > ul > *.office > dl > dt {
  background: #6FA9C3;
}
.jobs__inner > ul > *.office .haizoku dt {
  background: #6FA9C3;
}
@media screen and (max-width: 428px) {
  .jobs__navi {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .jobs__navi > * a {
    height: 60px;
  }
  .jobsHead .image img {
    -o-object-fit: cover;
       object-fit: cover;
    aspect-ratio: 2/1;
  }
  .jobsHead__inner {
    padding-bottom: 10vw;
  }
  .jobs__inner {
    margin-top: -10vw;
  }
  .jobs__inner > ul {
    margin: 0;
  }
  .jobs__inner > ul > * {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
    padding: 0 0 10vw;
  }
  .jobs__inner > ul > * > dl {
    border-radius: 5px;
  }
  .jobs__inner > ul > * > dl > dt {
    padding: 10px;
    margin-bottom: 5vw;
  }
  .jobs__inner > ul > * > dl > dd {
    padding: 0 5vw 5vw;
  }
  .jobs__inner > ul > * > dl > dd .haizoku {
    margin-top: 15px;
  }
  .jobs__inner > ul > * > dl > dd .haizoku dt {
    font-size: 12px;
  }
  .jobs__inner > ul > * > dl > dd .haizoku dd {
    font-size: 13px;
  }
  .jobs__inner > ul > * > dl .image {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 0 -10px;
  }
  .jobs__inner > ul > * > dl .image p {
    line-height: 1.5;
  }
  .jobs__inner > ul > * > dl .image a {
    text-decoration: none;
    color: #000;
  }
  .jobs__inner > ul > * > dl .image > * {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
    padding: 0 10px 20px;
  }
  .jobs__inner > ul > * > dl .image img {
    margin-bottom: 10px;
  }
  .jobs__inner > ul > *.tec > dl > dt {
    background: #9BAD60;
  }
  .jobs__inner > ul > *.tec .haizoku dt {
    background: #9BAD60;
  }
  .jobs__inner > ul > *.office > dl > dt {
    background: #6FA9C3;
  }
  .jobs__inner > ul > *.office .haizoku dt {
    background: #6FA9C3;
  }
}

.projectPerson {
  color: #fff;
  background: #E60012;
  border-radius: 20px;
  padding: 40px 0 50px;
}
.projectPerson__wrapper {
  position: relative;
}
.projectPerson__wrapper:after {
  content: "PROJECT";
  color: #FFF8F2;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 120px;
  position: absolute;
  top: 0;
  right: 0;
  letter-spacing: 0.08em;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  line-height: 0.8;
}
.projectPerson h3 {
  text-transform: uppercase;
  color: #fff;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
}
.projectPerson__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 15px;
}
.projectPerson__list > li {
  padding: 0 70px;
  position: relative;
}
.projectPerson__list > li dl {
  letter-spacing: 0.02em;
}
.projectPerson__list > li dl .image {
  width: 200px;
  margin: 0 auto 15px;
}
.projectPerson__list > li dl .name,.projectPerson__list > li dl .join {
  margin-top: 5px;
}
.projectPerson__list > li:not(:last-child):after {
  content: "";
  width: 30px;
  height: 30px;
  background: url(../img/jobs/prj-x.png) center center/contain no-repeat;
  display: block;
  position: absolute;
  right: 0;
  top: 85px;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
}
.projectPerson__list--2 > li {
  padding: 0 40px;
}
.projectText {
  background: rgba(255, 248, 242, 0.8);
  border-radius: 20px;
  padding: 130px 17%;
  margin: 100px 0 220px;
}
.projectText--2 {
  margin-bottom: 220px;
}
.projectText h3 {
  margin-bottom: 2em;
}
.projectText .image--1 {
  margin: 80px -48% -260px 0;
}
.projectText .image--1 img {
  display: block;
}
.projectText .image--2 {
  margin: 80px -15% -260px;
}
.projectText .image--3 {
  max-width: 100%;
  margin: 80px -34% -260px auto;
}
.projectText .image--4 {
  margin: 80px 0 -260px -48%;
}
@media screen and (max-width: 428px) {
  .projectPerson {
    border-radius: 10px;
    padding: 20px 0 30px;
  }
  .projectPerson__wrapper:after {
    display: none;
  }
  .projectPerson__list {
    justify-content: space-between;
    margin-top: 10px;
  }
  .projectPerson__list > li {
    padding: 0 5px;
    position: relative;
  }
  .projectPerson__list > li dl .image {
    width: 80px;
    margin: 0 auto 15px;
  }
  .projectPerson__list > li dl .name,.projectPerson__list > li dl .join {
    margin-top: 0px;
  }
  .projectPerson__list > li:not(:last-child):after {
    width: 30px;
    height: 30px;
    top: 50px;
  }
  .projectPerson__wrapper01 .projectPerson__list > li:first-child::after{
    right: -78vw;
    transform: translateX(-50vw);
  }
  .projectPerson__list > li:first-child::after{
    right: -20px;
  }
  .projectPerson__list > li:nth-child(2)::after{
    right: -8px;
  }
  .projectPerson__list--2 > li {
    padding: 0 10px;
    -ms-flex-preferred-size: 33.3%;
        flex-basis: 33.3%;
    maxw-width: 33.3%;
  }
  .projectPerson__list--2 > li dl .image {
    width: 80px;
    margin: 0 auto 15px;
  }
  .projectPerson__list--2 > li dl .name {
    margin-top: 0px;
  }
  .projectPerson__list--2 > li:not(:last-child):after {
    width: 20px;
    height: 20px;
    top: 30px;
    -webkit-transform: translateX(40%);
            transform: translateX(40%);
  }
  .projectText {
    border-radius: 10px;
    padding: 10vw 5vw;
    margin: 15vw 0 15vw;
  }
  .projectText--2 {
    margin-bottom: 35vw;
  }
  .projectText h3 {
    margin-bottom: 2em;
    margin-right: -1em;
  }
  .projectText .image--1 {
    margin: 5vw -8vw -15vw 0;
  }
  .projectText .image--1 img {
    display: block;
  }
  .projectText .image--2 {
    margin: 20px 0 -35vw;
  }
  .projectText .image--3 {
    max-width: 100%;
    margin: 30px -6vw -15vw auto;
  }
  .projectText .image--4 {
    margin: 5vw 0 -15vw -8vw;
  }
}

.prjAida-image {
  margin-top: 220px;
}
@media screen and (max-width: 428px) {
  .prjAida-image {
    margin-top: 35vw;
  }
}

.prjProfile {
  margin: 100px 0 135px;
  background: #E0AF52;
  padding: 140px 0 100px;
}
.prjProfile__image {
  max-width: 580px;
  margin: 0 auto;
}
.prjProfile h4 {
  margin: 80px 0;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
.prjProfile p {
  font-size: 15px;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 428px) {
  .prjProfile {
    margin: 10vw 0 15vw;
    padding: 10vw 0 15vw;
  }
  .prjProfile h4 {
    margin: 10vw 0;
    font-size: 15px;
    font-weight: 500;
    text-align: center;
  }
  .prjProfile p {
    font-size: 13px;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}

.reportMovie {
  background: #E60012;
  color: #fff;
  padding: 60px 11%;
  position: relative;
}
.reportMovie:after {
  content: "MOVIE";
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  color: #fff;
  line-height: 1;
  position: absolute;
  right: 20px;
  top: 30px;
  font-size: 60px;
  letter-spacing: 0.06em;
}
.reportMovie__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 60px -11px 0;
  font-size: 14px;
  font-weight: 500;
}
.reportMovie__list > * {
  padding: 0 11px;
}
.reportMovie__list > * span {
  display: block;
  margin-top: 10px;
  position: relative;
}
.reportMovie__list > * span:after {
  content: "";
  width: 52px;
  height: 52px;
  background: url(../img/jobs/icon-play.png) center center/contain no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.reportBlock {
  padding: 100px 0;
  border-radius: 20px;
  margin-bottom: 60px;
}
.reportBlock p {
  font-size: 15px;
  line-height: 2;
}
.reportBlock__lead {
  font-size: 18px !important;
  font-weight: 500;
  margin-top: 60px;
}
.reportBlock__flow li {
  margin-bottom: 10px;
  padding: 8px 0;
}
.reportBlock__flow li dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.reportBlock__flow li dl dt {
  -ms-flex-preferred-size: 70px;
      flex-basis: 70px;
  max-width: 70px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-right: 1px solid #fff;
  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;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
}
.reportBlock__flow li dl dd {
  padding: 10px 20px;
  line-height: 2;
}
.reportBlock__image {
  margin: 0 -19%;
}
.reportBlock__image ul {
  margin: 0 -10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.reportBlock__image ul > li {
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
  padding: 0 10px;
}
.reportBlock--1 {
  background: rgba(155, 173, 96, 0.1);
}
.reportBlock--1 h3 {
  color: #9BAD60;
}
.reportBlock--1 .reportBlock__flow li {
  background: #9BAD60;
}
.reportBlock--1 .reportBlock__lead {
  color: #9BAD60;
}
.reportBlock--2 {
  background: rgba(57, 147, 195, 0.1);
}
.reportBlock--2 h3 {
  color: #3993C3;
}
.reportBlock--2 .reportBlock__flow li {
  background: #3993C3;
}
.reportBlock--2 .reportBlock__lead {
  color: #3993C3;
}
@media screen and (max-width: 428px) {
  .reportMovie {
    padding: 30px 2vw 5vw;
  }
  .reportMovie:after {
    right: 3vw;
    top: 5vw;
    font-size: 32px;
  }
  .reportMovie h3 {
    margin-top: 10vw;
  }
  .reportMovie__list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 10vw 0 0;
    font-size: 13px;
    line-height: 1.2;
    text-align: center;
  }
  .reportMovie__list > * {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
    padding: 0 5px;
    margin-bottom: 5vw;
  }
  .reportMovie__list > * p {
    line-height: 1.5;
  }
  .reportMovie__list > * a {
    display: block;
    margin-top: 10px;
    position: relative;
  }
  .reportMovie__list > * a:after {
    width: 30px;
    height: 30px;
  }
  .reportBlock {
    padding: 10vw 0;
    border-radius: 10px;
    margin-bottom: 10vw;
  }
  .reportBlock p {
    font-size: 13px;
  }
  .reportBlock__lead {
    font-size: 14px !important;
    margin-top: 30px;
  }
  .reportBlock__flow li {
    margin-bottom: 10px;
    padding: 8px 0;
  }
  .reportBlock__flow li dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .reportBlock__flow li dl dt {
    -ms-flex-preferred-size: 50px;
        flex-basis: 50px;
    max-width: 50px;
  }
  .reportBlock__flow li dl dd {
    padding: 8px 10px;
    line-height: 1.8;
    font-size: 13px;
  }
  .reportBlock__image {
    margin: 0 -7vw;
  }
  .reportBlock__image ul {
    margin: 0 -2vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .reportBlock__image ul > li {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
    padding: 0 5px;
  }
  .reportBlock--1 {
    background: rgba(155, 173, 96, 0.1);
  }
  .reportBlock--1 h3 {
    color: #9BAD60;
  }
  .reportBlock--1 .reportBlock__flow li {
    background: #9BAD60;
  }
  .reportBlock--1 .reportBlock__lead {
    color: #9BAD60;
  }
  .reportBlock--2 {
    background: rgba(57, 147, 195, 0.1);
  }
  .reportBlock--2 h3 {
    color: #3993C3;
  }
  .reportBlock--2 .reportBlock__flow li {
    background: #3993C3;
  }
  .reportBlock--2 .reportBlock__lead {
    color: #3993C3;
  }
}

.factory__list {
  margin: 0 -30px;
}
.factory__list ul {
  -webkit-columns: 3;
     -moz-columns: 3;
          columns: 3;
  margin: 0 -30px;
}
.factory__list ul > * {
  padding: 30px;
}
.factory__list dl .image img {
  display: block;
  max-width: 280px;
  margin: 0 auto;
}
.factoryBlock:before {
  content: "";
  margin: 150px auto 70px;
  display: block;
}
.factoryBlock h3 {
  max-width: 650px;
  width: 100%;
  margin: 0 auto 0px;
  border-radius: 10em;
  padding: 20px 0;
}
.factoryBlockColumn {
  margin: 0 -90px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 20px 0 150px;
}
.factoryBlockColumn > li {
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
  padding: 60px 90px 20px;
}
.factoryBlockColumn > li dl dt {
  font-size: 18px;
  letter-spacing: 0.02em;
  font-weight: 500;
  margin-bottom: 30px;
}
.factoryBlockColumn > li dl dd {
  font-size: 15px;
  line-height: 2;
  letter-spacing: 0.02em;
}
.factoryBlockColumn > li dl dd img {
  display: block;
  margin-top: 30px;
}
.factoryBlock--1 h3 {
  background-color: #DD5840;
}
.factoryBlock--1:before {
  width: 96px;
  height: 94px;
  background: url(../img/jobs/factory-icon-1.png) center center/contain no-repeat;
}
.factoryBlock--1 .factoryBlockColumn {
  background: url(../img/jobs/clm-bg1.png) center bottom/380px auto no-repeat;
}
.factoryBlock--2 h3 {
  background-color: #9BAD60;
}
.factoryBlock--2:before {
  width: 96px;
  height: 67px;
  background: url(../img/jobs/factory-icon-2.png) center center/contain no-repeat;
}
.factoryBlock--2 .factoryBlockColumn {
  background: url(../img/jobs/clm-bg2.png) center bottom/380px auto no-repeat;
}
.factoryBlock--3 h3 {
  background-color: #E0AF52;
}
.factoryBlock--3:before {
  width: 96px;
  height: 92px;
  background: url(../img/jobs/factory-icon-3.png) center center/contain no-repeat;
}
.factoryBlock--3 .factoryBlockColumn {
  background: url(../img/jobs/clm-bg3.png) center bottom/380px auto no-repeat;
}
@media screen and (max-width: 428px) {
  .factory__list {
    margin: 0 0px;
  }
  .factory__list ul {
    -webkit-columns: 1;
       -moz-columns: 1;
            columns: 1;
    margin: 0 0;
  }
  .factory__list ul > * {
    padding: 0px 0 5vw;
  }
  .factory__list dl {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 10px 2fr;
    grid-template-columns: 1fr 2fr;
    -ms-grid-rows: auto, 1fr;
    grid-template-rows: auto, 1fr;
    grid-column-gap: 10px;
    grid-row-gap: 0px;
  }
  .factory__list dl > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .factory__list dl > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .factory__list dl > *:nth-child(3) {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .factory__list dl > *:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
  .factory__list dl > *:nth-child(5) {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
  }
  .factory__list dl > *:nth-child(6) {
    -ms-grid-row: 5;
    -ms-grid-column: 3;
  }
  .factory__list dl .image {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 1/1/3/2;
  }
  .factory__list dl .image img {
    display: block;
    max-width: 280px;
    margin: 0 auto;
  }
  .factory__list dl .name {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/2/3;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-bottom: 0 !important;
    text-align: left;
  }
  .factory__list dl .image {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    max-width: 100px;
  }
  .factory__list dl .text {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 2/2/3/3;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    margin-top: 0 !important;
    line-height: 1.6;
  }
  .factoryBlock:before {
    content: "";
    margin: 10vw auto 5vw;
  }
  .factoryBlock h3 {
    margin: 0 auto 0;
    padding: 15px 0;
  }
  .factoryBlockColumn {
    margin: 0 0px;
    padding: 5vw 0 0;
    display: block;
  }
  .factoryBlockColumn > li {
    padding: 5vw 5vw 5vw;
    max-width: 100%;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
  .factoryBlockColumn > li dl dt {
    font-size: 15px;
    margin-bottom: 2vw;
  }
  .factoryBlockColumn > li dl dd {
    font-size: 13px;
    line-height: 1.6;
  }
  .factoryBlockColumn > li dl dd img {
    display: block;
    margin-top: 5vw;
  }
  .factoryBlock--1:before {
    width: 67px;
    height: 65px;
  }
  .factoryBlock--1 .factoryBlockColumn {
    background: none;
  }
  .factoryBlock--2:before {
    width: 67px;
    height: 46px;
  }
  .factoryBlock--2 .factoryBlockColumn {
    background: none;
  }
  .factoryBlock--3:before {
    width: 67px;
    height: 64px;
  }
  .factoryBlock--3 .factoryBlockColumn {
    background: none;
  }
}

.rdeConcept {
  background: #E60012;
  border-radius: 20px;
  color: #fff;
}
.rdeConcept ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.rdeConcept ul > li {
  padding: 40px 55px;
  text-align: center;
}
.rdeConcept ul > li h3 {
  color: #fff;
  font-weight: 500;
  margin-bottom: 30px;
  text-transform: uppercase;
}
.rdeConcept ul > li h3:before {
  content: attr(data-cpt);
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-weight: 500;
  display: block;
  border-bottom: 7px solid #fff;
  font-size: 60px;
  text-align: center;
  display: inline-block;
}
.rdeConcept ul > li h3 span {
  display: block;
  font-size: 18px;
  letter-spacing: 0.08em;
  margin-top: 10px;
}
.rdeBlock {
  background: #FFF8F2;
  border-radius: 20px;
  padding: 80px 10%;
  margin: 110px 0;
  position: relative;
}
.rdeBlock__orn {
  color: rgba(230, 0, 18, 0.6);
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 24px;
  position: absolute;
  top: 0;
  right: -2%;
  letter-spacing: 0.08em;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  line-height: 0.8;
  vertical-align: bottom;
  font-weight: 500;
}
.rdeBlock__orn span {
  font-size: 64px;
  vertical-align: bottom;
}
.rdeBlock__column {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
}
.rdeBlock__column .columnimage {
  margin-top: 0;
  width: 140%;
  margin-bottom: -150px;
  -webkit-transform: translateX(88px);
          transform: translateX(88px);
}
.rdeBlock__column .columnimage img {
  display: block;
  width: 100%;
}
.rdeBlock .image--1 {
  max-width: 588px;
  margin: 50px auto 20px;
}
.rdeBlock .image--2 {
  max-width: 351px;
  margin: 50px auto 0px;
}
.rdeBlock .image--3 {
  max-width: 351px;
  margin: 50px auto 0px;
}
.rdeBlock .image--4 {
  margin: 50px auto -250px;
}
.rdeBlock .image--5 {
  margin: 50px -30% -250px 0;
}
.rdeBlock--area {
  background: #F3F5EC;
  margin: 150px 0 200px;
}
.rdeBlock--area h3 {
  color: #9BAD60;
}
.rdeBlock--area2 {
  margin-top: 350px;
}
.rdeBlock__floor {
  position: absolute;
  top: 0;
  left: 50%;
  font-size: 30px;
  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;
  letter-spacing: 0.08em;
  width: 120px;
  height: 120px;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: #F3F5EC;
  font-weight: 500;
  border-radius: 10em;
}
.rdeTitle {
  font-size: 18px;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.04em;
  margin-top: 210px;
}
.rdeTitle:before {
  content: attr(data-rde);
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-weight: 500;
  display: block;
  border-bottom: 7px solid #fff;
  font-size: 80px;
  text-align: center;
  letter-spacing: 0.08em;
  margin-bottom: 10px;
}
.rdeTitle__lead {
  margin: 80px 0 80px;
  font-size: 20px;
  letter-spacing: 0.04em;
  text-align: center;
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 428px) {
  .rdeConcept {
    border-radius: 10px;
  }
  .rdeConcept ul > li {
    padding: 20px 10px;
    text-align: center;
  }
  .rdeConcept ul > li h3 {
    margin-bottom: 10px;
  }
  .rdeConcept ul > li h3:before {
    border-bottom: 4px solid #fff;
    font-size: 30px;
  }
  .rdeConcept ul > li h3 span {
    font-size: 13px;
    margin-top: 10px;
  }
  .rdeBlock {
    border-radius: 10px;
    padding: 10vw 5vw;
    margin: 15vw 0;
  }
  .rdeBlock__orn {
    font-size: 15px;
    right: 4%;
  }
  .rdeBlock__orn span {
    font-size: 27px;
  }
  .rdeBlock__column {
    display: block;
  }
  .rdeBlock__column .columnimage {
    width: 90%;
    margin: 5vw auto 0;
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
  .rdeBlock__column .columnimage img {
    display: block;
    width: 100%;
  }
  .rdeBlock .image--1 {
    margin: 10vw auto 0px;
  }
  .rdeBlock .image--2 {
    max-width: 351px;
    margin: 10vw auto 0px;
  }
  .rdeBlock .image--3 {
    max-width: 351px;
    margin: 10vw auto 0px;
  }
  .rdeBlock .image--4 {
    margin: 10vw auto 0px;
  }
  .rdeBlock .image--5 {
    margin: 10vw 0 0px 0;
  }
  .rdeBlock--area {
    background: #F3F5EC;
    margin: 15vw 0 15vw;
  }
  .rdeBlock--area2 {
    margin-top: 20vw;
  }
  .rdeBlock__floor {
    font-size: 20px;
    width: 60px;
    height: 60px;
  }
  .rdeTitle {
    font-size: 14px;
    margin-top: 15vw;
  }
  .rdeTitle:before {
    border-bottom: 5px solid #fff;
    font-size: 34px;
    margin-bottom: 5px;
  }
  .rdeTitle__lead {
    margin: 30px 0 30px;
    font-size: 15px;
  }
}

/*============================
PEOPLE
============================*/
.peopleMV {
  width: 100%;
  height: 100vh;
}
.peopleMV .image {
  position: fixed;
  top: 0;
  left: 0;
}
.peopleMV .image:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #BABABA;
  mix-blend-mode: multiply;
  z-index: 1;
}
.peopleMV .image img {
  width: 100vw;
  height: 100vh;
  -o-object-fit: cover;
     object-fit: cover;
}
.peopleMV .lead {
  position: absolute;
  z-index: 2;
  left: 11vw;
  bottom: 80px;
  -webkit-animation: 1s 0.8s mvH1In ease-out both;
          animation: 1s 0.8s mvH1In ease-out both;
}
.peopleMV .lead p {
  font-size: 38px;
  font-size: 2.96875vw;
}
.peopleMV .title {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 75vw;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  line-height: 2;
}
.peopleMV .title .commonH1 {
  color: #fff;
}
.peopleMV .title .commonH1 > p {
  font-size: 15px;
  font-size: 1.171875vw;
  margin-bottom: 50px;
}
.peopleMV .title .commonH1:before {
  content: attr(data-en);
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 14px;
  font-size: 1.09375vw;
}
.peopleMV .title h1 {
  margin-top: 50px;
  font-size: 20px;
  color: #fff;
  font-size: 1.5625vw;
}
.peopleMV .title h1 span {
  display: block;
  font-size: 15px;
  font-size: 1.171875vw;
  font-weight: 400;
}
.peopleMV-top {
  position: relative;
  z-index: 0;
}
.peopleMV-top .image {
  -webkit-animation: 0.5s 0.3s mvIn ease-in both;
          animation: 0.5s 0.3s mvIn ease-in both;
}
.peopleMV-top .text {
  position: absolute;
  right: 11vw;
  bottom: 5vw;
  z-index: 3;
  color: #fff;
}
.peopleMV-top .title {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-left: 11vw;
}
.peopleMV-top .title .commonH1 {
  z-index: 2;
  color: #fff;
  font-size: 18px;
  font-size: 1.40625vw;
  letter-spacing: 0.06em;
  font-weight: 400;
  -webkit-animation: 1s 0.8s mvH1In ease-out both;
          animation: 1s 0.8s mvH1In ease-out both;
}
.peopleMV-top .title .commonH1:before {
  display: block;
  content: attr(data-en);
  text-transform: uppercase;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 90px;
  font-size: 7.03125vw;
  letter-spacing: 0.08em;
  margin-bottom: 10px;
  font-weight: 500;
  white-space: pre;
}
.peopleMV-talk {
  position: relative;
  z-index: 0;
}
.peopleMV-talk .image {
  -webkit-animation: 0.5s 0.3s mvIn ease-in both;
          animation: 0.5s 0.3s mvIn ease-in both;
}
.peopleMV-talk .text {
  position: absolute;
  right: 11vw;
  bottom: 5vw;
  z-index: 3;
  color: #fff;
}
.peopleMV-talk .text p {
  font-size: 27px;
  font-size: 2.109375vw;
}
.peopleMV-talk .title {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-left: 11vw;
  padding-top: 17vw;
}
.peopleMV-talk .title .commonH1 {
  z-index: 2;
  color: #fff;
  font-size: 18px;
  font-size: 1.40625vw;
  letter-spacing: 0.06em;
  font-weight: 400;
  -webkit-animation: 1s 0.8s mvH1In ease-out both;
          animation: 1s 0.8s mvH1In ease-out both;
}
.peopleMV-talk .title .commonH1:before {
  display: block;
  content: attr(data-en);
  text-transform: uppercase;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 90px;
  font-size: 7.03125vw;
  letter-spacing: 0.08em;
  margin-bottom: 10px;
  font-weight: 500;
  white-space: pre;
}
.peopleLists__wrapper {
  background: #fff;
  padding-top: 100px;
}
.peopleListsSec__inner {
  border-radius: 10px;
  background: #FFF8F2;
  padding: 70px 100px 50px;
}
.peopleListsSec__inner > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 -8px;
}

.peopleListsSec__inner > ul::after{
  content:"";
  display: block;
  width:33%;
}
.peopleListsSec__inner > ul > * {
  padding: 0 8px 70px;
  -ms-flex-preferred-size: 33.3%;
      flex-basis: 33.3%;
  max-width: 33.3%;
}
.peopleListsSec__inner > ul > * dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
}
.peopleListsSec__inner > ul > * dl .name {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin: 10px 0 5px;
}
.peopleListsSec__inner > ul > * dl .image {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.peopleListsSec__inner > ul > * dl .image img {
  border-radius: 5px;
}
.peopleListsSec__inner > ul > * dl .sec {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  line-height: 2;
}
.peopleListsSec__inner > ul > * dl .genre {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 13px;
  color: #fff;
  display: inline-block;
  padding: 0.3em 1em;
  border-top-left-radius: 5px;
  border-bottom-right-radius: 5px;
}
.peopleListsSec__inner > ul > * dl .genre--ow {
  background: #6FA9C3;
}
.peopleListsSec__inner > ul > * dl .genre--tw {
  background: #9BAD60;
}
.peopleListsSec__inner > ul > * dl .genre--te {
  background: #4DAA6A;
}
.peopleListsSec__inner > ul > * a {
  color: #000;
  text-decoration: none;
}
.peopleCatch {
  border-radius: 10px;
  background: rgba(154, 154, 154, 0.9);
  padding: 90px 17%;
  margin: 150px 0 130px;
}
.peopleCatch h2 {
  margin-bottom: 50px;
}
.peopleCnt {
  background: #fff;
  border-radius: 10px;
  padding-top: 95px;
}
.peopleCnt__blc {
  margin: 0 0 135px;
  padding: 0 15%;
}
.peopleCnt__blc h3 {
  font-size: 28px;
  font-weight: 500;
  line-height: 2;
  margin-bottom: 65px;
  margin-right: -5em;
}
.peopleCnt__blc--1 .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-right: -23%;
}
.peopleCnt__blc--1 .inner .text {
  -ms-flex-preferred-size: 400px;
      flex-basis: 400px;
  max-width: 400px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.peopleCnt__blc--1 .inner .image {
  -webkit-transform: translateX(50px);
          transform: translateX(50px);
}
.peopleCnt__blc--1 .inner .image img {
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
.peopleCnt__blc--2 h3 {
  padding-left: 52%;
}
.peopleCnt__blc--2 .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: -23%;
}
.peopleCnt__blc--2 .inner .text {
  -ms-flex-preferred-size: 400px;
      flex-basis: 400px;
  max-width: 400px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.peopleCnt__blc--2 .inner .image {
  -webkit-transform: translateX(-50px);
          transform: translateX(-50px);
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.peopleCnt__blc--2 .inner .image img {
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.peopleCnt__blc--3 .image {
  margin: 0 -10%;
}
.peopleCnt__blc--3 .image img {
  border-radius: 10px;
}
.peopleCnt__schedule {
  background: #F5F5F5;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  padding: 100px 0 110px;
}
.peopleCnt__schedule h3 {
  padding-left: 8%;
  font-size: 48px;
  color: #E60012;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  text-transform: uppercase;
}
.peopleCnt__schedule .scheduleDay {
  padding-top: 10px;
  padding-bottom: 70px;
}
.peopleCnt__schedule .scheduleDay__wrapper {
  padding-left: 8%;
}
.peopleCnt__schedule .scheduleDay__blc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.peopleCnt__schedule .scheduleDay__blc dt {
  font-size: 26px;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  padding-right: 2em;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.peopleCnt__schedule .scheduleDay__blc dd {
  font-size: 15px;
}
.peopleCnt__schedule .swiper {
  padding-right: 35%;
  padding-top: 120px;
  position: relative;
}
.peopleCnt__schedule .swiper .swiper-slide {
  padding-right: 140px;
}
.peopleCnt__schedule .swiper-button-prev,
.peopleCnt__schedule .swiper-button-next {
  width: 15px;
  height: 30px;
  position: absolute;
  background: url(../img/people/p-cursor.svg) center center/contain no-repeat;
  top: 70px;
}
.peopleCnt__schedule .swiper-button-prev:before, .peopleCnt__schedule .swiper-button-prev:after,
.peopleCnt__schedule .swiper-button-next:before,
.peopleCnt__schedule .swiper-button-next:after {
  display: none;
}
.peopleCnt__schedule .swiper-button-prev {
  left: auto;
  right: 160px;
}
.peopleCnt__schedule .swiper-button-next {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  right: 100px;
}
.peopleCnt__schedule .swiper-scrollbar {
  width: 90%;
}
.peopleCnt__schedule .holiday {
  max-width: 56%;
  max-width: 60%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 150px auto 0 16%;
}
.peopleCnt__schedule .holiday .text {
  margin-right: 60px;
  max-width: 434px;
  -ms-flex-preferred-size: 434px;
      flex-basis: 434px;
}
.peopleCnt__schedule .holiday .text h4 {
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 20px;
}
.peopleCnt__schedule .holiday .text p {
  font-size: 15px;
  line-height: 2;
}
.peopleCnt__schedule .holiday .image {
  max-width: 166px;
  min-height: 200px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.peopleNav {
  margin-top: 100px;
  background: #fff;
  border-radius: 10px;
  padding: 93px 100px;
}
.peopleNav__inner {
  padding: 0 80px;
  position: relative;
}
.peopleNav .peopleNav-swiper {
  width: 100%;
  overflow: hidden;
}
.peopleNav .swiper-wrapper {
  position: relative;
}
.peopleNav .swiper-slide {
  padding: 0 20px;
  text-align: center;
}
.peopleNav .swiper-slide a {
  text-decoration: none;
  color: #000;
}
.peopleNav .swiper-slide img {
  margin-bottom: 10px;
}
.peopleNav .swiper-slide p {
  font-size: 13px;
}
.peopleNav .swiper-button2-prev,
.peopleNav .swiper-button2-next {
  width: 15px;
  height: 30px;
  position: absolute;
  background: url(../img/people/p-cursor.svg) center center/contain no-repeat;
  top: 80px;
}
.peopleNav .swiper-button2-prev:before, .peopleNav .swiper-button2-prev:after,
.peopleNav .swiper-button2-next:before,
.peopleNav .swiper-button2-next:after {
  display: none;
}
.peopleNav .swiper-button2-prev-disabled,
.peopleNav .swiper-button2-next-disabled {
  opacity: 0.5;
}
.peopleNav .swiper-button-prev {
  left: 0;
}
.peopleNav .swiper-button-next {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  right: 0px;
}
.peopleNav .swiper-button-prev,
.peopleNav .swiper-button-next {
  width: 15px;
  height: 30px;
  position: absolute;
  background: url(../img/people/p-cursor.svg) center center/contain no-repeat;
  top: 80px;
}
.peopleNav .swiper-button-prev:before, .peopleNav .swiper-button-prev:after,
.peopleNav .swiper-button-next:before,
.peopleNav .swiper-button-next:after {
  display: none;
}
.peopleNav .swiper-button-prev {
  left: 0;
}
.peopleNav .swiper-button-next {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  right: 0px;
}
@media screen and (max-width: 428px) {
  .peopleMV {
    width: 100%;
    height: 100vh;
  }
  .peopleMV .image img {
    width: 100vw;
    height: 100vh;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .peopleMV .image--1 img {
    -o-object-position: 60% center;
       object-position: 60% center;
  }
  .peopleMV .image--2 img {
    -o-object-position: 30% center;
       object-position: 30% center;
  }
  .peopleMV .image--5 img {
    -o-object-position: 45% center;
       object-position: 45% center;
  }
  .peopleMV .image--6 img {
    -o-object-position: 55% center;
       object-position: 55% center;
  }
  .peopleMV .image--7 img {
    -o-object-position: 55% center;
       object-position: 55% center;
  }
  .peopleMV .image--10 img {
    -o-object-position: 55% center;
       object-position: 55% center;
  }
  .peopleMV .image--11 img {
    -o-object-position: 60% center;
       object-position: 60% center;
  }
  .peopleMV .image--12 img {
    -o-object-position: 35% center;
       object-position: 35% center;
  }
  .peopleMV .lead {
    position: absolute;
    z-index: 2;
    left: 5vw;
    bottom: 0px;
  }
  .peopleMV .lead p {
    font-size: 16px;
  }
  .peopleMV .title {
    top: 70%;
    right: auto;
    left: 5vw;
  }
  .peopleMV .title .commonH1 > p {
    font-size: 12px;
    margin-bottom: 15px;
  }
  .peopleMV .title .commonH1:before {
    font-size: 10px;
  }
  .peopleMV .title h1 {
    margin-top: 15px;
    font-size: 16px;
  }
  .peopleMV .title h1 span {
    display: block;
    font-size: 12px;
    line-height: 1.5;
  }
  .peopleMV-top .text {
    position: absolute;
    right: 6vw;
    bottom: 3vw;
    z-index: 3;
    color: #fff;
  }
  .peopleMV-top .text p {
    font-size: 12px;
    line-height: 2;
  }
  .peopleMV-top .title {
    padding-top: 15vw;
    padding-left: 6vw;
  }
  .peopleMV-top .title .commonH1 {
    font-size: 13px;
  }
  .peopleMV-top .title .commonH1:before {
    font-size: 28px;
  }
  .peopleMV-talk .text {
    right: 6vw;
    bottom: 3vw;
  }
  .peopleMV-talk .text p {
    font-size: 13px;
  }
  .peopleMV-talk .title {
    padding-left: 6vw;
    padding-top: 17vw;
  }
  .peopleMV-talk .title .commonH1 {
    font-size: 12px;
  }
  .peopleMV-talk .title .commonH1:before {
    font-size: 28px;
  }
  .peopleLists__wrapper {
    padding-top: 10vw;
  }
  .peopleListsSec__inner {
    padding: 10vw 5vw 10vw;
  }
  .peopleListsSec__inner > ul {
    margin: 0 -2vw;
  }
  .peopleListsSec__inner > ul > * {
    padding: 0 2vw 5vw;
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .peopleListsSec__inner > ul > * dl .name {
    margin: 5px 0 2px;
  }
  .peopleListsSec__inner > ul > * dl .genre {
    font-size: 10px;
    padding: 0.3em 0.5em;
  }
  .peopleCatch {
    border-radius: 5px;
    background: rgba(154, 154, 154, 0.9);
    padding: 10vw 5vw;
    margin: 10vw 0 15vw;
  }
  .peopleCatch h2 {
    margin-bottom: 15px;
  }
  .peopleCnt {
    border-radius: 5px;
    padding-top: 10vw;
  }
  .peopleCnt__blc {
    margin: 0 0 15vw;
    padding: 0 5vw;
  }
  .peopleCnt__blc h3 {
    font-size: 16px;
    margin-bottom: 5vw;
    margin-right: 0;
  }
  .peopleCnt__blc--1 .inner {
    display: block;
    margin-right: 0;
  }
  .peopleCnt__blc--1 .inner .text {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
    max-width: none;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    margin-bottom: 5vw;
  }
  .peopleCnt__blc--1 .inner .image {
    -webkit-transform: translateX(8vw);
            transform: translateX(8vw);
  }
  .peopleCnt__blc--1 .inner .image img {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
  }
  .peopleCnt__blc--2 h3 {
    padding-left: 0;
  }
  .peopleCnt__blc--2 .inner {
    display: block;
    margin-left: 0;
  }
  .peopleCnt__blc--2 .inner .text {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
    max-width: none;
    margin-bottom: 5vw;
  }
  .peopleCnt__blc--2 .inner .image {
    -webkit-transform: translateX(-8vw);
            transform: translateX(-8vw);
  }
  .peopleCnt__blc--2 .inner .image img {
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
  }
  .peopleCnt__blc--3 .image {
    margin: 0 -6vw;
  }
  .peopleCnt__blc--3 .image img {
    border-radius: 5px;
  }
  .peopleCnt__schedule {
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    padding: 10vw 0 15vw;
  }
  .peopleCnt__schedule h3 {
    padding-left: 5vw;
    font-size: 20px;
  }
  .peopleCnt__schedule .scheduleDay {
    padding-top: 10px;
    padding-bottom: 5vw;
  }
  .peopleCnt__schedule .scheduleDay__wrapper {
    padding-left: 8%;
  }
  .peopleCnt__schedule .scheduleDay__blc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .peopleCnt__schedule .scheduleDay__blc dt {
    font-size: 16px;
  }
  .peopleCnt__schedule .scheduleDay__blc dd {
    font-size: 12px;
  }
  .peopleCnt__schedule .swiper {
    padding-right: 10%;
    padding-top: 20vw;
  }
  .peopleCnt__schedule .swiper .swiper-slide {
    padding-right: 10vw;
  }
  .peopleCnt__schedule .swiper-button-prev,
.peopleCnt__schedule .swiper-button-next {
    width: 9px;
    height: 18px;
    top: 15vw;
  }
  .peopleCnt__schedule .swiper-button-prev:before, .peopleCnt__schedule .swiper-button-prev:after,
.peopleCnt__schedule .swiper-button-next:before,
.peopleCnt__schedule .swiper-button-next:after {
    display: none;
  }
  .peopleCnt__schedule .swiper-button-prev {
    left: auto;
    right: 15vw;
  }
  .peopleCnt__schedule .swiper-button-next {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
    right: 8vw;
  }
  .peopleCnt__schedule .swiper-scrollbar {
    width: 90%;
  }
  .peopleCnt__schedule .holiday {
    max-width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 5vw;
    margin: 15vw auto 0 0;
  }
  .peopleCnt__schedule .holiday .text {
    margin-right: 5vw;
  }
  .peopleCnt__schedule .holiday .text h4 {
    font-size: 15px;
    margin-bottom: 10px;
  }
  .peopleCnt__schedule .holiday .text p {
    font-size: 12px;
  }
  .peopleCnt__schedule .holiday .image {
    max-width: 30%;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .peopleNav {
    margin-top: 50px;
    background: #fff;
    border-radius: 5px;
    padding: 5vw 0vw;
  }
  .peopleNav__inner {
    padding: 0 5vw;
    position: relative;
  }
  .peopleNav .peopleNav-swiper {
    overflow: hidden;
  }
  .peopleNav .swiper-wrapper {
    position: relative;
  }
  .peopleNav .swiper-slide {
    padding: 0 5px;
    text-align: center;
  }
  .peopleNav .swiper-slide a {
    text-decoration: none;
    color: #000;
  }
  .peopleNav .swiper-slide img {
    margin-bottom: 10px;
  }
  .peopleNav .swiper-slide p {
    font-size: 10px;
    line-height: 1.5;
  }
  .peopleNav .swiper-button-prev,
.peopleNav .swiper-button-next {
    width: 9px;
    height: 18px;
    position: absolute;
    background: url(../img/people/p-cursor.svg) center center/contain no-repeat;
    top: 80px;
  }
  .peopleNav .swiper-button-prev:before, .peopleNav .swiper-button-prev:after,
.peopleNav .swiper-button-next:before,
.peopleNav .swiper-button-next:after {
    display: none;
  }
  .peopleNav .swiper-button-prev {
    left: 5px;
  }
  .peopleNav .swiper-button-next {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
    right: 5px;
  }
}

.talkMembers h2 {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
}
.talkMembers ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 -15px;
}
.talkMembers ul li {
  padding: 0 15px;
  -ms-flex-preferred-size: 16%;
      flex-basis: 16%;
  max-width: 16%;
}
.talkMembers ul li dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.talkMembers ul li dl .name {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.talkMembers ul li dl .sec {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  min-height: 10em;
}
.talkMembers ul li dl .dtl {
  -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
          order: 4;
}
.talkMembers ul li dl .image {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  margin-bottom: 10px;
}
.talkMembers ul li dl .image img {
  border-radius: 10px;
}
.talkBlc {
  background: #FFF8F2;
  border-radius: 20px;
  padding: 100px 200px;
  position: relative;
  margin-top: 100px;
  z-index: 2;
}
.talkBlc--2 {
  margin-top: -120px;
}
.talkBlc__orn {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  position: absolute;
  top: 55px;
  right: 50px;
  font-size: 26px;
  line-height: 1;
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.talkBlc__orn span {
  display: block;
  font-size: 80px;
  letter-spacing: 0.08em;
}
.talkBlc__image {
  margin: 0 -25px 55px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.talkBlc__image .image {
  padding: 0 25px;
}
.talkBlc__image .image--2 {
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
}
.talkBlc__image img {
  border-radius: 10px;
}
.talkBlc__bgimage {
  z-index: 0;
  margin: -120px 0 0;
}
.talkBlc .lead {
  padding-left: 135px;
}
.talkBlc p.int {
  margin: 0 -20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 55px;
  line-height: 2;
  letter-spacing: 0.02em;
}
.talkBlc p.int > * {
  padding: 0 20px;
}
.talkBlc p.int span {
  display: block;
}
.talkBlc p.int .image {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: block;
}
.talkBlc p.int .image img {
  border-radius: 10px;
  width: 95px;
}
.talkBlc p.int .name {
  font-size: 20px;
  font-weight: 500;
  display: block;
}
@media screen and (max-width: 428px) {
  .talkMembers ul {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0 -5px;
  }
  .talkMembers ul li {
    padding: 0 10px 20px;
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .talkMembers ul li dl .sec {
    min-height: 0;
    padding-bottom: 1em;
  }
  .talkMembers ul li dl .image img {
    border-radius: 5px;
  }
  .talkBlc {
    border-radius: 10px;
    padding: 10vw 5vw;
    position: relative;
    margin-top: 15vw;
  }
  .talkBlc--2 {
    margin-top: -10vw;
  }
  .talkBlc__orn {
    top: 15px;
    right: 10px;
    font-size: 12px;
  }
  .talkBlc__orn span {
    font-size: 30px;
  }
  .talkBlc__image {
    margin: 0 -5px 25px;
  }
  .talkBlc__image .image {
    padding: 0 5px;
  }
  .talkBlc__image .image--2 {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .talkBlc__image img {
    border-radius: 5px;
  }
  .talkBlc__bgimage {
    z-index: 0;
    margin: -10vw 0 0;
  }
  .talkBlc .lead {
    padding-left: 0;
    margin-right: -5vw;
  }
  .talkBlc p.int {
    margin: 0 -10px;
    margin-bottom: 25px;
  }
  .talkBlc p.int > * {
    padding: 0 10px;
  }
  .talkBlc p.int .image img {
    border-radius: 5px;
    width: 65px;
  }
  .talkBlc p.int .name {
    font-size: 14px;
    font-weight: 500;
    display: block;
    margin-top: -0.5em;
  }
}

/*============================
CAREER
============================*/
.career__lead {
  padding: 55px 0 105px;
}
.career__imagetitle {
  position: relative;
}
.career__imagetitle h3.title {
  font-size: 28px;
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  padding-bottom: 100px;
  width: 100%;
  height: 100%;
  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: 1;
}
.careerBlock {
  background: rgba(255, 248, 242, 0.8);
  overflow: hidden;
  border-radius: 20px;
  margin-top: 80px;
}
.careerBlock--1 {
  margin-top: -50px;
  position: relative;
  z-index: 1;
}
.careerBlock__bg {
  background: #FFEDDD;
}
.careerBlock h4 {
  font-size: 18px;
  padding-bottom: 20px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.careerBlock__text {
  padding: 100px 10% 100px;
}
.careerBlock__text--2 {
  padding: 100px 18% 100px;
}
.careerBlock__concept {
  max-width: 880px;
  margin: 0 auto;
}
.careerBlock__concept > dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 -50px;
}
.careerBlock__concept > dl > dt {
  -ms-flex-preferred-size: 30%;
      flex-basis: 30%;
  max-width: 30%;
  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;
}
.careerBlock__concept .nextstage {
  line-height: 2;
}
.careerBlock .concept__wrapper {
  background: #FFEDBA;
  border-radius: 20px;
  padding: 40px 0;
  margin-top: 100px;
}
.careerBlock .concept1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 -80px;
}
.careerBlock .concept1 > * {
  padding: 0 80px;
}
.careerBlock .concept1 > *:first-child {
  position: relative;
}
.careerBlock .concept1 > *:first-child:after {
  content: "";
  width: 30px;
  height: 30px;
  background: url(../img/career/ionic-ios-close.png) center center/contain no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(50%, -50%);
          transform: translate(50%, -50%);
}
.careerBlock__kaihatsu {
  margin: 0 -15%;
  padding: 45px 15%;
  background: rgba(249, 218, 221, 0.9);
  border-radius: 10px;
}
.career-icon {
  display: block;
  margin: 0 auto;
  max-width: 85px;
  margin-bottom: 10px;
}
.careerMoku {
  overflow: hidden;
  border-radius: 20px;
  margin: 60px 0 30px;
}
.careerMoku dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #C30110;
  color: #fff;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 60px;
}
.careerMoku dd {
  background: #F9DADD;
  padding: 45px;
}
.careerMezasu {
  margin: 30px 0 30px;
}
.careerMezasu dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #FFEDBA;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 60px;
  border-top-right-radius: 20px;
  border-top-left-radius: 20px;
}
.careerMezasu dd {
  background: #fff;
  padding: 0 45px;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
.careerMezasu dd ol > li {
  padding: 30px;
  position: relative;
}
.careerMezasu dd ol > li:not(:last-child) {
  border-bottom: 1px solid #BEC1C3;
}
.careerMezasu dd ol > li:after {
  content: "";
  width: 30px;
  height: 30px;
  background: url(../img/career/ionic-md-arrow-round-forward.png) center center/contain no-repeat;
  -webkit-transform: translate(-50%, 50%) rotate(-90deg);
          transform: translate(-50%, 50%) rotate(-90deg);
  position: absolute;
  bottom: 0;
  left: 50%;
}
.careerKitai {
  margin: 0 -10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.careerKitai > * {
  padding: 0 10px;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
  position: relative;
}
.careerKitai > *:not(:last-child):after {
  content: "";
  width: 38px;
  height: 38px;
  background: url(../img/career/ionic-md-arrow-round-forward.png) center center/contain no-repeat;
  -webkit-transform: translate(50%, -50%);
          transform: translate(50%, -50%);
  position: absolute;
  z-index: 1;
  top: 50%;
  right: 0%;
}
.careerKitai__inner {
  background: #FFEDBA;
  border-radius: 10px;
  padding: 20px 25px 45px;
}
.careerKitai__inner > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 40px -15px 0;
}
.careerKitai__inner > ul > li {
  -ms-flex-preferred-size: 33.3%;
      flex-basis: 33.3%;
  max-width: 33.3%;
  padding: 0 15px;
}
.careerKitai__inner > ul > li img {
  display: block;
  max-width: 85px;
  margin: 0 auto 15px;
}
.careerKitai__inner > ul > li p {
  line-height: 1.5;
  margin: 0 -20px;
}
@media screen and (max-width: 428px) {
  .career__lead {
    padding: 5vw 5vw 10vw;
  }
  .career__imagetitle h3.title {
    font-size: 18px;
    padding-bottom: 10vw;
  }
  .career__imagetitle .image img {
    -o-object-fit: cover;
       object-fit: cover;
    aspect-ratio: 7/3;
  }
  .careerBlock {
    overflow: hidden;
    border-radius: 10px;
    margin-top: 10vw;
  }
  .careerBlock--1 {
    margin-top: -10vw;
  }
  .careerBlock__cb {
    text-align: left !important;
  }
  .careerBlock h4 {
    height: 60px;
    font-size: 15px;
    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;
    font-weight: 500;
    letter-spacing: 0.04em;
  }
  .careerBlock__text {
    padding: 10vw 5vw 10vw;
  }
  .careerBlock__text--2 {
    padding: 10vw 5vw 10vw;
  }
  .careerBlock__text--2 p {
    text-align: left;
  }
  .careerBlock__concept > dl {
    display: block;
    margin: 0;
    text-align: center;
  }
  .careerBlock__concept > dl > dt {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .careerBlock__concept .nextstage {
    line-height: 2;
  }
  .careerBlock .concept__wrapper {
    border-radius: 10px;
    padding: 5vw 0;
    margin-top: 10vw;
  }
  .careerBlock .concept1 {
    margin: 0 -3vw;
    font-size: 13px;
  }
  .careerBlock .concept1 > * {
    padding: 0 6vw;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .careerBlock .concept1 > *:first-child:after {
    content: "";
    width: 24px;
    height: 24px;
  }
  .careerBlock__kaihatsu {
    margin: 0 -4vw;
    padding: 5vw 1vw;
    border-radius: 5px;
  }
  .career-icon {
    display: block;
    margin: 0 auto;
    max-width: 65px;
    margin-bottom: 10px;
  }
  .careerMoku {
    border-radius: 10px;
    margin: 10vw 0 10vw;
  }
  .careerMoku dt {
    height: 40px;
  }
  .careerMoku dd {
    padding: 20px 5vw;
  }
  .careerMezasu {
    margin: 20px 0 20px;
  }
  .careerMezasu dt {
    height: 40px;
    border-top-right-radius: 10px;
    border-top-left-radius: 10px;
  }
  .careerMezasu dd {
    background: #fff;
    padding: 0 15px;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
  }
  .careerMezasu dd ol > li {
    padding: 30px;
  }
  .careerMezasu dd ol > li:after {
    width: 20px;
    height: 20px;
  }
  .careerKitai {
    margin: 0 -5vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .careerKitai > * {
    padding: 0 3vw;
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
    position: relative;
  }
  .careerKitai > *:not(:last-child):after {
    width: 30px;
    height: 30px;
  }
  .careerKitai__inner {
    background: #FFEDBA;
    border-radius: 10px;
    padding: 5vw 3vw 10vw;
  }
  .careerKitai__inner > ul {
    margin: 5vw -20px 0;
    display: block;
  }
  .careerKitai__inner > ul > li {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
    padding: 0 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 3vw;
  }
  .careerKitai__inner > ul > li img {
    display: block;
    max-width: 50px;
    margin: 0 3vw 0 0;
  }
  .careerKitai__inner > ul > li p {
    line-height: 1.5;
    margin: 0 0px;
    font-size: 12px;
    line-height: 1.6;
    text-align: left;
  }
  .careerKitai__inner h4 {
    font-size: 13px;
  }
  .careerKitai__inner p {
    font-size: 12px;
    line-height: 1.6;
  }
}

.interviewBlock {
  position: relative;
  max-width: 95vw;
  width: 100%;
  margin: 170px 0 0 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.interviewBlock .orn {
  position: absolute;
  top: 0;
  font-size: 24px;
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  color: #E60012;
  z-index: 1;
}
.interviewBlock .orn span {
  font-size: 82px;
  vertical-align: bottom;
  line-height: 1;
  margin-top: 0.1em;
  display: inline-block;
}
.interviewBlockProfile {
  -ms-flex-preferred-size: 300px;
      flex-basis: 300px;
  max-width: 300px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: #F9DADD;
  padding: 70px 60px;
  border-radius: 20px;
}
.interviewBlockProfile__inner {
  max-width: 180px;
}
.interviewBlockProfile__inner .image {
  margin-bottom: 20px;
}
.interviewBlockProfile .profile:before {
  content: "PROFILE";
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #E60012;
}
.interviewBlockProfile .profile .text {
  margin-top: 50px;
}
.interviewBlockText {
  background: #fff;
}
.interviewBlockText__block {
  padding: 64px 0;
}
.interviewBlockText__block p {
  margin-top: 2em;
}
.interviewBlockText__block p:first-child {
  margin-top: 0;
}
.interviewBlockText__block + .interviewBlockText__block {
  border-top: 1px solid #F9DADD;
}
.interviewBlock--left {
  margin-right: auto;
}
.interviewBlock--left .orn {
  right: 0;
  -webkit-transform: translate(10%, -2.5em);
          transform: translate(10%, -2.5em);
}
.interviewBlock--left .interviewBlockProfile {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  -webkit-transform: translate(-40px, -40px);
          transform: translate(-40px, -40px);
}
.interviewBlock--left .interviewBlockText {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  padding: 85px 120px 85px 12vw;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
}
.interviewBlock--right {
  margin-left: auto;
}
.interviewBlock--right .orn {
  left: 0;
  -webkit-transform: translate(-10%, -2.5em);
          transform: translate(-10%, -2.5em);
}
.interviewBlock--right .interviewBlockProfile {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  -webkit-transform: translate(40px, -40px);
          transform: translate(40px, -40px);
}
.interviewBlock--right .interviewBlockText {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  padding: 85px 12vw 85px 120px;
  border-top-left-radius: 20px;
  border-bottom-left-radius: 20px;
}

.workstyleLists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 -30px;
}
.workstyleLists > * {
  padding: 30px;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
}
.workstyleLists > * > dl {
  background: #F9DADD;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border-radius: 10px;
  overflow: hidden;
  height: 100%;
}
.workstyleLists > * > dl .title {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  padding: 35px 30px 0;
}
.workstyleLists > * > dl .text {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  padding: 20px 30px 50px;
}
.workstyleLists > * > dl .image {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.workstyleLists > *:nth-child(2) dl, .workstyleLists > *:nth-child(3) dl, .workstyleLists > *:nth-child(6) dl, .workstyleLists > *:nth-child(7) dl {
  background: #FAB8BE;
}
@media screen and (max-width: 428px) {
  .workstyleLists {
    display: block;
    margin: 0 0px;
  }
  .workstyleLists > * {
    padding: 0 5vw 10vw;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
  }
  .workstyleLists > * > dl {
    border-radius: 5px;
  }
  .workstyleLists > * > dl .title {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    padding: 10vw 5vw 0;
  }
  .workstyleLists > * > dl .text {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    padding: 5vw 5vw 10vw;
  }
  .workstyleLists > * > dl .image {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .workstyleLists > *:nth-child(2) dl, .workstyleLists > *:nth-child(3) dl, .workstyleLists > *:nth-child(6) dl, .workstyleLists > *:nth-child(7) dl {
    background: #F9DADD;
  }
}

.diversityBlock__title {
  max-width: 480px;
  font-size: 20px;
  text-align: center;
  padding: 10px 10px;
  font-weight: 500;
  border-radius: 10px;
  background: #C30110;
  color: #fff;
  margin: 0 auto 40px;
}
.diversityBlock__title--1 {
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.diversityBlock__cycle {
  padding: 0 60px 70px;
  overflow: inherit;
}
.diversityBlock__image2clm {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 -10px;
}
.diversityBlock__image2clm > * {
  padding: 0 10px;
}
.diversityBlock__inc {
  max-width: 980px;
  margin: -50px auto 100px;
  border: 2px solid #000;
  background: #fff;
  padding: 0 50px 70px;
}
.diversityBlock__inc > ul {
  margin: 0 -40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.diversityBlock__inc > ul > * {
  padding: 0 40px;
}
.diversityBlock__inc > ul > *:not(:last-child) {
  border-right: 2px solid #000;
}
.diversityBlock__inc > ul > * dl dt {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
}
@media screen and (max-width: 428px) {
  .diversityBlock__title {
    max-width: 240px;
    font-size: 14px;
    padding: 8px 10px !important;
    border-radius: 5px;
    margin: 0 auto 20px;
    white-space: nowrap;
    height: auto !important;
  }
  .diversityBlock__title--1 {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .diversityBlock__cycle {
    padding: 0 5px 20px;
    overflow: inherit;
  }
  .diversityBlock__image2clm {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0 -5px;
  }
  .diversityBlock__image2clm > * {
    padding: 0 5px;
  }
  .diversityBlock__inc {
    margin: 0px 3vw 10vw;
    border: 2px solid #000;
    padding: 0 10vw 15vw;
  }
  .diversityBlock__inc > ul {
    margin: 0 0px;
    display: block;
  }
  .diversityBlock__inc > ul > * {
    width: 100%;
    padding: 0;
  }
  .diversityBlock__inc > ul > *:not(:last-child) {
    border-right: none;
    border-bottom: 1px solid #000;
    padding: 0 0px 20px;
  }
  .diversityBlock__inc > ul > *:not(:first-child) {
    padding-top: 20px;
  }
  .diversityBlock__inc > ul > * dl dt {
    font-family: "Raleway", sans-serif !important;
    font-weight: 400;
  }
}

/*============================
RECRUIT
============================*/
.recruit__wanted {
  margin-top: 70px;
}
.recruit__wanted li {
  padding: 80px 100px;
  background: #fff;
  margin-bottom: 60px;
}
.recruit__wanted li h3 {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  font-size: 36px;
  text-align: center;
  color: #E60012;
  margin-bottom: 50px;
  text-transform: uppercase;
}
.recruit__wanted li p {
  font-size: 15px;
}
.recruitMV {
  background: #C30110;
  width: 100%;
  aspect-ratio: 1280/280;
  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;
  border-bottom-right-radius: 20px;
  border-bottom-left-radius: 20px;
}
.recruitMV .commonH1 {
  position: static;
  color: #fff;
  text-align: center;
}
.recruitMV .commonH1:before {
  text-align: center;
}
.recruitMV .commonH1--2 {
  font-size: 60px;
  font-size: 4.6875vw;
  letter-spacing: 0.08em;
}
.recruitBlockLists > li {
  margin-bottom: 4px;
  background: #F9DADD;
  border-radius: 5px;
  padding: 13px 45px;
}
.recruitBlockLists > li:nth-of-type(even) {
  background: rgba(249, 218, 221, 0.4);
}
.recruitBlockLists--flow > li {
  margin-bottom: 30px;
  position: relative;
  overflow: inherit;
}
.recruitBlockLists--flow > li.nainaitei {
  background: #C30110;
  color: #fff;
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  padding: 30px 20px;
}
.recruitBlockLists--flow > li:not(:last-child):after {
  content: "";
  width: 12px;
  height: 12px;
  display: block;
  background: url(../img/recruit/icon-flow.png) center center/contain no-repeat;
  position: absolute;
  bottom: -20px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.recruitBlockLists--faq > li {
  margin-bottom: 8px;
  cursor: pointer;
}
.recruitBlockLists dl.basic {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 15px;
  line-height: 2;
}
.recruitBlockLists dl.basic dt {
  border-right: 1px solid #000;
  -ms-flex-preferred-size: 10em;
      flex-basis: 10em;
  max-width: 10em;
  padding: 10px 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-weight: 500;
}
.recruitBlockLists dl.basic dd {
  padding: 10px 0 10px 50px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.recruitBlockLists dl.basic dd h3 {
  font-weight: 500;
  line-height: 2;
  font-size: 15px;
}
.recruitBlockLists dl.basic dd ul > li:not(:last-child) {
  margin-bottom: 20px;
}
.recruitBlockLists dl.basic dd * + ul {
  margin-top: 20px;
}
.recruitBlockLists dl.basic dd table {
  font-size: 15px;
  border-collapse: collapse;
  width: 100%;
}
.recruitBlockLists dl.basic dd table th {
  font-weight: 500;
}
.recruitBlockLists dl.basic dd table thead th {
  padding-bottom: 20px;
}
.recruitBlockLists dl.basic dd table tbody th {
  padding-right: 30px;
}
.recruitBlockLists dl.basic dd table tbody td {
  padding: 20px 0 10px 0;
  text-align: center;
}
.recruitBlockLists dl.basic dd table tbody tr {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.recruitBlockLists dl.step {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 14px;
  line-height: 2;
  margin: 0 -10px;
}
.recruitBlockLists dl.step dt {
  -ms-flex-preferred-size: 14em;
      flex-basis: 14em;
  max-width: 14em;
  padding: 10px 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  line-height: 1.7;
}
.recruitBlockLists dl.step dt .num {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  color: #C30110;
  font-size: 12px;
  font-weight: 700;
}
.recruitBlockLists dl.step dt .num span {
  font-size: 21px;
  letter-spacing: 0.08em;
  margin-left: 0.1em;
}
.recruitBlockLists dl.step dd {
  padding: 10px 0 10px 40px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.recruitBlockLists dl.faq {
  font-size: 15px;
  line-height: 2;
  margin: 0 -10px;
}
.recruitBlockLists dl.faq dt {
  padding: 10px 0;
  line-height: 1.7;
  letter-spacing: 0.04em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.recruitBlockLists dl.faq dt .ques {
  font-family: "Raleway", sans-serif !important;
  font-weight: 400;
  color: #C30110;
  font-size: 12px;
  font-weight: 700;
  display: inline;
  letter-spacing: 0.04em;
  margin-right: 2em;
}
.recruitBlockLists dl.faq dt .ques span {
  font-size: 21px;
  letter-spacing: 0.08em;
  margin-left: 0.1em;
}
.recruitBlockLists dl.faq dd {
  display: none;
  margin-top: 15px;
  padding: 20px 0 10px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  border-top: 2px dotted #5C5C5C;
}
@media screen and (max-width: 428px) {
  .recruit__wanted {
    margin-top: 10vw;
  }
  .recruit__wanted li {
    padding: 10vw 5vw;
    margin-bottom: 10vw;
  }
  .recruit__wanted li h3 {
    font-size: 24px;
    margin-bottom: 5vw;
  }
  .recruit__wanted li p {
    font-size: 13px;
  }
  .recruitMV {
    aspect-ratio: 1280/580;
    border-bottom-right-radius: 15px;
    border-bottom-left-radius: 15px;
  }
  .recruitMV .commonH1:before {
    font-size: 22px;
  }
  .recruitBlockLists > li {
    padding: 10px 5vw;
  }
  .recruitBlockLists--flow > li {
    margin-bottom: 30px;
    position: relative;
    overflow: inherit;
  }
  .recruitBlockLists--flow > li.nainaitei {
    background: #C30110;
    color: #fff;
    font-size: 24px;
    font-weight: 700;
    text-align: center;
    padding: 30px 20px;
  }
  .recruitBlockLists--flow > li:not(:last-child):after {
    content: "";
    width: 12px;
    height: 12px;
    display: block;
    background: url(../img/recruit/icon-flow.png) center center/contain no-repeat;
    position: absolute;
    bottom: -20px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .recruitBlockLists--faq > li {
    margin-bottom: 8px;
  }
  .recruitBlockLists dl.basic {
    font-size: 13px;
    display: block;
  }
  .recruitBlockLists dl.basic dt {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
    padding: 6px 0;
    border: none;
    font-weight: 500;
  }
  .recruitBlockLists dl.basic dd {
    padding: 6px 0 6px 0;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
  .recruitBlockLists dl.basic dd h3 {
    font-size: 13px;
  }
  .recruitBlockLists dl.basic dd ul > li:not(:last-child) {
    margin-bottom: 10px;
  }
  .recruitBlockLists dl.basic dd * + ul {
    margin-top: 10px;
  }
  .recruitBlockLists dl.basic dd table {
    font-size: 12px;
  }
  .recruitBlockLists dl.basic dd table thead th {
    padding-bottom: 10px;
    padding-right: 10px;
    white-space: nowrap;
  }
  .recruitBlockLists dl.basic dd table tbody th {
    padding-right: 10px;
    line-height: 1.5;
  }
  .recruitBlockLists dl.basic dd table tbody td {
    padding: 10px 10px 10px 0;
    text-align: center;
  }
  .recruitBlockLists dl.basic dd table tbody tr {
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }
  .recruitBlockLists dl.step {
    display: block;
    font-size: 14px;
    line-height: 2;
    margin: 0 0px;
  }
  .recruitBlockLists dl.step dt {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
    padding: 10px 0;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    line-height: 1.7;
  }
  .recruitBlockLists dl.step dt .num {
    font-family: "Raleway", sans-serif !important;
    font-weight: 400;
    color: #C30110;
    font-size: 12px;
    font-weight: 700;
  }
  .recruitBlockLists dl.step dt .num span {
    font-size: 21px;
    letter-spacing: 0.08em;
    margin-left: 0.1em;
  }
  .recruitBlockLists dl.step dd {
    padding: 10px 0;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
  .recruitBlockLists dl.faq {
    font-size: 13px;
    margin: 0 0px;
  }
  .recruitBlockLists dl.faq dt {
    padding: 10px 0;
    display: block;
  }
  .recruitBlockLists dl.faq dt .ques {
    margin-right: 0em;
  }
  .recruitBlockLists dl.faq dt .ques span {
    font-size: 21px;
  }
  .recruitBlockLists dl.faq dd {
    margin-top: 10px;
    padding: 15px 0 10px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    border-top: 2px dotted #5C5C5C;
  }
}




/* 福利厚生 */
.walfare-mv{
  padding: 120px 0 0;
}

.grid1440{
  margin: 0 auto;
  max-width: 1440px;
  width: 80%;
}

.welfareBlockLists{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  gap: 80px 0;
}

.welfareBlockLists .item{
  width: 48%;
}

.welfareBlockLists .item .ttlcon{
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 20px;
}

.welfareBlockLists .item .ttlcon .point{
  width: 110px;
}

.welfareBlockLists .item .ttlcon .ttlbox{
  margin-top: 38px;
  width: calc(100% - 110px);
}

.welfareBlockLists .item .ttlcon .ttlbox .ttl{
  font-size: min(2.1vw,40px);
  font-weight: 700;margin-bottom: 16px;
}

.welfareBlockLists .item .txt{
  font-size: min(1.2vw,22px);
  font-weight: 400;
  margin: 24px auto 0;
  width: 82%;
}

.welfareBlockLists .item:nth-of-type(3) .txt{
  margin: min(11%,78px) auto 0;
}

.welfareBlockLists .item .img{
  margin: 40px auto 0;
  width: 90%;
}

.welfareBlock .buttonbox{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 40px;
  margin: 80px auto 0;
}

.welfareBlock .buttonbox .button a{
  background-color: #C30110;
  color: #fff;
  display: block;
  font-size: 14px;
  font-weight: 400;
  text-decoration: none;
  padding: 15px 8px;
  text-align: center;
}

@media screen and (max-width: 1080px) {
  .grid1440{
    width: 90%;
  }

  .welfareBlockLists .item:nth-of-type(3) .txt{
    margin: min(8%,78px) auto 0;
  }

  .welfareBlock .buttonbox{
    width: 60%;
  }

  .welfareBlock .buttonbox .button{
    width: 48%;
  }

  .welfareBlock .buttonbox .button a{
    font-size: 16px;
    padding: 20px 0;
  }
}

@media screen and (max-width: 768px) {
  .walfare-mv{
    padding: 60px 0 0;
  }

  .welfareBlockLists{
    gap: 40px;
  }

  .welfareBlockLists .item{
    width: 100%;
  }

  .welfareBlockLists .item .ttlcon{
    gap: 10px;
  }

  .welfareBlockLists .item .ttlcon .point{
    width: 80px;
  }

  .welfareBlockLists .item .ttlcon .ttlbox{
    margin-top: 21px;
  }

  .welfareBlockLists .item .ttlcon .ttlbox .ttl{
    font-size: 28px;
  }

  .welfareBlockLists .item .txt,.welfareBlockLists .item:nth-of-type(3) .txt{
    font-size: 18px;
    margin: 6px auto 0;
  }

  .welfareBlockLists .item .img{
    margin: 20px auto 0;
    width: 100%;
  }

  .welfareBlock .buttonbox{
    gap: 20px;
    margin: 60px auto 0;
    width: 90%;
  }

  .welfareBlock .buttonbox .button{
    width: 100%;
  }

  .welfareBlock .buttonbox .button a{
    font-size: 14px;
    padding: 15px 20px;
  }
}


/* 働く環境 */
.workstyle_mv .commonH1{
  top: auto;
  bottom: 4vw;
}

.grid1080_02{
  margin: 0 auto;
  max-width: 1080px;
  width: 90%;
}

.block01 .ttl,.block02 .ttl,.block03 .ttl{
  font-size: 40px;
  font-weight: 700;
  margin: 0 auto;
  position: relative;
  width: fit-content;
}

.block01 .ttl:before,.block01 .ttl:after,.block02 .ttl:before,.block02 .ttl:after,.block03 .ttl:before,.block03 .ttl:after{
  content: "";
  display: block;
  background-color: #E81F2F;
  height: 3px;
  width: 56px;
  position: absolute;
}

.block01 .ttl:before,.block02 .ttl:before,.block03 .ttl:before{
  top: 50%;
  left: -60px;
  transform: translateY(-50%) rotate(60deg);
}

.block01 .ttl:after,.block02 .ttl:after,.block03 .ttl:after{
  top: 50%;
  right: -60px;
  transform: translateY(-50%) rotate(120deg);
}

.block01 .flexbox{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 40px 0;
  margin: 60px auto 0;
}

.block01 .flexbox .item{
  width: 48%;
}

.block02{
  background-color: #fff;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}

.block02 .con{
  margin: 0 auto;
  max-width: 960px;
  margin: 60px auto 0;
  width: 90%;
}

.block02 .con .flexbox{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}

.block02 .con .flexbox:nth-child(odd){
  flex-direction: row-reverse;
}

.block02 .con .flexbox:nth-child(2){
  margin: 40px auto;
}

.block02 .con .flexbox .img{
  width: 48%;
}

.block02 .con .flexbox .textbox{
  margin: 0 auto;
  width: 302px;
}

.block02 .con .flexbox .textbox .ttl02{
  font-size: 20px;
  font-weight: 500;
  margin: 0 0 12px;
}

.block02 .con .flexbox .textbox .text{
  font-size: 16px;
  font-weight: 400;
}

.block03 .flexbox{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 60px auto 0;
}

.block03 .flexbox .item{
  width: 31%;
}

.block03 .flexbox .item .img{
  width: 100%;
}

.block03 .flexbox .item .ttl02{
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  margin: 16px 0 10px;
}

.block03 .flexbox .item .text{
  font-size: 16px;
  font-weight: 400;
  margin: 0 auto;
  width: 90%;
}

.block03 .flexbox .item .smalltext{
  display: block;
  font-size: 12px;
  font-weight: 400;
  text-align: right;
  margin: 4px 0 0;
}

@media screen and (max-width: 768px) {
  .workstyle_mv .commonH1{
    top: auto;
    bottom: 3vw;
  }

  .block01 .ttl, .block02 .ttl, .block03 .ttl{
    font-size: 24px;
    text-align: center;
  }

  .block01 .ttl:before, .block01 .ttl:after{
    width: 72px;
  }

  .block02 .ttl:before, .block02 .ttl:after, .block03 .ttl:before, .block03 .ttl:after{
    width: 40px;
  }

  .block02 .ttl:before, .block03 .ttl:before{
    left: -40px;
  }

  .block02 .ttl:after, .block03 .ttl:after{
    right: -40px;
  }

  .block01{
    padding: 0 0 60px;
  }

  .block01 .flexbox{
    gap: 30px;
    margin: 30px auto 0;
  }

  .block01 .flexbox .item{
    width: 100%;
  }

  .block02{
    padding: 60px 0;
  }

  .block02 .con{
    margin: 30px auto 0;
  }

  .block02 .con .flexbox .img{
    margin: 0 auto 20px;
    width: 100%;
  }

  .block02 .con .flexbox .textbox{
    width: 100%;
  }

  .block02 .con .flexbox .textbox .ttl02{
    margin: 0 0 6px;
  }

  .block03{
    padding: 60px 0 0;
  }

  .block03 .flexbox{
    gap: 30px;
    margin: 30px auto 0;
  }

  .block03 .flexbox .item{
    width: 100%;
  }

  .block03 .flexbox .item .smalltext{
    font-size: 11px;
  }
}


/* 100人にききました */
.grid1248{
  margin: 0 auto;
  max-width: 1248px;
  width: 90%;
}

.culture_btnbox{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
  width: 100%;
}

.culture_btnbox .item{
  width: 25%;
}

.culture_btnbox .item:not(:last-of-type){
  border-right: 3px solid #fff;
}

.culture_btnbox .item a{
  background-color: #E60012;
  color: #fff;
  display: block;
  font-size: 16px;
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  padding: 18px 6% 18px 0;
  position: relative;
}

.culture_btnbox .item a::after{
  content: "";
  display: block;
  background-image: url(../img/career/our_culture-arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  height: 20px;
  width: 16px;
  position: absolute;
  top: 50%;
  right: min(1.8vw,34px);
  transform: translateY(-50%);
  transition: .3s;
}

.culture_btnbox .item a:hover::after{
  top: 55%;
}


.culture_block01 .ttl,.culture_block02 .ttl,.culture_block03 .ttl,.culture_block04 .ttl{
  font-size: 40px;
  font-weight: 700;
  margin: 0 auto;
  position: relative;
  width: fit-content;
}

.culture_block01 .ttl::before,.culture_block01 .ttl::after,.culture_block02 .ttl::before,.culture_block02 .ttl::after,.culture_block03 .ttl::before,.culture_block03 .ttl::after,.culture_block04 .ttl::before,.culture_block04 .ttl::after{
  content: "";
  display: block;
  background-color: #E81F2F;
  height: 3px;
  width: 56px;
  position: absolute;
}

.culture_block01 .ttl::before,.culture_block02 .ttl::before,.culture_block03 .ttl::before,.culture_block04 .ttl::before{
  top: 50%;
  left: -60px;
  transform: translateY(-50%) rotate(60deg);
}

.culture_block01 .ttl::after,.culture_block02 .ttl::after,.culture_block03 .ttl::after,.culture_block04 .ttl::after{
  top: 50%;
  right: -60px;
  transform: translateY(-50%) rotate(120deg);
}

.culture_block01 .gridbox{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(10, 1fr);
  gap: 20px;
  margin: 60px auto 0;
}

.culture_block01 .gridbox .item01{
  grid-area: 1 / 1 / 3 / 3;
}

.culture_block01 .gridbox .item02{
  grid-area: 1 / 3 / 3 / 5;
}

.culture_block01 .gridbox .item03{
  grid-area: 3 / 1 / 5 / 3;
}

.culture_block01 .gridbox .item04{
  grid-area: 3 / 3 / 5 / 5;
}

.culture_block01 .gridbox .item05{
  grid-area: 5 / 1 / 7 / 5;
}

.culture_block01 .gridbox .item06{
  grid-area: 7 / 1 / 9 / 3;
}

.culture_block01 .gridbox .item07{
  grid-area: 7 / 3 / 9 / 5;
}

.culture_block01 .gridbox .item08{
  grid-area: 9 / 1 / 11 / 3;
}

.culture_block01 .gridbox .item09{
  grid-area: 9 / 3 / 11 / 5;
}

.culture_block01 .gridbox .item .grapfttl,.culture_block02 .gridbox .item .grapfttl,.culture_block03 .gridbox .item .grapfttl{
  font-size: 16px;
  font-weight: 500;
  margin: 0 0 10px;
}

.culture_block01 .gridbox .item .grapfttl .red,.culture_block02 .gridbox .item .grapfttl .red,.culture_block03 .gridbox .item .grapfttl .red{
  color: #E60012;
  font-size: 24px;
}

.culture_block02 .gridbox{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(3, 1fr);
  gap: 0 20px;
  margin: 60px auto 0;
}

.culture_block02 .gridbox .item01{
  grid-area: 1 / 1 / 3 / 3;
}

.culture_block02 .gridbox .item02{
  grid-area: 1 / 3 / 3 / 5;
}

.culture_block02 .gridbox .item03{
  grid-area: 3 / 1 / 4 / 5;
}

.culture_block03 .gridbox{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(7, 1fr);
  gap: 20px;
  margin: 60px auto 0;
}

.culture_block03 .gridbox .item01{
  grid-area: 1 / 1 / 5 / 5;
}

.culture_block03 .gridbox .item02{
  grid-area: 1 / 5 / 5 / 9;
}

.culture_block03 .gridbox .item03{
  grid-area: 1 / 9 / 5 / 13;
}

.culture_block03 .gridbox .item04{
  grid-area: 5 / 1 / 9 / 7;
}

.culture_block03 .gridbox .item05{
  grid-area: 5 / 7 / 9 / 13;
}

.culture_block03 .text{
  font-size: 16px;
  font-weight: 400;
  margin: 20px 0 0 auto;
  width: fit-content;
}

.culture_block04{
  background-color: #fff;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}

.culture_block04 .box{
  background-color: #FFF9F4;
  border-radius: 40px;
  margin: 60px auto 0;
  padding: 100px 80px;
  width: min(90%,1246px);
}

.culture_block04 .box .item{
  width: 85%;
}

.culture_block04 .box .item:nth-child(even){
  margin-left: auto;
}

.culture_block04 .box .item:not(:last-of-type){
  margin-bottom: 60px;
}

@media screen and (max-width: 1080px){
  .culture_btnbox .item{
    width: 50%;
  }

  .culture_btnbox .item:first-of-type{
    border-bottom: 3px solid #fff;
  }

  .culture_btnbox .item:nth-of-type(2){
    border-right: unset;
    border-bottom: 3px solid #fff;
  }

  .culture_block01 .gridbox .item .grapfttl, .culture_block02 .gridbox .item .grapfttl, .culture_block03 .gridbox .item .grapfttl{
    font-size: min(1.3vw,16px);
  }
}

@media screen and (max-width: 768px) {
  .culture_btnbox{
    width: 65%;
  }

  .culture_btnbox .item{
    width: 100%;
  }

  .culture_btnbox .item:not(:last-of-type){
    border-bottom: 2px solid #fff;
    border-right: unset;
  }

  .culture_btnbox .item a{
    font-size: 13px;
    text-align: left;
    padding: 10px 12px;
  }

  .culture_btnbox .item a::after{
    background-image: url(../img/career/our_culture-arrow-sp.svg);
    height: 12px;
    width: 9px;
    right: 12px;
  }

  .culture_block01 .ttl, .culture_block02 .ttl, .culture_block03 .ttl, .culture_block04 .ttl{
    font-size: 24px;
    text-align: center;
  }

  .culture_block01 .ttl::before, .culture_block01 .ttl::after, .culture_block02 .ttl::before, .culture_block02 .ttl::after, .culture_block03 .ttl::before, .culture_block03 .ttl::after, .culture_block04 .ttl::before, .culture_block04 .ttl::after{
    width: 40px;
  }

  .culture_block01 .ttl::before, .culture_block02 .ttl::before, .culture_block03 .ttl::before, .culture_block04 .ttl::before{
    left: -40px;
  }

  .culture_block01 .ttl::after, .culture_block02 .ttl::after, .culture_block03 .ttl::after, .culture_block04 .ttl::after{
    right: -40px;
  }

  .culture_block01 .gridbox .item .grapfttl, .culture_block02 .gridbox .item .grapfttl, .culture_block03 .gridbox .item .grapfttl{
    font-size: 13px;
    margin: 0 0 6px;
  }

  .culture_block01 .gridbox .item .grapfttl .red, .culture_block02 .gridbox .item .grapfttl .red, .culture_block03 .gridbox .item .grapfttl .red{
    font-size: 20px;
  }

  .culture_block01 .gridbox,.culture_block02 .gridbox,.culture_block03 .gridbox{
    display: block;
    margin: 40px auto 0;
  }

  .culture_block01 .gridbox .item.item:not(:last-of-type),.culture_block02 .gridbox .item.item:not(:last-of-type),.culture_block03 .gridbox .item.item:not(:last-of-type){
    margin: 0 auto 30px;
  }

  .culture_block03 .text{
    font-size: 13px;
    margin: 10px 0 0 auto;
    width: 67%;
  }

  .culture_block04 .box{
    border-radius: 20px;
    margin: 40px auto 0;
    padding: 40px 8px;
  }

  .culture_block04 .box .item{
    width: 96%;
  }

  .culture_block04 .box .item:not(:last-of-type){
    margin-bottom: 30px;
  }
}


