@charset "UTF-8";
.bnr{
      display:block;
    max-width:100%;
    height:auto;
    width:60%;
    margin:150px auto 0;
    padding-left:200px;
}

@media screen and (max-width:1024px){
    .bnr{
        width:80%;
        padding-left:100px;
        margin-top:120px;
    }
}

@media screen and (max-width:768px){
    .bnr{
        width:90%;
        padding-left:0;
        margin-top:80px;
    }
}

@media screen and (max-width:375px){
    .bnr{
        width:95%;
        padding-left:0;
        margin-top:50px;
    }
}

body {
    opacity: .1;
    animation: bodyAppear .3s .3s forwards;
}

@keyframes bodyAppear {
    0% {
        opacity: .1;
    }

    100% {
        opacity: 1;
    }
}

.visually-hidden {
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
}

@media screen and (min-width:768px) {}

@media screen and (min-width:1025px) {}

/*============================
	kv 
============================*/

.kv {
    margin-top: 60px;
}

.kv__swiper {
    background: #fff;
}

.kv__img {
    & img {
        width: 100%;
        object-fit: cover;
    }
}


.slide-in,
.slide-in_inner {
    animation-duration: 1s;
    animation-delay: .3s;
}

.kv__logo01 {
    position: absolute;
    max-width: 249px;
    width: calc((249/780)*100%);
    z-index: 99;
    transform: translate(-50%, -50%);
    top: 20%;
    left: 50%;
}

.kv__logo02 {
    position: absolute;
    max-width: 334px;
    width: calc((334/780)*100%);
    z-index: 99;
    transform: translate(-50%, -50%);
    top: 70%;
    left: 50%;
}


.kv__scroll {
    max-width: 14px;
    min-width: 10px;
    width: calc((14/1920)*100%);
    position: absolute;
    top: calc(100% + 20px);
    right: 3%;
    z-index: 9;
    display: block;
}

.kv.onetime {

    .kv__copy .slide-in,
    .kv__copy .slide-in_inner {
        animation-duration: 1s;
        animation-delay: 5s;
    }
}


@keyframes copyAnime {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}


/* swiper */
.kv__swiper-area {
    position: relative;
}

.swiper__imgwrap {
    overflow: hidden;
    display: block;
}

.kv .swiper-slide-active .swiper__imgwrap img,
.kv .swiper-slide-duplicate-active .swiper__imgwrap img,
.kv .swiper-slide-prev .swiper__imgwrap img {
    animation: zoom-out 10s linear 0s 1 normal both;
}

@keyframes zoom-out {
    0% {
        transform: scale(1.1);
    }

    100% {
        transform: scale(1);
    }
}

.kv .swiper-pagination {
    left: 5%;
    left: auto;
    bottom: 5%;
    z-index: 99;
    display: flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
}


.kv .swiper-pagination-bullet {
    display: block;
    width: 15px;
    height: 2px;
    z-index: 9;
    background: #fff;
    border-radius: 0% !important;
    margin: 0 10px !important;
    opacity: 1;

}

.kv .swiper-pagination-bullet-active {
    opacity: 1;
    background: #bf3600;
}




@media screen and (min-width:768px) {
    .kv {
        margin-top: 60px;
    }

    .kv__img {
        display: flex;
        justify-content: space-between;

        .swiper__imgwrap {
            width: 50%;
        }
    }

    .kv__logo01 {
        width: calc((249/1920)*100%);
        top: 50%;
        left: 25%;
    }

    .kv__logo02 {
        width: calc((334/1920)*100%);
        top: 50%;
        left: 75%;
    }


    .kv__scroll {
        width: calc((14/1920)*100%);
        top: calc(100% + 20px);
        right: 3%;
    }

}



