:root{
  --main: #ED7579;       /* 強調色*/
  --text: #343652;
}



/*-----------------------------------------------
共通
----------------------------------------------- */

html,body{
    margin: 0;
    font-family: "Montserrat","Noto Sans JP", sans-serif;
    color: var(--text);
    overflow-x: hidden;
    line-height: 1.6;
}
figure{
    margin: 0;
}
img{
    width: 100%;
    height: auto;
    display: block;
}
h2,h3{
    line-height: 1.6;
    letter-spacing: 1.2px;
    font-weight: 600;
}
p,li{
    line-height: 2;
    font-weight: 500;
    font-size: 15px;
    letter-spacing: 0.05em;
}
.wrapper{
    width: 100%;
    max-width: 1140px;
    margin: 0 auto;
}
.sp{
    display: none;
}
.pc{
    display: block;
}
@media only screen and (max-width:768px){

}

@media only screen and (max-width:540px){
    .sp{
        display: block;
    }
    .pc{
        display: none;
    }
}




/*-----------------------------------------------
title
----------------------------------------------- */
.title-box{
    text-align: center;
    z-index: 10;
    position: relative;
}
.title-box .subtitle{
    color: var(--main);
    font-size: 22px;
    font-weight: 500;
    line-height: 140%;
    letter-spacing: 1.1px;
    padding-bottom: 10px;
}
.title-box .title{
    color: var(--text);
    font-size: 40px;
    line-height: 140%;
    letter-spacing: 2px;
}
@media only screen and (max-width:540px){
    .title-box{
        text-align: center;
        z-index: 10;
        position: relative;
    }
    .title-box .subtitle{
        font-size: 18px;
    }
    .title-box .title{
        font-size: 27px;
    }
}
/*-----------------------------------------------
btn
----------------------------------------------- */

.cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    height: 64px;
    min-width: 240px;
    width: 80%;
    padding: 0 28px;
    border-radius: 9999px;
    background: #f08e91;
    color: #fff;
    font-weight: 700;
    line-height: 1;
    box-shadow: 0 16px 56px 0 rgba(237, 117, 121, 0.25);
    transition: background-color 0.45s ease, box-shadow 0.45s ease, transform 0.45s ease;
    -webkit-tap-highlight-color: transparent;
}

.cta-icon {
    display: inline-flex;
    transition: transform 0.45s ease;
}

.cta-btn:hover {
    box-shadow: none;
    background: #e06569;
}

.cta-btn:hover .cta-icon {
    transform: translateX(6px);
}

.cta-btn:active {
    transform: translateY(1px);
}

.cta-btn:focus-visible {
    outline: 3px solid rgba(237, 117, 121, 0.45);
    outline-offset: 3px;
    box-shadow: none;
}

@media only screen and (max-width:540px){
    .cta-btn {
        background: #e06569;
        font-size: 15px;
        height: 64px;
        max-width: 270px;
        width: 100%;
        padding: 0 28px;
    }
}
.fixed{
	position: fixed;
    bottom: 40px;
    right: 40px;
	z-index: 100;
	
}
.pc-btn .cta-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    width: 160px;
    height: 160px;
    min-width: initial;
    padding: 0;
    border-radius: 50%;

    background-color: var(--main);
    color: #fff;
    font-weight: 600;
    text-align: center;
    box-shadow: 0 16px 56px 0 rgba(237, 117, 121, 0.25);
    transition: background-color 0.45s ease, box-shadow 0.45s ease, transform 0.45s ease;
    -webkit-tap-highlight-color: transparent;
}
.pc-btn  .cta-btn:hover {
    box-shadow: none;
    background: #e06569;
}
.pc-btn  .cta-btn:hover .cta-icon {
    transform: translateX(6px);
}

.fixed .sp-btn{
    background-color: #fff;
    padding: 10px 20px;
    text-align: center;
    z-index: 100;
}

