@charset "UTF-8";

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

       Fixed ヘッダー

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

.libre {
        font-family: "Libre Baskerville","Shippori Mincho", serif;
        }

header.main-header{
        position: fixed;
        top: 0;
        width:100%;
        padding:0 40px;
        height:80px;
        background:#FFF;
        box-sizing: border-box;
        color:#3C3C3B;
        z-index:2;
        -webkit-transition: all .5s ease;
                transition: all .5s ease;
        }
        @media screen and (max-width:1800px) {
        header.main-header{ padding:0 2.2222vw; }
        }

        .fixed-navigation-wrap {
                width: 100%;
                height:80px;
                box-sizing: border-box;
                position:relative;
                overflow: hidden;
                z-index:5;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                }
                .fixed-logo {
                width:320px;
                position: absolute;
                left:0;
                top:26px;
                font-size:1px;/* 会員情報ページ用ハック */
                line-height:1;
                text-align: center;
                box-sizing: border-box;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                z-index: 1;
                }
                .fixed-logo a { display: block; line-height: 1; font-size:1px; }
                .fixed-logo a img { line-height: 1; }

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

        .fixed-navigation {
                position: relative;
                width:100%;
                z-index: 0;
                }
                .fixed-main-nav {
                position:absolute;
                top:30px;
                right:330px;
                text-align: center;
                list-style: none;
                font-size: 1px;/* 会員情報ページ用ハック */
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                }

                .fixed-main-nav li {
                float:left;
                position: relative;
                letter-spacing:0em;
                text-align: center;
                padding-right:1rem;
                box-sizing: border-box;
                line-height: 16px;
                z-index: 1;
                font-size:16px;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                }
                .fixed-main-nav li:after {
                content:"/";
                display:block;
                position: absolute;
                top:2px;
                right:0;
                margin:0 auto;
                width:1rem;
                color:#3C3C3B;
                font-weight:500;
                line-height: 16px;
                opacity: .6;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                }
                .fixed-main-nav li:last-child { padding-right:0; }
                .fixed-main-nav li:last-child:after { display: none; }

                .fixed-main-nav li a:hover {
                opacity:1;
                }

        .fixed-main-nav a {
                display: block;
                text-decoration: none;
                }
                .fixed-main-nav a {
                position: relative;
                text-align: center;
                overflow: hidden;
                padding: 3px 1rem;
                }
                .fixed-main-nav a::after {
                position: absolute;
                bottom: 0px;
                left: 0;
                display: block;
                content: "";
                width: 0%;
                height: 2px;
                background: #3C3C3B;
                transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
                }
                .fixed-main-nav a span {
                display: block;
                width: 100%;
                margin: 0 auto;
                transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
                }
                .fixed-main-nav a span.eng {
                font-family: "Noto Serif", serif;
                }
                .fixed-main-nav a span.ja {
                position: absolute;
                top: 100%;
                left: 0%;
                font-size: 15px;
                font-weight: 900;
                white-space: nowrap;
                color: #3C3C3B;
                font-family: "Shippori Mincho", serif;
                }
                .fixed-main-nav a:hover::after { width: 100%; }
                .fixed-main-nav a:hover span.eng { transform: translate(0%, -150%); }
                .fixed-main-nav a:hover span.ja { top: 0; }

        /*=================================================
                contact btn
        ==================================================*/

        .fixed-contact {
                position: absolute;
                text-align: center;
                top:15px;
                right:0;
                width:130px;
                font-size: 1px;/* 会員情報ページ用ハック */
                letter-spacing: 0rem;
                line-height: 1;
                z-index:3;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                }
                .fixed-contact a {
                position: relative;
                display:block;
                width:100%;
                height:50px;
                line-height:50px;
                box-sizing: border-box;
                border-radius: 0px;
                background:#5B6C7D;
                font-weight:500;
                font-size:16px;
                text-align: center;
                letter-spacing:0em;
                color:#FFF;
                overflow: hidden;
                padding: 0 1rem;
                white-space: nowrap;
                text-decoration:none !important;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                z-index: 1;
                }
                .fixed-contact 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:rgb(255 255 255 / .15);
                }
                .fixed-contact a:hover:after {
                left: 0;
                width: 100%;
                }
                .fixed-contact a:hover { opacity:1; }

                .fixed-contact a span {
                display: block;
                width: 100%;
                margin: 0 auto;
                transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
                }
                .fixed-contact a span.eng {
                font-family: "Noto Serif", serif;
                }
                .fixed-contact a span.ja {
                position: absolute;
                top: 100%;
                left: 0%;
                font-size: 15px;
                font-weight: 700;
                white-space: nowrap;
                color: #FFF;
                font-family: "Shippori Mincho", serif;
                }

                .fixed-contact a:hover span.eng { transform: translate(0%, -150%); }
                .fixed-contact a:hover span.ja { top: 0; }

        /*=================================================
                BUSINESS btn
        ==================================================*/

        .fixed-business {
                position: absolute;
                text-align: center;
                top:15px;
                right:135px;
                width:170px;
                font-size: 1px;/* 会員情報ページ用ハック */
                letter-spacing: 0rem;
                line-height: 1;
                z-index:3;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                }
                .fixed-business a {
                position: relative;
                display:block;
                width:100%;
                height:50px;
                line-height:50px;
                box-sizing: border-box;
                border-radius: 0px;
                background:#3C3C3B;
                font-weight:500;
                font-size:16px;
                text-align: center;
                padding: 0 1rem;
                letter-spacing:0em;
                color:#FFF;
                overflow: hidden;
                white-space: nowrap;
                text-decoration:none !important;
                -webkit-transition: all .5s ease;
                transition: all .5s ease;
                z-index: 1;
                }
                .fixed-business 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:rgb(255 255 255 / .15);
                }
                .fixed-business a:hover:after {
                left: 0;
                width: 100%;
                }
                .fixed-business a:hover { opacity:1; }

                .fixed-business a span {
                display: block;
                width: 100%;
                margin: 0 auto;
                transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
                }
                .fixed-business a span.eng {
                font-family: "Noto Serif", serif;
                }
                .fixed-business a span.ja {
                position: absolute;
                top: 100%;
                left: 0%;
                font-size: 15px;
                font-weight: 700;
                white-space: nowrap;
                color: #FFF;
                font-family: "Shippori Mincho", serif;
                }

                .fixed-business a:hover span.eng { transform: translate(0%, -150%); }
                .fixed-business a:hover span.ja { top: 0; }

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

        header.main-header.fixed { box-shadow:0 5px 10px rgb(0 0 0 / .1); }


        /*=================================================
                responsive
        ==================================================*/

        @media screen and (max-width:1600px) {
        .fixed-logo { width:295px; top:28px; }
        .fixed-contact { width:110px; }
        .fixed-business { right:115px; }
        .fixed-main-nav { right:290px; }
        }

        @media screen and (max-width:1530px) {
        .fixed-logo { top:28px; }
        .fixed-contact { top:10px; }
        .fixed-contact a { height:26px; line-height:26px; }
        .fixed-business { top:10px; }
        .fixed-business a { height:26px; line-height:26px; }
        .fixed-main-nav { right:0; top:43px; }
        }
        @media screen and (max-width:1240px) {
        .fixed-logo { width:260px; top:41px; }
        .fixed-main-nav li { padding-right:0rem; }
        .fixed-main-nav li:after { display: none; }
        }
        @media screen and (max-width:1100px) {
        .fixed-main-nav li { font-size:15px; }
        .fixed-main-nav a { padding:3px .75rem; }
        .fixed-main-nav a span.ja { font-size:14px; }
        .fixed-contact a { font-size:15px; }
        .fixed-business a { font-size:15px; }
        
        }

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

       Mobile ヘッダー

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

