@charset "UTF-8";
/* CSS INFORMATION -====================================================
File name : base.css
Description :
===================================================================== */
html {
  min-height: 100vh;
  overflow-x: hidden;
  font-size: calc(10 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  html {
    font-size: calc(10 / 1400 * 100vw);
  }
}
@media screen and (min-width: 1400px) {
  html {
    font-size: 10px;
  }
}

body {
  margin: 0;
  padding: 0;
}

#wrapper {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  color: #fff;
  min-height: 100vh;
  padding: 0;
  background: url(../images/common/bg.jpg) repeat;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  #wrapper {
    background-size: contain;
  }
}

.forSP {
  display: block;
}

.forPC {
  display: none;
}

@media screen and (min-width: 768px) {
  .forSP {
    display: none;
  }
  .forPC {
    display: block;
  }
}
img {
  width: 100%;
}

.gDef-top-banner {
  background: #d3d3be;
  position: relative;
  z-index: 3;
}

.gDef-contents p,
.gDef-contents dl {
  font-size: 2.8rem;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .gDef-contents p,
  .gDef-contents dl {
    font-size: 1.8rem;
  }
}
.gDef-contents h1,
.gDef-contents h2,
.gDef-contents h3,
.gDef-contents h4,
.gDef-contents p,
.gDef-contents ul,
.gDef-contents li,
.gDef-contents dl {
  font-weight: 900;
}
.gDef-contents .pink {
  color: #ff8e8b;
}

.set1,
.set1 * {
  position: relative;
}
.set1 img,
.set1 * img {
  width: 100%;
  height: auto;
  display: block;
}
.set1 a,
.set1 * a {
  color: #000;
  display: block;
}

.set2 {
  position: relative;
  z-index: 10;
}

.inner,
.inner_head {
  width: calc(690 / 750 * 100%);
  margin: 0 auto;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .inner,
  .inner_head {
    width: 100%;
    max-width: 1220px;
  }
}

svg {
  width: 100%;
  height: auto;
}

.banner_list {
  max-width: 48.8rem;
  margin: 0 auto 6rem;
}
.banner_list li {
  width: 100%;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .banner_list {
    max-width: 64rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .banner_list li {
    margin: 0 4rem 2rem 0;
    width: 30rem;
  }
  .banner_list li:nth-child(2n), .banner_list li:last-child {
    margin-right: 0;
  }
}

/* =====================================================================
*    mv_sub
* =================================================================== */
.mv_sub {
  background: url(../images/common/bg_mvsub.jpg) repeat-x bottom center/cover;
  position: relative;
}
.mv_sub .inner {
  width: 100%;
}
.mv_sub .mv_ttl {
  width: 100%;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .mv_sub .inner {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .mv_sub .inner .mv_ttl {
    position: relative;
    width: 100%;
    max-width: 1140px;
    margin: 0 auto auto;
  }
  .mv_sub .inner .mv_ttl picture {
    position: relative;
    z-index: 1;
  }
}
@media screen and (min-width: 1220px) {
  .mv_sub .mv_ttl::after {
    width: 820px;
    right: -8rem;
  }
}
/* =====================================================================
*    mv_date
* =================================================================== */
.mv_date {
  width: 100%;
  z-index: 3;
  text-align: center;
  background: #696f65;
}
.mv_date p {
  font-size: 6.2rem;
  text-align: center;
  letter-spacing: 0.05em;
  color: #fdfcf7;
  line-height: 1.2;
  padding-bottom: 0.5em;
  padding-top: 3rem;
}
.mv_date p span {
  color: #ff8e8b;
}
.mv_date p small {
  font-size: 0.72em;
}
.mv_date p small.yoru {
  font-size: 0.5em;
}
.mv_date .banner_list {
  padding-bottom: 3rem;
  margin-bottom: 0;
}

@media screen and (min-width: 768px) {
  .mv_date p {
    font-size: 5rem;
    line-height: 1.5;
    padding-bottom: 0.15em;
    padding-top: 0;
  }
  .mv_date .banner_list {
    padding-bottom: 0;
  }
}
/* =====================================================================
*    nav
* =================================================================== */
.header_nav {
  background: rgba(209, 205, 192, 0.7);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 1;
}
.header_nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: left;
      -ms-flex-pack: left;
          justify-content: left;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 1rem 0 2rem;
  position: relative;
}
.header_nav ul li {
  font-size: 2.8rem;
  padding: 1em 0 0.5em;
}
.header_nav ul li:not(.nav_sns) {
  width: 25%;
  margin: 0;
  /*a {
      display: block;
      padding: 5px;
      background:linear-gradient(
          to right,
          $color-secondary,
          $color-secondary 50%,
          transparent 50%,
          transparent) 100% 0 / 200% 100%;
      transition:background-position 0.3s;
      text-align: center;
      &:hover {
          background-position: 0 0;
          color: $color-thirdly;
      }
  }*/
}
.header_nav ul li:not(.nav_sns) a {
  display: block;
  padding: 5px;
  overflow: hidden;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  text-align: center;
}
.header_nav ul li:not(.nav_sns) a:hover {
  color: #f8f6f0;
}
.header_nav ul li:not(.nav_sns) a::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #ff8e8b;
  -webkit-transform: translateX(-101%);
          transform: translateX(-101%);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  z-index: -1;
}
.header_nav ul li:not(.nav_sns) a:hover::before {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
.header_nav ul li.nav_sns {
  width: 7.6rem;
  height: 7.6rem;
  border-radius: 50%;
  padding: 0;
  margin: 2rem 1rem 0;
}
.header_nav ul li.nav_sns.twitter {
  margin-left: 20rem;
}
.header_nav ul .nav_sns-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
}

