
html {
    font-size: 1vw;
    -webkit-overflow-scrolling: touch;
    background: #fff;
}

body {
    position: relative;
    padding-top: 14%;
    color: #052F46;
    font-weight: 500;
    text-align: center;
    font-weight: 600;
    font-family: "NotoSansJP";
    overflow: hidden;
}

a,
input[type="button"] {
    -webkit-transition: .5s;
    -o-transition: .5s;
    transition: .5s;
}

a:hover,
input[type="button"]:hover {
    opacity: .7;
    -webkit-transition: .5s;
    -o-transition: .5s;
    transition: .5s;
}

.wrapper {
    width: 100%;
}

.content {
    width: 100%;
    max-width: 1186px;
    margin: auto;
}

img {
    font-size: 20rem;
    display: block;
    margin: auto;
}

/**********************
        header
***********************/

header {
    width: 100%;
    background: #fff;
    z-index: 12;
    top: 0;
    position: fixed;
}

header > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
    aspect-ratio: 1/.14;
    font-size: 2.8rem;
}

.logo {
    height: 50%;
    margin-left: 4.5%;
}

.contact,
.contact * {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 100%;
    color: #fff;
    font-weight: 500;
}

.headerTel {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    aspect-ratio: 1.07/1;
    background-color: #C63D91;
}

.headerTel:before {
    content: '';
    width: 50%;
    aspect-ratio: 1/1;
    background: url('../images/header/tel.webp') center center/contain no-repeat;
}

.headerMail {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    aspect-ratio: 1.07/1;
    background-color: #38A7E1;
}

.headerMail:before {
    content: '';
    width: 56%;
    aspect-ratio: 1/1;
    background: url('../images/header/mail.svg') center center/contain no-repeat;
}

.headerMenu {
    aspect-ratio: 1.32/1;
    background-color: #052F46;
}

.headerTelpc,
.headerMailpc {
    display: none;
}

.pcMenu {
    display: none;
}

/**********************
        1 top
***********************/

.wrapper.top > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/1.215;
    padding-top: 64.6%;
    background: url('../images/1_top/h1Small.webp') 100% 0%/cover no-repeat;
}

.point {
    position: absolute;
    font-weight: 500;
    color: #fff;
    background-color: #C63D91;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    aspect-ratio: 1/1;
}

.point:nth-child(1) {
    top: 30px;
    right: 9%;
    width: 29%;
    padding-top: 5.5%;
    font-size: 4rem;
    border-radius: 360px;
    background-color: #C63D91;
    z-index: 2;
}

.point:nth-child(1) span {
    font-size: 8.8rem;
    color: #F7E300;
    line-height: .8;
    vertical-align: bottom;
}

.point:nth-child(2) {
    top: 30%;
    right: 25%;
    width: 20%;
    padding-top: 1%;
    font-size: 3rem;
    border-radius: 360px;
}

.point:nth-child(2) span {
    font-size: 5.5rem;
    color: #F7E300;
    line-height: .8;
    vertical-align: bottom;
    letter-spacing: -5px;
}
.point:nth-child(2) span > span  {
    font-size: 9rem;
    color: #F7E300;
    line-height: .8;
    vertical-align: bottom;
    letter-spacing: -4px;
}

.point:nth-child(3) {
    top: 30%;
    right: 4.5%;
    width: 20%;
    padding-top: 3%;
    font-size: 4rem;
    border-radius: 360px;
}

.point:nth-child(3) span {
    font-size: 7.5rem;
    color: #F7E300;
    line-height: .8;
    vertical-align: bottom;
}

.ribbon {
    position: relative;
    display: block;
    width: 82%;
    margin: auto;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    aspect-ratio: 408/68;
}

.ribbon p {
    position: relative;
    top: 8%;
    font-size: 4.5rem;
    font-weight: 500;
    text-shadow: #fff 10px 0 10px;
    z-index: 2;
}

.ribbon img {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
}

.wrapper.top > .content h1 {
    display: block;
    width: 74%;
    margin: -3% auto 0;
    position: relative;
    z-index: 2;
    aspect-ratio: 368/207;
}

.h1Img {
    width: 100%;
    height: 100%;
}

.hukidashi {
    position: absolute;
    top: 23%;
    right: 25%;
    display: block;
    width: 15% !important;
    aspect-ratio: 36/15;
    -webkit-transform:scale(-1,1);
        -ms-transform:scale(-1,1);
            transform:scale(-1,1);
}


/**********************
      2 solution
***********************/

.wrapper.solution {
    background-color: #052F46;
}