@media only screen and (max-width:768px){
.fixed{
	position: fixed;
    bottom: 20px;
    right: 20px;
	z-index: 1000;
	
}
}
@media only screen and (max-width:768px){
.fixed{
	position: fixed;
    bottom: 0;
    right: 0;
	width: 100%;
	z-index: 100;
	
}
}




/*-----------------------------------------------
fv
----------------------------------------------- */

.fv {
    position: relative;

}
.fv-contents{
    padding: 120px 80px 0;
    z-index: 10;
    position: relative;
}
.fv-box{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.fv-txt{
    width: 54%;

}
.fv-txt .btn-box{
    margin: 40px 0 0 40px;
}
.fv-video{
    width: calc(40% - 20px);
    margin-left: 20px;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}
.fv-video video {
    width: calc(50% - 20px);
    height: auto;
}
.fv-graphic{
    margin: 160px auto 100px;
}

.fv .ellipse-1 {
    position: absolute;
    top: 700px;
    right: -60px;
    width: 212px;
    height: 212px;
    background-color: #8ca7c9;
    border-radius: 106px;
    filter: blur(120px);
}

.fv .ellipse-2{
    position: absolute;
    top: 400px;
    right: -100px;
    width: 331px;
    height: 331px;
    background-color: #ffbfc099;
    border-radius: 165.5px;
    filter: blur(150px);
}

.fv .ellipse-3 {
    position: absolute;
    top: -80px;
    left: 60px;
    width: 268px;
    height: 268px;
    background-color: #8ca7c9;
    border-radius: 134px;
    transform: rotate(26.14deg);
    filter: blur(100px);
}

.fv .ellipse-4 {
    position: absolute;
    top: 40px;
    left: -90px;
    width: 244px;
    height: 244px;
    background-color: #ffbfc0cc;
    border-radius: 122px;
    transform: rotate(26.14deg);
    filter: blur(100px);
}


@media only screen and (max-width:768px){
    .fv-contents{
        padding: 80px 40px 0;
    }
    .fv-txt .btn-box{
    margin: 40px 0 0 0;
    }
    .fv-graphic{
        margin: 100px auto 50px;
    }
}

@media only screen and (max-width:540px){
    .fv-contents{
        padding: 80px 20px 0;
    }
    .fv-box{
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
    }
    .fv-txt{
        width: 100%;
    }
    .fv-txt .btn-box{
        margin: 40px auto 0;
        text-align: center;
    }
    .fv-video{
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 20px;
        margin: 40px 30px;
    }
    .fv-graphic{
        margin: 50px auto;
    }

    .fv .ellipse-1 {
        top: 500px;
        right: -100px;
        width: 212px;
        height: 212px;
    }

    .fv .ellipse-2{
        top: 336px;
        right: -100px;
        width: 200px;
        height: 200px;
    }

    .fv .ellipse-3 {
        top: -123px;
        left: 3px;
        width: 268px;
        height: 268px;
    }

    .fv .ellipse-4 {
        top: 10px;
        left: -114px;
        width: 244px;
        height: 244px;
    }
}



/*-----------------------------------------------
features
----------------------------------------------- */

.features-box{
    margin: 80px auto 0;
    padding: 0 80px;
    z-index: 10;
    position: relative;
}
.features-item{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 80px;
}
.features-txtbox{
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 50%;
}
.features-img{
    width: 40%;
}
.features-subtxt{
    color: var(--main);
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.7px;
}
.features-title{
    color: var(--text);
    font-size: 26px;
    letter-spacing: 1.3px;
}
.features-achieve-box{
    display: flex;
    gap: 30px;
}
.achieve-item{
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 30px;
    gap: 24px;
    box-shadow: 0 16px 34px -4px rgba(0, 0, 0, 0.10);
    border-radius: 24px;
    border: 1px solid rgba(204, 204, 204, 0.40);
    text-align: center;
    transition: 0.5s ease;
    letter-spacing: 1.24px;
    background-color: #ffffff;
}
.achieve-title{
    font-weight: 600;
}
.achieve-txt{
    font-size: 10px;
    font-weight: 500;
}
.achieve-item:hover{
    box-shadow: 0 16px 56px 0 rgba(237, 117, 121, 0.25);
}

.features-bg{
    position: relative;
    width: 100%;
    height: auto;
    background-color: #ffffff;
    border-radius: 80px;
    overflow: hidden;
    padding: 100px 0 160px;
}

.features-bg .ellipse-1 {
    top: -160px;
    right: 0;
    position: absolute;
    width: 320px;
    height: 320px;
    background-color: #8ca7c966;
    border-radius: 160px;
    filter: blur(130px);
}

.features-bg .ellipse-2 {
    top: -134px;
    left: -130px;
    position: absolute;
    width: 320px;
    height: 320px;
    background-color: #8ca7c966;
    border-radius: 160px;
    filter: blur(130px);
}

.features-bg .ellipse-3 {
    bottom: 0;
    right: 0;
    position: absolute;
    width: 320px;
    height: 320px;
    background-color: #8ca7c966;
    border-radius: 160px;
    filter: blur(100px);
}

.features-bg .ellipse-4 {
    bottom: 0;
    left: -143px;
    position: absolute;
    width: 320px;
    height: 320px;
    background-color: #8ca7c966;
    border-radius: 160px;
    filter: blur(100px);
}

@media only screen and (max-width:768px){
    .features-box{
        margin: 40px auto 0;
        padding: 0 40px;
    }
    .features-item{
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
        gap: 40px;
    }
    .features-item.left{
        flex-direction: column-reverse;
    }
    .features-txtbox{
        width: 100%;
    }
    .features-img{
        width: 100%;
    }
    .features-achieve-box{
        display: flex;
        flex-direction: column;
    }
    .achieve-item{
        width: 100%;
    }

    .features-bg .ellipse-1 {
        top: 0px;
        right: 0;
        position: absolute;
        width: 180px;
        height: 180px;
    }

    .features-bg .ellipse-2 {
        top: 0px;
        left: 0;
        position: absolute;
        width: 200px;
        height: 200px;
    }

    .features-bg .ellipse-3 {
        bottom: 0;
        right: 0;
        position: absolute;
        width: 200px;
        height: 200px;
    }

    .features-bg .ellipse-4 {
        bottom: 0;
        left: 0;
        position: absolute;
        width: 180px;
        height: 180px;
    }

}
@media only screen and (max-width:540px){
    .features-box{
        padding: 0 20px;
    }
    .features-title{
        font-size: 22px;
    }
    .features-bg{
        padding: 50px 0 80px;
		border-radius:40px;
    }
}

/*-----------------------------------------------
graphic
----------------------------------------------- */
.graphic{
    padding: 100px 80px 100px;
}
.graphic-item1{
    margin-bottom: 100px;
}
.graphic-title{
    font-size: 28px;
    line-height: 180%;
    padding-bottom: 30px;
}
.graphic-title span{
    color: var(--main);
}
.graphic-item1 img,.graphic-item2 img{
    padding-top: 60px;
}

.graphic-item2{
    text-align: center;
}
@media only screen and (max-width:768px){
    .graphic{
        padding: 100px 40px 160px;
    }
}
@media only screen and (max-width:540px){
    .graphic{
        padding: 80px 20px 80px;
    }
    .graphic-item1{
    margin-bottom: 80px;
    }
    .graphic-title{
        font-size: 22px;
        padding-bottom: 15px;
    }
    .graphic-title span{
        color: var(--main);
    }
    .graphic-item1 img,.graphic-item2 img{
        padding-top: 30px;
    }
}

/*-----------------------------------------------
price
----------------------------------------------- */
.price{
    padding: 100px 80px 160px;
    background-color: var(--text);
    border-radius: 60px 60px 0 0;
}
.price .title-box{
    text-align: center;
    z-index: 10;
    position: relative;
}
.price .title-box .subtitle{
    color: #ffffff;
}
.price .title-box .title{
    color: #ffffff;
}
.price-box{
    display: flex;
    flex-direction: column;
    gap: 80px;

    max-width: 980px;
    margin-top: 56px;
    padding: 100px 80px;
    border-radius: 20px;
    background: #FFF;
    box-shadow: 0 16px 56px 0 rgba(237, 117, 121, 0.25);
    font-family: "Noto Sans JP", sans-serif;
}
.price-title-box{
    border-bottom: 1px dashed #343652;
    display: flex;
    align-items: center;
    padding: 0 16px 8px 0;
    gap: 16px;
    margin-bottom: 24px;
}
.price-title-box img{
    width: 24px;
    height: 24px;
}
.price-title{
    font-size: 22px;
    font-weight: 600;
}
.price1{
    display: flex;
    gap: 30px;
}
.price1 .box{
    border-radius: 6px;
    border: 1px solid rgba(0, 33, 68, 0.10);
    padding: 24px;
}
.price1 .box:first-child{
    min-width: 120px;
}
.price1 .text{
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.8px;
    padding-bottom: 8px;
}
.price1 .element{
    text-align: center;
}
.price1 .element .text1{
    font-size: 48px;
    line-height: 100%;
}
.price1 .element .text2{
    font-size: 32px;
    line-height: 100%;
}
.element2 .text1{
    color: var(--main);
    font-size: 22px;
    font-weight: 600;
    letter-spacing: 1.1px;
}
.price2 , .price3{
    list-style-type: disc;
    padding-left: 16px;

    display: flex;
    flex-direction: column;
    gap: 16px;
}
.price2  li{
    font-weight: 600;
    font-size: 16px;
}
.price2  .sub-txt-box p{
    font-size: 14px;
}

@media only screen and (max-width:768px){
    .price{
        padding: 100px 40px 160px;
    }
    .price-box{
        padding: 100px 40px;
        border-radius: 20px;
        background: #FFF;
    }
}
@media only screen and (max-width:540px){
    .price{
        padding: 46px 20px 80px;
        border-radius: 20px 20px 0 0;
    }
    .price-box{
        gap: 52px;
        margin-top: 46px;
        padding: 40px 30px;
    }
    .price1{
        display: flex;
        flex-direction: column;
        gap: 30px;
    }
    .price1 .box{
        flex: 1;
        padding: 20px;
    }
    .price1 .box:first-child{
        min-width: initial;
    }
    .element2 .text1{
        font-size: 17px;
    }
    .price2 > .sub-txt-box p{
        font-size: 13px;
    }
}

/*-----------------------------------------------
step
----------------------------------------------- */
.screen {
    position: relative;
    width: 100%;
    height: auto;
    background-color: #f5f5f5;
    padding: 140px 80px 120px;
    
}
.step .screen::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 100%);
  z-index: 2;
  pointer-events: none;
}
.step-img{
    margin-top: 56px;
    position: relative;
    z-index: 10;
}

