@charset "utf-8";

/************************************
 BEYOND STADIUM 2025 追加コンテンツ用CSSファイル
 2025.09.18 公開分
*************************************/

.sectionWrapper .text-red {
	color: rgb(255, 0, 0);
}
.sectionWrapper .linkList.fWrapper li:nth-of-type(1):hover , 
.sectionWrapper .linkList.fWrapper li:nth-of-type(4):hover {
	background-color: #ff0137;
	opacity: 0.7;
}
.sectionWrapper .linkList.fWrapper li:nth-of-type(2):hover , 
.sectionWrapper .linkList.fWrapper li:nth-of-type(5):hover {
	background-color: #0077c7;
	opacity: 0.7;
}
.sectionWrapper .linkList.fWrapper li:nth-of-type(3):hover , 
.sectionWrapper .linkList.fWrapper li:nth-of-type(6):hover {
	background-color: #1ea942;
	opacity: 0.7;
}
.sectionWrapper .linkList.fWrapper li:hover a {
	color: #fff;
	font-weight: 700;
}


.sectionWrapper .stadium-btn a {
	margin: 10px 0 15px;
}
.sectionWrapper .btn-line {
	margin: 30px 0 15px;
}
.sectionWrapper .btn-line.top {
	margin: 0;
}
.sectionWrapper .btn-line a img:hover {
	opacity: 0.5;
	transform: translateY(3px);
}

.sectionWrapper .stadium-btn.close a {
	white-space: nowrap;
	background-color: #aaa;
}
.sectionWrapper dl {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
.sectionWrapper dl dt {
	width: 120px;
	margin-top: 20px;
	box-sizing: border-box;
}
.sectionWrapper dl dd {
	width: calc(100% - 120px);
	margin-top: 20px;
	box-sizing: border-box;
}
.text-left {
	text-align: left;
}



#about .text-center img {
	margin-top: 20px;
}


.sectionWrapper h3 {
	width: fit-content;
	margin: 50px auto 10px 10px;
	padding: 0 5px;
	text-align: left;
	border-bottom: 3px solid #017bc6;
}
.sectionWrapper#day2 h3 {
	border-bottom: 3px solid #fe0036;
}
.sectionWrapper h4 {
	margin-top: 30px;
	margin-bottom: 5px;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.sectionWrapper h4.first {
	margin-top: 20px;
}
.sectionWrapper h4::before {
	content: "■";
	margin-right: 5px;
	color: #000;
}
.sectionWrapper .imgBox {
	margin: 0 5px;
}
.sectionWrapper .imgBox img {
	aspect-ratio: unset;
}
.sectionWrapper .name {
	margin-top: 2px;
	font-size: 12px;
	line-height: 1.5;
	text-align: center;
}


.sectionWrapper .casts , 
.sectionWrapper .text-img {
	display: flex;
}
.sectionWrapper .text-img .texts {
	width: 60%;
	margin-right: 20px;
}
.sectionWrapper .text-img.talk .texts {
	width: 30%;
	margin-right: 10px;
}
.sectionWrapper .text-img .imgs {
	width: calc(100% - 60% - 20px);
}
.sectionWrapper .text-img.talk .imgs {
	display: flex;
	width: unset;
}
.sectionWrapper .casts.dance .imgBox , 
.sectionWrapper .casts.taiken .imgBox {
	max-width: unset;
}
.sectionWrapper .host {
	margin-top: -50px;
}
.sectionWrapper .host .imgBox {
	margin-left: auto;
}

.sectionWrapper dl dd span.note::before {
	content: '※';
}
.sectionWrapper dl dd span.note {
	display: block;
	padding: 0 0 0 1rem;
	text-indent:-1em;
}

.sectionWrapper ul {
  list-style: none;
}
.sectionWrapper ul li {
  position: relative;
  padding-left: 1.5rem;
}
.sectionWrapper ul li::before {
  content: '・';
  position: absolute;
  left: 0;
}
.sectionWrapper ol {
  list-style: none;
  counter-reset: number;
  font-size: 0.8em;
  line-height: 26px;
}
.sectionWrapper ol li {
  position: relative;
  padding-left: 2.5rem;
}
.sectionWrapper ol li::before {
  counter-increment: number;
  content: '（' counter(number) '）';
  position: absolute;
  left: -10px;
}
.sectionWrapper#boccia h2 img {
	width: 50%;
}



/* タブレット用
-------------------------------------------------------------------------------------------------------------*/
@media (max-width: 767px) {
	.sectionWrapper p , 
	.sectionWrapper .casts , 
	.sectionWrapper .text-img {
		width: 95%;
		margin-right: auto;
		margin-left : auto;
	}
	
	.sectionWrapper .btn-line a img {
		width: 50%;
	}
}



/* スマホ用
-------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 480px) { /* 480px以下に適用されるCSS */
	.sectionWrapper h4 {
		margin: 20px 10px 0;
		padding-left: 1rem;
		text-indent: -1rem;
	}
	.sectionWrapper h4.first {
		margin-top: 10px;
	}
	
	.sectionWrapper td, .sectionWrapper li {
		font-size: 12px;
		line-height: 21px;
	}
	
	.sectionWrapper .btn-line a img {
		width: 80%;
	}
	
	.sectionWrapper dl dt {
		width: 90px;
		margin-top: 10px!important;
	}
	.sectionWrapper dl dd {
		width: calc(100% - 90px);
		margin-top: 10px!important;
	}
	
	.sectionWrapper ul li {
		padding-left: 1.0rem;
	}
	
	.sectionWrapper .text-img {
		display: block;
	}
	.sectionWrapper .text-img .texts , 
	.sectionWrapper .text-img.talk .texts , 
	.sectionWrapper .text-img .imgs {
		width: 100%;
	}
	.sectionWrapper .text-img .imgs {
		text-align: center;
	}
	.sectionWrapper .text-img .imgs img {
		width: 80%;
		margin: 10px 0 0;
	}
	.sectionWrapper .casts {
		flex-wrap: wrap;
	}
	.sectionWrapper .casts .imgBox {
		width: 30%;
	}
	.sectionWrapper .casts.taiken .imgBox {
		width: 45%;
	}
	.sectionWrapper .casts.taiken .imgBox:nth-of-type(3) , 
	.sectionWrapper .casts.taiken .imgBox:nth-of-type(4) {
		margin-top: 10px;
	}
	
	.sectionWrapper .host {
		margin-top: 0px;
	}
	.sectionWrapper .host .imgBox {
		margin: 10px auto 0;
	}
}
