@charset "UTF-8";
/* function
----------------------------------------------*/
/* mixin
----------------------------------------------*/
.l-bekkaku-prologue,
.bekkaku-future_inner,
.bekkaku-team_inner,
.bekkaku-change_inner,
.bekkaku-challenge_inner,
.bekkaku-other_inner {
  position: relative;
}

.l-bekkaku-prologue > *:first-child,
.bekkaku-future_inner > *:first-child,
.bekkaku-team_inner > *:first-child,
.bekkaku-change_inner > *:first-child,
.bekkaku-challenge_inner > *:first-child,
.bekkaku-other_inner > *:first-child {
  margin-top: 0 !important;
}

.l-bekkaku-prologue > *:last-child,
.bekkaku-future_inner > *:last-child,
.bekkaku-team_inner > *:last-child,
.bekkaku-change_inner > *:last-child,
.bekkaku-challenge_inner > *:last-child,
.bekkaku-other_inner > *:last-child {
  margin-bottom: 0 !important;
}

.p-bekkaku--story {
  background-color: #f0f0f0;
}

.bekkaku-paragraph--ug {
  margin-bottom: 2em;
  color: #000;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 16px;
  line-height: 2;
}

.bekkaku-change_wrap .bekkaku-paragraph--ug {
  font-size: 17px;
}

.transition-title img {
  opacity: 0;
  transform: translateY(30px);
  transition-property: opacity, transform;
  transition-duration: 1.5s;
  transition-timing-function: ease;
}

.transition-title img:nth-child(1) {
  transition-delay: 0.5s;
}

.transition-title img:nth-child(2) {
  transition-delay: 1.5s;
}

.transition-title.is-active img {
  opacity: 1;
  transform: translateY(0);
}

.bekkaku-siteGuide_scroll--project {
  color: #fff;
}

.bekkaku-siteGuide_scroll--project:before {
  background-color: #fff;
}

/* unique
----------------------------------------------*/
.bekkaku-hero {
  position: relative;
}

.bekkaku-hero::before,
.bekkaku-hero::after {
  position: absolute;
  z-index: 100;
  content: "";
  transition: ease transform 2s;
}

.bekkaku-hero::before {
  background: url("/bekkaku/img/text_bek.svg") 0 0 no-repeat;
  transform: translateY(50%);
}

.bekkaku-hero::after {
  background: url("/bekkaku/img/text_kaku.svg") 0 0 no-repeat;
  transform: translateY(-50%);
}

.bekkaku-hero.is-active::before,
.bekkaku-hero.is-active::after {
  transform: translateY(0);
}

.bekkaku-hero_slideshow {
  position: relative;
  overflow: hidden;
}

.bekkaku-hero_slideshow img {
  transform: scale(1.25);
  transition: ease transform 4s;
  width: 100%;
}

.is-active .bekkaku-hero_slideshow img {
  transform: scale(1);
}

.bekkaku-hero_slideshow .slick-slide img {
  transform: scale(1.25);
  transition: ease transform 4s;
}

.bekkaku-hero_slideshow .slick-current img {
  transform: scale(1);
}

.bekkaku-clip {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  position: relative;
  z-index: 5;
}

.bekkaku-clip::before {
  position: absolute;
  top: 0;
  left: 50%;
  background: url("/bekkaku/img/icon_play.svg") 0 0 no-repeat;
  content: "";
}

.bekkaku-clip img {
  width: 100%;
}

.bekkaku-voice_title {
  margin-bottom: 30px;
  color: #666;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  text-align: center;
  font-weight: normal;
}

.bekkaku-voice_list {
  position: relative;
  color: #000;
  line-height: 1.8;
  text-align: center;
  font-weight: 400;
}

.bekkaku-voice_list::before,
.bekkaku-voice_list::after {
  position: absolute;
  top: 0;
  width: 34px;
  height: 27px;
  background: url("/bekkaku/img/icon_quotation.png") 0 0 no-repeat;
  background-size: 34px auto;
  content: "";
}

.bekkaku-voice_list::before {
  left: 0;
}

