@charset "utf-8";

/*---------------
main
---------------*/
main {
  width: auto;
  font-size: 20px;
}
#breadCrumb {
    font-size: 50%;
    margin-top: 10px;
}
a img:hover {
    opacity: 0.7;
}
/*---------------
 top-logo
---------------*/
   .h2-title {
    background-image: url(../images/main.webp);
    background-size: 100%,cover;
    position: relative;
    background-repeat: no-repeat;
    padding-bottom: 37vw;
    background-attachment: fixed;
    background-position-y: 5vw;
}
   h2.top-logo {
    position: absolute;
    bottom: 4vw;
    left: 0;
    right: 0;
    margin: auto;
}
   h2.top-logo img {
    width: 12vw;
}
   .h3-title {
    position: absolute;
    margin: auto;
    top: 20%;
    left: 0;
    right: 0;
}
    h3.h3-title img {
    width: 9vw;
}
/*---------------
intro
---------------*/
.intro {
    margin: 50px auto 0;
}
.intro p {
    margin: 0 auto;
}
.intro p:nth-child(1) {
    display: table;
    border-bottom: 1px solid #000;
    font-size: 110%;
}
.intro p:nth-child(2) {
    margin: 12px auto 0;
    width: 70%;
}
.intro + .cta_area {
    margin: 70px auto 15px;
}
/*---------------
plan
---------------*/
#campaign h2,#roca_plan h2{
    background: #000;
    padding: 15px;
    font-size: 160%;
    color: #fff;
    display: block;
}
#roca_plan h2 + p {
    margin: 60px auto 30px;
}
#roca_plan {
    margin: 70px auto 0;
}
#roca_plan ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 5% auto;
}
#roca_plan ul li {
    width: 40%;
}
div.plan-area {
    margin: 3% auto 5%;
}
p.plan_txt {
    margin: 5% auto;
}
.reserve_button div:nth-of-type(1) > a:before {
    content: '';
    background: url(/common/images/yoyaku_before.png) no-repeat;
    background-size: contain;
    width: 50px;
    height: 50px;
    top: 10px;
    left: 7%;
    position: absolute;
}
.reserve_button div:nth-of-type(2) > a:before, .reserve_button div:nth-of-type(3) > span:before {
    content: '';
    background: url(/common/images/tel_before.png) no-repeat;
    background-size: contain;
    width: 50px;
    height: 50px;
    top: 10px;
    left: 7%;
    position: absolute;
}
/*---------------
共通
---------------*/
div#sb-site {
    padding: 66px 0 0;
}
div#sb-site main {
    font-size: 20px;
    letter-spacing: 0.15em;
    line-height: 1.5;
}
#breadCrumb {
    font-size: 55%;
    letter-spacing: normal;
    line-height: inherit;
    width: 90%;
    margin: 20px auto 0;
}
/*---------------
SP
---------------*/
@media screen and (max-width: 640px){
    main {
        font-size: 12px;
    }
    /*---------------
    top-logo
    ---------------*/
    .h2-title {
        background-image: url(../images/main_sp.webp);
        background-size: 100%,cover;
        position: relative;
        background-repeat: no-repeat;
        padding-bottom: 67vw;
        background-attachment: scroll;
        background-position-y:0;
    }
    h2.top-logo img {
        width: 35vw;
    }
    .outer_dress_collection {
        margin: 30px auto 0;
        width: 90%;
        padding: 0;
    }
    /*---------------
    intro
    ---------------*/
    .intro {
        margin: 40px auto 0;
    }
    .intro p:nth-child(2) {
        margin: 7px auto 0;
        width: 90%;
    }
    .intro + .cta_area {
        margin: 30px auto 15px;
    }

    /*---------------
    plan
    ---------------*/
    #roca_plan {
        margin: 10% auto 0;
    }
    img.roca_plan_img {
        width: 100%;
    }
    #roca_plan ul {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }
    #roca_plan ul li {
        width: 95%;
        margin: 5% auto;
    }
    /*---------------
    共通
    ---------------*/
    div#sb-site {
        padding: 66px 0 0;
    }
    div#sb-site main {
        font-size: 12px;
        letter-spacing: 0.15em;
    }
    @media screen and (max-width: 640px) {
    .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: 6vw;
        top: 6px;
        width: 45px;
        height: 47px;
    }
}