.wrapper.solution > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/1.18;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding-top: 61%;
}

.mgtop {
    margin-top: -20%;
}

.wrapper.solution > .content img {
    position: absolute;
}

.woman01{
    top: 27%;
    left: 14%;
    width: 46%;
    aspect-ratio: 195/188;
    z-index: 4;
}

.woman02 {
    top: -1.5%;
    right: 22%;
    width: 28%;
    aspect-ratio: 60/91;
    z-index: 2;
}

.serif01 {
    top: -9%;
    right: -3%;
    width: 39%;
    aspect-ratio: 163/156;
}

.serif02 {
    top: 0%;
    left: 7%;
    width: 47%;
    aspect-ratio: 197/188;
    z-index: 3;
}

.serif03 {
    right: 10%;
    width: 44%;
    aspect-ratio: 192/183;
    top: 23%;
    z-index: 5;
}

.estimate {
    position: relative;
    z-index: 6;
    display: block;
    width: 68%;
    margin: auto;
    color: #fff;
    font-size: 4rem;
    text-shadow    :
    3px  3px 2px #0b2030,
    -3px  3px 2px #0b2030,
    3px -3px 2px #0b2030,
    -3px -3px 2px #0b2030,
    3px  0px 2px #0b2030,
    0px  3px 2px #0b2030,
    -3px  0px 2px #0b2030,
    0px -3px 2px #0b2030;
    background: url('../images/2_solution/estimate.webp') center bottom/contain no-repeat;
}

.estimate span {
    font-size: 1.16em;
    line-height: 1;
}

.telButton {
    display: block;
    width: 90%;
    aspect-ratio: 1/.14;
    padding: 1.4% 0 0 12%;
    margin: 3% auto 0;
    font-size: 7rem;
    color: #fff;
    background: url('../images/header/tel.webp') 14% 50%/11% no-repeat;
    background-color: #C63D91;
    border-radius: 7rem;
    letter-spacing: .4rem;
}

.mailButton {
    display: block;
    width: 90%;
    aspect-ratio: 1/.16;
    padding: 1.9% 0 0 12%;
    margin: 4.5% auto 0;
    font-size: 6.2rem;
    color: #fff;
    background: url('../images/header/mail.svg') 14% 40%/10% no-repeat;
    background-color: #38A7E1;
    border-radius: 7rem;
    letter-spacing: .4rem;
}

/**********************
      3 service
***********************/

.wrapper.service {
    background: url('../images/3_service/background.webp') 53% 61%/cover no-repeat;
}



.wrapper.service > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/4.2;
    padding-top: 18%;
}

.content h2 {
    color: #052F46;
    font-size: 8rem;
    font-weight: 900;
    font-family: "Poppins";
}

.subTitle {
    margin-top: 2%;
    font-size: 4.6rem;
    color: #052F46;
    font-weight: 900;
    font-family: "Poppins";
}

.message {
    display: block;
    width: 90%;
    height: 9.8%;
    margin: 18% auto 8%;
    font-size: 4.2rem;
    text-align: left;
    padding: 3.4% 0 0 1.8%;
    font-weight: 950;
    letter-spacing: -1.3px;
    background: #fff;
}

.message span {
    font-size: 1.6em;
    color: #C63D91;
}

.service3 > div {
    display: block;
    width: 72%;
    aspect-ratio: 1/1.2;
    margin: 0 auto 9%;
    background: #fff;
    font-size: 3rem;
    border: 1.3rem solid #052F46;
}

.service3 > div:nth-child(1) > img {
    position: relative;
    left: 5%;
    max-width: none;
    top: 4%;
    width: 103%;
    aspect-ratio: 356/252;
}

.service3 > div:nth-child(1) > h3 {
    font-size: 5.7rem;
    font-weight: 400;
    color: #fff;
    position: relative;
    background: #052F46;
    top: 7.1%;
    padding-top: 4%;
    width: 100%;
}

.service3 > div:nth-child(1) > p {
    font-size: 4.1rem;
    position: relative;
    top: 7%;
    padding-top: 5%;
}

.service3 > div:nth-child(2) > img {
    left: -1%;
    width: 52%;
    max-width: none;
    top: 3.3%;
    margin-top: 5%;
    margin-bottom: 5%;
    aspect-ratio: 132/181;
}

.service3 > div:nth-child(3) > img {
    left: -1%;
    width: 91%;
    max-width: none;
    top: 3.3%;
    margin-top: 2.8%;
    margin-bottom: 3.7%;
}

