@charset "utf-8";
/*------------------------------------------------------------
	l-lens
------------------------------------------------------------*/
.main-visual {
	position: relative;
	background-color: #000;
}
.main-visual-item {
	vertical-align: top;
	position: relative;
}
.main-visual .photo {
	margin: 0 auto;
	max-width: 1400px;
	height: 570px;
	overflow: hidden;
}
.main-visual .photo02 {
	max-width: inherit;
}
.main-visual .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center bottom;
}
.main-visual .text {
	padding: 0 0 0 2px;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	left: 0;
	top: 0;
	box-sizing: border-box;
}
.mv-dots .com-dots {
	padding: 0;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: -25px;
}
.main-visual .text-box {
	margin-top: -7px;
	max-width: 1000px;
	padding-left: 20px;
	display: block;
	top: 50%;
	left: 50%;
	height: auto;
	color: #fff;
	font-feature-settings: "palt";
	transform: translate(-50%,-50%);
	box-sizing: border-box;
}
.main-visual .text-box p {
	margin-bottom: 35px;
	font-size: 3rem;
	line-height: 1.35;
	font-weight: bold;
}
.main-visual .text-box .ttl {
	margin-bottom: 20px;
	font-size: 3.6rem;
	letter-spacing: 0.06em;
}
.main-visual .text-box .ttl span {
	color: #faf494;
}
.main-visual .text-box .btn a {
	padding: 10px 0;
	max-width: 37.6rem;
	display: block;
	font-size: 2.4rem;
	font-weight: 700;
	border-bottom: 2px solid #cc0000;
}
.main-visual .text-box .btn a span {
	padding-right: 38px;
	display: inline-block;
	background: url(../img/common/icon-arrow01.png) no-repeat right 1.1rem;
}
.main-visual .text-box02 {
	margin-top: -10px;
	display: flex;
	justify-content: flex-end;
}
.main-visual .text-box02 .sub {
	width: 370px;
}
.main-visual .text-box02 .logo {
	margin-bottom: 47px;
}
.news {
	padding: 70px 0 45px;
	background-color: #2c2c2c;
}
.news .news-list li {
	margin-bottom: 4px;
	display: flex;
	gap: 0 20px;
}
.news .news-list li:last-child {
	margin-bottom: 0;
}
.news .news-list .ttl {
	letter-spacing: 0.08em;
}
.news .news-list .ttl a {
	text-decoration: underline;
}
.news .news-list .date {
	letter-spacing: 0.08em;
}
#conts .body .link-list {
	padding: 0 10px 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	background-color: #2c2c2c;
}
#conts .body .link-list > li {
	margin-bottom: 10px;
	position: relative;
	width: 100%;
	cursor: pointer;
}
/*#conts .body .link-list > li:before {
	content: "";
	display: block;
	position: absolute;
	width: 3px;
	z-index: 1;
	background-color: #b90000;
	box-shadow: 0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000;
	left: 0;
	bottom: 0;
}
#conts .body .link-list > li:after {
	content: "";
	display: block;
	position: absolute;
	height: 3px;
	background-color: #b90000;
	box-shadow: 0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000;
	left: 0;
	top: 0;
}
*/
#conts .body .link-list > li:last-child {
	margin-bottom: 0;
}
#conts .body .link-list li .photo {
	position: relative;
}
/*
#conts .body .link-list li .photo:before {
	content: "";
	display: block;
	position: absolute;
	width: 3px;
	z-index: 1;
	background-color: #b90000;
	box-shadow: 0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000;
	right: 0;
	top: 0;
}
#conts .body .link-list li .photo:after {
	content: "";
	display: block;
	position: absolute;
	height: 3px;
	background-color: #b90000;
	box-shadow: 0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000,0 0 6px #b90000;
	right: 0;
	bottom: 0;
}
*/
#conts .body .link-list li .photo .photo {
	height: 320px;
	position: relative;
	overflow: hidden;
	background-color: #000;
}
#conts .body .link-list li .photo .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#conts .body .link-list li .text {
	padding: 7px 10px 30px 0;
	width: 60%;
	max-width: 830px;
	top: 50%;
	font-weight: bold;
	transform: translateY(-50%);
	display: flex;
	align-items: flex-end;
	position: absolute;
	border-bottom: 2px solid #b90000;
	right: 0;
	box-sizing: border-box;
}
#conts .body .link-list li:nth-child(2n) .text {
	justify-content: flex-end;
}
#conts .body .link-list li .text-l {
	justify-content: flex-start !important;
}
#conts .body .link-list li .text-r {
	justify-content: flex-end !important;
}
#conts .body .link-list li .text .ttl {
	margin: 0 25px -8px 0;
	font-size: 3.2rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	font-feature-settings: "palt";
}
#conts .body .link-list li .text .ttl:last-child {
	margin-right: 0;
}
#conts .body .link-list li .text .ttl a {
	display: inline-block;
	position: relative;
	padding-right: 28px;
	letter-spacing: 0.04em;
}
#conts .body .link-list li .text .ttl a::before {
	margin: 3px 0 0;
	width: 12px;
	height: 15px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	background: url(../img/common/icon-arrow01.png) no-repeat center / 100%;
	content: "";
}
#conts .body .link-list li .text .list {
	margin-top: -10px;
	font-size: 1.2em;
}
#conts .body .link-list li .text .list a {
	color: #aaa;
	line-height: 1.65;
	letter-spacing: 0.02em;
	padding-left: 1em;
	text-indent: -1em;
	display: inline-block;
}
#conts .body .link-list li.reverse .text {
	right: auto;
	left: 0;
	padding-left: 10px;
}
#conts .body .link-list li .text > div {
	width: 100%;
	display: flex;
	align-items: flex-end;
}
#conts .body .link-list li.reverse .text > div {
	justify-content: flex-end;
}
#conts .body .link-list li .text02 {
	padding-top: 40px;
}
#conts .body .link-list .wid01 {
	margin-bottom: 0;
	width: calc((100% - 10px)/2);
}
#conts .body .link-list .wid01 .text {
	top: 57%;
	width: 51%;
}
#conts .body .link-list .wid01.reverse .text {
	padding-right: 0;
}
.animate {
	padding: 91px 0 95px;
	background: linear-gradient(to top, #2c2c2c, #000);
}
.animate .link-box {
	margin-bottom: 16px;
}
.animate .link-box .slick-list {
	overflow: visible;
}
.animate .link-box .slick-slide {
	margin: 0 50px;
}
.animate .link-box .link-item {
	width: 470px !important;
}
.animate .link-box .link-item .iframe {
	margin-bottom: 9px;
	width: 470px;
	height: 264px;
	box-sizing: border-box;
	border: 1px solid #eaeaea;
}
.animate .link-box .link-item .iframe iframe {
	width: 100%;
	height: 100%;
}
.animate .link-box .link-item p {
	display: flex;
	justify-content: center;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.8rem;
	letter-spacing: 0.08em;
}
.animate .link-box .link-item p small {
	font-size: 1.6rem;
	line-height: 1.8rem;
}
.animate .animate-dots .com-dots {
	padding: 14px 0 0;
	background-color: transparent;
}
@media all and (max-width: 1200px) {
	#conts .body .link-list li .text .ttl {
		font-size: 2.833vw;
	}
	#conts .body .link-list li .text .list {
		margin-top: 0;
		font-size: 1.333vw;
	}
	#conts .body .link-list li .text {
		padding-bottom: 1.5vw;
	}
}
@keyframes move1 {
	0% {
		height: 100%;
		bottom: 0;
	}
	54% {
		height: 0;
		bottom: 100%;
	}
	55% {
		height: 0;
		bottom: 0;
	}
	100% {
		height: 100%;
		bottom: 0;
	}
}
@keyframes move2 {
	0% {
		width: 0;
		left: 0;
	}
	50% {
		width: 100%;
		left: 0;
	}
	100% {
		width: 0;
		left: 100%;
	}
}
@keyframes move3 {
	0% {
		height: 100%;
		top: 0;
	}
	54% {
		height: 0;
		top: 100%;
	}
	55% {
		height: 0;
		top: 0;
	}
	100% {
		height: 100%;
		top: 0;
	}
}
@keyframes move4 {
	0% {
		width: 0;
		right: 0;
	}
	55% {
		width: 100%;
		right: 0;
	}
	100% {
		width: 0;
		right: 100%;
	}
}
@media all and (min-width: 768px) {
	.news .news-list .ttl a:hover {
		text-decoration: none;
		opacity: 1;
	}
	#conts .body .link-list li .photo:hover {
		opacity: 1;
	}
	#conts .body .link-list li .photo .photo img {
		transition: 0.3s ease;
	}
	#conts .body .link-list li .photo:hover .photo img {
		transform: scale(1.05);
	}
	#conts .body .link-list > li:hover:before {
		animation: move1 1500ms infinite ease;
	}
	#conts .body .link-list > li:hover:after {
		animation: move2 1500ms infinite ease;
	}
	#conts .body .link-list li:hover .photo:before {
		animation: move3 1500ms infinite ease;
	}
	#conts .body .link-list li:hover .photo:after {
		animation: move4 1500ms infinite ease;
	}
	#conts .body .link-list li .text.wid01 {
		max-width: 900px;
		width: 63%;
	}
	#conts .body .link-list li .text .ttl a:hover,#conts .body .link-list li .text .list a:hover {
		opacity: 1;
		color: #b90000;
	}
}
@media all and (max-width: 767px) {
	.main-visual .photo {
		height: auto;
		aspect-ratio: 375/515;
	}
	.main-visual .text h2 {
		width: 43.2vw;
		min-width: 162px;
		aspect-ratio: 162/199;
	}
	.main-visual .text {
		padding: 0 0 24px;
	}
	.main-visual .text-box {
		width: 100%;
		top: 5.4%;
		left: 0;
		transform: translate(0);
		padding: 0 20px;
		text-align: center;
	}
	.main-visual .text-box p {
		margin-bottom: 6px;
		font-size: 1.8rem;
	}
	.main-visual .text-box .ttl {
		margin-bottom: 5px;
		font-size: 2rem;
	}
	.main-visual .text-box .btn a {
		padding: 4px;
		max-width: 188px;
		margin: 0 auto;
		font-size: 1.5rem;
		text-align: left;
		border-width: 1px;
		box-sizing: border-box;
	}
	.main-visual .text-box .btn a span {
		background-size: 9px auto;
		background-position: right top 6px;
	}
	.main-visual .text-box02 {
		top: 10%;
		justify-content: center;
	}
	.main-visual .text-box02 .sub {
		width: auto;
	}
	.main-visual .text-box02 .logo {
		margin: 0 auto 25px;
		width: 220px;
	}
	.main-visual .text-box02 .btn a {
		font-size: 1.4rem;
	}
	.main-visual .text-box02 .btn a span {
		padding-right: 28px;
	}
	.news {
		padding-bottom: 25px;
	}
	.news .content {
		padding: 0 19px;
	}
	.news .news-list li {
		margin-bottom: 9px;
		font-size: 1.6rem;
		line-height: calc(42/32);
		gap: 0 28px;
	}
	.news .news-list .date,
	.news .news-list .ttl {
		letter-spacing: 0.08em;
	}
	#conts .body .link-list li .photo {
		width: 100%;
		height: auto;
		aspect-ratio: 712/350;
		overflow: hidden;
	}
	#conts .body .link-list li .photo img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	#conts .body .link-list li .text {
		padding: 0 0 10px;
		flex-wrap: wrap;
		width: calc(50% + 92px);
		border-bottom-width: 1px;
	}
	#conts .body .link-list li .text .ttl {
		margin: 0 10px 5px 0;
		font-size: 2.2rem;
	}
	#conts .body .link-list li .text .ttl:last-child {
		margin-bottom: 0;
	}
	#conts .body .link-list li .text .ttl a {
		padding-right: 15px;
	}
	#conts .body .link-list li .text .ttl a::before {
		margin-top: 1px;
		width: 8px;
		height: 10px;
	}
	#conts .body .link-list li .text .list {
		font-size: 1rem;
		width: 100%;
		background:  rgba(0,0,0,0.4);
	}
	#conts .body .link-list li .text .list li a {
		line-height: 1.4;
	}
	#conts .body .link-list .reverse .text {
		width: calc(50% + 35px);
	}
	/* #conts .body .link-list li .text01 {
		width: calc(50% + 110px) !important;
	}
	#conts .body .link-list li .text01 .ttl {
		margin-right: 0;
	}
	#conts .body .link-list li .text01 .list {
		min-width: 245px;
	} */
	#conts .body .link-list li .text > div {
		width: auto;
		display: block;
	}
	#conts .body .link-list li.reverse .text02 {
		width: calc(50% + 135px);
		padding-bottom: 7px;
	}
	#conts .body .link-list .wid01 {
		width: calc((100% - 6px)/2);
	}
	#conts .body .link-list .wid01 .photo {
		aspect-ratio: 35/32;
	}
	#conts .body .link-list .wid01 .text {
		width: calc(100% - 10px);
		padding-bottom: 6px;
		top: 46%;
	}
	#conts .body .link-list .wid01 .text .ttl a {
		font-size: 1.7rem;
		letter-spacing: 0;
	}
	.animate {
		padding: 44px 0 52px;
	}
	.animate .link-box .link-item p {
		margin: 0 -20px;
		font-size: 1.4rem;
		line-height: calc(21/16);
		text-align: center;
	}
	.animate .link-box .link-item {
		width: 50.133vw !important;
	}
	.animate .link-box {
		margin-bottom: 6px;
	}
	.animate .link-box .link-item .iframe {
		margin-bottom: 8px;
		width: 100%;
		height: 28.3vw;
	}
	.animate .link-box .slick-slide {
		margin: 0 25px;
	}
	.animate .animate-dots .com-dots {
		gap: 0 44px;
	}
	.main-visual .photo img {
		object-position: center;
	}
}
@media all and (max-width: 374px) {
	#conts .body .link-list li .text {
		width: calc(50% + 60px);
	}
}