@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Overpass:wght@100;200;300;400;500;600;700;800;900&display=swap');
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
}
html {
	font-size: 62.5%;
}
body, table, input, textarea, select, option {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
	display: block;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
    height: auto;
}
a,
a:link {
	color: #191919;
	text-decoration: none;
}
a:visited {
	color: #191919;
}
a:hover {
	color: #191919;
}
a:active {
	color: #191919;
}
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	/*min-width: 1300px;*/
    width: 100%;
	color: #191919;
	font-size: 1.6rem;
	line-height: 1.5;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #faf6f1;
    }
#container {
    text-align: left;
    }
#main {
    display: block;
    }
a[href^="tel:"] {
    cursor: default;
    pointer-events: none;
    }
@media all and (min-width: 897px) {
	.sp {display: none !important;}
    }
@media all and (max-width: 896px) {
	body {
		min-width: inherit;
		font-size: 1.4rem;
	}
	body.fixed {
        position: fixed;
        width: 100%;
        height: 100%;
    }
	a:hover,
	a:hover img {
		opacity: 1 !important;
	}
	.pc {
		display: none !important;
	}
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
}

#topcontrol{z-index: 99;}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader {
	width: 100%;
	padding:40px 0 0;
	box-sizing: border-box;
    }

#gHeader h1 {
	margin-top: 10px;
    width: 100%;
	max-width:245px;
    }
#gHeader .hBox {
	max-width: 1800px;
	margin: 0 auto 0 0;
    }
#gHeader .rBox {
    width: calc(100% - 245px);
	max-width: 900px;
    }
#gNavi {
    width: 100%;
    position: relative;
    left: 0;
    top: 0;
    }
@media all and (min-width:897px) {
	#gHeader {
        position: absolute;
		top: 0;
		left:0 ;
		z-index: 40;
		width: 100%;
		box-sizing: border-box;
        margin: auto;
        }
	#gNavi {
        width: 100%;
        box-sizing: border-box;
        }
    }
#gNavi .naviList {
    max-width: 1050px;
    margin: 0 auto;
    display: flex;
    justify-content: end;
    align-content: center;
    align-items: center;
    box-sizing: border-box;
    }
#gNavi .naviList > li {
    box-sizing: border-box;
    width: 20%;
    text-align: center;
    position: relative;
    padding: 8px 5px;
    /*cursor: pointer;*/
    font-size: 1.8rem;
    }
#gNavi .naviList > li span{cursor: pointer;}
#gNavi .naviList > li:hover::before{
    position: absolute;
    content: "";
    background: url("../images/common/nav_on.png")no-repeat top center;
    width: 24px;
    height: 26px;
    top: -28px;
    left: 0;
    right: 0;
    margin: auto;
    }
#gNavi .naviList > li > a {
    padding: 8px 5px;
    display: block;
    width: 100%;
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    box-sizing: border-box;
    }

#gNavi .naviList > li span{font-weight: 600;}
#gNavi .naviList > li .subBox {
    padding:10px;
    width: 100%;
    position: absolute;
    left: 0;
    top: 40px;
    text-align: center;
    background-color: #ffe897;
    z-index: 10;
    display: none;
    font-size: 1.6rem;
    box-sizing: border-box;
    }
#gNavi .naviList > li .subBox li{
    border-bottom: 1px dashed #f4c319;
    }
#gNavi .naviList > li .subBox li:last-child{
    border-bottom: none;
    }
#gNavi .naviList > li .subBox li a {
    display: block;
    width: 100%;
    color: #4d3525;
    padding: 4px 0;
    }
#gNavi .naviList > li .subBox li a:hover {opacity: 0.7;}
#gNavi .naviList > li.navi05{
    width: 20%;
    }
#gNavi .naviList > li.navi05:hover::before{
    position: static;
    display: none;
    }
#gNavi .naviList > li.navi05 a{
    display: block;
    width: 100%;
    background: #ff9f15;
    color: #fff;
    border-radius: 10px;
    padding: 8px 0;
    }


