@charset "UTF-8";

/* main*/
main {
	display: none;
	position: relative;
	width: 100%;
	margin-bottom: 40px;
}

/* slick*/
.slick-container {
	width: 100%;
	margin: 0 auto;
}

.slick-initialized .slick-slide {
	padding: 0 8px;
}

.slick-initialized .slick-slide a:hover {
	opacity: 0.6 !important;
	cursor: pointer;
}

.slick-initialized .slick-slide img {
	width: 636px;
	height: auto;
}

.dots-wrap {
	display: flex;
	justify-content: center;
	margin-top: 16px;
}

.dots-wrap li {
	width: 8px;
	height: 8px;
	margin: 0 5px;
	background: #d1d1d1;
	border-radius: 50%;
	cursor: pointer;
}

.dots-wrap li:hover,
.dots-wrap li.slick-active {
	background: #d4a700;
}

.dots-wrap li button {
	display: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	outline: none;
	padding: 0;
	border: none;
	background-color: transparent;
}

.slick-dots li button:focus:before {
	opacity: 0 !important;
}

/*==== mobile スマフォ横〜用css ===*/
@media screen and (max-width: 768px) {
	.slick-initialized .slick-slide img {
		width: 300px;
	}
}

/* section01 */
#info {
	display: none;
	position: relative;
	height: 486px;
	background-image: url(../images/kv_pc.jpg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	margin-bottom: 83px;
}

#info .container {
	position: absolute;
	top: 0%;
	left: 50%;
	-webkit-transform: translate(-50%, 18%);
	transform: translate(-50%, 18%);
	text-align: center;
	font-family: "Hiragino Kaku Gothic ProN";
	width: 560px;
}

#info .mv_title {
	text-align: center;
	letter-spacing: 0.05em;
	margin-bottom: 20px;
}

#info .mv_title img {
	width: 272px;
}

#info .mv_sub_title {
	font-size: 32px;
	text-align: center;
	margin-top: 13px;
	color: #fff;
	font-weight: 600;
	line-height: 150%;
	letter-spacing: 0.05em;
}

#info .container .border {
	border: 1px solid #D4A700;
	margin: 2px;
	position: relative;
	margin: 0 auto;
	width: 476.5px;
}

#info .container .border::before {
	content: '';
	width: calc(100% + 2px);
	border: 1px solid #D4A700;
	position: absolute;
	top: -5px;
	left: -1px;
}

#info .container .read {
	max-width: 560px;
	margin: 48px auto 0;
}

#info .container .read p {
	margin-bottom: 24px;
}

#info .container .read p.notes {
	font-size: 14px;
	font-weight: 600;
	line-height: 150%;
	letter-spacing: 0.04em;
}

#info .container .mv-scroll {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	text-align: center;
}

#info .container .mv-scroll:after {
	position: absolute;
	top: 2.19rem;
	left: 50%;
	display: block;
	width: .06rem;
	margin-left: -.03rem;
	content: "";
}

#info .container .mv-scroll:after {
	height: 50px;
	background-color: #D4A700;
}

/*==== mobile スマフォ横〜用css ===*/
@media screen and (max-width: 768px) {
	#info {
		position: relative;
		background-image: url(../images/kv_sp.jpg);
		padding-bottom: 0px;
		height: 558px;
		margin-bottom: 85px;
	}

	#info .container {
		top: 0;
		left: calc(50% - 20px);
		-webkit-transform: translate(-50%, 14%);
		transform: translate(-50%, 14%);
		margin: 0 20px;
		width: 100%;
	}

	#info .container .mv_title {
		margin-bottom: 23px;
	}

	#info .container .mv_title img {
		width: 218px;
	}

	#info .container .mv_sub_title {
		font-style: normal;
		font-weight: 600;
		font-size: 24px;
		margin-top: 15px;
		margin-bottom: 15px;
	}

	#info .container .border {
		width: 307.5px;
	}

	#info .container .read {
		width: 335px;
		margin-bottom: 30px;
	}

	#info .container .read p {
		font-size: 16px;
		text-align: left;
	}

	#info .container .read p.notes {
		text-align: center;
		margin-bottom: 0;
	}
}

@media screen and (max-width: 334px) {
	#info .container .read {
		max-width: 300px;
	}
}

/* section02 */
#event {
	background: #000;
	color: #fff;
	padding-top: 25px;
	padding-bottom: 82px;
}

