@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

body {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: normal;
    font-style: normal;
    font-size: 16px;
}
.ttl-logo {
    margin: 0 auto;
    display: block;
}

.header {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 999;
}

.header-wrap {
    padding: 20px;
    display: flex;
    justify-content: space-between;
}

.header-wrap--call {
    display: none;
    /* display: flex; */
    flex-direction: column;
}



/*
* fv
*/
.fv {
    width: 100%;
    height: 80vh;
    max-height: 700px;
    background: url(../../images/zero/fv-bg.png) no-repeat;
    background-size: cover;
}
.fv-outer {
    margin: 0 auto;
    padding: 100px 0;
    display: flex;
    justify-content: center;
    gap: 30px;
    max-width: 1200px;
    width: calc(100% - 20px);
    height: inherit;
}
.fv-outer--img {
    max-width: 570px;
    width: 50%;
    height: auto;
    object-fit: contain;
    object-position: top;
}

.fv-outer__box {
    max-width: 580px;
    width: 100%;
}
.fv-outer__box--target {
    padding: 6px 0;
    display: block;
    width: 100%;
    color: #04309D;
    font-size: clamp(1.25rem,2.6vw,2rem);
    font-weight: 900;
    background-color: #FFFFFF;
    border-radius: 30px;
    text-align: center;
}
.fv-outer__box--company {
    margin-top: 30px;
    padding: 6px 0;
    display: block;
    font-size: clamp(1.25rem,2.6vw,1.5rem);
    font-weight: 900;
    color: #FFFFFF;
    text-align: center;
    border-top: 1px solid #FFFFFF;
    border-bottom: 1px solid #FFFFFF;
}
.fv-outer__box--ttl img {
    width: 100%;
    height: auto;
}
.fv-outer__box--txt {
    font-size: 18px;
    color: #FFFFFF;
    line-height: 1.4;
}

/*
* performance
*/
.performance {
    padding-bottom: 60px;
    width: 100%;
}

.performance-wrap {
    max-width: 1200%;
    width: 100%;
    margin: 0 auto;
}
.performance--txt {
    margin: 80px 0 40px 0;
    text-align: center;
    font-size: clamp(1.25rem,2.6vw,2rem);
    font-weight: 900;
    line-height: 1.6;
}

.blue {
    color: #031F88;
}

.performance-client {
    width: 100%;
    overflow: hidden;
}

.performance-client-wrap {
    display: flex;
}
.performance-client-wrap--logo {
    width: 100%;
    object-fit: contain;
    animation: scroll 20s linear infinite;
}
.performance-client-wrap--logo-bottom {
    width: 100%;
    object-fit: contain;
    animation: scrollP 20s linear infinite;
}

/* 横スクロールアニメーション */
@keyframes scroll {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-100%);
    }
}
/* 横スクロールアニメーション */
@keyframes scrollP {
    0% {
      transform: translateX(-100%);
    }
    100% {
      transform: translateX(0);
    }
}
  


/*
* worries
*/
.worries {
    width: 100%;
    height: auto;
}

.worries--ttl {
    padding: 40px 0;
    text-align: center;
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    background-color: #042DA0;
    color: #FFFFFF;
}

.worries-outer {
    padding-top: 80px;
    width: 100%;
    height: auto;
    background-color: #FFFF2F;

}

.worries-outer-inner {
    margin: 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
}

.worries-outer-inner img {
    width: 100%;
    height: auto;
}

.worries-solution-outer {
    width: 100%;
    height: auto;
    background: url(../../images/zero/worries-bg.png) no-repeat;
    background-size: cover;
    background-position: center;
    overflow: hidden;

}
.worries-solution-outer-inner {
    margin: 80px auto;
    max-width: 1200px;
    width: calc(100% - 20px);
}
.worries-solution-outer-inner img {
    margin: 0 auto;
    display: block;
    max-width: 900px;
    width: 100%;
    text-align: center;
}


