@charset "UTF-8";

/*==================================================================================================

       G translate

===================================================================================================*/

/* jsのclick function コメントアウト要 */

.g-translate-wrap {
        position: absolute;
        /*right:calc( 2.05vw + 140px);*/
        right:2.05vw;
        top:28px;
        line-height: 1;
        -webkit-transition: all .3s ease;
                transition: all .3s ease;
        }
        select.g-translate {
        writing-mode: horizontal-tb !important;
        text-rendering: auto;
        color: -internal-light-dark(black, white);
        letter-spacing: normal;
        word-spacing: normal;
        line-height: normal;
        text-transform: none;
        text-indent: 0px;
        text-shadow: none;
        display: inline-block;
        text-align: start;
        appearance: auto;
        box-sizing: border-box;
        align-items: center;
        white-space: pre;
        -webkit-rtl-ordering: logical;
        background-color: -internal-light-dark(rgb(255, 255, 255), rgb(59, 59, 59));
        cursor: default;
        margin: 0em;
        border-width: 1px;
        border-style: solid;
        border-color: -internal-light-dark(rgb(118, 118, 118), rgb(133, 133, 133));
        border-image: initial;
        border-radius: 3px;
        background: #F6F6F6;
        color: #222;
        border: 1px solid #C9C9C9;
        padding:.25rem;
        }

        .header-wrap.fixed .g-translate-wrap { top:-50px; }
        
        @media screen and (max-width: 1200px) {
        .g-translate-wrap { top:22px; right:calc( 2.05vw + 115px); }
        }

.g-translate-wrap-sp {
        position: relative;
        width: 270px;
        margin: 1rem 0;
        }
        select.g-translate-sp {
        writing-mode: horizontal-tb !important;
        text-rendering: auto;
        color: -internal-light-dark(black, white);
        letter-spacing: normal;
        word-spacing: normal;
        line-height: normal;
        text-transform: none;
        text-indent: 0px;
        text-shadow: none;
        display: inline-block;
        text-align: start;
        appearance: auto;
        box-sizing: border-box;
        align-items: center;
        white-space: pre;
        -webkit-rtl-ordering: logical;
        background-color: -internal-light-dark(rgb(255, 255, 255), rgb(59, 59, 59));
        cursor: default;
        margin: 0em;
        border-width: 1px;
        border-style: solid;
        border-color: -internal-light-dark(rgb(118, 118, 118), rgb(133, 133, 133));
        border-image: initial;
        border-radius: 0px;
        background: #FFF;
        color: #111;
        border: none;
        padding:1rem .25rem;
        box-sizing: border-box;
        width:270px;
        height: auto;
        }
/*==================================================================================================

       Fixed ヘッダー

===================================================================================================*/

