@charset "utf-8";


#imgArea *,
#wearshop *,
#wearshop_02 *,
#itemList *,
#mapArea * {
    box-sizing: border-box;
}



/* ==========================================================================
imgArea
========================================================================== */
#imgArea {
    position: relative;
    padding-top: 56px;
    height: 200vh;
}

#imgArea .background {
    width: 100%;
    height: 100%;
    height: 100vh;
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    left: 0;
    z-index: 1
}

#imgArea .backText {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    z-index: 3;
}

#imgArea .backTextWrap {
    position: relative;
    width: 100%;
    height: 100%;
    height: 300px;
}

#imgArea .backText p {
    position: relative;
    position: absolute;
    top: 500px;
    top: 0px;
    width: 100%;
    color: #000;
    font-size: 65px;
    font-weight: 700;
    text-align: center;
    line-height: 1.4;
}

#imgArea .backImg {
    width: 100%;
    height: 100%;
    height: 100vh;
    background: center center/cover no-repeat;
}

#imgArea .scroll {
    position: relative;
    width: 100%;
    height: 50vh;
    z-index: 2;
    bottom: 0;
    opacity: 0;
}

@media (max-width: 768px) {
    #imgArea .backText p {
        font-size: clamp(30px,8.5vw,65px);
    }
}



/* ==========================================================================
wearshop
========================================================================== */
#wearshop .headingH2_sub {
    text-align: center;
}

#wearshop .headingH2_sub p {
    display: inline-block;
    padding-bottom: 0.25em;
    margin-bottom: 60px;
    border-bottom: 7px solid #C00913;
    color: #000000;
    font-size: 60px;
    font-weight: 700;
    text-align: center;
}

#wearshop .shopPicList {
    display: flex;
    flex-wrap: wrap;
}

#wearshop .shopPicList li {
    flex: 1 1 33%;
    margin-right: 0.5%;
    margin-bottom: 0.5%;
    height: 406px;
    overflow: hidden;
}

#wearshop .shopPicList li:nth-child(3),
#wearshop .shopPicList li:nth-child(5) {
    margin-right: 0;
}

#wearshop .shopPicList li:nth-child(4),
#wearshop .shopPicList li:nth-child(5) {
    margin-bottom: 0;
}

#wearshop .shopPicList li.big {
    flex: 1 1 66.5%;
}

/* background img */
#wearshop .shopPicList li .img {
    width: 100%;
    height: 100%;
    transition: transform .5s ease 0s, filter .5s ease 0s;
}

#wearshop .shopPicList li.img01 .img { background: center center/cover no-repeat; }
#wearshop .shopPicList li.img02 .img { background: center center/cover no-repeat; }
#wearshop .shopPicList li.img03 .img { background: center center/cover no-repeat; }
#wearshop .shopPicList li.img04 .img { background: center center/cover no-repeat; }

/* text */
#wearshop .shopPicList .text01 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

#wearshop .shopPicList .text01 h3 {
    margin-bottom: 0.5em;
    color: #000;
    font-size: clamp(34px,4vw,40px);
    font-weight: 700;
    line-height: 1.2;
}

#wearshop .shopPicList .text01 h3::before {
    content: '';
    display: block;
    margin: 0 auto;
    margin-bottom: 15px;
    width: 56px;
    /*width: 20%;*/
    height: 7px;
    background: #C00913;
}

#wearshop .shopPicList .text01 p {
    color: #878787;
    font-size: 23px;
}

@media (min-width: 769px) {
    #wearshop .shopPicList li:hover .img {
        transform: scale(1.1);
        transform-origin: center center;
        filter: grayscale(100%);
    }
}