.bekkaku-voice_list::after {
  right: 0;
  transform: scale(-1, -1);
}

.bekkaku-voice_list .slick-slide {
  opacity: 0;
  transition: ease opacity 0.8s;
}

.bekkaku-voice_list .slick-slide.slick-active,
.bekkaku-voice_list .slick-slide.slick-cloned {
  opacity: 1;
}

.bekkaku-menu_item {
  position: relative;
}

.bekkaku-menu_item--movie {
  justify-content: center;
}

.bekkaku-menu_item--product {
  justify-content: flex-start;
}

/* bekkaku-prologue
----------------------------------------------*/
.l-bekkaku-prologue::before,
.l-bekkaku-prologue::after {
  position: absolute;
  left: 50%;
  width: 98px;
  margin-left: -49px;
  background: linear-gradient(#eaeaea, #e5e5e5, #d9d9d9);
  content: "";
}

.l-bekkaku-prologue::before {
  top: 0;
  height: 140px;
}

.l-bekkaku-prologue::after {
  bottom: 0;
  height: 160px;
}

.bekkaku-prologue_text > *:last-child {
  margin-bottom: 0 !important;
}

.bekkaku-prologue_text .bekkaku-paragraph--ug {
  font-feature-settings: "palt";
  letter-spacing: 0.05em;
}

.bekkaku-prologue_lead {
  margin-bottom: 35px;
}

/* bekkaku-future
----------------------------------------------*/
.bekkaku-future_title {
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
  position: absolute;
  z-index: 100;
}

/* bekkaku-team
----------------------------------------------*/
.bekkaku-team_title {
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
  position: absolute;
  z-index: 100;
}

.bekkaku-gallery_scroll--team {
  background: url("/bekkaku/img/team_bg_scroll.jpg") 0 0 repeat-x;
  animation-fill-mode: both;
}

@keyframes teamScroll {
  0% {
    background-position: 1650px 0;
  }
  100% {
    background-position: 0 0;
  }
}
@keyframes teamScrollSp {
  0% {
    background-position: 1155px 0;
  }
  100% {
    background-position: 0 0;
  }
}
/* bekkaku-change
----------------------------------------------*/
.bekkaku-change_title {
  position: absolute;
  z-index: 100;
}

.bekkaku-change_media {
  position: relative;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}

.bekkaku-change_media_image figure {
  margin: 0;
}

.bekkaku-change_media_image figcaption {
  margin: 1em 0;
  color: #444;
  font-size: 14px;
  text-align: center;
}

.bekkaku-change_media_text > *:last-child {
  margin-bottom: 0 !important;
}

.bekkaku-change_button {
  display: flex;
  align-items: center;
  justify-content: center;
}

.bekkaku-change_button a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 193px;
  height: 39px;
  padding: 6px 5px 4px;
  border: 1px solid #888;
  color: #444;
  font-size: 14px;
}

.bekkaku-change_button a[target=_blank] span {
  display: inline-block;
  position: relative;
  padding: 0 22px 0 0;
  margin-right: -8px;
}

.bekkaku-change_button a[target=_blank] span::after {
  position: absolute;
  top: calc(50% - 6px);
  right: 0;
  width: 12px;
  height: 12px;
  background: url("/bekkaku/img/icon_blank.svg") 0 0 no-repeat;
  background-size: 12px auto;
  content: "";
}

/* bekkaku-challenge
----------------------------------------------*/
.bekkaku-challenge_title {
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
  position: absolute;
  z-index: 100;
}

.bekkaku-challenge_lead {
  text-align: center;
  opacity: 0;
  transition: ease all 1.2s 0.2s;
}

.bekkaku-challenge_lead.is-active {
  opacity: 1;
}

/* bekkaku-other
----------------------------------------------*/
.l-bekkaku-other {
  background-color: #e8e8e8;
}

.bekkaku-other_logo {
  text-align: center;
}

.bekkaku-other_slider_elm {
  height: 279px;
  width: 100%;
  background: 50% 50% no-repeat;
  background-size: cover;
}

.bekkaku-other_slider_elm.is-cat01 {
  background-image: url("/bekkaku/img/other_im01.jpg");
}

