@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:active {
	color: #fff;
}
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_sp) 50% 0 repeat-y;
}
body::before,
body::after {
	position: fixed;
	display: block;
	content: "";
	width: 1px;
	height: 100%;
	top: 0;
	z-index: 1;
	background: #25282C;
}
body::before {
	left: 24px;
}
body::after {
	right: 24px;
}


button {
	font-family: "SST W20 Roman", sans-serif;
}
a {
	color: #fff;
	cursor: pointer;
}

iframe {
	border: 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;
}





#wrap.detail .related li a
{
	font-family: "SST W20 Bold", 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;
}



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


main {
	position: relative;
	z-index: 10;
}
#wrap.index main {
}









a.modal-link  {
	position: absolute;
	display: block;
	width: 64px;
	height: 64px;
	left: calc(50% - 32px);
	top: calc(50% - 32px);
	z-index: 50;
	font-size: 0;
	border-radius: 32px;
	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: 14px auto;
}
 a.modal-link:active {
	background: rgba(0,0,0,0.15);
}




a.video-link {
	position: relative;
	display: inline-block;
}
a.video-link::before {
	box-sizing: border-box;
	position: relative;
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	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: 5px auto;
	vertical-align: middle;
}
a.video-link i {
	position: absolute;
	display: block;
	width: calc(100% - 22px);
	height: 1px;
	left: 22px;
	bottom: -1px;
	background: #fff;
	transform-origin: left top;
	transform: scaleX(0);
	transition: all 300ms ease-out;
}
a.video-link:active i {
	transform: scaleX(1);
}



a.text-link {
	position: relative;
	display: inline-block;
}
a.text-link::after {
	position: relative;
	content: "";
	display: inline-block;
	width: 16px;
	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:active::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:active 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:active::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:active::after {
	transform: translateX(3px);
}






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





.return-top {
	max-width: 284px;
	margin: 48px auto 64px;
}
.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: 16px;
	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;
}
#wrap > header.sony {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	height: 48px;
	left: 0;
	top: 0;
	z-index: 1000;
	background: #000;
}
#wrap > header.sony .logo {
	margin: 0 0 0 22px;
}
#wrap > header.sony img {
	width: 80px;
	height: auto;
}




nav.ces {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 48px;
	top: 0;
	z-index: 1100;
	background: #25282c;
}

nav.ces h1 {
	position: relative;
	z-index: 10;
	font-size: 22px;
}
nav.ces h1 .at {
	position: relative;
	margin: 0 4px;
	top: -1px;
	font-size: 16px;
}
nav.ces h1 .event {
	font-size: 18px;
}

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: 58px;
	height: 48px;
	right: 0;
	top: 0;
	z-index: 1;
	font-size: 14px;
}
#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: 14px;
	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% - 5px);
	background: #25282c;
}
#lang-menu li + li {
}
#lang-menu .en a {
	text-indent: 1px;
}




#lang-menu .current a:hover {
	text-decoration: none;
}

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






#lang-menu ul {
	visibility: hidden;
	opacity: 0;
	transform: translateY(-20px);
	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: 18px;
	height: 1px;
	left: calc(50% - 9px);
	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: 30px 25px;
	font-size: 14px;
}
#wrap > footer .nav nav a {
	display: inline-block;
	padding: 4px 24px;
	color: #626262;
	text-decoration: none;
	background: #fff url(../img/arrow.svg) 14px 50% no-repeat;
	background-size: 6px auto;
	border-radius: 20px;
}
#wrap > footer .nav ul {
	margin: 22px 0 0;
}
#wrap > footer .nav li + li {
	margin-top: 22px;
}
#wrap > footer .nav li a {
	color: #898991;
}
#wrap > footer .copyright {
	margin: 30px 0 0;
	color: #898991;
	font-size: 14px;
}





/* 
.other-events  {
	position: relative;
	box-sizing: border-box;
	z-index: 10;
	margin: 64px 0 0;
	background: #000;
}
.other-events .extra {
	position: relative;
	display: flex;
	align-items: center;
	margin: 0 auto;
	padding: 12px 24px;
}
.other-events a {
	position: relative;
	box-sizing: border-box;
	display: inline-block;
	padding-right: 15px;
	font-size: 14px;
	color: #fff;
	transition: all 300ms ease-out;
}
.other-events a span {
	position: relative;
	display: inline-block;
	width: 14px;
	height: 100%;
	z-index: 1;
	font-size: 0;
}

.other-events a::before,
.other-events a::after {
	position: absolute;
	content: "";
	display: block;
	width: 10px;
	height: 10px;
	right: 12px;
	z-index: 10;
	top: calc(50% - 5px);
	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:active::after {
	transform: translate(2px, -2px);
}
 */






