@charset "utf-8";
.wid5{width:5%}
.wid10{width:10%}
.wid15{width:15%}
.wid20{width:20%}
.wid25{width:25%}
.wid30{width:30%}
.wid33{width:33.3333%}
.wid35{width:35%}
.wid40{width:40%}
.wid45{width:45%}
.wid50{width:50%}
.wid55{width:55%}
.wid60{width:60%}
.wid65{width:65%}
.wid70{width:70%}
.wid75{width:75%}
.wid80{width:80%}
.wid85{width:85%}
.wid90{width:90%}
.wid95{width:95%}

.mb0 { margin-bottom:0px !important; }
.mb5 { margin-bottom:5px !important; }
.mb10 { margin-bottom:10px !important; }
.mb15 { margin-bottom:15px !important; }
.mb20 { margin-bottom:20px !important; }
.mb25 { margin-bottom:25px !important; }
.mb30 { margin-bottom:30px !important; }
.mb35 { margin-bottom:35px !important; }
.mb40 { margin-bottom:40px !important; }
.mb45 { margin-bottom:45px !important; }
.mb50 { margin-bottom:50px !important; }
.mb60 { margin-bottom:60px !important; }
.mb70 { margin-bottom:70px !important; }
.mb80 { margin-bottom:80px !important; }
.mb90 { margin-bottom:90px !important; }
.mb100 { margin-bottom:100px !important; }
.ml10 { margin-left:10px !important; }
.ml20 { margin-left:20px !important; }
.ml30 { margin-left:30px !important; }
.ml40 { margin-left:40px !important; }
.ml50 { margin-left:50px !important; }
.mr10 { margin-right:10px !important; }
.mr15 { margin-right:15px !important; }
.mr20 { margin-right:20px !important; }
.mr30 { margin-right:30px !important; }
.mr40 { margin-right:40px !important; }
.mr50 { margin-right:50px !important; }
.mr60 { margin-right:60px !important; }
.mr70 { margin-right:70px !important; }
.mt0 { margin-top:0px !important; }
.mt10 { margin-top:10px !important; }
.mt20 { margin-top:20px !important; }
.mt30 { margin-top:30px !important; }
.mt40 { margin-top:40px !important; }
.mt50 { margin-top:50px !important; }
.mt60 { margin-top:60px !important; }
.mt70 { margin-top:70px !important; }
.mt80 { margin-top:80px !important; }



/*APP×BOOSTページ専用CSSここから*/

.app-boost_wrap {
    font-family: "Noto Sans JP", sans-serif;
    color: #3e3a39;
}

.app-boost_wrap *,
.app-boost_wrap *::before,
.app-boost_wrap *::after {
    box-sizing: border-box;
}

.app-boost_wrap img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

.app-boost_wrap a {
    text-decoration: none;
}
.app-boost_wrap a:hover {
    text-decoration: none;
    color: #fff;
    opacity: 1;
    filter: brightness(1.15);
}

.app-boost_wrap button {
    font-family: inherit;
}

.app-boost_inner {
    width: min(86.5%, 142rem);
    margin: 0 auto;
}

.app-boost_inner-narrow {
    width: min(78.5%, 129.2rem);
}

.app-boost_section {
    position: relative;
}

.app-boost_visual {
    overflow: hidden;
    min-height: 62.05rem;
    background: url("../../solution/app-boost/common/img/top_back.png") center top / cover no-repeat;
}

.app-boost_visualInner {
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    width: min(100%, 170.4rem);
    min-height: 62.05rem;
    margin: 0 auto;
    padding: 4rem 0 4.26rem 15%;
}

@media screen and (max-width: 1460px) {
    .app-boost_visualInner {
        min-height: auto;
    }
    .app-boost_visual {
        min-height: 50rem;
    }
}

@media screen and (max-width: 1200px) {
    .app-boost_visualInner {
        padding-left: 5%;
    }
    .app-boost_visualImage {
        min-width: 80vw;
    }
}

.app-boost_visualText {
    position: relative;
    z-index: 2;
    width: 70rem;
    max-width: 55%;
    text-align: center;
    font-weight: 700;
    display: block;
}

.app-boost_visualLead,
.app-boost_visualSub {
    margin: 0;
    font-size: clamp(2.698rem, 2.1vw, 3.763rem);
    line-height: 1.35;
    text-align: left;
    color: #3e3a39;
    display: block;
}