@media screen and (min-width:1025px) {
    .kv {
        margin-top: 0;

    }

    .kv__swiper {
        width: 81.25%;
        margin: 0 0 0 auto;
    }

    .kv__img {
        display: flex;
        justify-content: space-between;

        .swiper__imgwrap {
            width: 50%;
        }
    }

    .kv__logo01 {
        width: calc((249/1920)*100%);
        top: 50%;
        left: 38%;
    }

    .kv__logo02 {
        width: calc((334/1920)*100%);
        top: 50%;
        left: 82%;
    }


    .kv__scroll {
        width: calc((14/1920)*100%);
        top: calc(100% + 20px);
        right: 3%;
    }


}



/*============================
   concept
============================*/
.concept {
    padding: 60px 0 0;
}

.conc__txtwrap {
    padding: 0 5%;
    margin-bottom: 80px;
}

.conc__ttl {
    width: fit-content;
    margin: 0 auto 20px;
}

.conc__lead {
    padding: 0 5%;
    margin-bottom: 80px;
}

.conc__item {
    width: 95%;
    max-width: 830px;
    margin-bottom: 30px;
    position: relative;
}

.conc__num {
    max-width: 424px;
    width: calc((424/830)*100%);
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
}

.conc__container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    color: #fff;
}

.conc__h3 {
    margin-bottom: 20px;

    .font-ex {
        margin-top: .3em;
        display: block;
    }
}

.conc__item:last-child {
    margin: 0 0 0 auto;

    .conc__num {
        max-width: 484px;
        width: calc((484/830)*100%);
        top: 95%;
        left: 25%;
    }
}

.conc__btn {
    margin: 50px auto 0 5%;
}

@media screen and (min-width:768px) {
    .concept {
        padding: 100px 0 0;
    }

    .conc__ttl {
        position: absolute;
        left: 50%;
        top: 50%;
        margin: 0;
        transform: translate(-50%, -50%);
    }

    .conc__lead {
        position: absolute;
        width: 40%;
        right: 0;
        top: -2em;
        padding: 0 1em 0 0;
        margin-bottom: 0;
    }

    .conc__item {
        width: 43%;
        max-width: 830px;
        margin-bottom: 0;
    }

    .conc__num {
        width: calc((424/830)*100%);
        top: 0;
        left: 50%;
    }

    .conc__h3 {
        margin-bottom: 20px;

        .font-ex {
            margin-top: .3em;
        }
    }

    .conc__item:last-child {
        margin: 120px 0 0;

        .conc__num {
            width: calc((484/830)*100%);
            top: 95%;
            left: 25%;
        }
    }

    .conc__btn {
        margin: 50px 57% 0 auto;
    }

}

@media screen and (min-width:1025px) {
    .concept {
        padding: 270px 0 0;
    }



    .conc__ttl {
        left: 50%;
        top: 50%;
    }

    .conc__lead {
        width: 40%;
        right: 0;
        top: -2em;
        padding: 0 1em 0 0;
    }

    .conc__item {
        width: 43%;
    }


    .conc__h3 {
        margin-bottom: 20px;

        .font-ex {
            margin-top: 0em;
        }
    }

    .conc__item:last-child {
        margin: 160px 0 0;

    }

    .conc__btn {
        margin: 0 57% 0 auto;
    }
}


/*============================
   shop
============================*/
.shop {
    padding: 60px 0;
}

.shop__img {
    width: 95%;
    margin-bottom: 30px;
}

.shop__right {
    padding: 0 5%;
}

.shop__logo {
    max-width: 214px;
    width: 160px;
    display: block;
    margin-bottom: 20px;
}

.shop__copy {
    line-height: 1.6;
    font-size: 2rem;
}

@media screen and (min-width:768px) {
    .shop {
        padding: 80px 0;
    }

    .shop__img {
        width: 55%;
        margin-bottom: 0;
    }

    .shop__right {
        width: 40%;
        padding: 0 3% 0 0;
    }

    .shop__logo {
        max-width: 214px;
        width: 160px;
        margin-bottom: 20px;
    }

    .shop__copy {
        font-size: 2.4rem;
    }
}