.nav_date {
  position: absolute;
  top: -0.3em;
  left: 50%;
  padding: 0.2em 0.5em;
  text-align: center;
  line-height: 1;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: #81C5CA;
  border-radius: 2em;
  z-index: 1;
}
.nav_date::after {
  content: "";
  position: absolute;
  display: block;
  bottom: -0.2em;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0.25em 0.25em 0;
  border-color: transparent #81C5CA transparent transparent;
}
.nav_date span {
  display: block;
  font-size: 1.3rem;
  white-space: nowrap;
  color: #fff;
  line-height: 1;
}

@media screen and (min-width: 768px) {
  .header_nav {
    height: 10rem;
  }
  .header_nav .inner {
    width: 100%;
  }
  .header_nav ul {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0;
  }
  .header_nav ul li {
    font-size: 1.8rem;
    padding: 0 10px;
  }
  .header_nav ul li:not(.nav_sns) {
    width: auto;
    margin: 0 1rem;
  }
  .header_nav ul li:not(.nav_sns) a {
    display: inline-block;
  }
  .header_nav ul li.nav_sns {
    width: 4.8rem;
    height: 4.8rem;
    margin: 0 1rem;
  }
  .header_nav ul li.nav_sns.twitter {
    margin-left: 2rem;
  }
  .header_nav ul .nav_sns-block {
    width: auto;
  }
  .nav_date {
    top: -1em;
  }
}
/* =====================================================================
*    contents
* =================================================================== */
h2.ttl {
  position: absolute;
  top: 0;
  left: 0;
  padding-top: 5rem;
  border: 1px solid #16130c;
  border-bottom: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: rgba(248, 246, 240, 0.8);
  height: 60rem;
  z-index: 20;
}
h2.ttl.ttl_num {
  padding-top: 11rem;
}
h2.ttl.ttl_num::before {
  content: "";
  display: block;
  width: 100%;
  height: 9rem;
  position: absolute;
  top: 0;
  left: 0;
  border-bottom: 1px solid #16130c;
}
h2.ttl.ttl_num::after {
  content: "1";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 9rem;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #16130c;
  font-size: 3.6rem;
}
h2.ttl.t1::after {
  content: "1";
}
h2.ttl.t2::after {
  content: "2";
}
h2.ttl.t3::after {
  content: "3";
}
h2.ttl.t4::after {
  content: "4";
}
h2.ttl.t5::after {
  content: "5";
}
h2.ttl.t6::after {
  content: "6";
}
h2.ttl.t7::after {
  content: "7";
}
h2.ttl.t8::after {
  content: "8";
}
h2.ttl.t9::after {
  content: "9";
}
h2.ttl span.ja {
  display: block;
  font-size: 3.6rem;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
  color: #16130c;
  line-height: 7.3rem;
  position: relative;
  z-index: 5;
}
h2.ttl span.en {
  display: block;
  color: #ff8e8b;
  font-size: 17rem;
  -webkit-transform: rotate(-15deg);
          transform: rotate(-15deg);
  position: absolute;
  top: -0.15em;
  left: 0;
  z-index: 0;
  font-family: "Tangerine", cursive;
  font-weight: normal;
  opacity: 0.6;
}

