@media screen and (min-width: 1099px){
.hamburger{
	display: none;
}
.header .navi{
	position: relative;
	width: 100%;
	background-image: url(../img/comm/navi.png);
	background-position: center center;
	background-repeat: repeat-x;
}
.header .navi nav{
	position: relative;
	width: 1024px;
	margin: 0 auto;
}
.header .navi  nav .carp{
	position: absolute;
	top: -30px;
	left: -90px;
}
.header .navi ul{
	font-family: serif;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: flex;
}
.header .navi ul li a{
	text-align: center;
	text-decoration: none;
	display: block;
	padding: 0px 21px;
	height: 54px;
	line-height: 54px;
}
.header .navi ul li a:hover{
	background-image: url(../img/comm/hover.png);
	background-position: center center;
	background-repeat: repeat-x;
}
.header .navi ul li.current a{
	background-image: url(../img/comm/hover.png);
}

/* child */
.header ul.menu ul{
	width: 165px;
	position: absolute; 
	display: none; 
	list-style: none;
	margin: 0;
	padding: 0;
	background-color: rgba(0,0,0,0.5);
	background-image: none;
	box-shadow: 0 0 6px 0 rgba(255,255,255,0.3);
 	transition: 0.001s;
}
.header ul.menu ul li{
	position: relative;
}
.header ul.menu ul li:first-child{
	border-bottom: 1px solid rgba(255,255,255,0.2);
}
.header ul.menu ul li a:hover{
	background-color: rgba(109,108,23,0.5);
	background-image: none;
}
.header .navi ul li.current ul li a{
	background-image: none;
}
.header .navi ul li.current ul li a.current{
	background-color: rgba(109,108,23,0.5);
}


/* sub */
.header .sub{
	font-family: serif;
	width: 1024px;
	margin: 20px auto 0;
}
.header .sub ul{
	width: 500px;
	margin: 20px 0 0 auto;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: flex-end;
}
.header .sub ul li a{
	text-decoration: none;
	margin: 0 0 0 20px;
	padding: 0 15px;
	display: block;
	height: 35px;
	line-height: 35px;
	background-image: url(../img/comm/sub.png);
	background-position: center center;
	background-repeat: repeat-x;
}
.header .sub ul li a:hover{
	opacity: 0.6;
}

}