@media screen and (min-width:1025px) {
    .shop {
        padding: 150px 0 100px;
    }

    .shop__img {
        width: 55%;
    }

    .shop__right {
        width: 40%;
        padding: 0 1% 0 0;
    }

    .shop__logo {
        max-width: 214px;
        width: fit-content;
        margin-bottom: 30px;
    }

    .shop__copy {
        font-size: 3.4rem;
    }
}

/*============================
   menu
============================*/

.menu__top {
    padding: 40px 5%;
    background: url(../images/menu_bg.jpg) no-repeat center center/cover;
    color: #fff;
}

.menu__ttl {
    .fs-200 {
        font-size: 10rem;
        line-height: 1;
    }

    .fs-100 {
        font-size: 6rem;
        font-weight: 300;
        line-height: 1;
    }
}

.menu__main {
    padding: 60px 0 0;
}

.menu__atc {
    max-width: 695px;
    position: relative;
    margin: 0 auto 20px;
    position: relative;

    & a {
        display: block;
        width: 100%;
        height: 100%;
    }
}

.menu__h3 {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-feature-settings: initial;
    padding: 1em .5em;
    background: rgba(151, 14, 0, .9);
    color: #fff;
    white-space: nowrap;

    &::before {
        content: "";
        position: absolute;
        width: calc(100% + 10px);
        height: calc(100% + 10px);
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        border: solid 1px #970e00;
    }
}

@media screen and (min-width:768px) {

    .menu__top {
        padding: 60px 5%;
        align-items: center;
    }

    .menu__ttl {
        .fs-200 {
            font-size: 10rem;
            line-height: 1;
        }

        .fs-100 {
            font-size: 6rem;
            font-weight: 300;
            line-height: 1;
        }
    }

    .menu__lead {
        margin: 3em 0 0 2em;
    }

    .menu__main {
        padding: 60px 0 0;
    }

    .menu__items {
        width: 95%;
        margin-bottom: 30px;

        &:nth-child(2) {
            margin: 0 0 0 auto;
        }
    }

    .menu__img {
        & img {
            object-fit: cover;
            min-height: 220px;
        }
    }

    .menu__atc {
        width: 48%;
        margin: 0;
        position: relative;
    }

    .menu__h3 {

        padding: 1em .5em;

        &::before {
            width: calc(100% + 10px);
            height: calc(100% + 10px);
        }
    }

}

@media screen and (min-width:1025px) {

    .menu__top {
        padding: 120px 5%;
    }

    .menu__ttl {
        .fs-200 {
            font-size: 20rem;
        }

        .fs-100 {
            font-size: 10rem;
        }
    }

    .menu__lead {
        margin-left: 2em;
    }

    .menu__main {
        padding: 80px 0 0;
    }

    .menu__items {
        width: 95%;
        max-width: 1460px;
        margin-bottom: 50px;

        &:nth-child(2) {
            margin: 0 0 0 auto;
        }
    }

    .menu__img {
        & img {
            min-height: 320px;
        }
    }

    .menu__atc {
        width: 48%;
    }

    .menu__h3 {

        padding: 1em .5em;

        &::before {
            width: calc(100% + 10px);
            height: calc(100% + 10px);
        }
    }

}


/*============================
   scean
============================*/
.scean {
    padding: 80px 0 0;
}

.scene__img {
    width: 95%;

    & img {
        object-fit: cover;
        width: 100%;
        min-height: 160px;
    }
}

.scene__ttl {
    position: absolute;
    left: 0;
    top: 0;
    transform: translate(0, -50%);

    .fs-180 {
        font-size: 4rem;
    }

    .fs-130 {
        font-size: 3rem;
    }

}

.scene__box {
    width: 95%;
    margin: 0 0 0 auto;
    padding: 2em 5% 2em 5%;
    color: #fff;

    &::before {
        content: "";
        position: absolute;
        width: 150%;
        height: calc(100% + 100px);
        background: #22190c;
        z-index: -1;
        left: 0;
        bottom: 0;
    }
}

.scene__txt {
    margin-bottom: 20px;
}

