.remodal-close:before {
    content: "\00d7";
}
.bnr__shared {
    max-width: 100%;
}
.bnr__shared a {
    letter-spacing: 0.1em;
}
.d-flex {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}
.ob img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.bnr__shared.popup a::after {
    background: url("../img/lunch/icon_add.png") no-repeat;
    background-size: 100%;
}
#kv {
    background: url("../img/takeout/key.jpg") no-repeat center;
    background-size: cover;
    min-height: 120vw;
}
.bnr__shared a.style-1 {
    font-family: 'Noto Serif JP';
}
@media screen and (min-width: 768px) {
    img {
        width: auto
    }
    .bnr__shared {
        width: 467px;
    }
    .bnr__shared a.style-1 {
        font-size: 22px;
        padding: 20px;
        letter-spacing: 0px;
    }
    .bnr__shared a.style-1::before {
        width: 29px;
    }
    .bnr__shared a.style-1::after {
        width: 28px;
        height: 28px;
        top: 27px;
        right: 39px;
    }
    #kv {
        min-height: 900px;
    }
}


/* sec1 */
#sec1 {
    position: relative;
    padding: 10vw 0 15vw;
    background: url("../img/takeout/sec1_bg.jpg") no-repeat;
    background-size: cover;
}
#sec1 h2 {
    font-size: 9vw;
    text-align: center;
    line-height: 1.5;
    position: relative;
    margin-bottom: 6vw;
    letter-spacing: 0.1em;
}
#sec1 h2::before {
    content: "";
    background: url("../img/takeout/sec1_ttl_deco2.png") no-repeat;
    width: 14vw;
    height: 16vw;
    background-size: 100%;
    position: absolute;
    top: 14vw;
    left: -7%;
}
#sec1 h2::after {
    content: "";
    background: url("../img/takeout/sec1_ttl_deco3.png") no-repeat;
    width: 14vw;
    height: 16vw;
    background-size: 100%;
    position: absolute;
    top: 13vw;
    right: -7%;
}
#sec1 h2 small {
    font-size: 7vw;
}
#sec1 h2 span {
    font-size: 8vw;
    position: relative;
    z-index: 0;
}
#sec1 h2 span::before {
    content: "";
    background: url("../img/takeout/sec1_ttl_deco1.png") no-repeat;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 10vw;
    background-size: 100%;
    z-index: -1;
}
#sec1 .gr-photo {
    position: relative;
    margin-bottom: 8vw;
}
#sec1 .gr-photo .photo {
    width: 75%;
}
#sec1 .gr-photo .photo2 {
    position: absolute;
    right: 0;
    bottom: -10vw;
    width: 35%;
}
#sec1 .txt {
    background: #d03030;
    color: #fff;
    padding: 8% 5%;
    position: relative;
    z-index: 5;
}
@media screen and (min-width: 768px) {
    #sec1 {
        padding: 138px 0 105px;
    }
    #sec1 .wrap {
        max-width: 1341px;
    }
    #sec1 h2 {
        font-size: 62px;
        margin-bottom: 99px;
        letter-spacing: 2px;
    }
    #sec1 h2::before {
        width: 142px;
        height: 142px;
        top: 15px;
        left: 76px;
    }
    #sec1 h2::after {
        width: 141px;
        height: 135px;
        top: -10px;
        right: 55px;
    }
    #sec1 h2 small {
        font-size: 52px;
    }
    #sec1 h2 span {
        font-size: 62px;
    }
    #sec1 h2 span::before {
        width: 174px;
        height: 52px;
    }
    #sec1 .gr-photo {
        margin-bottom: -170px;
    }
    #sec1 .gr-photo .photo {
        width: auto;
        margin-left: 29px;
    }
    #sec1 .gr-photo .photo2 {
        width: auto;
        right: 43px;
        bottom: -86px;
    }
    #sec1 .txt {
        padding: 25px 51px 47px 30px;
        width: 648px;
        box-sizing: border-box;
        position: relative;
        letter-spacing: 0.01em;
    }
    #sec1 .txt::before {
        content: "";
        position: absolute;
        left: calc(50% - 50vw);
        top: 0;
        bottom: 0;
        right: 100%;
        background: #d03030;
    }
}
@media only screen and (min-width: 768px) and (max-width: 1300px) {
	#sec1 h2::before{
		left: -35px;
	}
	#sec1 h2::after{
		right: 35px;
	}
}

/* sec2 */
#sec2 .set1 {
    position: relative;
}
#sec2 .set1 .col {
    position: absolute;
    top: 20vw;
    left: 0;
    right: 0;
    color: #fff;
    z-index: 5;
    text-align: center;
}
#sec2 .set1 .col h2 {
    font-size: 11vw;
    line-height: 1.3;
    margin-bottom: 5vw;
}
#sec2 .set1 .col h2 small {
    font-size: 6vw;
}
#sec2 .set1 .col .note {
    font-size: 14px;
}

