@charset "UTF-8";

/* =============================================
 SCENE CSS
============================================= */

/* ================ page main image ================ */

.page_main_img{
    background-color: #FFF;
    background-image: url(../img/main_img.jpg);
    padding-bottom: 20%;
}

.page_scene{
  margin-bottom: 4%;
}
#baby.container,
#kids.container,
#other.container{
    background-position: top center;
    background-repeat: no-repeat;
}
#baby.container{
    background-image: url(../img/baby_bg.png);
}
#kids.container{
    background-image: url(../img/kids_bg.png);
}
#other.container{
    background-image: url(../img/other_bg.png);
}

/* ================ page scene BTN ================ */

.page_scene_btn{
    margin-top: -50%;
    margin-right: auto;
    margin-left: auto;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center left;
    max-width: 29vw;
    max-height: 29vw;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    border: 3px solid #FFF;
    transition: all 0.6s ease 0s;
}

.page_scene_btn:hover{
  cursor: pointer;
  transform: scale(1.06, 1.06);
}
.page_scene_btn.baby{
    background-image: url(../img/btn_baby.jpg);
}
.page_scene_btn.kids{
    background-image: url(../img/btn_kids.jpg);
}
.page_scene_btn.family{
    background-image: url(../img/btn_family.jpg);
}

.page_scene_btn p{
    font-size: 22px;
    font-weight: bold;
    color: #FFF;
    text-align: center;
    position: relative;
    top: 66%;
    transform: translateY(-50%);
    -webkit- transform: translateY(-50%);
}
.page_scene_btn p span{
    font-size: 12px;
    display: block;
}

.page_scene a{
    display: block;
}

/* ================ page scene ================ */


.scene_article.flex_box{
    margin-bottom: 20px;
}
.scene_article.flex_box > div{
    width: 50%;
}

.scene_article.flex_box > div:nth-of-type(2){
    padding: 20px 0;
}
.scene_article.flex_box > div.scene_txt{
    padding-bottom: 20px;
    margin-top: 0;
}
.scene_article.flex_box > div.scene_txt p{
    font-size: 120%;
    width: 100%;
    text-align: center;
}

.scene_article.flex_box >div.scene_txt p span{
    font-size: 13px;
    display: block;
    margin-top: 10px
}

.btn.btn_xs{
    margin: 20px auto 0;
}


/* ============================ SP ============================ */

@media only screen and (max-width: 767px) {
    /* ================ page scene ================ */
    .scene_article.flex_box{
        flex-wrap: wrap;
    }
    .scene_article.flex_box > div{
        width: 100%;
    }
}

/* ============================ MD ============================ */

@media only screen and (min-width: 768px) {

    /* ================  ================ */
    .page_main_img{
        padding-bottom: 15%;
    }

    /* ================ page scene BTN ================ */

    .page_scene_btn{
        margin-top: -40%;
    }

}
/* ============================ PC ============================ */

@media only screen and (min-width: 1024px) {

    /* ================  ================ */

}


/* =============================================
 SCENE COMMON CSS
============================================= */


/* ================ 現在未使用のため非表示 ================ */
.scene_plan_brother{
  display: none;
}

#scene .main{padding: 10px;}

#scene .scene_title h3{
    text-align: center;
    line-height: 2;
    font-size: 16px;
}

/* ================ page main image ================ */

#scene .page_main_img{
    padding: 50vw 0 10vw;
}

#scene h1.contents_title{
  margin-bottom: 0;
}

#scene h2.contents_title{
    line-height: 2;
    font-size: 115%;
    letter-spacing: 2px;
    margin-bottom: 0;
    padding-bottom: 40px;
}

/* ================  ================ */

.scene_bg{
    background-color: #fff4ef;
}

.sp .btn.yoyaku{
    margin-top: -10px;
}

/* ================  ================ */

.scene_title{
    background-position: right bottom;
    background-repeat: no-repeat;
    background-size: 20vw;
}
.scene_point{
    text-align: center;
    background-position: left center;
    background-repeat: no-repeat;
    background-size: 20vw;
}
.scene_point img{
    padding: 0 0 20px;
    width: 80px;
}
.scene_point p{
    font-weight: bold;
    font-size: 110%;
    line-height: 2;
}

/* ================  ================ */

.scene_tips{
    margin-top: 40px;
    background-color: #FFF;
    border-radius: 20px;
    padding: 15px;
}
.scene_tips h2{
    text-align: center;
    font-weight: bold;
    margin-top: 20px;
    margin-bottom: 15px;
}

.scene_tips p{
    line-height: 1.8;
}

.scene_tips_img{
    overflow: hidden;
    box-sizing: border-box;
    padding-top: 15px;
    text-align: center;
}

/* ================  ================ */

.costume_slider{
    margin: 0 -15px;
}

/* ================  ================ */

.help_txt{
    text-align: center;
    margin-top: 1rem;
}


/* ================  ================ */

.plan_top {
  display: inline-block;
  position: relative;
  height: 60px;
  line-height: 60px;
  text-align: center;
  padding: 7px 0;
  font-size: 18px;
  background: #fcb2a9;
  color: #FFF;
  box-sizing: border-box;
    left: 50%;
    transform: translateX(-50%);
}

