@charset "UTF-8";

/*==================================================================================================

       Fixed ヘッダー

===================================================================================================*/

header.main-header {
        position: fixed;
        width:100%;
        height:90px;
        background: #FFF;
        box-sizing: border-box;
        z-index:2;
        -webkit-transition: all .3s ease;
                transition: all .3s ease;
        }

        .fixed-navigation-wrap {
                width: 90%;
                max-width:1080px;
                margin-inline:auto;
                height:90px;
                box-sizing: border-box;
                position:relative;
                z-index:5;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .logo-wrap {
                position: absolute;
                left:0;
                top:0;
                width:160px;
                height:100%;
                }
                .fixed-logo {
                position: absolute;
                top:50%;
                left:0;
                translate:0 -50%;
                width:100%;
                line-height:1;
                text-align: center;
                box-sizing: border-box;
                -webkit-transition: all .3s ease;
                transition: all .3s 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:5px;
                left:220px;
                text-align: center;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-main-nav li {
                float:left;
                position: relative;
                letter-spacing:0.05em;
                text-align: center;
                padding-right:3rem;
                box-sizing: border-box;
                line-height: 1em;
                z-index: 1;
                font-size:16px;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-main-nav li:last-child {
                padding-right:0;
                }

                .fixed-main-nav li a {
                position: relative;
                display: inline-block;
                font-size:16px;
                line-height:16px;
                padding-top:50px;
                letter-spacing:0.05em;
                font-weight: 500;
                white-space:nowrap;
                color:#4b9d65;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }

                .fixed-main-nav li a:before {
                content:"";
                display: block;
                position: absolute;
                top:0;
                left:50%;
                width:48px;
                height:48px;
                translate:-50%;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-main-nav li:nth-child(1) a:before { background: url("../images/parts/menu_01.svg") center center / cover; }
                .fixed-main-nav li:nth-child(2) a:before { background: url("../images/parts/menu_02.svg") center center / cover; }
                .fixed-main-nav li:nth-child(3) a:before { background: url("../images/parts/menu_03.svg") center center / cover; }

                .fixed-main-nav li a:hover:before { top:-5px; }

                .fixed-main-nav li a:after {
                position:absolute;
                bottom:-8px;
                left:50%;
                transform: translateX(-50%);
                content:'';
                width:0px;
                height:2px;
                background-color:#f6993f;
                -webkit-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-main-nav li a:hover:after {
                width:100%;

                }
                .fixed-main-nav li a:hover {
                opacity:1;
                }
                
        /*=================================================
                fixed-header-address
        ==================================================*/

        .fixed-header-address {
                position: absolute;
                right:0;
                top:0;
                width:340px;
                height:100%;
                }
                .fixed-header-address .inner {
                position: absolute;
                top:50%;
                right:0;
                translate:0 -50%;
                width:100%;
                text-align: right;
                }

        /*=================================================
                fixed
        ==================================================*/

        header.main-header.fixed { box-shadow: 0 5px 10px rgb(0 0 0 / .2); }

        /*=================================================
            responsive
        ==================================================*/

/*==================================================================================================

       SP-header

===================================================================================================*/

.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%;
                z-index:4;
                }
        .mobile-logo-wrap {
                position: absolute;
                left:30px;
                top:0;
                width:140px;
                height:100%;
                }
                .mobile-logo {
                position: absolute;
                top:50%;
                left:0;
                translate:0 -50%;
                width:100%;
                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:0px;
                top:0px;
                padding:0;
                width:90px;
                height:90px;
                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:27px;
                height:18px;
                top:50%;
                left:50%;
                translate:-50% -50%;
                }
                .nav-toggle span {
                display: block;
                position: absolute;
                height: 2px;
                width:27px;
                background:#7cc68d;
                border-radius:0px;
                right: 0;
                -webkit-transition: .5s ease;
                transition: .5s ease;
                }
                .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:#7cc68d ; }
                .gnav.fixed.active .nav-toggle span { background: #7cc68d; }
                .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; }

                .gnav .menu  { opacity: 1; position: absolute; text-align:center; width:100%; left:0; top:23px; line-height: 1; font-size:13px; color:#2C2E2E; transition : all 0.5s ease; font-weight:400; }
                .gnav .close { opacity: 0; position: absolute; width:auto; text-align:right; left:0px; top:18px; line-height: 1; font-size:13px; color:#FFF; transition : all 0.5s ease; }
                .gnav.active .menu  { opacity: 0; }
                .gnav.active .close { opacity: 1; }

                
                
                /* 反転    */
                .gnav.fixed .nav-toggle span { background: #7cc68d; }
                .gnav.fixed .nav-toggle { mix-blend-mode: difference; }
                .gnav.fixed.active .nav-toggle { mix-blend-mode:normal; }

                @media screen and (max-width: 1024px) {
                .gnav { display: block; }
                .gnav.fixed .nav-toggle { top:0; }
                .gnav.fixed .active .nav-toggle { top:25px; }
                }
                @media screen and (max-width: 767px) {
                .nav-toggle { width:80px; height:80px; top:0; right:0; }
                .gnav.fixed .nav-toggle { top:0; }
                .gnav .menu  { font-size:11px; }
                .gnav .close { font-size:10px; }
                .header-wrap-sp.fixed .nav-toggle { top:0; }
                
                .gnav.fixed .active .nav-toggle { top:15px; }
                
                /*      反転    */
                .nav-toggle { background: none; }
                .gnav.fixed .nav-toggle { mix-blend-mode: difference; }

                }


        /*=================================================
                ナビゲーション
        ==================================================*/

/* android アンカー時スクロール対策済み visible + inner付与 */

.gnav-content {
                display: none;
                position: fixed;
                right: 0;
                top: 0;
                width: 100%;
                height: 100%;
                background:#fffbe0;
                color:#555;
                z-index:9999;
                overflow: visible;
                }
                .gnav-content-inner {
                height: 100%;
                overflow-y: auto;
                }

                /* 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:136px;
                position: relative;
                padding:15px 0 2rem 30px;
                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 30px;
                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 {
                width:100%;
                -webkit-transition:all .5s ease;
                transition       : all .5s ease;
                }
                .mobile-main-nav {
                position:relative;
                padding-bottom:1.5rem;
                }
                .mobile-main-nav > li {
                width:100%;
                text-align: left;
                font-weight:500;
                border-bottom: 1px dotted rgb(0 0 0 / .3);
                padding: .25em 0;
                }
                .mobile-main-nav > li:last-child { border-bottom:none; }

                .mobile-main-nav > li a {
                letter-spacing: 0.01em;
                padding: 1em 0;
                color:#555;
                display: block;
                position: relative;
                box-sizing: border-box;
                white-space:nowrap;
                line-height: 110%;
                font-size:18px;
                font-weight:600;
                }
                .mobile-main-nav.green > li a { color:#1f9d55; }



                

        @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; }
        }
        @media screen and (max-width: 767px) {
        .header-wrap-sp  { height:80px; }
        .mobile-logo-wrap     { left:20px; }
        .gnav-logo       { width:92px; padding:14px 0 2rem 20px; left:0; top:0;  position: relative; }
        .gnav-logo-outer { max-width:550px; margin: 0 auto; position: relative; box-sizing: border-box; }
        .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: .1; }
        .mobile-navigation {  }
        .mobile-main-nav > li a { font-size:16px; padding:.75rem 0; }
        .gnav-outer { padding:0 20px; max-width:550px; margin: 0 auto; }
        }

/*==================================================================================================

       フッター

===================================================================================================*/

footer {
        position: relative;
        width:100%;
        padding-top:3rem;
        z-index: 1;
        }
        .footer-image {
        position: relative;
        width:100%;
        padding:0 10%;
        box-sizing: border-box;
        } 
        .footer-image:before {
        content:"";
        display: block;
        position: absolute;
        bottom:-1px;
        left:0;
        width:100%;
        height:0;
        padding-bottom:6%;
        background: url("../images/parts/footer-wave.svg") bottom center / cover;
        z-index: -1;
        }
        .footer-img-inner {
        width:100%;
        max-width:1080px;
        margin-inline:auto;
        }
        .footer-content {
        position: relative;
        width:100%;
        box-sizing: border-box;
        background: #95cc13;
        font-size:1rem;
        font-weight:400;
        line-height: 180%;
        color:var(--footer-font-color);
        padding:7rem 0;
        z-index: 1;
        }
        
        .footer-section {
        position: relative;
        z-index: 0;
        }
        .footer-section:after {
        content:"";
        display: block;
        position: absolute;
        top:0;
        right:0;
        width:4px;
        height:100%;
        border-right:4px dotted rgb(255 255 255 / .7);
        }
        .footer-section.last:after { display: none; }
        
        footer a { color:var(--footer-font-color); }
    

        .footer-logo {
        width:180px;
        }
        @media only screen and (max-width: 1350px) {
        .footer-logo { width:160px;}
        }
        @media only screen and (max-width: 1024px) {
        .footer-content { padding:5rem 0; }
        .footer-logo { width:140px; margin-inline:auto; }
        .footer-section .inner { padding:3rem 0; }
        .footer-section:after { top:auto; bottom:0; width:100%; height: 4px; border-right:none; border-bottom:4px dotted rgb(255 255 255 / .7); }
        .footer-section.last:after { display: block; }
        }
        @media only screen and (max-width: 767px) {
        .footer-logo { width:120px; }
        }


.footer-menu {
        position: relative;
        width:100%;
        text-align:left;
        z-index: 10;
        }
        .footer-menu li {
        font-size:1rem;
        position: relative;
        text-align: left;
        line-height: 180%;
        }

        .footer-menu li a {
        font-size:1rem;
        line-height: 180%;
        position: relative;
        display: inline-block;
        text-decoration: none;
        white-space: nowrap;
        color:var(--footer-font-color);
        }
        .footer-menu li a:before {
        content:"〇";
        position: relative;
        display: inline-block;
        margin-right:1.5em;
        font-size:.35em;
        vertical-align: middle;
        }
        
        .footer-menu li a:hover {
        cursor: pointer;
        opacity: .6;
        text-decoration: none;
        }
        .footer-menu li a::after {
        position: absolute;
        bottom: 0;
        left: 0;
        content: '';
        width: 100%;
        height: 1px;
        background:var(--footer-font-color);
        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 { text-align: center; }
        .footer-menu ul { display: inline-block; }
        }





        .footer-sns {
        text-align: left;
        }
        .footer-sns li {
        display: inline-block;
        width:30px;
        margin-right:10px;
        }
        .footer-sns li:last-child { margin-right:0; }
        

.copyright {
        position: relative;
        line-height:200%;
        padding:3rem 0 0;
        text-align: center;
        z-index: 100;
        letter-spacing:0;
        color:var(--footer-font-color);
        box-sizing: border-box;
        width:100%;
        font-size:12px;
        }
        .copyright img { vertical-align: middle; }

        @media only screen and (max-width: 1024px) {
        
        }

        @media only screen and (max-width: 767px) {
        .footer-sns { text-align: center; }
        .copyright {  position: relative; right:auto; bottom:auto; padding-bottom:4rem; font-size:10px; text-align: center; line-height: 150%; }
        }

/*=================================================

		ページトップ

 ==================================================*/

#totop {
	display:none;
	position:fixed;
	bottom:0;
	right:0;
	z-index:999;
    border: none;
    padding: 0;
    background: none;
	}
    :root *> #totop { display:none;	}
    #totop { display:block; }
    *+html #totop { display:block; }
    #totop.open { display:block; }
    .totop{ background:#4b9d65; width:60px;height:60px; display:block; cursor:pointer; text-align: center; color:#FFF; font-size:13px; line-height: 125%; position: relative; }
    .totop span { position: absolute; top:50%; left:50%; -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
    .totop:hover{ opacity: .8; }
    .totop a { display: block; width:100%; height:100%; color:#FFF; }

    @media only screen and (max-width: 1024px) {
    #totop { bottom:10px; right:10px;}
	.totop{ width:55px;height:55px; font-size:10px; border-radius:50%; }
    }
    @media only screen and (max-width:767px) {
    #totop { bottom:5px; right:5px; }
    }