#sec2 .set1 .js1 li, #sec2 .set1 .js2 li{
	background-color: #000
}
#sec2 .set1 .js1 img {
    width: 220px;
}
#sec2 .set1 .js2 img {
    width: 220px;
}
#sec2 .set2 {
    position: relative;
    padding: 15vw 0 0vw;
}
#sec2 .set2 .group {
    position: relative;
    margin-bottom: -4vw;
	padding-top: 4vw;
}
#sec2 .set2 .group::after {
    content: "";
    background: url("../img/takeout/sec2_box_bg.jpg") repeat;
    position: absolute;
    top: -3vw;
    left: -5%;
    right: -5%;
    height: 97vw;
    border-radius: 50%;
    z-index: -1;
}
#sec2 .set2 .group h2 {
    text-align: center;
    font-size: 12vw;
    line-height: 1.4;
    margin-bottom: 2vw;
    color: #fff;
    letter-spacing: 0.1em;
}
#sec2 .set2 .group h2 span {
    font-size: 13.3vw;
    position: relative;
    margin-right: 4%;
    z-index: 0;
}
#sec2 .set2 .group h2 span::before {
    content: "";
    background: #cc9a00;
    position: absolute;
    width: 14vw;
    height: 14vw;
    border-radius: 50%;
    left: -58%;
    top: 18%;
    z-index: -1;
}
#sec2 .set2 .group h2 small {
    font-size: 8vw;
}
#sec2 .set2 .group .txt {
    color: #fff;
    width: 72%;
    margin: 0 auto 5vw;
    font-size: 14px;
}
#sec2 .set2 .photo {
    margin-left: -11%;
    width: 97%;
    position: relative;
    z-index: 6;
    margin-bottom: -9vw;
}
#sec2 .set2 .deco {
    position: absolute;
    width: 28%;
    right: 0;
    top: 66vw;
}
#sec2 .set2 .box {
    padding: 14% 5% 11%;
    background: url("../img/takeout/sec2_box_bg2.jpg") no-repeat left bottom -1px;
    background-color: #f6f0e1;
    border: 2px solid #000;
    background-size: 100%;
    box-shadow: 0px 7px 14px rgba(0, 0, 0, 0.3);
}
#sec2 .set2 .box .row .price {
    text-align: center;
    margin-bottom: 6vw;
    letter-spacing: 0.05em;
}
#sec2 .set2 .box .row .price dt {
    font-size: 7.9vw;
    margin-bottom: 2vw;
    position: relative;
    line-height: 1;
}
#sec2 .set2 .box .row .price dt small {
    font-size: 4.5vw;
    position: relative;
    display: inline-block;
    z-index: 0;
}
#sec2 .set2 .box .row .price dt small::after {
    content: "";
    background: #d03030;
    position: absolute;
    bottom: -28%;
    left: 0;
    height: 10px;
    right: 0;
    z-index: -1;
}
#sec2 .set2 .box .row .price dd {
    font-size: 5vw;
}
#sec2 .set2 .box .row .right h3 {
    font-size: 5vw;
    text-align: center;
}
#sec2 .set2 .box .row .right dl {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #000;
    padding: 5px 0;
    letter-spacing: 0;
}
#sec2 .set2 .box .row .right dl dt {
    width: 75%;
}
#sec2 .set2 .box .row .right dl dd {
    width: 20%;
    text-align: right;
}
@media screen and (min-width: 768px) {
    #sec2 .set1 {}
    #sec2 .set1 .col {
        top: 167px;
    }
    #sec2 .set1 .col h2 {
        font-size: 72px;
        margin-bottom: 20px;
    }
    #sec2 .set1 .col h2 small {
        font-size: 42px;
    }
    #sec2 .set1 .col .note {
        font-size: 16px;
    }
    #sec2 .set1 .js1 img {
        width: 420px;
    }
    #sec2 .set1 .js2 img {
        width: 420px;
    }
    #sec2 .set2 {
        padding: 136px 0 20px;
    }
    #sec2 .set2::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0px;
        bottom: 0;
        width: 996px;
        background: url("../img/takeout/sec2_deco2.png") no-repeat;
        z-index: -1;
        height: 1825px;
    }
    #sec2 .set2 .group {
        margin-bottom: -30px;
		padding-top: 0;
    }
    #sec2 .set2 .group::after {
        top: -70px;
        width: 740px;
        left: 0;
        right: 0;
        height: 740px;
        margin: 0 auto 0;
    }
    #sec2 .set2 .group h2 {
        font-size: 92px;
        margin-bottom: 27px;
    }
    #sec2 .set2 .group h2 span {
        font-size: 99px;
        margin-right: 17px;
        margin-left: 51px;
    }
    #sec2 .set2 .group h2 span::before {
        width: 112px;
        height: 112px;
        left: -42px;
        top: 16px;
    }
    #sec2 .set2 .group h2 small {
        font-size: 51px;
    }
    #sec2 .set2 .group .txt {
        margin: 0 auto 20px;
        font-size: 16px;
        width: 530px;
        text-align: center;
    }
    #sec2 .set2 .photo {
        margin-left: 0;
        margin-bottom: -134px;
        text-align: center;
        width: auto;
    }
    #sec2 .set2 .deco {
        top: 126px;
        width: auto;
        right: -160px;
    }
    #sec2 .set2 .box {
        padding: 180px 20px 79px;
        box-sizing: border-box;
        margin: 0 48px;
        border-width: 1px;
        background-size: 779px;
    }
    #sec2 .set2 .box .row {
        flex-direction: row;
        justify-content: space-between;
        margin: 0 95px;
    }
    #sec2 .set2 .box .row .price {
        margin-bottom: 20px;
        text-align: left;
    }
    #sec2 .set2 .box .row .price dt {
        font-size: 42px;
        margin-bottom: 26px;
        letter-spacing: 2px;
    }
    #sec2 .set2 .box .row .price dt small {
        font-size: 27px;
        letter-spacing: 0px;
        margin-left: -10px;
    }
    #sec2 .set2 .box .row .price dt small::after {
        left: 17px;
        right: 17px;
        height: 13px;
    }
    #sec2 .set2 .box .row .price dd {
        font-size: 32px;
        letter-spacing: 4px;
        margin-left: 10px;
    }
    #sec2 .set2 .box .row .price dd small {
        font-size: 22px;
    }
    #sec2 .set2 .box .row .right {
        width: 310px;
        margin-right: 19px;
    }
    #sec2 .set2 .box .row .right h3 {
        font-size: 22px;
        text-align: left;
        letter-spacing: 5px;
        margin-top: -5px;
        margin-bottom: 18px;
    }
    #sec2 .set2 .box .row .right dl {
        padding: 4px 0;
    }
    #sec2 .set2 .box .row .right dl dt {
        width: auto;
    }
    #sec2 .set2 .box .row .right dl dd {
        width: auto;
        letter-spacing: 2px;
    }
}

