@charset "UTF-8";

/* xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

	CaaS Header

xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx */

body.no_scroll{
	overflow-y: hidden;
}

.header {
	position: relative;
	width: 100%;
	background: #fff;
	border-bottom: 1px solid #b9b8bb;
	display: flex;
    justify-content: center;
}
.header a:active,
.header a:hover {
	text-decoration: none;
	outline: none;
}



/* ==================================================

	icon font

================================================== */

.header_logo a::before,
.header_search_icon::before,
.search_box .btn::before {
	font-family: HPIcons;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	vertical-align: bottom;
}

#header_close::after{
	font-family: HPIcons;
	content: "\E907";
	position: absolute;
	right: 2rem;
	top: 1.5rem;
	font-size: 20px;
	color: #999;
	cursor: pointer;
	z-index: 5;
}

#header_back::before{
	font-family: HPIcons;
	content: "\E90c";
	cursor: pointer;
	position: absolute;
	right: 260px;
	top:1.5rem;
	transform: rotate(90deg);
	font-size: 20px;
	color: #0171ad;
	z-index: 5;
}

/* ==================================================

	header_content

================================================== */

.header_content {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}

#header_close{
	display: none;
}

#header_back{
	display: none;
}


#header_overlay,#header_overlay_m {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background: rgba(0, 0, 0, 0.3);
	display: none;
	z-index: 3;
 }

@media screen and (max-width: 1023px) {
	.header_content {
		width: 100%;
		height: 60px;
		padding: 10px 16px 10px 10px;
	}

	/* order */
	.header_logo { order: 0; }
	.store_navi_mobile { order: 1; }
	.header_search_trigger { order: 2; }
	.header_menu { order: 3; }

	#header_overlay_m.active{
		display: block;
	}
}


@media screen and (min-width: 1024px) {
	.header_content {
		width: 1000px;
		height: 72px;
		margin: 0 auto;
	}
	
	#header_overlay.active{
		display: block;
	}
}

/* ==================================================

	logo

================================================== */

.header_logo a {
	display: block;
	color: #000;
}
.header_logo a:visited {
	color: #000;
}
.header_logo a::before {
	content: "\E900";
}
.header_logo img {
	display: none;
}



@media screen and (max-width: 1023px) {
	.header_logo {
		margin-right: auto;
	}
	.header_logo a {
		width: 40px;
		height: 40px;
		line-height: 40px;
	}
	.header_logo a::before {
		font-size: 40px;
	}
}



@media screen and (min-width: 1024px) {
	.header_logo a {
		width: 50px;
		height: 50px;
		line-height: 50px;
		margin-right: 40px;
	}
	.header_logo a::before {
		font-size: 50px;
	}
	.header_menu{
		width: 100%;
	}
}





/* ==================================================

	menu

================================================== */

.header_menu_level1 > li > a {
	display: flex;
	align-items: center;
	font-size: 17px;
	font-weight: normal;
}



/* livel2 -------------------- */

.header_menu_level2 {
	padding: 15px 30px 30px;
}
.header_menu_level2 .header_menu_level2_innner > dl dd a {
	padding: 10px 20px;
	display: block;
	color: #767676;
	font-size: 15px;
	white-space: nowrap;
}
.header_menu_level2 .header_menu_level2_innner > dl dd a:hover {
	background: #e6fcff;
}

/* display none -------------------- */

.header_menu_trigger,
.header_menu_guide,
.header_menu_close {
	display: none;
}



