@charset "UTF-8";
@import url("//fonts.googleapis.com/css?family=Arvo:700");
@import url("//fonts.googleapis.com/earlyaccess/notosansjapanese.css");
.onePiece {
  font-family: "Noto Sans Japanese", "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-weight: 600;
  color: #000; }
  .onePiece h1, .onePiece h2, .onePiece h3, .onePiece h4, .onePiece h5 {
    font-weight: 700; }

.onlyMobile {
  display: block; }
  @media only screen and (min-width: 769px) {
    .onlyMobile {
      display: none; } }

.onlyDesktop {
  display: none; }
  @media only screen and (min-width: 769px) {
    .onlyDesktop {
      display: block; } }

/** js-inView
/**************************************/
.js-inView.do-skew {
  opacity: 0;
  transform: rotateY(25deg) skewX(25deg);
  -webkit-transition: 1.5s cubic-bezier(0.23, 1, 0.32, 1);
  -moz-transition: 1.5s cubic-bezier(0.23, 1, 0.32, 1);
  -o-transition: 1.5s cubic-bezier(0.23, 1, 0.32, 1);
  transition: 1.5s cubic-bezier(0.23, 1, 0.32, 1); }
  .js-inView.do-skew.inView {
    opacity: 1;
    transform: rotateY(0) skewX(0); }

.js-inView.do-fade {
  opacity: 0;
  -webkit-transition: 1.5s cubic-bezier(0.39, 0.575, 0.565, 1);
  -moz-transition: 1.5s cubic-bezier(0.39, 0.575, 0.565, 1);
  -o-transition: 1.5s cubic-bezier(0.39, 0.575, 0.565, 1);
  transition: 1.5s cubic-bezier(0.39, 0.575, 0.565, 1); }
  .js-inView.do-fade.inView {
    opacity: 1; }

.js-inView.do-up {
  opacity: 0;
  -webkit-transition: 1.3s cubic-bezier(0.23, 1, 0.32, 1);
  -moz-transition: 1.3s cubic-bezier(0.23, 1, 0.32, 1);
  -o-transition: 1.3s cubic-bezier(0.23, 1, 0.32, 1);
  transition: 1.3s cubic-bezier(0.23, 1, 0.32, 1);
  -webkit-transform: translate3d(0, 50px, 0);
  -moz-transform: translate3d(0, 50px, 0);
  -o-transform: translate3d(0, 50px, 0);
  transform: translate3d(0, 50px, 0); }
  .js-inView.do-up.inView {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

.js-inView.do-left {
  opacity: 0;
  -webkit-transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  -moz-transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  -o-transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  -webkit-transform: translate3d(70px, 0, 0);
  -moz-transform: translate3d(70px, 0, 0);
  -o-transform: translate3d(70px, 0, 0);
  transform: translate3d(70px, 0, 0); }
  .js-inView.do-left.inView {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

.js-inView.do-right {
  opacity: 0;
  -webkit-transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  -moz-transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  -o-transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  transition: 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  -webkit-transform: translate3d(-70px, 0, 0);
  -moz-transform: translate3d(-70px, 0, 0);
  -o-transform: translate3d(-70px, 0, 0);
  transform: translate3d(-70px, 0, 0); }
  .js-inView.do-right.inView {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

.js-inView.do-rotate {
  -webkit-transition: 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s;
  -moz-transition: 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s;
  -o-transition: 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s;
  transition: 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s;
  -webkit-transform-origin: center center;
  -moz-transform-origin: center center;
  -ms-transform-origin: center center;
  -o-transform-origin: center center;
  transform-origin: center center;
  -webkit-transform: scaleX(0);
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -o-transform: scaleX(0);
  transform: scaleX(0); }
  .js-inView.do-rotate.inView {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1); }

.js-inView.do-delay1 {
  transition-delay: 0s !important; }

.js-inView.do-delay2 {
  transition-delay: 0.3s !important; }

.js-inView.do-delay3 {
  transition-delay: 0.6s !important; }

.js-inView.do-delay4 {
  transition-delay: 0.9s !important; }

.js-inView.do-delay5 {
  transition-delay: 1.2s !important; }

.js-inView.do-delay6 {
  transition-delay: 1.5s !important; }

/** chain
/**************************************/
.do-chain > * {
  opacity: 0;
  -webkit-transform: translate3d(0, 60px, 0);
  -moz-transform: translate3d(0, 60px, 0);
  -o-transform: translate3d(0, 60px, 0);
  transform: translate3d(0, 60px, 0);
  -webkit-transition: 2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -moz-transition: 2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -o-transition: 2s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: 2s cubic-bezier(0.165, 0.84, 0.44, 1); }

.do-chain.inView > * {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }
  .do-chain.inView > *:nth-child(1) {
    opacity: 1;
    -webkit-transition-delay: 0.3s;
    transition-delay: 0.3s; }
  .do-chain.inView > *:nth-child(2) {
    opacity: 1;
    -webkit-transition-delay: 0.4s;
    transition-delay: 0.4s; }
  .do-chain.inView > *:nth-child(3) {
    opacity: 1;
    -webkit-transition-delay: 0.5s;
    transition-delay: 0.5s; }
  .do-chain.inView > *:nth-child(4) {
    opacity: 1;
    -webkit-transition-delay: 0.6s;
    transition-delay: 0.6s; }
  .do-chain.inView > *:nth-child(5) {
    opacity: 1;
    -webkit-transition-delay: 0.7s;
    transition-delay: 0.7s; }
  .do-chain.inView > *:nth-child(6) {
    opacity: 1;
    -webkit-transition-delay: 0.8s;
    transition-delay: 0.8s; }
  .do-chain.inView > *:nth-child(7) {
    opacity: 1;
    -webkit-transition-delay: 0.9s;
    transition-delay: 0.9s; }
  .do-chain.inView > *:nth-child(8) {
    opacity: 1;
    -webkit-transition-delay: 1s;
    transition-delay: 1s; }
  .do-chain.inView > *:nth-child(9) {
    opacity: 1;
    -webkit-transition-delay: 1.1s;
    transition-delay: 1.1s; }
  .do-chain.inView > *:nth-child(10) {
    opacity: 1;
    -webkit-transition-delay: 1.2s;
    transition-delay: 1.2s; }
  .do-chain.inView > *:nth-child(11) {
    opacity: 1;
    -webkit-transition-delay: 1.3s;
    transition-delay: 1.3s; }
  .do-chain.inView > *:nth-child(12) {
    opacity: 1;
    -webkit-transition-delay: 1.4s;
    transition-delay: 1.4s; }
  .do-chain.inView > *:nth-child(13) {
    opacity: 1;
    -webkit-transition-delay: 1.5s;
    transition-delay: 1.5s; }

/** Border
/**************************************/
.opButtonBorder {
  border: 5px solid;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 86px; }
  @media only screen and (max-width: 769px) {
    .opButtonBorder {
      height: 62.5px; } }
  .opButtonBorder.is-black {
    border-color: #ffff;
    color: #fff; }
    .desctop .opButtonBorder.is-black {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .opButtonBorder.is-black:hover {
        background-color: #fff; }
        .desctop .opButtonBorder.is-black:hover span {
          color: #000; }
  .opButtonBorder.is-white {
    border-color: #000;
    color: #000; }
    .opButtonBorder.is-white i {
      background-color: #000; }
    .desctop .opButtonBorder.is-white {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .opButtonBorder.is-white:hover {
        background-color: #000; }
        .desctop .opButtonBorder.is-white:hover span {
          color: #fff; }
  .opButtonBorder.icon-plus i {
    display: block;
    position: relative; }
    .opButtonBorder.icon-plus i:before, .opButtonBorder.icon-plus i:after {
      position: absolute;
      background-color: #000;
      display: block;
      content: '';
      z-index: 1; }
    .opButtonBorder.icon-plus i:before {
      width: 10px;
      height: 2px;
      left: calc(50% - 5px);
      top: calc(50% - 1px); }
    .opButtonBorder.icon-plus i:after {
      width: 2px;
      height: 10px;
      left: calc(50% - 1px);
      top: calc(50% - 5px); }
  @media only screen and (min-width: 769px) {
    .opButtonBorder.icon-plus.is-black:hover i {
      background-color: #000; }
      .opButtonBorder.icon-plus.is-black:hover i:before, .opButtonBorder.icon-plus.is-black:hover i:after {
        background-color: #fff; } }
  .opButtonBorder.icon-plus.is-white i:before, .opButtonBorder.icon-plus.is-white i:after {
    background-color: #fff; }
  @media only screen and (min-width: 769px) {
    .opButtonBorder.icon-plus.is-white:hover {
      background-color: #000; }
      .opButtonBorder.icon-plus.is-white:hover i {
        background-color: #fff; }
        .opButtonBorder.icon-plus.is-white:hover i:before, .opButtonBorder.icon-plus.is-white:hover i:after {
          background-color: #000; } }
  .opButtonBorder.icon-down.is-black i {
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fff;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
    -khtml-border-radius: 50%;
    border-radius: 50%; }
    .opButtonBorder.icon-down.is-black i:before {
      display: block;
      content: '';
      width: 5.5px;
      height: 5.5px;
      border-top: 2px solid #fff;
      border-right: 2px solid #fff;
      border-color: #000;
      -webkit-transform: rotate(135deg);
      transform: rotate(135deg);
      margin-top: -2px; }
    .opButtonBorder.icon-down.is-black i:before {
      border-color: #000; }
  @media only screen and (min-width: 769px) {
    .opButtonBorder.icon-down.is-black:hover i {
      background-color: #000; }
      .opButtonBorder.icon-down.is-black:hover i:before {
        border-color: #fff; } }
  .opButtonBorder.icon-down.is-white i {
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #000;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
    -khtml-border-radius: 50%;
    border-radius: 50%; }
    .opButtonBorder.icon-down.is-white i:before {
      display: block;
      content: '';
      width: 5.5px;
      height: 5.5px;
      border-top: 2px solid #fff;
      border-right: 2px solid #fff;
      -webkit-transform: rotate(135deg);
      transform: rotate(135deg);
      margin-top: -2px; }
  @media only screen and (min-width: 769px) {
    .opButtonBorder.icon-down.is-white:hover i {
      background-color: #fff; }
      .opButtonBorder.icon-down.is-white:hover i:before {
        border-color: #000; } }
  .opButtonBorder span {
    font-size: 18px; }
    @media only screen and (max-width: 769px) {
      .opButtonBorder span {
        font-size: 14px; } }
  .opButtonBorder i {
    margin-right: 10px;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fff;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
    -khtml-border-radius: 50%;
    border-radius: 50%; }

/** Fill
/**************************************/
.opButtonFill {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 103px;
  position: relative; }
  @media only screen and (max-width: 769px) {
    .opButtonFill {
      height: 82px; } }
  .opButtonFill.is-red {
    background-color: #ca0915; }
    .opButtonFill.is-red.icon-right i {
      width: 22px;
      height: 22px;
      display: flex;
      align-items: center;
      justify-content: center;
      background-color: #ca0915;
      -moz-border-radius: 50%;
      -webkit-border-radius: 50%;
      -o-border-radius: 50%;
      -ms-border-radius: 50%;
      -khtml-border-radius: 50%;
      border-radius: 50%;
      background-color: #fff; }
      .opButtonFill.is-red.icon-right i:before {
        display: block;
        content: '';
        width: 5.5px;
        height: 5.5px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        border-color: #ca0915;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        margin-left: -2px;
        margin-top: -0px; }
    .desctop .opButtonFill.is-red {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .opButtonFill.is-red:hover {
        background-color: #ef2e3a; }
  .opButtonFill.is-black {
    background-color: #000; }
    .opButtonFill.is-black.icon-right i {
      width: 22px;
      height: 22px;
      display: flex;
      align-items: center;
      justify-content: center;
      background-color: #fff;
      -moz-border-radius: 50%;
      -webkit-border-radius: 50%;
      -o-border-radius: 50%;
      -ms-border-radius: 50%;
      -khtml-border-radius: 50%;
      border-radius: 50%; }
      .opButtonFill.is-black.icon-right i:before {
        display: block;
        content: '';
        width: 5.5px;
        height: 5.5px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        border-color: #000;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        margin-left: -2px;
        margin-top: -0px; }
    .desctop .opButtonFill.is-black {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .opButtonFill.is-black:hover {
        opacity: .6; }
  .opButtonFill.is-hidden {
    background-color: #9f9f9f;
    pointer-events: none; }
    .opButtonFill.is-hidden span {
      color: #fff;
      opacity: .6;
      font-weight: 700; }
  .opButtonFill i {
    margin-right: 10px;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fff;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
    -khtml-border-radius: 50%;
    border-radius: 50%; }
    .opDetailButton .opButtonFill i {
      position: absolute;
      right: 15px;
      top: calc(50% - 11px); }
      @media only screen and (max-width: 769px) {
        .opDetailButton .opButtonFill i {
          right: -5px;
          -webkit-transform: scale(0.6);
          -moz-transform: scale(0.6);
          -ms-transform: scale(0.6);
          -o-transform: scale(0.6);
          transform: scale(0.6); } }
  .opButtonFill span {
    color: #fff;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.4285714286; }
    @media only screen and (max-width: 769px) {
      .opButtonFill span {
        font-size: 14px; } }

/** opCampaign
/**************************************/
.opCampaign {
  margin-top: 130px;
  margin-top: 200px;
  text-align: center;
  position: relative;
  width: 1160px;
  margin-left: auto;
  margin-right: auto; }
  @media only screen and (max-width: 769px) {
    .opCampaign {
      width: 86.6666666667%; } }
  @media only screen and (max-width: 769px) {
    .opCampaign {
      margin-top: 65px;
      margin-top: 100px; } }
  .opCampaign_lead {
    font-size: 24px;
    font-weight: 700;
    margin-top: 75px; }
    @media only screen and (max-width: 769px) {
      .opCampaign_lead {
        font-size: 16px;
        margin-top: 60px; } }
  .opCampaign_body {
    font-size: 16px;
    margin-top: 40px; }
  .opCampaign_soon {
    margin-top: 50px; }
    @media only screen and (max-width: 769px) {
      .opCampaign_soon {
        margin-top: 30px;
        width: 65%;
        margin-left: auto;
        margin-right: auto; }
        .opCampaign_soon img {
          max-width: 100%;
          height: auto; } }

/** opConcept
/**************************************/
.opConcept {
  overflow: hidden;
  background-color: #fafafa;
  background-repeat: no-repeat;
  background-position: right bottom;
  background-image: url("../img/concept_bg.png"); }
  @media only screen and (max-width: 769px) {
    .opConcept {
      background-repeat: no-repeat;
      background-position: 80% 100%;
      background-size: 200% auto; } }
  @media only screen and (min-width: 769px) {
    .is-opScrolled .opConcept {
      padding-top: 100px; } }
  .opConcept_wrap {
    padding: 160px 0 55px;
    position: relative;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opConcept_wrap {
        width: 86.6666666667%; } }
    @media only screen and (max-width: 769px) {
      .opConcept_wrap {
        padding: 80px 0 25px; } }
  .opConcept_content {
    width: 630px; }
    @media only screen and (max-width: 769px) {
      .opConcept_content {
        width: 100%; } }
  .opConcept_headline {
    margin-bottom: 90px; }
    @media only screen and (max-width: 769px) {
      .opConcept_headline {
        margin-bottom: 70px; } }
  .opConcept_title {
    font-size: 46px;
    font-weight: 700;
    margin-bottom: 50px; }
    @media only screen and (max-width: 769px) {
      .opConcept_title {
        font-size: 23px;
        margin-bottom: 25px; } }
  .opConcept_body p {
    font-size: 16px;
    line-height: 2;
    margin-bottom: 22px; }
    @media only screen and (max-width: 769px) {
      .opConcept_body p {
        font-size: 14px; } }
  .opConcept_image {
    position: absolute;
    right: -44.7%;
    top: 10.8%;
    width: 86.2%; }
    .opConcept_image img {
      max-width: 100%;
      height: auto; }
    @media only screen and (max-width: 769px) {
      .opConcept_image {
        position: static;
        width: 150%; } }

/** opDetail
/**************************************/
.opDetail {
  background-repeat: no-repeat;
  background-size: cover; }
  .opDetail.is-black {
    color: #fff;
    padding-bottom: 220px;
    position: relative;
    z-index: 1; }
    @media only screen and (max-width: 769px) {
      .opDetail.is-black {
        padding-bottom: 12%;
        background-position: top center;
        background-image: url("../img/item_black_bg01-sp.png"); } }
  .opDetail.is-white {
    color: #000;
    padding-bottom: 170px;
    position: relative;
    z-index: 0; }
    @media only screen and (max-width: 769px) {
      .opDetail.is-white {
        padding-bottom: 0; } }
    @media only screen and (max-width: 769px) {
      .opDetail.is-white:after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        padding-top: 9.1%;
        background-repeat: no-repeat;
        background-position: center bottom;
        background-size: 100% auto;
        background-image: url("../img/item_black_bg02-sp.png"); }
      .opDetail.is-white:before {
        position: absolute;
        right: 0;
        top: 0;
        width: 246px;
        height: 364px;
        content: '';
        background-repeat: no-repeat;
        background-position: left top;
        background-size: cover;
        background-image: url("../img/item_white_bg-sp.png"); } }
  .opDetail.is-limited {
    padding-bottom: 16%;
    padding-bottom: 20%; }
  .opDetail_wrap {
    position: relative;
    display: flex;
    justify-content: space-between;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opDetail_wrap {
        width: 86.6666666667%; } }
    @media only screen and (max-width: 769px) {
      .opDetail_wrap {
        display: block; } }
    .is-white .opDetail_wrap {
      flex-direction: row-reverse; }
  @media only screen and (min-width: 769px) {
    .opDetail_outer {
      background-repeat: no-repeat;
      background-position: center center;
      background-position: top center;
      background-size: cover;
      background-image: url("../img/item_bg-pc.png"); } }
  .opDetail_panel {
    position: absolute;
    right: 0; }
    @media only screen and (max-width: 769px) {
      .opDetail_panel {
        width: 150px;
        width: 40%; }
        .opDetail_panel img {
          max-width: 100%;
          height: auto; } }
    .is-black .opDetail_panel {
      top: 0%; }
    .is-white .opDetail_panel {
      top: -12%;
      z-index: 1; }
      @media only screen and (max-width: 769px) {
        .is-white .opDetail_panel {
          top: 0; } }
  .opDetail_cast img {
    max-width: 100%;
    height: auto; }
  @media only screen and (max-width: 769px) {
    .opDetail_cast {
      margin-bottom: 30px; } }
  .is-black .opDetail_cast {
    margin-left: -60px; }
    @media only screen and (max-width: 769px) {
      .is-black .opDetail_cast {
        margin-left: 10%;
        width: 40%; } }
  .is-white .opDetail_cast {
    margin-top: 70px;
    margin-right: -60px;
    z-index: 1;
    position: relative; }
    @media only screen and (max-width: 769px) {
      .is-white .opDetail_cast {
        margin: 0;
        width: 45%;
        margin-left: 10%;
        margin-bottom: 30px; } }
  .opDetail_content {
    width: 640px; }
    @media only screen and (max-width: 769px) {
      .opDetail_content {
        width: 100%; } }
    .is-black .opDetail_content {
      margin-top: 243px; }
      @media only screen and (max-width: 769px) {
        .is-black .opDetail_content {
          margin-top: 0; } }
  .opDetail_label {
    font-size: 24px;
    position: relative;
    margin-bottom: 45px;
    font-family: 'Arvo', serif;
    font-weight: 700; }
    @media only screen and (max-width: 769px) {
      .opDetail_label {
        font-size: 16px;
        margin-bottom: 30px; } }
    .opDetail_label:before {
      content: '';
      width: 197px;
      height: 27px;
      display: block;
      position: absolute;
      left: 0;
      bottom: -20px;
      background-repeat: no-repeat;
      background-position: left top;
      background-size: cover; }
      @media only screen and (max-width: 769px) {
        .opDetail_label:before {
          width: 132px;
          height: 17.5px;
          bottom: -10px; } }
      .is-black .opDetail_label:before,
      .is-limited .opDetail_label:before {
        background-image: url("../img/item_line_white.svg"); }
      .is-white .opDetail_label:before {
        background-image: url("../img/item_line_black.svg"); }
  .opDetail_headline {
    margin-bottom: 18px; }
    @media only screen and (max-width: 769px) {
      .opDetail_headline {
        margin-bottom: 9px; } }
    .opDetail_headline span {
      display: block; }
      .opDetail_headline span.is-jp {
        font-size: 24px;
        font-weight: 700;
        margin-bottom: 10px; }
        @media only screen and (max-width: 769px) {
          .opDetail_headline span.is-jp {
            font-size: 16px;
            margin-bottom: 10px; } }
      .opDetail_headline span.is-en {
        font-size: 80px;
        font-weight: 700;
        font-family: 'Arvo', serif;
        font-weight: 700; }
        @media only screen and (max-width: 769px) {
          .opDetail_headline span.is-en {
            font-size: 40px; } }
  .opDetail_price {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 40px; }
    @media only screen and (max-width: 769px) {
      .opDetail_price {
        font-size: 14px;
        margin-bottom: 30px; } }
  .opDetail_body {
    font-size: 16px;
    line-height: 2;
    margin-top: 30px;
    font-weight: normal; }
    @media only screen and (max-width: 769px) {
      .opDetail_body {
        font-size: 14px;
        line-height: 2; } }
  .opDetail_textLink {
    font-size: 16px;
    line-height: 2;
    margin-top: 10px; }
    @media only screen and (max-width: 769px) {
      .opDetail_textLink {
        font-size: 14px; } }
    .is-limited .opDetail_textLink {
      font-weight: normal; }
    .opDetail_textLink a {
      color: #fff;
      border-bottom: 1px solid white;
      padding-bottom: 5px;
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      @media only screen and (max-width: 769px) {
        .opDetail_textLink a {
          padding-bottom: 6px; } }
      .desctop .opDetail_textLink a {
        -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
        .desctop .opDetail_textLink a:hover {
          border-bottom-color: rgba(255, 255, 255, 0); }
  .opDetail_spec {
    font-size: 14px;
    line-height: 2;
    border: 1px solid;
    padding: 10px 20px;
    margin-top: 35px;
    font-weight: normal; }
    @media only screen and (max-width: 769px) {
      .opDetail_spec {
        font-size: 10px;
        margin-top: 20px; } }
    .is-black .opDetail_spec,
    .is-limited .opDetail_spec {
      border-color: rgba(255, 255, 255, 0.2); }
    .is-white .opDetail_spec {
      border-color: rgba(0, 0, 0, 0.2); }
  .opDetailButton {
    position: relative;
    width: 700px;
    margin-left: auto;
    margin-right: auto;
    /*&:before {
      position: absolute;
      display: block;
      content: '';
      background: {
        repeat: no-repeat;
        position: left top;
        size: contain;
      }

      .is-black & {
        top: -114px;
        left: 24px;
        width: 288px;
        height: 114px;
        background-image: url('../img/item_cast01.png');

        @include onlyMobile() {
          top: -91px;
          left: auto;
          right: 30px;
          width: 288px * .8;
          height: 114px * .8;
        }
      }

      .is-white & {
        top: -114px;
        left: 24px;
        width: 309px;
        height: 114px;
        background-image: url('../img/item_cast02.png');

        @include onlyMobile() {
          top: -91px;
          left: 24px;
          width: 309px * .8;
          height: 114px * .8;
        }
      }

      .is-limited & {
        top: -110px;x
        left: 24px;
        width: 267px;
        height: 110px;
        background-image: url('../img/item_cast03.png');
      }
    }*/ }

@media only screen and (max-width: 769px) and (max-width: 769px) {
  .opDetailButton {
    width: 86.6666666667%;
    margin-left: auto;
    margin-right: auto; } }
    .is-black .opDetailButton {
      margin-top: 80px; }
      @media only screen and (max-width: 769px) {
        .is-black .opDetailButton {
          margin-top: 40px; } }
    .is-white .opDetailButton {
      margin-top: -90px; }
      @media only screen and (max-width: 769px) {
        .is-white .opDetailButton {
          margin-top: 35px; } }
    .is-limited .opDetailButton {
      margin-top: 80px; }
      @media only screen and (max-width: 769px) {
        .is-limited .opDetailButton {
          margin-top: 40px; } }
    .opDetailButton_comment {
      position: absolute;
      left: -5px;
      bottom: -30px;
      font-size: 16px;
      font-weight: normal; }
      @media only screen and (max-width: 769px) {
        .opDetailButton_comment {
          font-size: 14px;
          bottom: -27px; } }
    .opDetailButton_wrap {
      margin-bottom: 55px;
      display: flex;
      justify-content: space-between; }
      @media only screen and (max-width: 769px) {
        .opDetailButton_wrap {
          margin-bottom: 25px;
          display: block; } }
      .opDetailButton_wrap > a {
        width: 100%;
        position: relative; }
        @media only screen and (max-width: 769px) {
          .opDetailButton_wrap > a {
            width: 100%; } }
        @media only screen and (max-width: 769px) {
          .opDetailButton_wrap > a:first-child {
            margin-bottom: 40px; } }

/** gallery
/**************************************/
.opDetailGallery {
  opacity: 0;
  -webkit-transition: 1.5s cubic-bezier(0.165, 0.84, 0.44, 1) 0.2s;
  -moz-transition: 1.5s cubic-bezier(0.165, 0.84, 0.44, 1) 0.2s;
  -o-transition: 1.5s cubic-bezier(0.165, 0.84, 0.44, 1) 0.2s;
  transition: 1.5s cubic-bezier(0.165, 0.84, 0.44, 1) 0.2s; }
  .opDetailGallery.inView {
    opacity: 1; }
  .opDetailGallery .slick-slide {
    text-align: center; }
    .opDetailGallery .slick-slide img {
      max-width: 100%;
      height: auto; }
    @media only screen and (max-width: 769px) {
      .opDetailGallery .slick-slide {
        display: block; } }
    @media only screen and (max-width: 769px) {
      .opDetailGallery .slick-slide img {
        display: inline-block;
        width: 100%; } }
  .opDetailGallery .slick-dots {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 30px;
    margin-left: -10px; }
    @media only screen and (max-width: 769px) {
      .opDetailGallery .slick-dots {
        margin-top: 10px;
        margin-left: -3.5%;
        width: calc(100% + 25px); } }
    .opDetailGallery .slick-dots li {
      width: 100px;
      height: 76px;
      margin: 0 4px 8px;
      position: relative;
      cursor: pointer; }
      @media only screen and (max-width: 769px) {
        .opDetailGallery .slick-dots li {
          width: 14%;
          margin: 0 1% 5px;
          height: auto;
          padding-top: 11%; } }
      .desctop .opDetailGallery .slick-dots li {
        -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
        .desctop .opDetailGallery .slick-dots li:hover:before {
          opacity: 1; }
      .opDetailGallery .slick-dots li:before {
        width: 100%;
        height: 100%;
        content: '';
        display: block;
        position: absolute;
        left: 4px;
        top: 4px;
        z-index: 2;
        background-color: rgba(202, 10, 22, 0.5);
        opacity: 0;
        -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .opDetailGallery .slick-dots li > div {
        position: absolute;
        left: 4px;
        top: 4px;
        z-index: 1;
        width: 100%;
        height: 100%;
        background-repeat: no-repeat;
        background-position: center center;
        background-size: cover; }
        @media only screen and (max-width: 769px) {
          .opDetailGallery .slick-dots li > div {
            left: 2px;
            top: 2px; } }
    .opDetailGallery .slick-dots .slick-active {
      pointer-events: none; }
      .opDetailGallery .slick-dots .slick-active:after {
        width: 100%;
        height: 100%;
        content: '';
        display: block;
        border: 2px solid #ca0a16;
        position: absolute;
        left: 2px;
        top: 2px;
        z-index: 2; }
        @media only screen and (max-width: 769px) {
          .opDetailGallery .slick-dots .slick-active:after {
            width: calc(100% - 2px);
            height: calc(100% - 2px); } }
      .opDetailGallery .slick-dots .slick-active:before {
        opacity: 1; }
  .opDetailGallery .slick-arrow {
    position: absolute;
    right: 0;
    top: 420px;
    z-index: 2000;
    width: 61px;
    height: 61px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #000; }
    .is-white .opDetailGallery .slick-arrow {
      background-color: #fff; }
    @media only screen and (max-width: 769px) {
      .opDetailGallery .slick-arrow {
        width: 30px;
        height: 30px;
        top: 32%;
        background-color: rgba(0, 0, 0, 0.5); } }
    .desctop .opDetailGallery .slick-arrow {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .opDetailGallery .slick-arrow:hover {
        background-color: #ca0915; }
    .opDetailGallery .slick-arrow i {
      width: 8px;
      height: 8px;
      border-top: 2px solid #fff;
      border-right: 2px solid #fff;
      display: block;
      position: relative;
      z-index: 10; }
      .is-white .opDetailGallery .slick-arrow i {
        border-color: #000; }
    @media only screen and (min-width: 769px) {
      .is-white .opDetailGallery .slick-arrow:hover i {
        border-color: #fff; } }
    @media only screen and (min-width: 769px) {
      .opDetailGallery .slick-arrow:hover:before {
        opacity: 1; } }
  .opDetailGallery .slick-next i {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg); }
  .opDetailGallery .slick-prev {
    right: 60px; }
    @media only screen and (max-width: 769px) {
      .opDetailGallery .slick-prev {
        right: auto;
        left: 0; } }
    .opDetailGallery .slick-prev i {
      -webkit-transform: rotate(135deg);
      transform: rotate(225deg); }

/** limited
/**************************************/
.limited {
  margin-top: 210px;
  position: relative; }
  @media only screen and (min-width: 769px) {
    .limited {
      background-repeat: no-repeat;
      background-position: left top;
      background-size: cover;
      background-image: url("../img/item_limited_bg-pc.png"); } }
  @media only screen and (max-width: 769px) {
    .limited {
      margin-top: 70px;
      background-color: #000;
      background-repeat: no-repeat;
      background-position: center top;
      background-size: 100% auto;
      background-image: url("../img/item_limited_bg01-sp.png"); }
      .limited:after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        padding-top: 9.3%;
        background-repeat: no-repeat;
        background-position: center bottom;
        background-size: 100% auto;
        background-image: url("../img/item_limited_bg02-sp.png"); } }
  .limited_head {
    position: relative;
    margin-bottom: 60px;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .limited_head {
        width: 86.6666666667%; } }
    @media only screen and (max-width: 769px) {
      .limited_head {
        margin-bottom: 30px; } }
  .limited_character {
    position: absolute;
    left: 0;
    top: -230px; }
    @media only screen and (max-width: 769px) {
      .limited_character {
        position: static; }
        .limited_character img {
          max-width: 100%;
          height: auto; } }
    @media only screen and (max-width: 769px) {
      .limited_character img {
        margin-top: -60px; } }
  .limited_panel {
    display: flex;
    justify-content: center;
    padding-top: 280px; }
    @media only screen and (max-width: 769px) {
      .limited_panel {
        padding-top: 20px;
        display: block; }
        .limited_panel img {
          max-width: 100%;
          height: auto; } }
  .limited_wrap {
    display: flex;
    justify-content: space-between;
    color: #fff;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .limited_wrap {
        width: 86.6666666667%; } }
    @media only screen and (max-width: 769px) {
      .limited_wrap {
        display: block; } }
  .limited_content {
    width: 460px; }
    @media only screen and (max-width: 769px) {
      .limited_content {
        width: 100%; } }
  .limited_gallery {
    width: 640px; }
    @media only screen and (max-width: 769px) {
      .limited_gallery {
        width: 100%; } }

/** opGift
/**************************************/
.opGift {
  position: relative;
  margin-top: 140px;
  height: 482px;
  padding: 63px 0 0 70px;
  background-repeat: no-repeat;
  background-position: left top;
  background-size: cover;
  background-image: url("../img/gift_bg.jpg");
  width: 1160px;
  margin-left: auto;
  margin-right: auto; }
  @media only screen and (max-width: 769px) {
    .opGift {
      width: 86.6666666667%; } }
  @media only screen and (max-width: 769px) {
    .opGift {
      margin-top: 70px;
      padding: 25px;
      height: auto;
      background-image: url("../img/gift_bg01-sp.png"); } }
  @media only screen and (max-width: 769px) {
    .opGift:after {
      content: '';
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      padding-top: 3%;
      background-repeat: no-repeat;
      background-position: left top;
      background-size: 100% auto;
      background-image: url("../img/gift_bg02-sp.png"); } }
  .opGift_content {
    position: relative;
    z-index: 1; }
  .opGift_headline {
    font-size: 80px;
    color: #fff;
    margin-bottom: 18px;
    font-family: 'Arvo', serif;
    font-weight: 700; }
    @media only screen and (max-width: 769px) {
      .opGift_headline {
        font-size: 40px;
        margin-bottom: 15px; } }
  .opGift_title {
    font-size: 24px;
    color: #ca0915;
    margin-bottom: 30px; }
    @media only screen and (max-width: 769px) {
      .opGift_title {
        font-size: 16px;
        margin-bottom: 15px;
        line-height: 1.375; } }
  .opGift_body {
    font-size: 16px;
    line-height: 2;
    color: #fff;
    width: 460px;
    font-weight: normal; }
    @media only screen and (max-width: 769px) {
      .opGift_body {
        font-size: 14px;
        width: 100%; } }
  .opGift_image {
    position: absolute;
    right: 26px;
    top: -47px; }
    @media only screen and (max-width: 769px) {
      .opGift_image {
        position: static;
        margin-top: 20px; }
        .opGift_image img {
          max-width: 100%;
          height: auto; } }
  .opGift_note {
    font-size: 16px;
    line-height: 2;
    color: #fff;
    margin-top: 10px;
    font-weight: normal; }
    @media only screen and (max-width: 769px) {
      .opGift_note {
        font-size: 14px;
        padding-left: 1em;
        text-indent: -1em; } }

/** opGlobalMenu
/**************************************/
.opGlobalMenu {
  border-top: 1px solid #e5e5e5;
  border-bottom: 5px solid #e5e5e5;
  background-color: #fff; }
  .is-opScrolled .opGlobalMenu {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 2000; }
  @media only screen and (max-width: 769px) {
    .opGlobalMenu {
      display: none; } }
  .opGlobalMenu_wrap {
    display: flex;
    justify-content: center;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opGlobalMenu_wrap {
        width: 86.6666666667%; } }
  .opGlobalMenu_item {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100px;
    width: 16.6666666667%;
    position: relative; }
    .opGlobalMenu_item:before {
      width: 4px;
      height: 24px;
      content: '';
      position: absolute;
      left: 0;
      top: calc(50% - 11px);
      display: block;
      background-size: 11px 4px;
      margin: 0 auto;
      background-image: radial-gradient(#ccc 50%, transparent 0%); }
    .desctop .opGlobalMenu_item {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .opGlobalMenu_item:hover span {
        color: #ca0915; }
    .opGlobalMenu_item i {
      margin-right: 10px;
      width: 20px;
      height: 20px;
      display: flex;
      align-items: center;
      justify-content: center;
      background-color: redFill;
      -moz-border-radius: 50%;
      -webkit-border-radius: 50%;
      -o-border-radius: 50%;
      -ms-border-radius: 50%;
      -khtml-border-radius: 50%;
      border-radius: 50%;
      background-color: #ca0915; }
      .opGlobalMenu_item i:before {
        display: block;
        content: '';
        width: 5px;
        height: 5px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        -webkit-transform: rotate(135deg);
        transform: rotate(135deg);
        margin-top: -2px; }
    .opGlobalMenu_item span {
      font-size: 16px;
      color: #000;
      font-weight: 700;
      line-height: 1.4;
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }

/** opGlobalMenuMobile
/**************************************/
.opGlobalMenuMobile {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 3000;
  pointer-events: none;
  visibility: hidden; }
  .is-lifeMenuOpened .opGlobalMenuMobile {
    visibility: visible;
    pointer-events: auto; }
  .opGlobalMenuMobile:before {
    height: 0;
    width: 100%;
    background: #fff;
    position: absolute;
    left: 0;
    top: 0;
    content: '';
    z-index: 0;
    -webkit-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
    -moz-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
    -o-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1); }
    .is-lifeMenuOpened .opGlobalMenuMobile:before {
      height: 100%;
      visibility: visible; }
  .opGlobalMenuMobile_content {
    width: 100%;
    height: 100%;
    padding: 80px 0;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch; }
  .opGlobalMenuMobile_main {
    width: 73.3333333333%;
    margin-left: auto;
    margin-right: auto; }
    .opGlobalMenuMobile_main > a {
      visibility: hidden;
      overflow: hidden;
      position: relative;
      padding: 20px 0;
      display: block; }
      .opGlobalMenuMobile_main > a:before {
        width: 100%;
        height: 4px;
        content: '';
        position: absolute;
        left: 0;
        bottom: 0;
        display: block;
        background-size: 4px 4px;
        margin: 0 auto;
        background-image: radial-gradient(#ccc 50%, transparent 0%); }
      .opGlobalMenuMobile_main > a div {
        display: flex;
        -webkit-transform: translate3d(0, 50px, 0);
        -moz-transform: translate3d(0, 50px, 0);
        -o-transform: translate3d(0, 50px, 0);
        transform: translate3d(0, 50px, 0);
        -webkit-transition: 0s cubic-bezier(0.19, 1, 0.22, 1) 0s;
        -moz-transition: 0s cubic-bezier(0.19, 1, 0.22, 1) 0s;
        -o-transition: 0s cubic-bezier(0.19, 1, 0.22, 1) 0s;
        transition: 0s cubic-bezier(0.19, 1, 0.22, 1) 0s; }
      .opGlobalMenuMobile_main > a span {
        display: block;
        font-size: 20px;
        font-weight: 700; }
        @media screen and (max-width: 320px) {
          .opGlobalMenuMobile_main > a span {
            font-size: 18px; } }
      .opGlobalMenuMobile_main > a i {
        margin-right: 10px;
        background-color: #000;
        width: 22px;
        height: 22px;
        display: flex;
        align-items: center;
        justify-content: center;
        background-color: #ca0915;
        -moz-border-radius: 50%;
        -webkit-border-radius: 50%;
        -o-border-radius: 50%;
        -ms-border-radius: 50%;
        -khtml-border-radius: 50%;
        border-radius: 50%;
        background-color: #fff;
        background-color: #ca0915;
        position: relative;
        z-index: 1; }
        .opGlobalMenuMobile_main > a i:before {
          display: block;
          content: '';
          width: 5.5px;
          height: 5.5px;
          border-top: 2px solid #fff;
          border-right: 2px solid #fff;
          border-color: #ca0915;
          -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
          margin-left: -2px;
          margin-top: -0px; }
        .opGlobalMenuMobile_main > a i:before {
          border-color: #fff; }
      .is-lifeMenuOpened .opGlobalMenuMobile_main > a {
        visibility: visible; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a div {
          -webkit-transform: translate3d(0, 0, 0);
          -moz-transform: translate3d(0, 0, 0);
          -o-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0); }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(1) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.2s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(2) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.3s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.3s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.3s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.3s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(3) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.4s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(4) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.5s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.5s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.5s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.5s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(5) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.6s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(6) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.7s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.7s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.7s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.7s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(7) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.8s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.8s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.8s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.8s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(8) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.9s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.9s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.9s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 0.9s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(9) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(10) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.1s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.1s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.1s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.1s; }
        .is-lifeMenuOpened .opGlobalMenuMobile_main > a:nth-child(11) div {
          -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
          -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
          -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
          transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s; }
  .opGlobalMenuMobile_home {
    position: relative;
    z-index: 102;
    opacity: 0;
    margin-top: 20px;
    width: 50%;
    margin-left: auto;
    margin-right: auto; }
    .is-lifeMenuOpened .opGlobalMenuMobile_home {
      opacity: 1;
      -webkit-transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 1s;
      -moz-transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 1s;
      -o-transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 1s;
      transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 1s; }
    .opGlobalMenuMobile_home a {
      display: block;
      width: 100%;
      border: 1px solid #fff;
      color: #fff;
      font-size: 15px;
      font-weight: 700;
      padding: 10px;
      margin: 0 auto;
      text-align: center;
      font-family: "Noto Sans Japanese", "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, "ＭＳ Ｐゴシック", sans-serif; }
  .opGlobalMenuMobile .lifeSocial_content {
    opacity: 0;
    position: relative;
    z-index: 102;
    margin-top: 0; }
    .is-lifeMenuOpened .opGlobalMenuMobile .lifeSocial_content {
      opacity: 1;
      -webkit-transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0.8s;
      -moz-transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0.8s;
      -o-transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0.8s;
      transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0.8s; }
    @media only screen and (max-width: 769px) {
      .opGlobalMenuMobile .lifeSocial_content .lifeSocial_item {
        margin: 0;
        width: 50px;
        height: 50px;
        background-color: none; } }

/** opHero
/**************************************/
.opHero {
  overflow: hidden;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  background-image: url("../img/hero_bg.png"); }
  .opHero_wrap {
    position: relative;
    padding-top: 52.6041666667%;
    width: 92.1875%;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opHero_wrap {
        padding-top: 143.3333333333%; } }
    .opHero_wrap > * {
      position: absolute; }
      .opHero_wrap > * > * {
        opacity: 0; }
        .opHero_wrap > * > * img {
          max-width: 100%;
          height: auto; }
  .opHero_title {
    left: 0.2%;
    top: 1%;
    width: 66%; }
    @media only screen and (max-width: 769px) {
      .opHero_title {
        width: 100%;
        top: 10%;
        z-index: 1;
        position: absolute;
        left: 50%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0); } }
  .opHero_logo {
    left: -0.7%;
    bottom: 7.9%;
    width: 16.7%; }
    @media only screen and (max-width: 769px) {
      .opHero_logo {
        bottom: auto;
        top: 3%;
        width: 75%;
        position: absolute;
        left: 50%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0); } }
  .opHero_item {
    left: 18.3%;
    bottom: 7.9%;
    width: 28.8%;
    z-index: 2; }
    @media only screen and (max-width: 769px) {
      .opHero_item {
        left: 4%;
        bottom: 41%;
        width: 44%; } }
  .opHero_cast {
    right: 5%;
    bottom: 0;
    width: 48.7%; }
    .opHero_cast img {
      max-width: 100%;
      height: auto; }
    @media only screen and (max-width: 769px) {
      .opHero_cast {
        right: 0;
        width: 100%;
        z-index: 0; } }
  .opHero_20th {
    right: 0.2%;
    bottom: 12.2%;
    width: 12.7%; }
    @media only screen and (max-width: 769px) {
      .opHero_20th {
        width: 30%;
        bottom: 8%; } }
  .opHero_copyright {
    right: 0.4%;
    bottom: 7.7%; }
    @media only screen and (max-width: 769px) {
      .opHero_copyright {
        right: 0;
        bottom: 3%; } }
    .opHero_copyright p {
      font-size: 14px;
      background-color: #000;
      padding: 2px;
      color: #fff; }
      @media only screen and (max-width: 769px) {
        .opHero_copyright p {
          font-size: 10px; } }

/** onePiece
/**************************************/
.contents {
  min-width: 1280px;
  overflow: hidden; }
  @media only screen and (max-width: 769px) {
    .contents {
      min-width: 0; } }

body.page-onePeace2 {
  padding-top: 0; }

.onePiece {
  font-family: "Noto Sans Japanese", "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, "ＭＳ Ｐゴシック", sans-serif; }

.opCopyright {
  font-size: 12px;
  text-align: center;
  margin: 100px 0; }
  @media only screen and (max-width: 769px) {
    .opCopyright {
      font-size: 10px;
      margin: 50px 0; } }

.anchorPoint {
  position: absolute;
  top: -70px; }
  @media only screen and (max-width: 769px) {
    .anchorPoint {
      top: 0; } }

/** headline
/**************************************/
.headlineLv1 {
  font-size: 80px;
  position: relative;
  font-family: 'Arvo', serif;
  font-weight: 700; }
  @media only screen and (max-width: 769px) {
    .headlineLv1 {
      font-size: 40px; } }
  .headlineLv1:before {
    left: 0;
    bottom: -34px;
    display: block;
    content: '';
    width: 70px;
    height: 5px;
    background-color: #000;
    position: absolute; }
    @media only screen and (max-width: 769px) {
      .headlineLv1:before {
        width: 35px;
        bottom: -30px; } }
  .headlineLv1.is-center:before {
    left: calc(50% - 35px); }
    @media only screen and (max-width: 769px) {
      .headlineLv1.is-center:before {
        left: calc(50% - (35px / 2)); } }

/** modal
/**************************************/
.modal {
  background-color: rgba(0, 0, 0, 0.8);
  padding: 50px 0;
  position: relative;
  z-index: 4001; }
  @media only screen and (max-width: 769px) {
    .modal {
      padding: 20px 0 50px; } }
  .modal_overlay {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 4002; }
  .modal_close {
    position: fixed;
    z-index: 100;
    width: 120px;
    height: 120px;
    z-index: 1;
    cursor: pointer;
    right: calc(100vw - 100%);
    right: 16px;
    top: 0;
    background-color: #000;
    align-items: center;
    justify-content: center;
    display: flex; }
    @media only screen and (max-width: 769px) {
      .modal_close {
        width: 60px;
        height: 60px;
        right: calc(50% - 30px);
        top: auto;
        bottom: 20px; } }
    .desctop .modal_close {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .modal_close:hover {
        opacity: .6; }
    .modal_close > div:before {
      margin: 0 auto 8px;
      width: 40px;
      height: 40px;
      content: '';
      display: block;
      background-repeat: no-repeat;
      background-position: left top;
      background-size: cover;
      background-image: url("../img/icon_close.svg"); }
      @media only screen and (max-width: 769px) {
        .modal_close > div:before {
          width: 22px;
          height: 22px;
          margin-bottom: 4px; } }
    .modal_close span {
      color: #fff;
      font-size: 18px;
      font-weight: 700;
      font-family: 'Arvo', serif;
      font-weight: 700; }
      @media only screen and (max-width: 769px) {
        .modal_close span {
          font-size: 10px; } }
  .modal_container {
    background-color: #000;
    padding: 10px;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .modal_container {
        width: 86.6666666667%; } }
    @media only screen and (max-width: 769px) {
      .modal_container {
        padding: 5px 5px 1px;
        margin-bottom: 50px; } }
  @media only screen and (max-width: 769px) and (max-width: 769px) {
    .modal_container {
      width: 86.6666666667%;
      margin-left: auto;
      margin-right: auto; } }
  .modal_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    @media only screen and (max-width: 769px) {
      .modal_wrap {
        display: block; } }
  .modal_item {
    width: 565px; }
    @media only screen and (max-width: 769px) {
      .modal_item {
        width: 100%;
        margin-bottom: 5px !important; } }
    .modal_item:nth-child(1), .modal_item:nth-child(2) {
      margin-bottom: 10px; }
  @media only screen and (max-width: 769px) {
    .modal_image img {
      max-width: 100%;
      height: auto; } }
  .modal_body {
    background-color: #fff;
    font-size: 18px;
    padding: 30px 30px;
    display: flex;
    align-items: center;
    font-weight: 700; }
    @media only screen and (max-width: 769px) {
      .modal_body {
        font-size: 12px;
        padding: 5px 15px;
        text-align: left;
        line-height: 1.4; } }
    .modal_body em {
      margin-right: 10px;
      font-size: 40px;
      font-family: 'Arvo', serif;
      font-weight: 700; }
      @media only screen and (max-width: 769px) {
        .modal_body em {
          font-size: 30px; } }

/** novelty
/**************************************/
.opNovelty {
  margin-top: -240px;
  position: relative;
  z-index: 1;
  width: 1160px;
  margin-left: auto;
  margin-right: auto; }
  @media only screen and (max-width: 769px) {
    .opNovelty {
      width: 86.6666666667%; } }
  @media only screen and (max-width: 769px) {
    .opNovelty {
      margin-top: 0; } }
  .opNovelty_wrap {
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
    margin-bottom: 60px; }
    @media only screen and (max-width: 769px) {
      .opNovelty_wrap {
        display: block; } }
  .opNovelty_image {
    width: 50%;
    text-align: center; }
    @media only screen and (max-width: 769px) {
      .opNovelty_image {
        width: 100%; }
        .opNovelty_image img {
          max-width: 100%;
          height: auto; } }
    @media only screen and (max-width: 769px) {
      .opNovelty_image img {
        width: 70%;
        margin: 40px auto 0; } }
    .opNovelty_image p {
      margin-top: 40px;
      font-size: 18px;
      text-align: center;
      font-weight: 700; }
      @media only screen and (max-width: 769px) {
        .opNovelty_image p {
          font-size: 14px;
          margin-top: 20px; } }
  .opNovelty_content {
    width: 50%;
    margin-top: 200px;
    padding-left: 50px; }
    @media only screen and (max-width: 769px) {
      .opNovelty_content {
        width: 100%;
        margin-top: 50px;
        padding-left: 0; } }
  .opNovelty_lead {
    font-size: 24px;
    font-weight: 700;
    margin-top: 70px; }
    @media only screen and (max-width: 769px) {
      .opNovelty_lead {
        font-size: 16px;
        margin-top: 60px; } }
  .opNovelty_body {
    margin-top: 30px;
    font-size: 16px;
    line-height: 2;
    font-weight: normal; }
    @media only screen and (max-width: 769px) {
      .opNovelty_body {
        margin-top: 20px;
        font-size: 14px; } }
  .opNovelty_attention {
    margin-top: 20px;
    color: #ca0915;
    font-size: 16px;
    font-weight: 700; }
    @media only screen and (max-width: 769px) {
      .opNovelty_attention {
        font-size: 14px;
        margin-top: 15px; } }
  .opNoveltyGallery {
    display: flex;
    justify-content: space-between; }
    @media only screen and (max-width: 769px) {
      .opNoveltyGallery {
        display: block; } }
    .opNoveltyGallery_item {
      width: 370px; }
      @media only screen and (max-width: 769px) {
        .opNoveltyGallery_item {
          width: 100%;
          margin-bottom: 35px;
          text-align: center; }
          .opNoveltyGallery_item img {
            max-width: 100%;
            height: auto; } }
      .opNoveltyGallery_item:last-child {
        margin-top: -64px; }
        @media only screen and (max-width: 769px) {
          .opNoveltyGallery_item:last-child {
            margin-top: 0; } }
    .opNoveltyGallery_image {
      margin-bottom: 30px; }
      @media only screen and (max-width: 769px) {
        .opNoveltyGallery_image {
          margin-bottom: 15px; } }
    .opNoveltyGallery_caption {
      font-size: 18px;
      font-weight: 700;
      text-align: center; }
      @media only screen and (max-width: 769px) {
        .opNoveltyGallery_caption {
          font-size: 14px; } }

/** debug
/**************************************/
.debug {
  background: #2d9f00;
  position: fixed;
  left: 0;
  top: 0;
  color: #fff;
  font-size: 1.2rem;
  padding: 7px;
  display: block;
  z-index: 1000000; }
  @media only screen and (max-width: 769px) {
    .debug {
      font-size: .9rem;
      padding: 5px; } }

/** display
/**************************************/
.inlineDesktop {
  display: none !important; }
  @media only screen and (min-width: 769px) {
    .inlineDesktop {
      display: inline !important; } }

.inlineMobile {
  display: inline !important; }
  @media only screen and (min-width: 769px) {
    .inlineMobile {
      display: none !important; } }

.blockDesktop {
  display: none !important; }
  @media only screen and (min-width: 769px) {
    .blockDesktop {
      display: block !important; } }

.blockMobile {
  display: block !important; }
  @media only screen and (min-width: 769px) {
    .blockMobile {
      display: none !important; } }

.flexDesktop {
  display: none !important; }
  @media only screen and (min-width: 769px) {
    .flexDesktop {
      display: flex !important; } }

.flexMobile {
  display: flex !important; }
  @media only screen and (min-width: 769px) {
    .flexMobile {
      display: none !important; } }

.onlyIE {
  display: none; }
  .ie .onlyIE {
    display: block; }

/** lock
/**************************************/
.is-lock {
  pointer-events: none !important; }

/** scroll
/**************************************/
.is-noScroll {
  -webkit-overflow-scrolling: auto; }

.lock.is-show {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100000; }

/** fadein
/**************************************/
@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

/** accordion
/**************************************/
.js-accordion dt.is-opened i {
  -webkit-transform: rotate(180deg);
  -moz-transfrom: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  transform: rotate(180deg); }
  .js-accordion dt.is-opened i:before {
    -webkit-transform: rotate(-90deg);
    -moz-transfrom: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    transform: rotate(-90deg); }

.js-accordion dt i {
  width: 22px;
  height: 22px;
  position: absolute;
  right: 30px;
  display: block;
  -webkit-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  -moz-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  -o-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1); }
  @media only screen and (max-width: 769px) {
    .js-accordion dt i {
      width: 16px;
      height: 16px;
      right: 15px; } }
  .js-accordion dt i:before, .js-accordion dt i:after {
    background-color: #000;
    display: block;
    content: '';
    position: absolute;
    -webkit-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
    -moz-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
    -o-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1); }
  .js-accordion dt i:before {
    width: 4px;
    height: 100%;
    top: 0;
    left: calc(50% - 2px); }
    @media only screen and (max-width: 769px) {
      .js-accordion dt i:before {
        width: 3px;
        left: calc(50% - 1px); } }
  .js-accordion dt i:after {
    width: 100%;
    height: 4px;
    left: 0;
    top: calc(50% - 2px); }
    @media only screen and (max-width: 769px) {
      .js-accordion dt i:after {
        height: 3px;
        top: calc(50% - 1px); } }

.is-remodal .c-header,
.is-remodal .containers,
.is-remodal .menu,
.is-remodal .c-breadcrumb,
.is-remodal .c-footer,
.is-remodal .c-pagetop {
  visibility: hidden !important; }

html.remodal-is-locked {
  overflow: hidden; }

.remodal,
[data-remodal-id] {
  display: none;
  width: 100%; }

.remodal-overlay {
  position: fixed;
  z-index: 9999;
  top: -5000px;
  right: -5000px;
  bottom: -5000px;
  left: -5000px;
  display: none; }

.remodal-wrapper {
  position: fixed;
  z-index: 10000;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  display: none;
  overflow: auto;
  text-align: center;
  -webkit-overflow-scrolling: touch; }
  .remodal-wrapper > * {
    outline: none; }

.remodal-overlay,
.remodal-wrapper {
  backface-visibility: hidden; }

.remodal {
  position: relative;
  text-size-adjust: 100%; }

.remodal-is-initialized {
  display: inline-block; }

remodal, .remodal-wrapper:after {
  vertical-align: middle; }

.remodal-overlay.remodal-is-opening,
.remodal-overlay.remodal-is-closing {
  animation-fill-mode: forwards; }

.remodal-overlay.remodal-is-opening {
  animation: remodal-overlay-opening-keyframes 0.5s; }

.remodal-overlay.remodal-is-closing {
  animation: remodal-overlay-closing-keyframes 0.3s; }

.remodal.remodal-is-opening, .remodal.remodal-is-closing {
  animation-fill-mode: forwards; }

.remodal.remodal-is-opening {
  animation: remodal-opening-keyframes 0.5s; }

.remodal.remodal-is-closing {
  animation: remodal-closing-keyframes 0.3s; }

@keyframes remodal-opening-keyframes {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }

@keyframes remodal-closing-keyframes {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }

@keyframes remodal-overlay-opening-keyframes {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }

@keyframes remodal-overlay-closing-keyframes {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }

/** opSchedule
/**************************************/
.opSchedule {
  background-color: #fafafa;
  padding-bottom: 55px; }
  @media only screen and (max-width: 769px) {
    .opSchedule {
      padding-bottom: 27.5px; } }
  .opSchedule_wrap {
    position: relative;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opSchedule_wrap {
        width: 86.6666666667%; } }
  .opSchedule_button {
    position: absolute;
    display: block; }
    @media only screen and (max-width: 769px) {
      .opSchedule_button {
        width: 30.7%;
        height: 23.4%; } }
    .opSchedule_button img:nth-child(2) {
      position: absolute;
      left: 0;
      top: 0;
      opacity: 0;
      z-index: 1;
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
    @media only screen and (max-width: 769px) {
      .opSchedule_button img {
        display: none; } }
    .opSchedule_button:hover img:nth-child(2) {
      opacity: 1; }
    .opSchedule_button.is-button01 {
      top: 124px;
      left: 180px; }
      @media only screen and (max-width: 769px) {
        .opSchedule_button.is-button01 {
          top: 9.3%;
          left: 23.7%; } }
    .opSchedule_button.is-button02 {
      top: 250px;
      left: 435px; }
      @media only screen and (max-width: 769px) {
        .opSchedule_button.is-button02 {
          top: 33.2%;
          left: 44.6%; } }
    .opSchedule_button.is-button03 {
      top: 375px;
      left: 700px; }
      @media only screen and (max-width: 769px) {
        .opSchedule_button.is-button03 {
          top: 57.1%;
          left: 66.1%; } }
  @media only screen and (max-width: 769px) {
    .opSchedule_image img {
      max-width: 100%;
      height: auto; } }

/** opShop
/**************************************/
.opShop {
  margin-top: 130px;
  text-align: center;
  position: relative;
  width: 1160px;
  margin-left: auto;
  margin-right: auto; }
  @media only screen and (max-width: 769px) {
    .opShop {
      width: 86.6666666667%; } }
  @media only screen and (max-width: 769px) {
    .opShop {
      margin-top: 65px; } }
  .opShop_lead {
    font-size: 24px;
    font-weight: 700;
    margin-top: 75px; }
    @media only screen and (max-width: 769px) {
      .opShop_lead {
        font-size: 16px;
        margin-top: 60px; } }
  .opShop_body {
    font-size: 16px;
    margin-top: 40px;
    line-height: 2; }
    @media only screen and (max-width: 769px) {
      .opShop_body {
        font-size: 14px;
        margin-top: 25px; } }
  .opShop_button {
    margin-top: 60px;
    width: 700px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opShop_button {
        width: 100%;
        margin-top: 40px; } }
    .opShop_button a {
      margin-bottom: 20px; }
      @media only screen and (max-width: 769px) {
        .opShop_button a {
          margin-bottom: 15px; } }

/** opSocial
/**************************************/
.opSocial {
  margin-top: 200px;
  height: 655px;
  margin-bottom: 60px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  background-image: url("../img/sns_bg.png"); }
  @media only screen and (max-width: 769px) {
    .opSocial {
      margin-top: 100px;
      margin-bottom: 30px;
      height: auto;
      padding-top: 60%;
      position: relative; } }
  .opSocial_wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    height: 100%;
    width: 1160px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opSocial_wrap {
        width: 86.6666666667%; } }
    @media only screen and (max-width: 769px) {
      .opSocial_wrap {
        display: block;
        position: static; } }
  .opSocial_cast {
    position: absolute; }
    @media only screen and (max-width: 769px) {
      .opSocial_cast img {
        max-width: 100%;
        height: auto; } }
    .opSocial_cast.is-left {
      left: 0;
      top: -160px; }
      @media only screen and (max-width: 769px) {
        .opSocial_cast.is-left {
          width: 27%;
          top: -5%;
          left: calc(50% - 210px); } }
      @media screen and (max-width: 420px) {
        .opSocial_cast.is-left {
          width: 27%;
          top: -5%;
          left: calc(50% - 100px); } }
    .opSocial_cast.is-right {
      right: 0;
      bottom: 100px; }
      @media only screen and (max-width: 769px) {
        .opSocial_cast.is-right {
          width: 30%;
          right: auto;
          left: calc(50% + 50px);
          bottom: auto;
          top: 16%; } }
      @media screen and (max-width: 420px) {
        .opSocial_cast.is-right {
          width: 30%;
          left: calc(50% + 20px);
          bottom: auto;
          top: 16%; } }
  .opSocial_button {
    margin-top: -50px;
    width: 420px;
    margin-left: auto;
    margin-right: auto; }
    @media only screen and (max-width: 769px) {
      .opSocial_button {
        width: 100%;
        margin: 0 0 25%; } }
  .opSocial_title {
    font-size: 24px;
    text-align: center;
    margin-bottom: 35px;
    font-family: 'Arvo', serif;
    font-weight: 700; }
    @media only screen and (max-width: 769px) {
      .opSocial_title {
        font-size: 12px;
        margin-bottom: 20px; } }
    .opSocial_title span {
      position: relative; }
      .opSocial_title span:before, .opSocial_title span:after {
        content: '';
        background-color: #000;
        width: 2px;
        height: 50px;
        position: absolute;
        top: -10px;
        display: block; }
        @media only screen and (max-width: 769px) {
          .opSocial_title span:before, .opSocial_title span:after {
            height: 30px;
            top: -5px; } }
      .opSocial_title span:before {
        left: -20px;
        -webkit-transform: rotate(-30deg);
        -moz-transfrom: rotate(-30deg);
        -ms-transform: rotate(-30deg);
        -o-transform: rotate(-30deg);
        transform: rotate(-30deg); }
      .opSocial_title span:after {
        right: -20px;
        -webkit-transform: rotate(30deg);
        -moz-transfrom: rotate(30deg);
        -ms-transform: rotate(30deg);
        -o-transform: rotate(30deg);
        transform: rotate(30deg); }
  .opSocial_list {
    display: flex;
    justify-content: space-between; }
    @media only screen and (max-width: 769px) {
      .opSocial_list {
        width: 210px;
        margin-left: auto;
        margin-right: auto; } }
  .opSocial_item {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 120px;
    height: 120px;
    background-color: #000;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    -o-border-radius: 50%;
    -ms-border-radius: 50%;
    -khtml-border-radius: 50%;
    border-radius: 50%; }
    @media only screen and (max-width: 769px) {
      .opSocial_item {
        width: 60px;
        height: 60px; } }
    .desctop .opSocial_item {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
      .desctop .opSocial_item:hover {
        background-color: #808080; }
    .opSocial_item:before {
      content: '';
      background-repeat: no-repeat;
      background-position: left top;
      background-size: cover; }
    .opSocial_item.is-facebook:before {
      width: 41px;
      height: 41px;
      background-image: url("../img/icon_facebook.png"); }
      @media only screen and (max-width: 769px) {
        .opSocial_item.is-facebook:before {
          width: 20.5px;
          height: 20.5px; } }
    .opSocial_item.is-twitter:before {
      width: 40px;
      height: 31px;
      background-image: url("/assets/img/common/icon_twitter.svg"); }
      @media only screen and (max-width: 769px) {
        .opSocial_item.is-twitter:before {
          width: 20px;
          height: 15.5px; } }
    .opSocial_item.is-instagram:before {
      width: 40px;
      height: 40px;
      background-image: url("/assets/img/common/icon_instagram.svg"); }
      @media only screen and (max-width: 769px) {
        .opSocial_item.is-instagram:before {
          width: 20px;
          height: 20px; } }

/** lifeTrigger
/**************************************/
.lifeTrigger {
  cursor: pointer;
  justify-content: center;
  align-items: center;
  position: fixed;
  pointer-events: none;
  margin-top: 7px;
  display: none;
  z-index: 3001;
  position: fixed;
  right: 5.3333333333%;
  top: 17px;
  margin-top: 0;
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  background-color: #000;
  width: 50px;
  height: 50px;
  -webkit-transition: 1s cubic-bezier(0.77, 0, 0.175, 1);
  -moz-transition: 1s cubic-bezier(0.77, 0, 0.175, 1);
  -o-transition: 1s cubic-bezier(0.77, 0, 0.175, 1);
  transition: 1s cubic-bezier(0.77, 0, 0.175, 1); }
  @media only screen and (max-width: 769px) {
    .lifeTrigger {
      display: flex; } }
  .is-scrolled .lifeTrigger {
    opacity: 1;
    pointer-events: auto; }
  .is-lifeMenuOpened .lifeTrigger {
    background-color: #1a1a1a; }
  .lifeTrigger:before {
    width: calc(100% + 20px);
    height: calc(100% + 20px);
    cursor: pointer;
    position: absolute;
    left: -10px;
    top: -10px;
    content: ''; }
  .lifeTrigger_inner {
    position: relative;
    width: 25px;
    height: 16px;
    display: block;
    transition: all .4s;
    box-sizing: border-box; }
    @media only screen and (max-width: 769px) {
      .lifeTrigger_inner {
        width: 24px; } }
    .desctop .is-lifeMenuOpenedGlobal .lifeTrigger_inner {
      -webkit-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -moz-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
    .lifeTrigger_inner span {
      display: inline-block;
      transition: all .4s;
      box-sizing: border-box;
      position: absolute;
      width: 100%;
      height: 2px;
      background-color: #fff; }
      @media only screen and (max-width: 769px) {
        .lifeTrigger_inner span {
          width: 24px; } }
      .lifeTrigger_inner span:nth-child(1) {
        top: 0;
        left: 0;
        -webkit-animation: menu-bar01 .5s forwards;
        animation: menu-bar01 .5s forwards; }
      .lifeTrigger_inner span:nth-child(2), .lifeTrigger_inner span:nth-child(3) {
        height: 2px; }
      .lifeTrigger_inner span:nth-child(2) {
        top: 6px;
        opacity: 1; }
      .lifeTrigger_inner span:nth-child(3) {
        top: 12px;
        -webkit-animation: menu-bar02 .5s forwards;
        animation: menu-bar02 .5s forwards; }
      .is-lifeMenuOpened .lifeTrigger_inner span:nth-child(1) {
        -webkit-animation: active-menu-bar01 .5s forwards;
        animation: active-menu-bar01 .5s forwards;
        top: -14px; }
      .is-lifeMenuOpened .lifeTrigger_inner span:nth-child(2) {
        opacity: 0; }
      .is-lifeMenuOpened .lifeTrigger_inner span:nth-child(3) {
        -webkit-animation: active-menu-bar03 .5s forwards;
        animation: active-menu-bar03 .5s forwards;
        top: 28px; }

@-webkit-keyframes menu-bar01 {
  0% {
    -webkit-transform: translateY(21px) rotate(45deg); }
  50% {
    -webkit-transform: translateY(15px) rotate(0); }
  100% {
    -webkit-transform: translateY(0) rotate(0); } }

@keyframes menu-bar01 {
  0% {
    transform: translateY(21px) rotate(45deg); }
  50% {
    transform: translateY(15px) rotate(0); }
  100% {
    transform: translateY(0) rotate(0); } }

@-webkit-keyframes menu-bar02 {
  0% {
    -webkit-transform: translateY(-21px) rotate(-45deg); }
  50% {
    -webkit-transform: translateY(-15px) rotate(0); }
  100% {
    -webkit-transform: translateY(0) rotate(0); } }

@keyframes menu-bar02 {
  0% {
    transform: translateY(-21px) rotate(-45deg); }
  50% {
    transform: translateY(-15px) rotate(0); }
  100% {
    transform: translateY(0) rotate(0); } }

@-webkit-keyframes active-menu-bar01 {
  0% {
    -webkit-transform: translateY(0) rotate(0); }
  50% {
    -webkit-transform: translateY(21px) rotate(0); }
  100% {
    -webkit-transform: translateY(21px) rotate(45deg); } }

@keyframes active-menu-bar01 {
  0% {
    transform: translateY(0) rotate(0); }
  50% {
    transform: translateY(21px) rotate(0); }
  100% {
    transform: translateY(21px) rotate(45deg); } }

@-webkit-keyframes active-menu-bar03 {
  0% {
    -webkit-transform: translateY(0) rotate(0); }
  50% {
    -webkit-transform: translateY(-21px) rotate(0); }
  100% {
    -webkit-transform: translateY(-21px) rotate(-45deg); } }

@keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0); }
  50% {
    transform: translateY(-21px) rotate(0); }
  100% {
    transform: translateY(-21px) rotate(-45deg); } }

/*# sourceMappingURL=bundle.css.map */