/*
* reason
*/
.reason {
    padding-top: 80px;
    width: 100%;
    height: auto;
}

.reason--ttl {
    position: relative;
    margin-top: 30px;
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    color: #042DA0;
    text-align: center;
}

.reason--ttl::before {
    position: relative;
    top: -15px;
    margin: 0 auto;
    content: '';
    display: block;
    width: 250px;
    border-bottom: 1px solid #8ECEFF;
}
.reason-outer {
    margin-top: 80px;
    position: relative;
    width: 100%;
    height: auto;
}
.reason-outer-inner {
    position: relative;
    top: 0;
    left: 0;
    padding: 80px 0 120px 0;
    width: 100%;
    height: auto;
    clip-path: inset(0);
}
.reason-outer-inner-bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../../images/zero/reason-bg.png) no-repeat;
    background-size: cover;
    background-position: center;
    z-index: -1;
}
.reason__contents {
    margin: 100px auto 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
    display: flex;
    justify-content: space-between;
    gap: 40px;
}


.reason__contents img {
    max-width: 530px;
    width: 90%;
    height: auto;
    object-fit: contain;
    object-position: top;
}

.reason__contents-outer {
    width: 60%;
}

.reason__contents-outer--ttl {
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    line-height: 1.4;
    color: #FFFFFF;
}
.reason__contents-outer--txt {
    margin-top: 20px;
    font-size: clamp(1.25rem,2.6vw,1.5rem);
    font-weight: 900;
    line-height: 1.4;
    color: #FFFF2F;
}
.reason__contents-outer--txt-sub {
    display: inline-block;
    margin-top: 20px;
    margin-bottom: 20px;
    font-size: 18px;
    font-weight: normal;
    line-height: 1.2;
    color: #FFFFFF;
}
.reason__contents-outer-list {
    margin-top: 20px;
    padding: 20px;
    display: flex;
    justify-content: start;
    align-items: center;
    gap: 20px;
    border-radius: 10px;
    background-color: #FFFFFF;
}
.reason__contents-outer-list--img {
    width: 53px !important;
    height: auto !important;
}
.reason__contents-outer-list--txt {
    font-size: 18px;
    font-weight: 900;
    color: #008AA3;
    line-height: 1.4;
}
.reason__contents-outer-list--txt span {
    display: block;
    font-size: 12px;
    color: #000000;
}


/*
* largest
*/
.largest {
    width: 100%;
    height: 100%; 
}
.largest-wrap {
    position: relative;
    padding: 140px 0 100px 0;
    width: 100%;
    background-color: #F5F9FC;
}
.largest-wrap::before {
    position: absolute;
    top: -50px;
    left: 50%;
    content: url(../../images/zero/largest-icon.svg);
    transform: translateX(-50%);
}

.largest-wrap--ttl {
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    color: #031F88;
    text-align: center;
    line-height: 1.6;
}
.largest-wrap--ttl-b {
    padding: 4px;
    color: #FFFFFF;
    background-color: #FF3C3C;
    border-radius: 5px;
}
.largest-wrap--ttl-r {
    color: #FF3C3C;
}
.largest-outer {
    margin: 80px auto 80px auto;
    max-width: 1200px;
    width: calc(100% - 20px);
    display: flex;
    justify-content: center;
    gap: 40px;
}
.largest-outer--img {
    max-width: 530px;
    width: 45%;
    object-fit: contain;
    object-position: top;
}
.largest-outer__box {
    width: 100%;
}
.largest-outer__box--ttl {
    margin-top: 60px;
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    line-height: 1.6;
}
.largest-outer__box--ttl-b {
    padding: 4px;
    color: #FFFFFF;
    background-color: #FF3C3C;
    border-radius: 5px;
}
.largest-outer__box--txt {
    margin-top: 60px;
    font-size: clamp(1.1rem,2.6vw,1.5rem);
    line-height: 1.4;
}