@media all and (min-width: 896px) and (max-width: 1500px) {}
@media all and (min-width: 896px) and (max-width: 1400px) {}
@media all and (min-width:897px) {.menuBox {display: none !important;}}


@media all and (max-width: 1400px) {
    #gHeader h1 {max-width:245px;}
    #gHeader .hBox {max-width: 1800px;}
    #gHeader .rBox {width: calc(100% - 245px);}
    #gNavi .naviList > li{font-size: 1.7rem}
    #gNavi .naviList > li > a {font-size: 1.7rem}
    }
@media all and (max-width: 1000px) {
    #gHeader h1 {max-width:145px;}
    #gHeader .rBox {width: calc(100% - 145px);}
    #gNavi .naviList > li{font-size: 1.6rem}
    #gNavi .naviList > li > a {font-size: 1.6rem}
    }

@media all and (max-width: 896px) {
    #topcontrol{width: 70px;}
	#gHeader {
        position: absolute;
        /*z-index: 102;*/
        z-index: 2;
        }
	#gHeader h1 {
        margin-top: 0;
        max-width:125px;
        }
	#gHeader h1 img {}
	#gHeader .hBox {
		max-width: inherit;
		display: block;
        }
	#gHeader .rBox {
		width: auto;
		display: block;
		text-align: center;
        }
	#gNavi {
		display: none;
        }
	.menu {
		width: 40px;
		height: 40px;
		position:fixed;
		right: 10px;
		top: 5px;
		cursor: pointer;
		z-index: 103;
		background-color: #ff9f15;
        }
	.menu span {
		margin-left: -10px;
		width: 50%;
		height: 2px;
		position: absolute;
		left: 50%;
		top: 13px;
		background: #fff;
		transition: 0.3s;
        }
	.menu span:nth-child(2) {
		top: 20px;
        }
	.menu span:nth-child(3) {
		top: 27px;
        }
    .menu.on span{top: 15px;}
	.menu.on span:nth-child(1) {transform: translateY(5px) translateX(0) rotate(45deg);}
	.menu.on span:nth-child(2) {opacity: 0;}
	.menu.on span:nth-child(3) {transform: translateY(-6px) translateX(0) rotate(-45deg);top: 26px;}
	.menuBox {
		width: 100%;
		height: 100%;
		position: fixed;
		left: 0;
		top: 0;
		background: rgba(255, 255, 255, 0.95);
		overflow: auto;
		z-index: 100;
		display: none;
    	}
	.menuWrap {
		padding: 74px 20px;
        }
	.menuWrap .naviList {
		margin-bottom: 30px;
		border-bottom: 1px solid #ddd;
        }
	.menuWrap .naviList > li {
		border-top: 1px solid #ddd;
        }
	.menuWrap .naviList > li > a {
		padding: 15px 35px 15px 0;
		font-size: 1.6rem;
		display: block;
		position: relative;
        }
	.menuWrap .naviList > li.toggle > a {
		position: relative;
    	}
	.menuWrap .naviList > li.toggle > a::before {
		width: 15px;
		height: 1px;
		position: absolute;
		right: 10px;
		top: 50%;
		transform: translateY(-50%);
		background: #000;
		content: '';
        }
	.menuWrap .naviList > li.toggle > a::after {
		width: 1px;
		height: 15px;
		position: absolute;
		right: 17px;
		top: 50%;
		transform: translateY(-50%);
		background: #000;
		content: '';
        }
	.menuWrap .naviList > li.toggle > a.on::after {
		display: none;
        }
	.menuWrap .subBox li a {
		padding: 10px;
		display: block;
		font-size: 1.4rem;
        }
	.menuWrap li .subBox {
		padding-bottom: 15px;
		display: none;
        }
	.menuWrap li.navi02 .subBox a {
		padding-left: 40px;
		position: relative;
        }
	.menuWrap li.navi02 .subBox .icon {
		width: 20px;
		position: absolute;
		left: 10px;
		top: 50%;
		transform: translateY(-50%);
        }
    .menuWrap .menuBtnBox {
		text-align: center;
        }
    .menuWrap .menuBtnBox a{
        display: block;
        width: 100%;
        background: #fff;
        color: #ff9f15;
        padding: 15px 0;
        box-sizing: border-box;
        border-radius: 100px;
        font-size: 1.5rem;
        border: 2px solid #ff9f15;
        }
    .menuWrap .menuBtnBox a span{
        background: url("../images/common/ft_icon_mail.png")no-repeat left center;
        padding-left: 30px;
        }
}

