@charset "utf-8";


/* ----------------------------------------------------------------------
	drawer
---------------------------------------------------------------------- */

/* drawer-open */
.drawer-open {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden !important;
}


/* drawer-hamburger */
.drawer-hamburger {
    position: fixed;
    top: 30px;
    right: 30px;
    z-index: 1000;
    background: #fff;
    padding: 29px 15px;
	width: 60px;
	height: 60px;
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	transform: translate3d(0, 0, 0);
	border: 1px solid #444;
    border-radius: 30px;
	outline: 0;
    overflow: hidden;
    cursor: pointer;
}

.drawer-hamburger--home {
    background: none;
    border-color: #fff;
}

.drawer-scroll .drawer-hamburger,
.drawer-open .drawer-hamburger {
   background: #fff!important;
   border-color: #444!important;
}

.drawer-hamburger-icon {
	position: relative;
	display: block;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
	width: 100%;
	height: 2px;
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	background-color: #444;
}

.drawer-hamburger--home .drawer-hamburger-icon,
.drawer-hamburger--home .drawer-hamburger-icon:before,
.drawer-hamburger--home .drawer-hamburger-icon:after{ background-color: #fff; }

.drawer-scroll .drawer-hamburger-icon,
.drawer-scroll .drawer-hamburger-icon:before,
.drawer-scroll .drawer-hamburger-icon:after { background-color: #444!important; }

.drawer-open .drawer-hamburger-icon { background: none; }

.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
    content: '';
	position: absolute;
	top: -8px;
	left: 0;
}

.drawer-hamburger-icon:after { top: 8px; }

.drawer-open .drawer-hamburger-icon { background-color: none; }

.drawer-open .drawer-hamburger-icon:before,
.drawer-open .drawer-hamburger-icon:after {
	top: 0;
    background-color: #444;
}

.drawer-open .drawer-hamburger-icon:before { transform: rotate(45deg); }

.drawer-open .drawer-hamburger-icon:after { transform: rotate(-45deg); }

.drawer-open { overflow: hidden; }

@media screen and (max-width: 990px) {
    .drawer-hamburger {
        top: 20px;
        right: 20px;
        padding: 21px 11px;
        width: 44px;
        height: 44px;
        border-radius: 22px;
        display: block;
    }
    
    .drawer-hamburger-icon:before,
    .drawer-hamburger-icon:after { top: -6px; }

    .drawer-hamburger-icon:after { top: 6px; }
}


/* drawer-nav */
.drawer-nav {
	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
    background: url("../img/bg_circle.gif");
    background-size: 90px;
	width: 100%;
    height: 100%;
    max-height: 100%;
	overflow: hidden;
	overflow-y: scroll; 
	-webkit-overflow-scrolling: touch;
    transition: 0.4s;
    visibility: hidden;
    opacity: 0;
}

.drawer-open .drawer-nav {
    visibility: visible;
    opacity: 1;
}

.drawer-nav__inner {
    background: url("../img/bg_circle.gif");
    background-size: 90px;
    display: flex;
    align-items: center;
}

.drawer-nav__block {
    margin: 0 auto;
    width: 510px;
}

.drawer-nav__ph {
    background: url("../img/drawer_ph.jpg?=20251128") center center no-repeat;
    background-size: cover;
    width: calc(100% - 800px);
    height: 100vh;
}

@media screen and (max-width: 990px) {
    .drawer-open .drawer-nav { display: block; }

    .drawer-nav__inner { display: block; }

    .drawer-nav__block {
        padding: 110px 20px 40px;
        width: auto;
    }

    .drawer-nav__ph { display: none; }
}


/* drawer-g-nav */
.drawer-g-nav__column {
    margin: 0 0 60px;
    display: flex;
    justify-content: space-between;
}

.drawer-g-nav__column-inner { width: 240px; }

@media screen and (max-width: 990px) {
    .drawer-g-nav__column {
        margin: 0 0 40px;
        display: block;
    }
    
    .drawer-g-nav__column-inner { width: auto; }
}


/* drawer-g-nav__main */
.drawer-g-nav__main,
.drawer-g-nav__main { margin: 0 0 3em; }

.drawer-g-nav__main:last-child,
.drawer-g-nav__main:last-child { margin: 0; }

.drawer-g-nav__main > dt a,
.drawer-g-nav__main > p a {
    font-size: 1.8rem;
    text-decoration: none;
}

.drawer-g-nav__main > dt a i { display: none; }

.drawer-g-nav__main > dt { margin: 0 0 0.6em; }

.drawer-g-nav__main-index { display: none; }

.drawer-g-nav__main > dd ul li { margin: 0 0 0.6em; }
.drawer-g-nav__main > dd ul li:last-child { margin: 0; }

.drawer-g-nav__main > dd ul li a { font-size: 1.5rem; }

@media screen and (max-width: 990px) {
    .drawer-g-nav__main,
    .drawer-g-nav__main,
    .drawer-g-nav__main:last-child,
    .drawer-g-nav__main:last-child { margin: 0 0 1em; }

    .drawer-g-nav__main > dt,
    .drawer-g-nav__main > p { border-bottom: 1px solid #444; }

    .drawer-g-nav__main > dt a,
    .drawer-g-nav__main > p a {
        position: relative;
        padding: 0 0 0.4em;
        display: block;
    }
    
    .drawer-g-nav__main > dt a:hover { color: #444; }

    .drawer-g-nav__main > dt a i {
        position: absolute;
        top: 6px;
        right: 0;
        display: block;
    }
    
    .drawer-g-nav__main > p a {
        background: url("../img/icon_a_black.png") right 4px top 8px no-repeat;
        background-size: 6px 12px;
    }

    .drawer-g-nav__main > dt { margin: 0; }

    .drawer-g-nav__main > dd {
        padding: 16px 20px;
        display: none;
    }
    
    .drawer-g-nav__main-index {
        margin: 0;
        display: block;
    }
    
    .drawer-g-nav__main-index a {
        background: url("../img/icon_a_circle_black.png") right center no-repeat;
        background-size: 16px;
        font-size: 1.8rem;
        text-decoration: none;
        padding: 8px 22px 8px 0;
        display: inline-block;
    }
    
    
    .drawer-g-nav__main > dd ul li { margin: 0; }

    .drawer-g-nav__main > dd ul li a {
        background: url("../img/icon_a_black.png") left center no-repeat;
        background-size: 6px 12px;
        font-size: 1.6rem;
        text-decoration: none;
        padding: 8px 10px;
        display: inline-block;
    }
}


/* drawer-g-nav__sub-01 */
.drawer-g-nav__sub-01 { margin: 0 0 3em; }
.drawer-g-nav__sub-01 li { margin: 0 0 0.6em; }
.drawer-g-nav__sub-01 li:last-child { margin: 0; }
.drawer-g-nav__sub-01 li a {
    font-size: 1.8rem;
    text-decoration: none;
}

@media screen and (max-width: 990px) {
    .drawer-g-nav__sub-01 { margin: 0 0 40px; }
    
    .drawer-g-nav__sub-01 li {
         margin: 0 0 1em;
         border-bottom: 1px solid #444;
    }

    .drawer-g-nav__sub-01 li a {
        background: url("../img/icon_a_black.png") right 4px top 8px no-repeat;
        background-size: 6px 12px;
        padding: 0 0 0.4em;
        display: block;
    }
}

/* drawer-g-nav__sub-02 */
.drawer-g-nav__sub-02 {
    display: flex;
    gap: 0 30px;
}

.drawer-g-nav__sub-02 li a { font-size: 1.4rem; }

@media screen and (max-width: 990px) {
    .drawer-g-nav__sub-02 { display: block; }
    
    .drawer-g-nav__sub-02 li a {
        background: url("../img/icon_a_black.png") left top 13px no-repeat;
        background-size: 6px 12px;
        text-decoration: none;
        padding: 8px 0 8px 10px;
        display: inline-block;
    }
}


/* drawer-nav__link */
.drawer-nav__link { margin-top: 60px; }

.drawer-nav__link ul {
    display: flex;
    justify-content: space-between;
}

.drawer-nav__link li { width: 240px; }

@media screen and (max-width: 990px) {
    .drawer-nav__link { margin-top: 40px; }

    .drawer-nav__link ul { display: block; }

    .drawer-nav__link li {
        margin: 0 0 20px;
        width: auto;
    }
    
    .drawer-nav__link li:last-child { margin: 0; }
}



/* overlay */
.drawer-overlay {
	position: fixed;
	z-index: 10;
	top: 0;
	left: 0;
	display: none;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.6);
}

.drawer-open .drawer-overlay { display: block; }