@media screen and (max-width: 1098px){
.navi{
	display: none;
}

.hamburger{
	position: fixed;
	top: 0;
	right: 0;
	z-index: 10000;
	padding: 10px 0;
	overflow: visible;
}
.hamburger .menu{
	margin-top: 36px;
	margin-right: 6px;
	width: 54px;
	height: 54px;
	z-index: 9999;
	box-shadow: 0 0 6px 0 rgba(0,0,0,0.2);
}
.hamburger .menu .toggle:hover{
	opacity: 0.7;
}
.hamburger .menu .toggle{
	transition: 0.3s ease;
	position: relative;
	width: 54px;
	height: 54px;
	cursor: pointer;
	-webkit-appearance: none;
	 -moz-appearance: none;
	appearance: none;
	border: 0;
	z-index: 100;
	background-color: #8c8c00;
}
.hamburger .menu .toggle.navi-btn{
	outline: none;
}
.hamburger .menu .toggle.navi-btn-on{
	outline: none;

}
.navi-btn {
  position: relative;
  display: inline-block;
  box-sizing: border-box;
}
.navi-btn div {
  position: absolute;
  left: 14px;
  height: 2px;
  width: 26px;
  border-radius: 2px;
  display: inline-block;
  box-sizing: border-box;
}
.navi-btn div,
.header.fixed .navi-btn div {
	background-color: #fff;
}
.navi-btn div:nth-of-type(1) {
	top: 19px;
}
.navi-btn div:nth-of-type(2) {
	top: 27px;
}
.navi-btn div:nth-of-type(3) {
	bottom: 18px;
}
.navi-btn-on {
  position: relative;
  display: inline-block;
  box-sizing: border-box;
	transition: 0.3s;
   	background-image: url(../img/navi.svg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 55px;
}
.navi-btn-on div {
  position: absolute;
  left: 14px;
  height: 2px;
  width: 26px;
  border-radius: 2px;
  display: inline-block;
  box-sizing: border-box;
	transition: 0.3s;
}
.navi-btn-on div:nth-of-type(1) {
	top: 12px;
    transform: translateY(16px) rotate(45deg);
}
.navi-btn-on div:nth-of-type(2) {
    display: none;
}
.navi-btn-on div:nth-of-type(3) {
	bottom: 24px;
    transform: translateY(0px) rotate(-45deg);
}

/* ----spnavi---- */
.spnavi{
	display: none;
	position: absolute;
	top: 0;
	right: 0;
	margin: 0;
	padding: 0 0 20px;
	box-sizing: border-box;
	background-color: #000;
	width: 100vw;
	height: 100vh;
	overflow-x: hidden;
	overflow-y: auto;
    touch-action: manipulation;
    -webkit-overflow-scrolling: touch;
	z-index: 10;
}

.spnavi .title{
	transition: 0.3s;
	width: 250px;
	font-size: 1.1rem;
	font-weight: 400;
	margin: 0 auto;
	text-align: center;
}
.spnavi .title a:hover{
	opacity: 0.6;
}

.spnavi .service-title.sp{
	width: 100%;
	max-width: 640px;
	margin: 0 auto;
	text-align: center;
	font-family: serif;
	font-size: 1.8rem;
}
.page .spnavi .service-title.sp{
	margin-top: 30px;
}
.spnavi .service-title.sp .big{
	font-family: sans-serif , "メイリオ";
	font-size: 3.6rem;
	font-weight: 700;
	margin: 0 5px 0 0;
}
.spnavi .service-title.sp .big span{
	font-size: 2.4rem;
}

.spnavi .service-list{
	width: 100%;
	max-width: 640px;
	margin: 0 auto;
	background-color: #999;
}
.spnavi .service-list ul{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	padding: 0;
	margin: 0 auto;
}
.spnavi .service-list ul li{
	margin: 0 auto;
	width: 50%;
	text-align: center;
	color: #fff;
	transition: 0.3s;
}
.spnavi .service-list ul li:hover{
	opacity: 0.7;
}
.spnavi .service-list ul li.wide{
	width: 100%;
}
.spnavi .service-list .kind{
	font-size: 1.7rem;
	font-family: serif;
	padding: 5px 0;
}
.spnavi .service-list a{
	text-decoration: none;
}
.spnavi .service-list .img{
	width: 100%;
	overflow: hidden;
	margin: 0;
}
.spnavi .service-list .img img{
	display: block;
	margin: 0;
	width: 100%;
	height: 80px;
	object-fit: cover;
}

.spnavi .sub ul{
	width: 100%;
	max-width: 640px;
	margin: 15px auto;
	padding: 0;
	list-style: none;
}
.spnavi .sub ul li a{
	text-decoration: none;
	margin: 0;
	padding: 0 15px;
	display: block;
	height: 40px;
	line-height: 40px;
	background-image: url(../img/comm/sub.png);
	background-position: center center;
	background-repeat: repeat-x;
}
.spnavi .sub ul li a:hover{
	opacity: 0.6;
}

.spnavi .comm-menu ul{
	width: 100%;
	max-width: 640px;
	margin: 15px auto;
	padding: 0;
	list-style: none;
}
.spnavi .comm-menu ul li a{
	text-decoration: none;
	margin: 0;
	padding: 0 15px;
	display: block;
	height: 40px;
	line-height: 40px;
	background-image: url(../img/comm/navi.png);
	background-position: center center;
	background-repeat: repeat-x;
}
.spnavi .comm-menu ul li a:hover{
	opacity: 0.6;
}

.spnavi .contact{
	margin: 15px;
	padding: 0 0 30px;
	text-align: center;
	font-size: 1.3rem;
}
.spnavi .contact .phone{
	font-size: 2.2rem;
	font-weight: 600;
	margin: 20px 0 0;
}
.spnavi .contact .mail{
	font-size: 2.2rem;
	font-weight: 600;
	margin: 20px 0 0;
}
.spnavi .contact p{
	margin: 0;
}
.spnavi .contact .phone a,
.spnavi .contact .mail a{
	text-decoration: none;
}


}



@media screen and (max-width: 699px){
.hamburger .menu{
	margin-top: 1px;
	margin-right: 0;
}

}