@media all and (max-width: 540px) {
    #gHeader h1 {max-width: 95px;}
    #gHeader {padding:5px 0 0;}
    }

/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
    padding: 140px 0 50px;
    background: url("../images/common/ft_music01.png")no-repeat center 55px ,url("../images/common/ft_music02.png")no-repeat right 70% , #f0863c;
    font-size: 1.8rem;
    box-sizing: border-box;
    color: #fff;
    }
#gFooter .fLogo{
    text-align: center;
    margin-bottom: 40px;
    }
#gFooter .ftips{
    text-align: center;
    margin-bottom: 40px;
    }
#gFooter .ftips a{
    background: #fff;
    border:3px double #f0863c;
    padding: 4px 10px;
    color: #f0863c;
    font-weight: bold;
    }

#gFooter .wrapBox {
	align-items: flex-start;
    }
#gFooter .fNavi{
    border-left: 1px solid #fb9a4c;
    padding: 0 40px;
    width: 25%;
    box-sizing: border-box;
    }
#gFooter .fNavi:last-child{
    border-right: 1px solid #fb9a4c;
    }
#gFooter .fNavi li{margin-bottom: 10px;}
#gFooter .fNavi li a,
#gFooter .fNavi li span{
    display: block;
    width: 100%;
    box-sizing: border-box;
    position: relative;
    color: #fff;
    }
#gFooter .fNavi li.fNasub{
    font-size: 1.5rem;
    margin-bottom: 8px;
    margin-left: 12px;
    }
#gFooter .fNavi li.fNasub a{padding-left: 18px;}
#gFooter .fNavi li.fNasub a::before{
    position: absolute;
    content: "";
    width: 8px;
    height: 2px;
    background: #fff;
    top: 9px;
    left: 0;
    }

#gFooter .fNavi2{
    margin: 100px auto 80px;
    max-width:920px;
    }
#gFooter .fNavi2 li {width: 32%;}
#gFooter .fNavi2 li a{
    background: #fff;
    display: block;
    width: 100%;
    text-align: center;
    padding: 20px 10px;
    border-radius: 100px;
    font-size: 1.6rem;
    font-weight: 500;
    box-sizing: border-box;
    }
#gFooter .fNavi2 li a span{
    background: url("../images/common/ft_icon_mail.png")no-repeat left center;
    padding-left: 25px;
    }

#gFooter address {
	font-size: 1.2rem;
	font-style: normal;
	letter-spacing: 0.04em;
    display: block;
    box-sizing: border-box;
    text-align: center;
    }

@media all and (max-width: 1100px) {
#gFooter .fNavi{
    padding: 0 10px;
    width: 25%;
    }    
}


@media all and (max-width: 896px) {
#gFooter {
    background: #f0863c;
    padding: 40px 0 20px;
    font-size: 1.4rem;
    }
#gFooter .fLogo{
    text-align: center;
    max-width: 185px;
    margin: auto;
    margin-bottom: 20px;
    }
#gFooter .wrapBox {
	display: none;
    }


#gFooter .fNavi2{
    margin: 20px auto 20px;
    width: 100%;
    max-width: 400px;
    }
#gFooter .fNavi2 li {width:96%;margin: 1%;}
#gFooter .fNavi2 li a{
    width: 100%;
    padding: 15px 10px;
    font-size: 1.4rem;
    }
#gFooter .fNavi2 li a span{
    background: url("../images/common/ft_icon_mail.png")no-repeat left center;
    background-size: 20px;
    padding-left: 25px;
    }
#gFooter address {}
    
}