@media screen and (min-width:768px) {
    .scean {
        padding: 120px 0 0;
    }

    .scene__img {
        width: 90%;

        & img {
            min-height: 160px;
        }
    }

    .scene__ttl {
        left: 0;
        top: 0;

        .fs-180 {
            font-size: 8rem;
        }

        .fs-130 {
            font-size: 6rem;
        }
    }

    .scene__box {
        width: 90%;
        margin: 0 0 0 auto;
        align-items: flex-end;
        padding: 2em 5% 2em 5%;

        &::before {

            width: 150%;
            height: calc(100% + 150px);
        }
    }

    .scene__txt {
        margin: 0;
        max-width: calc(100% - 260px);
    }
}

@media screen and (min-width:1025px) {
    .scean {
        padding: 240px 0 0;
    }

    .scene__img {
        width: 90%;

        & img {
            min-height: 160px;
        }
    }

    .scene__ttl {
        left: 0;
        top: 0;

        .fs-180 {
            font-size: min(18rem, 10vw);
        }

        .fs-130 {
            font-size: min(13rem, 8vw);
        }
    }

    .scene__box {
        width: 90%;
        margin: 0 0 0 auto;
        justify-content: flex-start;
        padding: 2em 3% 3em 3%;

        &::before {

            width: 150%;
            height: calc(100% + 250px);
        }
    }

    .scene__txt {
        padding-right: 2em;
        margin: 0;
        max-width: calc(100% - 320px);
    }
}


/*============================
   cafe
============================*/
.cafe {
    padding: 60px 0 0;

    &::before {
        content: "";
        position: absolute;
        width: 100%;
        height: calc(100% + 100px);
        background: url(../images/cafe_bg.png);
        left: 0;
        bottom: 0;
        z-index: -2;
    }
}

.cafe__left {
    padding: 0 5%;
    margin-bottom: 30px;
}

.cafe__logo {
    max-width: 494px;
    width: 240px;
    display: block;
    margin-bottom: 20px;
}

.cafe__copy {
    line-height: 1.5;
}

.cafe__img {
    width: 95%;
    margin: 0 0 0 auto;
}

.cafe__btm {
    padding: 40px 0 0;
}

.cafe__obj {
    max-width: 573px;
    width: calc((573/1920)*100%);
    left: 0;
    top: 0;
    transform: translate(0, -50%);
    z-index: -1;
}

.cafe__circle {
    max-width: 283px;
    width: calc((283/1920)*200%);
    left: 0;
    top: 0;
    transform: translate(0, -50%);
    z-index: 99;
    pointer-events: none;

    & img {
        display: block;
        animation: circleAnime 10s infinite linear;
    }

}

@keyframes circleAnime {
    0% {
        transform: rotate(0);
    }

    100% {
        transform: rotate(360deg);
    }

}

.cafe__atc {
    max-width: 520px;
    margin: 0 auto 50px;
z-index: 9;
    &:last-child {
        margin-bottom: 0;
    }

    & a {
        display: block;
        width: 100%;
        height: 100%;
        position: relative;

        &::before {
            content: "";
            position: absolute;
            width: calc(100% - 15px);
            height: calc(100% - 15px);
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            border: solid 1px #fff;
        }
    }
}

.cafe__h3 {
    position: absolute;
    top: 45%;
    left: 50%;
    width: 90%;
    transform: translate(-50%, -50%);
    color: #fff;

    .font-en {
        font-size: 3rem;

    }

    .txt {
        margin-top: .5em;
    }
}

.cafe__btn02 {
    max-width: 248px;
    width: calc((248/520)*100%);
    top: 90%;
    right: 3%;
    transform: translate(0, -50%);
}