.screen .ellipse {
  top: 360px;
  left: -1px;
  width: 632px;
  height: 632px;
  background-color: #8ca7c9;
  border-radius: 316px;
  position: absolute;
  filter: blur(100px);
}

.screen .ellipse2  {
  top: 400px;
  left: 456px;
  width: 567px;
  height: 560px;
  background-color: #ffbfc0cc;
  border-radius: 283.5px / 280px;
  position: absolute;
  filter: blur(100px);
}

@media only screen and (max-width:768px){
    .screen {
    padding: 140px 40px 120px;
    }
    .screen .ellipse {
        top: 200px;
        left: 0;
        width: 400px;
        height: 400px;
        }

        .screen .ellipse2  {
        top: 300px;
        left: 300px;
        width: 300px;
        height: 300px;
        }
}
@media only screen and (max-width:540px){
    .screen {
        padding: 80px 20px;
    }
    .step-img{
        margin-top: 46px;
    }
    .screen .ellipse2  {
    top: 900px;
    left: 0;
    width: 567px;
    height: 560px;
    background-color: #ffbfc0cc;
    border-radius: 283.5px / 280px;
    position: absolute;
    filter: blur(100px);
    }
}

/*-----------------------------------------------
form
----------------------------------------------- */
.form{
    padding: 120px 80px 60px;
    background-color: var(--text);
}
.form-contents{
    padding: 64px 80px;
    border-radius: 20px;
    box-shadow: 0 16px 56px 0 rgba(237, 117, 121, 0.25);
    background-color: #ffffff;

    max-width: 980px;
    position: relative;
}
.form-sub-title{
    text-align: center;
}
.form-sub-title p{
    padding: 8px 32px;
    border-radius: 40px;
    background: var(--main);
    display: inline-block;
    margin-bottom: 32px;

    color: #FFF;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 1.6px;
}