.footer-link {
	position: relative;
	z-index: 10;
	margin: 64px 24px;
}

.footer-link a {
	position: relative;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	width: 100%;
	height: 56px;
	color: #fff;
	font-size: 14px;
	overflow: hidden;
}
.footer-link a + a {
	margin-top: 16px;
}
.footer-link a .label {
	box-sizing: border-box;
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	height: 100%;
	z-index: 50;
	padding: 0 32px;
}

.footer-link a::before {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 10;
	background: linear-gradient(to right, #154fbd, #bd5f55);
	transition: all 300ms ease-out;
	transform: translateX(-100%);
	transform-origin: left top;
}
.footer-link a:active::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: 12px;
	height: 12px;
	right: 30px;
	top: calc(50% - 6px);
	z-index: 20;
	background: url(../img/arrow_diagonal.svg) 50% 50% no-repeat;
	background-size: 12px auto;
	transition: all 300ms ease-out;
	will-change: transform;
}
.footer-link a .label:active::after {
	transform: translate(3px,-3px);
}






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


















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

#top-kv {
	position: relative;
	padding: 0 0 40px;
	background: #000;
}
#top-kv .bg {
	position: absolute;
	width: 100%;
	height: 75vw;
	left: 0;
	top: 0;
	z-index: 1;
}
#top-kv .bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#top-kv .content {
	position: relative;
	z-index: 10;
	padding-top: calc(75vw + 24px);
}
#top-kv .content .inner {
	padding: 0 24px;
}

#top-kv .primary {
}
#top-kv .secondary {
	margin: 24px 0 0;
	background: #202020;
}



#top-kv .primary ul {
	height: 60px;
	font-size: 1.0rem;
}

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

#top-kv .primary dl {
	margin: 8px 0 0;
	font-size: 1.125rem;
}
#top-kv .primary dt {
	display: inline-block;
	padding: 0 28px 0 0;
	background: url(../img/dots.png) right 14px top 50% no-repeat;
	background-size: 1px auto;
}
#top-kv .primary dd {
	margin: 8px 0 0;
}
#top-kv .primary dd a {
	line-height: 1.4;
}


#top-kv .secondary .sns {
}
#top-kv .secondary .sns dl {
	padding: 16px 10px;
}
#top-kv .secondary .sns dt {
	text-align: center;
	font-size: 0.75rem;
	line-height: 1.3;
	font-family: "SST W20 Roman", sans-serif;
}
#top-kv .secondary .sns dd {
	display: flex;
	justify-content: center;
	margin: 12px 0 0;
}
#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: 24px;
}
#top-kv .secondary .sns dd a:active {
	opacity: 0.7;
}




#top-kv a.modal-link {
	top: calc((75vw - 60px) / 2);
}






.top-section {
}

.top-section .inner {
	box-sizing: border-box;
	position: relative;
	height: 100%;
	z-index: 10;
	margin: 0 auto;
	padding: 0 24px;
}




#top-intro {
	position: relative;
	padding: 40px 0 64px;
}
#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;
}
#top-intro .bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}
#top-intro .bg span {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 1;
	/*
	opacity: 0.5;
	*/
}


#top-intro .inner {
}

#top-intro .text {
}

#top-intro .thumb img {
	width: 100%;
	height: auto;
}

#top-intro h2 {
	font-size: 1.375rem;
	line-height: 1.4;
}
#top-intro p {
	margin: 25px 0 0;
	font-size: 0.875rem;
	line-height: 1.8;
}
#top-intro .link {
	margin: 25px 0 0;
}

#top-intro .thumb {
	position: relative;
	margin: 35px 0 0;
}
#top-intro .thumb a.modal-link {
	width: 48px;
	height: 48px;
	left: calc(50% - 24px);
	top: calc(50% - 24px);
}
#top-intro .thumb a.modal-link::before {
	background-size: 12px auto;
}






#top-index {
	position: relative;
	padding: 40px 0 64px;
}
#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 {
}
#top-index .primary .text {
}

#top-index h2 {
	font-size: 1.375rem;
}
#top-index .primary p {
	margin: 25px 0 0;
	font-size: 0.875rem;
	line-height: 1.8;
}
#top-index .primary .link {
	margin: 25px 0 0;
	font-size: 1.125rem;
}
#top-index .primary .link a {
	line-height: 1.3;
}