.service3 > div > h3 {
    font-size: 5.7rem;
    font-weight: 400;
    color: #fff;
    background: #052F46;
    padding-top: 4%;
    width: 100%;
    aspect-ratio: 1/0.2;
}

.service3 > div > p {
    font-size: 4.1rem;
    padding-top: 5%;
    width: 100%;
    aspect-ratio: 1/0.195;
}


/**********************
      4 3features
***********************/


.wrapper.features {
    background-color: #99D1EA;
    margin-top: -10%;
}

.wrapper.features > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/4.23;
    padding-top: 18%;
}

.features3 {
    width: 100%;
    margin-top: 28%;
}

.features3 > div {
    width: 91%;
    aspect-ratio: 1/1.093;
    margin: 0 auto 19%;
    background: #fff;
    border-radius: 5rem;
}

.number {
    position: relative;
    top: -10rem;
    width: 21%;
    aspect-ratio: 1/1;
    margin: auto;
    font-size: 12rem;
    color: #fff;
    background: #052F46;
    border-radius: 360px;
}

.features3 > div > h3 {
    font-weight: 500;
    line-height: 0.5;
    font-size: 7.7rem;
}

.features3 > div > p {
    display: block;
    margin: 6.2% auto 0;
    width: 78%;
    text-align: left;
    font-size: 3.6rem;
    line-height: 1.76;
}

.features3 > div:nth-child(1) > img {
    margin-top: 3%;
    width: 30%;
    max-width: none;
    aspect-ratio: 1/1;
}

.features3 > div:nth-child(2) > img {
    margin-top: 3%;
    width: 51%;
    max-width: none;
}

.features3 > div:nth-child(3) > img {
    margin-top: 17%;
    width: 46%;
    max-width: none;
}


/**********************
  P5 Application flow
***********************/

.appearBR {
    display: none;
}

.wrapper.flow {
    background: url('../images/5_flow/background.webp') 53% 61%/cover no-repeat;
}

.wrapper.flow > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/2.768;
    padding-top: 18%;
    margin-top: -20%;
}

.flowList {
    display: block;
    width: 90%;
    margin: 18% auto 0;
    aspect-ratio: 1/2.23;
    padding: 9% 7% 0;
    background: #fff;
    -webkit-box-shadow: 3px 7px 19px -3px rgba(0, 0, 0, 0.09);
    -ms-box-shadow: 3px 7px 19px -3px rgba(0, 0, 0, 0.09);
    box-shadow: 3px 7px 19px -3px rgba(0, 0, 0, 0.09);
}

.flowList > li {
    width: 100%;
    height: 17%;
    margin-bottom: 23.4%;
}

.flowList > li:after {
    content: '';
    display: block;
    margin: 11% auto;
    width: 14%;
    height: 19%;
    background: url('../images/5_flow/arrow.svg') center center/contain no-repeat;
}

.flowList > li:nth-child(4):after{
    display: none;
}

.flowList > li > h3 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    justify-items: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 6rem;
    width: 100%;
    height: 39%;
    font-weight: 800;
    letter-spacing: -0.3rem;
}

.flowList > li:nth-child(1) > h3:before {
    background: #052F46 url('../images/5_flow/01small.webp') center center/76% no-repeat;
}

.flowList > li:nth-child(2) > h3:before {
    background: #052F46 url('../images/5_flow/02small.webp') center center/76% no-repeat;
}

.flowList > li:nth-child(3) > h3:before {
    background: #052F46 url('../images/5_flow/03small.webp') center center/76% no-repeat;
}

.flowList > li:nth-child(4) > h3:before {
    background: #052F46 url('../images/5_flow/04small.webp') center center/76% no-repeat;
}

.flowList > li > h3:before {
    content: '';
    display: block;
    width: 35.5%;
    height: 100%;
    margin-right: 3.6%;
}

.flowList > li:nth-child(1) > h3:after,
.flowList > li:nth-child(2) > h3:after {
    content: '無料';
    display: block;
    height: 50%;
    padding-top: .4%;
    margin-left: 1.1%;
    color: #fff;
    font-size: 4rem;
    font-weight: 500;
    border-radius: 1rem;
    background: #EB0000;
    width: 13.4%;
}

.flowList > li > p {
    font-size: 3rem;
    margin-top: 3.4%;
    width: 100%;
    height: 50%;
    text-align: left;
    letter-spacing: .189rem;
    line-height: 1.8;
}


/**********************
      6 Q&A
***********************/

.wrapper.qa {
    background-color: #99D1EA;
    padding-bottom: 14%;
}