.form .title-box{
    padding-bottom: 40px;
}
.form-box{
    display: flex;
    flex-direction: column;
    gap: 40px;
    max-width: 650px;
    margin: 40px auto 0;

    font-family: "Noto Sans JP", sans-serif;
}

.form-title{
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 1.92px;
}
.form-span{
    color: var(--main);
}
.form-imput{
    height: 58px;
    border-radius: 4px;
    border: 1px solid rgba(52, 54, 82, 0.30);
    padding: 10px 10px 10px 20px;
    font-size: 16px;
    width: 100%;
    margin-top: 16px;
    font-weight: 400;
}
.form-imput::placeholder {
    color: #D6D7DC;
}
.wpcf7-checkbox , .wpcf7-radio{
    display: flex;
    flex-direction: column;

    margin-top: 10px;
    gap: 4px;
}
.wpcf7-list-item label{
    display: flex;
    gap: 8px;
    font-size: 16px;
}
.wpcf7-not-valid-tip{
    color: #e06569;
}
#wpcf7-f142-o1-ve-checkbox-naiyo,#wpcf7-f142-o1-ve-radio-webadprice,#wpcf7-f142-o1-ve-checkbox-medium,
#wpcf7-f142-o1-ve-company,#wpcf7-f142-o1-ve-your-name,#wpcf7-f142-o1-ve-your-email,#wpcf7-f142-o1-ve-your-tel,#wpcf7-f142-o1-ve-url{
    display: none;
}
.submit-btn-box{
    text-align: center;
}
.submit-btn{
    padding: 24px 80px;
    border-radius: 10px;
    background: linear-gradient(108deg, #405591 0%, #987B9C 48.08%, #FDA7A8 100%);
    font-size: 19px;
    color: #fff;
    cursor: pointer;
    letter-spacing: 1.2px;
    transition: transform 0.45s ease;
    margin: 40px 0;
}
.submit-btn:hover{
    opacity: 0.8;
}
@media only screen and (max-width:768px){
    .form{
        padding: 120px 40px 60px;
        background-color: var(--text);
    }
    .form-contents{
        padding: 64px 40px;
    }
}
@media only screen and (max-width:540px){
    .form{
        padding: 60px 20px 30px;
        background-color: var(--text);
    }
    .form-contents{
        padding: 64px 30px;
    }
    .form-sub-title{
    text-align: center;
    }
    .form-sub-title p{
        padding: 6px 32px;
        margin-bottom: 20px;
        font-size: 16px;
    }

    .form .title-box{
        padding-bottom: 20px;
    }
    .form-box{
        margin: 20px auto 0;
    }
	.submit-btn{
    	padding: 24px 40px;
		width:100%;
	}
}

/*-----------------------------------------------
footer
----------------------------------------------- */
footer{
    background: var(--text);
    color: #FFF;
    font-size: 15px;
    letter-spacing: 1.44px;
    text-align: center;

    padding: 100px 0 100px;
}
.footer-link p{
    margin-bottom: 10px;

}
.footer-link p:hover{
    opacity: 0.8;

}