@charset "utf-8";

.content-title {
	text-align: center;
}
.news-list li:first-child::after,.news-list li::before,.note-list tbody:first-child::after,.note-list tr::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 2px;
	background: linear-gradient(
		to right,
		var(--color-orange)        0%, var(--color-orange)     14.2%,
		var(--color-blue)       14.2%, var(--color-blue)       28.4%,
		var(--color-green)      28.4%, var(--color-green)      42.6%,
		var(--color-purple)     42.6%, var(--color-purple)     56.8%,
		var(--color-light-blue) 56.8%, var(--color-light-blue)   71%,
		var(--color-pink)         71%, var(--color-pink)       85.2%,
		var(--color-red)        85.2%, var(--color-red)         100%
  );
}
#introduction,#news,#movie,#about {
	padding-top: 100px;
}
/* _____ 835px 以上 _____ */
@media (min-width: 835px) {
	#introduction,#news,#movie,#about {
		padding-top: 240px;
	}
}


.top-bg {
	background: linear-gradient(0deg, rgba(255, 255, 255, 0) 80%, rgba(212, 242, 250, 1) 100%);
	padding-bottom: 130px;
}
.content-title {
	font-size: 30px;
	margin-bottom: 20px;
}
/* _____ 835px 以上 _____ */
@media (min-width: 835px) {
	.top-bg {
		padding-bottom: 320px;
	}
	.content-title {
		font-size: 40px;
		margin-bottom: 40px;
	}
}


/*+-+-+-+-+-+-+-+-+-+-+- トップコンテンツ +-+-+-+-+-+-+-+-+-+-+-*/
#top {
	background-color: #fff;
}
.visual-box {
	background-size: cover;
	background-repeat: no-repeat;
}
.visual-content {
	position: relative;
}
.visual {
	position: relative;
}
.visual img {
	position: relative;
}
.detail-content {
	width: 95%;
	max-width: 650px;
	margin: auto;
	text-align: center;
	/* 500=100／834=200 */
	padding-bottom: clamp(6.25rem, -3.106rem + 29.94vw, 12.5rem);
}
.top-place {
	width: 75%;
	margin: auto;
	max-width: 550px;
	padding-top: 24px;
}
.topics {
	width: 75%;
	margin: auto;
	padding-top: 30px;
}

/* _____ 834px 以下 _____ */
@media not (min-width: 835px) {
	.visual-box {
		background-image: url(/2025/images/top/top-bg-sp.webp);
		background-position: bottom;
	}
	.visual {
		max-width: 650px;
    margin: auto;
	}
	.detail-content {
		/* 500=32／834=56 */
		padding-top: clamp(2rem, -0.246rem + 7.19vw, 3.5rem);
	}
}
/* _____ 835px 以上 _____ */
@media (min-width: 835px) {
	#top {
		padding-top: 82px;
	}
	.visual-box {
		padding-bottom: 40px;
		background-image: url(/2025/images/top/top-bg.webp);
		background-position: center;
	}
	.visual-box .warp {
		display: grid;
		grid-template-columns: 1fr 1fr;
		align-items: center;
		max-width: 1920px;
		margin: auto;
	}
	.detail-content {
		max-width: 800px;
		width: 90%;
		margin: auto;
		text-align: center;
		padding-bottom: 90px;
	}
	.top-place {
		/* 835=24／1680=36 */
		padding-top: clamp(1.5rem, 0.759rem + 1.42vw, 2.25rem);
		width: 80%;
	}
	.topics {
		/* 835=45／1680=90 */
		padding-top: clamp(2.813rem, 0.033rem + 5.33vw, 5.625rem);
	}
	.topics a {
		transition: .3s ease-out;
	}
	.topics a:hover {
		opacity: .5;
	}
}
/* _____ 1600px 以上 _____ */
@media (min-width: 1680px) {
	.detail-content {
		margin: unset;
	}

}
/*+-+-+-+-+-+-+-+-+-+-+- introduction +-+-+-+-+-+-+-+-+-+-+-*/
#introduction {
	width: 85%;
	margin: auto;
	text-align: center;
	font-weight: bold;
}
#introduction .txt01 {
	margin-top: 40px;
	font-size: 15px;
	line-height: 2;
	max-inline-size: 720px;
	margin-inline: auto;
}
#introduction .txt02 {
	margin-top: 25px;
	font-size: 18px;
	line-height: 1.8;
	max-inline-size: 720px;
	margin-inline: auto;
}
/* _____ 834px 以下 _____ */
@media not (min-width: 835px) {
	#introduction .txt01,#introduction .txt02 {
		text-align: left;
		letter-spacing: 0px;
		max-width: 564px;
		margin: 40px auto 0;
	}
}
/* _____ 835px 以上 _____ */
@media (min-width: 835px) {
	#introduction .intro-img {
		max-width: 720px;
	}
	#introduction .txt01 {
		margin-top: 80px;
		font-size: 20px;
		line-height: 2.2;
	}
	#introduction .txt02 {
		margin-top: 50px;
		font-size: 24px;
		line-height: 2;
	}
}