@media screen and (max-width: 1023px) {
	
	.header_menu {
		height: 24px;
	}

	.header_menu_level1 {
		display: none;
		position:fixed;
		top: 0;
		right: 0;
		width: 290px;
		background: #fff;
		z-index: 4;
		height: 100vh;
	}
	.header_menu_level1.mb_active {
		display: block;
	}
	.header_menu_level1 br {
		display: none;
	}

	.header_menu_level1 > li {
		position: relative;
		padding: 0;
		border-top:1px solid #ccc;
	}
	.header_menu_level1 > li:first-child {
		margin-top: 60px;
	}
	.header_menu_level1 > li:last-child {
		border-bottom:1px solid #ccc;
	}

	.header_menu_level1 > li > a {
		min-height: 60px;
		height: 60px;
		padding: 10px 20px;
		color: #2c3038;
		cursor: pointer;
	}
	.header_menu_level1 > li > a:visited {
		color: #2c3038;
	}
	.header_menu_level1 > li > a:hover {
		color: #000;
		background: #e6fcff;
	}
	.header_menu_level1 > li > a.active {
		color: #2c3038;
	}
	.header_menu_level1 > li.active > a:hover {
		color: #2c3038;
		background: #fff;
	}
	.header_menu_level1 > li > a::after {
		content: "\E90c";
		position: absolute;
		right: 1.6rem;
		transform: rotate(270deg);
		font-size: 18px;
		font-family: HPIcons;
		color: #999;
	}
	.header_menu_level1 > li.active > a{
		justify-content:center;
		cursor: default;
		pointer-events: none;
	}
	.header_menu_level1 > li.active > a::after {
		display:none;
	}

	.header_menu_level2 {
		display: none;
		height: calc(100vh - 75.5px);
		overflow-y: scroll;
		overflow-x: hidden;
		border-top: 1px solid #ccc;
		padding: 0;
	}
	.header_menu_level2_innner{
		padding-bottom: 60px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dt {
		padding: 25px 10px 10px 15px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dd a {
	    padding: 20px 10px 20px 30px;
	}
	/* header_menu_trigger -------------------- */

	.header_menu_trigger {
		display: inline-block;
		position: relative;
		width: 30px;
		height: 24px;
		transition: .4s;
		cursor: pointer;
	}
	.header_menu_trigger span {
		position: absolute;
		left: 0;
		width: 100%;
		height: 2px;
		background-color: #5a5a5a;
		border-radius: 1px;
		transition: .4s;
	}
	.header_menu_trigger span:nth-of-type(1) { top: 0; }
	.header_menu_trigger span:nth-of-type(2) { top: 11px; }
	.header_menu_trigger span:nth-of-type(3) { bottom: 0; }

	.header_menu_trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(11px) rotate(-45deg);
		transform: translateY(11px) rotate(-45deg);
	}
	.header_menu_trigger.active span:nth-of-type(2) {
		left: 50%;
		opacity: 0;
		-webkit-animation: active-menu-bar02 .8s forwards;
		animation: active-menu-bar02 .8s forwards;
	}
	@-webkit-keyframes active-menu-bar02 {
		100% { height: 0; }
	}
	@keyframes active-menu-bar02 {
		100% { height: 0; }
	}
	.header_menu_trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-11px) rotate(45deg);
		transform: translateY(-11px) rotate(45deg);
	}



	/* livel2 -------------------- */

	.header_menu_level2 {
		width: 100%;
		background: #fff;
	}

	.header_menu_level2_innner > dl dd a:hover {
		color: #000;
		background: #e6fcff;
	}

	.header_menu_level2 .header_menu_level2_innner > dl dt {
		font-size: 16px;
	}

	.header_menu_level2 .header_menu_level2_innner > dl dd a {
		white-space: normal;
	}


	/* guide -------------------- */

	.header_menu_guide {
		display: block;
	}

}