.wrapper.qa > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/2.98;
    padding-top: 18%;
}

.subTitle + .qaDiv {
    margin-top: 18%;
}

.qaDiv {
    display: block;
    width: 91%;
    margin: 0 auto 8.5%;
    border: .8rem solid #052F46;
    text-align: left;
    background: #fff;
}

.qaDiv.q1 {
    height: 19.5%;
}

.qaDiv.q2 {
    height: 18%;
}

.qaDiv.q3 {
    height: 13.4%;
}

.qaDiv.q4 {
    height: 20.5%;
}

.question {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-size: 4.54rem;
    font-weight: 800;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    width: 100%;
    color: #052F46;
    background: #e7e7e7 url(../images/6_qa/lineSmall.webp) center bottom/ contain no-repeat;
}

.qaDiv.q1 .question {
    padding: 5.6rem 5rem 6rem 2.7rem;
}

.qaDiv.q2 .question {
    padding: 6.6rem 5rem 7.3rem 2.7rem;
}

.qaDiv.q3 .question {
    padding: 5.5rem 5rem 6rem 2.7rem;
}

.qaDiv.q4 .question {
    padding: 4.8rem 5rem 6rem 2.7rem;
}

.question:before {
    content: '';
    position: relative;
    width: 13rem;
    aspect-ratio: 1/1;
    margin-right: 2%;
    border-radius: 360px;
    right: .2rem;
    top: .5rem;
    background: url('../images/6_qa/Q.webp') center center/contain no-repeat;
}

.qaDiv.q2 .question:before {
    width: 7rem;
    top: -.1rem;
}

.qaDiv.q3 .question:before {
    width: 7.8rem;
    right: 0;
}

.qaDiv.q4 .question:before {
    width: 7.8rem;
}

.answer {
    font-weight: 500;
    padding: 2.4rem 4rem 2rem 12rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    width: 100%;
    color: #052F46;
    font-size: 3.6rem;
    line-height: 1.5;
}

/**********************
      7 inquiry
***********************/

.wrapper.inquiry {
    background: url('../images/7_inquiry/background.webp') center center/cover no-repeat;
    margin-top: -12%;
}

.wrapper.inquiry > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/2.41;
    padding-top: 18%;
}

.indexForm {
    width: 91%;
    aspect-ratio: 1/1.8;
    padding-top: 13%;
    margin: 18.4% auto 0;
    background: #ffffff;
    border-radius: 5rem;
    text-align: left;
}

.indexForm p {
    width: 79%;
    margin: auto;
    padding-bottom: 1.4%;
    font-size: 4.5rem;
}

::-webkit-input-placeholder {
  color: #AAAAAA;
}

::-moz-placeholder {
  color: #AAAAAA;
}

:-ms-input-placeholder {
  color: #AAAAAA;
}

::-ms-input-placeholder {
  color: #AAAAAA;
}

::placeholder {
  color: #AAAAAA;
}

.inputArea {
    margin-bottom: 9%;
}

.indexForm input,
.indexForm textarea {
    display: block;
    width: 79%;
    margin: auto;
    background: #fff;
    border: .534rem solid #AAAAAA;
    font-weight: 200;
    font-size: 5.5rem;
    padding: .5rem 2.1rem;
}

textarea {
    aspect-ratio: 1/.38;
}

#submitBtn {
    width: 67%;
    aspect-ratio: 1/.24;
    margin: 2.5% auto;
    border-radius: 8rem;
    display: block;
    border: 1px solid #1FB6F1;
    color: #fff;
    font-size: 5rem;
    background: -o-linear-gradient(top, rgba(105,209,250,1) 0%, rgba(16,162,219,1) 74%, rgba(36,165,215,1) 100%);
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(105,209,250,1)), color-stop(74%, rgba(16,162,219,1)), to(rgba(36,165,215,1)));
    background: linear-gradient(180deg, rgba(105,209,250,1) 0%, rgba(16,162,219,1) 74%, rgba(36,165,215,1) 100%);
}

#submitBtn:hover {
    opacity: .8;
}


/**********************
      6 Company
***********************/

.wrapper.company {
    background-color: #99D1EA;
    padding-bottom: 14%;
	min-height: 360px;
}

.wrapper.company > .content {
    position: relative;
    width: 100%;
    aspect-ratio: 1/2.98;
    padding-top: 5%;
	height: 200px;
}


.wrapper.company > .content h2{
	margin-bottom: 5%;
}

.subTitle + .companyDiv {
    margin-top: 5%;
}

