@charset "UTF-8";

/* #onetrust-consent-sdk {
	display: none;
} */

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	line-height: 1;
}
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
li {
	list-style: none;
}
abbr {
	text-decoration: none;
}


a {
	color: #fff;
	text-decoration: none;
}
a:link, 
a:visited {
	color: #fff;
}
a:hover {
	color: #fff;
	text-decoration: none;
}
img,
video {
	vertical-align: bottom;
}


body[data-ui-mode="mouse"] * {
	outline: none;
}



body {
	color: #fff;
	font-family: "SST W20 Roman", sans-serif;
	background: #111 url(../img/line.png) 50% 0 repeat-y;
}
button {
	font-family: "SST W20 Roman", sans-serif;
}
a {
	color: #fff;
	cursor: pointer;
}

iframe {
	border: none;
}

body[data-ui-mode="mouse"] * {
	outline: none;
}




#top-index .secondary dt,
#top-nav li a,
.top-theme .intro h2,
.accordion h3
{
	font-family: "miller-display", serif;
}


.footer-share dt,
.footer-link a,
#wrap > footer .nav nav a,
h1 .sony,
h1 .event,
#top-kv .primary dt,
#top-kv .primary dd,
#top-index h2
{
	font-family: "SST W20 Medium", sans-serif;
}
a.button,
#top-intro h2,
#top-index .link a,
#top-slide .slide-item dt,
.top-theme .list .text dt,
.path-info > span,
#wrap.detail .detail h1,
#wrap.detail .share h2,
#wrap.detail .related h2,
#wrap.detail .accordion .title,
.news-list h1,
.text-version-section h1,
.text-version-section h2,
.news-list .date .day,
.news-list .date .month,
.news-list dt
{
	font-family: "SST W20 Bold", sans-serif;
}
h1 .at,
#wrap.detail .related dd.link
{
	font-family: "SST W20 Light", sans-serif;
}




html:lang(ja) body {
	font-family: "SST W55 Regular", sans-serif;
}
html:lang(ja) button {
	font-family: "SST W55 Regular", sans-serif;
}

html:lang(ja) #top-kv .primary dt,
html:lang(ja) #top-kv .primary dd,
html:lang(ja) #top-index h2
{
	font-family: "SST W55 Regular", sans-serif;
}

html:lang(ja) a.button,
html:lang(ja) #top-intro h2,
html:lang(ja) #top-index .link a,
html:lang(ja) #top-slide .slide-item dt,
html:lang(ja) .top-theme .list .text dt,
html:lang(ja) .path-info > span,
html:lang(ja) #wrap.detail .detail h1,
html:lang(ja) #wrap.detail .share h2,
html:lang(ja)  #wrap.detail .related h2,
html:lang(ja) #wrap.detail .accordion .title,
html:lang(ja) .news-list h1,
html:lang(ja) .text-version-section h1,
html:lang(ja) .text-version-section h2,
html:lang(ja) .news-list .date .day,
html:lang(ja) .news-list .date .month,
html:lang(ja) .news-list dt
{
	font-family: "SST W55 Bold", sans-serif;
}




/* ---------------------------------------------------------------------------------------------------- */

body {
	overflow-x: hidden;
	min-width: 1200px;
}
@media screen and (max-width:1199px) {
	body {
		overflow-x: auto;
	}
}

main {
	position: relative;
	z-index: 10;
}









a.modal-link  {
	position: absolute;
	display: block;
	width: 80px;
	height: 80px;
	left: calc(50% - 40px);
	top: calc(50% - 40px);
	z-index: 50;
	font-size: 0;
	border-radius: 40px;
	background: rgba(0,0,0,0.10);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	transition: all 300ms ease-out;
}
a.modal-link::before {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	left: calc(50% - 8px);
	top: calc(50% - 10px);
	background: url(../img/icon_play_micro.svg) 50% 50% no-repeat;
	background-size: 16px auto;
}
 a.modal-link:hover {
	background: rgba(0,0,0,0.15);
}




a.video-link {
	position: relative;
	display: inline;
/* -------------- 20250214コメントアウト*/
	/*display: inline-block;*/
}
a.video-link::before {
	box-sizing: border-box;
	position: relative;
	content: "";
	display: inline-block;
	width: 18px;
	height: 18px;
	top: -1px;
	margin-right: 6px;
	border: 1px solid #fff;
	border-radius: 10px;
	background: url(../img/icon_play_micro.svg) 50% 50% no-repeat;
	background-size: 6px auto;
	vertical-align: middle;
}

a.video-link i {
	position: absolute;
	display: block;
	width: calc(100% - 23px);
	height: 1px;
	left: 23px;
	bottom: -1px;
	background: #fff;
	transform-origin: left top;
	transform: scaleX(0);
	transition: all 300ms ease-out;
}

/* -------------- 20250214コメントアウト*/
/*a.video-link:hover i {
	transform: scaleX(1);
}*/

/* -------------- 20250214追記*/
#wrap.detail .related dt a.video-link:hover{
	background-size: 100% 1px;
}
#wrap.detail .related dt a.video-link{
	background: linear-gradient(#fff, #fff) 23px 100% / 0 1px no-repeat;
        transition: all 300ms ease-out;
}
/* -------------- 20250220追記*/
#wrap.detail .text-version a.video-link:hover{
	background-size: 100% 1px;
}
#wrap.detail .text-version a.video-link{
	background: linear-gradient(#fff, #fff) 23px 100% / 0 1px no-repeat;
        transition: all 300ms ease-out;
}

a.text-link {
	position: relative;
	display: inline-block;
}
a.text-link::after {
	position: relative;
	content: "";
	display: inline-block;
	width: 18px;
	height: 14px;
	top: -2px;
	margin-left: 5px;
	background: url(../img/arrow_mini.svg) 50% 50% no-repeat;
	background-size: 100% auto;
	vertical-align: middle;
	transition: all 300ms ease-out;
}
a.text-link:hover::after {
	transform: translateX(4px);
}


a.text-link i {
	position: absolute;
	display: block;
	width: calc(100% - 23px);
	height: 1px;
	left: 0;
	bottom: -1px;
	background: #fff;
	transform-origin: left top;
	transform: scaleX(0);
	transition: all 300ms ease-out;
}
a.text-link:hover i {
	transform: scaleX(1);
}






