/* 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: #024ad8;
}
.header_logo a:visited {
	color: #024ad8;
}
.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;
	}
}





/* xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

	CaaSヘッダー（2025.09）

xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx */

.header_content_inner {
	display: flex;
	align-items: center;
	height: 74px;
	padding: 0 14px 0 8px;
	margin: 0 auto;
}

@media screen and (min-width: 768px) {
	.header_content_inner {
		padding: 0 20px;
	}
}





/* ==================================================
	logo
================================================== */

.header_logo a::before {
	display: block;
	width: 40px;
	height: 40px;
}

@media screen and (min-width: 768px) {
	.header_logo a::before {
		width: 58px;
		height: 58px;
		font-size: 58px;
	}
}

@media screen and (min-width: 1024px) {
	.header_logo {
		margin-right: 60px;
	}
	.header_logo a {
		width: 58px;
		height: 58px;
		margin-right: 0;
		line-height: 58px;
	}
}





/* ==================================================
	sp
================================================== */

.header_menu_trigger svg,
.store_navi_mobile_menu svg {
	fill: #212121;
	transition: .2s;
}
.store_navi_mobile_menu :hover svg {
	fill: #545454;
}
.store_navi_mobile_menu > li > a {
	display: block;
	width: 32px;
	height: 32px;
}
.store_navi_mobile_menu > li {
	margin-right: 8px;
}

@media screen and (max-width: 1023px) {
	.header_content {
		display: block;
		height: auto;
		padding: 0;
	}
	.header_menu_trigger {
		width: 48px;
		height: 48px;
		padding: 8px;
		margin-right: 16px;
	}
}

@media screen and (max-width: 767px) {
	.store_navi_mobile_menu > li > a svg {
		width: 32px;
		height: 32px;
	}
}

@media screen and (max-width: 359px) {
	.header_menu_trigger {
		margin-right: 8px;
	}
}

@media screen and (min-width: 768px) {
	.store_navi_mobile_menu > li > a {
		width: 40px;
		height: 40px;
	}
}



/* ----------------------------------------
	header_menu
---------------------------------------- */