@media screen and (min-width: 1024px) {
	.header_menu_level1 {
		display: flex !important;
		overflow: visible !important;
		justify-content: flex-start;
		align-items: center;
		position: relative;
		z-index: 2;
	}
	.header_menu_level1.mb_active {
		display: none;
	}
	.header_menu_level1 > li {
		position: relative;
		margin-right: 40px;
	}
	.header_menu_level1 > li:nth-child(n+2) {
		margin-left: 20px;
	}
	.header_menu_level1 > li > a {
		height: 72px;
		color: #5a5a5a;
		text-align: center;
		line-height: 25px;
	}
	.header_menu_level1 > li > a:visited {
		color: #5a5a5a;
	}
	.header_menu_level1 > li > a:hover {
		color: #000;
	}

	/* active */
	.header_menu_level1 > li:hover > a:not(:only-child) {
		position: relative;
		color: #000;
	}
	.header_menu_level1 > li > a.active::after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 4px;
		background: #0171ad;
	}



	/* livel2 -------------------- */

	.header_menu_level2 {
		display: none;
		position: absolute;
		top: 72px;
		left: 2%;
		transform: translateX(-2%);
		margin: 0 auto;
		border-top: .2px solid #e1e5ed;
		box-shadow: 0 4px 4px 0 rgba(0,0,0,.2);
		opacity: 0;
		z-index: 3;
		transition: .2s;
		background: #fff;
	}
	.header_menu_level1 > li:nth-child(3) .header_menu_level2 {
		left: -220px;
	}
	.header_menu_level2 .header_menu_level2_innner{
		display: flex;
		justify-content:space-between;
	}
	.header_menu_level1 > li .header_menu_level2 {
		top: 72px;
		opacity: 1;
	}
	.header_menu_level2 .header_menu_level2_innner > dl {
		width: 200px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dt {
		padding: 15px 0;
		font-weight: bold;
		font-size:16px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dd a {
		white-space: normal;
	}

}





/* ==================================================

	search

================================================== */

.header_search_trigger {
	display: flex;
	align-items: center;
	position: relative;
	width: 32px;
	text-align: center;
	cursor: pointer;
}

.header_search_icon {
	height: 32px;
}
.header_search_icon::before {
	content: "\E901";
	color: #5a5a5a;
	font-size: 32px;
	line-height: 32px;
}
.header_search_icon.active::before,
.header_search_icon:hover::before {
	color: #007dba;
}



/* arrow -------------------- */

.header_search_arrow {
	display: none;
}
.active .header_search_arrow {
	display: inline-block !important;
	position: absolute;
	bottom: -1px;
	left: 50%;
	transform: translateX(-50%);
	width: 24px;
	height: 24px;
}
.header_search_arrow::before,
.header_search_arrow::after {
	content: "";
	position: absolute;
	top: 0;
	height: 0;
	width: 0;
	border: 12px solid transparent;
	pointer-events: none;
}
.header_search_arrow::before {
	right: 1px;
	border-color: rgba(204,31,12,0);
	border-bottom-color: #b9b8bb;
}
.header_search_arrow::after {
	top: 2px;
	right: 1px;
	border-color: rgba(242,242,242,0);
	border-bottom-color: #fff;
}



/* form -------------------- */

#header_search {
	display: none;
	position: absolute;
	top: calc(100% + 1px);
	left: 0;
	width: 100%;
	padding: 35px 1.65%;
	background: #fff;
	box-shadow: 0 6px 6px 0 rgba(0,0,0,.1);
	z-index: 2;
}
.search_box {
	display: flex;
	position: relative;
	width: 100%;
	margin: 0 auto;
}
.search_box input,
.search_box button {
	margin: 0;
	padding: 0;
	font-family: "HPSimplified","メイリオ",Meiryo,arial,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro";
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.search_box .text {
	width: 100%;
	height: 48px;
	padding: 0 100px 0 20px;
	font-size: 15px;
	background: #fff;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-left: 1px solid #ccc;
	color:#666;
}
.search_box .btn {
	position: absolute;
	top: 0;
	right: 0;
	width: 80px;
	height: 48px;
	background: #ccc;
	border: none;
	cursor: pointer;
}
.search_box .btn:hover {
	background: #999;
}
.search_box .btn::before {
	content: "\E901";
	position: absolute;
	top: 0;
	right: 0;
	width: 80px;
	height: 48px;
	color: #fff;
	font-size: 22px;
	text-align: center;
	line-height: 48px;
}



@media screen and (min-width: 1024px) {
	.search_box {
		width: 80%;
	}
}



@media screen and (max-width: 1023px) {
	.header_search_trigger {
		height: 60px;
		margin-right: 10px;
	}
	#header_search {
		top: 61px;
		padding: 20px 16px;
	}
	.search_box .btn,
	.search_box .btn::before {
		width: 60px;
	}
}



@media screen and (min-width: 1024px) {
	.header_search_trigger {
		display: none;
	}
	#header_search .search_box {
		width: 270px;
	}
	#header_search{
		display: block !important;
		position:absolute;
		width: 270px;
		left:auto;
		right: 0;
		top: 10px;
		padding: 0;
		box-shadow: none;
		background: none;
	}
	.search_box .text {
		border-right: 1px solid #ccc;
	}
	.header_content{
		position: relative;
	    display: flex;
		justify-content: space-between;
		width: 100%;
		max-width: 1000px;
		height: unset;
		background-color: unset;
		margin: 0 20px;
	}
	.search_box .btn {
		width: 60px;
		background: none;
	}
	.search_box .btn::before {
		width: 60px;
		color: #5a5a5a;
	}
	.search_box .btn:hover {
		background: none;
	}

}





/* xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

	Store Navi

xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx */



.store_navi {
	position: relative;
	width: 100%;
}