.companyDiv {
	display: block;
	width: 91%;
	margin: 0 auto 8.5%;
	border: .8rem solid #052F46;
	text-align: left;
	background: #fff;
}

.company_table_b {
	display: flex;
	justify-content: center;
}

.company_table .col {
	display: flex;
	margin-top: 10px;
	border-bottom: 1px black solid;
	padding: 0, 20px;
}

.company_table .col .col_n,
.company_table .col .col_v {
	font-size: 2.8rem !important;
	text-align: left;
}

.company_table .col .col_n {
	width: 10vw;
}

.company_table .col .col_v {
	margin-bottom: 10px;
}
/**********************
        footer
***********************/

footer {
    background-color: #052F46;
    margin-top: -5%;
}

footer p {
    padding-top: 3%;
    font-size: 3.6rem;
    color: #fff;
    font-weight: 400;
    height: 12rem;
}






@media screen and (min-width: 768px) {

    .remove-viewport-meta {
        display: none;
    }

    html {
        font-size: 6.2px;
    }

    body {
        padding-top: 87.75px;
        overflow: inherit;
    }

    .appearBR {
        display: block;
    }

    .hiddenBR {
        display: none;
    }

    .content {
    width: 1186px;
    overflow: visible;
    }

    .mobileMenu {
        display: none;
    }

    .pcMenu {
        display: block;
        color: #fff;
        background-color: #052F46;
    }

    .pcMenu > div {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        width: 1260px;
        margin: auto;
        font-size: 3.3rem;
        height: 8rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -ms-flex-pack: distribute;
            justify-content: space-around;
        padding: 0 6%;
    }

    .pcMenu a {
        font-weight: 500;
    }


    /**********************
            header
    ***********************/


    header {
        background: #fff;
    }

    header > div {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
        width: 1186px;
        margin: auto;
        font-size: 2.8rem;
        height: 87.75px;
    }

    .logo {
        margin-left: 8.5%;
        height: 57%;
        aspect-ratio: 235/50;
    }

    .contact{
        height: 56%;
        width: 44.2%;
        margin-right: 8.4%;
    }

    .contact * {
        height: 100%;
    }

    .headerTelpc {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        width: 57%;
        background: #00000040;
        font-size: 4.1rem;
        padding-left: 13%;
        letter-spacing: 2.3px;
        background: url('../images/header/tel.webp') 8% center/11% no-repeat;
        background-color: #C63D91;
        border-radius: 7rem;
        margin-right: 2%;
    }

    .headerMailpc {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        background-color: #38A7E1;
        aspect-ratio: inherit;
        width: 41%;
        font-size: 3.5rem;
        letter-spacing: 2.3px;
        background: url('../images/header/mail.svg') 16% center/13% no-repeat;
        background-color: #38A7E1;
        border-radius: 7rem;
        padding-left: 9%;
    }







    .headerTel, .headerMail, .menu {
        display: none;
    }

/**********************
        1 top
***********************/

    .wrapper.top {
        background-color: #F6FCFC;
    }

    .wrapper.top > .content {
        width: 1186px;
        aspect-ratio: 1/.52;
        padding-top: 41rem;
        background: url('../images/1_top/h1.webp') -26% 84%/96% no-repeat;
    }

    .point {
        position: absolute;
        font-weight: 500;
        color: #fff;
        background-color: #C63D91;
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
        aspect-ratio: 1/1;
    }

    .point:nth-child(1) {
        top: 5%;
        width: 16%;
        left: 8%;
        padding-top: 3.5%;
        font-size: 4.7rem;
    }


    .point:nth-child(1) span {
        font-size: 8.8rem;
        color: #F7E300;
        line-height: .8;
        vertical-align: bottom;
    }

    .point:nth-child(2) {
        top: 4%;
        right: 19.5%;
        width: 9%;
        font-size: 2.9rem;
        padding-top: 0.6%;
    }

    .point:nth-child(2) span {
        font-size: 4rem;
        line-height: .8;
    }
    .point:nth-child(2) span > span  {
        font-size: 7rem;
    }

    .point:nth-child(3) {
        top: 4%;
        right: 9%;
        width: 9%;
        padding-top: 1.2%;
        font-size: 3.4rem;
        border-radius: 360px;
    }

    .point:nth-child(3) span {
        font-size: 6.5rem;
        line-height: .9;
    }

    .ribbon {
        width: 44%;
        height: 28%;
    }

    .ribbon p {
        font-size: 5.4rem;
        top: 7%;
    }

    .ribbon img {
        top: 0;
        width: 100%;
    }

    .wrapper.top > .content h1 {
        display: block;
        width: 38%;
        margin: -2% auto 0;
        position: relative;
        z-index: 2;
    }

    .wrapper.top > .ribbon img {
        aspect-ratio: 463/260;
        width: 38rem;
    }

    .hukidashi {
        right: auto;
        left: 18%;
        width: 7% !important;
        -webkit-transform: none;
            -ms-transform: none;
                transform: none;
        top: 30%;
    }

/**********************
      2 solution
***********************/

    .wrapper.solution {
    background-color: #052F46;
    }

    .wrapper.solution > .content {
        width: 1186px;
        aspect-ratio: 1/0.292;
        padding-top: 2.4%;
    }

    .mgtop {
        margin-top: 0;
    }

    .woman01{
        top: auto;
        left: -.2%;
        width: 28.5%;
        bottom: 0;
    }

    .woman02 {
        top: auto;
        right: 7%;
        width: 20.5%;
        bottom: 0;
    }

    .serif01 {
        top: -65%;
        right: 7.5%;
        width: 24%;
    }

    .serif02 {
        top: -38%;
        left: 0.3%;
        width: 18%;
    }

    .serif03 {
        right: auto;
        width: 18%;
        top: -25%;
        left: 12.5%;
    }

    .estimate {
        font-size: 4.5rem;
        background: transparent;
    }

    .estimate span {
        font-size: 1.16em;
        line-height: 1;
    }

    .telButton {
       width: 42%;
       padding: 0% 0 0 4%;
       font-size: 6rem;
       letter-spacing: 0.2rem;
       margin: 2.4% auto 0;
       background-size: 7%;
       background-position: 18% 50%;
       aspect-ratio: 1/.114;
   }

   .mailButton {
       width: 42%;
       aspect-ratio: 1/.114;
       padding: 0.7% 0 0 5%;
       margin: 1.8% auto 0;
       letter-spacing: -0rem;
       font-size: 4.6rem;
       background-position: 31% 60%;
       background-size: 8.5%;
   }

/**********************
      3 service
***********************/


.wrapper.features {
    margin-top: 0;
}

   .wrapper.service > .content {
    position: relative;
    width: 1186px;
    padding-top: 5.7%;
    left: -1rem;
    aspect-ratio: 1/.833;
}

.content h2 {
    font-size: 8.6rem;
    line-height: 1;
}

.subTitle {
    font-size: 4rem;
    margin-top: 1%;
}

.message {
    width: 82%;
    margin: 6.5% auto 3.5%;
    font-size: 3.5rem;
    text-align: center;
    padding: .7% 0 0 1.8%;
    letter-spacing: -1.3px;
    height: 11%;
}

.message span {
    line-height: 1.2;
    font-size: 1.5em;
}

.service3 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 83%;
    margin: auto;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
}