@media screen and (max-width: 1023px) {
	.header_menu_level1 {
		/* 閉じるボタンの高さ：72px */
		top: 72px;
		right: auto;
		left: 0;
		width: 100%;
		max-width: 360px;
		height: calc(100dvh - 72px);
	}
	.header_menu_level1.mb_active {
		overflow-y: auto;
	}
	.header_menu_level1 > li,
	.header_menu_level1 > li:last-child {
		border-color: #212121;
	}
	.header_menu_level1 > li:first-child {
		margin-top: 0;
		border-top: none;
	}
	.header_menu_level1 > li > a {
		justify-content: space-between;
		gap: 16px;
		height: auto;
		min-height: auto;
		padding: 12px 16px;
		font-size: 16px;
		line-height: 22px;
	}
	.header_menu_level1 > li > a:hover {
		background: #d9d9d9;
	}
	.header_menu_level1 > li > a::after {
		content: "";
		display: block;
		position: static;
		transform: none;
		width: 32px;
		height: 32px;
		outline: 1px solid #212121;
		outline-offset: -1px;
		background: url('data:image/svg+xml;charset=UTF-8,<svg viewBox="0 0 16 17" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" clip-rule="evenodd" d="M3.70027 5.79297L8.00028 10.093L12.3003 5.79297L13.0074 6.50008L8.00028 11.5072L2.99316 6.50008L3.70027 5.79297Z" fill="%23212121"/></svg>') no-repeat center center / 16px 17px;
	}
	.header_menu_level1 > li > a.active::after {
		transform: rotate(180deg);
	}
	.header_menu_level2 {
		height: auto;
		border-top: none;
	}
	.header_menu_level2_innner {
		padding-bottom: 12px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl {
		padding: 0 16px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dt {
		padding: 16px 0 16px 16px;
		line-height: 22px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dd {
		padding-left: 28px;
		margin-bottom: 12px;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dd a {
		display: inline;
		padding: 0;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dd a:link,
	.header_menu_level2 .header_menu_level2_innner > dl dd a:visited {
		color: #000;
		text-decoration: underline;
	}
	.header_menu_level2 .header_menu_level2_innner > dl dd a:hover {
		text-decoration: none;
		background: rgb(0 0 0 / .2);
	}

	/* 閉じるボタン */
	.header_close_wrap {
		display: none;
	}
	body.no_scroll .header_close_wrap {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 4;
		width: 100%;
		max-width: 360px;
		height: 72px;
		padding: 0 16px;
		background: #fff;
		border-bottom: 1px solid #212121;
	}
	#header_close {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 32px;
		height: 32px;
		min-height: auto;
		padding: 0;
		outline: 1px solid #212121;
		outline-offset: -1px;
	}
	#header_close::after {
		content: "";
		position: static;
		width: 16px;
		height: 16px;
		background: url('data:image/svg+xml;charset=UTF-8,<svg viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" clip-rule="evenodd" d="M12.1458 3.14604L12.4993 2.79248L13.2065 3.49959L12.8529 3.85314L8.70632 7.99974L12.8528 12.1463L13.2064 12.4999L12.4993 13.207L12.1457 12.8534L7.99921 8.70684L3.85265 12.8534L3.4991 13.207L2.79199 12.4999L3.14554 12.1463L7.2921 7.99973L3.14556 3.85317L2.792 3.49962L3.49911 2.79251L3.85266 3.14607L7.99921 7.29263L12.1458 3.14604Z" fill="%23212121"/></svg>');
	}

	/* ファセット検索のボタン */
	body.no_scroll .facet_trigger {
		z-index: 1;
	}
}





/* ==================================================
	pc
================================================== */

@media screen and (min-width: 1024px) {
	.header_content_inner {
		max-width: calc(1220px + 40px);
	}
	.header_menu_level1 > li > a {
		cursor: pointer;
		color: #212121;
		font-size: 16px;
	}
	.header_menu_level1 > li > a.active,
	.header_menu_level1 > li > a.active:not(:only-child),
	.header_menu_level1 > li > a:hover,
	.header_menu_level1 > li > a:not(:only-child):hover {
		color: #024AD8;
	}
	.header_menu_level1 > li > a.active::after {
		height: 2px;
		background: #024AD8;
	}
	.header_menu_level1 > li > a.active + .header_menu_level2 {
		display: block;
	}
}

/* @media screen and (min-width: 1366px) {
	.header_content_inner {
		max-width: 1366px;
		padding-right: 28px;
		padding-left: 28px;
	}
}

@media screen and (min-width: 1920px) {
	.header_content_inner {
		max-width: 1920px;
		padding-right: 116px;
		padding-left: 116px;
	}
} */





/* xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

	ストアナビ（2025.09）

xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx */

.store_navi {
	border-bottom: 1px solid #d3d2d2;
}
.store_navi a[href^="tel:"] {
	pointer-events: all;
}
body.no_scroll .store_navi {
	z-index: 1;
}





/* ==================================================
	store_navi--inner
================================================== */

.store_navi--inner {
	padding: 8px 20px;
}

@media screen and (min-width: 1024px) {
	.store_navi--inner {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		gap: 32px;
		max-width: calc(1220px + 40px);
		margin: 0 auto;
	}
	.store_navi_menu {
		gap: 20px;
	}
	.store_navi_menu > li:nth-child(n+2) {
		margin: 0;
	}
	.store_navi_menu > li > a {
		width: 32px;
		height: 32px;
	}
}

/* @media screen and (min-width: 1366px) {
	.store_navi--inner {
		max-width: 1366px;
		padding-right: 28px;
		padding-left: 28px;
		margin: 0 auto;
	}
}

@media screen and (min-width: 1920px) {
	.store_navi--inner {
		max-width: 1920px;
		padding-right: 116px;
		padding-left: 116px;
	}
} */





/* ==================================================
	store_navi--contact
================================================== */

.store_navi--contact {
	display: flex;
	justify-content: center;
	gap: 20px;
	font-size: 14px;
	line-height: 18px;
}
.store_navi--contact > div {
	display: flex;
	gap: 8px;
}
.store_navi--contact a:link,
.store_navi--contact a:visited {
	color: #212121;
	text-decoration: underline;
}
.store_navi--contact a:hover {
	color: #545454;
}

@media screen and (min-width: 768px) {
	.store_navi--contact {
		justify-content: flex-end;
		font-size: 16px;
		line-height: 22px;
	}
}





/* ==================================================
	store_navi--links
================================================== */

.store_navi_menu svg {
	width: 32px;
	height: 32px;
	fill: #212121;
	transition: .2s;
}
.store_navi_menu :hover svg {
	fill: #545454;
}

@media screen and (max-width: 1023px) {
	.store_navi--links {
		display: none;
	}
}

@media screen and (min-width: 1024px) {
	.store_navi_menu_level2 {
		top: 100%;
		right: 0;
		left: auto;
		transform: none;
		color: #2C3038;
		font-size: 14px;
		line-height: 18px;
		border: none;
		border-bottom: 1px solid #ccc;
		border-radius: 5px;
		box-shadow: 0 4px 6px 1px rgb(0 0 0 / .29);
	}
	.store_navi_menu_level2 a:link,
	.store_navi_menu_level2 a:visited {
		color: #165DBA;
		text-decoration: underline;
	}
	.store_navi_menu_level2 a:hover {
		text-decoration: none;
	}
	.store_navi_menu_arrow {
		display: none;
	}
}



/* ----------------------------------------
	store_navi_menu_login（ログイン）
---------------------------------------- */

.store_navi_menu_login .store_navi_menu_level2 .list_basic > li::before {
	width: 5px;
	height: 5px;
	background: #024AD8;
}





/* ==================================================
	header--contactList（ご相談）
================================================== */

.store_navi .header--contactList {
	width: 312px;
	white-space: normal;
}
.header--contactList > li {
	display: grid;
	grid-template-columns: 56px 1fr;
	border-bottom: 1px solid #ccc;
}
.header--contactList > li:last-child {
	border-bottom: none;
}
.header--contactList > li > :first-child {
	padding: 12px 0 0 14px;
}
.header--contactList > li > :last-child {
	padding: 15px 20px 15px 0;
}
.header--contactList svg {
	width: 28px;
	height: 28px;
}
.header--contactList h3 {
	font-size: 14px;
	font-weight: normal;
	line-height: 18px;
}
.header--contactList a:link,
.header--contactList a:visited {
	color: #165DBA;
	text-decoration: underline;
}
.header--contactList a:hover {
	text-decoration: none;
}
.header--contactList dt.hr {
	position: relative;
	padding-top: 15px;
	margin-top: 15px;
}
.header--contactList dt.hr::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: calc(100% + 20px);
	height: 1px;
	background: #ccc;
}



/* ----------------------------------------
	モーダル - sp
---------------------------------------- */

@media screen and (max-width: 1023px) {
	.store_navi_mobile_contact {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 1000;
		width: 100%;
		height: 100dvh;
	}
	.store_navi_mobile_contact--overlay {
		width: 100%;
		height: 100%;
		background: rgb(0 0 0 / .3);
	}
	.store_navi_mobile_contact--content {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		max-width: 360px;
		height: 100%;
		background: #fff;
	}
	.store_navi_mobile_contact .store_navi_mobile_contact--body {
		overflow-y: auto;
		position: fixed;
		top: 72px;
		left: 0;
		width: 100%;
		max-width: 360px;
		height: calc(100dvh - 72px);
		padding: 0;
	}

	/* 閉じるボタン */
	.store_navi_mobile_contact--close {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 4;
		width: 100%;
		max-width: 360px;
		height: 72px;
		padding: 0 16px;
		background: #fff;
		border-bottom: 1px solid #ccc;
	}
	.store_navi_mobile_contact--close button {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 32px;
		height: 32px;
		min-height: auto;
		padding: 0;
		outline: 1px solid #212121;
		outline-offset: -1px;
	}
	.store_navi_mobile_contact--close button::after {
		content: "";
		width: 16px;
		height: 16px;
		background: url('data:image/svg+xml;charset=UTF-8,<svg viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" clip-rule="evenodd" d="M12.1458 3.14604L12.4993 2.79248L13.2065 3.49959L12.8529 3.85314L8.70632 7.99974L12.8528 12.1463L13.2064 12.4999L12.4993 13.207L12.1457 12.8534L7.99921 8.70684L3.85265 12.8534L3.4991 13.207L2.79199 12.4999L3.14554 12.1463L7.2921 7.99973L3.14556 3.85317L2.792 3.49962L3.49911 2.79251L3.85266 3.14607L7.99921 7.29263L12.1458 3.14604Z" fill="%23212121"/></svg>');
	}
}

@media screen and (min-width: 1024px) {
	.store_navi_mobile_contact {
		display: none !important;
	}
}