/* sec3 */
#sec3 {
    position: relative;
    padding: 15vw 0 0vw;
}
#sec3::before {
    content: "";
    background: url("../img/takeout/sec2_deco2.png") no-repeat;
    width: 50%;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    background-size: 100%;
    z-index: -1;
}
#sec3 .group {
    position: relative;
    margin-bottom: -8vw;
    padding-top: 6vw;
}
#sec3 .group::after {
    content: "";
    background: url("../img/takeout/sec2_box_bg.jpg") repeat;
    position: absolute;
    top: -2vw;
    left: -10%;
    right: -10%;
    height: 105vw;
    border-radius: 50%;
    z-index: -1;
}
#sec3 .group h2 {
    text-align: center;
    font-size: 12vw;
    line-height: 1.4;
    margin-bottom: 2vw;
    color: #fff;
    letter-spacing: 0.1em;
}
#sec3 .group h2 span {
    font-size: 13.3vw;
    position: relative;
    margin-right: 3%;
    z-index: 0;
}
#sec3 .group h2 span::before {
    content: "";
    background: #a8a8a8;
    position: absolute;
    width: 14vw;
    height: 14vw;
    border-radius: 50%;
    left: -38%;
    top: 18%;
    z-index: -1;
}
#sec3 .group h2 small {
    font-size: 9vw;
}
#sec3 .group .txt {
    color: #fff;
    width: 72%;
    margin: 0 auto 5vw;
    font-size: 13px;
}
#sec3 .photo {
    margin-left: -10%;
    width: 94%;
    position: relative;
    z-index: 6;
    margin-bottom: -13vw;
}
#sec3 .deco {
    position: absolute;
    width: 28%;
    left: -5%;
    top: 59vw;
}
#sec3 .catch {
    position: absolute;
    width: 22%;
    right: 0;
    top: 76vw;
}
#sec3 .box {
    padding: 13% 5% 11%;
    background: url("../img/takeout/sec4_bg.jpg") no-repeat left bottom;
    background-color: #f6f0e1;
    border: 2px solid #000;
    background-size: 100%;
    box-shadow: 0px 7px 14px rgba(0, 0, 0, 0.3);
}
#sec3 .box .row .price {
    text-align: center;
    margin-bottom: 6vw;
}
#sec3 .box .row .price dt {
    font-size: 6.9vw;
    margin-bottom: 2vw;
    position: relative;
    line-height: 1;
}
#sec3 .box .row .price dt span {
    position: relative;
    display: inline-block;
    z-index: 0;
}
#sec3 .box .row .price dt span::after {
    content: "";
    background: #d03030;
    position: absolute;
    bottom: -15%;
    left: 0;
    height: 10px;
    right: 0;
    z-index: -1;
}
#sec3 .box .row .price dt small {
    font-size: 4vw;
}
#sec3 .box .row .price dd {
    font-size: 5vw;
}
#sec3 .box .row .price dd small {
    font-size: 3vw;
}
#sec3 .box .row .right h3 {
    font-size: 3.5vw;
}
#sec3 .box .row .right dl {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #000;
    padding: 5px 0;
}
#sec3 .box .row .right dl dt {
    width: 75%;
}
#sec3 .box .row .right dl dd {
    width: 20%;
    text-align: right;
}

