@charset "UTF-8";

/* for End-User */
/* COMMON */
[class $= "_container"]{
    width:100%;
    max-width:1080px;
    margin-left: auto;
    margin-right: auto;
    padding:2rem 0;

    @media (width < 768px) {
        padding-left:1rem;
        padding-right:1rem;
    }
}

.el_title{
    font-size:2rem;
    color:rgb(var(--sub));
    font-weight:bold;

    padding-bottom: 0.5rem;
    border-bottom:1px rgb(var(--sub)) solid ;
    margin-bottom: 1rem;

    @media (width < 768px) {
        font-size: 1.5rem;
    }
}

.el_subTitle{
    font-size:1.2rem;
    font-weight:bold;
    margin-top:1rem;
    margin-bottom: 1rem;
}

.bl_itpwebmp_imageItems{
    display: grid;
    grid-template-columns: repeat(var(--num, 3), 1fr);
    flex-wrap: wrap;
    column-gap: 16px;
    row-gap:16px;

    & *{
        min-width: 0;
    }

    & figcaption{
        text-align: center;
    }
}

.bl_itpwebmp_note{
    color:rgb(var(--main));
    padding:8px;
    background-color: #f0f0f0;
    border:1px #ccc solid;
    margin-top:16px;

    &:before{
        content: "※";
    }
}

.bl_itpwebmp_developerInfo{
    width:fit-content;
    display: grid;
    grid-template-columns: max-content 1fr;
    column-gap: 16px;
}

.bl_itpwebmp_developerName{
    font-weight: bold;
    font-size: 1.1rem;
}

.bl_itpwebmp_developerDesc{
    margin-top: 1rem;
}

/* 対応ソリューション個別ページのヘッダ */
.uq_itpwebmp_heroSolBG{
    background-color: #f9f9f9;
    box-shadow: var(--shadow);
}

.uq_itpwebmp_heroSolContainer{
    width:100%;
    max-width: 1080px;
    margin-left: auto;
    margin-right:auto;
    padding-bottom:1rem;

    @media (width < 768px) {
        padding-left: 1rem;
        padding-right:1rem;
    }
}

.uq_itpwebmp_heroSol{
    padding:2rem 0;
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;

    @media (width < 768px) {
        display: block;
    }
}

.uq_itpwebmp_heroSolIcon{
    text-align: center;
    align-self: center;
}

.uq_itpwebmp_heroSolTitle{
    font-size:2rem;
    font-weight: bold;
}

.uq_itpwebmp_heroSolDevName a{
    color:rgb(var(--sub));
    text-decoration: underline;
}

.uq_itpwebmp_heroSolText{
    font-size: 0.95rem;
    margin-top: 1rem;
}

.uq_itpwebmp_heroSolCTAButton{
    display:block;
    background-color: rgb(var(--main));
    color: #fff;
    border-radius: 6px;
    padding:6px;
    text-align: center;
    
    &::after{
        --size:0.6rem;
        content:"";
        display:inline-block;
        position:relative;
        left:0;
        width: var(--size);
        height: var(--size);
        background-color: #fff;
        clip-path: polygon(30% 0%, 10% 10%, 50% 50%, 10% 90%, 30% 100%, 80% 50%);
    }

    &:hover{
        color:#fff;

        &::after{
            left: 3px;
        }
    }

    &:visited{
        color:#fff;
    }
}

.uq_itpwebmp_heroNav{
    display:flex;
    justify-content: center;
    align-items: center;
    column-gap: 3rem;

    @media (width < 768px) {
        display: block;
    }
}

.uq_itpwebmp_service_inner{
    display:grid;
    grid-template-columns:70% 1fr;

    @media (width < 769px){
        display:block;
        padding-left:1rem;
        padding-right:1rem;
    }
}


/* 個別section */
.uq_mp_hero{
    width: 100%;
    aspect-ratio: 4/1;
    max-height: 300px;
    position:relative;
    z-index:0;

    background-color: rgb(var(--sub));
    background-image: url('/itp/images/marketplace/img_header_da.jpg');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;

    &::after{
        content:"";
        display: block;
        width:100%;
        height:100%;
        position:absolute;
        z-index:1;
        top:0;
        left:0;
        backdrop-filter: blur(5px);
    }
}

.uq_mp_hero_container{
    position:relative;
    z-index:2;
    height:100%;
    width:100%;
    max-width:1080px;
    margin-left: auto;
    margin-right: auto;

    display:flex;
    align-items: center;

    @media (width < 768px) {
        height:auto;
    }
}

