/* カスタマイズ用CSS */
/*==========  anti  ============*/
.c-text01,
.c-footer__address,
#page_product_list .product_name,
.ec-productRole .ec-productRole__title .ec-headingTitle,
.ec-productRole .ec-productRole__description,
.ec-input input, .ec-birth input, .ec-select input, .ec-halfInput input, .ec-numberInput input, .ec-zipInput input, .ec-telInput input,.ec-cartRole,
.ec-productRole .ec-productRole__actions .ec-select select,
.ec-orderRole .ec-orderRole__detail,
.ec-totalBox,
.ec-registerRole,
.ec-role *{
    font-family: Monospace !important;
}
.ec-inlineBtn,
.ec-blockBtn--primary,
.ec-input textarea, .ec-birth textarea, .ec-select textarea, .ec-halfInput textarea, .ec-numberInput textarea, .ec-zipInput textarea, .ec-telInput textarea{
    font-size: 1em;
}

.ec-blockBtn--primary{
    background: #cd412d;
    border-color: #cd412d;
    color: #fff;
}
.ec-blockBtn--primary:hover{
    background: #fff;
    border-color: #cd412d;
    color: #cd412d;
}
.lang_btn__wrap{
    right: 4em;
    top: 4.25em;
    z-index: 9999;
    cursor: pointer;
    font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
   .lang_btn__wrap{
        right: 4.5%;
        top: 4.5em;
    }
}
.ec-modal .ec-modal-wrap{
    max-width: 425px;
    padding: 2.5em 1em;
}
.ec-role{
    /*display: flex;*/
    /*justify-content: center;*/
    /*gap: 1em;*/
}
.ec-role::after{
    content: unset;
}
.ec-inlineBtn--action,
.ec-inlineBtn--cancel{
    font-size: 2rem;
}
.ec-inlineBtn--cancel{
    color: #cd412d;
    border-color: #cd412d;
    background: transparent;
}
.ec-inlineBtn--cancel:hover{
    color: #fff;
    background: #cd412d;
    border-color: #cd412d;
    opacity: 0.5;
}
@media screen and (min-width: 768px) {
    .ec-input input, .ec-birth input, .ec-select input, .ec-halfInput input, .ec-numberInput input, .ec-zipInput input, .ec-telInput input {
        font-size: 2rem;
        letter-spacing: 0.01em;
    }
}
.ec-layoutRole .ec-layoutRole__contents{
    max-width: 1920px;
    margin: 15% auto 10%;
}
@media screen and (max-width: 767px) {
    .ec-layoutRole .ec-layoutRole__contents{
        margin: 6em auto;
    }
}
.front_page .ec-layoutRole .ec-layoutRole__contents{
    margin: 0 auto;
}

.ec-blockBtn--action,.ec-blockBtn--cancel{
    font-size: 1em;   
}

.ec-blockTopBtn,
#paypal-logo{
display: none !important;
}
.lg{
    font-size: 1.6em;
    font-weight: bold;
    padding-left: 0 !important;
}
.logo_finger{
        width: 7em !important;
    margin: 1em auto;
}
.red{
    color: #cd412d !important;
}
@media only screen and (max-width: 767px) {
    .sp-nav {
        padding: 0 15vw 0.4rem 5vw;
    }
}
/*=====================  top page  ============================*/

.c-mv01 .video__wrap{
                    display: flex;
                    justify-content:center;
                }
                .c-mv01 .video{
                    position: relative;
                    height: 100vh;
                    width: max-content;
                }
                .c-mv01 video{
                    height: 100%;
                }
                .c-mv01 .movie__btn{
                    position: absolute;
                    bottom: 1em;
                    right: 1em;
                    width: clamp(30px,calc(50/1440*100vw),50px);
                }
                .c-mv01 button{
                    background: transparent;
                    border: none;
                    padding: 0;
                }
                .c-mv01 button img{
                    width: 100%;
                }
                .pc{
                    display: block;
                }
                .sp{
                    display: none;
                }
                @media (max-width:767px){
                    .up_coming .video,
                    .up_coming video{
                        width: 100%;
                        height: auto;
                    }
                                    .pc{
                    display: none !important;
                }
                .sp{
                    display: block !important;
                }
                span.sp{
                    display: inline !important;
                }
                }