.app-boost_visualTitle {
    margin: 0.71rem 0 1.136rem;
    color: #eb6c00;
    font-size: clamp(3.834rem, 3.6vw, 6.035rem);
    font-weight: 700;
    line-height: 1.15;
    text-align: left;
    display: block;
}

.app-boost_visualCopy {
    margin: 5rem 0 2.5rem;
    color: #3e3a39;
    font-size: clamp(2.343rem, 1.85vw, 3.479rem);
    line-height: 1.85;
    text-align: left;
}

.app-boost_visualCopy span {
    position: relative;
    display: inline-block;
    color: #214d87;
    font-size: 1.55em;
    line-height: .95;
    text-align: left;
}


.app-boost_visualCopy02 {
    margin-top: 0;
    /*text-align: right;
    padding-right: clamp(0rem, 5vw, 6rem);*/
}

.app-boost_visualCopy span.app-boost_visualCopy_e_box {
    position: relative;
}

.app-boost_visualCopy span.app-boost_visualCopy_e {
    color: #214d87;
    font-size: .33em;
    position: absolute;
    top: -1.633rem;
    left: 50%;
    transform: translateX(-50%);
}

.app-boost_visualCopy span.app-boost_visualCopy_e::first-letter {
    color: #eb6c00;
}

.app-boost_visualImage {
    position: absolute;
    top: 0;
    right: -20rem;
    width: min(70vw, 110rem);
}

.app-boost_ctaList {
    display: flex;
    align-items: center;
    gap: 0.71rem;
}

.app-boost_ctaList-center {
    justify-content: center;
}

.app-boost_cta {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    width: min(100%, 32.66rem);
    min-height: 7.1rem;
    padding: 1.42rem 5rem 1.42rem 2.6rem;
    border-radius: 0.3976rem;
    color: #fff;
    font-size: 1.775rem;
    font-weight: 700;
    line-height: 1.25;
    transition: opacity .2s ease, transform .2s ease;
}

.app-boost_cta span {
    white-space: nowrap;
}

.app-boost_cta::after {
    position: absolute;
    right: 1.917rem;
    top: 50%;
    width: 2rem;
    height: 1.6rem;
    background: url("../../solution/app-boost/common/img/arrow_w.png") center / contain no-repeat;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
    content: "";
}

.app-boost_cta:hover::after {
    transform: translateY(-50%) translateX(0.6rem);
}


.app-boost_cta img {
    flex: 0 0 auto;
    width: 3.124rem;
    max-height: 3.124rem;
    object-fit: contain;
}

.app-boost_cta-orange {
    background: #ed6c00;
}

.app-boost_cta-blue {
    background: #224e87;
}

.app-boost_tel {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0 0.639rem;
    margin-top: 1.775rem;
    color: #224e87;
    font-family: "Inter", "Noto Sans JP", sans-serif;
    font-weight: 700;
}

.app-boost_tel img {
    width: 2.485rem;
}

.app-boost_tel span {
    font-size: 3.8rem;
    line-height: 1;
    letter-spacing: 2px;
}

.app-boost_tel a {
    color: #214d87;
}

.app-boost_tel a:hover {
    color: #214d87;
}

.app-boost_tel small {
    flex-basis: 100%;
    color: #3e3a39;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.221rem;
    font-weight: 600;
    line-height: 1.4;
}

.app-boost_section01 {
    padding: 6.958rem 0 6.816rem;
    background: #f1f1f1;
}

.app-boost_section01::after {
    position: absolute;
    bottom: -5.68rem;
    left: 50%;
    z-index: 2;
    width: 22.72rem;
    height: 5.68rem;
    background: #f1f1f1;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    transform: translateX(-50%);
    content: "";
}

.app-boost_sectionTitle,
.app-boost_largeTitle {
    margin: 0 0 5.68rem;
    color: #3e3a39;
    font-size: clamp(2.698rem, 2.3vw, 4.047rem);
    font-weight: 700;
    line-height: 1.35;
    text-align: center;
}

.app-boost_largeTitle {
    margin-bottom: 8rem;
}

.app-boost_sectionTitle {
    font-size: clamp(2.556rem, 2vw, 3.195rem);
}

.app-boost_sectionTitle::after {
    display: block;
    width: 5.112rem;
    height: 0.3976rem;
    margin: 1.633rem auto 0;
    background: #224e87;
    content: "";
}

.app-boost_largeTitle span,
.app-boost_solutionTitle span {
    position: relative;
    display: inline-block;
    color: #eb6c00;
    font-family: "Inter", "Noto Sans JP", sans-serif;
    font-size: 1.35em;
    font-weight: 700;
    line-height: 1;
}