a.button {
	position: relative;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	width: 100%;
	height: 56px;
	color: #fff;
	font-size: 0.875rem;
	overflow: hidden;
}
a.button .label {
	box-sizing: border-box;
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	height: 100%;
	z-index: 50;
	padding: 0 32px;
}
a.button::before {
	position: absolute;
	content: "";
	display: block;
	width: calc(100% + 1px);
	height: 100%;
	left: 0;
	top: 0;
	z-index: 10;
	background: linear-gradient(to right, #154fbd, #bd5f55);
	transition: all 300ms ease-out;
	transform: translateX(-101%);
	transform-origin: left top;
	will-change: transform;
}
a.button:hover::before {
	transform: translateX(0px);
}
a.button::after {
	box-sizing: border-box;
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1;
	border: 1px solid #fff;
	pointer-events: none;
}
a.button .label::after {
	position: absolute;
	content: "";
	display: block;
	width: 18px;
	height: 18px;
	right: 20px;
	top: calc(50% - 9px);
	z-index: 20;
	background: url(../img/arrow_mini.svg) 50% 50% no-repeat;
	background-size: 18px auto;
	transition: all 300ms ease-out;
	will-change: transform;
}
a.button .label:hover::after {
	transform: translateX(3px);
}






a.disabled {
	pointer-events: none;
	cursor: default;
}



.return-top {
	width: 284px;
	margin: 64px auto 160px;
}
.return-top .label {
	justify-content: center !important;
	padding: 0 !important;
}
.return-top .label::after {
	display: none !important;
}





span.text-link {
	position: relative;
	display: inline-block;
}
span.text-link::after {
	position: relative;
	content: "";
	display: inline-block;
	width: 18px;
	height: 14px;
	top: -2px;
	margin-left: 5px;
	background: url(../img/arrow_mini.svg) 50% 50% no-repeat;
	background-size: 100% auto;
	vertical-align: middle;
	transition: all 300ms ease-out;
}





/* ---------------------------------------------------------------------------------------------------- */
/* Header */

#wrap > header a {
	display: inline-block;
	color: #fff;
}
#wrap > header.sony {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	height: 70px;
	left: 0;
	top: 0;
	z-index: 1000;
	background: #000;
}
#wrap > header.sony .logo {
	box-sizing: border-box;
	width: 100%;
	margin: 0 auto;
	padding: 0 40px;
}
#wrap > header.sony img {
	position: relative;
	width: 108px;
	height: auto;
	top: -2px;
}







nav.ces {
	position: relative;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 72px;
	left: 0;
	top: 0;
	z-index: 1100;
	background: #25282c;
}
nav.ces h1 {
	position: relative;
	z-index: 10;
}
nav.ces h1 .sony {
	font-size: 2rem;
}
nav.ces h1 .at {
	position: relative;
	margin: 0 3px;
	top: -1px;
	font-size: 1.5rem;
}
nav.ces h1 .event {
	font-size: 1.625rem;
}
nav.ces h1 a:hover {
	text-decoration: none;
}
nav.ces a {
	color: #fff;
}






#lang-menu * {
	font-family: "SST W20 Medium", sans-serif !important;
}

#lang-menu {
	position: absolute;
	display: flex;
	box-sizing: border-box;
	width: 96px;
	height: 72px;
	right: 0;
	top: 0;
	z-index: 1;
	font-size: 1rem;
}
#lang-menu .inner {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	box-sizing: border-box;
	width: 100%;
	margin: 0 auto;
}
#lang-menu .current {
	position: relative;
	display: flex;
	width: 100%;
	height: 100%;
}
#lang-menu .current button {
	display: flex;
	width: 100%;
	height: 100%;
	justify-content: center;
	align-items: center;
	margin: 0;
	padding: 0;
	color: #fff;
	font-size: 1rem;
	border: none;
	background: none;
}
#lang-menu .current abbr {
	position: relative;
	display: inline-block;
	top: -5px;
}
#lang-menu .current span {
	position: absolute;
	display: block;
	width: 5px;
	height: 5px;
	left: calc(50% - 2.5px);
	top: calc(50% + 8px);
	font-size: 0;
	background: url(../img/arrow_down.svg) 50% 50% no-repeat;
	background-size: 5px auto;
}


#lang-menu ul {
	position: absolute;
	width: 100%;
	box-sizing: border-box;
	top: calc(100% - 10px);
	background: #25282c;
}
#lang-menu li + li {
}
#lang-menu .en a {
	text-indent: 1px;
}

#lang-menu .current a:hover {
	text-decoration: none;
}
#lang-menu li {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	width: 100%;
	height: 40px;
	color: #fff;
}
#lang-menu li a:hover {
	opacity: 0.85;
	text-decoration: none;
}





#lang-menu ul {
	visibility: hidden;
	opacity: 0;
	transform: translateY(-30px);
	transition: all 300ms ease-out;
}
#lang-menu.opened ul {
	visibility: visible;
	opacity: 1;
	transform: translateY(0px);
}
#lang-menu.opened .current span {
	background: none;
}
#lang-menu .current button::after {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 1px;
	left: calc(50% - 10px);
	top: calc(50% + 6px);
	background: #fff;
	opacity: 0;
	transition: all 300ms ease-out;
}
#lang-menu.opened .current button::after {
	opacity: 1;
}















/* ---------------------------------------------------------------------------------------------------- */
/* Footer */

#wrap > footer {
	position: relative;
	z-index: 10;
	border-top: 1px solid #26282C;
	background: #000;
}

#wrap > footer .nav {
	padding: 25px 30px;
	font-size: 1rem;
}
#wrap > footer .nav .inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 1456px;
	margin: 0 auto;
}
#wrap > footer .nav .extra {
	display: flex;
	align-items: center;
}
#wrap > footer .nav nav a {
	display: inline-block;
	padding: 4px 24px 4px 26px;
	color: #626262;
	font-size: 0.9375rem;
	text-decoration: none;
	background: #fff url(../img/arrow.svg) 15px 50% no-repeat;
	background-size: 6px auto;
	border-radius: 20px;
	transition: all 300ms ease-out;
}
#wrap > footer .nav nav a:hover {
	opacity: 0.8;
}
#wrap > footer .nav ul {
	display: flex;
	margin-left: 30px;
}
#wrap > footer .nav li + li {
	margin-left: 20px;
}
#wrap > footer .nav li a {
	color: #898991;
	transition: all 300ms ease-out;
}
#wrap > footer .nav li a:hover {
	opacity: 0.8;
}
#wrap > footer .copyright {
	color: #898991;
	font-size: 1rem;
}