@media screen and (min-width:768px) {
    .cafe {
        padding: 80px 0 0;

        &::before {
            height: calc(100% + 250px);
        }
    }

    .cafe__left {
        width: 50%;
        padding: 0 0 0 3%;
        margin-bottom: 0;
    }

    .cafe__logo {
        max-width: 494px;
        width: 300px;

        margin-bottom: 30px;
    }

    .cafe__img {
        width: 45%;
        margin: 0;
    }


    .cafe__btm {
        padding: 40px 0 0;
    }

    .cafe__obj {
        width: calc((573/1920)*100%);
        left: 0;
        top: 0;

    }

    .cafe__circle {
        width: calc((283/1920)*100%);
        left: 0;
        top: 0;


    }

    .cafe__items {
        align-items: flex-start;
    }

    .cafe__atc {
        width: 32%;
        margin: 0;

        &:nth-child(3) {

            margin: 30px 0 0;
        }

        &:last-child {

            margin: 60px 0 0;
        }

        & a {


            &::before {
                width: calc(100% - 15px);
                height: calc(100% - 15px);
            }
        }
    }

    .cafe__h3 {
        top: 45%;
        left: 50%;
        width: 90%;

        .font-en {
            font-size: 2.4rem;

        }

        .txt {
            margin-top: .5em;
        }
    }

    .cafe__btn02 {
        width: calc((248/520)*100%);
        top: 90%;
        right: 3%;
    }
}

@media screen and (min-width:1025px) {
    .cafe {
        padding: 200px 0 0;

        &::before {
            height: calc(100% + 300px);
        }
    }

    .cafe__left {
        width: 50%;
        padding: 0 0 0 1%;
    }

    .cafe__txtwrap {
        max-width: 612px;
        padding-left: 5%;
    }

    .cafe__logo {
        max-width: 494px;
        width: 300px;

        margin-bottom: 30px;
    }

    .cafe__img {
        width: 45%;
        margin: 0;
    }

    .cafe__btm {
        padding: 0;
    }

    .cafe__obj {
        width: calc((573/1920)*100%);
        left: 0;
        top: 0;

    }

    .cafe__circle {
        width: calc((283/1920)*100%);
        left: 0;
        top: 0;


    }

    .cafe__items {
        align-items: flex-start;
    }

    .cafe__atc {
        width: 32%;

        &:nth-child(3) {

            margin: 120px 0 0;
        }

        &:last-child {

            margin: 240px 0 0;
        }

        & a {


            &::before {
                width: calc(100% - 20px);
                height: calc(100% - 20px);
            }
        }
    }

    .cafe__h3 {
        top: 45%;
        left: 50%;
        width: 90%;

        .font-en {
            font-size: min(5.4rem, 3vw);

        }

        .txt {
            margin-top: .75em;
        }
    }

    .cafe__btn02 {
        width: calc((248/520)*100%);
        top: 90%;
        right: 3%;
    }
}

/*============================
   space
============================*/
.space {
    padding: 100px 0 60px;

    &::before {
        content: "";
        position: absolute;
        width: 100%;
        height: calc(100% + 60px);
        background: url(../images/cafe_bg.png);
        top: 0;
        left: 0;
    }
}

.space__obj {
    max-width: 497px;
    width: calc((497/1920)*100%);
    left: 0;
    top: 100px;
    transform: translate(0, -50%);
    z-index: 1;

}

.space__right {
    padding: 30px 5% 0;
    position: relative;
}

.space__logo {
    max-width: 266px;
    width: 160px;
    margin: 0 auto 20px;
    display: block;

}

.space__btn.-wh {
    border-color: #393c3c;
    color: #393c3c;

    &::before {
        background: url(../images/btn_arw_bk.png) no-repeat center center/contain;
    }
}

@media screen and (min-width:768px) {
    .space {
        padding: 100px 0 80px;

        &::before {
            height: calc(100% + 100px);
        }
    }

    .space__obj {
        width: calc((497/1920)*100%);
        left: 0;
        top: 100px;

    }

    .space__img {
        width: 50%;
    }

    .space__right {
        width: 50%;
        padding: 0 3% 0;

    }

    .space__logo {
        max-width: 266px;
        width: 160px;
        margin: 0 auto 20px;

    }
}

