@charset "utf-8";

/*------------------------------------------------
sectionName
------------------------------------------------*/

.loading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100vw;
  height: 100vh;
}
.loading-logo {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 238px;
  height: 184px;
  z-index: 101;
  transition: 1s;
}
.loading div {
  width: calc(100% / 5);
  height: 100%;
  background-color: #ffe109;
  transition: 1.5s;
}
.loading div:nth-child(2) {
  transition-delay: 0.1s;
}
.loading div:nth-child(3) {
  transition-delay: 0.2s;
}
.loading div:nth-child(4) {
  transition-delay: 0.3s;
}
.loading div:nth-child(5) {
  transition-delay: 0.4s;
}
.loading div:nth-child(6) {
  transition-delay: 0.5s;
}
.loading div:nth-child(7) {
  transition-delay: 0.6s;
}
.loading div:nth-child(8) {
  transition-delay: 0.7s;
}
.loading div:nth-child(9) {
  transition-delay: 0.8s;
}
.loading div:nth-child(10) {
  transition-delay: 0.8s;
}
.loading.js_load--on div {
  transform: translateY(110%);
  opacity: 0;
}
.loading.js_load--on .loading-logo {
  opacity: 0;
}
.loading.js_load--on {
  pointer-events: none;
  visibility: hidden;
}

/*------------------------------------------------
header
------------------------------------------------*/

/* pc-only ------------*/
@media screen and (min-width: 768px) {
  .header--home .header-logo {
    visibility: hidden;
    opacity: 0;
  }
  .header--home .header__nav {
    margin: -30px auto 30px;
    transition: 0.25s;
  }
}
/* /pc-only -----------*/

.locading {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  /*background: #fff;*/
  z-index: 10;
}

/*------------------------------------------------
lcl-top
------------------------------------------------*/

.lcl-top {
  position: relative;
  width: 100%;
  height: calc(100vh - 55px);
  min-height: 680px;
  max-height: 900px;
  overflow: hidden;
}
.lcl-top::before,
.lcl-top::after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  display: block;
  width: calc(50% + 0.1px);
  height: 100%;
  background: url(../img/top/bg_01.jpg) no-repeat center top / cover;
  transition: 2.5s;
  transform: scale(1.1);
  transition-delay: 0.1s;
  opacity: 0;
  transform-origin: right center;
}
.lcl-top::after {
  right: 0;
  left: auto;
  background: url(../img/top/bg_02.jpg) no-repeat center top / cover;
  transform-origin: left center;
}