.other-events  {
	position: relative;
	box-sizing: border-box;
	z-index: 10;
	margin: 80px 0 0;
	padding: 3px 0;
	background: #000;
}
.other-events .extra {
	position: relative;
	display: flex;
	align-items: center;
	max-width: 1456px;
	height: 50px;
	margin: 0 auto;
	padding: 0 30px;
}
.other-events a {
	position: relative;
	box-sizing: border-box;
	display: inline-block;
	padding-right: 16px;
	color: #fff;
	font-size: 1rem;
	transition: all 300ms ease-out;
}
.other-events a:hover {
	text-decoration: none;
}
.other-events a span {
	position: relative;
	display: inline-block;
	width: 16px;
	font-size: 0;
}

.other-events a::before,
.other-events a::after {
	position: absolute;
	content: "";
	display: block;
	width: 12px;
	height: 12px;
	right: 12px;
	z-index: 10;
	top: calc(50% - 6px);
	background-position: 0 0;
	background-repeat: no-repeat;
	background-size: 100% auto;
}
.other-events a::before {
	background-image: url(../img/icon_external_base_white.svg);
}
.other-events a::after {
	background-image: url(../img/icon_external_arrow_white.svg);
}
.other-events a::after {
	transition: all 300ms ease-out;
}
.other-events a:hover::after {
	transform: translate(2px, -2px);
}

/* 
#wrap.index .other-events {
	margin-top: 160px;
}
*/






.footer-link {
	position: relative;
	width: 728px;
	z-index: 10;
	margin: 96px auto 160px;
}
.footer-link a {
	position: relative;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	width: 100%;
	height: 80px;
	color: #fff;
	font-size: 1.125rem;
	overflow: hidden;
}
.footer-link a + a {
	margin-top: 32px;
}
.footer-link a .label {
	box-sizing: border-box;
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	height: 100%;
	z-index: 50;
	padding: 0 40px;
}

.footer-link a::before {
	position: absolute;
	content: "";
	display: block;
	width: calc(100% + 1px);
	height: 100%;
	left: 0;
	top: 0;
	z-index: 10;
	background: linear-gradient(to right, #154fbd, #bd5f55);
	transition: all 300ms ease-out;
	transform: translateX(-101%);
	transform-origin: left top;
	will-change: transform;
}
.footer-link a:hover::before {
	transform: translateX(0px);
}

.footer-link a::after {
	box-sizing: border-box;
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1;
	border: 1px solid #fff;
	pointer-events: none;
}

.footer-link a .label::after {
	position: absolute;
	content: "";
	display: block;
	width: 16px;
	height: 16px;
	right: 40px;
	top: calc(50% - 8px);
	z-index: 20;
	background: url(../img/arrow_diagonal.svg) 50% 50% no-repeat;
	background-size: 16px auto;
	transition: all 300ms ease-out;
	will-change: transform;
}
.footer-link a .label:hover::after {
	transform: translate(4px,-4px);
}








.footer-share {
	position: relative;
	z-index: 10;
	margin: 60px 0 0;
	text-align: center;
}
.footer-share dt {
	font-size: 1.25rem;
	letter-spacing: 5px;
}
.footer-share dd {
	margin: 16px 0 0;
}
.footer-share ul {
	display: inline-flex;
}
.footer-share li {
	width: 48px;
}
.footer-share li img {
	width: 100%;
	height: auto;
}
.footer-share li + li {
	margin-left: 24px;
}
.footer-share a {
	transition: all 300ms ease-out;
}
.footer-share a:hover {
	opacity: 0.7;
}











/* ---------------------------------------------------------------------------------------------------- */
/* Top */

#top-kv {
	position: relative;
	min-height: 40vw;
}
#top-kv .bg {
	position: absolute;
	width: 100%;
	height: 40vw;
	left: 0;
	top: 0;
	z-index: 15;
}
#top-kv .bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#top-kv .content {
	box-sizing: border-box;
	position: relative;
	max-width: calc(1456px + 80px);
	z-index: 10;
	margin: 0 auto;
	padding: 40vw 40px 0;
	background: #111;
}
#top-kv .content .inner {
	box-sizing: border-box;
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 46px 40px;
}

#top-kv .primary {
	width: calc(100% - 690px);
}
#top-kv .secondary {
	width: 690px;
	background: rgba(255,255,255,0.1);
	backdrop-filter: blur(25px);
	-webkit-backdrop-filter: blur(25px);
}



#top-kv .primary ul {
	display: flex;
}

#top-kv .primary dl {
	display: flex;
	margin: 14px 0 0;
	font-size: 1.125rem;
}

#top-kv .primary li + li {
	margin-left: 40px;
}


#top-kv .primary dt {
	padding: 0 30px 0 0;
	background: url(../img/dots.png) right 15px top 50% no-repeat;
	background-size: 1px auto;
}



#top-kv .secondary .sns {
}
#top-kv .secondary .sns dl {
	display: flex;
	justify-content: space-between;
	padding: 18px 24px;
}
#top-kv .secondary .sns dt {
	display: flex;
	align-items: center;
	font-size: 0.875rem;
	font-family: "SST W20 Roman", sans-serif;
}
#top-kv .secondary .sns dd {
	display: flex;
}
#top-kv .secondary .sns dd a {
	width: 28px;
	height: 28px;
	transition: all 300ms ease-out;
}
#top-kv .secondary .sns img {
	width: 100%;
	height: auto;
}
#top-kv .secondary .sns dd a + a {
	margin-left: 28px;
}
#top-kv .secondary .sns dd a:hover {
	opacity: 0.7;
}




#top-kv a.modal-link {
	top: calc(20vw - 40px);
}






.top-section {
}

.top-section .inner {
	box-sizing: border-box;
	position: relative;
	max-width: calc(1456px + 80px);
	height: 100%;
	z-index: 10;
	margin: 0 auto;
	padding: 0 40px;
}




#top-intro {
	position: relative;
	padding: 120px 0;
}
#top-intro .bg {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1;
}
#top-intro .bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: left center;
}
#top-intro .bg span {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1;
	/*
	opacity: 0.5;
	*/
}

#top-intro .inner {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

#top-intro .text {
	width: calc(50% - 30px);
}
#top-intro .thumb {
	position: relative;
	width: calc(50% - 30px);
}
#top-intro .thumb img {
	width: 100%;
	height: auto;
}

#top-intro h2 {
	font-size: 2.5rem;
	line-height: 1.4;
}


html:lang(ja) #top-intro h2 {
	line-height: 1.5;
}

#top-intro p {
	margin: 30px 0 0;
	font-size: 1.25rem;
	line-height: 1.8;
}
#top-intro .link {
	margin: 35px 0 0;
}