.app-boost_largeTitle span::after,
.app-boost_solutionTitle span::after {
    display: block;
    width: 80%;
    margin-left: 10%;
    height: 0.3976rem;
    margin-top: 1rem;
    background: #eb6c00;
    content: "";
}

.app-boost_nayamiList,
.app-boost_kaiketuList {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.491rem;
}

.app-boost_nayamiItem,
.app-boost_kaiketuItem {
    display: flex;
    flex-direction: column;
    text-align: center;
}

.app-boost_balloon {
    position: relative;
    display: flex;
    flex: 1 0 auto;
    align-items: center;
    justify-content: center;
    min-height: 10.93rem;
    padding: 1.42rem;
    border-radius: 0.8804rem;
    color: #fff;
    font-size: clamp(1.42rem, 1vw, 2.2rem);
    font-weight: 700;
    line-height: 1.85;
}



.app-boost_balloon-gray {
    background: #615d5d;
}

.app-boost_balloon-blue {
    background: #224e87;
}

.app-boost_nayamiItem img,
.app-boost_kaiketuItem img {
    width: min(100%, 22.72rem);
    margin: 0 auto;
    margin-top: 5px;
}

.app-boost_nayamiItem p,
.app-boost_kaiketuItem p {
    margin: 0.426rem 0 0;
    color: #224e87;
    font-size: 2.059rem;
    font-weight: 700;
}

.app-boost_solution {
    padding: 7.242rem 0 6.39rem;
    background: #fff;
}

.app-boost_solutionTitle {
    margin: 0 0 6.532rem;
    color: #3e3a39;
    font-size: clamp(2.698rem, 2.3vw, 4.047rem);
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
}

.app-boost_about {
    overflow: hidden;
    padding: 6.958rem 0 8.094rem;
    background: #bde5ff url("../../solution/app-boost/common/img/about_back.png") center top / cover no-repeat;
}

.app-boost_aboutGrid {
    display: grid;
    grid-template-columns: .98fr 1.05fr;
    align-items: center;
    gap: 7.1rem;
    width: min(100%, 117rem);
    margin: 0 auto;
}

.app-boost_aboutText {
    text-align: center;
}

.app-boost_aboutText p {
    margin: 0 auto 3.124rem;
    max-width: 60.35rem;
    font-size: 2rem;
    line-height: 1.75;
    text-align: left;
}

.app-boost_aboutText span,
.app-boost_aboutLogo p span,
.app-boost_reasonItem p span,
.app-boost_faqItem strong {
    color: #eb6c00;
}

.app-boost_cycle {
    width: 39.48rem;
}

.app-boost_aboutLogo {
    padding-top: 1.42rem;
}

.app-boost_aboutLogo img {
    display: block;
    width: 44.02rem;
    margin: 0 auto 4.402rem;
}

.app-boost_aboutLogo p {
    margin: 0;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.75;
}

.app-boost_aboutMessage {
    width: min(100%, 117rem);
    margin: 4.686rem auto 6.106rem;
    padding: 2.84rem 4.26rem;
    border-radius: 1.278rem;
    background: rgba(255,255,255,.4);
    font-size: clamp(2.04rem, 1.56vw, 2.94rem);
    font-weight: 700;
    line-height: 1.75;
    text-align: center;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1);
}

.app-boost_aboutMessage span {
    font-size: 1.38em;
    color: #224e87;
}

.app-boost_tools {
    padding: 8.378rem 0 8.52rem;
    background: #fff;
}

.app-boost_toolList {
    display: grid;
    gap: 1.065rem;
}

.app-boost_toolItem {
    display: grid;
    grid-template-columns: 35% 1fr;
    gap: 4.97rem;
    padding: 2.698rem 3.266rem 2.698rem 2.84rem;
    padding-left: 0;
    border: 0.0852rem solid #e6e6e6;
    border-radius: 1.278rem;
    background: #fff;
}

.app-boost_toolLogo p,
.app-boost_toolLogo h3,
.app-boost_toolText p,
.app-boost_toolText h4 {
    margin: 0;
}

.app-boost_toolLogo {
    border-left: 10px solid #214d87;
    padding-left: 30px;
}

.app-boost_toolLogo p {
    color: #224e87;
    font-size: 1.917rem;
    font-weight: 700;
}