@media screen and (min-width: 768px) {
  h2.ttl {
    height: 60rem;
  }
  h2.ttl::before {
    height: 7.3rem;
  }
  h2.ttl::after {
    width: 100%;
    height: 7.3rem;
    font-size: 2.8rem;
  }
  h2.ttl span.ja {
    font-size: 2.8rem;
  }
  h2.ttl span.en {
    font-size: 16rem;
  }
}
@media screen and (max-width: 767px) {
  .scroll {
    width: 100vw;
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-transform: translate3d(0px, 33.6886px, 0px);
            transform: translate3d(0px, 33.6886px, 0px);
  }
}
/*------ contents_header_layout ------------------------------------------*/
.wrapper_head,
.wrapper_head_r {
  padding: 3rem 0 8rem;
}
@media screen and (min-width: 768px) {
  .wrapper_head,
  .wrapper_head_r {
    padding: 4.7rem 0 8rem;
  }
}

.inner_head {
  padding: 25rem 0 0 0;
}
.inner_head h2.ttl {
  left: 0;
}

@media screen and (min-width: 768px) {
  .inner_head {
    padding: 20rem 0 0 0;
  }
  .inner_head h2.ttl {
    left: 3.5rem;
  }
}
.inner_contents {
  /*
  padding: 0 0 0 10rem;
  max-width: 1000px;
  margin: auto;
  box-sizing: border-box;
  @include mq-tab {
      width: 90%;
      padding: 0 0 0 11.5rem;
      box-sizing: border-box;
  }
  @include mq-pc {
      padding: 0 0 0 2rem;
  }*/
  padding: 0;
  max-width: 1000px;
  margin: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .inner_contents {
    width: 90%;
    padding: 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
}

.wrapper_head_r {
  /*.inner_contents {
      padding: 0 10rem 0 0;
      @include mq-tab {
          padding: 0 11.5rem 0 0;
      }
      @include mq-pc {
          padding: 0 2rem 0 0;
      }
  }*/
}
.wrapper_head_r .inner_head h2.ttl {
  left: auto;
  right: 0;
}
.wrapper_head_r .inner_head h2.ttl span.en {
  left: auto;
  right: -3.5rem;
}
@media screen and (min-width: 768px) {
  .wrapper_head_r .inner_head h2.ttl {
    left: auto;
    right: 3.5rem;
  }
}

/*------ hover ------------------------------------------*/
.hover_shadow {
  cursor: pointer;
  -webkit-box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}
.hover_shadow.on {
  -webkit-box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.25);
  -webkit-transform: translateY(-1em);
          transform: translateY(-1em);
}

.hover_shadow02 {
  cursor: pointer;
  -webkit-box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.25);
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}
.hover_shadow02:hover {
  -webkit-box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.25);
  -webkit-transform: translateY(-1em);
          transform: translateY(-1em);
}

.hover_slide {
  background: url(../images/common/bg_green.png) repeat;
  overflow: hidden;
  position: relative;
}
.hover_slide span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
}
.hover_slide::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: url(../images/common/bg_pink.png) repeat;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.hover_slide:hover::before {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.btn {
  width: 47rem;
  height: 7rem;
  margin: 3rem auto;
  max-width: 330px;
}
.btn span {
  color: #f8f6f0;
  font-size: 1.96rem;
}

/* =====================================================================
*    popup
* =================================================================== */
.popup {
  position: fixed;
  display: none;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 99999;
}

.popup_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}

.popup_bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(33, 38, 51, 0.95);
}

.popup_inner {
  position: relative;
  margin: auto;
  -ms-flex-item-align: start;
  align-self: flex-start;
  padding: 80px 0;
  width: calc(690 / 750 * 100%);
}

.popup_close {
  position: absolute;
  top: 30px;
  right: 0;
  width: 3em;
  height: 3em;
  z-index: 3;
}
.popup_close::before {
  content: "";
  display: block;
  width: 1px;
  padding-top: 100%;
  background-color: #cad3d6;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin: 0 auto;
}
.popup_close::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  right: 0;
  width: 1px;
  margin: 0 auto;
  padding-top: 100%;
  background-color: #cad3d6;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.popup_list {
  position: relative;
  width: 100%;
  height: 100%;
  background: #ffffff;
}
.popup_list > li {
  position: relative;
  display: none;
  margin: 0 auto;
  padding: 12rem 0;
  width: calc(560 / 690 * 100%);
  z-index: 2;
}

.popup_movie_embed {
  position: relative;
  padding-top: 56.25%;
}
.popup_movie_embed iframe,
.popup_movie_embed video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.popup_close2 {
  margin: 1em auto 0;
  padding: 0.5em;
  width: 30rem;
  font-size: 2.8rem;
  text-align: center;
  background: #7ca986;
  color: #fff;
  border: 1px solid #fff;
}