#top-intro.full .inner {
	display: block;
}
#top-intro.full .text {
	width: 100%;
	max-width: 1020px;
	margin: 0 auto;
	text-align: center;
}




#top-index {
	position: relative;
	padding: 120px 0;
}
#top-index .bg {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1;
}
#top-index .bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#top-index .primary {
	display: flex;
	justify-content: space-between;
}
#top-index .primary .text {
	box-sizing: border-box;
	width: calc(100% - ((100% - 88px) / 3));
	padding-right: 200px;
}
#top-index .primary .thumb {
	position: relative;
	width: calc((100% - 88px) / 3);
}
#top-index .primary .thumb img {
	width: 100%;
	height: auto;
}


#top-index h2 {
	font-size: 2.5rem;
}
#top-index .primary p {
	margin: 35px 0 0;
	font-size: 1.25rem;
	line-height: 1.8;
}
#top-index .primary .link {
	margin: 35px 0 0;
	font-size: 1.125rem;
}


#top-index .primary .thumb dl {
	text-align: center;
}
#top-index .primary .thumb dt {
	font-size: 1.25rem;
	font-family: "SST W20 Roman", sans-serif;
	line-height: 1.4;
}
#top-index .primary .thumb dt + dd {
	margin-top: 20px;
}
#top-index .primary .thumb dd + dd {
	margin-top: 14px;
	line-height: 1.4;
}


#top-index .secondary {
	margin: 60px 0 0;
}
#top-index .secondary ul {
	display: flex;
	justify-content: space-between;
}
#top-index .secondary li {
	width: calc((100% - 88px) / 3);
}
#top-index .secondary li img {
	width: 100%;
	height: auto;
}
#top-index .secondary dl {
	margin: 24px 0 0;
}
#top-index .secondary dt {
	font-size: 2rem;
}
#top-index .secondary dd {
	margin-top: 15px;
	font-size: 0.875rem;
	line-height: 1.7;
}

#top-index .secondary .link {
	width: calc((100% - 88px) / 3);
	margin: 64px auto 0;
}




#top-slide {
	position: relative;
	padding: 120px 0;
}
#top-slide .slide {
	padding-bottom: 58px;
}
#top-slide .slide-item {
	position: relative;
	width: calc(100vw - 80px);
	max-width: 1456px;
	aspect-ratio: 192 / 100;
	background: #000;
}
#top-slide .slide-item dl {
	position: absolute;
	width: 33%;
	max-width: 500px;
	left: 96px;
	top: 120px;
}
#top-slide .slide-item dt {
	font-size: 3rem;
	line-height: 1.2;
}
#top-slide .slide-item dd {
	margin: 35px 0 0;
	font-size: 1.125rem;
	line-height: 1.75;
}

#top-slide .slide-item .image {
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	left: 48%;
	right: 96px;
	top: 75px;
	bottom: 75px;
}
#top-slide .slide-item .image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center center;
}




.slide-dots {
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	width: calc(100% - 80px);
	height: 34px;
	left: 50%;
	bottom: 0;
	z-index: 100;
	transform: translateX(-50%);
}
.slide-dots span {
	position: relative;
	display: block;
	width: 34px;
	height: 34px;
}
.slide-dots span + span {
	margin-left: 10px;
}
.slide-dots span a {
	position: relative;
	display: block;
	height: 34px;
	font-size: 0;
}
.slide-dots span a::before {
	position: absolute;
	content: "";
	display: block;
	width: 6px;
	height: 6px;
	left: calc(50% - 3px);
	top: calc(50% - 3px);
	z-index: 10;
	background: #999;
	border-radius: 3px;
}
.slide-dots span a::after {
	box-sizing: border-box;
	position: absolute;
	content: "";
	display: block;
	width: 29px;
	height: 29px;
	left: calc(50% - 14.5px);
	top: calc(50% - 14.5px);
	z-index: 1;
	border: 1px solid #999;
	border-radius: 15px;
	transition: all 300ms ease-out;
	opacity: 0;
}
.slide-dots span svg {
	position: absolute;
	width: 30px;
	height: 30px;
	left: calc(50% - 15px);
	top: calc(50% - 15px);
	pointer-events: none;
	transform: rotate(-90deg);
}
.slide-dots span circle {
	fill: transparent;
	stroke: #fff;
	stroke-width: 2;
	stroke-dasharray: 0 366;
	visibility: hidden;
}
.slide-dots span.active circle {
	stroke-dasharray: 366 366;
	visibility: visible;
	transition: all 16000ms linear 200ms;
}
.slide-dots span.active a::after {
	opacity: 1;
}




.slick-arrow {
	position: absolute;
	width: 28px;
	height: 52px;
	top: calc(50% - 26px);
	margin: 0;
	padding: 0;
	font-size: 0;
	border: none;
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: 100% auto;
	cursor: pointer;
}
.slick-prev {
	left: -54px;
	background-image: url(../img/arrow_slide_prev.svg);
}
.slick-next {
	right: -54px;
	background-image: url(../img/arrow_slide_next.svg);
}




.slide-dots button {
	position: absolute;
	width: 24px;
	height: 24px;
	bottom: 6px;
	margin: 0;
	padding: 0;
	font-size: 0;
	border: none;
	background-color: transparent;
	background-size: 24px auto;
	background-position: 50% 50%;
	background-repeat: no-repeat;
	cursor: pointer;
}

.slide-dots button.play {
	right: 0;
	background-image: url(../img/icon_slide_play.svg);
}
.slide-dots button.pause {
	right: 34px;
	background-image: url(../img/icon_slide_pause.svg);
}




#top-nav {
	position: sticky;
	height: 80px;
	left: 0;
	top: 0;
	z-index: 1100;
	background: #26282c;
}
#top-nav .inner {
	box-sizing: border-box;
	position: relative;
	max-width: calc(1456px + 80px);
	height: 100%;
	z-index: 10;
	margin: 0 auto;
	padding: 0 40px;
}
#top-nav ul {
	display: flex;
}
#top-nav li {
	width: calc(100% / 3);
	height: 80px;
}
#top-nav li a {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 80px;
	font-size: 1.25rem;
	transition: all 300ms ease-out;
}
#top-nav li a::after {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 4px;
	left: 0;
	bottom: 0;
	background: #fff;
	transition: all 300ms ease-out;
	transform: scaleX(0);
	transform-origin: left top;
}

#top-nav li a:hover {
	color: rgba(255,255,255,0.7);
}

#top-nav li.active a::after {
	transform: scaleX(1);
}

