@charset "UTF-8";
/*--------------------------------------------
HEADER
---------------------------------------------*/
@media screen and (max-width: 1024px){
#header {
	height: auto;
}
.fixed-head.transform {
	padding-bottom: calc( 15.5 * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
#header {
	background: url("../images/home/bg_header.png") center 0/ cover no-repeat;
	
}
#header::before{
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	/*background-color: rgba(0,0,0,0.3);*/
}
}

/*--------------------------------------------
LIVE
---------------------------------------------*/
@media screen and (max-width: 1024px){
#live .iframe-container {
	height: calc( ( 1024 * 9 / 16 ) * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
#live {
	padding: 160px 0 30px 0;
	max-width: 1440px;
	min-width: 1100px;
	margin: 0 auto;
}
#live .iframe-container {
	height: 540px;
	margin: 0 auto;
	width: 960px;
}
}

/*--------------------------------------------
LOCAL NAV
---------------------------------------------*/
#localNav {
background-color: #f2f4f4


}
#localNav a {
/*color: #fff;*/
	color: #000;
}
@media screen and (max-width: 1024px){
	#localNav span {
		height: calc( 60 * 100vw / 1024 );
	}
	#localNav a .jp {
		font-size: 1.8rem;
		letter-spacing: .04em;
	}
	#localNav a .en {
		font-size: 2.4rem;
	}
}
/*--------------------------------------------
LEAD
---------------------------------------------*/
#lead {
	padding-bottom: 20px;
	padding-top: 100px;

}
#lead .wrap{
	align-items: center;
	border: 2px solid #ccc;
	display: flex;
	flex-direction: column;
	padding:50px;
}

#lead .wrap img{
	width:90%;
	height:90%;
}
#lead .title01{
	text-align: center;
}
@media screen and (max-width: 1024px){
	#lead {
		padding-bottom: 20px;
		padding-top: 20px;
	}	
	#lead .wrap{
		border: 0px;
		padding: calc( 30 * 100% / 1024 );
	}
	#lead .title01{
		padding-bottom: 40px;
	}
}
@media print,screen and (min-width: 1025px){

}

/*--------------------------------------------
STREAMING table
---------------------------------------------*/
table th ,td {
    border:1px solid #4d4d4d;
}
     
/*　スクロールバーの実装 */
.timetable {
    display: block;
    overflow-y: scroll;
    height: calc(100vh/2);
    border:1px solid ;
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
    table-layout: fixed;
    height: 700px;
}
.timetable thead{
	height: 50px;
	text-align:center;
	font-weight:600;
	font-size:120%;
}  
.timetable tbody{
	overflow-x: hidden;
	overflow-y: scroll;
	height: 1500px;
}  
.timetable thead td {
	width: 100px;
	position: sticky;
	top: 0;
	z-index: 1;
	background: #E4007F;
	border:1px solid #4d4d4d;
	color:#fff;
	vertical-align:middle;
} 
.timetable thead th {
	width: 500px;
	position: sticky;
	top: 0;
	z-index: 1;
	background: #E4007F;
	border:1px solid #4d4d4d;
	color:#fff;
	vertical-align:middle;
}
.timetable tbody th {
	height:162px;
	background: #8fc31f;
	color:#fff;
	font-weight:600;
} 
.timetable tbody td {
	width: 100px;
	padding: 10px;
	vertical-align:top;
} 
.timetable .empty {
	background-color:#4d4d4d;
} 
.timetable tbody tr {
	height:27px;
} 
.timetable tbody strong {
	font-weight:600;
} 
.timetable table th {
	width: 452px;
	padding-left: 30px;
	padding-right: 30px;
	padding-top: 22px;
	padding-bottom: 22px;
}
@media screen and (max-width: 1024px){
	.timetable td {
		font-size:120%;
		line-height: 1.3;
	}
	.timetable thead th {
	font-size:120%;
	}
}
@media print,screen and (min-width: 1025px){
	.timetable td {
		line-height: 1.5;
	}
}