#sec3 .box .row .bnr__shared {}
#sec3 .box .row .bnr__shared a {
        font-size: 14px;
        padding: 15px 0;
}

@media screen and (min-width: 768px) {
    #sec3 {
        padding: 117px 0 154px;
    }
    #sec3::before {
        width: 996px;
        height: 1823px;
        display: none;
    }
    #sec3 .group {
        margin-bottom: -120px;
		padding-top: 0;
    }
    #sec3 .group::after {
        top: -74px;
        width: 740px;
        left: 0;
        right: 0;
        height: 740px;
        margin: 0 auto;
    }
    #sec3 .group h2 {
        font-size: 92px;
        margin-bottom: 20px;
        line-height: 140px;
    }
    #sec3 .group h2 span {
        font-size: 99px;
        margin-left: 50px;
        margin-right: 20px;
    }
    #sec3 .group h2 span::before {
        width: 112px;
        height: 112px;
        left: -36px;
        top: 20px;
    }
    #sec3 .group h2 small {
        font-size: 51px;
    }
    #sec3 .group .txt {
        margin: 0 auto;
        font-size: 16px;
        text-align: center;
        width: 461px;
    }
    #sec3 .photo {
        margin-left: 0;
        margin-bottom: -160px;
        text-align: center;
        width: auto;
    }
    #sec3 .deco {
        width: auto;
        left: -150px;
        top: 77px;
    }
    #sec3 .catch {
        width: auto;
        right: 0;
        top: 220px;
		z-index: 8;
    }
    #sec3 .box {
        padding: 152px 20px 96px;
        box-sizing: border-box;
        margin: 0 48px;
        border-width: 1px;
        background-size: 1103px;
        background-position: right bottom;
    }
    #sec3 .box .row .price {
        margin-bottom: 41px;
        letter-spacing: 2px;
    }
    #sec3 .box .row .price dt {
        font-size: 42px;
        margin-bottom: 36px;
        letter-spacing: 0;
    }
    #sec3 .box .row .price dt small {
        font-size: 27px;
    }
    #sec3 .box .row .price dd {
        font-size: 32px;
    }
    #sec3 .box .row .price dd small {
        font-size: 22px;
    }
    #sec3 .box .row .bnr__shared {
        margin: 0 auto;
    }
	
#sec3 .box .row .bnr__shared a {
    font-size: 22px;
    padding: 21px 0;
}
	
}