#event h2 {
	display: block;
	/* text-align: center; */
	margin-bottom: 62px;
	font-family: var(--font_nobel);
	font-style: normal;
	font-weight: 200;
	font-size: 40px;
	line-height: 45px;
	text-align: center;
	letter-spacing: 0.2em;
	color: var(--gold);
}

#event h2 img {
	max-width: 149px;
	height: auto;
	opacity: 0.5;
}

#event .event_container {
	position: relative;
	height: 640px;
	background-image: url(../images/section01_bg.jpg);
	background-size: cover;
	background-position: center;
	max-width: 1440px;
	background-repeat: no-repeat;
	margin: 0 auto;
}

#event .event_title_container {
	padding-top: 40px;
}

#event .event_title_container h5 {
	position: relative;
	display: block;
	padding: 18px;
	color: #fff;
	font-family: var(--font_hiragino);
	line-height: 150%;
	letter-spacing: 0.04em;
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

#event .event_title_container h5:before {
	position: absolute;
	display: block;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

#event .event_title_container h5:after {
	position: absolute;
	display: block;
	top: 4%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

#event .event_title_container p {
	font-weight: 600;
	font-size: 28px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.04em;
	font-family: var(--font_hiragino);
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

#event .event_information_container {
	margin: 0 auto;
	margin-top: -53px;
	position: relative;
	z-index: 10;
	max-width: 668px;
	text-align: center;
	font-family: var(--font_hiragino);
}

.event_information_container .btn_red {
	margin-top: 33px !important;
	max-width: 435px;
}

.event_information_container .btn_red a {
	padding: 24px;
	font-size: 20px;
}

#event .event_information_container .information_title {
	margin: 0 0 59px;
}

#event .event_information_container .information_title h3 {
	font-style: normal;
	font-weight: 600;
	color: #fff;
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
	letter-spacing: 0.04em;
	display: flex;
	align-items: center;
}

#event .event_information_container .information_title h3:before,
#event .event_information_container .information_title h3:after {
	content: "";
	height: 1px;
	flex-grow: 1;
	background-color: #D4A700;
}

#event .event_information_container .information_title h3:before {
	margin-right: 1.1rem;
}

#event .event_information_container .information_title h3:after {
	margin-left: 1.1rem;
}

#event .event_information_container .information_texts ul,
#event .event_information_container .information_texts li,
#event .event_information_container .information_schedule p {
	font-style: normal;
	font-weight: 600;
	font-size: 14px;
	line-height: 150%;
	font-family: var(--font_hiragino);
}

#event .event_information_container .information_texts li:nth-child(2) {
	font-style: normal;
	font-size: 16px;
	line-height: 1.5;
}

#event .event_information_container .information_texts ul:nth-child(2) {
	padding: 8px 0;
}

#event .event_information_container .information_schedule p {
	padding-bottom: 8px;
}

#event .event_information_container .information_schedule {
	padding-bottom: 45px;
}

#event .event_information_container .information_schedule table {
	background-color: #fff;
	color: #000;
	font-family: var(--font_hiragino);
	font-style: normal;
	font-weight: 600;
	font-size: 12px;
	line-height: 150%;
	letter-spacing: 0.04em;
	margin: 0 auto;
}

#event .event_information_container .information_schedule table .schedule_date {
	background-color: #826700;
	color: #fff;
	border: solid 2px #000;
	padding: 6px 15px;
	text-align: right;
}

#event .event_information_container .information_schedule table .schedule_title {
	background-color: #fff;
	color: #000;
	border: solid 2px #000;
	padding: 6px 15px;
}

#event .event_information_container h1 {
	font-style: normal;
	font-weight: 600;
	color: #D4A700;
	font-family: var(--font_hiragino);
	font-size: 32px;
	padding-bottom: 15px;
	display: block;
}

@media (max-width:768px){
	#event .event_information_container h1 {
			font-size: 24px;
		}
}
#event .event_notice_container h1 {
	font-style: normal;
	font-weight: 600;
	color: #D4A700;
	font-family: var(--font_hiragino);
	font-size: 32px;
	padding-bottom: 15px;
	display: block;
}

@media (max-width:768px){
	#event .event_notice_container h1 {
			font-size: 24px;
		}
				#event .event_notice_container .note {
					padding: 0 20px;
					text-align: left;
				}
}