.plan_top p {
  font-weight: bold;
  margin: 0;
  padding: 0 50px;
  border-top: dashed 1px #FFF;
  border-bottom: dashed 1px #FFF;
  line-height: 46px;
}

.plan_top:before, .plan_top:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.plan_top:before {
  /*左端の山形*/
  top: 0;
  left: 0;
  border-width: 30px 0px 30px 15px;
  border-color: transparent transparent transparent #fff;
  border-style: solid;
}

.plan_top:after {
  /*右端の山形*/
  top: 0;
  right: 0;
  border-width: 30px 15px 30px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
}

.scene_plan{
    margin-top: 40px;
    background-color: #FFF;
    border-radius: 20px;
    padding: 50px 15px 15px;
    margin-top: -30px;
    border: 5px solid #fdd1cb;
    font-size: 18px;
}
.scene_plan small{
    margin-top: .5rem;
    display: block;
}

.scene_plan .float_box_md:first-child{
    margin-bottom: 20px;
}

.scene_plan .btn{
    margin: 20px auto;
}

.scene_plan_brother{
    background-color: #fef0ee;
    margin: 0 -15px -15px;
    padding: 20px 15px;
    border-radius: 0 0 15px 15px;
}

.scene_plan_brother h3 {
  position: relative;
  padding: 1em;
  background: #FFF;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 30px;
  max-width: 300px;
  left: 50%;
  transform: translateX(-50%);
}

.scene_plan_brother h3:after {
  position: absolute;
  content: '';
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 10px solid transparent;
  border-top: 10px solid #FFF;
  width: 0;
  height: 0;
}

.scene_plan_brother h4{
    text-align: center;
    margin-bottom: 1rem;
    font-size: 14px;
}
.scene_plan_brother p{
    font-size: 12px;
}
.scene_plan_brother .float_box_md:first-child{
    border-bottom: 1px solid #cebbb8;
    padding-bottom: 20px;
}

#plan .btn_l.yoyaku{
    max-width: 340px;
    line-height: 60px;
}

/* ================ 当日の流れ ================ */

#flow{
    background-color: #fff1db;
}

#flow ul{
    text-align: center;
}
#flow ul li {
    text-align: left;
  position: relative;
  display: inline-block;
  margin: 1em 0;
  padding: 7px 10px;
  width: 100%;
  color: #886c3d;
  font-size: 16px;
  background: #FFF;
  font-weight: bold;
  box-sizing: border-box;
}

#flow ul li:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -12px;
  border: 12px solid transparent;
  border-top: 12px solid #FFF;
}

#flow ul li:last-child:before{
  border: none;
}

#flow ul li span {
    display: inline-block;
    background-color: #886c3d;
    text-align: center;
    width: 40px;
    line-height: 40px;
    color: #FFF;
    margin-right: 1rem;
}

/* ============================ SP ============================ */

@media only screen and (max-width: 500px) {

}

/* ============================ MD ============================ */

@media only screen and (min-width: 768px) {

  #scene .main{padding: 15px;}

  #scene .page_main_img{
      padding: 22vw 0 4vw;
      max-width: 2500px;
  }

  #scene h2.contents_title{
    font-size: 130%;
    letter-spacing: 3px;
  }

    .scene_title{
        background-position: right center;
        background-size: 120px;
    }
    .scene_point{
        background-size: 120px;
    }

    .scene_tips{
        margin-top: 60px;
        padding: 25px;
    }
    .scene_tips h2{
        margin-top: 40px;
        margin-bottom: 40px;
    }
    .scene_tips_img{
        max-height: 280px;
        padding-left: 20px;
        padding-top: 0;
    }

    /* ================  ================ */

    .costume_slider{
        margin: 0 -30px;
    }

    .costume_slider li{
        padding: 0 10px;
    }

    /* ================  ================ */

    .scene_plan{
        padding: 60px 25px 25px;
    }

    .scene_plan .float_box_md:first-child img{
        width: 90%;
    }

    .scene_plan_brother{
        margin: 0 -25px -25px;
        padding: 40px 25px;
    }
    .scene_plan_brother h4{
        font-size: 16px;
    }
    .scene_plan_brother p{
        font-size: 14px;
        padding: 0 20px;
    }

    .scene_plan_brother .float_box_md:first-child{
        border-right: 1px solid #cebbb8;
        border-bottom: none;
        padding-bottom: 0;
        box-sizing: border-box;
    }


}
/* ============================ PC ============================ */

@media only screen and (min-width: 1024px) {

    /* ================  ================ */

    #flow ul li {
      position: relative;
      display: inline-block;
      margin: 1.5em 15px 1.5em 0;
      width: 17%;
    }

    #flow ul li:before {
        display: none;
    }

    #flow ul li:after {
        content: "";
        position: absolute;
        top: 50%;
        left: 100%;
        margin-top: -12px;
        border: 12px solid transparent;
        border-left: 12px solid #FFF;
    }

    #flow ul li:last-child:after{
      border: none;
    }
}