header.main-header { position: relative; z-index:10;}
        .header-wrap {
        position: fixed;
        width:100%;
        height:120px;
        background: #FEFCF5;
        box-sizing: border-box;
        z-index:2;
        -webkit-transition: all .3s ease;
        transition: all .3s ease;
        }
        .fixed-navigation-wrap {
                width:100%;
                box-sizing:border-box;
                position:relative;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                z-index: 10;
                }
                .fixed-logo {
                opacity: 1;
                width:220px;
                box-sizing:border-box;
                position: absolute;
                top:16px;
                left:2.05vw;
                line-height:1;
                z-index:2;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }

        /*=================================================
                main navigation
        ==================================================*/

        .fixed-navigation {
                position:absolute;
                top:62px;
                /*right:calc( 2.05vw + 140px);*/
                right:2.05vw;
                width:980px;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-main-nav {
                float: right;
                position:relative;
                text-align: center;
                }
                .fixed-main-nav li {
                float:left;
                font-size:18px;
                position: relative;
                letter-spacing:0.05em;
                text-align: center;
                padding-right:2rem;
                box-sizing: border-box;
                z-index: 1;
                }
                .fixed-main-nav li:last-child {
                padding-right:0;
                }
                .fixed-main-nav li a {
                line-height: 120%;
                letter-spacing:0em;
                color:#383E3B;
                font-weight: 500;
                display: block;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }

                /*=================================================
                        hover bar
                ==================================================*/

                .fixed-main-nav li a {
                position: relative;
                display: inline-block;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-main-nav li a:after {
                position:absolute;
                bottom:-4px;
                left:50%;
                content:'';
                width:0;
                height:2px;
                background-color:#383E3B;
                transition:.5s;
                -webkit-transform: translateX(-50%);
                transform: translateX(-50%); 
                }
                .fixed-main-nav li a:hover:after {
                width:100%;
                }
                .fixed-main-nav li a:hover {
                opacity:1;
                }

        /*=================================================
                sub navigation
        ==================================================*/

        .fixed-sub {
                position:absolute;
                top:34px;
                right:calc( 2.05vw + 370px);
                width:120px;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-sub-nav {
                float: right;
                position:relative;
                text-align: center;
                }
                .fixed-sub-nav li {
                float:left;
                position: relative;
                letter-spacing:0.05em;
                text-align: center;
                padding-right:2rem;
                box-sizing: border-box;
                z-index: 1;
                }
                .fixed-sub-nav li:last-child {
                padding-right:0;
                }
                .fixed-sub-nav li a {
                font-size:16px;
                line-height: 120%;
                letter-spacing:0em;
                color:#383E3B;
                font-weight: 500;
                display: block;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }

        /*=================================================
                SNS
        ==================================================*/

        .fixed-sns {
                position: absolute;
                top:23px;
                /*right:calc(2.05vw + 290px);*/
                right:calc( 2.05vw + 150px);
                width:500px;
                text-align: right;
                line-height: 1;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-sns li {
                display: inline-block;
                width:150px;
                height:30px;
                line-height: 1;
                margin-right:2px;
                }
                .fixed-sns li:last-child {
                margin-right:0;
                }

        /*=================================================
                Reservation btn
        ==================================================*/

        .fixed-reservation {
                position: absolute;
                text-align: center;
                top:22px;
                right:2.05vw;
                width:120px;
                letter-spacing: 0;
                line-height: 1;
                font-size:18px;
                z-index: 99999;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-reservation a {
                width:100%;
                height:66px;
                line-height:66px;
                box-sizing: border-box;
                border-radius: 10px;
                background: url("../images/parts/orange.jpg") center center repeat;
                text-align: center;
                font-weight:500;
                letter-spacing:0.05em;
                display:block;
                color:#FFF;
                overflow: hidden;
                white-space: nowrap;
                text-decoration:none !important;
                position: relative;
                z-index: 1;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-reservation a:after {
                position: absolute;
                content: "";
                width: 0;
                height: 100%;
                top: 0;
                right: 0;
                z-index: -1;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                background:rgba(255,255,255,.3);
                }
                .fixed-reservation a:hover:after {
                left: 0;
                width: 100%;
                }
                .fixed-reservation a:hover {
                opacity:1;
                width:100%;
                }

        /*=================================================
                fixed
        ==================================================*/

        .header-wrap.fixed {
                height:70px;
                -webkit-box-shadow: 0px 5px 9px rgba(0,0,0,.2);
                box-shadow:	        0px 5px 9px rgba(0,0,0,.2);
                }
                .header-wrap.fixed .fixed-logo { top:3px; width:160px; }
                .header-wrap.fixed .fixed-navigation { top:18px; }
                .header-wrap.fixed .fixed-sub { top:-30px; }
                .header-wrap.fixed .fixed-sns { top:-40px; }
                .header-wrap.fixed .fixed-reservation { top:7px; }
                .header-wrap.fixed .fixed-reservation a { height:56px; line-height: 56px; }

        @media screen and (max-width: 1420px) {
        .fixed-navigation { width:920px; }
        
        .fixed-main-nav li:first-child { display: none; }
        }
        @media screen and (max-width: 1350px) {
        .fixed-navigation { width:800px; }
        .fixed-main-nav li { padding-right:1.5rem; font-size:17px; }
        .fixed-reservation { font-size:17px; }
        }
        @media screen and (max-width: 1240px) {
        .fixed-navigation { width:730px;  }
        .fixed-main-nav li { padding-right:1.25rem; font-size:16px; }
        .fixed-reservation { font-size:16px; }
        }
        @media screen and (max-width: 1200px) {
        .header-wrap { height:100px; }
        .fixed-logo { top:19px; width:160px; }
        .fixed-navigation { width:680px; top:53px; right:calc( 2.05vw + 115px); }
        .fixed-main-nav li { padding-right:1.15rem; font-size:15px; }
        .fixed-sub { top:24px; }
        .fixed-sns { top:16px; right: calc(2.05vw + 265px); }
        .fixed-reservation { top:15px; width:100px; }
        }




/*==================================================================================================

       Mobile ヘッダー

===================================================================================================*/

.header-wrap-sp {
        display: none;
        position: absolute;
        width:100%;
        height:120px;
        box-sizing: border-box;
        z-index: 1;
        -webkit-transition: all .3s ease;
        transition: all .3s ease;
        }
        .mobile-navigation-wrap {
                position: relative;
                width:100%;
                height:120px;
                overflow: hidden;
                z-index: 0;
                }
        .mobile-logo {
                width:180px;
                position: absolute;
                top:15px;
                left:3vw;
                opacity: 1;
                z-index: 999;
                line-height: 1;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                
        /*=================================================
                ハンバーガー
        ==================================================*/

        .gnav {
                letter-spacing: 0;
                }
                .nav-toggle {
                display:block;
                position:fixed;
                right:20px;
                top:15px;
                padding:0;
                width:70px;
                height:70px;
                text-align: center;
                font-size: 0px;
                letter-spacing: 0;
                box-sizing: border-box;
                pointer-events: auto;
                cursor:pointer;
                z-index:99999;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                .nav-toggle div {
                position:absolute;
                width:27px;
                height:18px;
                top:26px;
                right:21px;
                }
                .nav-toggle span {
                display: block;
                position: absolute;
                height: 1px;
                width:27px;
                background:#383E3B;
                border-radius:0px;
                right: 0;
                -webkit-transition: .35s ease-in-out;
                -moz-transition: .35s ease-in-out;
                transition: .35s ease-in-out;
                }
                .nav-toggle span:nth-child(1) { top: 0; width:13px; }
                .nav-toggle span:nth-child(2) { top: 8px; width:20px; }
                .nav-toggle span:nth-child(3) { top: 16px; width:27px; }
                .gnav.active .nav-toggle span { background:#EFEFEF ; }
                .gnav.active .nav-toggle span:nth-child(1) { top: 8px;-webkit-transform: rotate(315deg);-moz-transform: rotate(315deg);transform: rotate(315deg); width:27px;}
                .gnav.active .nav-toggle span:nth-child(2) { width:0; left:50%;}
                .gnav.active .nav-toggle span:nth-child(3) { top: 8px;-webkit-transform: rotate(-315deg);-moz-transform: rotate(-315deg);transform: rotate(-315deg); width:27px; }
                .header-wrap-sp.fixed .nav-toggle { top:0; }
                .header-wrap-sp.fixed .nav-toggle span { background: #332E25; }
                .header-wrap-sp.fixed .active .nav-toggle span { background: #EFEFEF; }
                
                .gnav .menu  { opacity: 1; position: absolute; width:27px; right:21px; top:42px; line-height: 1; font-size:10px; color:#111; -webkit-transition : all 0.2s ease;  -moz-transition : all 0.2s ease; -o-transition : all 0.2s ease;}
                .gnav .close { opacity: 0; position: absolute; width:31px; right:19px; top:42px; line-height: 1; font-size:10px; color:#111;  -webkit-transition : all 0.2s ease; -moz-transition : all 0.2s ease; -o-transition : all 0.2s ease;}
                .gnav.active .menu  { opacity: 0; }
                .gnav.active .close { opacity: 1; }

        /*=================================================
                ナビゲーション
        ==================================================*/

        .gnav-content {
                display: none;
                position: fixed;
                right: 0;
                top: 0;
                width: 100%;
                height: 100%;
                background:#2B2725;
                color:#FFF;
                overflow: auto;
                z-index:9999;
                }
                .gnav-content a { color:#FFF; }
                .gnav-logo {
                width:170px;
                position: relative;
                opacity: 1;
                z-index: 999;
                padding-top:26px;
                padding-bottom:2.5rem;
                line-height: 100%;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                .gnav-wrap {
                max-width:370px;
                width:370px;
                min-width:370px;
                }
                .gnav-outer {
                padding:0 32px;
                box-sizing: border-box;
                }
                .gnav-img {
                background: url("../images/parts/header-sp.jpg") left center / cover;
                width:100%;
                height:100%;
                opacity: .6;
                }
                .mobile-navigation {
                        padding-bottom:2rem;
                        width:100%;
                        -webkit-transition:all .5s ease;
                        transition       : all .5s ease;
                        }
                        .mobile-main-nav {
                        position:relative;
                        }
                        .mobile-main-nav li {
                        width:100%;
                        text-align: left;
                        font-weight:400;
                        }
                        .mobile-main-nav li a {
                        letter-spacing: 0.01em;
                        padding:10px 1rem;
                        border-top:1px dotted rgba(255,255,255,.3);
                        color:#FFF;
                        display:block;
                        font-size:16px;
                        position: relative;
                        box-sizing: border-box;
                        }

                        .mobile-main-nav li:first-child a {
                        border-top: none;
                        }
                        
                        .mobile-main-nav li:last-child a {
                        background:#EC9F47;
                        color:#FFF;
                        border-top: none;
                        border-radius: 2px;
                        height: 48px;
                        }

                .mobile-sns {
                padding:0 0 1rem 0;
                }
                .mobile-sns li {
                display:inline-block;
                margin-right:10px;
                width:36px;
                }


        @media screen and (max-width: 1024px) {
        header.main-header { position: absolute; width:100%; }
        .header-wrap { display:none; }
        .header-wrap-sp { margin-top:0; display:block; opacity: 1; }
        }
        @media screen and (max-width: 767px) {
        .header-wrap-sp { height:96px; }
        .mobile-navigation-wrap { height:96px; }
        .nav-toggle { right: 10px; top:13px; }
        .header-wrap-sp.fixed .nav-toggle { top:0; }
        .mobile-logo  { top:13px; left:3vw; width:180px; }
        .gnav-logo    { top:13px; left:0; width:180px; padding-top:0; position: relative; }
        .gnav-content:after { content:""; display:block; position: fixed; top:0; left:0;width:100%; height:100%; background:  url("../images/parts/header-sp.jpg") left center / cover; z-index: -1; opacity: .15; }
    
        .mobile-main-nav li { }
        .mobile-navigation { padding-top:40px; }
        .gnav-outer { padding:0 18px; max-width:550px; margin: 0 auto; }
        }
/*==================================================================================================

       フッター

===================================================================================================*/

footer {
        width:100%;
        position: relative;
        background:url("../images/parts/footer-bg.jpg") center center / cover;
        font-size:1rem;
        line-height: 180%;
        z-index: 0;
        color:#FFF;
        }
        .footer-logo {
        width:100%;
        max-width:210px;
        position: relative;
        }
        @media only screen and (max-width: 1024px) {
        .footer-logo { max-width:200px; }
        }
        @media only screen and (max-width: 767px) {
        .footer-logo { margin: 0 auto 1rem auto; max-width:180px; }
        }

.footer-navigation {
        padding-bottom:4rem;
        }
.footer-menu {
        position: relative;
        width:100%;
        text-align:center;
        z-index: 10;
        }
        .footer-menu li {
        display:inline-block;
        font-size:1rem;
        position: relative;
        padding:.25rem 0;
        margin:0 1rem 0 1rem;
        line-height: 150%;
        }
        
        .footer-menu li a {
        font-size:1rem;
        position: relative;
        display: inline-block;
        text-decoration: none;
        color:#FFF;
        }
        .footer-menu li a:hover {
        cursor: pointer;
        opacity: .6;
        text-decoration: none;
        }
        .footer-menu li a::after {
        position: absolute;
        bottom: 0px;
        left: 0;
        content: '';
        width: 100%;
        height: 1px;
        background:#FFF;
        transform: scale(0, 1);
        transform-origin: right top;
        transition: transform .5s;
        }
        .footer-menu li a:hover::after {
        transform-origin: left top;
        transform: scale(1, 1);
        }
        @media only screen and (max-width: 1024px) {
        .footer-menu li { margin:0 .65rem; }
        }
        
.footer-instagram { width:100%; max-width:270px; margin-bottom:1.5rem; }



.copyright {
        position: relative;
        z-index: 100;
        letter-spacing:0;
        line-height: 150%;
        text-align:  left;
        box-sizing: border-box;
        padding-right:75px;
        color:#FFF;
        width:100%;
        font-size:13px;
        }
        .copyright img { vertical-align: middle; }

        @media only screen and (max-width: 767px) {
        .footer-nav { display:none; }
        .footer-menu { border-top:1px solid rgba(255,255,255,.3); }
        .footer-menu.top-line-none { border-top:none; }
        .footer-menu li { display: block; width:100%; text-align: center; border-bottom:1px solid rgba(255,255,255,.3); padding:0; }
        .footer-menu li:last-child {  }
        .footer-menu li a { padding:.75rem 1rem; display: block; }
        .footer-menu li a:before { display:none; }
        .footer-menu li:before {  display:none ;}

        .wifi-banner { margin:0 auto; }
        .footer-instagram { margin:0 auto 1.5rem; }
        .footer-sns { text-align: center; }
        .footer-sns li { float:none; display: inline-block; margin:0 .5rem; }
        .copyright {  font-size:10px; text-align: center; padding-right:0; }
        }

/*=================================================

		ページトップ

 ==================================================*/

#totop {
	display:none;
	*display:block; /* IE 7 and below */
	position:fixed;
	bottom:0px;
	right:0px;
	z-index:999;
	}
    :root *> #totop { display:none;	}
    #totop { display:block; }
    *+html #totop { display:block; }
    #totop.open { display:block; }
    a.totop{ background:#EC9F47; width:60px;height:60px; display:block; cursor:pointer; text-align: center; color:#FFF; font-weight:700; font-size:13px; line-height: 125%; position: relative; }
    a.totop p { position: absolute; top:50%; left:50%; -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
    a.totop:hover{ background-position:center bottom;}

@media only screen and (max-width: 767px) {
    #totop { bottom:20px; right:5px;}
	a.totop{ width:55px;height:55px; font-size:13px;
    color:#FFF;
    border-radius:50%;
    }
}