#event .event_notice_container p{
	
		font-family: var(--font_hiragino);
		font-style: normal;
		font-weight: 300;
		font-size: 16px;
		line-height: 175%;
		/* ボックスの高さと同一、または28px */
		letter-spacing: 0.04em;
		text-indent: -1rem;
		margin-left: 1rem;
	
		color: #FFFFFF;
	
}
#event .event_information_container .note {
	padding: 11px 0;
	border-top: 1px solid var(--gold);
	border-bottom: 1px solid var(--gold);
	max-width: 561px;
	margin: 13px auto;
}
#event .event_information_container .note p{
	font-style: normal;
	font-weight: 600;
	font-size: 24px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.04em;

	color:var(--white);

}

#event .event_information_container .btn {
	margin-top: 16px;
}

#event .event_information_container .information_texts p {
	font-weight: 300;
	font-size: 16px;
	line-height: 175%;
	text-align: left;
	max-width: 480px;
	margin: 0 auto;
}

#event .event_information_container .information_artist_container {
	margin-bottom: 61px;
}

#event .event_information_container .information_artist_container .information_artist_area {
	display: flex;
	flex-direction: column;
	width: 100%;
	margin-bottom: 58px;
}

.information_artist {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	align-items: flex-start;
	background: linear-gradient(180deg, #DCBFA7 0%, #FFF8E7 100%);
	padding: 15px 16px;
	margin-bottom: 42px;
}
.information_artist:last-child {
	max-width: 468px;
	margin: 0 auto;
}

.information_artist-img {
	width: 150px;
	height: auto;
	flex-shrink: 0;
}

.information_artist-content {
	flex: 1;
	min-width: 200px;
}

.information_artist-title {
	margin: 0 0 10px;
	font-size: 1.5rem;
}

.information_artist-text {
	margin: 0;
	font-size: 1rem;
	line-height: 1.5;
}

#event>div.event_information_container>div>div.information_artist_container>div>div:nth-child(6)>p{
	margin-top: 0;
}



#event .event_information_container .information_artist_container .information_artist-img {
	max-width: 166px;
	width: 100%;
}

#event .event_information_container .information_artist_container .information_artist:last-child .information_artist-img {
	max-width: 431px;
}

#event .event_information_container .information_artist_container h2.information_artist-title {
	color: var(--dark_gold);
	padding: 9px 0 12px;
	margin: 0;
	font-size: 24px;
	line-height: 1;
	font-family: var(--font_hiragino);
	font-weight: 600;
	letter-spacing: 0.96px;
	text-align: left;
	border-bottom: solid 1px;
}
#event .event_information_container .information_artist_container .information_artist:last-child h2.information_artist-title {
	text-align: center;
	width: 100%;
}
#event .event_information_container .information_artist_container h2.information_artist-title>span {
	font-size: 16px;
	font-family: var(--font_hiragino);
	font-style: normal;
	font-weight: 600;
	line-height: 150%;
	letter-spacing: 0.04em;
}

#event .event_information_container .information_artist_container p.information_artist-text {
	text-align: left;
	font-style: normal;
	font-weight: 300;
	font-size: 16px;
	line-height: 175%;
	letter-spacing: 0.04em;
	color: var(--black);
	margin-top: 15px;
}


#event .event_information_container .information_artist_container .other_artists {
	max-width: 668px;
	border-top: 1px solid #D4A700;
	border-bottom: 1px solid #D4A700;
	padding: 11px;
}