/*--------------------------------------------
STREAMING
---------------------------------------------*/
#streaming li {
display: flex;
}
#streaming .jp p {
line-height: 1.75;
}
#streaming li + li {
border-top: 1px solid #000;
}
#streaming .datetime {
color: var(--accentColor01);
color:  #231815;
font-family: 'Noto Sans JP', sans-serif;
font-weight:600;
letter-spacing: .02em;
line-height: 1.6;

}
@media screen and (max-width: 1024px){
	#streaming li {
		flex-direction: column;
	}
	#streaming li + li {
		margin-top: calc( 40 * 100vw / 1024 );
		padding-top: calc( 40 * 100vw / 1024 );
	}
	#streaming .text {
		margin-top: calc( 30 * 100vw / 1024 );
	}
	#streaming dl:not(:nth-child(1)) {
		margin-top: calc( 40 * 100vw / 1024 );
	}
	#streaming .datetime {
		width:100%;
	}
	#streaming .texts02 .photo {
		text-align:center;
	}
	#streaming .texts02 .photo img {
		width:50%;
	}
}
@media print,screen and (min-width: 1025px){
	#streaming li {
		align-items: first baseline;
		justify-content: space-between;
	}
	#streaming li + li {
		margin-top: 25px;
		padding-top: 25px;
	}
	#streaming .texts01 .text {
		/*margin-left: 80px;*/
		/*width: 427px;*/
	}
	#streaming dl:not(:nth-child(1)) {
		margin-top: 20px;
	}
	#streaming .datetime {
		width:100%;
	}
	#streaming .texts02 .text {
		padding-left: 30px;
		width:80%;
	}
	#streaming .texts02 .photo {
		width: 20%;
	}
	#streaming .texts02 .photo img {
		width:100%;
	}
}

/*--------------------------------------------
OUTLINE
---------------------------------------------*/
#outline,
#outline .title01,
#outline a {
color: #fff;
}
#outline .jp p {
line-height: 1.75;
}
#outline .en {
font-weight: 600;
letter-spacing: .04em;
}
#outline dl {
display: flex;
margin-top: 1em;
}
#outline dt {
flex-shrink: 0;
}
#outline dt:after {
content:'：';
}
@media screen and (max-width: 1024px){
#outline {
	background: url("../images/common/bg_head_sp.png") center 0/ cover no-repeat;
}
#outline dl {
	flex-direction: column;
}
#outline p,
#outline dt,
#outline dd {
	letter-spacing: .05em;
}
}
@media print,screen and (min-width: 1025px){
#outline {
	background: url("../images/common/bg_overview_pc.png") center 0/ cover no-repeat;
}
}
/*--------------------------------------------
Exhibition
---------------------------------------------*/
#exhibition .exhibition_link {
	width: 50%;
	margin: 50px auto;
	
}
#exhibition .exhibition_link a {
	align-items: center;
	background-color: #8dc21f;
	background-color: var(--accentColor01);
	color: #fff;
	display: flex;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	justify-content: center;
	letter-spacing: .05em;
	border-radius: 4px;
	font-size: 2.7rem;
	margin-top: auto;
	order: 4;
	text-align:center;
}
#exhibition .exhibition_link a span {
	align-items: center;
	display: flex;
}
@media screen and (max-width: 1024px){
	#exhibition .exhibition_link {
		width: 80%;
		margin: 50px auto;
		
	}
	#exhibition .exhibition_link a {
		height: 80px;
	}

}
@media print,screen and (min-width: 1025px){
	#exhibition .exhibition_link a {
		height: 120px;
	}

}