@media screen and (max-width: 1023px) {
	.store_navi_pc {
		display: none;
	}
	.store_navi_bar_mobile {
		width: 100%;
		padding: 0 10px;
		text-align: right;
		line-height: 22px;
		background: #0096d6;
	}
	.store_navi_bar_mobile > a {
		color: #fff;
		font-size: 13px;
	}
}



@media screen and (min-width: 1024px) {
	.store_navi_mobile,
	.store_navi_bar_mobile {
		display: none;
	}
	.store_navi {
		background: #fff;
		border-bottom: 1px solid #b9b8bb;
	}
	.store_navi_pc {
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
		position: relative;
		width: 1000px;
		margin: 0 auto;
		padding: 5px 0;
	}
}





/* ==================================================

	store_navi_tel

================================================== */

@media screen and (min-width: 1024px) {
	.store_navi_tel {
		display: flex;
		justify-content: flex-start;
		align-items: baseline;
		padding-bottom: 5px;
		color: #5a5a5a;
		line-height: 1;
	}

	.store_navi_tel > div:nth-of-type(1) {
		font-size: 12px;
	}
	.store_navi_tel > div:nth-of-type(1)::before {
		content: url(images/mark_tel.gif);
		vertical-align: bottom;
	}

	.store_navi_tel > div:nth-of-type(2) {
		margin-left: 5px;
		color: #007dba;
		font-size: 16px;
		font-weight: bold;
		letter-spacing: .5px;
	}

	.store_navi_tel > div:nth-of-type(2) span {
		margin-right: 5px;
		font-size: 12px;
		font-weight: normal;
		letter-spacing: .5px;
	}

	.store_navi_tel > div:nth-of-type(3) {
		font-size: 12px;
	}
	.store_navi_tel > div:nth-of-type(3) a {
		margin: 0 5px;
		color: #0096d6;
		font-size: 10px;
		text-decoration: none;
	}
}





/* ==================================================

	store_navi_mobile_menu

================================================== */

@media screen and (max-width: 1023px) {
	.store_navi_mobile_menu {
		display: flex;
		margin-left: 5px;
	}
	.store_navi_mobile_menu > li {
		margin-right: 5px;
	}
	.store_navi_mobile_menu > li img {
		max-height: 40px;
	}
}





/* ==================================================

	store_navi_menu

================================================== */

@media screen and (min-width: 1024px) {
	.store_navi_menu {
		display: flex;
	}
	.store_navi_menu > li {
		position: relative;
	}
	.store_navi_menu > li:nth-child(n+2) {
		margin-left: 10px;
	}
	.store_navi_menu > li > a {
		display: block;
	}



	/* level2 -------------------- */

	.store_navi_menu_level2 {
		visibility: hidden;
		position: absolute;
		top: calc(100% + 10px);
		left: 50%;
		transform: translateX(-50%);
		transition: .2s;
		background: #fff;
		border: 2px solid #ccc;
		border-bottom: 3px solid #0096d6;
		opacity: 0;
	}
	.store_navi_menu > li:hover > .store_navi_menu_level2 {
		visibility: visible;
		opacity: 1;
		z-index: 2;
	}
	.store_navi_menu_level2_inner {
		padding: 20px;
	}

	.store_navi_menu_login .store_navi_menu_level2_inner {
		width: 340px;
	}

	.store_navi_menu_guide .store_navi_menu_level2_inner, 
	.store_navi_menu_tell .store_navi_menu_level2_inner {
		white-space: nowrap;
	}

	.store_navi_menu_tell .store_navi_menu_level2_inner > p:nth-of-type(1) {
		margin-bottom:10px;
	}

	/* arrow -------------------- */

	.store_navi_menu_arrow {
		display: inline-block;
		position: absolute;
		top: -24px;
		left: 0;
		width: 100%;
		height: 24px;
		z-index: 2;
	}
	.store_navi_menu_arrow::before,
	.store_navi_menu_arrow::after {
		content: "";
		position: absolute;
		top: 0;
		left: 50%;
		transform: translateX(-50%);
		height: 0;
		width: 0;
		border: 12px solid transparent;
		pointer-events: none;
	}
	.store_navi_menu_arrow::before {
		border-color: rgba(204,31,12,0);
		border-bottom-color: #b9b8bb;
	}
	.store_navi_menu_arrow::after {
		top: 3px;
		border-color: rgba(242,242,242,0);
		border-bottom-color: #fff;
	}
}