#event .event_information_container .information_artist_container .other_artists h4 {
	color: #fff;
}
/* スマホ時（幅768px以下）で縦並びに変更 */
@media (max-width: 500px) {
	.information_artist {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.information_artist {
		gap: 1px;
	}

	#event .event_information_container .information_artist_container h2.information_artist-title {
		text-align: center;
	}

	.information_artist-img {
		margin-bottom: 10px;
	}
#event>div.event_information_container>div>div.information_artist_container>div>div:nth-child(6)>p{
	margin-top: 15px;
}
	.information_artist-content {
		width: 100%;
	}

	.information_artist:last-child {
		width: 100%;
		margin: 0 auto;
	}
}
/*==== mobile スマフォ横〜用css ===*/
@media screen and (max-width: 768px) {
	#event {
		padding-bottom: 103px;
	}

	#event h2 {
		margin-bottom: 87px;
	}

	#event .event_information_container {
		width: 100%;
		padding: 0 20px;
	}

	#event .event_information_container .event_information_inner {
		/* max-width: 335px; */
		margin: 0 auto;
	}

	#event .event_information_container .information_artist_container {
		margin-bottom: 65px;
	}

	#event .event_information_container .information_artist_container .information_artist_area {
		display: block;
		margin-bottom: 80px;
	}

	/* #event .event_information_container .information_artist_container .information_artist {
		width: 100%;
		margin-bottom: 40px;
	}

	#event .event_information_container .information_artist_container .information_artist:nth-child(n+5) {
		width: 100%;
		margin-bottom: 40px;
	} */

	/* #event .event_information_container .information_artist_container p.information_artist-text {
		margin: 0 16px;
	} */

	/* #event .event_information_container .information_artist_container .information_artist:nth-child(2n) {
		margin-left: 0;
	} */

	/* #event .event_information_container .information_artist_container .information_artist-img {
		width: 50%;
	} */

	/* #event .event_information_container .information_artist_container .information_artist:last-child .information_artist-img {
		width: 100%;
		padding: 0 16px;
	} */

	/* #event .event_information_container .information_artist_container .other_artists {
		max-width: 335px;
		padding: 11px 0;
	} */

	#event .event_information_container .information_texts ul:nth-child(2) {
		padding-top: 5px;
	}

	#event .event_information_container .information_artist_container h2.information_artist-title>span {
		display: inline-block;
	}
}

