@charset "UTF-8";



/* --------------------------------------------------
  animation
-------------------------------------------------- */
.animation,
#wrapper {
  transform: translate3d(0,20px,0);
  opacity: 0;
  transition: transform 1200ms cubic-bezier(0.165, 0.84, 0.44, 1), opacity 1800ms cubic-bezier(0.165, 0.84, 0.44, 1);
}
.load .animation.show-animation,
.load #wrapper {
  transform: translate3d(0,0,0);
  opacity: 1;
}



/* --------------------------------------------------
  hero
-------------------------------------------------- */
#wrapper #hero {
  height: 1044px;
}
#wrapper #hero .bg_wrap {
  height: 100%;
  background: url(../img/hero_bg.jpg) center center / 100% auto no-repeat;
}
@media screen and (max-width: 1399px) {
  #wrapper #hero .bg_wrap {
    position: relative;
    left: 50%;
    width: 1400px;
    margin-left: -700px;
  }
}
#wrapper #hero .inner {
  position: relative;
  z-index: 1;
  width: 1000px;
  margin: 0 auto;
  transform: translate3d(0,20px,0);
  opacity: 0;
  transition: transform 1200ms cubic-bezier(0.165, 0.84, 0.44, 1), opacity 1800ms cubic-bezier(0.165, 0.84, 0.44, 1);
}
.load #wrapper #hero .inner {
  transform: translate3d(0,0,0);
  opacity: 1;
}
#wrapper #hero .inner .title {
  position: absolute;
  top: 110px;
  left: 50%;
  margin-left: 37px;
  width: 496px;
}



/* --------------------------------------------------
  intro
-------------------------------------------------- */
#wrapper #intro {
  position: relative;
  z-index: 1;
  height: 400px;
  margin-top: -289px;
  background: url(../img/intro_bg.png) top center / 100% auto no-repeat;
}
@media screen and (max-width: 1399px) {
  #wrapper #intro {
    background-size: 1400px auto;
  }
}
#wrapper #intro .catch,
#wrapper #intro .text,
#wrapper #intro .present dt,
#wrapper #intro .present dd {
  position: absolute;
  left: 50%;
}
#wrapper #intro .catch {
  top: 117px;
  width: 732px;
  margin-left: -366px;
}
#wrapper #intro .text {
  top: 366px;
  width: 977px;
  margin-left: -490px;
}
#wrapper #intro .present dt {
  top: 502px;
  width: 218px;
  margin-left: -405px;
}
.fewtokuten #wrapper #intro .present dt:after {
  content: "";
  display: block;
  position: absolute;
  top: -40px;
  left: -110px;
  width: 118px;
  height: 118px;
  background: url(../img/intro_present_few.png) 0 0 / 100% auto no-repeat;
}
#wrapper #intro .present dd {
  top: 486px;
  width: 627px;
  margin-left: -108px;
}
.notokuten #wrapper #intro .present dt,
.notokuten #wrapper #intro .present dd {
  opacity: 0.2;
}
.notokuten #wrapper #intro .present:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 534px;
  height: 42px;
  background: url(../img/intro_present_finish.png) 0 0 / 100% auto no-repeat;
  margin-top: 159px;
  margin-left: -267px;
}



/* --------------------------------------------------
  bodyitem
-------------------------------------------------- */
#wrapper #bodyitem {
  padding-bottom: 132px;
}
#wrapper #bodyitem .inner {
  width: 1000px;
  margin: 0 auto;
}
#wrapper #bodyitem .bodyitem_title {
  width: 733px;
  margin: 0 auto 154px auto;
  padding-top: 156px;
}
#wrapper #bodyitem .category_section:not(:last-child) {
  margin-bottom: 139px;
}
#wrapper #bodyitem .category_section#im:not(:last-child) {
  margin-bottom: 174px;
}
#wrapper #bodyitem .category_section .category_title {
  margin: 0 auto;
}
#wrapper #bodyitem .category_section#dg .category_title {
  width: 578px;
  margin-bottom: 90px;
}
#wrapper #bodyitem .category_section#im .category_title {
  width: 516px;
  margin-bottom: 122px;
}
#wrapper #bodyitem .category_section#nr .category_title {
  width: 598px;
  margin-bottom: 122px;
}
#wrapper #bodyitem .category_section .box {
  display: flex;
  align-items: center;
}
#wrapper #bodyitem .category_section .box:not(:last-child) {
  margin-bottom: 89px;
}
#wrapper #bodyitem .category_section#im .box:not(:last-child) {
  margin-bottom: 125px;
}
#wrapper #bodyitem .category_section#nr .box:not(:last-child) {
  margin-bottom: 110px;
}
#wrapper #bodyitem .category_section .box .img {
  width: 450px;
  padding-left: 56px;
}
#wrapper #bodyitem .category_section .box .text_wrap {
  position: relative;
  left: 47px;
  width: 483px;
}
#wrapper #bodyitem .category_section .box .text_wrap .text {
}
#wrapper #bodyitem .category_section .box .text_wrap .btn {
  width: 416px;
  margin: 46px 0 0 2px;
}



/* --------------------------------------------------
  another
-------------------------------------------------- */
#wrapper #another {
  background-color: #e7d5c2;
}
#wrapper #another .inner {
  padding-top: 70px;
  padding-bottom: 110px;
}
#wrapper #another .inner .title {
  width: 487px;
  margin: 0 auto 78px auto;
}
#wrapper #another .inner .list {
  display: flex;
  justify-content: space-between;
  max-width: 1269px;
  margin: 0 auto;
}
#wrapper #another .inner .list .item {
  width: calc(378 / 1269 * 100%);
}



/* --------------------------------------------------
  hover
-------------------------------------------------- */
.noTouch #wrapper #another .inner .list .item a img,
.noTouch #wrapper #bodyitem .category_section .box .text_wrap .btn a img {
  transform: translate3d(0,0,0);
  transition: all 800ms cubic-bezier(0.23, 1, 0.32, 1);
}
.noTouch #wrapper #another .inner .list .item a:hover img,
.noTouch #wrapper #bodyitem .category_section .box .text_wrap .btn a:hover img {
  opacity: 0.8;
}