.service3 > div {
    display: block;
    width: 30.5%;
    aspect-ratio: 1/1.2;
    border: .9rem solid #052F46;
    font-size: 3rem;
    margin: 0;
}

.service3 > div:nth-child(1) > img {
    left: 6%;
    width: 96%;
    top: 6%;
    margin-bottom: 4%;
}

.service3 > div:nth-child(1) > h3 {
    font-size: 4rem;
    top: 7.1%;
    padding-top: 4%;
    height: 16.8%;
}

.service3 > div:nth-child(2) > img {
    left: -1%;
    width: 44%;
    max-width: none;
    top: 3.3%;
    margin-top: 10%;
    margin-bottom: 10%;
}

.service3 > div:nth-child(3) > img {
    left: -1%;
    width: 77%;
    top: 3.3%;
    margin-top: 7.8%;
    margin-bottom: 8.7%;
}

.service3 > div > h3 {
    font-size: 4rem;
    top: 7.1%;
    padding-top: 4%;
    height: 16.8%;
}

.service3 > div:nth-child(1) > p,
.service3 > div > p {
    font-size: 3rem;
}

.service3 > div > p {
    padding-top: 4%;
}

/**********************
      4 3features
***********************/

.wrapper.features > .content {
    width: 1186px;
    aspect-ratio: 1/0.915;
    padding-top: 9%;
}

.features3 {
    width: 87%;
    margin: 10% auto 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
        justify-content: space-around;
}

.features3 > div {
    width: 30%;
    aspect-ratio: 1/1.775;
    margin: 0;
}

.number {
    top: -7%;
    font-size: 8rem;
    width: 26%;
    margin-bottom: 1%;
}