/* sec4 */
#sec4 {
    position: relative;
    padding: 15vw 0 7vw;
}
#sec4::before {
    content: "";
    background: url("../img/takeout/sec5_deco1.png") no-repeat center bottom 50%;
    width: 50%;
    position: absolute;
    right: 0;
    bottom: 0;
    background-size: 100%;
    z-index: -1;
    top: 0;
}
#sec4 .group {
    position: relative;
    margin-bottom: 7vw;
	padding-top: 7vw;
}
#sec4 .group::after {
    content: "";
    background: url("../img/takeout/sec2_box_bg.jpg") repeat;
    position: absolute;
    top: 0;
    left: -10%;
    right: -10%;
    height: 105vw;
    border-radius: 50%;
    z-index: -1;
}
#sec4 .group h2 {
    text-align: center;
    font-size: 12vw;
    line-height: 1.4;
    margin-bottom: 2vw;
    color: #fff;
    letter-spacing: 0.1em;
}
#sec4 .group h2 span {
    font-size: 13.3vw;
    position: relative;
    margin-right: 3%;
    z-index: 0;
}
#sec4 .group h2 span::before {
    content: "";
    background: #673f1e;
    position: absolute;
    width: 14vw;
    height: 14vw;
    border-radius: 50%;
    left: -40%;
    top: 18%;
    z-index: -1;
}
#sec4 .group h2 small {
    font-size: 8vw;
}
#sec4 .group .txt {
    color: #fff;
    width: 72%;
    margin: 0 auto -3vw;
    font-size: 13px;
}
#sec4 .photo {
    margin-left: -10%;
    width: 94%;
    position: relative;
    z-index: 5;
    margin-bottom: -13vw;
}
#sec4 .deco {
    position: absolute;
    width: 37%;
    right: -6vw;
    top: 94vw;
}
#sec4 .catch {
    position: absolute;
    width: 28%;
    right: 0;
    top: 74vw;
}
#sec4 .box {
    padding: 11% 5% 8%;
    background: url("../img/takeout/sec5_bg.jpg") no-repeat left bottom;
    background-color: #f6f0e1;
    border: 2px solid #000;
    background-size: 100%;
    margin-bottom: 6vw;
}
#sec4 .box .row .price {
    text-align: center;
    margin-bottom: 6vw;
}
#sec4 .box .row .price dt {
    font-size: 7.9vw;
    margin-bottom: 2vw;
    position: relative;
    line-height: 1;
}
#sec4 .box .row .price dt span {
    position: relative;
    display: inline-block;
    z-index: 0;
}
#sec4 .box .row .price dt span::after {
    content: "";
    background: #d03030;
    position: absolute;
    bottom: -15%;
    left: 0;
    height: 10px;
    right: 0;
    z-index: -1;
}
#sec4 .box .row .price dt small {
    font-size: 4vw;
    position: relative;
    display: inline-block;
    z-index: 0;
}
#sec4 .box .row .price dt small::after {
    content: "";
    background: #d03030;
    position: absolute;
    bottom: -15%;
    left: 0;
    height: 10px;
    right: 0;
    z-index: -1;
}
#sec4 .box .row .price dd {
    font-size: 6vw;
}
#sec4 .box .row .price dd small {
    font-size: 4.5vw;
}
#sec4 .box .row .right dl {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #000;
    padding: 5px 0;
}
#sec4 .box .row .right dl dt {
    width: 75%;
}
#sec4 .box .row .right dl dd {
    width: 20%;
    text-align: right;
}

#sec4 .box .row .bnr__shared a {
    font-size: 14px;
    padding: 15px 0;
}


@media screen and (min-width: 768px) {
    #sec4 {
        padding: 40px 0 91px;
    }
    #sec4::before {
        width: 756px;
        height: 1856px;
        right: 0;
        top: -560px;
    }
    #sec4 .group {
        margin-bottom: 20px;
		padding-top: 0;
    }
    #sec4 .group::after {
        top: -74px;
        width: 740px;
        left: -333px;
        right: 0;
        height: 740px;
        margin: 0 auto;
    }
    #sec4 .group h2 {
        font-size: 92px;
        margin-bottom: 38px;
        line-height: 125px;
        width: 880px;
    }
    #sec4 .group h2 span {
        font-size: 99px;
        margin-left: 27px;
        margin-right: 20px;
    }
    #sec4 .group h2 span::before {
        width: 112px;
        height: 112px;
        left: -30px;
        top: 20px;
    }
    #sec4 .group h2 small {
        font-size: 51px;
    }
    #sec4 .group .txt {
        font-size: 16px;
        text-align: left;
        width: 825px;
        margin-bottom: 93px;
		position: relative;
		z-index: 5;
    }
    #sec4 .photo {
        margin-left: 0;
        margin-bottom: 0;
        position: absolute;
        width: auto;
        top: 240px;
        right: -54px;
    }
    #sec4 .deco {
        right: 20px;
        width: auto;
        top: -50px;
    }
    #sec4 .box {
        margin-bottom: 20px;
        padding: 20px;
        padding: 76px 205px 64px;
        box-sizing: border-box;
        margin: 0 48px 110px;
        border-width: 1px;
        background-size: 758px;
        background-position: right bottom;
        box-shadow: 0px 7px 14px rgba(0, 0, 0, 0.3);
    }
    #sec4 .box .row .price {
        margin-bottom: 35px;
        text-align: left;
    }
    #sec4 .box .row .price dt {
        font-size: 42px;
        margin-bottom: 35px;
    }
    #sec4 .box .row .price dt span::after {
        height: 14px;
    }
    #sec4 .box .row .price dt small {
        font-size: 22px;
    }
    #sec4 .box .row .price dd {
        font-size: 32px;
        letter-spacing: 3px;
    }
    #sec4 .box .row .price dd small {
        font-size: 22px;
    }
    #sec4 .group > .bnr__shared {
        margin: 0 auto;
        width: 460px;
    }