#top-nav li br {
	display: none;
}





#top-theme-list {
	padding: 60px 0 0;
}
.top-theme {
	padding: 60px 0;
}

.top-theme .intro {
	position: relative;
	display: flex;
	justify-content: space-between;
	padding-top: 40px;
}
.top-theme .intro .text {
	width: calc(50% - 40px);
}
.top-theme .intro .thumb {
	width: calc(50% - 40px);
	max-width: 456px;
}


.top-theme .intro::before {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 4px;
	left: 0;
	top: 0;
	background: #fff;
}
.top-theme .intro h2 {
	font-size: 4rem;
}
.top-theme .intro p {
	margin: 40px 0 0;
	font-size: 1.125rem;
	line-height: 1.8;
}

.top-theme .intro .thumb img {
	width: 100%;
	height: auto;
}
.top-theme .intro .thumb dl {
	text-align: center;
}
.top-theme .intro .thumb dt {
	font-size: 1.25em;
	font-family: "SST W20 Roman", sans-serif;
	line-height: 1.4;
}
.top-theme .intro .thumb dd {
	position: relative;
}
.top-theme .intro .thumb dt + dd {
	margin-top: 20px;
}
.top-theme .intro .thumb dd + dd {
	margin-top: 14px;
	line-height: 1.4;
}

.top-theme .intro .thumb a.modal-link {
	width: 64px;
	height: 64px;
	left: calc(50% - 32px);
	top: calc(50% - 32px);
}
.top-theme .intro .thumb a.modal-link::before {
	background-size: 14px auto;
}


.top-theme .list {
	margin: 80px 0 0;
}
.top-theme .list li {
	display: flex;
	justify-content: space-between;
}
.top-theme .list li + li {
	margin-top: 96px;
}
.top-theme .list li:nth-child(2n + 1) {
	flex-direction: row-reverse;
}

.top-theme .list li > * {
	width: calc(50% - 40px);
}

.top-theme .list .thumb img {
	width: 100%;
	height: auto;
}

.top-theme .list .text dt {
	font-size: 2rem;
	line-height: 1.6;
}
.top-theme .list .text dd {
	margin: 30px 0 0;
	font-size: 1.125rem;
	line-height: 1.8;
}
.top-theme .list .link {
	margin: 40px 0 0;
}
.top-theme .list .button {
	width: 284px;
}







/* ---------------------------------------------------------------------------------------------------- */
/* Scroll */

nav.ces.motion {
	transition: all 300ms ease-out;
}
#top-nav {
	transition: all 300ms ease-out;
}

body.fix-menu nav.ces {
	position: fixed;
	transform: translateY(-100%);
}
body.fix-menu.show-menu nav.ces {
	transform: translateY(0%);
}

body.fix-menu.show-menu.sticky-nav #top-nav {
	transform: translateY(72px);
}


body.fix-menu main {
	padding-top: 72px;
}











/* ---------------------------------------------------------------------------------------------------- */
/* 2nd */

.path-info {
	position: relative;
	box-sizing: border-box;
	max-width: calc(1456px + 180px);
	z-index: 10;
	margin: 32px auto 30px;
	padding: 0 90px;
	font-size: 0.875rem;
}
.path-info > * {

}
.path-info > span {
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}
.path-info a::after {
	display: inline-block;
	content: "/";
	margin: 0 8px;
}
.path-info a {
	position: relative;
	display: inline-block;
}

.path-info a i {
	position: absolute;
	display: block;
	width: calc(100% - 23px);
	height: 1px;
	left: 0;
	bottom: -1px;
	background: #fff;
	transform-origin: left top;
	transform: scaleX(0);
	transition: all 300ms ease-out;
}
.path-info a:hover i {
	transform: scaleX(1);
}







#wrap.detail main img {
	width: 100%;
	height: auto;
}

#wrap.detail main .primary h2 {
	font-weight: normal;
}

#wrap.detail main {
	position: relative;
	box-sizing: border-box;
	max-width: calc(1456px + 180px);
	min-height: 600px;
	z-index: 10;
	margin: 0 auto;
	padding: 0 90px 80px;
}
#wrap.news main {
	min-height: 600px;
}

#wrap.detail main > .inner {
	display: flex;
	justify-content: space-between;
}
#wrap.detail .primary {
	width: 62.5%;
	max-width: 910px;
}
#wrap.detail .secondary {
	width: 25.0%;
	max-width: 364px;
}








#wrap.detail .video {
	position: relative;
	padding-top: 56.25%;
}
#wrap.detail .video .video-inner {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}

#wrap.detail .video a .play {
	position: absolute;
	width: 80px;
	height: 80px;
	left: calc(50% - 40px);
	top: calc(50% - 40px);
	z-index: 10;
	font-size: 0;
	border-radius: 40px;
	background: rgba(0,0,0,0.10);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	transition: all 300ms ease-out;
}
#wrap.detail .video a .play::before {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	left: calc(50% - 8px);
	top: calc(50% - 10px);
	background: url(../img/icon_play_micro.svg) 50% 50% no-repeat;
	background-size: 16px auto;
}
#wrap.detail .video a:hover .play {
	background: rgba(0,0,0,0.15);
}

#wrap.detail .video .player {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 100;
}
#wrap.detail .video .player iframe {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}







#wrap.detail .text-version {
	margin: 24px 0 0;
}



#wrap.detail .detail {
	margin: 20px 0 0;
}

#wrap.detail .detail h1 {
	font-size: 2rem;
	line-height: 1.6;
}
#wrap.detail .detail .caption {
	margin: 25px 0 0;
}
#wrap.detail .detail .caption p {
	font-size: 1.125rem;
	line-height: 1.8;
}




#wrap.detail .share {
	margin: 35px 0 0;
}
#wrap.detail .share h2 {
	font-size: 1.5rem;
}
html:lang(ja) #wrap.detail .share h2 {
	font-size: 1.25rem;
}

#wrap.detail .share img {
	width: 28px;
	height: auto;
}
#wrap.detail .share ul {
	display: flex;
	margin: 12px 0 0;
}
#wrap.detail .share li + li {
	margin-left: 18px;
}
#wrap.detail .share li a {
	display: block;
	width: 28px;
	height: 28px;
	transition: all 300ms ease-out;
}
#wrap.detail .share li a:hover {
	opacity: 0.7;
}






#wrap.detail .related {
	margin: 45px 0 0;
}
#wrap.detail .related h2 {
	margin: 0 0 30px;
	font-size: 1.5rem;
}

