@charset "utf-8";
/* CSS Document */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500&display=swap');

#bos {
	font-family: 'Noto Sans JP', sans-serif;
}

body, h1, h2, h3, h4, h5, ul, li, dl, dt, dd, p {
	margin: 0;
	padding: 0;
}

#bos img {
	border: none;
	vertical-align: bottom;
}

#bos ul {
	list-style: none;
}

#bos a {
	transition: opacity 0.3s;
	backface-visibility: hidden;
}

#bos a:hover {
	opacity: 0.6;
}

#bos .sp_br {
	display: none;
}

#bos .bg_grad {
	background: linear-gradient(70deg, #41bfd5, #8451d7);
}

#bos .cnt_inner {
	width: 1000px;
	margin: 0 auto;
}

#bos .f_neuzeit {
	font-family: neuzeit-grotesk, sans-serif;
	font-weight: 900;
	font-style: normal;
}

#bos #main_visual {
	position: relative;
	height: 570px;
	background: url(../img/main_bg.jpg) center center repeat-x;
	background-size: auto 100%;
}

#bos #main_visual .thumb {
	position: absolute;
	top: 50%;
	left: 50%;
	margin: -177px 0 0 -177px;
}

#bos #main_visual .grad {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0.2;
}

#bos #title {
	padding: 30px 0 0;
	background-color: #000;
}

#bos #title h1 {
	font-size: 66px;
	text-align: center;
	color: #fff;
	line-height: 1;
}

#bos #title h1 span {
	margin-right: 16px;
	font-weight: 300;
}

#bos #title h1 br {
	display: none;
}

#bos #title .info {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	padding-bottom: 15px;
	color: #fff;
}

#bos #title .info .date {
	width: 610px;
	padding: 18px 0 0 20px;
	overflow: hidden;
	letter-spacing: 0.025em;
	font-weight: 300;
}

#bos #title .info .date .oa {
	width: 96px;
	height: 65px;
	padding-top: 19px;
	margin-right: 15px;
	font-size: 24px;
	text-align: center;
	line-height: 1.1;
	box-sizing: border-box;
	float: left;
}

#bos #title .info .date .txt {
	margin-top: -4px;
	font-size: 27px;
}

#bos #title .info .date .txt .b_l {
	font-size: 34px;
	font-weight: 400;
}

#bos #title .info .date .txt .b {
	font-weight: 400;
}

#bos #title .info .navigator {
	width: 220px;
	padding: 6px 0 0;
	overflow: hidden;
}

#bos #title .info .navigator .photo {
	padding-right: 15px;
	float: left;
}

#bos #title .info .navigator p {
	padding-top: 20px;
	font-size: 19px;
}

#bos #title .info .navigator p span {
	display: block;
	margin-bottom: 4px;
	font-size: 18px;
	font-weight: 900;
}

#bos #contents {
	text-align: center;
}

#bos #contents .read {
	padding-top: 55px;
	font-size: 20px;
	line-height: 1.75;
}

#bos #contents .lineup_title {
	display: inline-block;
	margin: 95px 0 75px;
	font-size: 44px;
	line-height: 1;
	border-bottom: 1px solid #000;
}

#bos #contents .lineup {
	margin-bottom: 95px;
}

#bos #contents .lineup h3 {
	width: 380px;
	padding-top: 3px;
	margin-bottom: 48px;
	display: inline-block;
	color: #fff;
	font-size: 54px;
	border-radius: 100px;
	line-height: 1;
}

#bos #contents .lineup h3 span {
	font-weight: 300;
}

#bos #contents .lineup p.prg_reed {
	max-width: 600px;
	margin: 50px auto;
	text-align: left;
	font-size: 13pt;
	line-height: 1.4em;
}




#bos #contents .thumb_list {
	display: flex;
	justify-content: center;
	width: 636px;
	margin: 0 auto 35px;
}

#bos #contents .thumb_list .img {
	border-radius: 6px;
	overflow: hidden;
}

#bos #contents .thumb_list div.img img {
	max-width: 500px;
}

#bos #contents .thumb_list p {
	margin-top: 12px;
	font-size: 17px;
}

#bos #contents .guest_h {
	margin-bottom: 4px;
	font-size: 20px;
}

#bos #contents .guest_list {
	display: flex;
	justify-content: space-around;
	width: 328px;
	margin: 0 auto;
}

#bos #contents .guest_list div.img {
	width: 150px;
	margin: 0 auto;
	border-radius: 50%;
	overflow: hidden;
}

#bos #contents .guest_list div.img img {
	width: 150px;
}

#bos #contents .guest_list p {
	margin: 13px 0 15px;
	font-size: 15px;
}

#bos #contents .guest_list p.sub {
	margin: -12px 0 0;
	font-size: 12px;
}


#bos #contents .bnr_spinear {
	display: block;
	width: 344px;
	margin: 130px auto 130px;
	border: 1px solid #e0e0e0;
	border-radius: 6px;
	box-shadow: 0 0 20px 0 rgba(0,0,0,.2);
	overflow: hidden;
}

#bos #footer {
	background-color: #201d26;
	color: #fff;
}

#bos #footer .cnt_inner {
	display: flex;
	justify-content: space-between;
}

#bos #footer .left {
	padding: 38px 0 40px 20px;
}

#bos #footer .right {
	padding: 36px 20px 30px 0;
	text-align: right;
}

#bos #footer .right .copyright {
	padding-top: 10px;
	font-size: 14px;
}