#top-index .primary .thumb {
	position: relative;
	margin: 40px 0 0;
}
#top-index .primary .thumb img {
	width: 100%;
	height: auto;
}

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


#top-index .secondary {
	margin: 40px 0 0;
}
#top-index .secondary ul {
}
#top-index .secondary li {
}
#top-index .secondary li + li {
	margin-top: 40px;
}
#top-index .secondary li img {
	width: 100%;
	height: auto;
}
#top-index .secondary dl {
	margin: 20px 0 0;
}
#top-index .secondary dt {
	font-size: 1.875rem;
}
#top-index .secondary dd {
	margin-top: 14px;
	font-size: 0.875rem;
	line-height: 1.7;
}

#top-index .secondary .link {
	margin: 40px auto 0;
}




#top-slide {
	position: relative;
	padding: 40px 0;
}
#top-slide .slide {
	padding-bottom: 94px;
}
#top-slide .slide-item {
	position: relative;
	width: calc(100vw - 48px);
	background: #000;
}
#top-slide .slide-item dl {
	box-sizing: border-box;
	width: 80%;
	padding: 32px 0 0 24px;
}
#top-slide .slide-item dt {
	font-size: 1.5rem;
}
#top-slide .slide-item dd {
	margin: 15px 0 0;
	font-size: 0.75rem;
	line-height: 1.75;
}

#top-slide .slide-item .image {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 45px 24px 32px;
}
#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: 36px;
	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: 24px;
	height: 24px;
	bottom: -50px;
	margin: 0;
	padding: 0;
	font-size: 0;
	border: none;
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: 12px auto;
	cursor: pointer;
}
.slick-prev {
	left: -5px;
	background-image: url(../img/arrow_slide_prev_mini.svg);
}
.slick-next {
	right: -5px;
	background-image: url(../img/arrow_slide_next_mini.svg);
}




.slide-dots button {
	position: absolute;
	width: 24px;
	height: 24px;
	left: calc(50% - 12px);
	bottom: -36px;
	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 {
	margin-left: -16px;
	background-image: url(../img/icon_slide_play.svg);
}
.slide-dots button.pause {
	margin-left: 16px;
	background-image: url(../img/icon_slide_pause.svg);
}




#top-nav {
	position: sticky;
	height: 64px;
	left: 0;
	top: 0;
	z-index: 1100;
	background: #26282c;
}
#top-nav .inner {
}
#top-nav ul {
	display: flex;
}
#top-nav li {
	width: calc(100% / 3);
	height: 64px;
}
#top-nav li a {
	box-sizing: border-box;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 64px;
	padding-bottom: 4px;
	font-size: 0.875rem;
	line-height: 1.3;
	text-align: center;
	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-theme-list {
}
.top-theme {
	padding: 40px 0;
}

.top-theme .intro {
	position: relative;
	padding-top: 24px;
}


.top-theme .intro::before {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 4px;
	left: 0;
	top: 0;
	background: #fff;
}

.top-theme .intro .text {
}

.top-theme .intro h2 {
	font-size: 1.875rem;
}
.top-theme .intro p {
	margin: 20px 0 0;
	font-size: 0.75rem;
	line-height: 1.8;
}

.top-theme .intro .thumb {
	margin: 40px 0 0;
}
.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.125em;
	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: 18px;
}
.top-theme .intro .thumb dd + dd {
	margin-top: 14px;
	line-height: 1.4;
}

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


.top-theme .list {
	margin: 40px 0 0;
}
.top-theme .list li {
	display: flex;
	flex-direction: column-reverse;
}
.top-theme .list li + li {
	margin-top: 64px;
}
.top-theme .list li:nth-child(2n + 1) {
}

.top-theme .list li > * {
}

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

.top-theme .list .text {
	margin: 24px 0 0;
}
.top-theme .list .text dt {
	font-size: 1.5rem;
	line-height: 1.4;
}
.top-theme .list .text dd {
	margin: 15px 0 0;
	font-size: 0.75rem;
	line-height: 1.8;
}
.top-theme .list .link {
	margin: 35px 0 0;
}
.top-theme .list .button {
}