#wrap.detail .related ul {
}
#wrap.detail .related li {
	display: flex;
	justify-content: space-between;
}
#wrap.detail .related li a {
}
#wrap.detail .related li + li {
	margin-top: 32px;
}
#wrap.detail .related .thumb {
	position: relative;
	width: 224px;
	min-height: 126px;
	overflow: hidden;
}
#wrap.detail .related .thumb a {
	display: block;
}
#wrap.detail .related .thumb a .play {
	position: absolute;
	width: 32px;
	height: 32px;
	left: calc(50% - 16px);
	top: calc(50% - 16px);
	font-size: 0;
	border-radius: 16px;
	background: rgba(0,0,0,0.4) url(../img/icon_play_micro.svg) 52% 50% no-repeat;
	background-size: 8px auto;
}

#wrap.detail .related dl {
	width: calc(100% - 224px - 18px);
}
#wrap.detail .related dt {
	position: relative;
	line-height: 1.4;
}
#wrap.detail .related dd p {
	font-size: 0.75rem;
	line-height: 1.65;
}
#wrap.detail .related dt + dd {
	margin-top: 12px;
}
#wrap.detail .related dd.link {
	margin: 8px 0 0;
	font-size: 0.75rem;
}


#wrap.detail .related .thumb a:focus-within .play {
	outline-color: Highlight;
	outline-color: -webkit-focus-ring-color;
	outline-style: auto;
	outline-width: 1px;
}

#wrap.detail .related dt a:not(.video-link) {
	background: linear-gradient(#fff, #fff) 0 100% / 0 1px no-repeat;
	transition: all 300ms ease-out;
}

#wrap.detail .related dt a:not(.video-link):hover {
	background-size: 100% 1px;
}


#wrap.detail .related .inner {
	overflow: hidden;
	transition: all 500ms ease-out;
}







#wrap.detail .related .more {
	box-sizing: border-box;
	margin: 50px auto 0;
	overflow: hidden;
}
#wrap.detail .related .more button {
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 40px;
	margin: 0 auto;
	padding: 0;
	font-size: 0.875rem;
	text-align: center;
	color: #fff;
	border: 1px solid #fff;
	background: transparent;
	cursor: pointer;
	transition: all 300ms ease-out;
}
#wrap.detail .related .more button:hover {
	color: #000;
	background: #fff;
}
#wrap.detail .related .more button i {
	position: relative;
	display: inline-block;
	box-sizing: border-box;
	width: 16px;
	height: 16px;
	margin-left: 10px;
	background: url(../img/icon_plus.svg) 50% 50% no-repeat;
	background-size: 8px auto;
	border-radius: 8px;
	border: 1px solid #fff;
	transition: all 300ms ease-out;
}

#wrap.detail .related.show-all .more button i {
	background-image: url(../img/icon_minus.svg);
}
#wrap.detail .related .more button:hover i {
	transform: rotate(180deg);
	filter: invert(1);
}













.accordion {
	position: relative;
	z-index: 10;
}
.accordion + .accordion {
	margin-top: 80px;
}
.accordion h3 {
	margin: 0 0 26px;
	font-size: 1.75rem;
}
.accordion li + li {
	margin-top: 32px;
}
.accordion li a {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.accordion .thumb {
	width: 160px;
	overflow: hidden;
}
.accordion .content {
	box-sizing: border-box;
	width: calc(100% - 160px - 24px);
	padding-right: 16px;
}
.accordion .title {
	display: inline-block;
}
.accordion .active a {
	background: #25282c;
}

/*
#wrap.detail .accordion a .title {
	background: linear-gradient(#fff, #fff) 0 100% / 0 1px no-repeat;
	transition: all 300ms ease-out;
}
#wrap.detail .accordion a:hover .title {
	background-size: 100% 1px;
}
*/


.accordion .title {
	line-height: 1.2;
}

.accordion li a:hover .title {
	text-decoration: underline;
}


html:lang(ja) .accordion .title {
	line-height: 1.4;
	font-size: 0.9375rem;
}












/* ---------------------------------------------------------------------------------------------------- */
/* Press Room */

#wrap.news main {
	min-height: calc(100vh - 72px - 72px - 76px - 80px - 56px - 74px);
}

.news-list {
	box-sizing: border-box;
	max-width: calc(1456px + 80px);
	margin: 0 auto 0;
	padding: 20px 40px 0;
}
.news-list h1 {
	font-size: 2.5rem;
}

.news-list ul {
	margin: 40px 0 0;
}
.news-list li {
}
.news-list li + li {
}
.news-list a {
	box-sizing: border-box;
	position: relative;
	display: flex;
	justify-content: space-between;
	width: 100%;
	padding: 30px 140px 30px 40px;
	transition: all 300ms ease-out;
}
.news-list .date {
	display: grid;
	grid-template-columns: 64px 256px;
	grid-template-rows: 20px 22px;
	width: 320px;
}
.news-list .date .day {
	position: relative;
	grid-column: 1 / 2;
	grid-row: 1 / 3;
	top: -1px;
	font-size: 2.5rem;
}
.news-list .date .year {
	grid-column: 2 / 3;
	grid-row: 1 / 2;
	font-size: 0.875rem;
}
.news-list .date .month {
	grid-column: 2 / 3;
	grid-row: 2 / 3;
	font-size: 1rem;
}


.news-list dl {
	box-sizing: border-box;
	width: calc(100% - 320px);
}
.news-list dt {
	position: relative;
	display: inline-block;
	font-size: 1.125rem;
	line-height: 1.4;
}
.news-list dd {
	margin: 8px 0 0;
	font-size: 1rem;
	line-height: 1.5;
}

.news-list dt i {
	position: absolute;
	display: block;
	width: calc(100%);
	height: 1px;
	left: 0;
	bottom: 2px;
	background: #fff;
	transform-origin: left top;
	transform: scaleX(0);
	transition: all 300ms ease-out;
}

.news-list a:hover {
	background: #26282c;
}
.news-list a:hover dt i {
	transform: scaleX(1);
}



.news-list .popup {
	position: absolute;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 24px;
	height: 24px;
	right: 40px;
	top: calc(50% - 12px);
	border: 1px solid #fff;
	border-radius: 12px;
	transition: all 300ms ease-out;
}
.news-list .popup img {
	width: 8px;
	height: auto;
	transition: all 300ms ease-out;
}

.news-list a:hover .popup {
	background: #fff;
}
.news-list a:hover .popup img {
	filter: invert(1);
}









/* ---------------------------------------------------------------------------------------------------- */
/* Text Version */