.header-wrap-sp {
        display: none;
        position: absolute;
        width:100%;
        height: 90px;
        background:#FFF;
        box-sizing: border-box;
        z-index: 3;
        }
        .mobile-navigation-wrap {
                position: relative;
                width:100%;
                height:100%;
                overflow: hidden;
                z-index: 0;
                }
        .mobile-logo {
                width:283px;
                position: absolute;
                top:33px;
                left:20px;
                opacity: 1;
                z-index: 999;
                line-height: 1;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                .mobile-logo a { display: block; line-height: 1; }
                .mobile-logo a img { display: block; line-height: 1; }

        /*=================================================
                ハンバーガー
        ==================================================*/

        .gnav {
                display: none;
                letter-spacing: 0;
                }
                .nav-toggle {
                display:block;
                position:fixed;
                right:20px;
                top:19px;
                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:100001;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                .nav-toggle div {
                position:absolute;
                width:50px;
                height:20px;
                top:20px;
                left:10px;
                }
                .nav-toggle span {
                display: block;
                position: absolute;
                height: 2px;
                width:50px;
                background:#3C3C3B;
                border-radius:0px;
                -webkit-transition: .5s ease;
                transition: .5s ease;
                }
                .nav-toggle span:nth-child(1) { top: 2px;  }
                .nav-toggle span:nth-child(2) { top: 10px; }
                .nav-toggle span:nth-child(3) { top: 16px; }
                .gnav.active .nav-toggle span { background:#EFEFEF ; }
                .gnav.active .nav-toggle span:nth-child(1) { top: 8px;-webkit-transform: rotate(315deg); transform: rotate(315deg); width:50px;}
                .gnav.active .nav-toggle span:nth-child(2) { top: 8px;-webkit-transform: rotate(-315deg); transform: rotate(-315deg); width:50px; }
                .gnav.active .nav-toggle span:nth-child(3) {  }
                /*.gnav.fixed .nav-toggle { top:0; }*/
                .gnav.fixed .nav-toggle span { background: #3C3C3B; }
                .gnav.fixed.active .nav-toggle span { background: #EFEFEF; }

                .gnav .menu  { opacity: 1; position: absolute; width:100%; text-align:center; left:0px; top:40px; line-height: 1; font-size:10px; color:#3C3C3B; -webkit-transition : all 0.5s ease; transition : all 0.5s ease; font-family: "Poppins", sans-serif; font-weight:500; }
                .gnav .close { opacity: 0; position: absolute; width:100%; text-align:center; left:0px; top:18px; line-height: 1; font-size:13px; color:#FFF; -webkit-transition : all 0.5s ease; transition : all 0.5s ease; }
                .gnav.active .menu  { opacity: 0; }
                .gnav.active .close { opacity: 1; }

                .gnav.fixed .menu  { color:#3C3C3B; }
                .gnav.fixed .close  { color:#686868; }

                @media screen and (max-width: 1024px) {
                .gnav { display: block; }
                .gnav.fixed .active .nav-toggle { top:25px; }
                .gnav.fixed .active .nav-toggle { top:10px; }
                }
                @media screen and (max-width: 767px) {
                .nav-toggle div { width:40px; left:15px; }
                .nav-toggle span { width:40px; }
                .gnav.active .nav-toggle span:nth-child(1) { top: 6px; width:40px;}
                .gnav.active .nav-toggle span:nth-child(2) { top: 6px; width:40px; }
                .gnav .menu  { font-size:10px; }
                .gnav .close { font-size:10px; }
                
                .gnav.fixed .active .nav-toggle { top:15px; }
                }

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

        .gnav-content {
                display: none;
                position: fixed;
                right: 0;
                top: 0;
                width: 100%;
                height: 100%;
                background:#111;
                color:#FFF;
                overflow: auto;
                z-index:9999;
                }
                /* tablet→PC時ナビ表示強制解除 */
                @media screen and (min-width: 1025px) {
                .gnav-content { opacity: 0; z-index: -999999; display: none !important; }
                }
                .gnav-content a { color:#FFF; }
                .gnav-logo {
                width:283px;
                position: absolute;
                top:35px;
                left:20px;
                opacity: 1;
                z-index: 999;
                line-height: 100%;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                .gnav-logo a { line-height: 1; display: block; }
                .gnav-logo a img { line-height: 1; display: block; }
                
                .gnav-wrap {
                max-width:53%;
                width:53%;
                min-width:53%;
                }
                .gnav-outer {
                padding:0 5vw;
                box-sizing: border-box;
                }
                .gnav-img {
                position: fixed;
                top:0;
                background: url("../images/parts/header-sp.jpg") center center / cover;
                width:47%;
                height:100%;
                opacity: .5;
                }
                @media screen and (max-width: 767px) {
                .gnav-img { position: relative; width:100%; }
                }
    
                .mobile-navigation {
                padding-top:7rem;
                padding-bottom:1.5rem;
                border-bottom:1px solid rgb(255 255 255 / .3);
                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;
                font-size:17px;
                }
                .mobile-main-nav > li a {
                letter-spacing: 0.01em;
                padding: .45em 0;
                color: #FFF;
                display: block;
                position: relative;
                box-sizing: border-box;
                }
                .mobile-main-nav > li a span { font-size:12px; opacity:.5; }
                
                .mobile-sub-navigation {
                padding-top:1.5rem;
                padding-bottom:1.5rem;
                border-bottom:1px solid rgb(255 255 255 / .3);
                margin-bottom:2rem;
                width:100%;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                .mobile-sub-nav {
                position:relative;
                }
                .mobile-sub-nav > li {
                width:100%;
                text-align: left;
                font-weight:400;
                font-size:15px;
                }
                .mobile-sub-nav > li a {
                letter-spacing: 0.01em;
                padding: .35em 0 .35em 25px;
                color: #FFF;
                display: block;
                position: relative;
                box-sizing: border-box;
                }

                .mobile-sns {
                padding-top:1.5rem;
                }
                .mobile-sns li {
                display: inline-block;
                width:34px;
                line-height: 1;
                margin-right:10px;
                }
                
                .mobile-instagram {
                width:27px;
                padding:2rem 0 1rem;
                }
                
                .mobile-address {
                padding-top:2rem;
                padding-bottom:2rem;
                }
                .mobile-address p { line-height:250%; }

        @media screen and (max-width: 1024px) {
        header.main-header { position: relative; width:100%; }
        .header-wrap { display:none; }
        .header-wrap-sp { margin-top:0; display:block; opacity: 1; }
        .toppage .header-wrap-sp { display: block; }
        
        .nav-toggle { right:18px; top:12px; }
        .nav-toggle div { width:30px; left:20px; }
        .nav-toggle span { width:30px; }
        .gnav.active .nav-toggle span:nth-child(1) { width:36px; top:10px; }
        .gnav.active .nav-toggle span:nth-child(2) { width:36px; top:10px; }
        }
        @media screen and (max-width: 767px) {
        .header-wrap-sp { height:90px; }
        .mobile-navigation-wrap { height:90px; }
        .nav-toggle { right: 7px; top:12px; }
        .header-wrap-sp.fixed .nav-toggle { top:0; }
        .mobile-logo  { top:35px; left:20px; width:236px; }
        .gnav-logo { width:236px; top:0; padding-top:35px; }
        
        .gnav-logo-outer { padding:0 7vw; max-width:550px; margin: 0 auto; position: relative; box-sizing: border-box; }
        .gnav-logo    { position: relative; left:0; }
        .gnav-content:after { content:""; display:block; position: fixed; top:0; left:0;width:100%; height:100%; background:  url("../images/parts/header-sp.jpg") center center / cover; z-index: -1; opacity: .15; }
    
        .mobile-main-nav li { }
        .mobile-navigation { padding-top:2.5rem; }
        .gnav-outer { padding:0 7vw; max-width:550px; margin: 0 auto; }
        .mobile-main-nav > li:last-child a { height:50px; }
        }
        @media screen and (max-width: 374px) {
        .mobile-main-nav > li:last-child a { height:48px; }
        }

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

       フッター

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

footer {
        position: relative;
        width:100%;
        box-sizing: border-box;
        font-size:1rem;
        font-weight:400;
        color:#FFF;
        background: url("../images/parts/black.jpg") top left repeat;
        z-index: 0;
        }
        footer a { color:#FFF; }

        .footer-logo {
        width:100%;
        max-width:320px;
        position: relative;
        }
        @media only screen and (max-width: 1024px) {
        .footer-logo { max-width:300px; }
        }
        @media only screen and (max-width: 767px) {
        .footer-logo { margin: 0 auto; max-width:270px; }
        }

.footer-menu {
        position: relative;
        width:100%;
        text-align:left;
        border-top:1px solid rgb(255 255 255 / .5);
        padding-top:1.5rem;
        padding-left:0;
        z-index: 10;
        }
        .footer-menu li {
        display: block;
        font-size:1rem;
        position: relative;
        text-align: left;
        padding-bottom:1rem;
        line-height: 18px;
        }
        .footer-menu li:last-child { padding-right:0; }
        .footer-menu li a {
        font-size:1rem;
        line-height: 22px;
        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: -3px;
        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);
        }
        
        .footer-sns {
        text-align: center;
        }
        .footer-sns li {
        display: inline-block;
        width:24px;
        margin-right:10px;
        }
        .footer-sns li:last-child { margin-right:0; }
        

.copyright {
        position: absolute;
        bottom:0;
        right:80px;
        z-index: 100;
        letter-spacing:0;
        text-align:right;
        color:#FFF;
        line-height:60px;
        box-sizing: border-box;
        width:100%;
        font-size:13px;
        }
        .copyright img { vertical-align: middle; }

        @media only screen and (max-width: 1024px) {
        .footer-sns { text-align: center; }
        .copyright {  padding-bottom:60px; }
        }
        @media only screen and (max-width: 767px) {
        .footer-nav { display:none; }
        .footer-menu { padding-top:0; border-top:1px solid rgba(255,255,255,.3); }
        .footer-menu li { display: block; width:100%;  border-bottom:1px solid rgba(255,255,255,.3); padding:0; }
        .footer-menu li:last-child {  border-bottom:none; }
        .footer-menu.bottom-on li:last-child {  border-bottom:1px solid rgba(255,255,255,.3); }
        .footer-menu li a { padding:.5rem 1rem; display: block; }
        .footer-menu li a:before {
        content:"";
        display: block;
        position: absolute;
        top:50%;
        right:.5rem;
        translate:0 -50%;
        width:12px;
        height:12px;
        background: url("../images/parts/icon-arrow-w.svg") center center / cover;
        z-index: -1;
        opacity:.4;
        }
        
        

        .footer-sns { text-align: center; }
        .copyright {  position: relative; bottom: auto; right:auto; font-size:12px; text-align: center; padding-top:4rem;  }
        
        .instagram-banner { margin-inline:auto; }
        }

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

		ページトップ

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

#totop {
	display:none;
	*display:block; /* IE 7 and below */
	position:fixed;
	bottom:0;
	right:0;
	z-index:999;
	}
    :root *> #totop { display:none;	}
    #totop { display:block; }
    *+html #totop { display:block; }
    #totop.open { display:block; }
    a.totop{ background:#55585A; width:60px;height:60px; border-radius: 0; display:block; cursor:pointer; text-align: center; color:#FFF; 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{ opacity: .8; }

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


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

       mobile CTA

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

.mobile-cta {
        display: none;
        position: fixed;
        bottom:1%;
        left:2%;
        z-index: 10;
        width:96%;
        height: 60px;
        text-align: center;
        }
        .mobile-cta a { width:100%; display: block; text-align: center; line-height: 60px; background:#4C8732; color:#FFF; }

        @media only screen and (max-width:1024px) {
        .mobile-cta { display: block; }
        }