.lcl-top__in {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  width: 1000px;
  height: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-bottom: 80px;
  transition: 2.5s;
  transition-delay: 0.1s;
  opacity: 0;
}
.lcl-top__logo {
  width: 171px;
  min-height: 0;
}
.lcl-top__ttl {
  width: 742px;
  min-height: 0;
  margin-top: 40px;
}
.lcl-top__txt {
  font-size: 28px;
  font-weight: bold;
  line-height: 45px;
  min-height: 0;
  margin-top: 20px;
  text-align: center;
  letter-spacing: 0.25em;
  color: #fff;
}
.lcl-top__btn {
  display: block;
  width: 188px;
  height: 188px;
  transition: 0.3s;
}
.lcl-top__btn--01 {
  background: url(../img/top/btn_03.png) no-repeat center / cover;
}
.lcl-top__btn--02 {
  background: url(../img/top/btn_01.png) no-repeat center / cover;
}
.lcl-top__btn-wrap {
  position: absolute;
  bottom: 80px;
  right: -20px;
  width: 386px;
  height: 188px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

/* pc-only ------------*/
@media screen and (min-width: 768px) {
  .lcl-top__btn-wrap .lcl-top__btn--01:hover {
    animation: kurukuru1 0.5s ease-out forwards;
  }
  .lcl-top__btn-wrap .lcl-top__btn--02:hover {
    animation: kurukuru2 0.5s ease-out forwards;
  }
}
/* /pc-only -----------*/
@keyframes kurukuru1 {
  from {
    transform: rotateY(0deg);
  }
  to {
    transform: rotateY(360deg);
    background: url(../img/top/btn_04.png) no-repeat center / cover;
  }
}
@keyframes kurukuru2 {
  from {
    transform: rotateY(0deg);
  }
  to {
    transform: rotateY(360deg);
    background: url(../img/top/btn_02.png) no-repeat center / cover;
  }
}

.js_load--on.lcl-top::before,
.js_load--on.lcl-top::after {
  transform: scale(1);
  opacity: 1;
}

.js_load--on .lcl-top__in {
  opacity: 1;
}

/*------------------------------------------------
lcl-voice
------------------------------------------------*/

.lcl-voice {
  width: 100%;
  margin: 20px 0 30px;
  padding: 55px 0 10px;
  background: #ffe109;
}
.lcl-voice__in {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
  width: 1000px;
  margin-right: auto;
  margin-left: auto;
}
.lcl-voice__block-l {
  width: 370px;
  border-right: 5px solid #87580e;
}
.lcl-voice__block-r {
  width: 630px;
  padding-left: 20px;
}
.lcl-voice__item {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  flex-wrap: wrap;
}
.lcl-voice__item img {
  transition: 1.4s;
  opacity: 0;
}
/*------------ lcl-voice__item01 ------------*/

.lcl-voice__item01 {
  width: 345.5px;
  height: 480px;
  border-bottom: 5px solid #87580e;
}
.lcl-voice__item01 img {
  width: 328px;
}

/*------------ lcl-voice__item02 ------------*/

.lcl-voice__item02 {
  width: 345.5px;
  height: 455px;
}
.lcl-voice__item02 img {
  width: 345.5px;
}

/*------------ lcl-voice__item03 ------------*/

.lcl-voice__item03 {
  width: 605px;
  border-bottom: 5px solid #87580e;
}
.lcl-voice__item03 img {
  width: 580.5px;
}

/*------------ lcl-voice__item04 ------------*/

.lcl-voice__item-sbs {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin: 20px 0;
  padding-bottom: 20px;
  border-bottom: 5px solid #87580e;
}
.lcl-voice__item04 {
  align-items: center;
  width: 50%;
  height: 400px;
  border-right: 5px solid #87580e;
}
.lcl-voice__item04 img {
  width: 266.5px;
}

/*------------ lcl-voice__item05 ------------*/

.lcl-voice__item05 {
  align-items: center;
  width: 50%;
  height: 400px;
}
.lcl-voice__item05 img {
  width: 273px;
}

/*------------ lcl-voice__item06 ------------*/

.lcl-voice__item06 {
  width: 605px;
}
.lcl-voice__item06 img {
  width: 579px;
}

/* animation ------------*/
.lcl-voice__item.scr_active img {
  opacity: 1;
}
/* /animation -----------*/

/*------------------------------------------------
lcl-bnr
------------------------------------------------*/

.lcl-bnr {
  width: 100%;
}
.lcl-bnr__head {
  width: 100%;
  height: 950px;
  background: url(../img/bnr/bg_01.jpg) no-repeat center center/ cover;
  display: flex;
  justify-content: center;
  align-items: center;
}
.lcl-bnr__ttl {
  width: 70%;
  margin-right: auto;
  margin-left: auto;
}
.lcl-bnr__block {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin-top: -110px;
}
.lcl-bnr__item {
  display: block;
  width: 480px;
  transition: 1.4s;
  transform: translateY(50px) rotateY(30deg);
  opacity: 0;
}
.lcl-bnr__item:not(:last-child) {
  margin-right: 40px;
}

/* animation ------------*/
.lcl-bnr__item.scr_active {
  transform: translateY(0px) rotateY(0deg);
  opacity: 1;
}
/* /animation -----------*/

.lcl-bnr__links {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  margin-top: 40px;
}
.lcl-bnr__link {
  margin-bottom: 60px;
  transition: 1.4s;
  transform: translateY(50px) rotateY(30deg);
  opacity: 0;
}
.lcl-bnr__link:not(:last-child) {
  margin-right: 20px;
}
.lcl-bnr__link-img {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  width: 30.76923076923077vw;
  min-width: 320px;
  max-width: 400px;
  height: 13.846153846153847vw;
  min-height: 145px;
  max-height: 180px;
}
.lcl-bnr__link-img::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  transition: 0.3s;
  opacity: 0;
  background: #000;
}
.lcl-bnr__link-ttl {
  position: relative;
  z-index: 2;
}
.lcl-bnr__link-txt {
  font-size: 16px;
  font-weight: bold;
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  height: 50px;
  padding-left: 25px;
  letter-spacing: 0.1em;
  color: #fff;
  background-color: #000;
}
.lcl-bnr__link-txt::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 30px;
  display: block;
  width: 15px;
  height: 15px;
  margin: auto;
  transition: 0.3s;
  background: url(../img/bnr/arrow.png) no-repeat center / cover;
}