/*+-+-+-+-+-+-+-+-+-+-+- ニュース +-+-+-+-+-+-+-+-+-+-+-*/
.news-list {
	height: 200px;
	width: 90%;
	overflow-y: auto;
	margin: auto;
	position: relative;
}
.news-list li {
	display: flex;
	flex-wrap: wrap;
	padding: 20px 0;
	position: relative;
	align-items: center;
}
.news-list li::before {
	bottom: -2px;
}
.news-list li::after {
	top: 0;
}
.news-list li .category {
	border: #0d0d0d 1px solid;
	text-align: center;
	font-size: 12px;
	padding: 0 5px 0;
}
/* _____ 834px 以下 _____ */
@media not (min-width: 835px) {
	.news-list {
		font-size: 10px;
		max-width: 650px;
	}
	.news-list li {
		flex-wrap: nowrap;
	}
	.news-list li .category {
		font-size: 10px;
	}
	.spbox {
		padding: 0 10px;
	}
	.news-list .title {
		font-size: 12px;
	}
}
/* _____ 835px 以上 _____ */
@media (min-width: 835px) {
	.news-list {
		/* height: 290px; */
		max-width: 800px;
		padding-right: 25px;
	}
	.spbox {
		display: flex;
		flex-wrap: wrap;
		margin-left: 25px;
	}
	.news-list li {
		align-items: center;
		padding: 40px 0;
	}
	.news-list li .category {
		padding: 1px 5px 0;
		margin: 0 15px 0 10px;
	}
	.news-list li .title {
		width: 65%;
		margin-right: 25px;
	}

}



/*+-+-+-+-+-+-+-+-+-+-+- ムービー +-+-+-+-+-+-+-+-+-+-+-*/
#movie {
	width: 90%;
	max-width: 650px;
	margin: auto;
}
.movie-arrows-pc,.movie-arrows-sp,.movie-img {
	position: relative;
}
.slick-arrow {
	display: inline-block;
	cursor: pointer;
}
.movie-img::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #333333;
	z-index: 0;
	transform: rotate(5deg);
}
#movie .content-title {
	margin-bottom: 20px;
}
.movie-title {
	text-align: center;
}
.movie-img {
	width: 100%;
}
/* _____ 834px 以下 _____ */
@media not (min-width: 835px) {
	.movie-arrows-sp {
		text-align: center;
		margin-top: 20px;
	}
}
/* _____ 835px 以上 _____ */
@media (min-width: 835px) {
	#movie {
		display: flex;
		max-width: 1000px;
	}
	#movie {
		flex-wrap: wrap;
		align-items: center;
	}
	.movie-title {
		width: 28%;
		font-size: 28px;
		margin-bottom: 30px;
	}
	.movie-arrows .arrows {
		margin: 0 5px;
		display: inline-block;
	}
	.movie-img {
		width: 72%;
		font-size: 0;
	}
	.slick-arrow svg {
		transition: .3s ease-out;
	}
	.slick-arrow svg:hover {
		fill: var(--color-orange);
	}
}



/*+-+-+-+-+-+-+-+-+-+-+- 開催概要 +-+-+-+-+-+-+-+-+-+-+-*/
#about {
	font-size: 0;
}
.note-list {
	width: 90%;
	max-width: 650px;
	margin: auto;
	position: relative;
}
.note-list::before {
	top: -2px;
}
.note-list li:first-child::after {
	top: -2px;
}
.note-list tr {
	position: relative;
}
.note-list tr td .note01 {
	font-weight: 400;
	font-size: 14px;
}
#about .access {
	display: flex;
	align-items: center;
	line-height: 1.2;
}
#about .access a {
	border-bottom: 1px solid #333333;
}
/* _____ 834px 以下 _____ */
@media not (min-width: 835px) {
	.note-list tr::after {
		top: 0px;
	}
	.note-list tr td {
		display: block;
		width: 90%;
		font-size: 14px;
	}
	.note-list .title {
		margin: 20px auto 10px;
	}
	.note-list .contents {
		margin: 10px auto 20px;
	}
}
/* _____ 835px 以上 _____ */
@media (min-width: 835px) {
	.note-list {
		max-width: 800px;
		font-size: 16px;
	}
	.note-list tr {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.note-list tr .title {
		padding: 30px 0;
		align-content: center;
		width: 180px;
		font-weight: bold;
	}
	.note-list tr .contents {
		padding: 30px 0;
		width: 530px;
	}
	#about .access a {
		transition: .3s ease-out;
	}
	#about .access a:hover {
		border-color: var(--color-orange);
		text-decoration: unset;
	}
	#about .access a:hover + svg {
		animation: poyon 1.1s linear 0s 1;
	}
}