/*
* achievements
*/
.achievements {
    padding: 80px 0;
    width: 100%;
    height: auto;
    background-color: #F5F9FC;
}
.achievements--ttl {
    position: relative;
    margin-top: 30px;
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    color: #042DA0;
    text-align: center;
}
.achievements--ttl::before {
    position: relative;
    top: -15px;
    margin: 0 auto;
    content: '';
    display: block;
    width: 250px;
    border-bottom: 1px solid #8ECEFF;
}
.achievements-outer {
    margin: 60px auto 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
}
.achievements-outer__box img {
    width: 100%;
    height: auto;
}


/*
* comparison
*/

.comparison {
    padding: 80px 0;
    width: 100%;
    height: auto;
    background-color: #F5F9FC;
}
.comparison--ttl {
    position: relative;
    margin-top: 30px;
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    color: #042DA0;
    text-align: center;
}
.comparison--ttl::before {
    position: relative;
    top: -15px;
    margin: 0 auto;
    content: '';
    display: block;
    width: 250px;
    border-bottom: 1px solid #8ECEFF;
}
.comparison-outer {
    margin: 60px auto 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
}
.comparison-outer img {
    width: 100%;
    height: auto;
}

.comparison-outer--txt {
    margin-top: 80px;
    text-align: center;
    font-size: 20px;
    font-weight: 600;
    line-height: 1.4;
}
.comparison-outer--ad {
    margin-top: 40px;
}


/*
* why
*/
.why {
    padding: 80px 0;
    width: 100%;
    height: auto;
    background-color: #F5F9FC;
}
.why--ttl {
    position: relative;
    margin-top: 30px;
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    color: #042DA0;
    text-align: center;
}
.why--ttl::before {
    position: relative;
    top: -15px;
    margin: 0 auto;
    content: '';
    display: block;
    width: 250px;
    border-bottom: 1px solid #8ECEFF;
}
.why-outer {
    margin: 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
}
.why-outer--img {
    margin-top: 30px;
    width: 100%;
    height: auto;
}


/*
* industry
*/
.industry {
    width: 100%;
    height: auto;
}
.industry-outer {
    margin: 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
}
.industry-outer--ttl {
    margin-top: 100px;
    text-align: center;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.4;
}
.industry-outer--ttl span {
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
}

.industry-outer__list {
    margin: 60px auto;
    max-width: 1200px;
    width: calc(100% - 20px);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px;
}

.industry-outer__list--item {
    padding: 30px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 228px;
    width: 100%;
    height: auto;
    box-shadow: 0 0 14px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
}
.industry-outer__list--item img {
    width: 138px;
    height: auto;  
}
.industry-outer__list--item span {
    font-size: 20px;
    font-weight: 600;
}



/*
* cta
*/
.cta {
    padding: 80px 0;
    width: 100%;
    height: auto;
    background: url(../../images/zero/cta-bg.png) no-repeat;
    background-size: cover;
    background-position: center;
    overflow: hidden;
}

.cta-outer { 
    margin: 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);

}

.cta-outer--ttl {
    color: #FFFFFF;
    font-weight: 900;
    font-size: clamp(1.25rem,2.6vw,2rem);
    text-align: center;
    line-height: 1.4;
}

.cta-outer__list {
    margin-top: 40px;
    display: flex;
    justify-content: center;
    gap: 40px;
}

.cta-outer__list--item {
    display: flex;
    flex-direction: column;
    text-align: center;
    gap: 20px;
}
.cta-outer__list--item img {
    width: 100px;
    height: 100px;
}
.cta-outer__list--item span {
    color: #FFFFFF;
    font-weight: 600;
    font-size: 18px;
    line-height: 1.4;
}

.cta-outer__links {
    display: flex;
    justify-content: center;
    gap: 40px;
}