/* ---------------------------------------------------------------------------------------------------- */
/* 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(48px);
}


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
















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

.path-info {
	position: relative;
	box-sizing: border-box;
	z-index: 10;
	margin: 10px auto;
	padding: 0 20px;
	font-size: 0.625rem;
}
.path-info > * {

}
.path-info > span {
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}
.path-info a::after {
	display: inline-block;
	content: "/";
	margin: 0 5px;
}
.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:active i {
	transform: scaleX(1);
}












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

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


#wrap.detail main {
	position: relative;
	z-index: 10;
}

#wrap.detail main > .inner {
}
#wrap.detail .primary {
}
#wrap.detail .secondary {
	margin: 64px 0 0;
}




#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: 48px;
	height: 48px;
	left: calc(50% - 24px);
	top: calc(50% - 24px);
	z-index: 10;
	font-size: 0;
	border-radius: 24px;
	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: 12px auto;
}
#wrap.detail .video a:active .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: 20px 24px 0;
}







#wrap.detail .detail {
	margin: 16px 24px 0;
}
#wrap.detail .detail h1 {
	font-size: 1.5rem;
	line-height: 1.4;
}
#wrap.detail .detail .caption {
	margin: 15px 0 0;
}
#wrap.detail .detail .caption p {
	font-size: 1rem;
	line-height: 1.5;
}












#wrap.detail .share {
	margin: 30px 24px 0;
}
#wrap.detail .share h2 {
	font-size: 1.125rem;
}
#wrap.detail .share img {
	width: 28px;
	height: auto;
}
#wrap.detail .share ul {
	display: flex;
	margin: 15px 0 0;
}
#wrap.detail .share li + li {
	margin-left: 12px;
}











#wrap.detail .related {
	margin: 48px 24px 0;
}
#wrap.detail .related h2 {
	font-size: 1.125rem;
	margin-bottom: 20px;
}
#wrap.detail .related ul {
}
#wrap.detail .related li {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#wrap.detail .related li a {
	word-break: break-all;
}
#wrap.detail .related li + li {
	margin-top: 20px;
}
#wrap.detail .related .thumb {
	position: relative;
	width: 160px;
	min-height: 90px;
	overflow: hidden;
}
#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% - 160px - 12px);
}
#wrap.detail .related dt {
	font-size: 1rem;
	line-height: 1.3;
}
#wrap.detail .related dd.content {
	display: none;
}
#wrap.detail .related dd.link {
	margin: 8px 0 0;
	font-size: 0.6875rem;
}
#wrap.detail .related dt {
	position: relative;
	line-height: 1.4;
}

#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):active {
	background-size: 100% 1px;
}






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




#wrap.detail .related .more {
	box-sizing: border-box;
	margin: 32px 0 0;
}
#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:active {
	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 .more button:active i {
	filter: invert(1);
}

#wrap.detail .related.show-all .more button i {
	background-image: url(../img/icon_minus.svg);
}







.accordion {
	position: relative;
}
.accordion + .accordion {
	margin-top: 64px;
}
.accordion h3 {
	margin: 0 0 18px 24px;
	font-size: 1.875rem;
	line-height: 1.2;
}

.accordion ul {
	margin: 0 24px;
}
.accordion li a {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.accordion li + li {
	margin-top: 20px;
}
.accordion .thumb {
	width: 160px;
	overflow: hidden;
}
.accordion .content {
	width: calc(100% - 160px - 12px);
}
.accordion .title {
	font-size: 1rem;
	line-height: 1.3;
	word-break: break-all;
}
.accordion .active a {
	background: #25282c;
}


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










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

.news-list {
	box-sizing: border-box;
	margin-bottom: -24px;
	padding: 14px 0 0;
}
.news-list h1 {
	margin-left: 24px;
	font-size: 2rem;
}

.news-list ul {
	margin: 20px 0 0;
}
.news-list li {
}
.news-list li + li {
}
.news-list a {
	box-sizing: border-box;
	position: relative;
	display: block;
	width: 100%;
	padding: 20px 60px 20px 24px;
}

.news-list .date {
	display: grid;
	grid-template-columns: 38px auto;
	grid-template-rows: 12px 12px;
}
.news-list .date .day {
	position: relative;
	grid-column: 1 / 2;
	grid-row: 1 / 3;
	top: -1px;
	font-size: 1.5rem;
}
.news-list .date .year {
	grid-column: 2 / 3;
	grid-row: 1 / 2;
	font-size: 0.625rem;
}
.news-list .date .month {
	grid-column: 2 / 3;
	grid-row: 2 / 3;
	font-size: 0.625rem;
}


.news-list dl {
	box-sizing: border-box;
	margin: 10px 0 0;
}
.news-list dt {
	position: relative;
	display: inline-block;
	font-size: 1rem;
	line-height: 1.3;
}
.news-list dd {
	margin: 6px 0 0;
	font-size: 0.875rem;
	line-height: 1.4;
}






.news-list .popup {
	position: absolute;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 24px;
	height: 24px;
	right: 24px;
	top: 44px;
	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:active .popup {
}
.news-list a:active .popup img {
}









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

.text-version-section {
	padding: 14px 24px 0;
}
.text-version-section h1 {
	font-size: 1.5rem;
	line-height: 1.4;
}

.text-version-section .box {
	margin: 48px 0 0;
}
.text-version-section h2 {
	margin: 0 0 20px;
	font-size: 1.125rem;
	line-height: 1.3;
}
.text-version-section p {
	font-size: 0.875rem;
	line-height: 1.4;
}
.text-version-section p + p {
	margin-top: 1.4em;
}












/* ---------------------------------------------------------------------------------------------------- */
/* 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;
	box-sizing: border-box;
	width: calc(100vw - 40px);
	height: calc((100vw - 40px) * 0.5625);
	left: 20px;
	top: calc(50% - calc((100vw - 40px) * 0.5625 * 0.5));
	z-index: 1000010;
	
	opacity: 0;
	transition: all 300ms ease-out;
}
#video-player.vertical {
	width: 248px;
	height: 440px;
	left: calc(50% - 124px);
	top: calc(50% - 220px);
}


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: 30px;
	height: 30px;
	right: 20px;
	top: 20px;
	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: 30px;
	height: 1px;
	left: 0;
	top: calc(50% - 0.5px);
	background: #fff;
}
#video-close::before {
	transform: rotate(45deg);
}
#video-close::after {
	transform: rotate(-45deg);
}








#viewer-overlay {
	position: fixed;
	width: 100vw;
	height: 100vh;
	left: 0;
	top: 0;
	z-index: 1000000;
	background: rgba(0,0,0,0.9);
}
#viewer-btn {
	position: fixed;
	width: 30px;
	height: 30px;
	right: 20px;
	top: 20px;
	z-index: 1000010;
	margin: 0;
	padding: 0;
	font-size: 0;
	border: none;
	cursor: pointer;
	background: none;
}
#viewer-image {
	position: fixed;
	width: 100%;
	max-width: 1200px;
	height: auto;
	max-height: 100vh;
	padding-top: 56.25%;
	left: 50%;
	top: 50%;
	z-index: 1000020;
	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: 30px;
	height: 1px;
	left: 0;
	top: calc(50% - 0.5px);
	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: all 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: 40px;
	height: 40px;
	top: calc(50% + 28.125vw + 10px);
	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: 12px auto;

}
#viewer-next {
	right: 0;
	background: transparent url(../img/arrow_slide_next.svg) 50% 50% no-repeat;
	background-size: 12px 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;
	*/
}