@media screen and (min-width:1025px) {
    .space {
        padding: 150px 0;

        &::before {
            height: calc(100% + 150px);
        }
    }

    .space__obj {
        width: calc((497/1920)*100%);
        left: 0;
        top: 100px;

    }

    .space__img {
        width: 50%;
    }

    .space__right {
        width: 50%;
        padding: 0 3% 0;

    }

    .space__logo {
        max-width: 266px;
        width: fit-content;
        margin: 0 auto 30px;

    }
}

/*============================
   access
============================*/
.access {
    padding: 0 0 60px;
}

.acc__ttl {
    font-size: 5rem;
    font-weight: 300;
    padding: 0 5%;
}

.acc__atc {
    width: 95%;
    margin: 0 0 40px auto;

    &:last-child {
        margin-bottom: 0;
    }
}

.acc__ttlwrap {
    height: 200px;

    & a {
        display: flex;
        align-items: center;
        position: relative;
        width: 100%;
        height: 100%;
        padding: 0 5%;
        background: url(../images/access_bg01.jpg) no-repeat center center/cover;
    }

}

.acc__logo {
    transform: scale(.75);
    transform-origin: left center;
}

.acc__btn {
    max-width: 130px;
    width: 100px;
    bottom: 20px;
    right: 5%;
    display: block;
}

.acc__atc:nth-child(2) {
    .acc__ttlwrap a {
        background: url(../images/access_bg02.jpg) no-repeat center center/cover;
    }
}

.acc__txtwrap {
    padding: 1em 5% 1em 0;
}

.acc__txt {
    margin-bottom: 2em;
}

.acc__btnwrap {
    align-items: flex-end;
    display: flex;
}

.acc__ig {
    max-width: 27px;
    width: 20px;
    margin-right: 5%;
    display: block;
}

.acc__reserve {
    display: block;
    max-width: 233px;
    width: 180px;
}

@media screen and (min-width:768px) {
    .access {
        padding: 0 0 80px;
    }

    .acc__ttl {
        font-size: 10rem;
        line-height: 1;
        padding: 0;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        font-feature-settings: initial;
    }

    .acc__items {
        flex: 1 1 auto;
        padding-left: 5%;
    }

    .acc__atc {
        width: 100%;
        margin: 0 0 40px auto;

    }

    .acc__ttlwrap {
        height: 200px;

        & a {
            display: flex;
            align-items: center;
            width: 100%;
            height: 100%;
            padding: 0 5%;
        }
    }

    .acc__logo {
        transform: scale(.75);
    }

    .acc__btn {
        max-width: 130px;
        width: 100px;
        bottom: 20px;
        right: 5%;
    }


    .acc__txtwrap {
        padding: 1em 3% 0 0;
    }

    .acc__txt {
        margin-bottom: 0;
    }

    .acc__ig {
        max-width: 27px;
        width: 20px;
        margin-right: 5%;
    }

    .acc__reserve {
        max-width: 233px;
        width: 180px;
    }
}

@media screen and (min-width:1025px) {
    .access {
        padding: 0 0 120px;
    }

    .acc__ttl {
        font-size: 22rem;

    }

    .acc__items {
        flex: 1 1 auto;
        padding-left: 2%;
    }

    .acc__atc {
        width: 100%;
        margin: 0 0 60px auto;

    }

    .acc__ttlwrap {
        height: 290px;
    }

    .acc__logo {
        transform: scale(1);
    }

    .acc__btn {
        max-width: 130px;
        width: 130px;
        bottom: 30px;
        right: 5%;
    }


    .acc__txtwrap {
        padding: 1em 1% 0 0;
        max-width: 1080px;
    }

    .acc__txt {
        margin-bottom: 0;
    }

    .acc__ig {
        max-width: 27px;
        width: 27px;
        margin-right: 20px;
    }

    .acc__reserve {
        max-width: 233px;
        width: 233px;
    }
}

/* hd__pd */

@media screen and (min-width:1025px) {
    .hd__pd {
        padding-left: 200px;
    }
}