/* =================================
               v2
================================= */
body:not(#page_homepage)::before{
    background-color: unset;
    pointer-events: none;
}
.header-logo img{
    width: 30rem;
    height: auto;
    filter: invert(1);
}
.for_pages header{
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.499) 80%, transparent);
}
.for_pages .pc-nav {
    padding: 1vw 12rem 3.125vw 1.4rem;
}
.for_pages footer{
    background-color: #1e1e1e;
}
ul.sns_wrap{
    display: flex;
    margin-top: 2em;
}
ul.sns_wrap li{
    width: 50%;
}
ul.sns_wrap li a{
    width: fit-content;
    font-size: 1.4em;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5em;
    margin: auto;
    letter-spacing: 0.1em;
}
ul.sns_wrap li img{
    width: 1.4em;
}

@media screen and (max-width: 767px) {
    .header-logo img{
    width: 12.5rem;
    }
    .video__wrap{
        overflow: hidden;
    }
    .video__wrap .video, .video__wrap video {
        width: auto !important;
        height: 100vh !important;
    }
    .top-about-case__description{
        text-align: right;
    }
    .top-about-cases::after{
        width: 100%;
    }
    .top-partners__texts{
        display: none;
    }
    .top-insight-card{
        flex-direction: column;
    }
    .top-insight-card__visual{
        width: 100%  !important;
    }
    .top-news{
        padding: 7.578125vw 9.375vw 46vw;
    }
    .footer{
        padding: 3rem 2em;
    }
    .footer__logo__wrap{
        display: flex;
        justify-content: space-between;
        margin-top: 3rem;
        max-width: calc(100% - 7em);
    }
    .footer__sns-list{
        margin-top: 0;
    }
    .footer__page-list{
        margin-top: 3rem;
    }
    .footer__page-list,
    .footer__other-pages{
        display: flex;
        flex-wrap: wrap;
    }
    .footer__page-list li,
    .footer__other-pages li{
        width: 50%;
    }
    .footer__copyright{
        text-align: center;
    }
}
.pc-nav{
    padding: 3.125vw 12rem 3.125vw 1.4rem;
}
.top__kv{
    padding-top: 0;
}
.top-kv {
    width: 100%;
    height: 100vh;
}
.video__wrap {
    width: 100%;
    height: 100%;
    position: relative;
}
.video__wrap .video,
.video__wrap video{
    position: absolute;
    width: 100%;
    height: 100%;
}
.top-about-case__title{
    font-size: 2rem;
}
.top-about-us__body{
    padding: 7.5vw 9vw 15vw;
}
.top-about-cases{
    margin-bottom: 2.8125vw;
}
.top-about-us__more .c-link{
    margin-right: 0;
}
.top-partners__item {
    width: 33%;
}
.top-partners__company ._name{
    font-size: 2rem;
    font-family:impact;
}
.top-insight-card{
    display: flex;
}
.top-insight-card__name-en{
    font-size: 4rem;
}
.top-insight-card__visual{
    position: relative;
    width: 60%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.top-insight-card__visual img{
    height: auto;
}
.top-partners__company{
    width: 100% !important;
}
.top-team {
    margin-top: -15vw;
    background: linear-gradient(135deg, #1e1e1e, #fff);
}
.top-team__itemImage{
    height: auto;
    aspect-ratio: 1;
    background: #fff;
}
.top-team__itemImage img{
    object-fit: contain;
}
.top-news{
    padding: 7.578125vw 9.375vw 20vw;
}
.footer__sns-item{
    border: none;
    background: none;
}
.footer__logo-link{
    filter: invert(1);
}
.top__portfolio,
.top__note,
.l__footer,
.c-footer{
    display: none;
}

/*==========  anti  ============*/
.top-insight-card__message,
.top-about-introduction__description,
.top-insight-card__name-en ._name,
.c-text01,
.c-footer__address,
#page_product_list .product_name,
.ec-productRole .ec-productRole__title .ec-headingTitle,
.ec-productRole .ec-productRole__description,
.ec-input input, .ec-birth input, .ec-select input, .ec-halfInput input, .ec-numberInput input, .ec-zipInput input, .ec-telInput input,.ec-cartRole,
.ec-productRole .ec-productRole__actions .ec-select select,
.ec-orderRole .ec-orderRole__detail,
.ec-totalBox,
.ec-registerRole,
.ec-shelfRole *,
.ec-role *{
    font-family: Monospace !important;
}
.ec-inlineBtn,
.ec-blockBtn--primary,
.ec-input textarea, .ec-birth textarea, .ec-select textarea, .ec-halfInput textarea, .ec-numberInput textarea, .ec-zipInput textarea, .ec-telInput textarea{
    font-size: 1em;
}

.ec-blockBtn--primary{
    background: #cd412d;
    border-color: #cd412d;
    color: #fff;
}
.ec-blockBtn--primary{
    background: #fff;
    border-color: #cd412d;
    color: #cd412d;
}
.lang_btn__wrap{
    right: 4em;
    top: 2em;
    z-index: 9999;
    cursor: pointer;
}
@media screen and (max-width: 767px) {
   .lang_btn__wrap{
        right: 4.5%;
        top: 4.5em;
    }
}
.logo_finger{
    width: 8em;
    margin: 0 auto 1em;
}
.ec-modal .ec-modal-wrap{
    max-width: 425px;
    padding: 2.5em 1em;
}
.ec-role{
    /*display: flex;*/
    /*justify-content: center;*/
    /*gap: 1em;*/
}
.ec-role::after{
    content: unset;
}
.ec-inlineBtn--action,
.ec-inlineBtn--cancel{
    font-size: 2rem;
}
.ec-inlineBtn--cancel{
    color: #cd412d;
    border-color: #cd412d;
    background: transparent;
}
.ec-inlineBtn--cancel:hover{
    color: #fff;
    background: #cd412d;
    border-color: #cd412d;
    opacity: 0.5;
}
@media screen and (min-width: 768px) {
    .ec-input input, .ec-birth input, .ec-select input, .ec-halfInput input, .ec-numberInput input, .ec-zipInput input, .ec-telInput input {
        font-size: 2rem;
        letter-spacing: 0.01em;
    }
}
.ec-layoutRole .ec-layoutRole__contents{
    max-width: unset !important;
    margin: 15% auto 10%;
}
@media screen and (max-width: 767px) {
    .ec-layoutRole .ec-layoutRole__contents{
        margin: 6em auto;
    }
}
.front_page .ec-layoutRole .ec-layoutRole__contents{
    margin: 0 auto;
}

.ec-blockBtn--action,.ec-blockBtn--cancel{
    font-size: 1em;   
}

.ec-blockTopBtn,
#paypal-logo{
display: none !important;
}
.lg{
    font-size: 1.6em;
    font-weight: bold;
    padding-left: 0 !important;
}

/*=====================  list page  ============================*/

@media only screen and (min-width: 768px) {
.ec-productRole .ec-productRole__profile {
padding-left: 10%;
margin-right: 0;
}
}


#page_product_list .ec-shelfGrid{
justify-content: center;
row-gap: 4em;
}
#page_product_list .ec-shelfGrid .ec-shelfGrid__item{
min-width: 300px;
padding-right: 1.5em !important;
padding-left: 1.5em!important;
padding-bottom: 3rem !important;
margin-bottom: 0 !important;
}
.ec-shelfGrid .ec-shelfGrid__item:nth-child(odd) {
padding-right: unset;
}
#page_product_list .ec-shelfGrid .ec-shelfGrid__item.spacer{
height: 0;
}
.ec-shelfGrid .ec-shelfGrid__item-image{
height: 15em;
display: flex;
justify-content: center;
align-items: center;
}
#page_product_list .product_name {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
font-weight: bold;
}
#page_product_list .price02-default{
color:#CD412D;
font-size: 1.125em;
margin:0.5em 0;
}
.ec-shelfGrid__item select:not([multiple]):not([size]){
width: 100%;
}
#page_product_list form{
    position: relative;
    height: 6em;
}
#page_product_list .ec-numberInput{
position: absolute;
bottom: 0;
transform: translateY(100%);
}
#page_product_list .ec-numberInput .show{
display: inline-block !important;
}
#page_product_list .ec-shelfGrid .ec-shelfGrid__item .ec-productRole__btn{
width: 150px;
margin:0 0 0 auto;
}

