html{
    scroll-padding: 100px;
}
body{
    width: 100%;
}
img{
    max-width: 100%;
}
a{
    text-decoration: none;
}
/* トップ------------------------- */
.top{
    width: 100%;
}
.top-bg{
    background-image: url(../img/lp/top-bg.png);
    background-size: 100%;
    background-repeat: no-repeat;
    width: 100%;
    aspect-ratio: 2160/960;
}
.logo{
    text-align: right;
    padding: 30px 50px;
}
.top-title{
    margin-top: 100px;
    text-align: center;
}
.top-title h3{
    font-size: 28px;
    letter-spacing: 2px;
    margin-bottom: 20px;
}
.top-title h2{
    font-size: 38px;
    letter-spacing: 2px;
}
.top-point{
    padding: 80px 300px 150px;
    display: flex;
    justify-content: space-around;
}
.point-item{
    background-image: url(../img/lp/Polygon.png);
    background-size: 100%;
    background-repeat: no-repeat;
    width: 350px;
    aspect-ratio: 328/274;
    text-align: center;
    display: grid;
	place-items: center center;
    font-size: 30px;
}
/* 各セクション部分----------------- */
.section-container{
    width: 100%;
}
.section-wrapper{
    width: 1200px;
    margin: 0 auto;
}
/* ３つのポイント------------------------ */
#point .section-container{
    background-image: url(../img/lp/section1-bg.png);
    background-size: 100%;
}
#point .section-wrapper{
    padding-top: 100px;
    padding-bottom: 50px;
}
.point-box{
    display: flex;
    justify-content: space-between;
    margin-bottom: 150px;
}
.point-img{
    width: 550px;
    position: relative;
}
.point-img-1{
    width: 500px;
    /* height: 309px; */
    aspect-ratio: 460/310;
    position: absolute;
    top: 10px;
    left: 20px;
}
.img1-a{
    background-color: #D974C2;
}
.point-img-2{
    width: 500px;
    aspect-ratio: 460/310;
    position: absolute;
    top: 0;
    left: 0;
}
.point-img-2 img{
    width: 100%;
}
.point-content{
    width: 600px;
}
.point-title{
    text-align: center;
    font-size: 28px;
    font-weight: bold;
    padding-top: 80px;
    line-height: 1.5;
}
.p-title_a{
    color: #D02B66;
}
.point-text{
    padding: 50px 0;
    font-size: 20px;
    line-height: 1.5;
}
.pb-2{
    flex-direction: row-reverse;
}
.img1-b{
    background-color: #72CEEB;
    position: absolute;
    top: 10px;
    left: 0px;
}
.img2-b{
    position: absolute;
    top: 0;
    left: 20px;
}
.p-title_b{
    color: #239FC7;
}
.img1-c{
    background-color: #92E9AB;
    position: absolute;
    top: 30px;
    left: 20px;
}
.p-title_c{
    color: #28BF52;
}
/* 徹底サポート------------------------ */
#support .section-wrapper{
    padding: 100px 0;
    text-align: center;
}
.support-text{
    font-size: 18px;
    font-weight: bold;
}
.support-text .br-sp,
.support-title .br-sp{
    display: none;
}
.support-title{
    padding: 50px 0 100px;
    font-size: 32px;
    font-weight: bold;
    color: #C01653;
}
/* 成婚までのフロー------------------------ */
#flow .section-container{
    width: 100%;
    background-color: #fccde9;
}
#flow .section-wrapper{
    padding: 100px 0;
}
.flow-title{
    font-size: 48px;
    font-weight: bold;
    color: #FFFFFF;
    text-align: center;
}
.flow-content{
    width: 100%;
    padding-top: 100px;
}
.flow-item{
    display: flex;
    justify-content: space-between;
    padding-bottom: 50px;
    align-items: center;
}
.step{
    background-image: url(../img/lp/flow-step.png);
    background-size: 100%;
    background-repeat: no-repeat;
    width: 150px;
    aspect-ratio: 114/100;
    text-align: center;
    display: grid;
	place-items: center center;
}
.step p{
    font-size: 30px;
    color: #D974C2;
}
.step p span{
    font-size: 42px;
    font-weight: bold;
}
.step-text{
    width: 1000px;
    font-size: 30px;
    font-weight: bold;
    color: #D974C2;
    /* padding: 45px 0; */
    line-height: 1.5;
    vertical-align: middle;
}
.flow-text{
    margin-top: 100px;
    background-color: #FFFFFF;
    padding: 20px 30px;
    color: #000000;
    font-size: 20px;
    line-height: 1.7;
}
/* FAQ
--------------------------------------- */
#faq .section-wrapper{
    margin-top: 200px;
    padding: 50px;
    display: flex;
    justify-content: space-between;
    color: #f1a2b7;
}
#faq .section-title h2{
    font-size: 65px;
    font-family: 'Castoro Titling';
    letter-spacing: 10px;
    color:  #f1a2b7;
}
.section-title p{
    font-size: 20px;
    line-height: 1.7;
    margin-bottom: 20px;
}
#faq .br-sp{
    display: none;
}
.faq-wrapper{
    width: 840px;
    position: relative;
}
.faq-wrapper ul li{
    border-bottom: 1px solid #f1a2b7;
    padding: 20px 20px 15px 30px;
}
.faq-wrapper ul li:first-child{
    border-top: 3px solid #f1a2b7;
}
.faq-q{
    display: flex;
    cursor: pointer;
    font-family: 'Zen Maru Gothic';
}
.faq-q h3{
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 2px;
    line-height: 1.7;
}
.question{
    margin-right: 50px;
    font-family: 'Castoro Titling';
    font-size: 38px;
    
}
.slidedown{
    display: none;
}
.faq-a{
    width: 100%;
    margin-top: 30px;
    display: flex;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 2px;
    line-height: 1.7;
    font-family: 'Zen Maru Gothic';
}
.anser{
    margin-right: 50px;
    font-family: 'Castoro Titling';
    font-size: 38px;
    color: #ef5880;
}
.faq-balloon{
    position: absolute;
    top: -130px;
    left: -390px;
}
.faq-a span{
    color: #ef5880;
    font-weight: bold;
}
.faq-heart{
    position: absolute;
    top: -160px;
    right: 60px;
}
.faq-heart img{
    width: 90%;
}
/* CONTACT US
--------------------------------- */
#contact-us .section-wrapper{
    justify-content: space-between;
    color: #f1a2b7;
    display: block;
    margin-top: 50px;
    margin-bottom: 100px;
}
#contact-us .section-title h2{
    font-size: 65px;
    font-family: 'Castoro Titling';
    letter-spacing: 5px;
    color:  #f1a2b7;
}
#contact-us .section-title p{
    margin-bottom: 20px;
}
.contact-us-wrapper{
    display: flex;
    justify-content: space-between;
    margin-top: 50px;
}
.contact-us-item{
    width: 550px;
}
.map{
    width: 100%;
}
.map-top{
    width: 100%;
    height: auto;
    aspect-ratio: 550/550;
}
.map-sp{
    display: none;
}
iframe{
    width: 100%;
    height: auto;
    aspect-ratio: 1200/800;
}
.infomation{
    margin-top: 30px;
    font-size: 20px;
    line-height: 1.7;
}
.infomation .br-sp{
    display: none;
}
.contact-line-title{
    background: linear-gradient(transparent 70%, #FFBCC5 40%);
}
.line-title-wrapper{
    width: 470px;
    margin: 0 auto;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding-bottom: 15px;
}
.line-icon{
    width: 80px;
}
.contact-line-text{
    font-size: 30px;
    font-weight: bold;
    color: #292929;
    font-family: 'Zen Maru Gothic';
}
.contact-line-text span{
    font-size: 40px;
    color: #06C755;
    padding: 0 10px;
}
.line-qr{
    width: 150px;
    margin: 30px auto 50px;
}
.line-qr-sp{
    display: none;
}
.line-qr img{
    width: 100%;
}
.line-qr-title{
    font-size: 20px;
    font-weight: bold;
    color: #000000;
    line-height: 1.5;
    font-family: 'Zen Maru Gothic';
}
.line-qr-text{
    margin: 30px 0;
    color: #000000;
    line-height: 1.5;
}
.line-qr-text-sp{
    display: none;
}
/* BACK TO PAGE TOP
------------------------ */
.btn-container{
    width: 100%;
}
.back-btn{
    width: 300px;
    margin: 0 0 0 auto;
    padding: 10px 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #ef5880;
    color: #fff;
    font-weight: bold;
    cursor: pointer;
}
/* FOOTER
--------------------------------------- */
footer{
    max-width: 100%;
    width: 1920px;
    padding-top: 20px;
    background-color: #f1a2b7;
    color: #fff;
}
.footer-container{
    width: 100%;
    padding-bottom: 40px;
}
.footer-wrapper{
    width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-around;
}
.footer-logo-pc{
    width: 250px;
    padding-top: 20px;
}
.footer-logo-pc img{
    width: 100%;
}
.footer-imfomation{
    font-size: 20px;
    letter-spacing: 1px;
    line-height: 1.7;
}
.footer-imfomation .br-sp{
    display: none;
}
.copy{
    width: 100%;
    padding: 20px 0;
    text-align: center;
    background-color: #ef5880;
}
.br-gara{
    display: none;
}

.video {
    width: 800px;
    margin: 30px auto;
    max-width: 100%;
}
@media screen and (max-width: 1700px){
    .point-item{
        width: 30%;
    }
}
@media screen and (max-width: 1400px){
    .section-wrapper{
        width: 80%;
    }
    .top-point{
        padding: 80px 200px 150px;
    }
    .point-item{
        font-size: 24px;
    }
    .point-img{
        width: 43%;
    }
    .point-img-1{
        width: 97%;
        position: absolute;
        top: 3%;
        left: 2%;
    }
    .point-img-2{
        width: 96%;
    }
    .point-content{
        width: 50%;
    }
    .img1-b{
        position: absolute;
        top: 3%;
        left: 0;
    }
    .img2-b{
        position: absolute;
        top: 0;
        left: 3%;
    }
    .img1-c{
        position: absolute;
        top: 9%;
        left: 2%;
    }
    .step{
        width: 15%;
    }
    .step-text{
        width: 80%;
    }
    .faq-wrapper{
        width: 75%;
    }
    .faq-wrapper ul li {
        padding: 20px;
    }
    #faq .br-sp{
        display: block;
    }
    .faq-balloon{
        position: absolute;
        top: -100px;
        left: -300px;
    }
    .faq-balloon img{
        width: 80%;
    }
    .faq-heart{
        position: absolute;
        top: -150px;
        right: 0;
    }
    .faq-heart img{
        width: 80%;
    }
    .faq-q h3{
        font-size: 18px;
    }
    .question{
        margin-right: 40px;
    }
    .anser{
        margin-right: 40px;
    }
    .faq-a{
        font-size: 15px;
    }
    .contact-us-item{
        width: 45%;
    }
    .infomation{
        font-size: 18px;
    }
    .line-title-wrapper{
        width: 90%;
    }
    .line-icon{
        width: 20%;
    }
    .contact-line-text{
        font-size: 24px;
    }
    .contact-line-text span{
        font-size: 32px;
    }
    .line-qr{
        width: 30%;
    }
    footer{
        width: 100%;
    }
    .footer-wrapper{
        width: 70%;
    }
    .footer-logo-pc{
        width: 30%;
    }
    .infomation .br-sp{
        display: block;
    }
    .footer-imfomation .br-sp{
        display: block;
    }
}
@media screen and (max-width: 1200px){
    .logo img{
        width: 17%;
    }
    .point-box{
        margin-bottom: 100px;
    }
    .point-title{
        padding-top: 40px;
        font-size: 24px;
    }
    .point-text{
        font-size: 18px;
        padding: 40px 0 20px;
    }
    #faq .section-title h2{
        font-size: 50px;
    }
    .step-text{
        font-size: 26px;
    }
    .faq-balloon{
        position: absolute;
        top: -80px;
        left: -230px;
    }
    .faq-balloon img{
        width: 65%;
    }
    .faq-heart{
        position: absolute;
        top: -130px;
        right: 0;
    }
    .faq-heart img{
        width: 70%;
    }
    .faq-q h3{
        font-size: 17px;
    }
    .faq-a{
        font-size: 14px;
    }
    #contact-us .section-title h2{
        font-size: 50px;
        letter-spacing: 3px;
    }
    .infomation .br-sp{
        display: block;
    }
    .line-icon{
        width: 15%;
    } 
    .contact-line-text{
        font-size: 22px;
    }
    .line-qr-title{
        font-size: 18px;
    }
    .line-qr-text{
        font-size: 15px;
    }
}
@media screen and (max-width: 980px){
    .section-wrapper{
        width: 90%;
    }
    .top-title h3{
        font-size: 24px;
    }
    .top-title h2{
        font-size: 34px;
    }
    .top-point{
        padding: 50px 150px 100px;
    }
    .point-item{
        font-size: 18px;
        font-weight: bold;
    }
    .point-img{
        width: 40%;
    }
    .point-content{
        width: 55%;
    }
    .point-title{
        padding-top: 20px;
    }
    .point-text{
        font-size: 15px;
        padding: 40px 0 20px;
    }
    .support-text{
        font-size: 15px;
    }
    .flow-title{
        font-size: 40px;
    }
    .step p{
        font-size: 26px;
    }
    .step p span{
        font-size: 38px;
    }
    .step-text{
        font-size: 24px;
    }
    .flow-text{
        margin-top: 50px;
        font-size: 18px;
    }
    #faq .section-wrapper{
        padding: 0 0 50px;
    }
    .faq-balloon{
        position: absolute;
        top: -80px;
        left: -180px;
    }
    .faq-q h3{
        font-size: 16px;
    }
    .faq-a{
        font-size: 13px;
    }
    .contact-line-text span{
        font-size: 30px;
    }
    .footer-imfomation{
        font-size: 18px;
    }
}
@media screen and (max-width: 780px){
    .top-title h3{
        font-size: 22px;
    }
    .top-title h2{
        font-size: 30px;
    }
    .top-point{
        padding: 50px 80px 80px;
    }
    .point-item{
        font-size: 16px;
    }
    .point-box{
        display: flex;
        flex-direction: column-reverse;
        margin-bottom: 200px;
    }
    .point-content{
        width: 100%;
    }
    .point-title{
        padding-top: 0;
        font-size: 26px;
    }
    .point-text{
        padding: 20px 0;
        font-size: 18px;
    }
    .point-img{
        width: 85%;
        height: 200px;
        margin: 0 auto;
        position: relative;
    }
    .point-img-1{
        width: 85%;
        position: absolute;
        top: 10%;
        left: 10%;
    }
    .point-img-2{
        width: 85%;
        position: absolute;
        left: 5%;
    }
    .img1-b{
        position: absolute;
        top: 10%;
        left: 0;
    }
    .img2-b{
        position: absolute;
        top: 0;
        left: 5%;
    }
    .img1-c{
        position: absolute;
        top: 15%;
        left: 10%;
    }
    .support-text{
        font-size: 16px;
    }
    .support-text .br-sp,
    .support-title .br-sp{
    display: block;
    }
    .flow-title{
        font-size: 38px;
    }
    .step p{
        font-size: 22px;
    }
    .step p span{
        font-size: 30px;
    }
    .step-text{
        font-size: 22px;
    }
    .flow-text{
        margin-top: 30px;
        font-size: 17px;
    }
    #faq .section-wrapper{
        margin-top: 150px;
        padding: 10px;
        display: block;
    }
    .faq-wrapper{
        width: 100%;
    }
    #faq .section-title p{
        font-size: 18px;
    }
    #faq .br-sp{
        display: none;
    }
    .faq-balloon{
        position: absolute;
        top: -230px;
        left: 10px;
    }
    .faq-balloon img{
        width: 100%;
    }
    .faq-heart{
        width: 25%;
        position: absolute;
        top: -170px;
        right: -20px;
    }
    .faq-heart img{
        width: 90%;
    }
    #contact-us .section-wrapper{
        padding: 10px;
    }
    .contact-us-wrapper{
        display: block;
    }
    #contact-us .section-title p{
        font-size: 18px;
    }
    .contact-us-item{
        width: 100%;
    }
    .infomation{
        font-size: 18px;
        margin-bottom: 50px;
    }
    .infomation .br-sp{
        display: none;
    }
    .contact-line-title{
        background: linear-gradient(transparent 75%, #FFBCC5 40%);
    }
    .line-title-wrapper{
        width: 80%;
        padding-bottom: 15px;
    }
    .line-icon{
        width: 20%;
    }
    .contact-line-text{
        font-size: 26px;
    }
    .contact-line-text span{
        font-size: 40px;
        padding: 0 10px;
    }
    .line-qr{
        display: none;
    }
    .line-qr-sp{
        display: block;
        width: 40%;
        margin: 50px auto 80px
    }
    .line-qr-title{
        font-size: 20px;
    }
    .line-qr-text{
        display: none;
    }
    .line-qr-text-sp{
        display: block;
        font-size: 16px;
    }
    .footer-container{
        padding-bottom: 30px;
    }
    .footer-wrapper{
        display: block;
        width: 100%;
        padding: 10px 50px;
    }
    
    .footer-logo-pc{
        display: block;
        margin-bottom: 30px;
    }
    .footer-logo-pc,
    .footer-imfomation{
        width: 100%;
    }
    .footer-logo-pc img{
        width: 50%;
    }
    .footer-imfomation{
        font-size: 18px;
    }
    .footer-imfomation .br-sp{
        display: none;
    }
}
@media screen and (max-width: 600px){
    .logo{
        padding: 20px 30px;
    }
    .point-box{
        margin-bottom: 150px;
    }
    .flow-content{
        padding-top: 80px;
    }
    .flow-title{
        font-size: 34px;
    }
    .step p{
        font-size: 18px;
    }
    .step p span{
        font-size: 28px;
    }
    .step-text{
        font-size: 20px;
    }
    .flow-text{
        padding: 20px;
        font-size: 16px;
    }
    #faq .section-title h2,
    #contact-us .section-title h2{
        font-size: 40px;
    }
    .faq-balloon{
        position: absolute;
        top: -240px;
        left: 10px;
    }
    .faq-heart{
        width: 30%;
        position: absolute;
        top: -130px;
        right: -20px;
    }
    .faq-heart img{
        width: 80%;
    }
    .map{
        display: none;
    }
    .map-sp{
        display: block;
    }
    .map-sp iframe{
        width: 100%;
        aspect-ratio: 400/300;
    }
    .infomation{
        font-size: 18px;
    }
    .form-item h3{
        font-size: 18px;
    }
    
    .line-title-wrapper{
        width: 88%;
        padding-bottom: 10px;
    }
    .line-icon{
        width: 18%;
    }
    .back-btn{
        width: 100%;
    }
    .footer-imfomation{
        font-size: 18px;
    }
    .footer-logo-pc img{
        width: 60%;
    }
    .footer-imfomation .br-sp{
        display: block;
    }
}
@media screen and (max-width: 420px){
    .logo{
        padding: 20px;
    }
    .top-title{
        margin-top: 50px;
    }
    .top-title h3{
        font-size: 20px;
    }
    .top-title h2{
        font-size: 24px;
        font-weight: bold;
    }
    .top-point{
        padding: 50px 20px;
    }
    .point-item{
        font-size: 12px;
    }
    #point .section-wrapper{
        padding-bottom: 20px;
    }
    .point-box{
        margin-bottom: 80px;
    }
    .point-text{
        font-size: 16px;
    }
    .support-text .br-sp{
        display: none;
    }
    .support-text{
        text-align: left;
        font-size: 15px;
    }
    .support-title{
        padding: 50px 0 80px;
        font-size: 24px;
    }
    .flow-title{
        font-size: 30px;
        letter-spacing: 2px;
    }
    .flow-content{
        padding-top: 50px;
    }
    .step{
        width: 25%;
    }
    .step-text{
        width: 70%;
        font-size: 16px;
    }
    .flow-text{
        margin-top: 0;
        font-size: 15px;
    }
    #faq .section-wrapper {
        margin-top: 200px;
        margin-bottom: 80px;
    }
    #faq .section-title h2,
    #contact-us .section-title h2{
        font-size: 32px;
    }
    #faq .section-title p,
    #contact-us .section-title p{
        font-size: 16px;
    }
    .infomation{
        font-size: 16px;
    }
    .contact-line-title{
        background: linear-gradient(transparent 70%, #FFBCC5 40%);
    }
    .line-title-wrapper{
        width: 95%;
    }
    .line-icon{
        width: 14%;
    }
    .contact-line-text{
        font-size: 19px;
    }
    .contact-line-text span{
        font-size: 23px;
    }
    .line-qr-sp{
        width: 50%;
    }
    .line-qr-title{
        font-size: 18px;
    }
    .line-qr-text-sp{
        font-size: 14px;
    }
}
@media screen and (max-width: 280px){
    .logo{
        padding: 15px;
    }
    .top-title h3{
        font-size: 15px;
    }
    .top-title h2{
        font-size: 18px;
    }
    .top-point{
        padding: 50px 10px;
    }
    .point-item{
        font-size: 10px;
    }
    #point .section-wrapper{
        padding-top: 80px;
    }
    .point-box{
        margin-bottom: 0px;
    }
    .point-title{
        font-size: 22px;
    }
    .point-text{
        font-size: 14px;
    }
    .point-img-1{
        top: 9%;
        left: 12%;
    }
    .img1-b{
        top: 10%;
        left: 0;
    }
    .img2-b{
        top: 3%;
        left: 7%;
    }
    #support .section-wrapper,
    #flow .section-wrapper{
        padding: 70px 0;
    }
    .support-text{
        font-size: 14px;
    }
    .support-title{
        padding: 50px 0;
        font-size: 22px;
    }
    .flow-title{
        font-size: 26px;
    }
    .step{
        width: 27%;
    }
    .step p{
        font-size: 16px;
    }
    .step p span{
        font-size: 24px;
    }
    .step-text{
        width: 68%;
        font-size: 14px;
    }
    .flow-text{
        padding: 15px;
        font-size: 14px;
    }
    .line-title-wrapper{
        padding-bottom: 5px;
    }
    .line-icon{
        width: 11%;
    }
    .contact-line-text{
        font-size: 15px;
    }
    .contact-line-text span{
        font-size: 18px;
        padding: 0 3px;
    }
    .line-qr-sp{
        width: 55%;
        margin: 30px auto;
    }
    .line-qr-title{
        font-size: 15px;
    } 
    .line-qr-text-sp{
        font-size: 13px;
        line-height: 1.4;
    }
    .footer-wrapper{
        padding: 10px 20px;
    }
    .footer-imfomation{
        font-size: 15px;
    } 
}