/*------------ lcl-bnr__link01 ------------*/

.lcl-bnr__link01 .lcl-bnr__link-img {
  background: url(../img/bnr/bg_02.jpg) no-repeat center / cover;
}
.lcl-bnr__link01 .lcl-bnr__link-ttl {
  width: 202px;
}

/*------------ lcl-bnr__link02 ------------*/

.lcl-bnr__link02 {
  transition-delay: 0.2s;
}
.lcl-bnr__link02 {
  transform: translateY(120px) rotateY(30deg);
}
.lcl-bnr__link02 .lcl-bnr__link-img {
  background: url(../img/bnr/bg_03.jpg) no-repeat center / cover;
}

/*------------ lcl-bnr__link03 ------------*/

.lcl-bnr__link03 {
  transition-delay: 0.4s;
}
.lcl-bnr__link03 .lcl-bnr__link-img {
  background: url(../img/bnr/bg_04.jpg) no-repeat center / cover;
}
.lcl-bnr__link03 .lcl-bnr__link-ttl {
  position: absolute;
  bottom: -15px;
  left: 0;
  width: 155px;
}

/* pc-only ------------*/
@media screen and (min-width: 768px) {
  .lcl-bnr__link:hover .lcl-bnr__link-img::before {
    opacity: 0.5;
  }
  .lcl-bnr__link:hover .lcl-bnr__link-txt::after {
    right: 20px;
  }
}
/* /pc-only -----------*/

/* animation ------------*/
.lcl-bnr__link.scr_active {
  transform: translateY(0px) rotateY(0deg);
  opacity: 1;
}
.lcl-bnr__link02.scr_active {
  transform: translateY(60px) rotateY(0deg);
  opacity: 1;
}
/* /animation -----------*/

/*------------------------------------------------
lcl-human
------------------------------------------------*/

.lcl-human__in {
  width: 100%;
  height: auto;
  margin-top: -102px;
  padding: 75px 15px 0;
  background: url(../img/human/bg_01.jpg) no-repeat center / cover;
}
.lcl-human__list {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
}
.lcl-human__item {
  transition: 1s;
  transform: scale(0.8) translateY(20px);
  opacity: 0;
}
.lcl-human__item:not(:last-child) {
  margin-right: 17px;
}

.lcl-human__img {
  width: 687px;
  margin: 20px auto 0;
}
.lcl-human__item01 {
  width: 241.5px;
}
.lcl-human__item02 {
  width: 261.5px;
  transition-delay: 0.2s;
  transform: scale(0.8) translateY(50px);
}
.lcl-human__item03 {
  width: 241.5px;
  transition-delay: 0.4s;
}
.lcl-human__item04 {
  width: 261.5px;
  transition-delay: 0.6s;
  transform: scale(0.8) translateY(50px);
}