@media (max-width: 768px) {
    #wearshop {
        margin-bottom: 50px;
    }

    #wearshop .headingH2_sub p {
        margin-bottom: 40px;
        font-size: clamp(30px,7.5vw,60px);
    }

    #wearshop .shopPicList li {
        flex: 1 1 49.5%;
        margin-right: 0;
    }

    #wearshop .shopPicList li:nth-child(1) { order: 1; }
    #wearshop .shopPicList li:nth-child(2) { order: 2; }
    #wearshop .shopPicList li:nth-child(3) { order: 4; }
    #wearshop .shopPicList li:nth-child(4) { order: 3; }
    #wearshop .shopPicList li:nth-child(5) { order: 5; }

    #wearshop .shopPicList li:nth-child(1),
    #wearshop .shopPicList li:nth-child(3) {
        margin-right: 0.5%;
    }

    #wearshop .shopPicList li:nth-child(3),
    #wearshop .shopPicList li:nth-child(5) {
        margin-bottom: 0;
    }

    #wearshop .shopPicList li.big {
        flex: 1 1 100%;
        margin-bottom: 0.5%;
    }

    /* text */
    #wearshop .shopPicList .text01 h3 {
        font-size: 5vw;
    }

    #wearshop .shopPicList .text01 p {
        font-size: 4.3vw;
    }
}



/* ==========================================================================
wearshop_02
========================================================================== */
#wearshop_02 {
    transition: padding 1s;
}

#wearshop_02.padding {
    padding-bottom: 0 !important;
}

#wearshop_02 .shopLogoImg {
    margin-bottom: 90px;
    width: 30%;
    max-width: 355px;
    opacity: 0;
    transition: opacity .5s ease-in;
}

#wearshop_02 .shopLogoImg.scrollin {
    opacity: 1;
}

#wearshop_02 .shopLogoImg img {
    width: 100%;
}

#wearshop_02 .shopPicList_02 {
    position: relative;
    height: 2500px;
}

#wearshop_02 .shopPicList_02 img {
    width: 100%;
}

#wearshop_02 .shopPicList_02 > div {
    width: 49.75%;
    float: left;
}

#wearshop_02 .shopPicList_02 .bigPic {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    left: 0;
    width: 49.75%;
    height: 100vh;
    margin-right: 0.25%;
    background: no-repeat center center/cover;
}

#wearshop_02 .shopPicList_02 .smallPic {
    margin-left: 0.25%;
    overflow: hidden;
}

#wearshop_02 .shopPicList_02 .smallPicList {
    width: 49.5%;
    float: left;
}

#wearshop_02 .shopPicList_02 .smallPicList.typeA {
    margin-right: 1%;
}

#wearshop_02 .shopPicList_02 .smallPicList.typeB {
    margin-top: -50px;
}

#wearshop_02 .shopPicList_02 .smallPicList li {
    width: 100%;
    height: 458px;
    margin-bottom: 2%;
}

#wearshop_02 .shopPicList_02 .smallPicList li:last-child {
    margin-bottom: 0;
}

#wearshop_02 .shopPicList_02 .smallPicList.typeB li:last-child {
    height: calc(458px + 50px);
}

#wearshop_02 .shopPicList_02 > div::after,
#wearshop_02 .shopPicList_02 .smallPicList::after {
    content: "";
    display: block;
    clear: both;
}

/* background img */
#wearshop_02 .shopPicList_02 .smallPicList li .img {
    position: relative;
    width: 100%;
    height: 100%;
}

#wearshop_02 .shopPicList_02 .smallPicList.typeA li.img01 .img { background: center center/cover no-repeat; }
#wearshop_02 .shopPicList_02 .smallPicList.typeA li.img02 .img { background: center center/cover no-repeat; }
#wearshop_02 .shopPicList_02 .smallPicList.typeA li.img03 .img { background: center center/cover no-repeat; }
#wearshop_02 .shopPicList_02 .smallPicList.typeA li.img04 .img { background: center center/cover no-repeat; }
#wearshop_02 .shopPicList_02 .smallPicList.typeB li.img01 .img { background: center center/cover no-repeat; }
#wearshop_02 .shopPicList_02 .smallPicList.typeB li.img02 .img { background: center center/cover no-repeat; }
#wearshop_02 .shopPicList_02 .smallPicList.typeB li.img03 .img { background: center center/cover no-repeat; }
#wearshop_02 .shopPicList_02 .smallPicList.typeB li.img04 .img { background: center center/cover no-repeat; }