.uq_mp_heroTxt{
    font-size:3rem;
    color:#fff;
    font-weight: bold;

    @media (width < 768px) {
        font-size: 1.5rem;
        margin-left: auto;
        margin-right: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
    }
#sub {
    font-size:1.2rem;
    color:#fff;
    font-weight: bold;
}
}


.uq_mp_localNavBG{
    background-color: rgba(var(--sub),0.2);
    padding:16px 0;
}

.uq_mp_localNav_container{
    display: grid;
    grid-template-columns: repeat(2, max-content);
    column-gap: 32px;
    align-items: center;
    padding-top:16px;
    padding-bottom:16px;

    @media (width < 768px) {
        display:flex;
        flex-direction: column;
        column-gap: 0;
        row-gap: 1rem;
    }
}

.uq_mp_localNav_container > ul{
    padding-top:0.3rem;
    display:flex;
    column-gap: 1rem;

    @media (width < 768px) {
        display: contents;
    }
}


.uq_mp_intro_container{
    padding-top:48px;
    padding-bottom:48px;

    & .el_title{
        display:flex;
        align-items: center;
    }
}

.uq_mp_serviceBG{
    padding: 48px 0;
    background-color: rgba(var(--sub), 0.05);
}

.uq_mp_service_container{
    & .el_title{
        padding-bottom: 0.5rem;
        border-bottom:1px rgb(var(--sub)) solid ;
        margin-bottom: 1rem;
    }
}

.uq_mp_serviceItems{
    --gap:32px;
    display:grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    column-gap: var(--gap);
}

.uq_mp_serviceItem{
    --paddingFromCard:24px;
    background-color: #fff;
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 6;
    border-radius: 16px;
    box-shadow: var(--shadow);
    margin-bottom: var(--gap);


    &:has(a.uq_mp_serviceItemCTA):hover{
        box-shadow: var(--shadowHover);
    }
}

.uq_mp_serviceItemLogo{
    height:160px;
    display:flex;
    justify-content: center;
    align-items: center;

    padding: 16px var(--paddingFromCard);

    & img{
        height:100%;
        width:100%;
        object-fit: contain;
    }
}

.uq_mp_serviceItemCat{
    display:flex;
    align-items: center;
    column-gap: 8px;
    padding: 8px var(--paddingFromCard);

    & span{
        font-size:0.8rem;
        background-color:rgb(var(--sub));
        color:#fff;
        padding:3px 1rem 1px 1rem;
    }
}

.uq_mp_serviceItemTitle{
    display:flex;
    align-items: center;
    font-size:1.5rem;
    font-weight: bold;
    padding:0 var(--paddingFromCard);
}

.uq_mp_serviceItemDesc{
    line-height:1.75;
    padding:0 var(--paddingFromCard);
}

.uq_mp_serviceItemProvider{
    font-weight:bold;
    font-size: 0.9rem;
    padding:8px var(--paddingFromCard);

    &::before{
        content: "提供元：";
        display:block;
    }
}

.uq_mp_serviceItemToDetail{
    text-align: right;
    padding: 8px var(--paddingFromCard) 24px var(--paddingFromCard);
    justify-self: flex-end;
}

.uq_mp_serviceItemToDetail > .uq_mp_serviceItemCTA{
    position:relative;
    width: 100%;
    display:inline-flex;
    justify-content: center;
    align-items:center;
    background-color:rgb(var(--main));
    color:#fff;
    padding:0.2rem 1rem 0.1rem 1rem;
    border-radius: 8px;
}

.uq_mp_serviceItemCTA::after{
    --size:1rem;
    content:"";
    display:inline-block;
    position:relative;
    left:0;
    top:-1px;

    width:var(--size);
    height:var(--size);
    background-color:currentColor;
    clip-path: polygon(40% 0%, 30% 10%, 70% 50%, 30% 90%, 40% 100%, 90% 50%);
    transition:all 0.1s;
}

.uq_mp_serviceItemCTA:is(:hover, :focus)::after{
    left:3px;
}

/* How To Use */
.uq_mp_howtouseItems{
    --gap:48px;
    counter-reset:step;
    display: grid;
    row-gap: var(--gap);
}