.app-boost_toolLogo h3 {
    margin-top: 0.568rem;
    color: #224e87;
    font-family: "Inter", "Noto Sans JP", sans-serif;
    font-size: 3.124rem;
    font-weight: 700;
    line-height: 1.15;
}

.app-boost_toolLogo small {
    font-family: "Noto Sans JP", sans-serif;
    font-size: .55em;
    white-space: nowrap;
}

.app-boost_toolLogo img {
    width: 44.59rem;
    margin-top: 2.414rem;
}

.app-boost_toolText {
    padding-top: 0.639rem;
}

.app-boost_toolText p {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.8;
}

.app-boost_toolText h4 {
    margin-top: 1.917rem;
    color: #224e87;
    font-size: 2.414rem;
    font-weight: 700;
}

.app-boost_toolText ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0.497rem;
    margin: 0.852rem 0 0;
    padding: 0;
    list-style: none;
}

.app-boost_toolText li {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24%;
    padding: 0.781rem 1.136rem;
    border: 0.1704rem solid #224e87;
    border-radius: 0.781rem;
    color: #224e87;
    font-size: 1.7rem;
    font-weight: 700;
    line-height: 1.35;
    text-align: center;
}

.app-boost_case {
    padding: 7.384rem 0 7.1rem;
    background: linear-gradient(180deg, #fff 0%, #a9d0ff 100%);
}

.app-boost_caseList {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 2.13rem;
}

.app-boost_caseItem {
    position: relative;
    padding: 6.674rem 3.479rem 2.982rem;
    border-radius: 1.562rem;
    background: #fff;
}

.app-boost_caseItem h3 {
    position: absolute;
    left: 50%;
    top: -3.834rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 84%;
    min-height: 8rem;
    margin: 0;
    border-radius: 0.8804rem;
    background: #224e87;
    color: #fff;
    font-size: 2.059rem;
    font-weight: 700;
    line-height: 1.45;
    text-align: center;
    transform: translateX(-50%);
}

.app-boost_caseItem dl {
    margin: 0;
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}

.app-boost_caseItem dl > div {
    display: grid;
}

.app-boost_caseItem dt {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 6.248rem;
    height: 6.248rem;
    margin: 0 1.562rem 1.775rem 0;
    margin-bottom: 0;
    border-radius: 50%;
    background: #f1f1f1;
    color: #224e87;
    font-size: 1.491rem;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
}

.app-boost_caseItem_first dt {
    background: #ed6c00;
    color: #fff;
}

.app-boost_caseItem dd {
    padding-top: 0.497rem;
    font-size: 1.5rem;
    line-height: 1.65;
    overflow: hidden;
    flex: 1;
}

.app-boost_caseItem strong {
    color: #eb6c00;
    font-size: 2rem;
    line-height: 1.45;
}

.app-boost_docCta {
    display: grid;
    justify-items: center;
    margin-top: 5.538rem;
}

.app-boost_docCta > img {
    width: 39.5rem;
    margin-bottom: -0.497rem;
    position: relative;
    z-index: 2;
}

.app-boost_docCta .app-boost_cta {
    width: 57.5rem;
    min-height: 8.5rem;
    font-size: 2.343rem;
}

.app-boost_reason {
    padding: 7.668rem 0 5.964rem;
    background: #fff;
}

.app-boost_reasonList {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.852rem;
}

.app-boost_reasonItem {
    position: relative;
    min-height: 34.08rem;
    padding: 4.544rem 5.396rem 3.266rem;
    border-radius: 1.278rem;
    background: #f0f0f0;
}

.app-boost_reasonItem::before {
    position: absolute;
    top: 0;
    left: 5rem;
    width: 8.662rem;
    height: 0.5112rem;
    background: #224e87;
    content: "";
}

.app-boost_reasonItem > span {
    display: block;
    color: #224e87;
    font-family: "Inter", sans-serif;
    font-size: 6.958rem;
    font-weight: 300;
    line-height: 1;
}

.app-boost_reasonItem img {
    position: absolute;
    top: 4.686rem;
    right: 5.68rem;
    width: 11.79rem;    
}
/* タブレット〜スマホサイズ向け（1024px以下） */
@media screen and (max-width: 1024px) {
    .app-boost_reasonItem img {
        width: 10rem;    
    }
}

.app-boost_reasonItem h3 {
    margin: 3.408rem 0 2.13rem;
    color: #224e87;
    font-size: 2.769rem;
    font-weight: 700;
    line-height: 1.35;
}

.app-boost_reasonItem p {
    margin: 0;
    font-size: 1.732rem;
    font-weight: 700;
    line-height: 1.7;
}

.app-boost_flow {
    padding: 6.674rem 0 0;
    background: #fff;
}

.app-boost_flowList {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.633rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.app-boost_flowList li {
    position: relative;
    text-align: center;
}

.app-boost_flowList li:not(:last-child)::after {
    position: absolute;
    top: 9.674rem;
    right: -1.562rem;
    width: 1.988rem;
    height: 4.118rem;
    background: url("../../solution/app-boost/common/img/flow_arrow.png") center / contain no-repeat;
    content: "";
}

.app-boost_flowList img {
    width: 22rem;
}

.app-boost_flowList p {
    margin: 1.562rem 0 0;
    font-size: 1.732rem;
    font-weight: 700;
    line-height: 1.65;
}

.app-boost_consult {
    position: relative;
    min-height: 24.85rem;
    margin-top: 5.68rem;
    text-align: center;
}

.app-boost_consultLabel {
    display: block;
    width: 48rem;
    margin: 0 auto -0.213rem;
}

.app-boost_consult .app-boost_cta {
    width: 57.5rem;
    min-height: 7.1rem;
    margin: 0 auto;
    font-size: 2.343rem;
    min-height: 8.5rem;
}

.app-boost_consult .app-boost_cta em {
    padding: 0.2556rem 0.8804rem 0.3976rem;
    border: 0.1704rem solid #fff;
    border-radius: 0.3976rem;
    font-style: normal;
}

.app-boost_consultPerson {
    position: absolute;
    left: calc(50% + 31.5rem);
    bottom: -6.5rem;
    z-index: 3;
    width: 24rem;
}

@media screen and (max-width: 1024px) {
    .app-boost_consultPerson {
    bottom: -4.1rem;
}
}

.app-boost_faq {
    padding: 6.532rem 0 7.952rem;
    background: #224e87;
}

.app-boost_sectionTitle-white {
    color: #fff;
}

.app-boost_sectionTitle-white::after {
    background: #fff;
}

.app-boost_inner-faq {
    width: min(72.5%, 121.6rem);
}

.app-boost_faqBox {
    padding: 5.112rem 4.828rem 5.396rem;
    border-radius: 0.8804rem;
    background: #fff;
}

.app-boost_faqItem {
    margin: 0;
    border-bottom: 0.0852rem solid #3e3a39;
}

.app-boost_faqItem dt {
    margin: 0;
}

.app-boost_faqItem button {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 6.674rem;
    padding: 1.136rem 5.396rem 1.136rem 0;
    border: 0;
    background: transparent;
    color: #3e3a39;
    font-size: 1.775rem;
    font-weight: 700;
    line-height: 1.5;
    text-align: left;
    cursor: pointer;
}

.app-boost_faqItem button::before,
.app-boost_faqItem button::after {
    position: absolute;
    right: 1.136rem;
    top: 50%;
    width: 1.704rem;
    height: 0.2556rem;
    background: #224e87;
    transform: translateY(-50%);
    content: "";
}

.app-boost_faqItem button::after {
    transform: translateY(-50%) rotate(90deg);
}

.app-boost_faqItem.is-open button::after {
    opacity: 0;
}

.app-boost_faqItem button span,
.app-boost_faqItem dd > span {
    flex: 0 0 5.538rem;
    color: #224e87;
    font-family: "Inter", sans-serif;
    font-size: 3.195rem;
    font-weight: 700;
}

.app-boost_faqItem dd {
    display: flex;
    align-items: flex-start;
    max-height: 0;
    overflow: hidden;
    margin: 0;
    padding: 0 2.414rem 0 0;
    background: #fff3df;
    transition: max-height 0.3s ease, padding 0.3s ease, margin 0.3s ease;
}

.app-boost_faqItem.is-open dd {
    margin: 0 0 1.988rem;
    padding: 1.207rem 2.414rem 1.349rem 0;
}

.app-boost_faqItem.is-open dd {
    display: flex;
}

.app-boost_faqItem dd > span {
    padding-left: 2.13rem;
    color: #eb6c00;
}

.app-boost_faqItem dd p {
    margin: 0;
    padding-top: 0.639rem;
    font-size: 1.59rem;
    font-weight: 700;
    line-height: 1.65;
}

.app-boost_sideCta {
    position: fixed;
    right: -150px;
    top: 30%;
    z-index: 30;
    display: grid;
    gap: 0.355rem;
    transform: translateY(-50%);
    transition: right 0.5s ease;
}
.app-boost_sideCta.show {
    right: 0;
}

.app-boost_sideCta a {
    display: block;
    width: 13.35rem;
    transition: opacity .2s ease;
}

.app-boost_sideCta a:hover {
    opacity: .86;
}

.app-boost_about_blue {
    color: #214d87 !important;
}

@media screen and (max-width: 1024px) {
    .app-boost_inner,
    .app-boost_inner-narrow,
    .app-boost_inner-faq {
        width: min(92%, 82.36rem);
    }

    .app-boost_visual {
        min-height: auto;
    }

    .app-boost_visualInner {
        min-height: 49.7rem;
        padding: 4.26rem 4% 3.55rem;
    }

    .app-boost_visualText {
        width: 100rem;
        max-width: 100%;
    }

    .app-boost_visualImage {
        right: -12.78rem;
        width: 75%;
    }

    .app-boost_visualCopy {
        margin-top: 4.26rem;
    }
    .app-boost_visualCopy02 {
        margin-top: 0;
    }

    .app-boost_ctaList {
        flex-wrap: wrap;
        justify-content: center;
    }

    .app-boost_nayamiList,
    .app-boost_kaiketuList,
    .app-boost_caseList {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        row-gap: 3.124rem;
    }

    .app-boost_caseList {
        grid-template-columns: repeat(1, minmax(0, 1fr));
    }

    .app-boost_caseItem {
        margin-bottom: 50px;
    }

    .app-boost_aboutGrid,
    .app-boost_toolItem {
        grid-template-columns: 1fr;
        gap: 2.84rem;
    }

    .app-boost_toolItem {
        padding: 2.414rem;
    }

    .app-boost_toolLogo img {
        width: min(100%, 34.08rem);
    }

    .app-boost_flowList {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        row-gap: 2.84rem;
    }

    .app-boost_consultPerson {
        left: calc(50% + 24rem);
        width: 14rem;
    }

    .app-boost_sideCta a {
        width: 10.22rem;
    }

    .app-boost_aboutLogo img {
        display: none;
    }

    .app-boost_cycle {
        display: none;
    }
}

@media screen and (max-width: 740px) {
    .app-boost_inner,
    .app-boost_inner-narrow,
    .app-boost_inner-faq {
        width: min(90%, 39.76rem);
    }

    .app-boost_visual {
        background-position: center top;
    }

    .app-boost_visualInner {
        
        min-height: auto;
        padding: 3.124rem 5% 3.55rem;
        padding-top: 0;
        flex-direction: column-reverse;
    }

    .app-boost_visualText {
        width: 100%;
        max-width: none;
    }

    .app-boost_visualLead,
    .app-boost_visualSub {
        font-size: 2rem;
    }

    .app-boost_visualTitle {
        font-size: 2.8rem;
    }

    .app-boost_visualImage {
        position: relative;
        right: auto;
        top: auto;
        width: 100%;
        margin: 0;
    }

    .app-boost_visualCopy {
        margin: 1rem 0 1rem;
        font-size: 5vw;
        line-height: 2;
    }
    .app-boost_visualCopy02 {
        margin-top: 0;
    }

    .app-boost_cta {
        width: 100%;
        min-height: 6.106rem;
        padding: 1.42rem 4.2rem 1.42rem 1.8rem;
        gap: 1.2rem;
        font-size: 1.534rem;
    }

    .app-boost_tel span {
        font-size: 2.698rem;
    }

    .app-boost_section01,
    .app-boost_solution,
    .app-boost_about,
    .app-boost_tools,
    .app-boost_case,
    .app-boost_reason,
    .app-boost_flow,
    .app-boost_faq {
        padding-top: 4.828rem;
    }

    .app-boost_case {
        padding-top: 0;
    }

    .app-boost_sectionTitle,
    .app-boost_largeTitle,
    .app-boost_solutionTitle {
        margin-bottom: 3.408rem;
    }

    .app-boost_solutionTitle {
        margin-top: 1rem;
    }

    .app-boost_sectionTitle {
        font-size: 1.9rem;
    }

    .app-boost_largeTitle {
        font-size: 2.4rem;
    }

    .app-boost_solutionTitle {
        font-size: 2.2rem;
    }

    .app-boost_nayamiList,
    .app-boost_kaiketuList,
    .app-boost_caseList,
    .app-boost_reasonList,
    .app-boost_flowList {
        grid-template-columns: 1fr;
    }

    .app-boost_caseList {
        margin-top: 80px;
    }

    .app-boost_balloon {
        min-height: 9.23rem;
        font-size: 1.59rem;
    }

    .app-boost_aboutGrid {
        gap: 3.692rem;
    }

    .app-boost_aboutText p,
    .app-boost_aboutLogo p {
        font-size: 1.42rem;
    }

    .app-boost_aboutText p {
        margin-bottom: 0;
    }

    .app-boost_aboutLogo {
        padding-top: 0;
    }

    .app-boost_aboutLogo img {
        display: none;
         width: 80%;
         margin: 0 auto;
        margin-bottom: 10px;
    }

    .app-boost_aboutMessage {
        padding: 1.988rem 1.42rem;
        font-size: 1.5rem;
    }

    .app-boost_toolLogo h3 {
        font-size: 2.4rem;
    }

    .app-boost_toolText h4 {
        font-size: 1.9rem;
    }

    .app-boost_toolText li {
        width: 100%;
        min-height: 5rem;
        font-size: 1.4rem;
    }

    .app-boost_caseItem {
        padding: 5.964rem 1.846rem 2.13rem;
    }

    .app-boost_caseItem h3 {
        font-size: 1.775rem;
    }

    .app-boost_docCta > img,
    .app-boost_consultLabel {
        width: 100%;
    }
    .app-boost_docCta {
        margin-top: 0;
    }

    .app-boost_docCta .app-boost_cta,
    .app-boost_consult .app-boost_cta {
        width: 100%;
    }
    .app-boost_docCta .app-boost_cta {
        font-size: 1.8rem;
        min-height: 6.5rem;
    }

    .app-boost_consult .app-boost_cta {
        gap: 1rem;
        padding-left: 1.4rem;
        padding-right: 4rem;
        font-size: 1.6rem;
    }

    .app-boost_reasonItem {
        min-height: auto;
        padding: 3.55rem 1.988rem 2.556rem;
    }

    .app-boost_reasonItem img {
        right: 1.846rem;
        width: 8.236rem;
    }

    .app-boost_reasonItem > span {
        font-size: 5.68rem;
    }

    .app-boost_reasonItem h3 {
        font-size: 2.201rem;
    }

    .app-boost_reasonItem p {
        font-size: 1.42rem;
    }

    .app-boost_flowList img {
        width: 15rem;
    }

    .app-boost_consult {
        min-height: auto;
        padding-bottom: 12rem;
    }

    .app-boost_flowList p {
        text-align: left;
        margin: 0 0 0 20px;
        font-size: 1.42rem;
    }

    .app-boost_consultPerson {
        left: auto;
        right: 1rem;
        bottom: -35px;
        width: 12.78rem;
    }

    .app-boost_faqBox {
        padding: 2.13rem 1.562rem 2.556rem;
    }

    .app-boost_faqItem button {
        align-items: flex-start;
        font-size: 1.42rem;
    }

    .app-boost_faqItem button span,
    .app-boost_faqItem dd > span {
        flex-basis: 3.976rem;
        font-size: 2.556rem;
    }

    .app-boost_faqItem dd {
        padding-right: 1.136rem;
    }

    .app-boost_faqItem dd > span {
        padding-left: 1.136rem;
    }

    .app-boost_faqItem dd p {
        font-size: 1.349rem;
    }

    .app-boost_sideCta {
        display: none;
        top: auto;
        bottom: 0;
        grid-template-columns: repeat(2, 1fr);
        width: 100%;
        transform: none;
    }

    .app-boost_sideCta a {
        width: 100%;
    }

    .app-boost_sideCta img {
        width: 100%;
    }
    .app-boost_section01::after {
    position: absolute;
    bottom: -3.98rem;
    left: 50%;
    z-index: 2;
    width: 15.90rem;
    height: 3.98rem;
    background: #f1f1f1;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    transform: translateX(-50%);
    content: "";
}
.app-boost_toolLogo {
    border: none;
    padding-left: 0px;
}

.app-boost_toolText p {
    font-size: 1.5rem;
}

.app-boost_caseItem strong {
    font-size: 1.8rem;
}

.app-boost_reasonItem::before {
    position: absolute;
    top: 0;
    left: 2.5rem;
    width: 6rem;
    height: 0.3rem;
    background: #224e87;
    content: "";
}

.app-boost_visualCopy span {
    font-size: 2.5rem;
}
.app-boost_visualCopy span.app-boost_visualCopy_e {
    display: none;
}

}


.app-boost_aboutLogo_sp {
    display: none;
}
@media screen and (max-width: 1024px) {
    .app-boost_aboutLogo_sp {
    display: block;
    width: 80%;
    max-width: 500px;
    margin: 0 auto;
}
}

.app-boost_caseItem_list {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.app-boost_caseItem_list li {
    width: 50%;
}

@media screen and (max-width: 740px) {
    .app-boost_flowList li {
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        justify-content: flex-start;
    }
    .app-boost_flowList li:not(:last-child)::after {
        top: 14.674rem;
        right: inherit;
        left: 6.5rem;
        width: 1.988rem;
        height: 4.118rem;
        transform: rotate(90deg);
    }
}







/* sso_new06 */

#sso_new06 {
    margin-top: 100px;
    margin-bottom: 100px;
}

#sso_new06 .ttl01 {
	text-align: center;
	font-size: 250%;
	font-weight: 700;
	position: relative;
	padding-bottom: 20px;
	margin-bottom: 50px;
	color: #0e1726;
}
#sso_new06 .ttl01::after {
	position: absolute;
	display: block;
	content: "";
	width: 50px;
	height: 6px;
	background: #224e87;
	right: 50%;
	bottom: 0;
	transform: translate(50%,0);
}

