@charset "utf-8";
main {
    width: 100%;
}
section {
    z-index: 1;
    position: relative;
}
#sb-site {
    overflow: hidden;
}
main {
    margin: 50px auto 0;
}

/*--------------------------
slider
---------------------------*/
section#top-section {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    padding-top: 66px;
}
.Opening {
    position:relative;
    background: #fff;
}
.Opening ul li{
    position: relative;
    overflow: hidden;
    width: 100%;
    text-align: center;
}
.Opening ul li img.Opening__text{
    position: absolute;
    top:50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform:translate(-50%, -50%);
    z-index: 9;
}
.Opening ul li span img.Opening__img{
    max-width: inherit;
    width: 100%;
    height: auto;
}
/*------------------------
main-section
------------------------*/
section#main-section {
    margin-top: 32vw;
    background: url(../images/main/main_bg.webp)no-repeat;
    background-size: contain;
    padding-top: 130px;
    position: relative;
}
.intro-txt {
    position: relative;
    margin: 100px auto 70px;
}
.intro-txt:before {
    background: url(../images/main/intro-star.png) no-repeat;
    background-size: contain;
    content: '';
    position: absolute;
    z-index: 3;
    height: 20px;
    width: 20px;
    top: -20%;
    left: auto;
}
.intro-txt p {
    font-size: 15px;
    margin-bottom: 35px;
    line-height: 30px;
}
.campaign {
    padding: 80px 0;
    position: relative;
    z-index: 1;
}
.campaign h2:before {
    background: url(../images/kira01.png) no-repeat;
    background-size: contain;
    content: '';
    position: absolute;
    z-index: 3;
    height: 80px;
    width: 65px;
    top: 5%;
    left: 25%;
}
.h2_title, .h2_title img {
    margin-bottom: 5px;
}
div.campaign h2.h2_title {
    width: 243px;
    height: 17px;
}
div.campaign .cam-img {
    width: 650px;
    height: 472px;
    z-index: 9;
    position: relative;
}
.summary_txt {
    margin-bottom: 20px;
    font-size: 12px;
    letter-spacing: 0.5px;
}
/*------------------------
 cta_area
------------------------*/
.cta_area {
    margin: 0 auto;
    width: 90%;
    max-width: 500px;
    display: flex;
    justify-content: space-between;
}
.cta_area div {
    border: 1px solid #c24952;
    border-radius: 5px;
    overflow: hidden;
    display: flex;
}
.cta_area div > a,
.cta_area div > span {
    display: block;
    width: 100%;
    cursor: pointer;
}
.cta_area div > a:hover {
    opacity: 0.7;
}
.cta_area .tel {
    width: 25%;
    font-size: 120%;
}
.cta_area .tel a,
.cta_area .tel span {
    color: #c24952;
    padding: 41px 10px 0;
    font-size: 14px;
    background: url(../images/cta_icon_tel.png) center 10px / 30px auto no-repeat #fff;
}
.cta_area .form {
    width: 70%;
}
.cta_area .form a {
    color: #fff;
    font-size: 12px;
    background: #c24952;
    position: relative;
}
.cta_area .form a > span {
    background: url(../images/cta_icon_calender.png) left center / 40px auto no-repeat;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    padding: 4px 0 0 50px;
    white-space: nowrap;
}
.cta_area .form a span span {
    display: block;
    font-size: 170%;
}
/*------------------------
photo_menu
------------------------*/
#photo_menu {
    position: relative;
}
#photo_menu:before {
    background: url(../images/kira02.png) no-repeat;
    background-size: contain;
    content: '';
    position: absolute;
    z-index: 3;
    height: 80px;
    width: 15px;
    margin: -30px auto 0;
}
#photo_menu:after {
    background: url(../images/kira05.png) no-repeat;
    background-size: contain;
    content: '';
    position: absolute;
    z-index: 3;
    height: 94px;
    width: 70px;
    bottom: 0;
    left: 5%;
}
#photo_menu .photo_menu_inner {
    padding-top: 80px;
    background: linear-gradient(#f8dfc6, #f0cecd , #d9d4ea);
    border-top-right-radius: 2000px 300px;
    border-top-left-radius: 2000px 300px;
    margin-left: -200px;
    margin-right: -200px;
    padding-left: 200px;
    padding-right: 200px;
}
#photo_menu ul {
    display: flex;
    justify-content: center;
    padding-top: 10px;
    flex-wrap: wrap;
}
#photo_menu ul li {
    width: 20%;
    position: relative;
}
#photo_menu ul li p {
    font-size: 14px;
    margin: 10px auto;
}
.photo_menu_inner p span {
    line-height: 3;
}
#photo_menu ul li p:nth-child(3) {
    margin-bottom: -5px;
}
#photo_menu ul li div {
    background: #fff;
    width: 110px;
    margin: 10px auto;
    border-radius: 15px;
}
#photo_menu ul li div p {
    color: #f8b8a0;
    background: -webkit-linear-gradient(0deg, #f29395, #f8b9a1);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 12px;
    padding: 5px 0;
}
#photo_menu ul:before {
    background: url(../images/kira03.png) no-repeat;
    background-size: contain;
    content: '';
    position: absolute;
    z-index: 3;
    height: 50px;
    width: 50px;
    top: 40%;
    left: 10%;
}
#photo_menu ul:after {
    background: url(../images/kira04.png) no-repeat;
    background-size: contain;
    content: '';
    position: absolute;
    z-index: 3;
    height: 35px;
    width: 30px;
    right: 2%;
    top: 55%;
}
.scroll img {
    width: 40px;
    height: 40px;
    margin: 50px auto 30px;
}
/*------------------------
shop-list
------------------------*/
div#shop-list {
    /*padding: 80px 0 0;*/
    background: #dbd5e7;
    position: relative;
}
div#shop-list .shop-list_inner {
    padding: 80px 0;
    background: #fef9f3;
    border-top-right-radius: 2000px 300px;
    border-top-left-radius: 2000px 300px;
    margin-left: -200px;
    margin-right: -200px;
    padding-left: 200px;
    padding-right: 200px;
}
#shop-list ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 960px;
    margin: 0 auto;
}
#shop-list ul li {
    width: 28%;
    margin: -15px;
    position: relative;
}
#shop-list ul li p span {
    letter-spacing: -2.4px;
}
/*------------------------
 whatsNew 新着情報
------------------------*/
div#wp_contents {
    background: #fff;
    padding: 80px 0 1px;
    border-top-right-radius: 2000px 300px;
    border-top-left-radius: 2000px 300px;
    margin-left: -200px;
    margin-right: -200px;
    padding-left: 200px;
    padding-right: 200px;
    margin-top: -80px;
    z-index: 9;
    position: relative;
}
#WHATS_NEW .clear {
  width: 960px;
  margin: 0 auto;
}
.tabs-box .tab li {
    display: table-cell;
    border-top: 1px solid #f9d3d4;
    border-bottom: 1px solid #f9d3d4;
    border-right: 2px solid #fff;
    font-size: 160%;
    padding: 20px 2%;
    width: 21%;
    text-align: center;
    cursor: pointer;
    background: #f9d3d4;
}
.tabs-box .tab li:hover{
    background: #f49091;
}
.tabs-box .tab .active {
    background: #f49091;
    border-top: 1px solid #f49091;
    border-bottom: 1px solid #f49091;
    color: #000;
}
.kids_top .content ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.kids_top .min-title02 {
    padding-top: 10px;
}
.kids_top .tabs-box .item-4th,.column_content .item-4th {
    box-sizing: border-box;
    padding: 8px;
}
.kids_top .tabs-box .item-4th .wp_ph,.column_content .item-4th .wp_ph {
    width: 217px;
}
.kids_top .tabs-box .pickup {
    background: #fbf4e2;
}
.kids_top .tabs-box .minbox.pickup .data {
    color: #ab8429;
}
.tabs-box .tab {
    border-left: 1px solid #fff;
}
/*------------------------
 sub-contents コンテンツ
------------------------*/
.bottom_contents {
    background: #fff;
}
@media screen and (min-width:641px){
    #sub-contents{
        width: 920px;
        margin: 0 auto;
        overflow: hidden;
        padding: 50px 0 0;
    }
    #sub-contents ul {
        width: 930px;
    }
    #sub-contents li {
        width: 300px;
        float: left;
        margin: 0 10px 10px 0;
    }
    #sub-contents li img {
        height: 80px;
    }
}