.bekkaku-other_slider_elm.is-cat02 {
  background-image: url("/bekkaku/img/other_im02.jpg");
}

.bekkaku-other_slider_elm.is-cat03 {
  background-image: url("/bekkaku/img/other_im03.jpg");
}

.bekkaku-other_slider_elm.is-cat04 {
  background-image: url("/bekkaku/img/other_im04.jpg");
}

@media print, (min-width: 1050px) {
  .l-bekkaku-prologue,
  .bekkaku-future_inner,
  .bekkaku-team_inner,
  .bekkaku-change_inner,
  .bekkaku-challenge_inner,
  .bekkaku-other_inner {
    width: 898px;
    margin: 0 auto;
    padding: 110px 0 160px;
  }
  .transition-title img {
    width: 4.5vw;
  }
  .bekkaku-hero::before {
    top: -3.7%;
    right: 7.3%;
    width: 186px;
    height: 305px;
  }
  .bekkaku-hero::after {
    bottom: -3.8%;
    left: 7.1%;
    width: 181px;
    height: 311px;
  }
  .bekkaku-gallery {
    margin: 75px calc(-50vw + 50%) 75px 0;
  }
  .bekkaku-clip {
    width: 119px;
    height: 93px;
    transition: ease opacity 0.3s;
  }
  a:hover .bekkaku-clip {
    opacity: 0.8;
  }
  .bekkaku-clip::before {
    width: 62px;
    height: 62px;
    margin-left: -31px;
    background-size: 62px auto;
  }
  .bekkaku-voice {
    width: 804px;
    margin: 0 auto 85px;
  }
  .bekkaku-voice_title {
    font-size: 18px;
  }
  .bekkaku-voice_list {
    padding: 0 50px;
    font-size: 20px;
  }
  .bekkaku-menu {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .bekkaku-menu_item {
    display: flex;
    align-items: center;
    width: calc(50% - 20px);
    height: 279px;
    background-color: #dcdcde;
    transition: ease opacity 0.3s;
  }
  .bekkaku-menu_item:hover {
    opacity: 0.8;
  }
  .bekkaku-menu_item .bekkaku-menu_bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
  }
  .bekkaku-menu_item--product {
    padding: 10px 0 0 38px;
  }
  .bekkaku-menu_item--product .bekkaku-menu_bg {
    top: auto;
    right: 17px;
    bottom: 10px;
    left: auto;
  }
  .l-bekkaku-prologue {
    width: 896px;
    padding: 140px 0 160px;
  }
  .l-bekkaku-prologue::before,
  .l-bekkaku-prologue::after {
    display: none;
  }
  .bekkaku-prologue_title {
    position: absolute;
    top: 140px;
    left: 114px;
  }
  .bekkaku-prologue_text {
    padding-left: 350px;
  }
  .bekkaku-prologue_text .bekkaku-paragraph--ug {
    line-height: 2.125;
  }
  .bekkaku-prologue_image {
    margin-top: 100px;
  }
  .bekkaku-future_title {
    top: 100px;
    left: calc(50% - 70px);
  }
  .bekkaku-future_title img:nth-child(2) {
    margin: 95px 10px 0 0;
  }
  .bekkaku-future_image {
    margin-top: 90px;
  }
  .bekkaku-team_title {
    top: 100px;
    left: calc(50% - 4.6vw);
  }
  .bekkaku-team_title img:nth-child(2) {
    margin: 68px 10px 0 0;
  }
  .bekkaku-gallery_scroll--team {
    height: 220px;
    animation: teamScroll 70s linear 0s infinite;
  }
  .bekkaku-change_title {
    top: 220px;
    left: calc(50% - 2.3vw);
  }
  .bekkaku-change_media_image {
    position: absolute;
    top: 0.2em;
    left: 546px;
    width: 468px;
  }
  .bekkaku-change_media_text {
    width: 48%;
  }
  .bekkaku-challenge_title {
    top: 100px;
    left: calc(50% - 4.6vw);
  }
  .bekkaku-challenge_title img:nth-child(2) {
    margin: 74px 10px 0 0;
  }
  .bekkaku-challenge_image {
    margin: 80px -117px 0;
  }
  .bekkaku-challenge_lead {
    margin-top: 165px;
  }
  .bekkaku-other_inner {
    width: 1132px;
    padding: 58px 0 126px;
  }
  .bekkaku-other_logo {
    margin-bottom: 60px;
  }
}
@media (max-width: 1049px) {
  .l-bekkaku-prologue,
  .bekkaku-future_inner,
  .bekkaku-team_inner,
  .bekkaku-change_inner,
  .bekkaku-challenge_inner,
  .bekkaku-other_inner {
    padding: 0 30px;
  }
  .p-bekkaku--story {
    overflow: hidden;
  }
  .bekkaku-hero::before {
    top: -19px;
    right: -2px;
    width: 92px;
    height: 150px;
    background-size: cover;
  }
  .bekkaku-hero::after {
    bottom: -32px;
    left: -3px;
    width: 89px;
    height: 152px;
    background-size: cover;
  }
  .bekkaku-menu_bg {
    text-align: center;
  }
  .bekkaku-gallery {
    margin: 65px -30px;
  }
  .bekkaku-clip {
    height: 87px;
  }
  .bekkaku-clip::before {
    width: 58px;
    height: 58px;
    margin-left: -29px;
    background-size: 58px auto;
  }
  .bekkaku-voice {
    margin-bottom: 30px;
  }
  .bekkaku-voice_title {
    font-size: 16px;
  }
  .bekkaku-voice_list {
    padding: 42px 0;
    font-size: 15px;
  }
  .bekkaku-voice_list::after {
    top: auto;
    bottom: 0;
  }
  .bekkaku-voice_list .slick-track {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .bekkaku-menu_item {
    display: block;
    margin-bottom: 40px;
  }
  .bekkaku-menu_item:last-child {
    margin-bottom: 0;
  }
  .bekkaku-menu_item span:first-child {
    display: none;
  }
  .l-bekkaku-prologue {
    padding-top: 75px;
    padding-bottom: 130px;
  }
  .l-bekkaku-prologue::before,
  .l-bekkaku-prologue::after {
    display: none;
  }
  .bekkaku-prologue_title {
    width: 69px;
    margin: 0 auto 54px;
  }
  .bekkaku-prologue_image {
    margin-top: 60px;
  }
  .bekkaku-future_title {
    top: 13.973%;
    left: 34.9%;
    width: 30.2%;
  }
  .bekkaku-future_title img {
    max-width: calc(50% - 2.5px);
  }
  .bekkaku-future_title img:nth-child(2) {
    margin: 77px 5px 0 0;
  }
  .bekkaku-future_inner {
    padding-top: 85px;
    padding-bottom: 114px;
  }
  .bekkaku-future_image {
    margin-top: 85px;
  }
  .bekkaku-team_title {
    top: 8.4175%;
    left: 34.9%;
    width: 30.2%;
  }
  .bekkaku-team_title img {
    max-width: calc(50% - 2.5px);
  }
  .bekkaku-team_title img:nth-child(2) {
    margin: 77px 5px 0 0;
  }
  .bekkaku-team_inner {
    padding-top: 75px;
    padding-bottom: 112px;
  }
  .bekkaku-gallery_scroll--team {
    height: 154px;
    background-size: 1155px 154px;
    animation: teamScrollSp 35s linear 0s infinite;
  }
  .bekkaku-change_title {
    top: 8.4175%;
    left: 42.83845%;
    width: 14.3231%;
  }
  .bekkaku-change_inner {
    padding-top: 53px;
    padding-bottom: 100px;
  }
  .bekkaku-change_media_image {
    margin-bottom: 50px;
  }
  .bekkaku-challenge_title {
    top: 8.4175%;
    left: 34.9%;
    width: 30.2%;
  }
  .bekkaku-challenge_title img {
    max-width: calc(50% - 2.5px);
  }
  .bekkaku-challenge_title img:nth-child(2) {
    margin: 49px 5px 0 0;
  }
  .bekkaku-challenge_inner {
    padding-top: 75px;
    padding-bottom: 66px;
  }
  .bekkaku-challenge_image {
    margin-top: 58px;
  }
  .bekkaku-challenge_image img {
    width: 100%;
  }
  .bekkaku-challenge_lead {
    margin-top: 68px;
  }
  .l-bekkaku-other .bekkaku-clip {
    position: absolute;
    top: calc(50% - 36px);
    left: calc(50% - 45px);
    height: auto;
    display: block !important;
    padding-top: 55px;
  }
  .l-bekkaku-other .bekkaku-clip:before {
    width: 50px;
    height: 50px;
    margin-left: -25px;
    background-size: 50px auto;
  }
  .bekkaku-other_inner {
    padding-top: 48px;
    padding-bottom: 55px;
  }
  .bekkaku-other_logo {
    width: 44px;
    margin: 0 auto 45px;
  }
  img.bekkaku-other_movie {
    height: auto;
    width: 90px;
  }
  .bekkaku-other_slider_elm {
    height: 25vh;
    min-height: 161px;
  }
}
.bekkaku-mv_new {
  position: absolute;
  z-index: 5;
  color: #604a35;
  text-align: center;
  font-feature-settings: "palt";
}

.bekkaku-mv_new_icon {
  font-size: 27px;
  font-family: serif;
  letter-spacing: 0.06em;
}

.bekkaku-mv_new_title {
  font-size: 15px;
  line-height: 1.46;
  letter-spacing: 0.15em;
  white-space: nowrap;
}

.bekkaku-mv_new_button {
  position: relative;
  display: block;
  margin: 12px 0 0;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background-color: #b68b37;
  color: #fff;
}

.bekkaku-mv_new_arw {
  position: absolute;
  bottom: 12px;
  left: calc(50% - 6px);
  z-index: 15;
  display: block;
  animation: linkarrow_attention 1.5s infinite;
}

.bekkaku-mv_new_arw:after {
  transform: rotate(135deg);
  width: 12px;
  height: 12px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  content: "";
  display: block;
  transition: ease all 0.3s;
}

.bekkaku-mv_new_label {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 0;
  width: 100%;
  font-size: 20px;
  line-height: 1.4;
  text-indent: 0.24em;
  font-weight: bold;
  letter-spacing: 0.24em;
  text-align: center;
  transform: translateY(-50%);
  white-space: nowrap;
}

.bekkaku-mv_new_hover {
  position: absolute;
  z-index: 5;
  bottom: -1px;
  left: calc(50% - 104px);
  width: 208px;
  transform: scale(0);
  transition: ease all 0.5s;
  transform-origin: 50% 100%;
}

@media print, (min-width: 1050px) {
  .bekkaku-mv_new {
    width: 120px;
    bottom: 22%;
    right: 12.72%;
  }
  .bekkaku-mv_new_button:hover .bekkaku-mv_new_hover {
    transform: scale(1);
  }
}
@media (max-width: 1049px) {
  .bekkaku-mv_new {
    top: 45.333vw;
    left: 8.3vw;
    width: 24vw;
    height: 24vw;
  }
  .bekkaku-mv_new_button {
    width: 100%;
    height: 100%;
    font-size: 14px;
  }
  .bekkaku-mv_new_arw {
    bottom: 8px;
    left: calc(50% - 4px);
  }
  .bekkaku-mv_new_arw:after {
    border-width: 1px;
    width: 8px;
    height: 8px;
  }
  .bekkaku-mv_new_label {
    font-size: 3.733vw;
  }
  .bekkaku-mv_new_hover {
    display: none;
  }
}
.bekkaku-mv_design {
  position: absolute;
  z-index: 5;
}

@media print, (min-width: 1050px) {
  .bekkaku-mv_design {
    top: calc(50% + 230px);
    left: 9%;
    width: 140px;
  }
}
@media (max-width: 1049px) {
  .bekkaku-mv_design {
    bottom: 20px;
    left: 38vw;
    width: 24vw;
  }
}/*# sourceMappingURL=style.css.map */