/*--------------------------------------------
PREFACE
---------------------------------------------*/
#preface dl {
/*background-color: #1a1a1a;*/background-color: #231815;
color: #fff;
display: flex;
}
#preface dt {
display: flex;
}
#preface dt img {
width: auto;
}
#preface dt div {
display: flex;
flex-direction: column;
justify-content: center;
}
#preface dt span {
display: block;
}
#preface dt span:nth-child(1) {
font-family: 'Noto Sans JP', sans-serif;
font-weight: 700;
letter-spacing: .06em;
}
#preface dt span:nth-child(2) {
font-family: 'Noto Sans JP', sans-serif;
font-weight: 700;
letter-spacing: .04em;
}
#preface dd {
display: flex;
flex-direction: column;
}
#preface dd span:nth-child(1) {
font-family: 'Noto Sans JP', sans-serif;	
letter-spacing: .06em;
line-height: 1.5;
}
#preface dd span:nth-child(2) {
font-family: 'Noto Sans JP', sans-serif;
letter-spacing: .02em;
line-height: 1.42;
}
@media screen and (max-width: 1024px){
#preface li:not(:last-child) {
	margin-bottom: calc( 90 * 100vw / 1024 );
}
#preface dl {
	flex-direction: column;
	margin-bottom: calc( 60 * 100vw / 1024 );
}
#preface dt {
	position: relative;
}
#preface dt img {
	height: calc( 149 * 100vw / 1024 );
}
#preface dt div {
	padding-left: calc( 30 * 100% / 1024 );
	z-index: 2;
}
#preface dt div span:nth-child(1) {
	font-size: 4.3rem;
}
#preface dt div span:nth-child(2){
	font-size: 2.4rem;
	margin-top: calc( 14 * 100vw / 1024 );
}
#preface dt:after {
	background: url("../images/ui/logo/badge_geidai01.svg") 0 0/ contain no-repeat;
	bottom: 50%;
	content: '';
	height: calc( 99 * 100vw / 1024 );
	margin-bottom: calc( ( -99 / 2 ) * 100vw / 1024 );
	position: absolute;
	right: calc( 26 * 100% / 1024 );
	width: calc( 93 * 100% / 1024 );
}
#preface dd {
	border-top: 1px solid #fff;
	padding: calc( 26 * 100vw / 1024 );
}
#preface dd span:nth-child(1) {
	font-size: 2.7rem;
}
#preface dd span:nth-child(2){
	font-size: 2.3rem;
	margin-top: calc( 10 * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
#preface li {
	margin-bottom: 60px;
}
#preface dl {
	align-items: center;
	margin-bottom: 40px;
	position: relative;
}
#preface dl:after {
	background: url("../images/ui/logo/badge_geidai01.svg") 0 0/ contain no-repeat;
	bottom: 50%;
	content: '';
	height: 86px;
	margin-bottom: -43px;
	position: absolute;
	right: 30px;
	width: 80px;
}
#preface dt {
	width: 345px;
}
#preface dt img {
	height: 130px;
}
#preface dt div {
	padding-left: 20px;
}
#preface dt span:nth-child(1) {
	font-size: 3rem;
}
#preface dt span:nth-child(2){
	font-size: 1.6rem;
	margin-top: 10px;
}
#preface dd {
	border-left: 1px solid #fff;
	min-height: 98px;
	padding: 16px 30px;
	width: 755px;
}
#preface dd span:nth-child(1) {
	font-size: 1.4rem;
}
#preface dd span:nth-child(2){
	font-size: 1.4rem;
	margin-top: 5px;
}
}
#preface h3 {
font-weight: 700;
position: relative;
}
#preface .en h3 {
letter-spacing: .04em;
}
#preface h3:after {
content: '';
left: 0;
position: absolute;
top: 100%;
}
#preface .jp h3:after {
background-color: var(--accentColor02);
/*background-color: #8dc21f;*/
}
#preface .en h3:after {
background-color: var(--accentColor02);
/*background-color: #e0c2a2;*/
}
#preface .en p {
/*font-weight: 600;*/
}
#preface p + p {
margin-top: 1em;
}
@media screen and (max-width: 1024px){
#preface h3 {
	font-size: 3.4rem;
	letter-spacing: .02em;
	line-height: 1.2;
	margin-bottom: calc( 24 * 100vw / 1024 );
	padding-bottom: calc( 14 * 100vw / 1024 );
}
#preface h3:after {
	height: calc( 6 * 100vw / 1024 );
	width: calc( 400 * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
#preface h3 {
	font-size: 2rem;
	margin-bottom: 12px;
	padding-bottom: 10px;
}
#preface h3:after {
	height: 3px;
	width: 50%;
}
}

