@charset "utf-8";

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

/* smt menu
==============================================*/
	.smt-fixed {
		/*position: fixed; headerをfixed（移動式）にする場合はOFF*/
		width: 100%;
		height: 100%;
		overflow-y: hidden;
	}
    
	/* オーバーレイ */
	.smt-overlay {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		visibility: hidden;
		opacity: 0;
		transition: .3s;
		background-color: #000000;
		z-index: 5;
	}
    
	/* アクティブ */
	.smt-fixed .smt-overlay {
		visibility: visible;
		opacity: .6;
	}
    
	/* ヘッダー */
	header  {
        position: fixed; /*headerをfixed（移動式）にする場合*/
		width:100%;
        background-color: #fff;
		z-index:9;
		-webkit-user-select:none;
		-moz-user-select:none;
		user-select:none;
	}
	header .inner {
		position:relative;
		-webkit-box-sizing:border-box;
		-moz-box-sizing:border-box;
		box-sizing:border-box;
	}
    
	/* ナビゲーション */
	header .smt-nav {
		position: fixed;
		/*top: 56px;*/
		right: 0;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		width: 80vw;
		height: 100%;
		-webkit-tap-highlight-color: rgba(0,0,0,0);
		z-index:9999;
		background-color: #f5f5f5;
        background-color: #eaeaea;

        contain: paint;
		pointer-events: auto;
		will-change: transform;
		-webkit-backface-visibility:hidden;

        -webkit-transition: all 0.5s;
        -moz-transition: all 0.5s;
        transition: all 0.5s;
        -webkit-transform: translate3d(100%, 0, 0);
        -moz-transform: translate3d(100%, 0, 0);
        transform: translate3d(100%, 0, 0);
	}
    
	header.smt-open .smt-nav {
        -webkit-transform: translate3d(0, 0, 0);
        -moz-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
	}
	
	header .smt-navare {
		position: relative;
		width: 100%;
		height: 100%;
	}
    
	/* ナビゲーションアイコン */
	header .smt-botn {
		position: absolute;
        bottom: 10px;
        right: 15px;
        display: flex;
        flex-direction: column;
        justify-content: center;
        z-index: 9;
        -webkit-appearance: none;
        background: transparent;
        -webkit-tap-highlight-color: rgba(0,0,0,0);
        cursor: pointer;
        pointer-events: auto;
        contain: paint;
        touch-action: manipulation;
        -webkit-transition: all 0.5s;
        -moz-transition: all 0.5s;
        transition: all 0.5s;
        -webkit-transform: translate(0, 0);
        -moz-transform: translate(0, 0);
        transform: translate(0, 0);
        background-color: #fff;
        
        height: 45px;
        width: 46px;
        padding: 0 8px;
        border: 1px solid #fba41a;
        border-radius: 4px;
	}
	header.smt-open .smt-botn {
		/*width: 46px;*/
	}
	
	.ico-bar {
		display: block;
		width: 100%;
		height: 2px;
		background-color: #ef6c1d;
		transition: .3s;
		margin-top: 15px;
	}
    
	.ico-bar + .ico-bar {
		margin-top: 8px;
	}
	.ico-txt {
        position: absolute;
        white-space: nowrap;
        transition: .3s;
        font-size: 1.0rem;
        letter-spacing: 0.03em;
        line-height: 1;
        top: 5px;
        left: 50%;
        transform: translate(-50%, 0);
        
        font-weight: 600;
        color: #ef6c1d;
	}
    
	/* アクティブ */
	.smt-open .ico-bar {
		background-color: #fff;
	}
    .smt-open .smt-botn {
        background: #757575;
        border-color: #fff;
    }
	.smt-open .smt-botn .button {
		pointer-events: none;
	}
	.smt-open .smt-botn .ico-txt:nth-of-type(1) {
		opacity: 0;
	}
	.smt-open .smt-botn .ico-bar:nth-of-type(2) {
		transform: translate(0,0px) rotate(45deg);
	}
	.smt-open .smt-botn .ico-bar:nth-of-type(3) {
		transform: translate(0,-10px) rotate(-45deg);
	}
    
	/* menu-hed */
	.menu-hed {
        /*background-color: #ffffff;*/
        margin-bottom: 10px;
    }
	.menu-hed ul {
        display: -webkit-flex;
        display: flex;
    }
	.menu-hed li {
        margin-left: 13px;
    }
	.menu-hed li:nth-of-type(2) {
        margin-left: 40px;
    }
    .menu-hed li a {
        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        letter-spacing: normal;
        font-size: 1.45rem;
    }
    .menu-hed li a i {
        font-size: 2.0rem;
        color: #151144;
        width: 36px;
        height: 36px;
        border: 1px solid #c7c7c7;
        border-radius: 50%;
        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        -webkit-justify-content: center;
        justify-content: center;
        background-color: #fff;
    }
    .menu-hed li a span {
        margin-left: 5px;
        letter-spacing: 0.05em;
        color: #151144;
    }
    .menu-hed li a:hover {
        /*background-color: #cef1e7;*/
    }
	
	.smt-navflow {
		display: block;
		width: 100%;
        height: 100%;
		overflow-y: auto;
		overflow-x: hidden;
		padding-left: 10px;
		padding-right: 10px;
		padding-top: 5px;
        padding-bottom: 110px;
	}
    
    /* menu-list */
	.menu-list {
	}

	.menu-list > li {
		padding: 20px 10px;
        padding-left: 5px;
		text-transform: uppercase;
		border-bottom: 1px solid rgba(0, 0, 0, .2);
        box-shadow: 0 1px 0 #ffffff;
	}
	.menu-list > li:last-of-type {
	}
    .menu-list > li.lnot {
        box-shadow: none;
        border-bottom: 1px dashed rgba(0, 0, 0, .2);
    }
    
	.menu-list > li a {
        font-size: 1.6rem;
		display: -webkit-flex;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
        line-height: 1;
        font-weight: 600;
	}
	.menu-list > li a i {
        font-size: 1.9rem;
        margin-right: 2px;
        color: #ef6c1d;
	}
    .menu-list > li.lnot a i {
        /*color: #f6b68f;*/
    }
    .menu-list > li a i.icon-home {
        font-size: 1.8rem;
        margin-left: -1px;
        margin-right: 3px;
    }
    

	/* 矢印 */
	.menu-list > li {
		cursor: pointer;
		position: relative;
	}
	.menu-list > li a.sarw::before,
	.menu-list > li a.sarw::after {
		content: '';
		display: block;
		position: absolute;
		top: 50%;
		right: 0;
		width: 10px;
		height: 1px;
		margin-top: -1px;
        background-color: #444;
		-webkit-transform-origin: 2% 45%;
		-ms-transform-origin: 2% 45%;
		transform-origin: 2% 45%;
		-webkit-transition: all 0.3s;
		transition: all 0.3s ease-out;
		transform: rotate(135deg);
	}
	.menu-list > li a.sarw::before {
		-webkit-transform: rotate(225deg);
		-ms-transform: rotate(225deg);
		transform: rotate(225deg);
		opacity: 1;
		z-index: 2;
	}
    
    
	/* menu-sns 
	.menu-sns {
        margin-top: 15px;
	}
	.menu-sns ul {
        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        -webkit-justify-content: center;
        justify-content: center;
	}
	.menu-sns li {
        margin: 0 10px;
	}
	.menu-sns li a {
        width: 40px;
        height: 40px;
        border: 1px solid #c7c7c7;
        border-radius: 50%;
        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        -webkit-justify-content: center;
        justify-content: center;
        background-color: #fff;
	}
	.menu-sns li a i {
	}
*/
    
    
	/* menu-fot */
    .menu-fot {
        margin-top: 20px;
        display: flex;
    }
    .menu-fot li {
        padding: 0 10px;
    }
    .menu-fot li a {
        font-size: 1.3rem;
        line-height: 1.3;
        position: relative;
        color: #0052a4;
        display: flex;
    }
    .menu-fot li a::before {
        content: '▶︎';
        font-size: 1.1rem;
    }
    .menu-fot li a:hover {
        color: #db4800;
    }
    
    
	/* menu-copy */
	.menu-copy {
        margin-top: 30px;
        padding: 0 10px;
	}
    .menu-copy > li {
        margin-top: 30px;
    }
    .menu-copy > li h4 {
        font-size: 1.5rem;
        font-weight: 600;
        margin-bottom: 10px;
    }
    .menu-copy > li ol {
        display: flex;
        flex-wrap: wrap;
    }
    .menu-copy > li ol li {
        font-size: 1.4rem;
        line-height: 1.3;
    }
    .menu-copy > li p {
        font-size: 1.4rem;
        line-height: 1.3;
    }
    .menu-copy > li p b {
        font-size: 1.5rem;
        font-weight: 600;
    }
    .menu-copy > li p a {
        display: inline-block;
        color: #0052a4;
    }
    .menu-copy > li p a:hover {
        color: #db4800;
    }
    
    
	/* copyright */
	.copyright {
        padding: 0 10px;
        padding-top: 30px;
	}
	.copyright h5 {
        font-size: 1.3rem;
        font-weight: bold;
        font-family: 'Source Sans Pro', sans-serif;
	}

    
    /*///// 変更 /////*/
    .menu-list > li a.not {
        pointer-events: none;
        color: #b5b5b5;
        font-weight: normal;
    }
    .menu-list > li a.not::before,
    .menu-list > li a.not::after {
        background-color: #f5f5f5;
    }
    .menu-list > li a.not i {
        background-color: #f5f5f5;
    }

    
    /* menu-list list */
    .menu-list li.list {
        padding: 0;
    }
    .menu-list li.list ol {
        padding: 5px 0;
        padding-left: 10px;
    }
    .menu-list li.list ol li {
        padding: 10px 10px;
    }
    .menu-list li.list ol li a {
        font-size: 1.55rem;
        font-weight: 500;
        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        line-height: 1;
    }
    .menu-list li.list ol li a i {
        font-size: 1.5rem;
        font-weight: 600;
        line-height: 1;
        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        -webkit-justify-content: center;
        justify-content: center;
    }
    
    
    /* menu-list link */
    .menu-list li.link {
        padding: 16px 0;
    }
    .menu-list li.link ol {
    }
    .menu-list li.link ol li {
        margin: 0 8px;
        margin-top: 8px;
    }
    .menu-list li.link ol li:first-of-type {
        margin-top: 0;
    }
    .menu-list li.link ol li a {
        display: flex;
        place-items: center;
        justify-content: center;
        line-height: 1;
        font-weight: 500;
        color: #fff;
        font-size: 1.45rem;
        height: 40px;
        min-width: 140px;
        border-radius: 6px;
        background-color: #009244;
        font-feature-settings: "palt";
    }
    .menu-list li.link ol li.dan a {
        background-color: #9129c0;
    }
    .menu-list li.link ol li.rai a {
        background-color: #ef6c1d;
    }
    .menu-list li.link ol li a i {
        color: inherit;
        font-size: 2.0rem;
    }
    .menu-list li.link ol li a i.icon-groups {
        font-size: 2.1rem;
        margin-right: 5px;
    }
    .menu-list li.link ol li a:hover {
        background: #ec596f;
    }
    
    
    .menu-list > li.not a {
        color: #aaa;
        pointer-events: none; 
    }
    .menu-list > li.not a i {
        color: #aaa;
    }
    
    
    
    
    

}



@media screen and (max-width: 575px) {
    
    header .smt-botn {
        right: 10px;
        bottom: 10px;
    }
    
    header.smt-open .smt-botn {
    }
    
	header .smt-nav {
        min-width: 88%;
    }
    .smt-fixed .smt-pusher {
        -webkit-transform: translate3d(-290px, 0, 0);
        -moz-transform: translate3d(-290px, 0, 0);
        transform: translate3d(-290px, 0, 0);
    }    
    
    .menu-list > li {
        padding-top: 16px;
        padding-bottom: 16px;
	}
    
    .menu-list li.link ol {
        justify-content: center;
    }
    
	.copyright h5 {
        font-size: 1.2rem;
	}

}