#wrap.text-version main {
	min-height: calc(100vh - 72px - 72px - 76px - 80px - 56px - 74px);
}

.text-version-section {
	box-sizing: border-box;
	max-width: calc(1456px + 80px);
	margin: 0 auto 0;
	padding: 20px 40px 0;
}
.text-version-section h1 {
	font-size: 2.0rem;
}

.text-version-section .box {
	margin: 64px 0 0;
}
.text-version-section h2 {
	margin: 0 0 20px;
	font-size: 1.5rem;
}
.text-version-section p {
	font-size: 1rem;
	line-height: 1.5;
}
.text-version-section p + p {
	margin-top: 1.5em;
}







/* ---------------------------------------------------------------------------------------------------- */
/* Modal */

#video-overlay {
	position: fixed;
	width: 100vw;
	height: 100vh;
	left: 0;
	top: 0;
	z-index: 1000000;
	background: rgba(0,0,0,0.9);
	
	opacity: 0;
	transition: all 300ms ease-out;
}
body[data-player="on"] #video-overlay {
	opacity: 1;
}


#video-player {
	position: fixed;
	width: 960px;
	height: 540px;
	left: calc(50% - 480px);
	top: calc(50% - 270px);
	z-index: 1000010;
	
	opacity: 0;
	transition: all 300ms ease-out;
}
body[data-player="on"] #video-player {
	opacity: 1;
	transition-delay: 150ms;
}

#video-player iframe {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}

#video-close {
	position: fixed;
	display: block;
	width: 50px;
	height: 50px;
	right: 50px;
	top: 50px;
	z-index: 1000020;
	font-size: 0;
	
	opacity: 0;
	transition: all 300ms ease-out;
}
body[data-player="on"] #video-close {
	opacity: 1;
	transition-delay: 300ms;
}

#video-close::before,
#video-close::after {
	position: absolute;
	content: "";
	display: block;
	width: 50px;
	height: 1px;
	left: 0px;
	top: calc(50% - 1px);
	background: #fff;
}
#video-close::before {
	transform: rotate(45deg);
}
#video-close::after {
	transform: rotate(-45deg);
}




#viewer-overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1000000;
	background: rgba(0,0,0,0.9);
}
#viewer-btn {
	position: fixed;
	width: 50px;
	height: 50px;
	right: 50px;
	top: 50px;
	z-index: 1000010;
	margin: 0;
	padding: 0;
	font-size: 0;
	border: none;
	cursor: pointer;
	background: none;
}
#viewer-image {
	position: fixed;
	width: calc(100% - 140px);
	max-width: 1200px;
	height: auto;
	max-height: 100vh;
	padding-top: 56.25%;
	left: 50%;
	top: 50%;
	z-index: 10020;
	transform: translate(-50%, -50%);
}
#viewer-image img {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	object-fit: contain;
	object-position: center center;
}
#viewer-image img.coming {
	opacity: 0;
	transition: opacity 500ms linear;
}
#viewer-image img.coming.show {
	opacity: 1;
}

#viewer-btn::before,
#viewer-btn::after {
	position: absolute;
	content: "";
	display: block;
	width: 50px;
	height: 1px;
	left: 0px;
	top: calc(50% - 1px);
	background: #fff;
}
#viewer-btn::before {
	transform: rotate(45deg);
}
#viewer-btn::after {
	transform: rotate(-45deg);
}


#viewer-overlay,
#viewer-btn {
	opacity: 0;
	transition: all 300ms ease-out;
}
body.viewer #viewer-overlay,
body.viewer #viewer-btn {
	opacity: 1;
}

#viewer-image {
	opacity: 0;
	transition: opacity 500ms ease-out 150ms;
}
body.viewer #viewer-image {
	opacity: 1;
}

#viewer-image.hide {
	transition-duration: 300ms;
	transition-delay: 0ms;
}


#viewer-prev,
#viewer-next {
	position: fixed;
	width: 50px;
	height: 50px;
	top: calc(50% - 25px);
	z-index: 1000020;
	border: none;
	font-size: 0;
	cursor: pointer;
	filter: brightness(0) invert(1);
	opacity: 0;
	transition: all 300ms ease-out;
}
#viewer-prev {
	left: 0;
	background: transparent url(../img/arrow_slide_prev.svg) 50% 50% no-repeat;
	background-size: 20px auto;

}
#viewer-next {
	right: 0;
	background: transparent url(../img/arrow_slide_next.svg) 50% 50% no-repeat;
	background-size: 20px auto;
}
body.viewer #viewer-prev,
body.viewer #viewer-next {
	opacity: 1;
}
#viewer-prev:disabled,
#viewer-next:disabled {
	opacity: 0.5 !important;
	cursor: default;
	
	/*
	display: none !important;
	*/
}


@media screen and (min-width:1340px) {
	#viewer-prev {
		left: calc(50% - 600px - 20px - 50px);
	}
	#viewer-next {
		right: calc(50% - 600px - 20px - 50px);
	}
}










#wrap.teaser {
}
#wrap.teaser #lang-menu ul {
	background: #000;
}

#wrap.teaser main {
	box-sizing: border-box;
	min-height: calc(100vh - 70px - 80px - 73px - 56px);
	padding: 80px 0 0;
}

#wrap.teaser #top-video .video {
	position: relative;
	width: 960px;
	height: 540px;
	margin: 0 auto;
}
#wrap.teaser #top-video .video img,
#wrap.teaser #top-video .video iframe {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}


#wrap.teaser #top-video a .play {
	position: absolute;
	width: 80px;
	height: 80px;
	left: calc(50% - 40px);
	top: calc(50% - 40px);
	z-index: 10;
	font-size: 0;
	border-radius: 40px;
	background: rgba(0,0,0,0.10);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	transition: all 300ms ease-out;
}
#wrap.teaser #top-video a .play::before {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	left: calc(50% - 8px);
	top: calc(50% - 10px);
	background: url(../img/icon_play_micro.svg) 50% 50% no-repeat;
	background-size: 16px auto;
}
#wrap.teaser #top-video a:hover .play {
	background: rgba(0,0,0,0.15);
}




#wrap.teaser .teaser-description {
	width: 960px;
	margin: 40px auto 0;
	text-align: center;
	color: #fff;
}
#wrap.teaser .teaser-description h1 {
	font-size: 3.5rem;
	font-family: "SST W20 Bold", sans-serif;
}
#wrap.teaser .teaser-description p {
	margin: 24px 0 0;
	font-size: 1.5rem;
	font-family: "SST W20 Medium", sans-serif;
	line-height: 1.4;
}
#wrap.teaser .teaser-description p .sp {
	display: none;
}