#wrap.teaser main {
}
#wrap.teaser #lang-menu ul {
	background: #000;
}
#wrap.teaser > footer {
}
#wrap.teaser main {
	box-sizing: border-box;
	padding: 40px 0 0;
}

#wrap.teaser #top-video .video {
	position: relative;
	width: 100vw;
	height: 56.25vw;
	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: 48px;
	height: 48px;
	left: calc(50% - 24px);
	top: calc(50% - 24px);
	z-index: 10;
	font-size: 0;
	border-radius: 24px;
	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: 12px auto;
}
#wrap.teaser #top-video a:active .play {
	background: rgba(0,0,0,0.15);
}





#wrap.teaser .teaser-description {
	margin: 32px auto 0;
	text-align: center;
	color: #fff;
}
#wrap.teaser .teaser-description h1 {
	font-size: 32px;
	font-family: "SST W20 Bold", sans-serif;
}

#wrap.teaser .teaser-description p {
	margin: 20px 20px 0;
	font-size: 14px;
	font-family: "SST W20 Medium", sans-serif;
	line-height: 1.4;
}

#wrap.teaser .teaser-description .asl {
	margin: 24px 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: 30px;
	font-family: "SST W55 Bold", sans-serif;
}
html:lang(ja) #wrap.teaser .teaser-description p {
	font-size: 14px;
	font-family: "SST W55 Bold", sans-serif;
	line-height: 1.5;
}



body[data-player="on"] #wrap {
	position: fixed;
	width: 100vw;
}











#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; 
	}





