/* カスタマイズ用CSS */


/*==========  anti  ============*/

html,
body {
    overflow-x: hidden;
}

.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;
}

.lg {
    font-size: 1.6em;
    font-weight: bold;
    padding-left: 0 !important;
}

.logo_finger {
    width: 7em !important;
    margin: 1em auto;
}

.red {
    color: #cd412d !important;
}


/*=====================  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;
}

.js-footerLayout {
    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;
    }
}