#wrap.teaser .teaser-description .asl {
	margin: 30px 0 0;
}
#wrap.teaser .teaser-description .enter {
	margin: 15px 0 0;
}
#wrap.teaser .teaser-description .enter a {
	font-size: 1.125rem;
	font-family: "SST W20 Bold", sans-serif;
}



html:lang(ja) #wrap.teaser .teaser-description h1 {
	font-size: 3.25rem;
	font-family: "SST W55 Bold", sans-serif;
}

html:lang(ja) #wrap.teaser .teaser-description p {
	font-size: 1.25rem;
	font-family: "SST W55 Bold", sans-serif;
	line-height: 1.5;
}



/*
@media screen and (max-width:1280px) {
	#wrap.teaser main {
		padding: 45px 0 60px;
	}
	#wrap.teaser #top-video .video {
		width: 640px;
		height: 360px;
	}
	#wrap.teaser .teaser-description {
		width: 640px;
		margin-top: 24px;
	}
	#wrap.teaser .teaser-description h1 {
		margin-bottom: 20px;
		padding-bottom: 20px;
		font-size: 2.5rem;
	}
	#wrap.teaser .teaser-description p {
		font-size: 1.25rem;
	}
}
*/

















/*
@media screen and (min-width:1640px) {
	.top-content h2 {
		font-size: 1.5rem;
	}
	.top-content h3 {
		left: -4px;
		font-size: 5rem;
	}
	.top-content .content1 dl {
		font-size: 1.125rem;
	}
	
	.top-content .content2 p {
		font-size: 1.5rem;
	}
	.top-content .content2 .sns dt {
		font-size: 0.875rem;
	}
	
	
	#top-intro h2 {
		font-size: 5rem;
	}
	#top-intro p {
		font-size: 1.5rem;
	}
	
	#top-report h2 {
		font-size: 3rem;
	}
	#top-report .box dt + dd {
		font-size: 1.25rem;
	}
	
	.theme h2 {
		font-size: 4rem;
	}
	.theme p {
		font-size: 1.25rem;
	}
	.theme .intro .booth dt {
		font-size: 2rem;
	}
	html:lang(ja) .theme .intro .booth dt {
		font-size: 1.25rem;
	}
	
	.theme .intro .box {
		width: 64%;
	}
	.theme .intro .booth {
		width: 36%;
	}
	
	.item-list dt {
		font-size: 2.25rem;
	}
	.item-list dt + dd {
		font-size: 1.125rem;
	}
	
	
	#wrap.detail .detail h1 {
		font-size: 2.25rem;
	}
	#wrap.detail .detail .caption p {
		font-size: 1.125rem;
	}
	
	
	.accordion h3 {
		font-size: 1.75rem;
	}
}

@media screen and (max-width:1639px) {
	.top-content h2 {
		font-size: 1.25rem;
	}
	.top-content h3 {
		left: -4px;
		font-size: 4.5rem;
	}
	.top-content .content1 dl {
		font-size: 1rem;
	}
	
	.top-content .content2 p {
		font-size: 1.375rem;
	}
	.top-content .content2 .sns dt {
		font-size: 0.75rem;
		line-height: 1.4;
	}
	
	
	#top-intro h2 {
		font-size: 4.25rem;
	}
	#top-intro p {
		font-size: 1.375rem;
	}
	
	#top-report h2 {
		font-size: 2.75rem;
	}
	#top-report .box dt + dd {
		font-size: 1.125rem;
	}
	
	.theme h2 {
		font-size: 3.5rem;
	}
	.theme p {
		font-size: 1.125rem;
		margin-right: 80px;
	}
	.theme .intro .booth dt {
		font-size: 1.75rem;
	}
	html:lang(ja) .theme .intro .booth dt {
		font-size: 1.25rem;
	}
	
	.theme .intro .box {
		width: calc(100% - 500px);
	}
	.theme .intro .booth {
		width: 500px;
	}
	
	.item-list dt {
		font-size: 2.125rem;
	}
	.item-list dt + dd {
		font-size: 1.0625rem;
	}
	
	
	#wrap.detail .detail h1 {
		font-size: 2.125rem;
	}
	#wrap.detail .detail .caption p {
		font-size: 1.0625rem;
	}
	
	
	.accordion h3 {
		font-size: 1.75rem;
	}
}

@media screen and (max-width:1480px) {
	.top-content h2 {
		font-size: 1.25rem;
	}
	.top-content h3 {
		left: -4px;
		font-size: 3.5rem;
	}
	.top-content .content1 dl {
		font-size: 0.8125rem;
	}
	
	.top-content .content2 p {
		font-size: 1.25rem;
	}
	.top-content .content2 .sns dt {
		font-size: 0.75rem;
		line-height: 1.4;
	}
	
	
	#top-intro h2 {
		font-size: 3.5rem;
	}
	#top-intro p {
		font-size: 1.25rem;
	}
	
	#top-report h2 {
		font-size: 2.5rem;
	}
	#top-report .box dt + dd {
		font-size: 1.125rem;
	}
	
	.theme h2 {
		font-size: 2.5rem;
	}
	.theme p {
		font-size: 1.125rem;
		margin-right: 40px;
	}
	.theme .intro .booth dt {
		font-size: 1.5rem;
	}
	
	.theme .intro .box {
		width: calc(100% - 450px);
	}
	.theme .intro .booth {
		width: 450px;
	}
	
	.item-list dt {
		font-size: 1.875rem;
	}
	.item-list dt + dd {
		font-size: 1rem;
	}
	
	
	#wrap.detail .detail h1 {
		font-size: 2rem;
	}
	#wrap.detail .detail .caption p {
		font-size: 1rem;
	}
	
	
	.accordion h3 {
		font-size: 1.625rem;
	}
}

@media screen and (max-width:1280px) {
}

*/








#transition-overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 10000;
	pointer-events: none;
	opacity: 0;
}
#transition-overlay span {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	visibility: hidden;
}
#transition-overlay img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#transition-overlay.show {
	opacity: 1;
	transition: all 500ms ease-out;
}


#transition-overlay.hide {
	display: none;
}


#wrap.detail #transition-overlay.fade-out {
	opacity: 0 !important;
	transition: all 300ms ease-out;
}
#wrap.detail #transition-overlay.ready span {
	visibility: visible;
}


/* -------------- 20250214追記*/
span.copyright { 
	font-size: .8rem; 
}

div#top-intro h2 {
		font-size: 1.8rem; 
	}