@media (min-width: 769px) {
    /* hover */
    #wearshop_02 .shopPicList_02 .smallPicList li .black {
        display: flex;
        flex-direction: column;
        justify-content: end;
        position: absolute;
        padding: 1em;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, .6);
        opacity: 0;
        transition: padding .5s ease 0s, opacity .5s ease 0s;
    }
    
    #wearshop_02 .shopPicList_02 .smallPicList li:hover .black {
        opacity: 1;
    }
}

@media (max-width: 768px) {
    #wearshop_02 .shopLogoImg {
        margin-bottom: 50px;
        width: 50%;
    }

    #wearshop_02 .shopPicList_02 {
        height: fit-content !important;
    }

    #wearshop_02 .shopPicList_02 > div {
        width: 100%;
        float: none;
    }

    #wearshop_02 .shopPicList_02 .bigPic {
        position: relative;
        top: 0 !important;
        margin-bottom: -2px !important;
        margin-right: 0;
        width: 100%;
        height: auto;
        background: none;
    }

    #wearshop_02 .shopPicList_02 .smallPic {
        margin-left: 0;
        margin-top: 1%;
    }

    #wearshop_02 .shopPicList_02 .smallPicList.typeB {
        margin-top: -50px;
    }

    #wearshop_02 .shopPicList_02 .smallPicList li {
        height: 70vw !important;
    }

    #wearshop_02 .shopPicList_02 .smallPicList.typeB li:last-child {
        height: calc(70vw + 50px) !important;
    }
}



/* ==========================================================================
mapArea
========================================================================== */
#mapArea {
    padding: 79px 0;
    background: #343434;
}

#mapArea .headingH2 {
    margin-bottom: 0;
}

#mapArea .address {
    display: flex;
    margin-top: 2em;
    margin-bottom: 1em;
}

#mapArea .address > div {
    display: flex;
}

#mapArea .address .icon {
    width: 25px;
    margin-top: 0.8em;
    margin-right: 0.5em;
    flex-shrink: 0;
}

#mapArea .address .icon img {
    width: 100%;
}

#mapArea .address p {
    color: #8AA6F5;
    font-size: 30px;
    line-height: 1.4;
}

#mapArea .map {
    width: 100%;
    height: 550px;
    background: no-repeat center center/cover;
}

#mapArea .infoList {
    display: flex;
    justify-content: space-between;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    margin-top: 90px;
}

#mapArea .infoList li {
    width: 30%;
}

#mapArea .infoList li .iconImg {
    max-width: 149px;
    margin: 0 auto;
}

#mapArea .infoList li .iconImg img {
    width: 100%;
}

#mapArea .infoList li p {
    color: #fff;
    font-size: 25px;
    font-size: clamp(18px,2.4vw,25px);
    font-weight: 700;
    text-align: center;
    line-height: 1.4;
}

#mapArea .infoList li p.title {
    margin-top: 0.5em;
    color: #DFDFDF;
    font-weight: 500;
}

@media (max-width: 768px) {
    #mapArea .spFlex {
        display: flex;
        flex-direction: column-reverse;
    }

    #mapArea .address {
        flex-wrap: wrap;
        margin-bottom: 0;
        padding-bottom: 2em;
        border-bottom: 1px solid #fff;
    }

    #mapArea .address .icon {
        margin-top: 0.5em;
        width: 28px;
    }

    #mapArea .address p {
        font-size: clamp(20px,4vw,30px);
    }

    #mapArea .address p.onlySp {
        color: #fff;
        font-size: clamp(25px,4vw,35px);
    }

    #mapArea .map {
        margin-top: 2em;
        height: 45vw;
        max-height: 550px;
    }
    
    #mapArea .infoList {
        flex-direction: column;
        align-items: center;
    }

    #mapArea .infoList li {
        width: 100%;
    }

    #mapArea .infoList li + li {
        margin-top: 4em;
    }

    #mapArea .infoList li .iconImg {
        width: 20%;
        min-width: 90px;
    }

    #mapArea .infoList li p {
        font-size: 20px;
    }
}