@media screen and (max-width: 1000px) {

	#bos .cnt_inner {
		width: auto;
	}

	#bos #main_visual {
		position: relative;
		height: 470px;
	}

	#bos #main_visual .thumb {
		position: absolute;
		top: 50%;
		left: 50%;
		margin: -150px 0 0 -150px;
		width: 300px;
	}

	#bos #title h1 {
		font-size: calc(100vw / ( 1000 / 64 ));
	}

	#bos #title .info .date {
		width: 490px;
		padding: 30px 0 0 20px;
		overflow: hidden;
		letter-spacing: 0.025em;
		font-weight: 300;
	}

	#bos #title .info .date .oa {
		width: 86px;
		height: 55px;
		padding-top: 17px;
		margin-right: 15px;
		font-size: 19px;
	}

	#bos #title .info .date .txt {
		margin-top: -2px;
		font-size: 22px;
	}

	#bos #title .info .date .txt .b_l {
		font-size: 27px;
	}

	#bos #title .info .date .txt .b {
		font-weight: 400;
	}

	#bos #title .info .navigator {
		width: 190px;
		padding: 18px 0 0;
	}

	#bos #title .info .navigator .photo {
		width: 70px;
	}

	#bos #title .info .navigator p {
		padding-top: 15px;
		font-size: 16px;
	}

	#bos #title .info .navigator p span {
		font-size: 16px;
	}

	#bos #contents .read {
		font-size: 19px;
	}

	#bos #contents .lineup_title {
		font-size: 40px;
	}

	#bos #contents .lineup h3 {
		padding-top: 2px;
		font-size: 50px;
	}

}


@media screen and (max-width: 765px) {

	#bos .sp_br {
		display: inline;
	}

	#bos #main_visual {
		height: 0;
		padding-bottom: 80%;
	}

	#bos #main_visual .thumb {
		position: absolute;
		top: 50%;
		left: 50%;
		width: 46%;
		transform: translate(-50%, -50%);
		margin: 0;
	}

	#bos #main_visual .grad {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		opacity: 0.2;
	}

	#bos #title {
		padding: 7% 0 0;
		background-color: #000;
	}

	#bos #title h1 {
		padding: 0 16px;
		font-size: calc(100vw / ( 375 / 42 ));
		text-align: center;
	}

	#bos #title h1 span {
		margin: 0 0 0 1%;
	}

	#bos #title h1 br {
		display: inline;
	}

	#bos #title .info {
		padding-bottom: 4%;
	}

	#bos #title .info .date {
		width: 100%;
		padding: 6% 0 0 0;
	}

	#bos #title .info .date .oa {
		display: table;
		width: auto;
		height: auto;
		margin: 0 auto;
		padding: 3px 15px 1px;
		font-size: calc(100vw / ( 375 / 14 ));
		float: none;
	}

	#bos #title .info .date .txt {
		margin-top: 4px;
		font-size: calc(100vw / ( 375 / 19 ));
		text-align: center;
	}

	#bos #title .info .date .txt .b_l {
		font-size: calc(100vw / ( 375 / 23 ));
	}

	#bos #title .info .navigator {
		width: 45%;
		padding: 3% 0 0 5%;
		overflow: hidden;
	}

	#bos #title .info .navigator .photo {
		width: 35%;
		padding-right: 15px;
		float: left;
	}

	#bos #title .info .navigator p {
		padding-top: 7%;
		font-size: calc(100vw / ( 375 / 16 ));
	}

	#bos #title .info .navigator p span {
		margin-bottom: 2px;
		font-size: calc(100vw / ( 375 / 14 ));
	}

	#bos #contents .read {
		padding: 10% 0 0;
		font-size: calc(100vw / ( 375 / 16 ));
		line-height: 1.6;
	}

	#bos #contents .lineup_title {
		margin: 20% 0 14%;
		font-size: calc(100vw / ( 375 / 32 ));
	}

	#bos #contents .lineup {
		margin-bottom: 18%;
	}

	#bos #contents .lineup h3 {
		width: 80%;
		margin-bottom: 10%;
		font-size: calc(100vw / ( 375 / 36 ));
	}

	#bos #contents .lineup p.prg_reed {
		max-width: 90%;
		margin: 50px auto;
		text-align: left;
		font-size: 12pt;
}


	#bos #contents .thumb_list {
		width: 90%;
		margin: 0 auto 6%;
	}

/* 	#bos #contents .thumb_list li {
		width: 47%;
	} */

	#bos #contents .thumb_list .img img {
		width: 100%;
	}

	#bos #contents .thumb_list p {
		margin-top: 10px;
		font-size: 15px;
	}

	#bos #contents .guest_h {
		font-size: 18px;
	}

	#bos #contents .guest_list {
		width: 74%;
	}

	#bos #contents .guest_list li {
		width: 50vw;
	}

	#bos #contents .guest_list .img {
		width: 28vw;
	}

	#bos #contents .guest_list .img img {
		width: 100%;
	}

	#bos #contents .guest_list p {
		margin: 10px 0 15px;
		font-size: 14px;
	}

	#bos #contents .guest_list p.sub {
		margin: -12px 0 0;
		font-size: 10px;
	}


	#bos #contents .bnr_spinear {
		width: 65%;
		margin: 20% auto 20%;
	}

	#bos #contents .bnr_spinear img {
		width: 100%;
	}

	#bos #footer .left {
		padding: 28px 0 30px 20px;
	}

	#bos #footer .right {
		padding: 26px 20px 20px 0;
		text-align: right;
	}

	#bos #footer .right .logo {
		width: 150px;
	}

	#bos #footer .right .copyright {
		font-size: 10px;
	}

}