.cta-outer__links--download,.cta-outer__links--contact {
    margin-top: 60px;
    position: relative;
    padding: 24px 0;
    max-width: 420px;
    width: 100%;
    text-align: center;
    font-size: 24px;
    font-weight: 900;
    border-radius: 50px;
    border: 3px solid #FFFFFF;
    box-shadow: 0px 3px 10px #000000;
}
.cta-outer__links--download {
    color: #FFFFFF;
    background-color: #FD1818;

}
.cta-outer__links--contact {
    color: #03238B;
    background-color: #FFFFFF;
}

.cta-outer__links--download::before {
    content: url(../../images/zero/cta-button01.svg);
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
}
.cta-outer__links--contact::before {
    content: url(../../images/zero/cta-button02.svg);
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
}


/*
* contact
*/
.contact {
    width: 100%;
    height: auto;
    background-color: #F5F9FC;
    overflow: hidden;
}

.contact--ttl {
    margin-top: 80px;
    font-size: clamp(1.5rem,4.1vw,2.5rem);
    font-weight: 900;
    color: #031F88;
    text-align: center;
}

.contact iframe {
    margin: 80px auto;
    max-width: 830px;
    width: calc(100% - 20px) !important;
}


/*
* footer
*/
.footer {
    padding: 40px 0;
    width: 100%;
    height: auto;
    background-color: #263239;
}
.footer-outer {
    margin: 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
    display: flex;
    justify-content: space-between;
}
.footer-outer__box {
    
}
.footer-outer__box--logo {

}
.footer-outer__box--company {
    margin-top: 20px;
    display: block;
    font-size: 16px;
    font-weight: 900;
    color: #FFFFFF;
}
.footer-outer__box--txt {
    margin-top: 10px;
    display: block;
    font-size: 16px;
    color: #FFFFFF;
    line-height: 1.4;
}

.footer-outer__links-item a {
    font-size: 16px;
    color: #FFFFFF;
}
.footer--copy {
    margin-top: 30px;
    display: block;
    font-size: 16px;
    text-align: center;
    color: #FFFFFF;
}

@media screen and (max-width: 1200px) { 
    .fv {
        height: 70%;
    }
}