/*--------------------------------------------
SQUARE ENIX
---------------------------------------------*/
#squareenix dl {
	/*background-color: #1a1a1a;*/background-color: #231815;
	color: #fff;
	display: flex;
}
#squareenix dt {
	display: flex;
}
#squareenix dt img {
	width: auto;
}
#squareenix dt div {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
#squareenix dt span {
	display: block;
}
#squareenix dt span:nth-child(1) {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: .06em;
}
#squareenix dt span:nth-child(2) {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: .04em;
}
#squareenix dd {
	display: flex;
	flex-direction: column;
}
#squareenix dd span:nth-child(1) {
	font-family: 'Noto Sans JP', sans-serif;	
	letter-spacing: .06em;
	line-height: 1.5;
}
#squareenix dd span:nth-child(2) {
	font-family: 'Noto Sans JP', sans-serif;
	letter-spacing: .02em;
	line-height: 1.42;
}
@media screen and (max-width: 1024px){
	#squareenix li:not(:last-child) {
		margin-bottom: calc( 90 * 100vw / 1024 );
	}
	#squareenix dl {
		flex-direction: column;
		margin-bottom: calc( 60 * 100vw / 1024 );
	}
	#squareenix dt {
		position: relative;
	}
	#squareenix dt img {
		height: calc( 149 * 100vw / 1024 );
	}
	#squareenix dt div {
		padding-left: calc( 30 * 100% / 1024 );
		z-index: 2;
	}
	#squareenix dt div span:nth-child(1) {
		font-size: 4.3rem;
	}
	#squareenix dt div span:nth-child(2){
		font-size: 2.4rem;
		margin-top: calc( 14 * 100vw / 1024 );
	}
	#squareenix dt:after {
		/*background: url("../images/ui/logo/sqenixlogo.svg") 0 0/ contain no-repeat;*/
		top: 40%;
		content: '';
		height: calc( 99 * 100vw / 1024 );
		margin-bottom: calc( ( -99 / 2 ) * 100vw / 1024 );
		position: absolute;
		right: calc( 26 * 100% / 1024 );
		width: calc( 293 * 100% / 1024 );
	}
	#squareenix dd {
		border-top: 1px solid #fff;
		padding: calc( 26 * 100vw / 1024 );
	}
	#squareenix dd span:nth-child(1) {
		font-size: 2.7rem;
	}
	#squareenix dd span:nth-child(2){
		font-size: 2.3rem;
		margin-top: calc( 10 * 100vw / 1024 );
	}
}
@media print,screen and (min-width: 1025px){
	#squareenix li {
		margin-bottom: 60px;
	}
	#squareenix dl {
		align-items: center;
		margin-bottom: 40px;
		position: relative;
	}
	#squareenix dl:after {
		/*background: url("../images/ui/logo/sqenixlogo.svg") 0 0/ contain no-repeat;*/
		top: 40%;
		content: '';
		height: 186px;
		margin-bottom: -43px;
		position: absolute;
		right: 30px;
		width: 280px;
	}
	#squareenix dt {
		width: 345px;
	}
	#squareenix dt img {
		height: 130px;
	}
	#squareenix dt div {
		padding-left: 20px;
	}
	#squareenix dt span:nth-child(1) {
		font-size: 3rem;
	}
	#squareenix dt span:nth-child(2){
		font-size: 1.6rem;
		margin-top: 10px;
	}
	#squareenix dd {
		border-left: 1px solid #fff;
		min-height: 98px;
		padding: 16px 30px;
		width: 755px;
	}
	#squareenix dd span:nth-child(1) {
		font-size: 1.4rem;
	}
	#squareenix dd span:nth-child(2){
		font-size: 1.4rem;
		margin-top: 5px;
	}
}
#squareenix h3 {
	font-weight: 700;
	position: relative;
}
#squareenix .en h3 {
	letter-spacing: .04em;
}
#squareenix h3:after {
	content: '';
	left: 0;
	position: absolute;
	top: 100%;
}
#squareenix .jp h3:after {
	background-color: var(--accentColor02);
	/*background-color: #8dc21f;*/
}
#squareenix .en h3:after {
	background-color: var(--accentColor02);
	/*background-color: #e0c2a2;*/
}
#squareenix .en p {
	/*font-weight: 600;*/
}
#squareenix p + p {
	margin-top: 1em;
}
@media screen and (max-width: 1024px){
	#squareenix h3 {
		font-size: 3.4rem;
		letter-spacing: .02em;
		line-height: 1.2;
		margin-bottom: calc( 24 * 100vw / 1024 );
		padding-bottom: calc( 14 * 100vw / 1024 );
	}
	#squareenix h3:after {
		height: calc( 6 * 100vw / 1024 );
		width: calc( 400 * 100vw / 1024 );
	}
}
@media print,screen and (min-width: 1025px){
	#squareenix h3 {
		font-size: 2rem;
		margin-bottom: 12px;
		padding-bottom: 10px;
	}
	#squareenix h3:after {
		height: 3px;
		width:50%;
	}
}