@media screen and (max-width: 767px) {
  .popup_movie .popup_inner {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .popup_bg {
    cursor: pointer;
  }
  .popup_inner {
    padding: 5.5em 0;
    width: 80%;
    max-width: 1400px;
  }
  .popup_movie .popup_inner {
    max-width: 1220px;
  }
  .popup_close {
    top: 1.5em;
    cursor: pointer;
  }
  .popup_list > li {
    padding: 6rem 0;
    width: 90%;
    max-width: 880px;
  }
  .popup_close2 {
    width: 50rem;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
    cursor: pointer;
  }
  .popup_close2:hover {
    background-color: #7ca986;
  }
}
/* =====================================================================
*    footer
* =================================================================== */
.footer {
  background: url(../images/common/bg_sns.png) repeat;
  padding: 7rem 0;
}
.footer .footer_sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.footer .footer_sns li {
  width: 7.6rem;
  height: 7.6rem;
  border-radius: 50%;
  padding: 0;
  margin: 0 4rem;
}
.footer .copyright p {
  font-size: 1.4rem !important;
  text-align: center;
  border-top: 1px solid #4e4636;
  padding-top: 4rem;
  margin-top: 7rem;
}
@media screen and (min-width: 768px) {
  .footer .copyright p {
    font-size: 1.8rem;
  }
}

.pagetop {
  font-size: 2.4rem;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
  font-family: "Zen Old Mincho", serif;
  position: absolute;
  bottom: 20rem;
  right: 1rem;
  z-index: 10;
}
.pagetop a {
  display: block;
  line-height: 4rem;
  padding: 1.5rem 0;
  border-top: 1px solid #16130c;
  position: relative;
  color: #16130c;
}
.pagetop a::before {
  content: "";
  width: 4rem;
  height: 3rem;
  position: absolute;
  top: -4.4rem;
  left: 0;
  background: url(../images/common/icon_pagetop.svg) no-repeat top center;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.pagetop a:hover::before {
  -webkit-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

#top .pagetop {
  bottom: 1rem !important;
}

@media screen and (min-width: 768px) {
  .pagetop {
    font-size: 1.4rem;
  }
  .pagetop a::before {
    content: "";
    width: 4rem;
    height: 4.4rem;
  }
}
/* =====================================================================
*    モーダルウィンドウ
* =================================================================== */
.modal {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  z-index: 1000;
  font-family: "Zen Old Mincho", serif;
  -webkit-transform: all 0.3s;
          transform: all 0.3s;
}
.modal__inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100%;
  padding: calc(150 / 750 * 100%) 0 50px;
}
.modal__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(140, 137, 127, 0.95);
  cursor: pointer;
  z-index: -2;
}
.modal__cont {
  position: relative;
  width: 85%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 30px;
  font-size: 3rem;
  background: white url(../images/common/bg_popup01.png) repeat top left;
  -webkit-box-shadow: 0 0 80px 16px rgba(171, 165, 137, 0.5) inset;
          box-shadow: 0 0 80px 16px rgba(171, 165, 137, 0.5) inset;
  padding: 11rem 0;
}
.modal__cont::before {
  content: "";
  display: block;
  width: 120%;
  height: 80%;
  position: absolute;
  top: 10%;
  left: -10%;
  background: url(../images/common/bg_popup02.png) repeat top left;
  -webkit-box-shadow: 0 0 80px 16px rgba(171, 165, 137, 0.5) inset;
          box-shadow: 0 0 80px 16px rgba(171, 165, 137, 0.5) inset;
  z-index: -1;
}
.modal__cont h3 {
  font-size: 2.8rem;
  line-height: 8.3rem;
  margin: 0 auto calc(60 / 1400 * 100%);
  background: #f8f6f0;
  border-top: 1px solid #16130c;
  border-bottom: 1px solid #16130c;
  width: 90%;
  max-width: 60.7rem;
  text-align: center;
  color: #16130c;
}
.modal__cont p {
  font-size: 2.8rem;
  line-height: 1.7;
  width: 90%;
  max-width: 60.7rem;
  margin: auto;
}
.modal__cont .close {
  display: block;
  width: 8rem;
  height: 8rem;
  border-radius: 50%;
  background: rgba(248, 246, 240, 0.6) url(../images/common/icon_plus.svg) no-repeat center center/50%;
  border: 1px solid #16130c;
  position: absolute;
  top: -9rem;
  right: 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.modal.is-show {
  display: block;
  opacity: 1;
  visibility: visible;
}

@media screen and (min-width: 768px) {
  .modal__inner {
    padding: 10rem 0 5rem;
  }
  .modal__cont {
    padding: 10rem 0;
  }
  .modal__cont h3 {
    font-size: 1.8rem;
    line-height: 6.3rem;
    text-align: center;
  }
  .modal__cont p {
    font-size: 1.8rem;
  }
}