#sso_new06 .inner {
	padding-top: 0;
	width: 100%;
	max-width: 1200px;
	font-family: "Noto Sans", sans-serif;
	color: #0e1726;
    margin: 0 auto;
}

.sso_list_service {
	max-width: 1080px;
	margin: 0 auto;
	display: flex;
	flex-flow: row wrap;
	align-items: stretch;
	justify-content: flex-start;
	gap: 30px;
}
.sso_list_service li {
	width: calc((100% - 60px)/3);
	border: 1px solid #a6a6a6;
	border-radius: 16px;
	padding: 30px 10px;
	text-align: center;
}
.sso_list_service li .ttl {
	font-weight: 700;
	font-size: 2.2rem;
	margin-bottom: 20px;
    min-height: 70px;
}
.sso_list_service li .img {
	margin-bottom: 30px;
}
.sso_list_service li .img img {
	max-width: 190px;
}
.sso_list_service li .txt {
	line-height: 2;
}
.sso_list_service .btn_service a {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #224e87;
	width: 100%;
	max-width: 265px;
	height: 70px;
	font-size: 1.8rem;
	font-weight: 700;
	color: #fff;
	position: relative;
	text-decoration: none;
	border-radius: 200px;
	transition: .3s;
	margin: 30px auto 0;
}
.sso_list_service .btn_service a:hover {
	opacity: 0.7;
}
.sso_list_service .btn_service a::after {
	position: absolute;
	display: block;
	content: "";
	color: #fff;
	line-height: 1;
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: rotate(45deg);
	right: 30px;
}