.features3 > div > h3 {
    font-weight: 500;
    line-height: 1;
    font-size: 6.4rem;
}

.features3 > div > p {
    display: block;
    font-size: 2.8rem;
    line-height: 1.76;
    margin: 8.2% auto 0;
    width: 84%;
}

.features3 > div:nth-child(1) > img {
    margin-top: 16%;
    width: 36%;
}

.features3 > div:nth-child(2) > img {
    margin-top: 11%;
    width: 73%;
    max-width: none;
}

.features3 > div:nth-child(3) > img {
    margin-top: 34%;
    width: 58%;
    max-width: none;
}


/**********************
  P5 Application flow
***********************/

.wrapper.flow {
}

.wrapper.flow > .content {
    margin-top: 0;
}

.appearBR {
}

.wrapper.flow > .content {
    width: 1186px;
    aspect-ratio: 1/1.15;
    padding-top: 9.4%;
}

.flowList {
    width: 82.7%;
    margin: 6.5% auto 0;
    aspect-ratio: 1/.815;
    padding: 5% 6% 0;
}

.flowList > li {
    height: 15.7%;
    margin-bottom: 8.4%;
    padding-left: 20.3%;
    position: relative;
}

.flowList > li:before {
    content: '';
    display: block;
    position: absolute;
    width: 18%;
    height: 100%;
    left: 0;
}


.flowList > li:nth-child(1):before {
    background: #052F46 url('../images/5_flow/01.webp') center center/76% no-repeat;
}

.flowList > li:nth-child(2):before {
    background: #052F46 url('../images/5_flow/02.webp') center center/76% no-repeat;
}

.flowList > li:nth-child(3):before {
    background: #052F46 url('../images/5_flow/03.webp') center center/76% no-repeat;
}

.flowList > li:nth-child(4):before {
    background: #052F46 url('../images/5_flow/04.webp') center center/76% no-repeat;
}

.flowList > li:after {
    display: block;
    margin: 0;
    position: absolute;
    left: 5.2%;
    bottom: -41%;
    width: 7.7%;
    height: 26%;

}

.flowList > li > h3 {
    font-size: 5rem;
    height: 42%;
}

.flowList > li > h3:before {
    display: none;
}

.flowList > li:nth-child(1) > h3:after,
.flowList > li:nth-child(2) > h3:after {
    font-size: 3.8rem;
    width: 10.4%;
    margin-left: 1.5%;
    padding-top: 0;
    height: 73%;
}

.flowList > li > p {
    font-size: 2.66rem;
    margin-top: 0.6%;
    width: 100%;
    height: 50%;
    text-align: left;
    letter-spacing: .189rem;
    line-height: 1.8;
}


/**********************
      6 Q&A
***********************/

.wrapper.qa {
    padding-bottom: 0;

}

.wrapper.qa > .content {
    width: 1186px;
    padding-top: 9%;
    left: -1rem;
    aspect-ratio: 1/1.108;
}

.subTitle + .qaDiv {
    margin-top: 6.3%;
}

.qaDiv {
    width: 82.5%;
    margin: 0 auto 3.5%;
    text-align: left;
    background: #fff;
    border-width: 1rem;
}

.qaDiv.q1 {
    height: 15.2%;
}

.qaDiv.q2 {
    height: 15%;
}

.qaDiv.q3 {
    height: 15%;
}

.qaDiv.q4 {
    height: 17%;
}

.question {
    font-size: 4.4rem;
    background: #e7e7e7 url(../images/6_qa/line.webp) center bottom/ contain no-repeat;
}

.qaDiv.q1 .question {
    padding: 2.8rem 5rem 3rem 11.7rem;
}

.qaDiv.q2 .question {
    padding: 2.8rem 5rem 3rem 11.7rem;
}

.qaDiv.q3 .question {
    padding: 2.8rem 5rem 3rem 11.7rem;
}

.qaDiv.q4 .question {
    padding: 2.8rem 5rem 3rem 11.7rem;
}

.question:before {
    width: 7rem;
    top: -0.1rem;
}

.qaDiv.q2 .question:before,
.qaDiv.q3 .question:before,
.qaDiv.q4 .question:before, {
    width: 8rem;
    top: -0.5rem;
}

.answer {
    padding: 2rem 13rem 2rem 23rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    width: 100%;
    font-size: 2.8rem;
    line-height: 1.7;
}

/**********************
      7 inquiry
***********************/

.wrapper.inquiry {
    margin-top: 0;
}

.wrapper.inquiry > .content {
    width: 1186px;
    aspect-ratio: 1/0.99;
    padding-top: 18rem;
    position: relative;
}