#sec4 .box .row .bnr__shared a {
    font-size: 22px;
    padding: 21px 0;
}

}
@media only screen and (min-width: 768px) and (max-width: 1300px) {
	#sec4 .box{
		padding-left: 100px;
	}
	
}
@media only screen and (min-width: 768px) and (max-width: 1200px) {
	#sec4 .group .txt{
		width: 685px;
		margin-left: 100px;
	}
}
/* sec5 */
#sec5 {
    position: relative;
    background: #f6f0e1;
    padding: 10vw 0 10vw;
}
#sec5 h2 {
    font-size: 6.9vw;
    text-align: center;
    margin-bottom: 5vw;
    position: relative;
    letter-spacing: 0.1em;
}
#sec5 h2::before {
    content: "";
    position: absolute;
    top: 7vw;
    left: 0;
    width: 24%;
    height: 2px;
    background: #000;
}
#sec5 h2::after {
    content: "";
    position: absolute;
    top: 7vw;
    right: 0;
    width: 24%;
    height: 2px;
    background: #000;
}
#sec5 .txt {
    margin-bottom: 12vw;
    text-align: center;
    letter-spacing: 0.1em;
    font-weight: normal;
}
#sec5 .txt span {
    background: #d03030;
    color: #fff;
    padding: 0 2%;
}
#sec5 .box {
    border: 2px solid #000;
    padding: 13% 5%;
    text-align: center;
    margin-bottom: 9vw;
    position: relative;
}
#sec5 .box .txt {
    margin-bottom: 5vw;
}
#sec5 .box.box-tel::before {
    content: "";
    background: url("../img/takeout/sec6_icon1.png") no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
    width: 51px;
    height: 51px;
    position: absolute;
    top: -12%;
    right: 0;
    margin-top: -13px;
    transition: all .4s ease;
    left: 0;
    margin: auto;
}
#sec5 .box.box-tel2::before {
    content: "";
    background: url("../img/takeout/sec6_icon2.png") no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
    width: 51px;
    height: 51px;
    position: absolute;
    top: -2.5%;
    right: 0;
    margin-top: -13px;
    transition: all .4s ease;
    left: 0;
    margin: auto;
}
#sec5 .box .tel dt {
    font-size: 3.5vw;
    line-height: 1.5;
}
#sec5 .box .tel dt .tel-icon {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    font-weight: bold;
    font-size: 9vw;
}