footer {
    z-index: 1;
    position: relative;
    background: #fff;
}
/*-----------------------------------------------------
SP
-----------------------------------------------------*/
@media screen and (max-width:640px){
    section#top-section {
        padding-top: 66px;
    }
    section#main-section {
        margin-top: 57vw;
        padding: 50px 0 0;
        background: url(../images/main/main_bg_sp.webp)no-repeat;
        background-size: contain;
    }
    div.intro-img {
        width: 60%;
        height: auto;
        margin: 0 auto 40px;
    }
    .h2_title, .h2_title img {
        margin-bottom: 0;
    }
    .intro-txt {
        position: relative;
        margin-top: 50px;
        margin-bottom: 35px;
    }
    .intro-txt p {
        font-size: 12px;
        margin-bottom: 15px;
        line-height: 25px;
    }
    .intro-txt:before {
        background: url(../images/main/intro-star.png) no-repeat;
        background-size: contain;
        content: '';
        position: absolute;
        z-index: 3;
        height: 15px;
        width: 15px;
        top: -15%;
        left: auto;
    }
    /*------------------------
    campaign
    ------------------------*/
    .campaign {
        padding: 50px 0;
        position: relative;
        z-index: 1;
    }
    .campaign h2:before {
        background: url(../images/kira01.png) no-repeat;
        background-size: contain;
        content: '';
        position: absolute;
        z-index: 3;
        height: 50px;
        width: 50px;
        top: 5%;
        left: 5%;
    }
    div.campaign h2.h2_title img {
        height: 12px;
        width: 171px;
    }
    .summary_txt {
        margin: 10px auto;
        font-size: 11px;
        letter-spacing: 1px;
    }
    div.campaign .cam-img {
        width: 85%;
        height: auto;
        z-index: 9;
        position: relative;
    }
    /*------------------------
     phto_menu
    ------------------------*/
    #photo_menu .photo_menu_inner {
        padding-top: 80px;
        background: linear-gradient(#f6e2c3,#f8d8bf,#f7d0c3,#f0ceca,#ebcbd0,#e1cce3);
        border-top-right-radius: 500px 300px;
        border-top-left-radius: 500px 300px;
        margin-left: -50px;
        margin-right: -50px;
        padding-left: 50px;
        padding-right: 50px;
    }
    #photo_menu ul li {
        width: 45%;
        position: relative;
        margin: 10px 0;
    }
    #photo_menu ul li p {
        font-size: 14px;
        margin: 5px auto 0;
    }
    #photo_menu ul li div {
        background: #fff;
        width: 110px;
        margin: -5px auto;
        border-radius: 15px;
    }
    #photo_menu ul li div p {
        font-size: 11px;
        padding: 3px 0;
        letter-spacing: 1px;
    }
    #photo_menu ul li p.baby {
        font-size: 12px;
        margin: 5px auto 10px;
    }
    #photo_menu .h2_title img {
        margin-bottom: 5px;
        height: 12px;
        width: 116px;
    }
    #photo_menu ul:before {
        background: url(../images/kira03.png) no-repeat;
        background-size: contain;
        content: '';
        position: absolute;
        z-index: 3;
        height: 45px;
        width: 45px;
        top: 5%;
        left: 4%;
    }
    #photo_menu ul:after {
        background: url(../images/kira04.png) no-repeat;
        background-size: contain;
        content: '';
        position: absolute;
        z-index: 3;
        height: 40px;
        width: 40px;
        right: 0;
        top: 35%;
        transform: scale(-1, 1);
    }
    #photo_menu:after {
        background: url(../images/kira05.png) no-repeat;
        background-size: contain;
        content: '';
        position: absolute;
        z-index: 3;
        height: 50px;
        width: 50px;
        bottom: 10%;
        right: 0;
        left: auto;
    }
    .scroll img {
        width: 40px;
        height: 40px;
        margin: -15px auto 20px;
    }
    /*------------------------
    予約ボタン
    ------------------------*/
    .reserve_button div:nth-of-type(1) > a {
        background: #d91a40;
        box-shadow: 3px 3px 0 #91202e;
        font-size: 4vw;
        position: relative;
        display: block;
        box-sizing: border-box;
        width: 65vw;
        padding: 10px 50px 10px;
        cursor: pointer;
        -webkit-transition: none;
        transition: none;
        color: #fff;
        border-radius: 10px;
        margin: 3% auto;
        text-align: right;
    }
    .reserve_button div:nth-of-type(2) > a, .reserve_button div:nth-of-type(3) > span {
        background: #4fa9b0;
        box-shadow: 3px 3px 0 hsl(183deg 65% 24%);
        font-size: 4vw;
        position: relative;
        display: block;
        box-sizing: border-box;
        width: 65vw;
        padding: 10px 0 10px 50px;
        cursor: pointer;
        -webkit-transition: none;
        transition: none;
        color: #fff;
        border-radius: 10px;
        margin: 3% auto;
        text-align: center;
    }
    .reserve_button div:nth-of-type(1) > a:before, .reserve_button div:nth-of-type(2) > a:before, .reserve_button div:nth-of-type(3) > span:before {
        content: '';
        left: 8vw;
        top: 4px;
        width: 35px;
        height: 35px;
    }
    /*---------------------------
    cta_area
    ----------------------------*/
    .cta_area {
        margin: 10vw auto 0;
    }
    .cta_area .sb-toggle-right {
        position: static;
        background: none;
        height: auto;
    }
    /*------------------------
    shop-list
    ------------------------*/
    div#shop-list {
        padding: 0;
        background: #e1cce3;
        position: relative;
    }
    div#shop-list h2 img {
        height: 12px;
        width: 100px;
    }
    div#shop-list .shop-list_inner {
        padding: 80px 0;
        background: #fef9f3;
        border-top-right-radius: 500px 300px;
        border-top-left-radius: 500px 300px;
        margin-left: -50px;
        margin-right: -50px;
        padding-left: 50px;
        padding-right: 50px;
    }
    #shop-list ul {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        width: 100%;
        margin: 0 auto;
    }
    #shop-list ul li {
        width: 54%;
        margin: -15px;
        position: relative;
    }
    #shop-list .scroll img {
        width: 40px;
        height: 40px;
        margin: 30px auto;
    }
    /*------------------------
    whatsNew 新着情報
    ------------------------*/
    div#wp_contents {
        background: #fff;
        padding: 50px 0 1px;
        margin-top: -80px;
        z-index: 9;
        position: relative;
        border-top-right-radius: 500px 300px;
        border-top-left-radius: 500px 300px;
        margin-left: -50px;
        margin-right: -50px;
        padding-left: 50px;
        padding-right: 50px;
    }
    div#WHATS_NEW {
        width: 95%;
        margin: 0 auto;
    }
    div#WHATS_NEW h2 img {
        height: 12px;
        width: 96px;
    }
    .entry_box {
        margin: 0;
        padding-bottom: 50px;
        border-bottom: none;
    }
     #WHATS_NEW .clear {
        width: 100%;
    }
    .tabs-box .tab li {
        font-size: 10px;
    }
    .kids_top .tabs-box .item-4th,.column_content .item-4th {
        padding: 5px;
    }
    .kids_top .tabs-box .item-4th .wp_ph,.column_content .item-4th .wp_ph {
        padding-right: 0;
        width: 100%;
    }
    .kids_top .tabs-box .minbox.item-4th,.column_content .minbox.item-4th {
        margin-right: 0;
        width: 49%;
    }
    .kids_top .tabs-box .content li:nth-child(odd),.column_content .content li:nth-child(odd) {
        margin-right: 2%;
    }
    .kids_top .tabs-box .minbox a,.column_content .minbox a {
        display: block;
        table-layout: auto;
    }
    .kids_top .tabs-box .minbox.item-4th .data-box,.column_content .minbox.item-4th .data-box {
        min-height: auto;
    }
    .kids_top .tabs-box .minbox h4,.column_content .minbox h4{
        margin-top: 5px;
    }
    /*------------------------
    sub-contents コンテンツ
     ------------------------*/
     #sub-contents {
         width: 95%;
         margin: 0 auto;
     }
     #sub-contents ul {
        width: 100%;
        margin: 0 auto;
    }
    #sub-contents li{
        margin-bottom: 20px;
    }
}