.indexForm {
    padding-top: 11rem;
    margin: 11.4rem auto 0;
    border-radius: 5rem;
    text-align: left;
    width: 82.6%;
    aspect-ratio: inherit;
    height: 119rem;
}

.indexForm p {
    width: 70%;
    padding-bottom: .5rem;
    font-size: 3.3rem;
}

::-webkit-input-placeholder {
  color: #AAAAAA;
}

::-moz-placeholder {
  color: #AAAAAA;
}

:-ms-input-placeholder {
  color: #AAAAAA;
}

::-ms-input-placeholder {
  color: #AAAAAA;
}

::placeholder {
  color: #AAAAAA;
}

.inputArea {
    margin-bottom: 4rem;
}

.indexForm input,
.indexForm textarea {
    width: 70%;
    background: #fff;
    font-size: 4rem;
}

textarea {
    aspect-ratio: 1/.175;
}

#submitBtn {
    width: 54%;
    aspect-ratio: 1/.19;
    margin: 2.5% auto;
    border: 1px solid #1FB6F1;
}

#submitBtn:hover {
    opacity: .8;
}

/**********************
        footer
***********************/

footer {
    margin-top: 0;
}

footer p {
    padding-top: 18rem;
    font-size: 3rem;
    height: 32rem;
}
}


/**********************
     hambergurMenu
***********************/

.menu{
  position: relative;
  aspect-ratio: 1.34/1;
  cursor: pointer;
  background-color: #052F46;
}

.menu span{
    display: inline-block;
    -webkit-transition: all .4s;
    -o-transition: all .4s;
    transition: all .4s;
    position: absolute;
    left: 24%;
    height: 0.6rem;
    background: #fff;
    width: 53%;
    border-radius: 5px;
}

.menu span:nth-of-type(1) {
  top:18%;
}

.menu span:nth-of-type(2) {
  top:32%;
}

.menu span:nth-of-type(3) {
  top:48%;
}

.menu span:nth-of-type(3)::after {
  content:"メニュー";
  position: absolute;
  left:-10%;
  color: #fff;
  font-size: 2.6rem;
  text-transform: uppercase;
  top:2rem;
}

.menu.active span:nth-of-type(1) {
    top: 22%;
    left: 20%;
    -webkit-transform: translateY(1.2rem) rotate(-24deg);
        -ms-transform: translateY(1.2rem) rotate(-24deg);
            transform: translateY(1.2rem) rotate(-24deg);
    width: 60%;
}

.menu.active span:nth-of-type(2) {
  opacity: 0;
}

.menu.active span:nth-of-type(3){
    top: 41%;
    left: 20%;
    -webkit-transform: translateY(-1.2rem) rotate(23deg);
        -ms-transform: translateY(-1.2rem) rotate(23deg);
            transform: translateY(-1.2rem) rotate(23deg);
    width: 60%;
}

.menu.active span:nth-of-type(3)::after {
  content:"閉じる";
  -webkit-transform: translateY(0) rotate(-24deg);
      -ms-transform: translateY(0) rotate(-24deg);
          transform: translateY(0) rotate(-24deg);
  top:3rem;
  left:2rem;
  width:108%;
  font-size: 2.6rem;
}

.mobileMenu {
    position: fixed;
    top: -90vh;
    width: 100%;
    height: 92vh;
    z-index: 10;
    color: #fff;
    font-size: 4rem;
    text-align: left;
    background: #052F46;
    opacity: 0;
    -webkit-transition: .5s;
    -o-transition: .5s;
    transition: .5s;
}

.mobileMenu.open {
    top: auto;
    opacity: 1;
    -webkit-transition: .5s;
    -o-transition: .5s;
    transition: .5s;
}

.mobileMenu > div {
    width: 72%;
    height: 60%;
    margin: 0 auto 11%;
    padding-top: 13%;
}

.mobileMenu > div a {
    height: 20%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-left: 3%;
    border-bottom: 1px solid #fff;
}

.mobileMenu > div a span {
    font-weight: 100;
    font-size: .8em;
    padding-left: 5%;
}

.mobileMenu .telButton{
    height: 9%;
    width: 81%;
    background-size: 9%;
    padding: .7% 0 0 19%;
    font-size: 6.3rem;
    background-position-x: 12%;
}

.mobileMenu .mailButton {
    height: 9%;
    width: 81%;
    background-size: 10%;
    padding: 1% 0 0 25%;
    font-size: 5.6rem;
    background-position: 14% 47%;
}