/*----- menu -----*/
.cp_offcm01 .cp_menu,
.cp_offcm01 .cp_menu.l_menu_my{
	z-index: 999;
	position: fixed;
	-webkit-transition: 0.53s transform;
	transition: 0.53s transform;
	-webkit-transition-timing-function: cubic-bezier(.38,.52,.23,.99);
	transition-timing-function: cubic-bezier(.38,.52,.23,.99);
	opacity: 1.0;
	font-size:14px;
	overflow: auto;
	
	width: 100vw;
	height: 100vh;
	top: -30vh;
	left: 0;
	visibility:hidden;
	background:rgba(255, 255, 255 , 0.8);
}

.cp_offcm01 #cp_toggle01 {
	position: absolute;
	display: none;
	opacity: 0;
}

:not(.mypage) .cp_offcm01 #cp_toggle01:checked ~ .cp_menu.l_menu_top {
	-webkit-transform: translateY(30vh);
	transform: translateY(30vh);
	visibility:visible;
}

.mypage:has(.cp_offcm01) #cp_toggle01:checked ~ .cp_menu.l_menu_my{
	-webkit-transform: translateY(30vh);
	transform: translateY(30vh);
	visibility:visible;
}

/* menu toggle */
.cp_offcm01 #cp_toggle01 ~ label {
	display: block;
	cursor: pointer;
	margin-bottom: 3px;
}

.cp_menu .lc_menu_close{
	position:absolute;
	top  :23px;
	right:20px;
	cursor:pointer;
}


/*----- menu design -----*/
.cp_menu .menu_inner{
	background: #FFFFFF;
	box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
	border-radius: 0px 0px 20px 20px;
	width:90%;
	max-width:1300px;
	margin:0 auto;
	padding: 0 70px; 70px; 70px;
	position:relative;
	top:64px;
}


.cp_menu h3 {
	font-size: 14px;
	color: #099775;
	padding:10px 10px;
	border-bottom: 0;

	font-family: 'Noto Sans JP';
	font-weight: 700;
	font-size: 20px;
	line-height: 150%;

	color: #000000;
}

.cp_offcm01 .cp_menu ul {
	margin: 0;
	padding: 0;
}
.cp_offcm01 .cp_menu li {
	list-style: none;
	padding-bottom:20px;
}

.cp_offcm01 .cp_menu li a {
	text-decoration: none;
	border: none;
	text-align: left;
	color:#333;
}

.cp_offcm01 .cp_menu li a:hover {
	color:#999;
}



/* menu list */
.menu_list_area .list_title{
	margin-bottom:10px;
	position:relative;
}

.menu_list_area .list_title a{
	display:inline-block;
	border:1px solid #FFF;
	border-radius: 5px;
	color: #099775;
	padding:10px 20px;
	width:100%;
	text-align:left;
	cursor:pointer;
	box-shadow: 0px 0px 12px rgba(0, 140, 107, 0.09);
}

.menu_list_area .list_title a:hover{
	text-decoration:none;
	border-color:#E9E9E9;
}

.menu_list_area .list_title a:before{
	content:"";
	display:block;
	border:none;
	width:10px;
	height:18px;
	position:absolute;
	top: calc(50% - 9px);
	right:20px;
	z-index:5;
	background:url("{{ asset('assets/img/icon2/carat_r_099775.svg', 'user_data')}}") no-repeat;
	background-size:cover;
}

.menu_list_area a.list_item{
	font-size: 12px;
	color: #333333;
}

.menu_list_area a.list_item:hover{
	text-decoration:none;
	color:#666;
}


.cp_menu.l_menu_my .l_navi__title{
	border-bottom:0;
}

@media screen and (max-width: 767px){
	.cp_offcm01 .cp_menu ul {
		padding: 28px;
	}
	
	body#page_contact .cp_menu.l_menu_top,
	body.mypage .cp_menu.l_menu_top{
		display:none;
	}
	
	body#page_contact .cp_menu.l_menu_my,
	body.mypage .cp_menu.l_menu_my{
		display:block;
	}
}


/*----- 追加分 -----*/
.cp_menu .menu_header{
	border-bottom: 1px solid #CCCCCC;
	margin-bottom:20px;
}

.cp_menu .list_item{
	position:relative;
}

.cp_menu .servie_menu li::after {
	content:'>';
	display:inline;
	position:absolute;
	left:180px;
}


@media screen and (max-width:767px){
	.cp_menu .menu_inner{
		padding: 0 20px; 20px; 20px;
	}
	
	.cp_menu li a{
		font-size: 12px;
	}
}