@media screen and (max-width: 1100px) {
     #sso_new06 {
    margin-left: 20px;
    margin-right: 20px;
}
}


@media screen and (max-width: 740px) {

    #sso_new06 {
    margin-top: 50px;
    margin-bottom: 50px;
}
	

	/* sso_new06 */
	.sso_list_service {
		flex-flow: column;
		align-items: center;
		justify-content: center;
		gap: 30px;
	}
	.sso_list_service li {
		width: 100%;
		border-radius: 16px;
		padding: 20px 10px;
	}
	.sso_list_service li .ttl {
		font-size: 1.8rem;
		line-height: 1.4;
        min-height: auto;
	}
	.sso_list_service li .img {
		margin-bottom: 20px;
	}
	.sso_list_service li .img img {
		max-width: 60%;
	}
	.sso_list_service li .txt {
		line-height: 1.6;
	}
	.sso_list_service .btn_service a {
		max-width: 265px;
		height: 50px;
		font-size: 1.5rem;
		margin: 20px auto 0;
	}

	/* contact */
	.sso_content #contact .inner {
		width: 90%;
	}

	#sso_new06 .ttl01 {
		font-size: 170%;
		margin-bottom: 30px;
		margin-top: 0!important;
		line-height: 1.2;
	}
	#sso_new06 .ttl01::after {
		width: 40px;
		height: 4px;
	}
}


.app-boost_visualImage_img_pc {
    display: block;
}
.app-boost_visualImage_img_sp {
    display: none;
}
@media screen and (max-width: 740px) {
    .app-boost_visualImage_img_pc {
    display: none;
}
.app-boost_visualImage_img_sp {
    display: block;
}

.app-boost_visualText h1 {
    display: block;
}
}