@media only screen and (max-width: 767px) {
	.l-main {
		padding-bottom: 50px;
	}

	.l-footer-pagetop {
		top: -55px;
	}
}

@media only screen and (min-width: 768px) {
	.block-home-visual {
		position: relative;
		z-index: 0;
		overflow: hidden;
		width: 100%;
		min-width: 1040px;
		height: 440px;
		margin-bottom: 40px;
		background: #000;
	}

	.block-home-visual:after {
		position: absolute;
		z-index: 5;
		top: 0;
		left: 0;
		display: block;
		width: 100%;
		height: 100%;
		content: '';
		background: url(../img/home/bg_mesh_01.png) repeat 0 0;
	}

	.block-home-visual .inner {
		position: relative;
		height: 0;
		padding-bottom: 56.25%;
	}

	.block-home-visual #movie {
		position: absolute;
		top: -10%;
		left: 0;
		width: 100%;
		height: 100%;
		border: none;
	}

	.block-home-visual p {
		font-family: serif;
		font-size: 3.5rem;
		position: absolute;
		z-index: 10;
		top: 47%;
		width: 100%;
		text-align: center;
		color: #fff;
	}
}

@media only screen and (max-width: 767px) {
	.block-home-visual {
		position: relative;
		height: 158px;
		margin: 0 -10px 20px;
		background: url(../img/home/ph_visual_sp.jpg) no-repeat 50% 50%;
		background-size: cover;
	}

	.block-home-visual iframe {
		display: none;
	}

	.block-home-visual p {
		font-family: serif;
		font-size: 1.8rem;
		position: relative;
		top: 45%;
		width: 100%;
		text-align: center;
		color: #fff;
	}
}

.block-home-kv {
	display: block;
	padding-bottom: 20px;
}

.block-home-kv .swiper-pagination {
	bottom: 0;
}

.block-home-kv .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	background-color: #ACACAC;
	opacity: 1;
}

.block-home-kv .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background-color: #E51926;
}

@media only screen and (min-width: 768px) {
	.block-home-kv {
		margin: 0 0 30px;
	}
}

@media only screen and (max-width: 767px) {
	.block-home-kv {
		margin: 0 -10px 40px;
	}

	.block-home-kv .swiper-slide {
		width: 100%;
	}

	.block-home-kv .swiper-slide img {
		width: 100%;
	}
}

.block-home-youtube .inner {
	position: relative;
}

.block-home-youtube .inner:after {
	content: '';
	display: block;
	padding-bottom: 56.25%;
}

.block-home-youtube #movie {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}

.block-home-youtube p {
	font-family: serif;
	position: absolute;
	z-index: 10;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
	text-align: center;
	color: #fff;
}

@media only screen and (min-width: 768px) {
	.block-home-youtube {
		margin: 0 0 40px;
	}

	.block-home-youtube .inner {
		width: 600px;
		margin: 0 auto 40px;
	}

	.block-home-youtube p {
		font-size: 3.5rem;
	}
}

@media only screen and (max-width: 767px) {
	.block-home-youtube {
		margin: 30px -10px 50px;
	}

	.block-home-youtube .inner {
		margin: 0 0 25px;
	}

	.block-home-youtube p {
		font-size: 1.8rem;
	}
}

.block-home-index-about {
	margin: 50px auto 0;
}

.block-home-index-about .heading {
	margin: 0 0 30px;
	font-size: 1.8rem;
	text-align: center;
}

.block-home-index-about .item-image img {
	width: 100%;
	height: 100%;
	aspect-ratio: 230 / 120;
	object-fit: cover;
}

@media only screen and (min-width: 768px) {
	.mod-index .item {
		width: 320px;
	}
}

@media only screen and (max-width: 767px) {
	.block-home-index-about .heading {
		font-size: 2.0rem;
	}

	.mod-index {
		display: flex;
		margin-bottom: 10px;
		flex-wrap: wrap;
	}

	.mod-index .item {
		width: 50%;
		margin-bottom: 10px;
	}

	.mod-index .item .item-text-heading {
		font-size: 1.5rem;
		margin: .7em 0 .5em;
	}

	.mod-index .item:nth-child(2n) {
		padding-left: 2%;
	}

	.mod-index .item:nth-child(2n+1) {
		padding-right: 2%;
	}

	.mod-index .item .item-text-summary {
		text-align: left;
	}
}

.block-home-index-contents {
	padding: 40px 0 0;
	border-top: 2px solid #f5f5f5;
}

.block-home-index-contents .item {
	max-width: 800px;
	margin: 0 auto 40px;
}