/*--------------------------------------------
CREDIT
---------------------------------------------*/
#credit {
background-color: #231815;
}
#credit,
#credit a {
color: #fff;
}
#credit dt {
font-weight: 700;
}
#credit dt:after {
content:'：';
}
#credit .en dd {
/*font-weight: 600;*/
}
@media screen and (max-width: 1024px){
#credit dl:not(:nth-child(1)),
#credit .logo dl,
#credit p {
	margin-top: calc( 40 * 100vw / 1024 );
}
#credit dt,
#credit dd {
	letter-spacing: .02em;
}
#credit .logo img {
	height: calc( 102 * 100vw / 1024 );
	margin-top: calc( 14 * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
#credit dl:not(:nth-child(1)),
#credit .logo dl,
#credit p {
	margin-top: 20px;
}
#credit .logo {
	display: flex;
	position: relative;
	align-items: flex-end;
}
#credit .logo img {
	flex-shrink: 0;
	margin-left: 10px;
	width: 162px;
}
}

/*--------------------------------------------
TEXTS
---------------------------------------------*/
@media screen and (max-width: 1024px){
.texts01 .jp dt,
.texts01 .jp dd {
	/*font-size: 2.7rem;*/
		font-size: 3.2rem;
	line-height: 1.74;
}
.texts01 .en dt,
.texts01 .en dd {
	/*font-size: 2.7rem;*/
		font-size: 3.2rem;
	/*font-weight: 600;*/
	line-height: 1.6;
}
.texts01 .jp dt{
	font-weight: 700;
}
.texts01 .en dt{
	font-weight: 700;
}
.texts01 .session_title{
	font-weight: 700;
}
	.texts02 .jp dt,
	.texts02 .jp dd {
		/*font-size: 2.7rem;*/
		font-size: 3.2rem;
		line-height: 1.74;
	}
	.texts02 .en dt,
	.texts02 .en dd {
		/*font-size: 2.7rem;*/
		font-size: 3.2rem;
		/*font-weight: 600;*/
		line-height: 1.6;
	}
	.texts02 .jp dt{
		font-weight: 700;
	}
	.texts02 .en dt{
		font-weight: 700;
	}
	.texts02 .session_title{
		font-weight: 700;
	}
	.texts02 .profile_name{
		font-weight: 700;
	}
}
@media print,screen and (min-width: 1025px){
.texts01 .jp dt,
.texts01 .jp dd {
	font-size: 1.6rem;
	line-height: 1.75;
}
.texts01 .jp dt{
font-weight: 700;
}
.texts01 .en dt,
.texts01 .en dd {
	font-size: 1.7rem;
	line-height: 1.6;
}
.texts01 .en dt{
	font-weight: 700;
}
.texts01 .session_title{
	font-weight: 700;
}
	.texts02 .jp dt,
	.texts02 .jp dd {
		font-size: 1.6rem;
		line-height: 1.75;
	}
	.texts02 .jp dt{
		font-weight: 700;
	}
	.texts02 .en dt,
	.texts02 .en dd {
		font-size: 1.7rem;
		line-height: 1.6;
	}
	.texts02 .en dt{
		font-weight: 700;
	}
	.texts02 .session_title{
		font-weight: 700;
	}
	.texts02 .profile_name{
		font-weight: 700;
	}
}

/*--------------------------------------------
CATALOG_DOWNLOAD BANNER
---------------------------------------------*/
#catalog_download{
		margin-top: 0px;
		
	}
@media screen and (max-width: 1024px){
	#catalog_download .catalog_download_banner{
		width: 80%;
		margin: 30px auto;
		
	}
	#catalog_download .catalog_download_banner a{
		align-items: center;
		background-color: #B24996;
		background-color: var(--accentColor01);
		color: #fff;
		display: flex;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		justify-content: center;
		letter-spacing: .05em;
		line-height:1.5;
		border:5px solid #aaa;
		border-radius: 4px;
		font-size: 3.2rem;
		height: 150px;
		margin-top: auto;
		order: 4;
		text-align: center;
		background: url("../images/common/bg_banner.png") center 0/ cover no-repeat;
		
	}
	#catalog_download .catalog_download_banner span{
		
	}

}
@media print,screen and (min-width: 1025px){
	#catalog_download .catalog_download_banner{
		width: 80%;
		margin: 60px auto;
		
	}
	#catalog_download .catalog_download_banner a{
		align-items: center;
		background-color: #B24996;
		background-color: var(--accentColor01);
		color: #fff;
		display: flex;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		justify-content: center;
		letter-spacing: .05em;
		line-height:1.5;
		border:5px solid #aaa;
		border-radius: 4px;
		font-size: 3.3rem;
		height: 150px;
		margin-top: auto;
		order: 4;
		text-align: center;
		background: url("../images/common/bg_banner.png") center 0/ cover no-repeat;

	}
	#catalog_download .catalog_download_banner span{
		
	}
	

}