/* section03 */
.history {
	position: relative;
	padding-top: 81px;
	background-image: url(../images/section02_bg_2.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	padding-bottom: 52px;
	font-family: var(--font_hiragino);
	margin-bottom: 107px;
}

.history .history_title_container {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
}

.history .history_title_container h2 {
	position: relative;
	display: block;
	padding: 20px 0;
	color: #fff;
	font-family: var(--font_hiragino);
	width: 280px;
}

.history .history_title_container h2:before {
	position: absolute;
	display: block;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

.history .history_title_container h2:after {
	position: absolute;
	display: block;
	top: 4%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

.history .history_title_container h1 {
	font-style: normal;
	font-weight: 600;
	color: #D4A700;
	font-family: var(--font_hiragino);
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

.history .history_container p {
	margin: 37px 0 0;
}
.history .history_caption p{
	font-size: 14px;
}
.history .history_schedule_container {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 39px;
}

.history .history_schedule_container_inner {
	width: 1090px;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	gap: clamp(16px, 5vw, 40px);
	padding: 0 16px;
}

.history_schedule_l,
.history_schedule_m,
.history_schedule_r {
	flex:1;
	display: flex;
	flex-direction: column;
}
.history_schedule_img {
	margin-top: auto;
}

.history_container .history_schedule_container h5 {
	display: block;
	width: 100%;
	line-height: 1;
	font-family: var(--font_nobel);
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	padding: 16px 0 13px;
}

.history_container .history_schedule_container span {
	font-size: 23px;
}

.history_container .history_schedule_container p {
	margin: 16px 0 11px;
}

.history_container .history_schedule_container_inner>div {
	max-width: 311px;
}

.history_container .history_schedule_container table {
	width: calc(100% + 6px);
	margin-left: -3px;
	margin-right: -3px;
	border-spacing: 3px;
	border-collapse: separate;
}

.history_container .history_schedule_container th {
	font-family: var(--font_hiragino);
	font-style: normal;
	font-weight: 600;
	font-size: 12px;
	/* line-height: 150%; */
	text-align: center;
	padding: 5px;
}

.history_container .history_schedule_container th:nth-of-type(1) {
	width: 60%;
}

.history_container .history_schedule_container .history_schedule_l h5,
.history_container .history_schedule_container .history_schedule_l th {
	background-color: #674500;
}

.history_container .history_schedule_container .history_schedule_m h5,
.history_container .history_schedule_container .history_schedule_m th {
	background-color: #4C5900;
}
.history_container .history_schedule_container .history_schedule_r h5,
.history_container .history_schedule_container .history_schedule_r th {
	background-color: var(--aqua);
}

.history_container .history_schedule_container td {
	color: #000;
	background-color: #fff;
	text-align: center;
	font-family: var(--font_hiragino);
	font-style: normal;
	font-weight: 600;
	font-size: 13px;
	line-height: 1;
	padding: 9px 0;
}
.history_container .history_schedule_container td:nth-of-type(1) {
	background-color: #ececec;
}


.history_container .history_schedule_container_inner .history_schedule_img img {
	padding: 22px 0 0;
	max-width: 233px;
}

/*==== mobile スマフォ横〜用css ===*/
@media screen and (max-width: 768px) {
	.history {
		padding-top: 81px;
	}

		.history .history_container .history_lead p {
			text-align: left;
			padding: 0 10%;
		}

.history .history_schedule_container_inner {
	width: 100%;
	max-width: 311px;
	gap: 0;
	flex-direction: column;
	padding: 0;
}
		.history_container .history_schedule_container_inner>div{
			width: 311px;
		}

	.history_schedule_m,
		.history_schedule_r {
		margin-top: 65px;
	}

		.history .history_container .history_caption p {
			font-size: 14px;
		}
}

/* section04 */
.circuit {
	position: relative;
	padding-top: 20.8%;
	background-image: url(../images/section03_bg.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	margin-bottom: 80px;
}

.circuit .circuit_title_container {
	padding-top: 8px;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 300px;
}

.circuit .circuit_title_container h2 {
	position: relative;
	display: block;
	padding: 20px 0;
	color: #fff;
	font-family: var(--font_hiragino);
}

.circuit .circuit_title_container h2:before {
	position: absolute;
	display: block;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

.circuit .circuit_title_container h2:after {
	position: absolute;
	display: block;
	top: 4%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

.circuit .circuit_title_container h1 {
	font-style: normal;
	font-weight: 600;
	color: #D4A700;
	font-family: var(--font_hiragino);
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

/*==== mobile スマフォ横〜用css ===*/
@media screen and (max-width: 768px) {
	.circuit {
		padding-top: 80%;
		margin-bottom: 80px;
	}
}

/* section05 */
#experience {
	position: relative;
	background: #000;
	margin: 0;
	height: 1272px;
	padding-top: 72px;
	background-image: url(../images/section04_bg.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

#experience .experience_title_container {
	position: relative;
	margin: 0 20px;
	font-family: var(--font_hiragino);
}

#experience .experience_title_container h2 {
	position: relative;
	display: block;
	padding: 16px;
	color: #fff;
}

#experience .experience_title_container h2:before {
	position: absolute;
	display: block;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

#experience .experience_title_container h2:after {
	position: absolute;
	display: block;
	top: 4%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	/* Safari用 */
	transform: translate(-50%, -50%);
	width: 35px;
	height: 1px;
	content: '';
	background: #D4A700;
}

#experience .experience_title_container h5 {
	color: #D4A700;
}

#experience .experience_title_container .experience_subtitle {
	max-width: 332px;
	border-top: 1px solid #D4A700;
	border-bottom: 1px solid #D4A700;
	padding: 16px;
	margin: 40px auto 70px;
}

#experience .experience_title_container .experience_subtitle p {
	color: #fff;
}

#experience .experience_container {
	margin: 0 20px;
}

#experience .experience_container .item {
	max-width: 728px;
	margin: 0 auto;
}

/*==== mobile スマフォ横〜用css ===*/
@media screen and (max-width: 768px) {
	#experience {
		padding-top: 72px;
	}

	#experience .btn {
		margin-top: 40px;
	}
}

@media screen and (min-width: 320px) and (max-width:600px) {
	#experience {
		height: 1245px;
	}
}

#experience .date {
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: bold;
	text-align: center;
	position: relative;
	width: 100px;
	margin: 0 auto 8px;
	color: #D4A700;
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 150%;
	letter-spacing: 0.1em;
}

#experience .date::before,
#experience .date::after {
	position: absolute;
	content: '';
	bottom: 0;
	width: 1px;
	height: 40px;
	background-color: #D4A700;
}

#experience .date::before {
	left: 0;
	transform: rotate(45deg)
}

#experience .date::after {
	left: 4px;
	transform: rotate(45deg)
}

#experience h3 {
	display: block;
	color: #D4A700;
	font-family: var(--font_hiragino);
}


#experience .experience_container .item .movie {
	padding-top: 16px;
	padding-bottom: 25px;
}

#experience .experience_container .item iframe {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
}

#experience .experience_container .item p {
	text-align: left;
}