.uq_mp_howtouseItem{
    counter-increment: step;
    position:relative;
    display:grid;
    grid-template-columns: 1fr 2fr;
    column-gap: 32px;
    background-color: #fff;

    &:nth-of-type(n + 2)::before{
        --size:32px;
        --width:var(--size);
        --height:calc(var(--size)/1.41);
        content: "";
        display:block;
        position:absolute;
        width: var(--width);
        height: var(--height);
        background-color: rgb(var(--sub));
        left:calc(16.5% - var(--width) / 2);
        top:calc(-1 * var(--height) - (var(--gap) - var(--height))/2); /* gridのrow-gap:24pxの半分 */
        clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
    }

    @media (width < 768px) {
        display: block;
    }
}

.uq_mp_howtouseItemDescHeader{
    font-size: 1.5rem;
    font-weight:bold;
    color: rgb(var(--sub));

    &::before{
        content: "Step" counter(step);
    }

    @media (width < 768px) {
        font-size: 1.25rem;
    }
}

.uq_mp_howtouseItemDescBody{
    font-size: 1.25rem;

    & p:nth-of-type(n + 2){
        margin-top:1rem;
    }

    & span.notice{
        font-size:1rem;
        display: block;
        width:100%;
        margin-top: 1rem;
        margin-right: auto;
        margin-bottom:1rem;
        padding:0.5rem 0.5rem 0.5rem 1.5rem;
        border:1px rgb(255, 0, 0) solid;
        background-color: rgba(255, 0, 0, 0.05);

        text-indent:-1rem;
        &::before{
            content: "※";
        }

        @media (width < 768px) {
            width:100%;
        }
    }

    @media (width < 768px) {
        font-size: 1rem;
    }
}

/* uq_mp_cta_container */
.uq_mp_ctaBG{
    background-color: rgba(var(--sub), 1);
    padding: 1rem 0;
}

.uq_mp_cta_container{
    display: flex;
    justify-content: center;
    align-items: center;
}

.uq_mp_cta_container .uq_mp_cta_button{
    position:relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding:1rem;
    color:#fff;
    background-color: rgb(var(--main));
    border-radius: 6px;
    box-shadow: 1px 1px 0px currentColor;
    transition: all var(--delay);
    font-size: 1.25rem;

    &::after{
        --size:1rem;
        position: relative;
        content:"";
        width: var(--size);
        height: var(--size);
        background-color: currentColor;
        clip-path: polygon(40% 0%, 30% 10%, 70% 50%, 30% 90%, 40% 100%, 90% 50%);
    }

    &:is(:hover, :focus){
        box-shadow: none;

        &::after{
            left:0.2rem;
        }
    }
}


.contents {
     width: 100%;
     max-width: 1200px;
     margin: auto;
 }
 .contents img {
     width: 100%;
 }
 .text-left {
     text-align: left;
 }
 .flexbox {
     display: flex;
 }
 .box1 {
     width: 55%;
     margin: auto;
 }
 .box2 {
     width: 45%;
     margin: auto .5rem;
 }
 @media screen and (max-width: 767px) {
     .flexbox {
         display: block;
     }
     .flexbox .box1 {
         width: 100%;
         margin: 0 auto;
     }
     .flexbox .box2 {
         width: 100%;
         margin: 0 auto;
     }
 }


/* for table */
    table {
      border-collapse: collapse;
    }
    th {
      border: 1px solid #9e9e9e;
      padding: 5px 8px;
      text-align: center;
      background-color: #e0e0e0;
    }
    td {
      border: 1px solid #9e9e9e;
      padding: 5px 8px;
    }
    td.color {
      background-color: #f1f0f0;
    }
    th:last-of-type {
      width: 450px;
    }