@media screen and (max-width: 768px) {
    .fv {
        max-height: unset;
        height: auto;
        background: url(../../images/zero/fv-bg-sp.png) no-repeat;
        background-size: 100% 90%;
    }
    .fv-outer {
        flex-direction: column;
        align-items: center;
        gap: 0;
    }
    .fv-outer--img {
        max-width: 580px;
        width: 100%;
    }
    
    .fv-outer__box {
        max-width: 580px;
        width: 100%;
    }
    .fv-outer__box--txt {
        display: none;
    }


    /*
    * performance
    */
    .performance--txt {
        margin: 0px 0 40px 0;
    }
    .performance-client-wrap--logo {
        width: 2000px;
        
    }
    .performance-client-wrap--logo-bottom {
        width: 2000px;
        
    }


    /*
    * worries
    */
    .worries {
        width: 100%;
        height: auto;
    }

    .worries--ttl {
        padding: 40px 0;
        text-align: center;
        font-size: clamp(1.5rem,4.1vw,2.5rem);
        font-weight: 900;
        background-color: #042DA0;
        color: #FFFFFF;
    }

    .worries-outer {
        padding-top: 80px;
        width: 100%;
        height: auto;
        background-color: #FFFF2F;

    }

    .worries-outer-inner {
        margin: 0 auto;
        max-width: 1200px;
        width: calc(100% - 20px);
    }

    .worries-outer-inner img {
        width: 100%;
        height: auto;
    }

    .worries-solution-outer {
        width: 100%;
        height: auto;
        background: url(../../images/zero/worries-bg.png) no-repeat;
        background-size: cover;
        background-position: center;
        overflow: hidden;

    }
    .worries-solution-outer-inner {
        margin: 40px auto;
    }


    /*
    * reason
    */
    .reason {
        padding-top: 40px;
    }
    .reason-outer {
        margin-top: 40px;
    }
    .reason-outer-inner {
        padding: 40px 0 40px 0;
    }
    .reason__contents {
        margin: 80px auto;
        flex-direction: column-reverse;
        align-items: center;
        justify-content: center;
    }
    .reason__contents img {
        max-width: unset;
        width: 100%;
        height: auto;
    }
    .reason__contents-r {
        flex-direction: column;
    }
    .reason__contents-outer {
        width: 100%;
    }
    .reason__contents-outer--ttl {
        text-align: center;
    }
    .reason__contents-outer--txt {
        text-align: center;
    }
    .reason__contents-outer--txt-sub {
        display: block;
        text-align: center;
    }


    /*
    * largest
    */
    .largest-wrap {
        padding: 140px 0 40px 0;
    }
    .largest-outer {
        flex-direction: column-reverse;
        align-items: center;
        gap: 0;
    }
    .largest-outer--img {
        width: 100%;
        
    }
    .largest-outer__box {
        width: 100%;
    }
    .largest-outer__box--txt {
        margin-top: 20px;
    }
    .largest-outer__box--ttl {
        margin-top: unset;
    }

    /*
    * achievements
    */
    .achievements {
        padding: 40px 0;
    }
    .achievements-outer {
        margin: 20px auto 0 auto;
    }


    /*
    * comparison
    */
    .comparison {
        padding: unset;
    }
    .comparison-outer {
        margin: 60px auto 40px auto;
    }
    .comparison-outer--txt {
        margin-top: 40px;
    }
    .comparison-outer img {
        margin: 20px auto 0 auto;
        /* padding-bottom: 40px; */
        display: block;
        max-width: 580px;
    }
    


    /*
    * industry
    */
    .industry-outer__list {
        gap: 10px;
    }
    .industry-outer__list--item {
        padding: 20px 0;
        max-width: 150px;
        width: 30%;
        gap: 4px;
    }
    .industry-outer__list--item img {
        width: 80px;  
    }
    .industry-outer__list--item span {
        font-size: 16px;
    }
        

    /*
    * cta
    */
    .cta-outer__links {
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }
    .cta-outer__list {
        margin-top: 40px;
        display: flex;
        justify-content: center;
        gap: 10px;
    }
    .cta-outer__list--item {
        align-items: center;
        gap: 10px;
    }
    .cta-outer__list--item img {
        width: 60px;
        height: 60px;
    }
    .cta-outer__list--item span  {
        font-size: clamp(0.65rem, 2.9vw, 1.1rem);
    }


    /*
    * contact
    */
    .contact--ttl {
        margin-top: 40px;
    }

    .contact iframe {
        margin: 40px auto;
    }


    /*
    * footer
    */
    .footer-outer {
        flex-direction: column;
        gap: 20px;
    }   
}


/*
* Download
*/
.download {
    padding: 80px 0;
    width: 100%;
    background-color: #EFF3FF;
}
.download-outer {
    margin: 0 auto;
    max-width: 1200px;
    width: calc(100% - 20px);
}
.download--ttl {
    font-size: clamp(1.5rem ,2.6vw,2rem);
    text-align: center;
    color: #031F88;
    font-weight: 900;
}
.download--txt {
    margin-top: 40px;
    font-size: 18px;
    line-height: 1.4;
    font-weight: 600;
    text-align: center;
}
.download-outer__box {
    margin-top: 80px;
    display: flex;
    justify-content: center;
    gap: 20px;
}
.download-outer__box-inner--img {
    width: 100%;
}
.download-outer__box iframe {
    width: 50%;
}

@media screen and (max-width: 768px) {
    .download-outer__box {
        align-items: center;
        flex-direction: column;
    }
    .download-outer__box {
        margin-top: 40px;
    }
}