/* Flexnav Base Styles */

.flexnav {
  -webkit-transition: none;
  -moz-transition: none;
  -ms-transition: none;
  transition: none;
  -webkit-transform-style: preserve-3d;
  overflow: hidden;
  margin: 0 auto;
  width: 100%;
  max-height: 0; 
  z-index: 10;
  padding:0;
  }
.flexnav.opacity {
	opacity: 0;
	}
.flexnav.flexnav-show {
	max-height: 2000px;
	opacity: 1;
	-webkit-transition: all .5s ease-in-out;
	-moz-transition: all .5s ease-in-out;
	-ms-transition: all .5s ease-in-out;
	transition: all .5s ease-in-out;
	}
.flexnav.one-page {
	position: fixed;
	top: 50px;
	right: 5%;
	max-width: 200px; 
	}
.flexnav li {
	font-size: 100%;
	position: relative;
	overflow: hidden; 
	}
.flexnav li ul {
	width: 100%; 
	}
.flexnav li ul li {
	font-size: 100%;
	position: relative;
	overflow: hidden;  
	}
.flexnav li ul.flexnav-show li {
	overflow: visible;
	}
.flexnav li ul li a {
    display: block;
    }
.flexnav .touch-button:hover {
    cursor: pointer;
    }
.menu-button.one-page {
    position: fixed;
    top: 0;
    right: 5%;
    padding-right: 45px;
    }

/* phone */
@media only screen and (max-width: 640px) {
.cd-header{
	position:fixed;
	top:0;
	width:100%;
	z-index:10;
	background:rgba(255,255,255,1);
	height:60px;
	border-bottom:1px solid rgba(200,200,200,1);
	}
.cd-main-nav {
	position: absolute;
	background: none;
	margin-top:58px;
	width:100%;
	top: 0;
	}
body#pano .cd-main-nav {
	margin-top:58px;
	} 
 .flexnav {
  -webkit-transition: none;
  -moz-transition: none;
  -ms-transition: none;
  transition: none;
  -webkit-transform-style: preserve-3d;
  overflow: hidden;
  margin: 0 auto;
  width: 90%;
  max-height: 0; 
  z-index: 10;
  padding:0;
  }

/* new1 */
/* iPhone13~ */
.flexnav .menu:first-child{
	border-top: 1px solid rgba(0, 0, 0, 0.15);
	}
.flexnav .menu:first-child a{
	padding-top: 15px;
	padding-bottom: 15px;
	}
.flexnav .menu:first-child a img{
	vertical-align: middle;
	padding-right: 10px;
	}	
/*  */

.flexnav .menu {
	font-size: 100%;
	overflow: hidden; 
	}
.flexnav .menu a {
	position: relative;
	display: block;
	padding-top: 26px;
	padding-bottom: 26px;
	z-index: 10;
	overflow: hidden;
	color: #373737;
	text-decoration:none;
	text-align:center;
	background: #fff;
	line-height: 1;
	border-bottom: 1px solid rgba(0, 0, 0, 0.15);
	}
.flexnav .menu#access_{
display: table;
width: 100%;
text-align: center;
vertical-align: middle;
}
.flexnav .menu#access_ a,
.flexnav .menu#access_ a span .fab,
.flexnav .menu#access_ a span .fas{
display: table-cell;
vertical-align: text-bottom;
}

/* new2 */
/* iPhone13~ */
.menu-button {
	position: relative;
	display: block;
	font-size:16px;
	font-weight:bold;
	float:right;
	top:0;
	right:5px;
	height:60px;
	padding: 1em;
	cursor: pointer;
	}
 i.fas.fa-bars {
	margin: 0;
	padding: 0;
	font-size: 26px;
	line-height: 25px;
	}
.flexnav .touch-button {
	position: absolute;
	z-index: 999;
	top: 0;
	right: 0;
	width: 50px;
	height: 50px;
	display: inline-block;
	text-align: center; 
	}
.flexnav .touch-button .navicon {
	position: relative;
	top: 1.4em;
	font-size: 12px;
	color: #373737;
	}
.menu-button .touch-button .navicon {
	display:none;
	}
.menu-button .touch-button {
    background: transparent;
    position: absolute;
    z-index: 999;
    top: 0px;
    right: 0px;
    width: 60px;
    height: 60px;
    display: inline-block;
    text-align: center;
    }
.cd-main-nav ul {
	width: 100%;
	z-index: 999;
	}
}/* sp end */  


/* pc tablet */    

@media all and (min-width: 641px) {
.cd-main-nav ul .menu {
	margin-right:25px;
	float: left;
	margin-top:10px;
	padding-bottom:15px;
	}
.cd-main-nav ul li a {
	text-decoration: none;
	color: #373737;
	font-size:16px;
	}
.cd-main-nav ul li a img{
	vertical-align: middle;
	padding-right: 10px;
	}	
.cd-main-nav ul li a:hover {
	opacity:0.8;
	}
.sub_menu {
	text-decoration: none;
	color: #fff;
	font-size:16px;
	}
body.one-page {
	padding-top: 70px; 
	}
.flexnav {
	overflow: visible; 
	}  
.flexnav.opacity {
	opacity: 1; 
	}
.flexnav.one-page {
	top: 0;
	right: auto;   
	}    
.flexnav li {
	position: relative;
	list-style: none;
	float: left;
	display: block;
	overflow: visible;
	}
.flexnav li a {
	border-bottom: none;
	}
.flexnav li > ul {
	position: absolute;
	top: auto;
	left: 0; 
	}
.flexnav li > ul li {
	width: 100%;
	}
.flexnav li ul li > ul {
	margin-left: 100%;
	top: 0;
	}
.flexnav li ul li a {
	padding:20px;
	vertical-align:middle;
	display:block;
	padding-left:10px;
	background:rgba(255, 255, 255, 1);
	border-bottom: 1px solid rgba(0, 0, 0, 0.15);
	}
.flexnav li ul.open {
	display: block;
	opacity: 1;
	visibility: visible;
	z-index: 1;
	}
.flexnav li ul.open li {
	overflow: visible;
	max-height: 100px;
	}
.flexnav li ul.open ul.open {
	margin-left: 100%;
	top: 0;
	}
.flexnav .touch-button {
	z-index: 999;
	top: 0;
	right: 0;
	width: 50px;
	height: 50px;
	display: inline-block;
	text-align: center;
	display: none;
	}
.menu-button {
    display: none; 
	}    
}