.block-home-index-contents .item-image img {
	width: 100%;
	height: 100%;
	aspect-ratio: 400 / 210;
	object-fit: cover;
}

.block-home-index-contents .item .item-text .item-text-summary {
	color: #666;
	font-size: 1.4rem;
	line-height: 1.5;
}

.block-home-index-contents .item-bnr a {
	display: block;
	transition: all .3s ease;
}

.block-home-index-contents .item-bnr a:hover {
	opacity: .7;
}

.block-home-index-contents .item-bnr img {
	width: 100%;
	height: auto;
}

@media only screen and (min-width: 768px) {
	.block-home-index-contents .item {
		display: flex;
		justify-content: space-between;
		align-items: center;
		width: 100%;
	}
	.block-home-index-contents .item .item-image {
		width: 50%;
	}
	.block-home-index-contents .item .item-text {
		width: calc(50% - 50px);
	}
	.block-home-index-contents .item .item-text .item-text-heading {
		font-size: 2.2rem;
	}
	.block-home-index-contents .item .item-text .item-text-summary {
		margin: 20px 0 30px;
	}
	.block-home-index-contents .item .mod-btn {
		margin: 0;
	}
}

@media only screen and (max-width: 767px) {
	.block-home-index-contents .item {
		width: calc(100% - 80px);
		margin: 0 auto 40px;
	}
	.block-home-index-contents .item .item-image {
		width: 100%;
	}
	.block-home-index-contents .item .item-text {
		width: 100%;
		margin: 20px auto 0;
	}
	.block-home-index-contents .item .item-text .item-text-heading {
		font-size: 2.0rem;
		text-align: center;
	}
	.block-home-index-contents .item .item-text .item-text-summary {
		margin: 20px 0;
	}
	.block-home-index-contents .item .mod-btn {
		width: calc(100% - 40px);
	}
}

.block-home-news {
	border-top: 2px solid #f5f5f5;
}

@media only screen and (min-width: 768px) {
	.block-home-news {
		padding-top: 40px;
	}

	.block-home-news .inner {
		display: table;
		width: 720px;
		margin: 0 auto 40px;
	}

	.block-home-news .heading {
		font-size: 1.8rem;
		display: table-cell;
		width: 120px;
		vertical-align: middle;
		border-right: 1px solid #ccc;
	}

	.block-home-news .mod-news {
		display: table-cell;
		padding-top: 10px;
		padding-left: 15px;
	}
}

@media only screen and (max-width: 767px) {
	.block-home-news {
		padding: 20px 0;
	}

	.block-home-news .heading {
		font-size: 1.8rem;
		margin: 0 0 20px;
		text-align: center;
	}
}

.block-home-other {
	margin: 40px 0 -40px;
	padding-top: 40px;
	border-top: 2px solid #f5f5f5;
}

@media only screen and (max-width: 767px) {
	.block-home-other {
		margin-top: 0;
	}
}

.block-home-other ul:after {
	display: block;
	clear: both;
	content: '';
}

.block-home-other li {
	float: left;
	width: 500px;
	margin-bottom: 40px;
}

.block-home-other li:nth-child(2n+1) {
	margin-right: 40px;
}

.block-home-other a {
	position: relative;
	display: block;
	height: 120px;
	transition: all .3s ease;
	text-align: right;
	background: #eee;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: cover;
}

.block-home-other a span {
	font-size: 1.6rem;
	line-height: 50px;
	position: absolute;
	top: 30px;
	right: 0;
	display: block;
	width: 160px;
	height: 50px;
	padding: 0 0 0 10px;
	transition: all .3s ease;
	text-align: left;
	border-radius: 3px 0 0 3px;
	background: rgba(255, 255, 255, .8);
}

.block-home-other a span:after {
	font-family: FontAwesome;
	font-size: 1.6rem;
	line-height: 1;
	position: absolute;
	top: 36%;
	right: 15px;
	display: block;
	margin-left: .5em;
	content: '\f138';
	transition: all .3s ease;
	text-align: center;
	color: #e51926;
	border-radius: 100%;
}

.block-home-other a:hover {
	opacity: .7;
}

.block-home-other a:hover span {
	color: #fff;
	background: #e51926;
}

.block-home-other a:hover span:after {
	color: #fff;
}

@media only screen and (max-width: 767px) {
	.block-home-other {
		margin-bottom: 20px;
		padding-top: 20px;
	}

	.block-home-other li {
		float: none;
		width: 100%;
		margin-bottom: 20px;
	}

	.block-home-other li:nth-child(2n+1) {
		margin-right: 0;
	}
}