#sec5 .box .tel dt a:hover img {
	opacity: 1;
}
#sec5 .box .tel dt .tel-icon span {
    width: 9%;
    margin-top: 0%;
}
#sec5 .box .tel dd {
    font-size: 12px;
}
#sec5 .box .bnr__shared {
    margin-bottom: 7vw;
}
#sec5 .box h3 {
    font-weight: bold;
    text-align: center;
    margin-bottom: 7vw;
    font-size: 5vw;
    position: relative;
}
#sec5 .box h3::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    width: 40%;
    height: 2px;
    background: #000;
    bottom: 0;
    margin: 0 auto;
}
#sec5 .box .flow {
    flex-direction: column;
}
#sec5 .box .flow .step {
    margin-bottom: 6vw;
    border: 2px solid;
    padding: 8% 5%;
    text-align: center;
    box-sizing: border-box;
    position: relative;
}
#sec5 .box .flow .step h4 {
    font-size: 5vw;
    text-align: center;
    position: relative;
    margin-bottom: 6vw;
    font-weight: bold;
}
#sec5 .box .flow .step h4::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    width: 40%;
    height: 2px;
    background: #000;
    bottom: 0;
    margin: 0 auto;
}
#sec5 .box .flow .step .txt2 {
    text-align: center;
    margin-bottom: 5vw;
}
#sec5 .box .flow .step .txt2 span {
    font-weight: bold;
    font-size: 18px;
    position: relative;
	z-index: 0;
}
#sec5 .box .flow .step .txt2 span::after {
    content: "";
    background: #d03030;
    position: absolute;
    bottom: -15%;
    left: 0;
    height: 10px;
    right: 0;
    z-index: -1;
}
#sec5 .box .flow .step .txt3 {
    text-align: left;
}
#sec5 .box .flow .step .img2 {
    position: absolute;
    bottom: 0;
    right: 0;
}
#sec5 .box .flow .step:nth-child(3) {
    padding-bottom: 0;
}
#sec5 .box .slick-dots {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
}
#sec5 .box .slick-dots li {
    margin: 0 10px;
}
@media screen and (min-width: 768px) {
    #sec5 {
        padding: 173px 0 96px;
    }
    #sec5 h2 {
        font-size: 52px;
        margin-bottom: 72px;
    }
    #sec5 h2::before {
        top: 20px;
        height: 5px;
        left: 100px;
        width: 320px;
    }
    #sec5 h2::after {
        height: 5px;
        right: 100px;
        width: 320px;
        top: 20px;
    }
    #sec5 .txt {
        margin-bottom: 157px;
        font-size: 22px;
        letter-spacing: 0px;
    }
    #sec5 .txt span {
        padding: 2px 8px;
    }
    #sec5 .box {

        margin-bottom: 20px;
        border-width: 3px;
        width: 1000px;
        margin: 0 auto 139px;
        padding: 98px 38px 77px;
        box-sizing: border-box;
    }
    #sec5 .box + .box {
        padding-bottom: 37px;
        margin-bottom: 71px;
    }
    #sec5 .box .txt {
        margin-bottom: 43px;
        letter-spacing: 2px;
    }
    #sec5 .box.box-tel::before {
        width: 101px;
        height: 101px;
        top: -53px;
    }
    #sec5 .box.box-tel2::before {
        width: 101px;
        height: 101px;
        top: -50px;
    }
    #sec5 .box .tel {
        letter-spacing: 4px;
    }
    #sec5 .box .tel dt {
        font-size: 22px;
    }
    #sec5 .box .tel dt .tel-icon {
        font-size: 53px;
        margin-top: 12px;
        letter-spacing: 2px;
    }
    #sec5 .box .tel dt .tel-icon span {
        width: 47px;
        margin-left: 2px;
        margin-right: -3px;
        margin-top: -3px;
    }
    #sec5 .box .tel dd {
        font-size: 16px;
        letter-spacing: 0.5px;
    }
    #sec5 .box .bnr__shared {
        margin: 0 auto 87px;
        width: 390px;
    }
    #sec5 .box .bnr__shared a {
        font-size: 17px;
        letter-spacing: 0px;
                padding: 17px 0;
        font-weight: 600;
    }
    #sec5 .box h3 {
        margin-bottom: 41px;
        font-size: 30px;
        padding-bottom: 11px;
        letter-spacing: 3px;
    }
    #sec5 .box h3::after {
        width: 131px;
    }
    #sec5 .box .flow {
        flex-direction: row;
        justify-content: space-between;
    }
    #sec5 .box .flow .step {
        margin-bottom: 20px;
        box-sizing: border-box;
        width: 288px;
        padding: 32px 10px;
        min-height: 634px;
    }
    #sec5 .box .flow .step h4 {
        font-size: 30px;
        margin-bottom: 30px;
        letter-spacing: 2px;
        padding-bottom: 10px;
    }
    #sec5 .box .flow .step h4::after {
        width: 105px;
        height: 3px;
    }
    #sec5 .box .flow .step .txt2 {
        margin-bottom: 30px;
        font-size: 20px;
		letter-spacing: 0.01em;
    }
    #sec5 .box .flow .step .txt2 span {
        font-size: 20px;
    }
    #sec5 .box .flow .step .txt3 {
        font-size: 20px;
        padding: 0 13px 0 12px;
        line-height: 39px;
        position: relative;
        z-index: 5;
    }
    #sec5 .wrap > .bnr__shared {
        margin: 0 auto;
        width: 389px;
    }
    #sec5 .wrap > .bnr__shared a {
        font-size: 17px;
        letter-spacing: 0.1em;
        font-weight: 600;
        margin: 0 auto;
                padding: 16px 0;
    }
}
@media only screen and (min-width: 768px) and (max-width: 1300px) {
	#sec5 h2::before,#sec5 h2::after{
		max-width: 25%;
	}
}


/* sec6 */
#sec6 {
    position: relative;
    padding: 15vw 0 29vw;
	z-index: 2;
}
#sec6 .box {
    position: relative;
    padding: 9% 5% 6%;
    background: url("../img/takeout/sec5_box_deco1.jpg"), url("../img/takeout/sec5_box_deco2.jpg");
    background-position: left top, right bottom;
    background-size: 25%, 25%;
    background-repeat: no-repeat, no-repeat;
    background-color: #f6f0e1;
    box-shadow: 3px 5px 16px rgba(0, 0, 0, 0.3);
    border: 1px solid;
}
#sec6 .box h2 {
    font-size: 5.5vw;
    text-align: center;
    margin-bottom: 6vw;
    position: relative;
}
#sec6 .box h2::before {
    content: "";
    width: 2px;
    height: 40px;
    display: inline-block;
    transform: rotate(-30deg);
    background: #000;
    position: absolute;
    top: 2vw;
    left: -2%;
}
#sec6 .box h2::after {
    content: "";
    width: 2px;
    height: 40px;
    display: inline-block;
    transform: rotate(30deg);
    background: #000;
    position: absolute;
    top: 2vw;
    right: -2%;
}
#sec6 .box .g-btn {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
}
#sec6 .box .g-btn .btn {
    margin-bottom: 4vw;
    width: 48%;
}
@media screen and (min-width: 768px) {
    #sec6 {
        padding: 80px 0 198px;
    }
    #sec6 .box {
        padding: 98px 98px 114px;
        box-sizing: border-box;
        width: 1103px;
        margin: 0 auto 0;
        background-size: auto, auto;
        background-position: left top, right -2px bottom -8px;
    }
    #sec6 .box h2 {
        font-size: 42px;
        margin-bottom: 83px;
    }
    #sec6 .box h2::before {
        left: 137px;
        top: 0px;
        height: 63px;
    }
    #sec6 .box h2::after {
        right: 148px;
        top: 0px;
        height: 63px;
    }
    #sec6 .box .g-btn {
        margin: 0 120px;
    }
    #sec6 .box .g-btn .btn {
        margin-bottom: 20px;
        width: auto;
    }
}