/* for Developer */
.uq_itpwebmp_header{
    position: relative;
    width: 100%;
    aspect-ratio: 4/1;
    max-height: 300px;

    background-color: rgb(var(--sub));
    background-image: url('/itp/images/marketplace/img_header_da.jpg');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

.uq_itpwebmp_header::after{
    content: "";
    position: absolute;
    top:0;
    right: 0;
    bottom: 0;
    left:0;
    z-index:1;
    background-color: rgba(0,0,0,0.5);
}

.uq_itpwebmp_headerTitle{
    position: relative;
    max-width: 1080px;
    height: 100%;
    min-width: 0;
    min-height: 0;
    margin-left: auto;
    margin-right: auto;
    z-index: 10;
    color: #fff;
    font-size: 1.5rem;
    z-index: 2;

    display: flex;
    align-items: center;
}

.uq_itpwebmpTitle{
    font-size: 1.5rem;
    text-align: left;
    padding: 1rem 0;
    margin-bottom: 1rem;
}

@media screen and (max-width:768px) {
    .uq_itpwebmp_headerTitle{
        display: block;
        padding: 2rem 0.5rem;
        text-align: center;
        height: auto;
    }
}

.uq_mpSaiyouJirei_logo{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 20px;
}

.uq_mpSaiyouJirei_logoImg{
    object-fit: contain;
    width:100%;
    max-width: 300px;
    aspect-ratio: 16/9;
}

.uq_mpSaiyouJirei_title{
    font-size: 1.5rem;
    text-align: left;
    padding: 1rem 0;
    margin-bottom: 1rem;
}

.uq_mpSaiyouJirei_container{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    grid-template-rows: repeat(5, max-content);
    grid-auto-flow: column;
    column-gap: 5%;
    row-gap: 6px;
}

.uq_mpSaiyouJireiCard{
    display: contents;
}

.uq_mpSaiyouJireiCardImg > img{
    width: 100%;
    aspect-ratio: 20/10;
}

.uq_mpSaiyouJireiCardName{
    font-weight: bold;
    font-size: 1rem;
    display: flex;
    align-items: center;
    border-bottom: 1px #ccc solid;
    padding-bottom: 0.5rem;
}

.uq_mpSaiyouJireiCardServiceName{
    color: rgb(var(--sub));
}

.uq_mpSaiyouJireiCardDesc{
    line-height: 175%;
}

.uq_mpSaiyouJireiCardToDetail{
    margin-top: 1rem;
}

@media screen and (max-width:768px) {
    .uq_mpSaiyouJirei_title{
        text-align: center;
    }

    .uq_mpSaiyouJirei_logo{
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
        gap: 20px;
    }

    .uq_mpSaiyouJirei_container{
        display: grid;
        grid-template-columns: 1fr;
    }

    .uq_mpSaiyouJireiCard{
        display: grid;
        grid-template-columns: 1fr 2fr;
        grid-template-rows: repeat(4, max-content);
        column-gap: 12px;
    }

    .uq_mpSaiyouJireiCard:nth-of-type(n + 2){
        margin-top: 2rem;
    }

    .uq_mpSaiyouJireiCardName{
        grid-column: span 2;
    }
    
    .uq_mpSaiyouJireiCardServiceName{
        padding-top:0.5rem;
    }

    .uq_mpSaiyouJireiCardImg{
        grid-row: 2/5;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .uq_mpSaiyouJireiCardImg > img{
        aspect-ratio: 1/1;
    }

    .uq_mpSaiyouJireiCardToDetail{
        display: block;
        text-align: right;
        margin-top: 0.5rem;
    }
   
}


.uq_mpMerit_bgFull{
    --ex_height:40px;
    position: relative;
    background-color: rgb(var(--sub));
    margin-top: var(--ex_height);
    margin-bottom: calc(var(--ex_height) * 2);
}

.uq_mpMerit_bgFull::before{
    content: "";
    display: block;
    position: absolute;
    clip-path: polygon(0 60%, 0 100%, 100% 100%, 100% 0);
    background-color: rgb(var(--sub));
    left:0;
    top:calc(0px - var(--ex_height) + 1px);
    width: 100%;
    height: var(--ex_height);
}

.uq_mpMerit_bgFull::after{
    content: "";
    display: block;
    position: absolute;
    clip-path: polygon(0 0 , 0 100%, 100% 20%, 100% 0);
    background-color: rgb(var(--sub));
    left:0;
    bottom:calc(0px - var(--ex_height) + 1px);
    width: 100%;
    height: var(--ex_height);
}

.uq_mpMerit_title,
.uq_mpTgt_title{
    font-size: 1.5rem;
    text-align: left;
    padding-bottom: 0.75rem;
}

.uq_mpMerit_card *{
    min-width: 0;
}

.uq_mpMerit_card_container{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5%;
}

.uq_mpMerit_card{
    background-color: #eee;
    border: 3px #fff solid;
    border-radius: var(--radius);
    padding: 1rem;
}

.uq_mpMerit_img > img{
    width: 100%;
    aspect-ratio: 20/10;
    object-fit: cover;
}

.uq_mpMerit_cardTxt{
    line-height: 175%;
    text-align: justify;
}

.uq_mpTgt_card_container{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, max-content);
    grid-auto-flow: column;
    column-gap: 5%;
}

.uq_mpTgt_card{
    display: contents;
}

.uq_mpTgt_cardTitle{
    background-color: #eee;
    border-top-left-radius: var(--radius);
    border-top-right-radius: var(--radius);
    padding: 1rem 1rem;
    font-size: 1.25rem;
}

.uq_mpTgt_cardTxt{
    position: relative;
    background-color: #fff;
    border-bottom-left-radius: var(--radius);
    border-bottom-right-radius: var(--radius);
    padding: 1rem 1rem 0.5rem 1rem;
    font-size: 1.25rem;
    display: flex;
    justify-content: space-between;
    align-items: center;

}

.uq_mpTgt_cardTxt.uq_mpTgt_cardTxt__FL::before{
    content: "→";
    display: inline-block;
    width: max-content;
    padding:1rem 1rem 1rem 0;
    color: rgb(var(--sub));
    font-weight: bold;
}

.uq_mpNonTgt{
    border: 1px #fff solid;
    background-color: #fff;
    border-radius: var(--radius);
}

.uq_mpNonTgtTxt{
    font-size: 1.2rem;
    padding:1rem 1rem 0.75rem 1rem;
    color:#333;
}

.uq_mpNonTgtTxt > a:is(:hover, :focus){
    color: rgb(var(--main));
    background-color: #fff;
}

@media screen and (max-width:768px) {
    .uq_mpMerit_card_container{
        display: block;
    }

    .uq_mpMerit_card:nth-of-type(2){
        margin-top: 16px;
    }

    .uq_mpMerit_bgFull{
        padding-top:0;
        padding-bottom: 0;
    }

    .uq_mpMerit_title{
        text-align: center;
    }

    .uq_mpTgt_card_container{
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        grid-auto-flow: row;
        row-gap:1rem;
    }

    .uq_mpTgt_card{
        display: block;
    }
}


.uq_mpRenkeiMethodSubTitle{
    font-size: 1.2rem;
    text-align: center;
    padding-bottom: 1rem;
}

.uq_mpRenkeiMethod_container{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 5rem;
}

.uq_mpRenkeiMethodItems{
    display: contents;
}

.uq_mpRenkeiMethodItem{
    position: relative;
    background-color: rgb(var(--sub));
    padding: 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    border-radius: var(--radius);
    text-align: center;
    color: #fff;
    font-size: 1.25rem;
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__ITP{
    grid-column: span 4;
    font-weight: bold;
    margin-bottom: 3rem;
}

.uq_mpRenkeiMethodItem__ITP::before{
    display: none;
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__Ser{
    grid-column: span 3;
    font-weight: bold;
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__Uns{
    grid-column: span 1;
    background-color: #ccc;
    color: #111;
    border: 1px #999 solid;
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__ITPMP{
    grid-column: span 2;
    font-weight: bold;
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__CSV{
    background-color: #ccc;
    color: #111;
    border: 1px #999 solid;
    grid-column: span 2;
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__Jyoui{
    background-color: #ccc;
    color: #111;
    border: 1px #999 solid;
}

.uq_mpRenkeiMethodItem__CSV::after,
.uq_mpRenkeiMethodItem__Jyoui::after{
    content:"詳細を見る";
    position: relative;
    display: block;
    font-size: 1rem;
    background-color: #333;
    border-radius: 6px;
    color: #fff;
    margin-top:0.25rem;
    padding: 0.3rem 1rem 0.1rem 1rem;
    margin-top: 1rem;
}

.uq_mpRenkeiMethodItem__Uns::before,
.uq_mpRenkeiMethodItem__CSV::before{
    border-left: 3px #999 solid;
    border-bottom: 3px #999 solid;
}
    
.uq_mpRenkeiMethodItem__CSV:is(:hover, :focus)::after{
    text-decoration: underline;
    background-color: #666;
}

.uq_mpRenkeiMethodItem__CSV:is(:hover, :focus){
    background-color: #eee;
}

.uq_mpRenkeiMethodItemsSubTxt{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    font-size: 0.8rem;
    text-align: center;
    margin-top: 1rem;
    margin-bottom: 3rem;
}

.uq_mpRenkeiMethodItemsSubTxtT{
    color: rgb(var(--sub));
    font-size: 1rem;
    font-weight: bold;
    grid-column: span 2;
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__arrow::before{
    --size:1rem;
    position: absolute;
    display: block;
    content: "";
    width: var(--size);
    height: var(--size);
    border-left: 8px rgb(var(--sub)) solid;
    border-bottom: 8px rgb(var(--sub)) solid;
    top:-2.5rem;
    transform: rotate(-45deg);
}

.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__arrowNT::before{
    --size:1rem;
    position: absolute;
    display: block;
    content: "";
    width: var(--size);
    height: var(--size);
    border-left: 3px #999 solid;
    border-bottom: 3px #999 solid;
    top:-2.5rem;
    transform: rotate(-45deg);
}

.uq_mpRenkeiMethodItemsSubTxt.uq_mpRenkeiMethodItem__arrow::after{
    --size:1rem;
    position: absolute;
    display: block;
    content: "";
    width: var(--size);
    height: var(--size);
    border-left: 8px rgb(var(--sub)) solid;
    border-bottom: 8px rgb(var(--sub)) solid;
    bottom:-1.5rem;
    transform: rotate(-45deg);
}

.uq_mpRenkeiMethodItemsSubTxt.uq_mpRenkeiMethodItem__arrowNT::after{
    --size:1rem;
    position: absolute;
    display: block;
    content: "";
    width: var(--size);
    height: var(--size);
    border-left: 3px #999 solid;
    border-bottom: 3px #999 solid;
    bottom:-1.5rem;
    transform: rotate(-45deg);
}

/* 最後のブロックの下矢印 */
.uq_mpRenkeiMethodItem.uq_mpRenkeiMethodItem__ITPMP::after{
    --size:1rem;
    position: absolute;
    display: block;
    content: "";
    width: var(--size);
    height: var(--size);
    border-left: 8px rgb(var(--sub)) solid;
    border-bottom: 8px rgb(var(--sub)) solid;
    bottom:-2.5rem;
    transform: rotate(-45deg);
}

@media screen and (max-width:768px) {
    .uq_itpwebmp_container{
        display: none;
    }
}



/* 利用までの流れ */
.uq_mpHowToUseFlow{
    counter-reset: step 0;
    display: flex;
    justify-content: space-between;
    flex-direction: row;
    column-gap: 3rem;
}

.uq_mpHowToUseFlowItem{
    flex: 0 0 calc((100% - (3rem * 2)) / 3);
}

.uq_mpHowToUseFlowItemTitle{
    border-top-left-radius: var(--radius);
    border-top-right-radius: var(--radius);
    border: 1px rgb(var(--sub)) solid;
    background-color: rgb(var(--sub));
    color: #fff;
    padding: 0.5rem 0.5rem 0.25rem 0.5rem;
}

.uq_mpHowToUseFlowItemTitle::before{
    counter-increment: step 1;
    content: "Step" counter(step) ": ";
}

.uq_mpHowToUseFlowItemTxt{
    position: relative;
    border: 1px rgb(var(--sub)) solid;
    padding: 1rem 0.5rem;
}

.uq_mpHowToUseFlowItem:nth-last-of-type(n + 2) .uq_mpHowToUseFlowItemTxt::after{
    --size:1rem;
    position: absolute;
    content: "";
    display: block;
    border-right: 3px rgb(var(--sub)) solid;
    border-bottom: 3px rgb(var(--sub)) solid;
    width: var(--size);
    height: var(--size);
    right: calc(var(--size) * -1.5);
    top:calc(50% - calc(var(--size) * 1.5));
    transform: rotate(-45deg);
}
    
.uq_mpHowToUseFlowDesc{
    position: relative;
    padding-top: 2rem;
    text-align: center;
}

.uq_mpHowToUseFlowCTA{
    margin-top: 2rem;
    display: flex;
    justify-content: center;
    align-items: center;
    column-gap: 6rem;
}

.uq_mpHowToUseFlowCTA > a.el_btn{
    border-radius: 10rem;
    text-align: center;
    min-width: 50%;
}

@media screen and (max-width:768px) {
    .uq_mpHowToUseFlow{
        flex-direction: column;
        column-gap: 0;
        row-gap:3rem;
    }

    .uq_mpHowToUseFlowItem:nth-last-of-type(n + 2) .uq_mpHowToUseFlowItemTxt::after{
        right:calc(50% - (var(--size) / 2));
        top:calc(100% + var(--size)/2);
        transform: rotate(45deg);
    }
}


.uq_mp_bannerForTP{
    width: 100%;
}

.uq_mp_bannerForTP > img{
    width: 100%;
    object-fit: contain;
    aspect-ratio: 4/1;
}