/* animation ------------*/
.lcl-human__list.scr_active .lcl-human__item {
  transform: scale(1) translateY(0px);
  opacity: 1;
}
.lcl-human__list.scr_active .lcl-human__item02,
.lcl-human__list.scr_active .lcl-human__item04 {
  transform: scale(1) translateY(30px);
  opacity: 1;
}
/* /animation -----------*/

/* ---------------------------------------------------------------- SP ---- */
@media screen and (max-width: 767px) {
  .loading-logo {
    width: 166.6px;
    height: 128.8px;
  }

  /*------------------------------------------------
	lcl-top
	------------------------------------------------*/

  .lcl-top {
    height: 590px;
    min-height: 100%;
    max-height: 100%;
  }
  .lcl-top::before,
  .lcl-top::after {
    top: auto;
    bottom: 0;
    width: 100%;
    height: 50%;
    background: url(../img/top/sp/bg_01.jpg) no-repeat center bottom /
      cover;
    transform-origin: center top;
  }
  .lcl-top::after {
    top: 0;
    bottom: auto;
    background: url(../img/top/sp/bg_02.jpg) no-repeat center top /
      cover;
    transform-origin: center bottom;
  }
  .lcl-top__in {
    width: 100%;
    padding: 0 15px 90px;
  }
  .lcl-top__logo {
    width: 119.5px;
  }
  .lcl-top__ttl {
    width: 100%;
    max-width: 342.5px;
    margin-top: 22.5px;
  }
  .lcl-top__txt {
    font-size: 14px;
    line-height: 22.5px;
    margin-top: 10px;
  }
  .lcl-top__btn {
    width: 126px;
    height: 126px;
    transition: 0.3s;
  }
  .lcl-top__btn-wrap {
    bottom: 20px;
    right: 15px;
    width: 262px;
    height: 126px;
  }

  /*------------------------------------------------
	lcl-voice
	------------------------------------------------*/

  .lcl-voice {
    width: 100%;
    margin-top: 0;
    padding: 15px 0 25px;
  }
  .lcl-voice__in {
    width: 100%;
    padding: 0 15px;
  }
  .lcl-voice__block-l {
    display: flex;
    justify-content: center;
    align-items: stretch;
    flex-wrap: wrap;
    width: 100%;
    padding-bottom: 10px;
    border-right: 0;
  }
  .lcl-voice__block-r {
    width: 100%;
    padding-left: 0;
    border-top: 3px solid #87580e;
  }
  .lcl-voice__item {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    flex-wrap: wrap;
  }
  .lcl-voice__item img {
    transition: 1.4s;
    opacity: 0;
  }
  /*------------ lcl-voice__item01 ------------*/

  .lcl-voice__item01 {
    width: 50%;
    height: auto;
    border-bottom: 0 solid #87580e;
  }
  .lcl-voice__item01 img {
    width: calc(100% - 35px);
  }

  /*------------ lcl-voice__item02 ------------*/

  .lcl-voice__item02 {
    width: 50%;
    height: auto;
    border-left: 3px solid #87580e;
  }
  .lcl-voice__item02 img {
    width: calc(100% - 15px);
  }

  /*------------ lcl-voice__item03 ------------*/

  .lcl-voice__item03 {
    width: 100%;
    padding-top: 10px;
    border-bottom: 3px solid #87580e;
  }
  .lcl-voice__item03 img {
    width: calc(100% - 15px);
  }

  /*------------ lcl-voice__item04 ------------*/

  .lcl-voice__item-sbs {
    justify-content: stretch;
    margin: 0;
    padding: 10px 0;
    border-bottom: 3px solid #87580e;
  }
  .lcl-voice__item04 {
    width: 50%;
    height: auto;
    border-right: 3px solid #87580e;
  }
  .lcl-voice__item04 img {
    width: calc(100% - 15px);
  }

  /*------------ lcl-voice__item05 ------------*/

  .lcl-voice__item05 {
    align-items: center;
    width: 50%;
    height: auto;
  }
  .lcl-voice__item05 img {
    width: calc(100% - 15px);
  }

  /*------------ lcl-voice__item06 ------------*/

  .lcl-voice__item06 {
    width: 100%;
    padding-top: 10px;
  }
  .lcl-voice__item06 img {
    width: calc(100% - 15px);
  }

  /*------------------------------------------------
	lcl-bnr
	------------------------------------------------*/

  .lcl-bnr {
    width: 100%;
    padding-bottom: 40px;
  }
  .lcl-bnr__head {
    height: 275px;
    padding: 25px 15px 0;
    background-attachment:initial;
  }
  .lcl-bnr__ttl {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
  .lcl-bnr__block {
    display: block;
    width: 100%;
    margin-top: -35px;
    padding: 0 30px;
  }
  .lcl-bnr__item {
    width: 100%;
  }
  .lcl-bnr__item:not(:last-child) {
    margin-right: 0;
    margin-bottom: 20px;
  }
  .lcl-bnr__links {
    display: block;
    margin-top: 20px;
    padding: 0 30px;
  }
  .lcl-bnr__link {
    display: block;
    margin-bottom: 0;
    transform: translateY(30px) rotateY(0deg);
  }
  .lcl-bnr__link:not(:last-child) {
    margin-right: 0;
    margin-bottom: 20px;
  }
  .lcl-bnr__link-img {
    width: 85.33333333333333vw;
    min-width: 100%;
    max-width: 100%;
    height: 37.86666666666667vw;
    min-height: 100%;
    max-height: 100%;
  }
  .lcl-bnr__link-txt {
    font-size: 13px;
    height: 40px;
    padding-left: 20px;
  }
  .lcl-bnr__link-txt::after {
    right: 20px;
    width: 10px;
    height: 10px;
  }

  /*------------ lcl-bnr__link01 ------------*/

  .lcl-bnr__link01 .lcl-bnr__link-ttl {
    width: 160px;
  }

  /*------------ lcl-bnr__link02 ------------*/

  .lcl-bnr__link02 {
    transition-delay: 0s;
  }

  /*------------ lcl-bnr__link03 ------------*/

  .lcl-bnr__link03 {
    transition-delay: 0s;
  }
  .lcl-bnr__link03 .lcl-bnr__link-ttl {
    width: 130px;
  }

  .lcl-bnr__link02.scr_active {
    transform: translateY(0px) rotateY(0deg);
  }

  /*------------------------------------------------
	lcl-human
	------------------------------------------------*/

  .lcl-human__in {
    margin-top: -80px;
    padding: 75px 0 0;
    background: url(../img/human/sp/bg_01.jpg) no-repeat center / cover;
  }
  .lcl-human__list {
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0 15px;
  }
  .lcl-human__item:not(:last-child) {
    margin-right: 0;
  }

  .lcl-human__img {
    position: relative;
    width: 100%;
    margin: 0 auto;
  }
  .lcl-human__item01 {
    width: 42.13333333333333vw;
  }
  .lcl-human__item02 {
    width: 45.6vw;
    transition-delay: 0s;
    transform: scale(0.8) translateY(20px);
  }
  .lcl-human__item03 {
    width: 42.13333333333333vw;
    transition-delay: 0s;
  }
  .lcl-human__item04 {
    width: 45.6vw;
    transition-delay: 0s;
    transform: scale(0.8) translateY(20px);
  }

  /* animation ------------*/
  .lcl-human__list.scr_active .lcl-human__item {
    transform: scale(1) translateY(0px);
  }
  .lcl-human__list.scr_active .lcl-human__item02,
  .lcl-human__list.scr_active .lcl-human__item04 {
    transform: scale(1) translateY(0px);
    opacity: 1;
  }
  /* /animation -----------*/
}