.btn-fixed {
    position: fixed;
    right: 0;
    top: 200px;
    z-index: 10;
    opacity: 0;
    visibility: hidden;
}
.fixed-btn .btn-fixed {
    opacity: 1;
    visibility: visible;
}
.popup-menu .popup {
    padding-top: 20px;
}
.popup-menu h2 {
    font-size: 6vw;
    position: relative;
}
.popup-menu h2::before {
    content: "";
    position: absolute;
    top: 33%;
    width: 2px;
    height: 30px;
    background: #fff;
    display: inline-block;
    transform: rotate(-45deg);
    left: 2%;
}
.popup-menu h2::after {
    content: "";
    position: absolute;
    top: 33%;
    width: 2px;
    height: 30px;
    background: #fff;
    display: inline-block;
    transform: rotate(45deg);
    right: 2%;
}
.popup-menu .flow2 {
    flex-direction: column;
}
.popup-menu .step {
    margin-bottom: 6vw;
    border: 2px solid;
    padding: 8% 2%;
    text-align: center;
    box-sizing: border-box;
    position: relative;
    height: auto !important;
}
.popup-menu .step h4 {
    font-size: 5vw;
    text-align: center;
    position: relative;
    margin-bottom: 6vw;
    font-weight: bold;
}
.popup-menu .step h4::after {
    content: "";
    position: absolute;
    left: 0;
    width: 25%;
    height: 3px;
    background: #fff;
    bottom: 0;
    margin: 0 auto;
    right: 0;
}
.popup-menu .flow2 .step .txt2 {
    text-align: center;
    margin-bottom: 5vw;
}
.popup-menu .flow2 .step .btn {
	max-width: 240px;
	margin-left: auto;
	margin-right: auto;
}
.popup-menu .flow2 .step .txt3 {
    text-align: left;
}
.popup-menu .flow2 .step .txt2 span {
    font-weight: bold;
    font-size: 18px;
    position: relative;
    z-index: 0;
}
.popup-menu .flow2 .step .txt2 span::after {
    content: "";
    background: #d03030;
    position: absolute;
    bottom: -15%;
    left: 0;
    height: 10px;
    right: 0;
    z-index: -1;
}
.popup-menu .flow2 .txt3 {
    text-align: left;
}
.popup-menu .flow2:nth-child(3) {
    padding-bottom: 0;
}
@media only screen and (min-width: 768px) {
    .remodal-close {
        top: -20px;
    }
    .popup-menu .popup {
        padding-top: 20px !important;
    }
    .popup-menu h2 {
        font-size: 32px;
        margin-bottom: 65px;
    }
    .popup-menu h2::before {
        height: 60px;
        left: 390px;
        top: -2px;
    }
    .popup-menu h2::after {
        height: 60px;
        right: 390px;
        top: -2px;
    }
    .popup-menu .flow2 {
        flex-direction: row;
        justify-content: center;
        margin-bottom: 44px;
    }
    .popup-menu .step {
        padding: 30px 0 0;
        margin: 0 20px;
        width: 280px;
        box-sizing: border-box;
    }
    .popup-menu .flow2 + .step {
        width: 922px;
        margin: 0 auto;
        padding-bottom: 20px;
		        margin-bottom: 40px;
    }
    .popup-menu .flow2 + .step h4 {
        text-align: left;
        margin-left: 27px;
    }
    .popup-menu .flow2 + .step h4::after {
        right: auto;
    }
    .popup-menu .flow2 + .step .txt3 {
        text-align: left;
        margin-left: 40px;
        width: 671px;
    }
    .popup-menu .flow2 .step .btn {
        margin-top: 90px;
    }
    .popup-menu .step h4 {
        font-size: 32px;
        margin-bottom: 30px;
    }
    .popup-menu .step h4::after {
        width: 110px;
        bottom: -6px;
    }
    .popup-menu .flow2 .step .txt2 {
        margin-bottom: 11px;
    }
}