/*=====================  details page  ============================*/
.ec-productRole{
padding-right: 5%;
padding-left: 5%;
}
.ec-productRole .slick-slide{
    aspect-ratio: 1;
}
.ec-sliderItemRole{
padding: 0 !important;
}
.ec-productRole .ec-productRole__price .ec-price{
color:#CD412D;
}
.ec-productRole__priceRegular,
.ec-productRole__code,
.ec-productRole__category{
display: none;
}
.ec-productRole .ec-productRole__price .ec-price__price{
font-size: 1.2em;
}
.ec-numberInput input[type=number]{
max-width: 2.5em;
margin: 0 0 0 0.5em;
height: 2em;
}
.ec-numberInput input[type=number],
select:not([multiple]):not([size]),
.ec-productRole .ec-productRole__actions .ec-select select{
font-size: 1.8rem;
min-width: unset;
}
.ec-productRole .ec-productRole__actions .ec-select select{
width: 100%;
/*max-width: calc(100% - 5em);*/
min-width: unset;
height: 2em;
line-height: 2;
padding: 0 0.5em;
font-size: 1.4rem;
}

.ec-productRole .cart_btn__wrap{
display:flex;
align-items: center;
justify-content: space-between;
column-gap: 1.5em;
margin-bottom: 0.5em;
}
.ec-productRole .cart_btn__wrap .show{
display:  inline-block !important;
}
.ec-productRole .ec-productRole__btn{
min-width: unset !important;
}
.ec-productRole .ec-productRole__btn.has_btn_cart{
flex:1;
width:unset;
margin-bottom: 0;
}
.ec-productRole .ec-productRole__btn.has_btn_fav{
width: 100% !important;
}
.ec-blockBtn--action,
.ec-blockBtn--cancel{
height: 3.5rem !important;
line-height: 3.5rem !important;
border:solid 1px #CD412D !important;
border-radius: 0.25em;
}
.ec-blockBtn--action{
background-color: #CD412D !important;
}
.ec-blockBtn--action:hover{
background-color: #fff !important;
color: #CD412D !important;
}
.ec-blockBtn--cancel{
color: #CD412D !important;
background-color: transparent !important;
}
.ec-blockBtn--cancel:hover{
background-color: #eee !important;
color: #555 !important;
}
.ec-productRole .ec-productRole__price,
.ec-productRole .ec-productRole__tags{
border: none;
}
select:not([multiple]):not([size]){
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='4'%1E%3Cpath d='M4 0h6L7 4'/%3E%3C/svg%3E") !important;
}
select {
-webkit-appearance: none;/* ベンダープレフィックス(Google Chrome、Safari用) */
-moz-appearance: none; /* ベンダープレフィックス(Firefox用) */
appearance: none; /* 標準のスタイルを無効にする */
}
::-ms-expand { /* select要素のデザインを無効にする（IE用） */
display: none;
}
.ec-sliderItemRole .item_nav{
    flex-wrap: unset;
}
.ec-sliderItemRole {
    position: sticky;
    top: 3em;
}

/*===============  movie  ====================*/
              .video__wrap{
                    display: flex;
                    justify-content:center;
                }
                 .video__wrap .video{
                    position: relative;
                    height: 100vh;
                    width: max-content;
                }
              .movie__btn{
                    position: absolute;
                    bottom: 1em;
                    right: 1em;
                    width: clamp(30px,calc(50/1440*100vw),50px);
                }
              button{
                    background: transparent;
                    border: none;
                    padding: 0;
                }
                button img{
                    width: 100%;
                }
                .pc{
                    display: block;
                }
                .sp{
                    display: none;
                }
                @media (max-width:767px){
            
                                    .pc{
                    display: none !important;
                }
                .sp{
                    display: block !important;
                }
                }