@charset "utf-8";
.bx-wrapper {
	margin: 0 !important;
	-moz-box-shadow: none !important;
	-webkit-box-shadow: none !important;
	box-shadow: none !important;
	border: none !important;
	background: none !important;
}

.bxslider__ul__li a {
	cursor: pointer;
}
.keyvisual {
	position: relative;
}
.keyvisual .keyvisual__back {
	display: block;
	width: 100vw;
	height: auto;
	min-height: 100vw;
	max-width: unset;
}
.keyvisual .keyvisual__front {
	width: 100vw;
	height: auto;
	max-width: 375px;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
}
#previcon {
	left: 0;
	transform: rotate(135deg);
	border-left-color: transparent !important;
	border-top-color: transparent !important;
}
#nexticon {
	right: 0;
	transform: rotate(-45deg);
	border-left-color: transparent !important;
	border-top-color: transparent !important;
}
.bx-prev,
.bx-next {
	display: block;
	width: inherit;
	height: inherit;
}
#bxslider .bx-pager-link {
	width: 13px;
	height: 13px;
	margin: 0 5px;
	border-radius: 50%;
}
#bxslider .bx-pager {
	position: static;
	padding: 20px 0;
	box-sizing: border-box;
}
.bx-pager-link {
	background: #666;
}

@media screen and (max-width: 374px) {
	/* iphone5 */
}

@media screen and (min-width: 500px) {
	.bxslider__ul__li {
		overflow: hidden;
		height: 420px;
		max-height: none;
		display: flex;
		align-items: flex-end;
		position: relative;
	}

	@media screen and (max-width: 1023px) {
		.keyvisual .keyvisual__back {
			position: relative;
			top: 100px;
		}
	}
}

@media screen and (min-width: 1024px) {
	/* PC/Tablet */
	.widget_home_main_visual {
		position: relative;
	}
	.bx-viewport {
		overflow-x: visible !important;
		overflow: visible !important;
	}
	.bx-viewport {
		margin: 0 calc((100vw - 100%) / -2);
		padding: 0 calc((100vw - 100%) / 2);
		overflow: hidden;
		height: 420px;
	}
	.bx-wrapper img {
		max-width: 100vw;
	}
	.bxslider__ul__li {
		margin: 0 calc(-50vw + 50%);
		display: block;
	}

	.keyvisual {
		margin: 0;
	}
	.keyvisual .keyvisual__back {
		width: 100vw !important;
		min-height: 420px;
		position: relative;
		left: calc((100vw - 100%) / -2);
		object-fit: cover;
		object-position: bottom;
		/* IE対策 */
		font-family: "object-fit: cover;";
	}
	.keyvisual .keyvisual__front {
		width: 1024px !important;
		max-width: 1024px;
		position: absolute;
		margin: auto;
	}
	.keyvisual__control {
		width: 1024px;
		height: 420px;
		position: absolute;
		top: 0;
		margin: auto;
	}
	.keyvisual__control__icon {
		position: absolute;
		top: 50%;
		margin-top: -16px;
		outline: 0;
		text-indent: -9999px;
		z-index: 33;
		border-radius: 4px;
		width: 18px;
		height: 18px;
		border: 2px solid;
		cursor: pointer;
	}
}
