@charset "UTF-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,500,700');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500;700&display=swap');
/* LOAD ---DESTYLE.CSS RESET */
/*  Z-INDEX ========
.global-header 120
#toggle-button 140
#header-nav 130
.js-overlayer 100
#go-page-top 90 */ :root {
	/*=======*/
	--font-helvetica: 'Helvetica', 'Arial', sans-serif;
	--font-montserrat: 'Montserrat', sans-serif;
	--font-sans: 'Noto Sans JP', sans-serif;
	--text-color: #111111;
	--primary-color: #D50707;
	--box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
	--x-margin: calc(4.266666666666667vw + constant(safe-area-inset-right)); /* 基本左右パディング */
	--x-margin: calc(4.266666666666667vw + env(safe-area-inset-right)); /* 基本左右パディング */
	--y-margin-l: 35px; /* セクションの上空き */
	--y-margin-xl: 40px; /* セクションの下空き */
	--global-header-height: 90px;
}
@media screen and (min-width: 1200px) {
	:root {
		--x-margin: 5.856515373352855vw;
		--y-margin-l: 40px; /* セクションの上空き */
		--y-margin-xl: 55px; /* セクションの下空き */
		--global-header-height: 124px;
	}
}
html {
	word-break: break-word;
}
body {
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.5;
	color: var(--text-color);
	line-break: normal;
	font-family: var(--font-sans);
}
::-moz-selection {
	background-color: #b3d4fc;
	color: #000000;
	text-shadow: none;
}
::selection {
	background-color: #b3d4fc;
	color: #000000;
	text-shadow: none;
}
img {
	width: 100%;
	height: auto;
}
a {
	outline: none;
	color: inherit;
	text-decoration: underline;
	transition: color 300ms ease-out, background-color 300ms ease-out, opacity 300ms ease-out;
}
a:focus {
	outline: none;
}
[type="text"], [type="email"], [type="search"], [type="tel"], [type="url"], [type="password"], textarea {
	font-size: 16px;
	border: var(--border-lightgray);
	padding: 6px;
	transition: 100ms;
}
input:focus, textarea:focus {
	outline: none;
}
[type="text"]:focus, [type="email"]:focus, [type="search"]:focus, [type="tel"]:focus, [type="url"]:focus, [type="password"]:focus, textarea:focus {
	border-color: #2196f3;
	box-shadow: 0 0 0 3px rgba(33, 150, 243, .30);
}
select {
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	border: 1px solid #fff;
	border-radius: 6px;
	padding: 0.35em 2.5em 0.35em 0.75em;
	background: transparent url("../images/common/chev_d1.png") no-repeat center right 0.5em;
	background-size: 1em;
	font-weight: 500;
}
button, input, optgroup, option {
	color: inherit;
	background-color: #e9e9ed;
	cursor: pointer;
}
optgroup, option {
	color: #333;
}
/* ============================== */
/*  LAYOUT */
/* ============================== */
@media screen and (max-width: 1199.98px) {
	.only-pc {
		display: none;
	}
}
@media screen and (min-width: 1200px), print {
	.only-sp {
		display: none;
	}
}
#page {
	width: 100%;
}
/* ============================== */
/*  共通パーツ */
/* ============================== */
/*トップページ主要セクション*/
.chapter-section {
	padding: var(--y-margin-l) var(--x-margin) var(--y-margin-xl);
}
@media screen and (min-width: 1200px), print {
	.chapter-section {}
}
/*下層ページ主要セクション*/
.page-section {
	padding: 108px var(--x-margin) 60px;
	background: linear-gradient(to bottom left, #DB0000, #BE0606);
}
@media screen and (min-width: 1200px), print {
	.page-section {
		padding-top: 180px;
		padding-bottom: 80px;
	}
}
/* セクションヘッダ */
.section-header {
	margin: 0 0 25px;
	position: relative;
}
/* メインセクションのタイトル */
.section-heading {
	font-size: 30px;
	font-size: 29px;
	line-height: 1;
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 25px;
}
.section-header .section-heading {
	margin-bottom: 0;
}
.section-heading .en {
	font-family: var(--font-helvetica);
}
.section-heading .ja {
	display: block;
	font-size: 40%;
	margin-bottom: 0.75em;
	font-weight: 500;
}
@media screen and (min-width: 1200px), print {
	.section-header {
		margin: 0 0 55px;
		position: relative;
	}
	.section-heading {
		font-size: 40px;
		margin: 0 0 55px;
	}
	.section-heading .ja {
		font-size: 35%;
	}
}
/* 左にボーダーのあるセクション（色の変更は個別調整） */
section.side-border {
	position: relative;
	padding-left: calc(var(--x-margin) + 2.4vw);
}
section.side-border::after {
	content: "";
	position: absolute;
	top: 0;
	left: 2.4vw;
	width: 1px;
	height: 100%;
	background: rgba(255, 255, 255, 0.35);
}
section.side-border .section-heading {
	border-left: 4px solid #fff;
	margin-left: calc(var(--x-margin) * -1);
	padding-left: calc(var(--x-margin) - 4px);
}
@media screen and (min-width: 1200px), print {
	section.side-border {
		padding-left: var(--x-margin);
	}
	section.side-border::after {
		left: calc(var(--x-margin) - 40px);
	}
	section.side-border .section-heading {
		margin-left: -40px;
		padding-left: 36px;
	}
}
@media screen and (max-width: 1199.98px) {
	.page-section.side-border::after {
		top: 108px;
		height: calc(100% - 108px);
	}
}
/* More View　ボタン*/
.more-button a {
	font-family: var(--font-montserrat);
	font-weight: 700;
	font-size: 14px;
	line-height: 1.5;
	padding: 0.857142857142857em 1.8em;
	padding-right: 2.2em;
	border-radius: 1.607142857142857em;
	background: #fff;
	text-transform: uppercase;
	display: inline-block;
	color: var(--text-color);
	position: relative;
	text-decoration: none;
	box-shadow: var(--box-shadow);
}
.more-button a::after {
	content: "";
	width: 0.7em;
	height: 0.7em;
	display: block;
	position: absolute;
	top: calc(50% - 0.35em);
	right: 0.8em;
	border-top: 2px solid #707070;
	border-right: 2px solid #707070;
	transform: rotate(45deg);
}
.more-button .sub {
	display: none;
}
.more-button a:hover {
	background: #111111;
	color: #eee;
}
.section-header .more-button {
	position: absolute;
	right: 0;
	top: 0;
	height: 100%;
	display: flex;
	align-items: center;
}
@media screen and (min-width: 768px), print {
	.more-button .sub {
		display: inline;
	}
	.more-button a {
		padding: 1.035714285714286em 1.8em;
		padding-right: 2.2em;
		border-radius: 1.785714285714286em;
	}
}
/* コンテンツ上部のナビ */
nav.contents-top-nav {
	width: 100%;
	position: absolute;
	top: calc(var(--global-header-height) + 5px);
	left: 0;
	z-index: 2;
	font-size: 13px;
	line-height: 1.5;
}
nav.contents-top-nav a.back {
	padding-left: 1.9em;
	position: relative;
	color: #fff;
	text-decoration: none;
}
nav.contents-top-nav a.back::before {
	content: "";
	position: absolute;
	display: block;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
	transform: rotate(-45deg);
	left: 0.9em;
	top: calc(50% - 0.3em);
	width: 0.6em;
	height: 0.6em;
}
nav.contents-top-nav a:hover {
	text-decoration: underline;
}
@media screen and (min-width: 1200px), print {
	nav.contents-top-nav {
		background: rgba(0, 0, 0, 0.6);
		padding: 15px 0;
		font-size: 16px;
		line-height: 1.5;
		position: fixed;
		top: var(--global-header-height);
		left: 0;
		width: 100%;
	}
	nav.contents-top-nav a.back {
		margin-left: 2em;
	}
}
/* タブナビゲーション */
nav.tab-nav {
	border-bottom: 3px solid #fff;
}
nav.tab-nav ul.tab-list {
	display: flex;
	justify-content: space-around;
}
nav.tab-nav li {
	width: 100%;
	text-align: center;
	line-height: 1.2;
	font-weight: 500;
	font-feature-settings: "palt"1;
}
nav.tab-nav li:not(:first-child) {
	margin-left: 12px;
}
nav.tab-nav li a {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	border-radius: 6px 6px 0 0;
	padding: 20px 0.5em 17px;
	background-color: #4D0D0D;
	color: #C7B5B4;
	text-decoration: none;
}
nav.tab-nav li.selected a {
	background-color: #fff;
	color: #830C00;
}
nav.tab-nav li a:hover {
	background-color: #803030;
}
nav.tab-nav li.selected a:hover {
	background-color: #fff;
}
@media screen and (min-width: 1200px), print {
	nav.tab-nav li {
		font-size: 20px;
	}
	nav.tab-nav li a {
		padding: 18px 0.5em 15px;
	}
}
.tabpanel .panel {
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.8s;
	height: 0;
	overflow: hidden;
}
.tabpanel .panel.selected {
	opacity: 1;
	visibility: visible;
	height: auto;
	overflow: visible;
}
/* ============================== */
/*  GLOBAL-HEADER SP-ONLY */
/* ============================== */
@media screen and (max-width: 1199.98px) {
	.site-id {
		position: fixed;
		top: 12px;
		left: 12px;
		left: calc(12px + constant(safe-area-inset-right));
		left: calc(12px + env(safe-area-inset-right));
		margin: 0;
		z-index: 130;
		width: 66px;
	}
	.site-id a {
		display: block;
	}
	.site-id a:hover {
		opacity: 0.7;
	}
	#header-nav {
		background: linear-gradient(#222222, #292929);
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		overflow-y: scroll;
		z-index: 110;
		display: none;
		color: #fff;
	}
	.header-nav-inner {
		padding-bottom: 140px;
	}
	.direct-menu {
		margin-top: var(--global-header-height);
		display: flex;
		border-top: 1px solid #707070;
		border-bottom: 1px solid #707070;
	}
	.direct-menu a {
		text-decoration: none;
		padding: 66px 10px 16px;
		display: block;
		background-repeat: no-repeat;
		background-size: 40px;
		background-position: top 20px center;
		font-size: 12px;
		font-family: var(--font-montserrat);
		font-weight: 700;
		text-align: center;
	}
	.direct-menu a:hover {
		background-color: #000;
	}
	.direct-menu .sns {
		width: 66.66666666%;
	}
	.direct-menu .sns ul {
		display: flex;
	}
	.direct-menu .sns ul li {
		text-align: center;
		width: 50%;
	}
	.direct-menu .sns > ul > li:nth-child(2) {
		border-left: 1px solid #707070;
	}
	.direct-menu .sns .instagram a {
		background-image: url("../images/common/ico_nav-insta.png");
	}
	.direct-menu .sns .twitter a {
		background-image: url("../images/common/f_new_x_icon.png");
	}
	.direct-menu .gallery {
		width: 33.33333333%;
		border-left: 1px solid #707070;
		text-transform: uppercase;
	}
	.direct-menu .gallery a {
		background-image: url("../images/common/ico_nav-gallery.png");
	}
	.global-nav, .global-header .contact {
		width: 68%;
		min-width: 260px;
		max-width: 400px;
		margin-left: auto;
		margin-right: auto;
	}
	.global-nav {
		margin-top: 30px;
		margin-bottom: 34px;
	}
	.global-nav li {
		font-size: 14px;
		font-weight: 700;
		font-family: var(--font-helvetica);
		margin-top: 18px;
	}
	.global-nav > ul > li.gnav-contact {
		display: none;
	}
	.global-nav li a {
		padding: 3px 0;
		display: block;
		text-decoration: none;
		color: #DDDDDE;
		text-transform: uppercase;
	}
	.global-nav li a:hover {
		background-color: #e00b0b;
	}
	/* お問合せ */
	.global-header .contact-button a {
		background: rgba(255, 255, 255, 0.16);
		font-size: 12px;
		padding: 0.5em 2.2em 0.5em 1.8em;
		border-radius: 5px;
		text-decoration: none;
		text-align: center;
		position: relative;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.global-header .contact-button a::before {
		content: "";
		width: 1.5em;
		height: 1.5em;
		background: url("../images/common/ico_contact.png") no-repeat center;
		background-size: 100%;
		margin-right: 0.5em;
		position: relative;
		display: block;
	}
	.global-header .contact-button a::after {
		content: "";
		width: 0.6em;
		height: 0.6em;
		display: block;
		position: absolute;
		top: calc(50% - 0.3em);
		right: 0.8em;
		border-top: 1px solid #aaa;
		border-right: 1px solid #aaa;
		transform: rotate(45deg);
	}
	.global-header .contact-notice {
		font-size: 11px;
		margin-top: 20px;
	}
	.global-header .contact-button a:hover {
		background-color: #e00b0b;
	}
	/*  TOGGLE BUTTON */
	.js-overlayer {
		position: fixed;
		width: 100%;
		height: 100vh;
		top: 0;
		left: 0;
		background: rgba(0, 0, 0, 0.5);
		z-index: 100;
		display: none;
	}
	#toggle-button {
		width: 62px;
		height: 62px;
		top: 0;
		right: 0;
		right: constant(safe-area-inset-right);
		right: env(safe-area-inset-right);
		position: fixed;
		z-index: 140;
		background: #000;
	}
	#page.top-page #toggle-button {
		background: transparent;
	}
	#toggle-button .menu-icon {
		display: block;
		width: 34px;
		height: 4px;
		position: absolute;
		left: 50%;
		top: 50%;
		bottom: auto;
		right: auto;
		transform: translateX(-50%) translateY(-50%);
		transform-origin: center;
		background-color: #fff;
		border-radius: 2px;
		transition: 40ms;
	}
	#toggle-button .menu-icon::before, #toggle-button .menu-icon:after {
		content: '';
		width: 100%;
		height: 100%;
		border-radius: 2px;
		position: absolute;
		left: 0;
		transform-origin: center;
		background-color: #fff;
		transition: transform 40ms, top 40ms 40ms;
	}
	#toggle-button .menu-icon::before {
		top: -13px;
	}
	#toggle-button .menu-icon::after {
		top: 13px;
	}
	#toggle-button.js-clicked {
		background-color: transparent;
	}
	#toggle-button.js-clicked .menu-icon {
		background-color: rgba(255, 255, 255, 0);
	}
	#toggle-button.js-clicked .menu-icon::before, #toggle-button.js-clicked .menu-icon::after {
		transition: transform 80ms 40ms, top 40ms;
	}
	#toggle-button.js-clicked .menu-icon::before {
		top: 0;
		transform: rotate(45deg);
	}
	#toggle-button.js-clicked .menu-icon::after {
		top: 0;
		transform: rotate(-45deg);
	}
}
/* ============================== */
/*  GLOBAL-HEADER PC-ONLY */
/* ============================== */
@media screen and (min-width: 1200px) {
	.global-header {
		position: fixed;
		z-index: 120;
		width: 100%;
		height: var(--global-header-height);
		top: 0;
		left: 0;
		background: #000;
	}
	.site-id {
		position: absolute;
		top: 30px;
		left: calc(50% - 33px);
		width: 66px;
		z-index: 2;
	}
	.site-id a {
		display: block;
	}
	.site-id a:hover {
		opacity: 0.7;
	}
	#toggle-button {
		display: none;
	}
	.js-overlayer {
		display: none !important;
	}
	#header-nav {
		display: block !important;
		padding-top: 30px;
	}
	.global-nav {
		display: flex;
		margin: 0 5%;
	}
	.global-nav ul {
		display: flex;
	}
	.global-nav > ul > li > a {
		display: block;
		color: #DDDDDE;
		text-decoration: none;
		font-family: var(--font-helvetica);
		text-transform: uppercase;
		font-weight: 700;
		font-size: 14px;
		text-align: center;
	}
	.global-nav > ul > li > a:hover {
		color: #CB0000;
	}
	.global-nav ul.left-side {
		width: 50%;
		justify-content: flex-end;
		justify-content: space-between;
		padding-right: 7%;
	}
	.global-nav ul.right-side {
		width: 50%;
		justify-content: space-between;
		padding-right: calc(175px + 1%);
		padding-left: 7%;
	}
	.direct-menu {
		position: absolute;
		top: 0;
		right: 1%;
		display: flex;
	}
	.direct-menu .sns {
		margin-top: 5px;
	}
	.direct-menu .sns a {
		text-indent: -9999px;
		overflow: hidden;
		display: block;
		background-repeat: no-repeat;
		background-size: 30px;
		background-position: center;
	}
	.direct-menu .sns ul li {
		width: 30px;
		height: 30px;
		margin-top: 12px;
	}
	.direct-menu .sns .instagram a {
		background-image: url("../images/common/ico_nav-insta.png");
	}
	.direct-menu .sns .twitter a {
		background-image: url("../images/common/f_new_x_icon.png");
	}
	.direct-menu .gallery {
		margin-left: 20px;
	}
	.direct-menu .gallery a {
		background: #1F1F1F url("../images/common/ico_nav-gallery.png") no-repeat top 15px center;
		background-size: 40px;
		padding: 66px 10px 16px;
		display: block;
		border: 1px solid #fff;
		border-top: none;
		border-radius: 0 0 5px 5px;
		text-transform: uppercase;
		width: 125px;
		text-decoration: none;
		font-size: 12px;
		font-family: var(--font-montserrat);
		font-weight: 700;
		text-align: center;
		color: #fff;
	}
	.direct-menu .sns .instagram a:hover, .direct-menu .sns .twitter a:hover {
		opacity: 0.7;
	}
	.direct-menu .gallery a:hover {
		color: #000;
		background-color: #fff;
		background-image: url("../images/common/ico_nav-gallery-bk.png");
	}
	.global-header .contact {
		display: none;
	}
	.direct-menu .tts {
		display: inline !important;
		margin: auto;
	}
}
/* ============================== */
/*  GLOBAL FOOTER */
/* ============================== */
.global-footer {
	background: #222222;
	padding: 30px 0 15px;
	color: #fff;
	position: relative;
}
.global-footer .footer-title a {
	text-decoration: none;
}
.global-footer .footer-title a:hover {
	opacity: 0.7;
}
ul.footer-link {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	font-size: 14px;
	font-family: var(--font-helvetica);
	font-weight: 700;
	text-transform: uppercase;
	margin-left: -1em;
	margin-right: -1em;
	margin: -35px calc(var(--x-margin) - 1em) 0;
	padding-bottom: 30px;
}
ul.footer-link li {
	padding: 0 1em;
	margin-top: 35px;
}
ul.footer-link a {
	color: #C8C9C9;
	text-decoration: none;
}
ul.footer-link a:hover {
	color: #cb0000;
}
/* SNS */
.footer-direct-menu {
	display: flex;
	justify-content: center;
	border-top: 1px solid #707070;
	border-bottom: 1px solid #707070;
	padding: 20px 18%;
}
.footer-direct-menu a {
	text-decoration: none;
	display: block;
	text-align: center;
}
.footer-direct-menu .footer-sns {
	width: 153px;
	display: flex;
}
.footer-direct-menu .footer-sns li {
	width: 50px;
	height: 50px;
}
.footer-direct-menu .footer-sns li:not(:first-child) {
	margin-left: 24px;
}
.footer-direct-menu .footer-sns a {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%
}
.footer-direct-menu .footer-sns a img {
	width: 30px;
	display: block;
}
.footer-direct-menu .gallery {
	width: 84px;
}
.footer-direct-menu .gallery a {
	padding: 58px 10px 10px;
	font-size: 12px;
	font-family: var(--font-montserrat);
	font-weight: 700;
	background: url("../images/common/ico_nav-gallery.png") no-repeat top 10px center;
	background-size: 40px;
	text-transform: uppercase;
	width: 100%;
}
.direct-menu .tts {
	display: none;
}
.footer-direct-menu a:hover {
	opacity: 0.7;
}
.footer-address {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	margin-top: 24px;
}
.footer-title {
	font-size: 12px;
	font-weight: 700;
	padding-left: 82px;
	position: relative;
}
.footer-contact {
	padding-left: 82px;
}
.footer-title .logo {
	width: 4.833333333333333em;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}
.footer-contact {
	padding-left: 82px;
	margin-top: 0.4em;
}
.footer-contact a {
	background: rgba(255, 255, 255, 0.16);
	font-size: 12px;
	padding: 0.5em 2.2em 0.5em 1.8em;
	border-radius: 5px;
	text-decoration: none;
	text-align: center;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}
.footer-contact a::before {
	content: "";
	width: 1.5em;
	height: 1.5em;
	background: url("../images/common/ico_contact.png") no-repeat center;
	background-size: 100%;
	margin-right: 0.7em;
	position: relative;
	display: block;
}
.footer-contact a::after {
	content: "";
	width: 0.6em;
	height: 0.6em;
	display: block;
	position: absolute;
	top: calc(50% - 0.3em);
	right: 0.8em;
	border-top: 1px solid #aaa;
	border-right: 1px solid #aaa;
	transform: rotate(45deg);
}
.footer-contact a:hover {
	background-color: #e00b0b;
}
.footer-regal {
	font-size: 10px;
	margin-top: 24px;
	padding: 0 15px;
	text-align: center;
	color: #AAAAAA;
}
.copyright {
	font-size: 10px;
	font-family: var(--font-helvetica);
}
.footer-notice {
	margin-top: 0.75em;
	font-size: 10px;
}
@media screen and (min-width: 1200px), print {
	.global-footer {
		background: #000000;
		padding: 36px 20px 45px;
	}
	.footer-nav {
		display: flex;
		justify-content: center;
	}
	ul.footer-link {
		font-family: var(--font-helvetica);
		font-size: 14px;
		width: 804px;
		margin: -35px -1em 0;
		padding-bottom: 30px;
	}
	ul.footer-link li {
		padding: 0 1em;
	}
	.footer-direct-menu {
		justify-content: flex-start;
		border: none;
		padding: 0;
		margin-left: 40px;
		margin-top: -17px;
	}
	.footer-address {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		margin-top: 0;
	}
	.footer-title {
		font-size: 14px;
	}
	.footer-title .logo {
		width: 4.142857142857143em;
		top: -5px;
	}
	.footer-contact a {
		padding: 0.5em 3.7em 0.5em 3.3em;
	}
	.footer-contact a::after {
		content: "";
		width: 0.6em;
		height: 0.6em;
		display: block;
		position: absolute;
		top: calc(50% - 0.3em);
		right: 0.8em;
		border-top: 1px solid #aaa;
		border-right: 1px solid #aaa;
		transform: rotate(45deg);
	}
	.footer-info {
		display: flex;
		align-items: flex-end;
		justify-content: center;
	}
	.footer-regal {
		margin-top: 24px;
		padding: 0;
		display: flex;
		align-items: flex-end;
		padding-bottom: 0.5em;
	}
	.copyright {
		font-size: 12px;
		margin: 0 2em;
	}
	.footer-notice {
		margin-top: 0;
		padding-bottom: 0.2em;
	}
}
/* カテゴリカラー */
.cat > span.news, .category > span.news, .cat > span.event, .category > span.event {
	text-transform: uppercase;
	font-family: var(--font-helvetica);
	font-weight: 700;
}
.cat > span.news, .category > span.news {
	color: #C20505;
}
.cat > span.event, .category > span.event {
	color: #C6870F;
}
/* ============================== */
/*  SCROLL ICON */
/* ============================== */
/* Scroll Donw */
@media screen and (max-width: 1199.98px) {
	.hero .scroll-hint-down {
		display: none !important;
	}
}
@media screen and (min-width: 1200px), print {
	.hero .scroll-hint-down {
		width: 25px;
		height: 50px;
		position: fixed;
		bottom: 10px;
		right: 30px;
		z-index: 90;
		display: block;
	}
	.hero .scroll-hint-down a {
		width: 100%;
		height: 100%;
		background: url("../images/common/ico_scroll-down.png") no-repeat center;
		background-size: 100%;
		overflow: hidden;
		text-indent: -9999px;
		display: block;
	}
}
/* Scroll Up */
#go-pagetop a {
	display: none;
}
@media screen and (min-width: 1200px), print {
	#go-pagetop a {
		display: block;
		position: absolute;
		right: 30px;
		bottom: 38px;
		z-index: 90;
		width: 25px;
		height: 50px;
		text-indent: -9999px;
		overflow: hidden;
		background: url("../images/common/ico_scroll-up.png") no-repeat center;
		background-size: 100%;
	}
}
/* ============================== */
/*  トップページ  */
/* ============================== */
/* トップページ ヒーローイメージ */
.hero {
	width: 100%;
	position: relative;
}
.hero .slide {
	position: relative;
}
.hero .slide-image img {
	width: 100%;
	height: 100vh;
	object-fit: cover;
}
.hero .slide .player-name {
	position: absolute;
	bottom: 12%;
	left: 10%;
	width: 80%;
	transform: translateY(-50%);
}
.hero .more-button {
	display: none;
}
.hero .slide a:hover {
	opacity: 0.7;
}

/* first-slide */
.first-slide .slide-pc {
	display: none;
}
.first-slide .slide-sp {
	position: relative;
}
.first-slide .slide-sp .first-slide-image img {
	width: 100%;
	height: 100vh;
	object-fit: cover;
}
.first-slide .slide-sp .title {
	position: absolute;
	top: 95px;
	left: 4vw;
	height: calc(100% - 115px);
}
.first-slide .slide-sp .title img {
	height: 100%;
	width: auto;
}
/* ----- MV（PC） ----- */
#hero-slider-pc {
	display: none;
}
@media screen and (min-width: 768px), print {
	.hero {
		padding-top: 0;
		width: 100%;
		position: relative;
		background: #000;
	}
	.hero .slide-image img {
		width: 100%;
		height: calc(100vh - 44px);
		object-fit: cover;
	}
	.hero .slide .player-name {
		position: absolute;
		bottom: 13%;
		left: 16%;
		width: 41%;
		transform: translateY(-50%);
	}
	/* More View　ボタン*/
	.hero .more-button {
		position: absolute;
		bottom: 8%;
		right: var(--x-margin);
		font-family: var(--font-montserrat);
		font-weight: 700;
		font-size: 14px;
		line-height: 1.5;
		padding: 1.035714285714286em 1.8em;
		padding-right: 2.2em;
		border-radius: 1.785714285714286em;
		background: #fff;
		text-transform: uppercase;
		display: inline-block;
		color: var(--text-color);
		text-decoration: none;
		box-shadow: var(--box-shadow);
	}
	.hero .more-button::after {
		content: "";
		width: 0.7em;
		height: 0.7em;
		display: block;
		position: absolute;
		top: calc(50% - 0.35em);
		right: 0.8em;
		border-top: 2px solid #707070;
		border-right: 2px solid #707070;
		transform: rotate(45deg);
	}
}
@media screen and (min-width: 1200px), print {
	.hero {
		padding-top: var(--global-header-height);
	}
	.hero .slide{
		display: block;
		height: calc(100vh - var(--global-header-height));
	}
	.hero .slide > a {
		display: block;
		height: 100%;
		background-position: center bottom;
		background-repeat: no-repeat;
		background-size: cover;
	}
	#hero-slider-pc .slide > a:hover {
		opacity: 1;
	}
	.hero .player-mono,
	.hero .player-photo,
	.hero .slide .player-name {
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		display: block;
	}

	#hero-slider-pc:not(.is-active) .player-photo img {
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		width: auto;
	}

	
	/* マルキ */
	.hero .n-malki > a {
		background-image: url('../images/hero/pc/malki/malki-bg.jpg');
	}
	/* 山田 */
	.hero .s-yamada > a {
		background-image: url('../images/hero/pc/yamada/yamada-bg.jpg');
	}
	#hero-slider-pc:not(.is-active) .s-yamada .player-photo img {
		left: calc(50% + (100vh - var(--global-header-height))/1000 * 190);
	}
	/* 安達 */
	.hero .r-adachi > a {
		background-image: url('../images/hero/pc/adachi/adachi-bg.png');
	}
	#hero-slider-pc:not(.is-active) .r-adachi .player-photo img {
		left: calc(50% + (100vh - var(--global-header-height))/1000 * -215);
	}
	/* 水町 */
	.hero .t-mizumachi > a {
		background-image: url('../images/hero/pc/mizumachi/mizumachi-bg.png');
	}
	#hero-slider-pc:not(.is-active) .t-mizumachi .player-photo img {
		left: calc(50% + (100vh - var(--global-header-height))/1000 * 615);
	}
	
	/* 森 */
	.hero .m-mori > a {
		background-image: url('../images/hero/pc/mizumachi/mizumachi-bg.png');
	}
	#hero-slider-pc:not(.is-active) .m-mori .player-photo img {
		left: calc(50% + (100vh - var(--global-header-height))/1000 * -640);
	}

	/* 秋重 */
	.hero .w-akishige > a {
		background-image: url('../images/hero/pc/mizumachi/mizumachi-bg.png');
	}
	#hero-slider-pc:not(.is-active) .w-akishige .player-photo img {
		left: calc(50% + (100vh - var(--global-header-height))/1000 * 600);
	}
	.first-slide .slide-pc {
		display: flex;
	}
	.first-slide .slide-pc .title {
		width: 110px;
		transition: width 0.5s;
	}
	.first-slide .slide-pc .first-silde-list {
		display: flex;
		width: calc(100% - 110px);
	}
	.first-slide .slide-pc .first-silde-list li.slide {
		width: 25%;
		overflow: hidden;
		transition: width 0.5s;
	}
	.first-slide .slide-pc .title img, .first-slide .slide-pc .slide img {
		width: 100%;
		height: calc(100vh - var(--global-header-height));
		object-fit: cover;
	}

	/* 矢印 */
	#hero-slider-pc .mv-arrow-prev,
	#hero-slider-pc .mv-arrow-next {
		position: absolute;
    top: calc(50% - 22px);
    z-index: 2;
    width: 44px;
    height: 44px;
		background-color: transparent;
    cursor: pointer;
		transition: opacity 0.3s;
	}
	#hero-slider-pc .mv-arrow-prev:hover,
	#hero-slider-pc .mv-arrow-next:hover {
		opacity: 0.35;
	}
	#hero-slider-pc .mv-arrow-prev::after,
	#hero-slider-pc .mv-arrow-next::after {
		position: absolute;
    top: calc(50% - 15px);
		content: "";
		width: 30px;
    height: 30px;
		transform: rotate(45deg);
	}
	#hero-slider-pc .mv-arrow-prev {
		left: 35px;
	}
	#hero-slider-pc .mv-arrow-prev::after {
		left: calc(50% - 3px);
    border-bottom: 4px solid #fff;
    border-left: 4px solid #fff;
	}
	#hero-slider-pc .mv-arrow-next {
		right: 35px;
	}
	#hero-slider-pc .mv-arrow-next::after {
		right: calc(50% - 3px);
		border-top: 4px solid #fff;
    border-right: 4px solid #fff;
	}

	/* アクティブ時 */
	.first-slide.is-active .slide-pc .first-silde-list {
		width: 100%;
	}
	.first-slide.is-active .slide-pc .title {
		width: 0;
	}
	.first-slide.is-active .slide-pc .first-silde-list li.slide:not(.is-open) {
		width: 0;
	}
	.first-slide .slide-pc .first-silde-list li.slide.is-open {
		width: 100%;
	}

	/* ----- 表示制御 ----- */
	/* --- MV（SP） --- */
	#hero-slider {
		display: none;
	}

	/* --- MV（PC） --- */
	#hero-slider-pc {
		display: block;
	}

	#hero-slider-pc .slide .player-deco {
		transition: opacity 0.5s 0.5s ease-out;
		opacity: 1;
	}
	#hero-slider-pc .slide .player-mono {
		transition: transform 0.5s 0.7s ease-in-out;
		transform: translateX(0);
	}
	#hero-slider-pc .slide .player-name {
		transition: transform 0.5s 0.9s ease-in-out;
		transform: translateX(0);
	}
	#hero-slider-pc .slide .more-button,
	#hero-slider-pc .mv-arrow-prev::after,
	#hero-slider-pc .mv-arrow-next::after {
		transition: opacity 0.5s 1s ease-in-out;
		opacity: 1;
	}

	#hero-slider-pc .slide:not(.is-open) .player-deco {
		opacity: 0;
		transition: opacity 0.2s ease-in-out;
	}
	#hero-slider-pc .slide:not(.is-open) .player-mono {
		transform: translateX(100%);
		transition: none;
	}
	#hero-slider-pc .slide:not(.is-open) .player-name {
		transform: translateX(-100%);
		transition: none;
	}
	#hero-slider-pc .slide:not(.is-open) .more-button,
	#hero-slider-pc .slide:not(.is-open) .mv-arrow-prev::after,
	#hero-slider-pc .slide:not(.is-open) .mv-arrow-next::after {
		opacity: 0;
		transition: none;
	}
}
/* SLICK SLIDER */
#hero-slider {
	width: 100%;
	list-style-type: none;
	margin-bottom: 0;
	opacity: 0;
	transition: 200ms;
}
#hero-slider.slick-initialized {
	opacity: 1;
}
#hero-slider .slide-arrow {
	position: absolute;
	top: calc(50% - 22px);
	width: 44px;
	height: 44px;
	z-index: 2;
	cursor: pointer;
}
#hero-slider .slide-arrow.prev-arrow {
	left: 10px;
}
#hero-slider .slide-arrow.next-arrow {
	right: 10px;
}
#hero-slider .slide-arrow::after {
	content: "";
	width: 24px;
	height: 24px;
	position: absolute;
	top: calc(50% - 12px);
	transform: rotate(45deg);
}
#hero-slider .slide-arrow.prev-arrow::after {
	left: calc(50% - 3px);
	border-bottom: 4px solid #fff;
	border-left: 4px solid #fff;
}
#hero-slider .slide-arrow.next-arrow::after {
	right: calc(50% - 3px);
	border-top: 4px solid #fff;
	border-right: 4px solid #fff;
}
@media screen and (min-width: 768px), print {
	#hero-slider .slide-arrow.prev-arrow {
		left: 35px;
	}
	#hero-slider .slide-arrow.next-arrow {
		right: 35px;
	}
	#hero-slider .slide-arrow::after {
		width: 30px;
		height: 30px;
		top: calc(50% - 15px);
		opacity: 0.34;
	}
}
#hero-slider .slide-dots {
	font-size: 20px;
	line-height: 1;
	position: absolute;
	bottom: 10px;
	width: 100%;
	left: 0;
	display: flex;
	justify-content: center;
}
#hero-slider .slide-dots li {
	display: inline-block;
	margin: 0 4px;
	padding: 0;
}
#hero-slider .slide-dots li button {
	position: relative;
	text-indent: -9999px;
	width: 1em;
	height: 1em;
	padding: 0;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	background: transparent;
	margin: 0;
}
#hero-slider .slide-dots li button:focus {
	outline: none;
}
#hero-slider .slide-dots li button::-moz-focus-inner {
	border: 0;
}
#hero-slider .slide-dots li button::before {
	content: '';
	text-indent: 0;
	position: absolute;
	top: calc(50% - 4.5px);
	left: calc(50% - 4.5px);
	width: 9px;
	height: 9px;
	border: 1px solid #fff;
	border-radius: 50%;
}
#hero-slider .slide-dots li.slick-active button::before {
	opacity: 0.9;
	background: #fff;
}
@media screen and (min-width: 1200px), print {
	#hero-slider .slide-dots {
		bottom: -32px;
	}
	#hero-slider .slide-dots li button::before {
		border: none;
		background: #fff;
		opacity: 0.4;
	}
	#hero-slider .slide-dots li.slick-active button::before {
		opacity: 0.9;
		background: #fff;
	}
}
/* TOPPAGE TWITTER */
.twitter-feed {
	background: linear-gradient(#292929, #222222);
	color: #fff;
	padding-left: calc((20 / 375) * 100vw);
	padding-right: calc((20 / 375) * 100vw);
}
.twitter-feed h2.section-heading {
	text-transform: none;
	background: url("../images/common/f_new_x_icon.png") no-repeat left center;
	background-size: 1.25em;
	padding: 0.2em 0 0.2em 1.7em;
	margin-top: -10px;
}
.twitter-container {
	overflow: auto;
	background: #fff;
	margin: 0;
	padding: 0;
	height: 337px;
	border-radius: 10px;
}
.twitter-container iframe {
	background: #454545;
	border-radius: 10px; /* safari対策 */
	overflow: hidden; /* safari対策 */
}
.timeline-Body {
	position: relative;
	border-top: 10px solid rgba(145, 165, 180, .6);
	border-bottom: 10px solid rgba(145, 165, 180, .6);
}
@media screen and (min-width: 1200px), print {
	.twitter-feed h2.section-heading {
		margin-top: 0.2125em;
		margin-bottom: 35px;
		font-size: 37px;
		background-size: 1em;
		padding: 0.2em 0 0.2em 1.7em;
	}
	.twitter-feed .section-body {
		height: calc(100% - 100px);
	}
	.twitter-container {
		height: 594px;
	}
}
/* TOPPAGE NEXT-GAME */
section.next-game {
	background: linear-gradient(to bottom left, #D50707, #AD0E0E);
	color: #fff;
}
.next-game .article a {
	background: rgba(0, 0, 0, 0.2);
	border-radius: 10px;
	padding: 18px 16px;
}
.next-game .article:not(:first-child) {
	margin-top: 8px;
}
.next-game .article .article-header {
	display: flex;
	margin: 0 0 0.2em;
}
.next-game .article .date {
	font-size: 26px;
	font-family: var(--font-helvetica);
	margin-right: 0.5em;
	font-weight: 700;
}
.next-game .article .dow {
	font-size: 20px;
	font-weight: 700;
}
.next-game .article .article-title {
	font-size: 18px;
}
.next-game .article .article-place {
	margin: 1em 0 0;
	font-size: 15px;
	padding-left: 1.4em;
	background: url("../images/common/ico_place.png") no-repeat left top 0.1em;
	background-size: 0.88em;
}
.next-game .article a {
	text-decoration: none;
	display: block;
}
.next-game .article a .article-title {
	text-decoration: underline;
	font-weight: 500;
}
.next-game .article a:hover {
	background: rgba(0, 0, 0, 0.4);
}
@media screen and (min-width: 1200px), print {
	.twitter-nextgamewrapper {
		display: flex;
		flex-direction: row-reverse;
	}
	.twitter-feed {
		width: 41.800878477306003%;
		flex: 0 0 auto;
		padding-left: 40px;
	}
	.next-game {
		width: 100%;
		padding-right: 40px;
	}
	.twitter-feed .section-heading, .next-game .section-header {
		margin-bottom: 35px;
	}
}
/* TOPPAGE GAME RESULT */
section.game-result {
	background: linear-gradient(#D50707, #AD0E0E);
	color: #fff
}
section.game-result .section-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
section.game-result .section-bg img {
	width: 100%;
	height: auto;
}
section.game-result .section-header, section.game-result .article, section.game-result .result-list-section {
	position: relative;
	z-index: 1;
}
.game-result .article .article-title {
	margin: 0;
	font-size: 20px;
	font-weight: 500;
}
.game-result .article .article-title a {
	text-decoration: none;
}
.game-result .article .article-title a:hover {
	text-decoration: underline;
}
.game-result .article .article-period {
	font-size: 26px;
	font-family: var(--font-helvetica);
	margin: 0.5em 0 0;
	font-weight: 700;
}
.game-result .article .article-place {
	margin: 1em 0 0;
	font-size: 15px;
	padding-left: 1.4em;
	background: url("../images/common/ico_place.png") no-repeat left top 0.1em;
	background-size: 0.88em;
}
@media screen and (min-width: 1200px), print {
	section.game-result {
		background: url("../images/common/bg_result.png") no-repeat center top 0, linear-gradient(#D50707, #AD0E0E);
		background-size: 100%, 100%;
	}
	.game-result .article .article-title {
		font-size: 36px;
	}
	.game-result .article .article-period {
		font-size: 30px;
	}
}
/* 出場ペア最終順位のセクション */
.result-list-section {
	background: rgba(0, 0, 0, 0.5);
	border-radius: 10px;
	padding: 15px 10px;
	margin: 15px 0 0;
}
.result-list-section h3 {
	font-size: 18px;
	font-weight: 500;
	margin: 0 0 0.5em;
}
.result-list-item {
	display: flex;
	color: var(--text-color);
}
.result-list-item:not(:first-child) {
	margin-top: 9px;
}
.result-list-item dt {
	border-radius: 4px 0 0 4px;
	border-right: 1px solid #72170A;
	background: rgba(255, 255, 255, 0.75);
	width: 28.700906344410876%;
	flex: 0 0 auto;
	font-size: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 500;
}
.result-list-item dd {
	border-radius: 0 4px 4px 0;
	background: rgba(255, 255, 255, 0.75);
	width: 71.299093655589124%;
}
.result-list-item .recipient {
	padding: 10px 10px 10px 74px;
	min-height: 88px;
	position: relative;
	display: flex;
	justify-content: center;
	flex-direction: column;
}
.result-list-item .recipient.has-photo {
	padding-left: 100px;
}
.result-list-item .recipient + .recipient {
	border-top: 1px solid #72170A;
}
.result-list-item .recipient .photo {
	width: 55px;
	height: 55px;
	border-radius: 50%;
	overflow: hidden;
	position: absolute;
	top: calc(50% - 27.5px);
	left: 38px;
	z-index: 1;
}
.result-list-item .photo img {
	transition: 300ms ease-out;
}
.result-list-item a {
	text-decoration: none;
}
.result-list-item a:hover {
	text-decoration: underline;
}
.result-list-item a:hover .photo img {
	transform: scale(1.1);
}
.result-list-item .recipient .player {
	font-size: 14px;
	font-weight: 500;
}
.result-list-item .recipient .belongs {
	display: flex;
	font-size: 12px;
	margin-top: 0.35em;
}
.result-list-item .recipient .belongs .icon {
	display: inline-block;
	width: 1.5em;
	margin-right: 0.2em;
	position: relative;
	top: -0.15em;
}
.result-list-section .section-footer {
	font-size: 13px;
	margin: 20px 0 0;
}
@media screen and (min-width: 1200px), print {
	.result-list-section {
		background: transparent;
		border-radius: 0;
		padding: 0;
		margin: 65px 0 0;
	}
	.result-list-section h3 {
		font-size: 23px;
		margin: 0 0 1em;
	}
	.result-list {
		display: flex;
		flex-wrap: wrap;
		margin-left: -20px;
		margin-top: -20px;
	}
	.result-list-item:nth-child(n) {
		margin-top: 20px;
		margin-left: 20px;
		width: calc(50% - 20px);
	}
	.result-list-item dt {
		border-right: 1px solid #72170A;
		width: 21.585160202360877%;
		flex: 0 0 auto;
		font-size: 20px;
		display: flex;
		align-items: center;
		justify-content: center;
		font-weight: 500;
		min-height: 109px;
	}
	.result-list-item dd {
		width: 78.414839797639123%;
		display: flex;
	}
	.result-list-item .recipient {
		padding: 10px 10px 10px 7%;
		min-height: auto;
		width: 50%;
	}
	.result-list-item .recipient.has-photo {
		padding-left: 100px;
		padding-left: calc(7% + 65px);
	}
	.result-list-item .recipient + .recipient {
		border-top: none;
		border-left: 1px solid #72170A;
	}
	.result-list-item .recipient .photo {
		left: 14%;
	}
	.result-list-item a:hover .recipient .photo {}
	.result-list-section .section-footer {
		font-size: 15px;
		margin: 60px 0 0;
	}
}
/* TOPPAGE NEWS-EVENT */
.news-event {
	background: linear-gradient(to bottom right, #E5E5E5, #D5D5D5);
}
.news-event h2.section-heading {
	color: var(--text-color);
	border-color: currentColor;
}
.news-event.side-border::after {
	background: rgba(17, 17, 17, 0.26)
}
.news-event .news-list {
	display: flex;
	flex-wrap: wrap;
	margin-top: -20px;
}
.news-event .news-list .news-list-item {
	width: calc((100% - 4.878048780487805%) / 2);
	margin-top: 20px;
	margin-left: 4.878048780487805%;
}
.news-event .news-list .news-list-item:nth-child(odd) {
	margin-left: 0;
}
/* news-list */
.news-list-item a {
	text-decoration: none;
}
.news-list-item .news-thumb {
	overflow: hidden;
	height: calc(42.36vw * 152 / 228);
}
.news-list-item .news-thumb img {
	transition: 300ms ease-out;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.news-list-item .news-text {
	margin: -15px 5px 0;
	padding: 10px;
	background: #fff;
	position: relative;
	z-index: 1;
	color: #111;
}
.news-list-item .news-header {
	margin: 0 0 0.4em;
	display: flex;
	justify-content: space-between;
}
.news-list-item .cat {
	font-size: 8px;
	color: #777777;
}
.news-list-item .date {
	font-size: 7px;
	font-family: var(--font-helvetica);
	font-weight: 500;
}
.news-list-item .news-title {
	font-size: 13px;
	font-weight: 500;
}
.news-list-item a {
	text-decoration: none;
}
.news-list-item a:hover h3 {
	text-decoration: underline;
}
.news-list-item a:hover .news-thumb img {
	transform: scale(1.1);
}
@media screen and (min-width: 1200px), print {
	.news-event .news-list {
		display: flex;
		flex-wrap: wrap;
		margin-top: -20px;
	}
	.news-event .news-list .news-list-item:nth-child(n) {
		width: calc((100% - 3.174603174603175% * 4) / 5);
		margin-top: 20px;
		margin-left: 3.174603174603175%;
	}
	.news-event .news-list .news-list-item:nth-child(5n + 1) {
		margin-left: 0;
	}
	.news-list-item .news-thumb {
		height: calc(15.415vw * 152 / 228);
	}
	.news-list-item .news-text {
		padding: 14px;
	}
	.news-list-item .cat {
		font-size: 11px;
	}
	.news-list-item .date {
		font-size: 10px;
	}
}
/* TOPPAGE INSTAGRAM */
.instagram-feed {
	padding-left: 0;
	padding-right: 0;
	padding-bottom: 0;
	background: #222222;
}
.instagram-feed .section-header {
	margin: 0 var(--x-margin);
	margin-bottom: var(--y-margin-l);
}
.instagram-feed h2 {
	width: 181px;
}
@media screen and (min-width: 1200px), print {
	/*instagram*/
}
/* BLOG */
section.blog {
	background: linear-gradient(#c60000, #AF0606);
	color: #fff;
}
.blog .article:not(:first-child) {
	margin-top: 25px;
}
.blog .article .date {
	opacity: 0.6;
	font-size: 14px;
	font-family: var(--font-helvetica);
	font-weight: 700;
	margin: 0 0 0.9em;
}
.blog .article .article-title {
	font-size: 22px;
	font-weight: 500;
	margin: 0 0 0.5em;
}
.blog .article .article-body {
	font-size: 16px;
}
.blog .article a {
	text-decoration: none;
	display: block;
}
.blog .article a:hover .article-title, .blog .article a:hover .article-body {
	text-decoration: underline;
}
@media screen and (min-width: 1200px), print {
	section.blog {
		display: flex;
		justify-content: space-between;
	}
	.blog .section-header {
		width: 22.166666666666667%;
	}
	.blog .section-body {
		width: 77.916666666666667%;
	}
	.blog .section-heading {
		margin-bottom: 35px;
	}
	.blog .section-header .more-button {
		position: relative;
		right: auto;
		height: auto;
	}
	.blog .article-list {
		display: flex;
	}
	.blog .article {
		width: calc((100% - 8% * 2) / 3);
	}
	.blog .article:not(:first-child) {
		margin-top: 0;
		margin-left: 8%;
	}
}
/* バナー */
.foot-banners {
	background: #fff;
	color: var(--text-color);
	padding-bottom: var(--y-margin-l);
	position: relative;
}
.foot-banners ul {
	display: flex;
	flex-wrap: wrap;
	margin-left: -20px;
	margin-top: -30px;
	justify-content: center;
}
.foot-banners li {
	width: calc(50% - 20px);
	margin-left: 20px;
	margin-top: 30px;
}
.foot-banners li a {
	height: 100%;
	display: flex;
	align-items: center;
}
.foot-banners li a:hover {
	opacity: 0.7;
}
@media screen and (min-width: 768px), print {
	.foot-banners ul {
		margin-left: -40px;
		margin-top: -30px;
	}
	.foot-banners li {
		width: calc(25% - 40px);
		margin-left: 40px;
		margin-top: 30px;
	}
}
@media screen and (min-width: 1200px), print {
	.foot-banners ul {
		margin-left: -58px;
		margin-top: -35px;
	}
	.foot-banners li {
		width: calc(20% - 58px);
		margin-left: 58px;
		margin-top: 35px;
	}
	.foot-banners li:first-child {
		width: calc(17.5% - 58px);
	}
	.foot-banners li:nth-child(2) {
		width: calc(17.5% - 58px);
	}
	.foot-banners li:nth-child(3) {
		width: calc(25% - 58px);
	}
}
@media print {
	a:after {
		content: " ("attr(href)") ";
		font-size: 0.8em;
		font-weight: normal;
	}
}
/* ============================== */
/*  下層ページ */
/* ============================== */
/*  TEAM PAGE */
/* ============================== */
section.team {
	background: linear-gradient(#DB0000, #A00C0C);
	color: #fff;
}
section.team h2 {
	font-family: var(--font-montserrat);
	font-weight: 700;
	font-size: 20px;
	text-transform: uppercase;
	margin-bottom: var(--y-margin-l);
}
.team .sub-section + .sub-section {
	border-top: 1px solid #fff;
	margin-top: var(--y-margin-l);
	padding-top: var(--y-margin-l);
}
/* ロゴエリア */
.team .slogan-logo {
	text-align: center;
}
.team .slogan-logo img {
	width: 167px;
	max-width: 100%;
	margin-top: 35px;
	margin-bottom: 40px;
}
.team .slogan-box-head h3{
	font-size: 38px;
	font-weight: 700;
	line-height: 1.58;
}
.team .slogan-box-body p {
	font-size: 16px;
	line-height: 1.75;
	font-weight: 300;
}
.team .slogan-box-body .more-button {
	margin-top: 15px;
}
.team br.slogan-br-sp {
	display: block;
}
/* プレイヤーリスト */
.player-list {
	display: flex;
	flex-wrap: wrap;
	margin-top: -25px;
}
.player-list li {
	width: calc((100% - 4.191616766467066%) / 2);
	margin-left: 4.191616766467066%;
	margin-top: 25px;
}
.player-list li:nth-child(odd) {
	margin-left: 0;
}
.player-list li a {
	text-decoration: none;
}
.player-list .player-name {
	margin-top: 0.75em;
	text-align: center;
	font-size: 16px;
}
.player-list .player-photo {
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
	border-radius: 8px;
	position: relative;
	z-index: 1;
	height: calc(89.066666666vw * 0.479041916167665);
	overflow: hidden;
}
.player-list .player-photo img {
	transition: 300ms ease-out;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.player-list .player-name .ja {
	display: block;
	font-weight: 500;
}
.player-list .player-name .en {
	display: block;
	font-size: 11px;
	margin-top: 0.4em;
	font-family: var(--font-montserrat);
	font-weight: 500;
}
.player-list li a:hover .player-photo img {
	transform: scale(1.1);
}
/* スタッフリスト */
.staff-list {
	display: flex;
	flex-wrap: wrap;
	margin-left: -14px;
	margin-top: -20px;
}
.staff-list > li {
	width: calc(50% - 14px);
	margin-left: 14px;
	margin-top: 20px;
	background: #fff;
	border-radius: 8px;
	text-align: center;
	padding: 20px 10px;
	color: var(--text-color);
}
.staff-list .pos {
	font-size: 14px;
	margin-bottom: 0.5em;
	font-weight: 500;
}
.staff-list .pos::after {
	content: "";
	display: block;
	width: 2em;
	height: 2px;
	background: #8D1000;
	margin: 0.4em auto 0;
}
.staff-list .staff-name {
	font-size: 18px;
	font-weight: 500;
}
.staff-list .staff-name .en {
	color: #750C00;
	font-weight: 500;
	font-size: 61.111111111111111%;
	font-family: var(--font-montserrat);
	display: block;
	margin-top: 0.2em;
}
.staff-list .staff-name .company {
	font-weight: 500;
	font-size: 61.111111111111111%;
	font-family: var(--font-montserrat);
	display: block;
	margin-top: 0.2em;
}
.staff-list > li.size-double {
	width: 100%;
	display: flex;
	align-items: center;
}
.staff-list > li.size-double .photo {
	width: 36%;
	max-width: 203px;
	border-radius: 8px;
	overflow: hidden;
	flex: 0 0 auto;
	margin-top: -3px;
	margin-bottom: -3px;
}
.staff-list > li.size-double .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.staff-list > li.size-double .text {
	flex: 1 1 auto;
}
@media screen and (min-width: 768px), print {
	/* ロゴエリア */
	.team .slogan-box {
		position: relative;
		padding-left: 293px;
	}
	.team .slogan-logo {
		position: absolute;
		top: 0;
		left: 0;
	}
	.team .slogan-logo img {
		width: auto;
	}
	.team .slogan-box-head h3{
		font-size: 44px;
		font-weight: 700;
	}
	.team .slogan-box-head + .slogan-box-body {
		margin-top: 26px;
	}
	.team .slogan-box-body p {
		font-size: 16px;
		line-height: 1.75;
		font-weight: 300;
	}
	.team .slogan-box-body .more-button {
		margin-top: 40px;
	}
	.team br.slogan-br-sp {
		display: none;
	}
}
@media screen and (min-width: 1200px), print {
	section.team {
		display: flex;
		align-items: flex-start;
	}
	.team .section-header {
		width: 20.833333333333333%;
		max-width: 260px;
		flex: 0 0 auto;
	}
	.team .section-body {
		flex: 1 1 auto;
	}
	.team .sub-section {
		padding-top: 16px;
	}
	/* プレイヤーリスト */
	.player-list {
		margin-top: -25px;
	}
	.player-list li:nth-child(n) {
		width: calc((100% - 4.1125541125541% * 3) / 4);
		margin-left: 4.1125541125541%;
		margin-top: 25px;
	}
	.player-list li:nth-child(4n + 1) {
		margin-left: 0;
	}
	.player-list .player-photo {
		height: calc(69.893850659152269vw * 0.219155844155844);
	}
	/* スタッフリスト */
	.staff-list {
		margin-left: -38px;
		margin-top: -30px;
	}
	.staff-list > li {
		width: calc(25% - 38px);
		margin-left: 38px;
		margin-top: 30px;
	}
	.staff-list > li.size-double {
		width: calc(50% - 38px);
	}
	.staff-list > li.size-double .photo {
		margin-top: -20px;
		margin-bottom: -20px;
		width: 41.891891891891892%;
		max-width: 203px;
		height: calc(100% + 40px)
	}
	.staff-list > li.size-double .text {
		margin-top: -20px;
		margin-bottom: -20px;
		width: 58.108108108108108%;
	}
}
@media screen and (min-width: 1414px) {
	.player-list .player-photo {
		height: calc((88.28696925329429vw - 260px) * 0.219155844155844);
	}
}
/* ============================== */
/*  TEAM SLOGAN PAGE */
/* ============================== */
section.team-slogan {
	padding-top: 135px;
	background: linear-gradient(#DB0000, #A00C0C);
	color: #fff;
}
section.team-slogan h1 {
	font-family: var(--font-montserrat);
	font-weight: 700;
	font-size: 20px;
	text-transform: uppercase;
	margin-bottom: var(--y-margin-l);
}
.team-slogan .slogan-logo {
	text-align: center;
}
.team-slogan .slogan-logo img {
	width: 167px;
	max-width: 100%;
	margin-top: 35px;
	margin-bottom: 40px;
}
.team-slogan .slogan-box-head h3{
	font-size: 38px;
	font-weight: 700;
	line-height: 1.58;
}
.team-slogan .slogan-box-body p {
	font-size: 16px;
	line-height: 1.75;
	font-weight: 300;
}
.team-slogan .slogan-box-body .more-button {
	margin-top: 15px;
}
/* 改行 */
.team-slogan br.slogan-br-sp {
	display: block;
}
.team-slogan br.slogan-br-pc {
	display: none;
}
@media screen and (min-width: 768px), print {
	/* ロゴエリア */
	section.team-slogan {
		padding-bottom: 130px;
	}
	.team-slogan .slogan-box {
		position: relative;
		padding-right: 293px;
	}
	.team-slogan .slogan-logo {
		position: absolute;
		top: 0;
		right: 0;
	}
	.team-slogan .slogan-logo img {
		width: auto;
		margin-top: 0;
	}
	.team-slogan .slogan-box-head h3{
		font-size: 44px;
		font-weight: 700;
	}
	.team-slogan .slogan-box-head + .slogan-box-body {
		margin-top: 26px;
	}
	.team-slogan .slogan-box-body p {
		font-size: 16px;
		line-height: 1.75;
		font-weight: 300;
	}
	/* 改行 */
	.team-slogan br.slogan-br-sp {
		display: none;
	}
	.team-slogan br.slogan-br-pc {
		display: block;
	}
}
@media screen and (min-width: 1200px), print {
	section.team-slogan {
		display: flex;
		align-items: flex-start;
		padding-top: 194px;
	}
	.team-slogan .section-header {
		width: 20.833333333333333%;
		max-width: 260px;
		flex: 0 0 auto;
	}
	.team-slogan .section-body {
		width: 100%;
		max-width: 870px;
		margin: 0 auto;
	}
	.team-slogan .sub-section {
		padding-top: 16px;
	}
}

/* チームの歴史 */
section.team-history {
	padding-top: 40px;
	padding-bottom: 40px;
	color: #fff;
	background: none;
}
section.team-history.side-border::after {
	top: 40px;
	height: calc(100% - 40px);
}
.team-history-section-wrapper {
	display: flex;
	position: relative;
	z-index: 1;
}
.team-history-section-wrapper:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
	background: linear-gradient(to bottom left, #212121, #1A1919);
	opacity: 0.9;
}
.list-a1 .team-history-list-item .date {
	margin-top: 20px;
}
.team-history-list-item h3 {
	margin-top: 8px;
	font-size: 15px;
	line-height: 2;
}
.team-history-list-item h3::before {
	content: "・";
	display: inline;
}
.team-history-list-item .team-history-list-body p {
	margin-top: 14px;
	font-size: 14px;
	line-height: 2;
}
/* 過去在籍選手 */
.player-history-box {
	padding: 20px 40px;
	margin-top: 42px;
	background-color: #2B2929;
	border-radius: 8px;
}
.player-history-box-ttl {
	font-size: 20px;
	line-height: 1.35;
	font-weight: bold;
}
.player-history-box-ttl + * {
	margin-top: 24px;
}
.player-history-box dl {
	display: inline-flex;
	width: 100%;
	padding-right: 1.5em;
}
.player-history-box dt,.player-history-box dd {
	font-size: 14px;
	line-height: 2;
	font-weight: 300;
}
.player-history-box dd {
	margin-left: 1em;
}
/* 表示切り替え */
.team-history .sp {
	display: block;
}
.team-history .inline-sp {
	display: inline;
}
.team-history .pc,
.team-history .inline-pc {
	display: none;
}

@media screen and (min-width: 1200px), print {
	.team-history.page-section {
		background-color: #a20000;
		overflow: hidden;
	}
}
@media screen and (min-width: 768px) {
	section.team-history {
		padding-top: 108px;
		padding-bottom: 60px;
	}
	
	section.team-history.side-border::after {
		top: 108px;
		height: calc(100% - 108px);
	}
	.team-history.page-section {
		padding-top: 58px;
		background-color: #a20000;
	}
	.team-history-section-wrapper > * {
		position: relative;
		z-index: 2;
	}
	.team-history-section-wrapper .chapter-section {
		background: transparent;
	}
	.team-history-section-wrapper .chapter-section.side-border::after {
		display: none;
	}
	.team-history-section-wrapper > div {
		position: relative;
		width: 100%;
		max-width: calc(870px + var(--x-margin) * 2);
		margin: 0 auto;
	}
	.team-history-section-wrapper > div::after {
		content: "";
		position: absolute;
		top: 0;
		left: calc(var(--x-margin) - 40px);
		width: 1px;
		height: 100%;
		background: rgba(255, 255, 255, 0.35);
	}
	.team-history-list-item {
		display: flex;
		flex-wrap: wrap;
	}
	.list-a1 .team-history-list-item .date {
		margin-top: 0;
		margin-bottom: 0;
	}
	.team-history-list-body {
		width: calc(100% - 10em);
		margin-left: auto;
	}
	.team-history-list li.team-history-list-item .date {
		width: 10em;
		line-height: 2.14;
	}
	.team-history-list-item h3 {
		margin-top: 0;
		font-size: 16px;
		line-height: 1.875;
	}
	.team-history-list-item .team-history-list-body p {
		margin-top: 10px;
		font-size: 14px;
		line-height: 2;
	}
	.team-history-list-body .text-indent-pc {
		display: block;
		text-indent: 1em;
	}
	/* 過去在籍選手 */
	.player-history-box dl {
		min-width: 33%;
	}
	/* 表示切り替え */
	.team-history .sp,
	.team-history .inline-sp {
		display: none;
	}
	.team-history .pc {
		display: block;
	}
	.team-history .inline-pc {
		display: inline;
	}
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
	.team-history-section-wrapper > div::after {
		left: 2.4vw;
	}
}
@media screen and (max-width: 767px) {
	.team-history-list-item h3 {
		padding-left: 1em;
		text-indent: -1em;
	}
}
/* ============================== */
/*  SCHEDULE/RESULT PAGE */
/* ============================== */
section.schedule-result {
	color: #fff;
}
section.schedule-result .section-header {
	color: #fff;
	margin-bottom: 0;
}
/*期間設定ナビ（共通）*/
.period-select .period-change {
	display: flex;
	margin-top: 18px;
	margin-bottom: 27px;
}
.period-select .period-change .select-wrapper:not(:first-child) {
	margin-left: 30px;
}
.period-select .period-title {
	font-size: 30px;
	font-family: var(--font-montserrat);
	font-weight: 700;
	margin: 0 0 27px;
}
@media screen and (min-width: 1200px), print {
	.period-select {
		margin: 18px 0 30px;
	}
	.period-select .period-change {
		margin: 0;
	}
	.period-select .period-title {
		margin: 0;
	}
}
@media screen and (min-width: 1200px), print {
	section.schedule-result .period-select {
		display: flex;
		flex-direction: row-reverse;
		justify-content: space-between;
		align-items: center;
	}
}
/* カレンダー */
.calendar-body {
	border: 1px solid #4B2929;
}
.calendar-body li {
	display: flex;
	background: rgba(255, 255, 255, 0.3);
	position: relative;
}
.calendar-body li:not(:first-child) {
	border-top: 1px solid #4B2929;
}
.calendar-body li .date {
	width: 30.2%;
	max-width: 150px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	border-right: 1px solid #4B2929;
	padding: 0.4em 0.5em;
	font-family: var(--font-montserrat);
	font-weight: 700;
	font-size: 18px;
}
.calendar-body li .date .num {
	text-align: center;
	width: 1.7em;
}
.calendar-body li .date .dow {
	font-size: 66.66666666%;
	width: 3.5em;
	text-align: center;
	margin-left: 0.25em;
}
.calendar-body li .event {
	font-size: 14px;
	background: #fff;
	padding: 8px;
	display: block;
	flex: 1 1 auto;
	margin: 8px;
	position: relative;
	line-height: 1.4;
	color: var(--text-color);
}
.calendar-body li .event a {
	color: #4D0D0D;
	display: block;
}
/* 右下の三角形 */
.calendar-body li .event a::after {
	content: "";
	width: 0;
	height: 0;
	box-sizing: content-box;
	border-bottom: 14px solid #333;
	border-left: 14px solid transparent;
	position: absolute;
	bottom: 0;
	right: 0;
}
.calendar-body li .event a.green::after {
	border-bottom-color: #3a8138;
}
.calendar-body li .event a.blue1::after {
	border-bottom-color: #064a90;
}
.calendar-body li .event a.blue2::after {
	border-bottom-color: #0a91de;
}
.calendar-body li .event a.blue3::after {
	border-bottom-color: #48cce0;
}
.calendar-body li .event a.red1::after {
	border-bottom-color: #e60020;
}
.calendar-body li .event a.red2::after {
	border-bottom-color: #d22d50;
}
.calendar-body li .event a.pink::after {
	border-bottom-color: #ff829f;
}
.calendar-body li .event a.orange::after {
	border-bottom-color: #f4943e;
}
.calendar-body li .event a.ocher::after {
	border-bottom-color: #b09d20;
}
.calendar-body li .event a.gray::after {
	border-bottom-color: #848484;
}
/* 空の場合 */
.calendar-body li .event:empty {
	padding: 0;
	background-color: transparent;
}
.calendar-body li .event:empty::after {
	display: none;
}
/* 白枠 **/
.calendar-body li.selected::after {
	content: "";
	position: absolute;
	top: 0px;
	left: 0px;
	pointer-events: none;
	width: 100%;
	height: 100%;
	border: 2px solid #fff;
}
@media screen and (max-width: 1199.98px) {
	.calendar-body li.no-data-wap {
		display: none;
	}
}
@media screen and (min-width: 1200px), print {
	.calendar-body {
		display: flex;
		flex-wrap: wrap;
		border: 1px solid #4B2929;
		border-top: none;
		border-left: none;
		margin-top: 50px;
	}
	.calendar-body li:nth-child(n) {
		width: calc(100% / 7);
		border-top: 1px solid #4B2929;
		border-left: 1px solid #4B2929;
		display: block;
		flex-direction: column;
		position: relative;
		min-height: 112px;
	}
	.calendar-body li .date {
		width: 100%;
		max-width: none;
		border-right: none;
		padding: 0.4em;
		display: block;
		font-size: 18px;
		text-align: center;
	}
	.calendar-body li span.dow {
		display: none;
	}
	.calendar-body li:nth-child(-n+7)::before {
		display: flex;
		justify-content: center;
		align-items: center;
		margin: 0;
		width: 100%;
		position: absolute;
		top: -50px;
		left: 0;
		height: 50px;
		font-size: 16px;
		font-family: var(--font-montserrat);
		font-weight: 700;
	}
	.calendar-body li:first-child::before {
		content: "Mon";
	}
	.calendar-body li:nth-child(2)::before {
		content: "Tue";
	}
	.calendar-body li:nth-child(3)::before {
		content: "Wed";
	}
	.calendar-body li:nth-child(4)::before {
		content: "Thu";
	}
	.calendar-body li:nth-child(5)::before {
		content: "Fri";
	}
	.calendar-body li:nth-child(6)::before {
		content: "Sat";
	}
	.calendar-body li:nth-child(7)::before {
		content: "Sun";
	}
	.calendar-body li .event {
		min-height: 50px;
		margin: 5px 19px 14px;
	}
	.calendar-body li .event:empty {
		padding: 0;
		height: 0;
		background-color: transparent;
	}
}
/* CALENDAR-PAGER */
.calendar-pager {
	font-size: 13px;
	padding-top: 15px;
}
.calendar-pager ul::after {
	content: "";
	display: block;
	clear: both;
}
.calendar-pager .prev {
	float: left;
}
.calendar-pager .next {
	float: right;
}
.calendar-pager a {
	display: block;
	position: relative;
	text-decoration: none;
}
.calendar-pager a:hover {
	text-decoration: underline;
}
.calendar-pager .prev a {
	padding-left: 1.25em;
}
.calendar-pager .next a {
	padding-right: 1.25em;
}
.calendar-pager .prev a::before, .calendar-pager .next a::before {
	content: "";
	position: absolute;
	display: block;
	border-top: 1px solid currentColor;
	border-left: 1px solid currentColor;
	transform: rotate(45deg);
	top: calc(50% - 0.3em);
	width: 0.6em;
	height: 0.6em;
}
.calendar-pager .prev a::before {
	left: 0.25em;
	transform: rotate(-45deg);
}
.calendar-pager .next a::before {
	right: 0.25em;
	transform: rotate(135deg);
}
/* ============================== */
/*  ABOUT */
/* ============================== */
section.about {}
.about .section-header {
	color: #fff;
}
.about .section-body {
	background: #fff;
	border-radius: 8px;
	box-shadow: var(--box-shadow);
	color: var(--text-color);
	padding: 0 12px;
}
.about .section-header .lead-copy {
	font-size: 16px;
	line-height: 1.75;
	margin-top: 18px;
	font-weight: 500;
}
.about .section-body {
	font-size: 14px;
	line-height: 1.75;
}
.about .section-body h2 {
	font-size: 26px;
	line-height: 1.4;
	margin: 0 0 0.6em;
	font-weight: 500;
}
.about .section-body h3 {
	font-size: 14px;
	line-height: 1.5;
	font-weight: 500;
	padding: calc(0.464285714285714em - 1px) 1.4em;
	border-radius: 1.214285714285714em;
	border: 1px solid currentColor;
	display: inline-block;
	margin: 0 0 1em;
}
.about .section-body .section-l {
	border-top: 1px solid currentColor;
	padding: 25px 0;
}
.section-body > .section-l:first-child {
	border-top: none;
}
.about .section-body .section-m + .section-m {
	margin-top: 23px;
}
.about figure {
	margin: 30px 0;
}
.about figure + figure {
	margin-top: 20px;
}
@media screen and (min-width: 1200px), print {
	section.about {
		display: flex;
		align-items: flex-start;
	}
	.about .section-header {
		width: 25%;
		max-width: 300px;
		flex: 0 0 auto;
		padding-right: 40px;
	}
	.about .section-body {
		flex: 1 1 auto;
		padding: 15px 40px;
		font-size: 16px;
	}
	.about .section-body .section-m {
		font-size: 14px;
	}
	.col2 {
		column-count: 2;
		column-gap: 80px;
	}
	.col2 * {
		break-inside: avoid;
	}
	.about .about-figure1 {
		margin: 0 0 0 -30px;
	}
	.about figure + figure {
		margin-top: 20px;
	}
}
/* ストライプのテーブル */
table.stripe-table1 {
	display: block;
	font-size: 14px;
	margin: 30px -4px 0;
	width: calc(100% + 8px);
}
table.stripe-table1 thead, table.stripe-table1 tbody {
	display: block;
}
table.stripe-table1 tr {
	display: flex;
	position: relative;
}
table.stripe-table1 td, table.stripe-table1 th {
	display: block;
	z-index: 1;
	position: relative;
}
/* テーブルの幅*/
table.stripe-table1 tr > *:first-child {
	width: 23%;
	flex: 0 0 auto;
}
table.stripe-table1 tr > *:nth-child(2), table.stripe-table1 tr > *:nth-child(3) {
	width: calc((77% - 7px) / 2);
	flex: 0 0 auto;
	border-left: 1px solid #707070;
	border-right: 1px solid #707070;
}
table.stripe-table1 tr > *:nth-child(3) {
	margin-left: 7px;
}
/*テーブルヘッダ */
table.stripe-table1 thead th:not(:first-child) {
	border-radius: 8px 8px 0 0;
	border-top: 1px solid #707070;
	color: #fff;
	padding: 16px 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	font-weight: 500;
}
table.stripe-table1 thead th:nth-child(2) {
	background: #656565;
}
table.stripe-table1 thead th:nth-child(3) {
	background: #905959;
}
/*テーブルボディ */
table.stripe-table1 tbody tr > *:nth-child(2), table.stripe-table1 tbody tr > *:nth-child(3) {
	padding: 10px 8px calc(10px + 5px);
	display: flex;
	align-items: center;
}
table.stripe-table1 tbody tr:last-child > *:nth-child(2), table.stripe-table1 tbody tr:last-child > *:nth-child(3) {
	border-bottom: 1px solid #707070;
	border-radius: 0 0 8px 8px;
	padding-bottom: 10px;
}
table.stripe-table1 tbody th {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 8px;
	font-size: 13px;
	font-weight: 500;
}
table.stripe-table1 tbody .align-center {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}
/* 背景カラー */
table.stripe-table1 tbody tr::before {
	content: "";
	background: #EAEAEA;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: calc(100% - 5px);
	border-radius: 8px 0 0 8px;
}
table.stripe-table1 tbody tr:nth-child(even)::before {
	background: #F2DBDB;
}
table.stripe-table1 tbody tr:last-child::before {
	height: 100%;
	border-radius: 8px 0 8px 8px;
}
.game-progress-table tbody th span {
	word-break: keep-all;
}
@media screen and (min-width: 1200px), print {
	table.stripe-table1 tr > *:first-child {
		width: 19%;
	}
	table.stripe-table1 tr > *:nth-child(2), table.stripe-table1 tr > *:nth-child(3) {
		width: calc((81% - 16px) / 2);
	}
	table.stripe-table1 tr > *:nth-child(3) {
		margin-left: 16px;
	}
	/*テーブルヘッダ */
	table.stripe-table1 thead th:not(:first-child) {
		padding: 16px 15px;
		font-size: 18px;
	}
	table.stripe-table1 thead th:nth-child(2) {
		background: #656565;
	}
	table.stripe-table1 thead th:nth-child(3) {
		background: #905959;
	}
	/*テーブルボディ */
	table.stripe-table1 tbody tr > *:nth-child(2), table.stripe-table1 tbody tr > *:nth-child(3) {
		padding: 18px 20px calc(18px + 6px); /*6pxは上下の空き*/
	}
	table.stripe-table1 tbody tr:last-child > *:nth-child(2), table.stripe-table1 tbody tr:last-child > *:nth-child(3) {
		padding-bottom: 18px;
		min-height: calc(1.75em * 2 + 18px + 18px + 6px);
	}
	table.stripe-table1 tbody th {
		font-size: 16px;
		padding: 8px 1em;
	}
}
/* ============================== */
/*  RESULT DETAIL */
/* ============================== */
section.result-detail {
	color: #fff;
	padding-top: calc(108px + 30px);
	background: linear-gradient(#D50707, #AD0E0E);
}
section.result-detail .section-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
section.result-detail .section-bg img {
	width: 100%;
	height: auto;
}
section.result-detail .section-header, section.result-detail .section-body {
	position: relative;
	z-index: 1;
}
.result-detail.side-border::after {
	top: calc(108px + 30px);
	height: calc(100% - 108px - 30px);
}
.result-detail .section-header .section-heading {
	border-left: none;
	margin-left: 0;
	padding-left: 0;
	font-size: 20px;
	line-height: 1.5;
}
.result-detail .section-header {
	border-left: 4px solid #fff;
	margin-left: calc(var(--x-margin) * -1);
	padding-left: calc(var(--x-margin) - 4px);
}
.result-detail .section-header .date {
	font-size: 26px;
	font-family: var(--font-helvetica);
	margin: 0.5em 0;
	font-weight: 400;
}/*
.result-detail .section-header .dow {
	display: none;
}*/
.result-detail .section-header .place {
	margin: 1em 0 0;
	font-size: 15px;
	padding-left: 1.4em;
	background: url("../images/common/ico_place.png") no-repeat left top 0.1em;
	background-size: 0.866666666666667em;
}
@media screen and (min-width: 1200px), print {
	section.result-detail {
		padding-top: 100px;
		margin-top: var(--global-header-height);
	}
	.result-detail.side-border::after {
		top: 100px;
		height: calc(100% - 100px);
	}
	.result-detail .section-header .section-heading {
		font-size: 30px;
	}
	.result-detail .section-header {
		border-left: 4px solid #fff;
		margin-left: -40px;
		padding-left: 36px;
	}
	.result-detail .section-header .date {
		font-size: 30px;
	}/*
	.result-detail .section-header .dow {
		display: none;
	}*/
}
.result-panel + .result-panel {
	margin-top: 20px;
}
.result-panel .remarks {
	font-size: 13px;
	margin-bottom: 35px;
}
.result-panel .remarks:empty {
	display: none;
}
.result-panel .result-panel-inner {
	color: var(--text-color);
	border-radius: 8px;
	background: #fff;
	box-shadow: var(--box-shadow);
}
.result-panel.panel-a .result-panel-inner {
	background: rgba(255, 255, 255, 0.6);
	padding: 20px 8px 15px;
}
.result-panel.panel-a h2 {
	font-size: 18px;
	font-weight: 700;
	margin: 0 0 15px;
}
.result-panel.panel-a .footnote {
	font-size: 13px;
	margin-top: 10px;
}
.result-panel.panel-a .footnote:empty {
	display: none;
}
@media screen and (min-width: 1200px), print {
	.result-panel + .result-panel {
		margin-top: 30px;
	}
	.result-panel > .remarks {
		font-size: 15px;
		margin-bottom: 15px;
	}
	.result-panel.panel-a .result-panel-inner {
		padding: 30px 30px 30px;
	}
	.result-panel.panel-a h2 {
		font-size: 23px;
		font-weight: 500;
		margin: 0 0 20px;
	}
	.result-panel.panel-a .footnote {
		font-size: 15px;
		margin-top: 20px;
	}
	.result-panel.panel-a .result-list-item {}
	.result-panel.panel-a .result-list-item dt {
		border-radius: 8px 0 0 8px;
		background: #fff;
	}
	.result-panel.panel-a .result-list-item dd {
		border-radius: 0 8px 8px 0;
		background: #fff;
	}
}
.result-panel.panel-b .result-panel-inner {
	background: #fff;
	padding: 20px 15px 0;
}
.result-panel.panel-b .result-header {
	padding-bottom: 10px;
}
.result-panel.panel-b h2 {
	font-size: 30px;
	line-height: 1.3;
	font-family: var(--font-helvetica);
	font-weight: 700;
	margin: 0 0 0.2em;
}
.result-panel.panel-b h2 .dow {
	font-size: 66.66666666%;
	margin-left: 0.33333333em;
}
.result-panel.panel-b .games {
	font-size: 14px;
	font-weight: 500;
	text-align: center;
	padding: 0.6em 1em;
	border-radius: 4px;
	border: 2px solid #444444;
	color: #444444;
	margin: 0 0 10px;
}
.result-panel.panel-b .games.red {
	border-color: #8D1000;
	color: #8D1000;
}
.result-panel.panel-b .game-footnote {
	font-size: 15px;
}
.result-panel.panel-b .result-body {
	margin-left: -15px;
	margin-right: -15px;
	padding-top: 10px;
}
.result-panel.panel-b .score {
	border-top: 1px solid #aaaaaa;
	display: flex;
}
.result-panel.panel-b .score.withdrew {
	position: relative;
}
.result-panel.panel-b .score.withdrew:after {
	content: '途中棄権';
	position: absolute;
	transform: translate(-50%, 0);
	-webkit-transform: translate(-50%, 0);
	-ms-transform: translate(-50%, 0);
	top: 3.5em;
	left: 50%;
	padding: 0 0.4em;
	color: #da2222;
	font-size: 1.3em;
	font-weight: bold;
	background-color: #f6c9c9;
	border: 2px solid #da2222;
}
.result-panel.panel-b .score > * {
	width: 50%;
	text-align: center;
	font-size: 13px;
	font-family: var(--font-helvetica);
	padding: 14px 10px 12px;
	line-height: 1.5;
}
.result-panel.panel-b .score.withdrew > * {
	padding-bottom: 6em;
}
.result-panel.panel-b .score .point {
	font-size: 43px;
	font-weight: 700;
	line-height: 1.3;
}
.result-panel.panel-b .score > *:nth-child(2) {
	border-left: 1px solid #aaaaaa;
}
.result-panel.panel-b .player {
	border-top: 1px solid #aaaaaa;
	display: flex;
}
.result-panel.panel-b .player > * {
	width: 50%;
	font-size: 14px;
	padding: 14px 10px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.result-panel.panel-b .player > *:nth-child(2) {
	border-left: 1px solid #aaaaaa;
}
.result-panel.panel-b .player .player-name {
	line-height: 1.3;
	font-weight: 500;
	display: flex;
}
.result-panel.panel-b .player .player-name + .player-name {
	margin-top:6px;
}
.result-panel.panel-b .player .player-name .icon {
	display: block;
	width: 1.285714285714286em;
	line-height: 1;
	margin-right: 0.5em;
	position: relative;
	flex: 0 0 auto;
}
.result-panel.panel-b .score .team {
	background: #eae7e7;
	font-size: 13px;
	font-weight: 500;
	text-align: center;
	padding: 0.6em 0.5em;
	border-radius: 6px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 0 15px;
}
.result-panel.panel-b .score .team .icon {
	display: block;
	width: 1.4em;
	height: 1.4em;
	border-radius: 50%;
	overflow: hidden;
	margin-right: 0.6em;
	line-height: 1;
}
.result-panel.panel-b .score .team .text {
	padding-top: 0.15em;
	line-height: 1.2;
	display: block;
}
@media screen and (min-width: 1200px), print {
	.result-panel.panel-b .result-panel-inner {
		display: flex;
		padding: 0;
	}
	.result-panel.panel-b .result-header {
		width: 43%;
		display: flex;
		flex-direction: column;
		justify-content: center;
		padding: 10px 6%;
	}
	.result-panel.panel-b .result-body {
		width: 57%;
		border-left: 1px solid #aaaaaa;
		border-right: 1px solid #aaaaaa;
		margin: 0;
		padding: 0;
		margin-right: 6%;
	}
	.result-panel.panel-b h2 {
		font-size: 50px;
	}
	.result-panel.panel-b h2 .dow {
		font-size: 48%;
		margin-left: 0.33333333em;
	}
	.result-panel.panel-b .games {
		font-size: 18px;
		padding: 0.5em 1em;
		margin: 0 0 24px;
	}
	.result-panel.panel-b .score {
		border-top: none;
	}
	.result-panel.panel-b .score.withdrew:after {
		top: 6em;
	}
	.result-panel.panel-b .score > * {
		font-size: 18px;
		padding: 35px 10px 25px;
		line-height: 1.88;
	}
	.result-panel.panel-b .score .point {
		font-size: 80px;
		line-height: 1.15;
	}
	.result-panel.panel-b .player > * {
		font-size: 16px;
		padding: 17px 10px;
	}
	.result-panel.panel-b .player .player-name {
		padding-top: 0.35em;
		padding-bottom: 0.35em;
	}
	.result-panel.panel-b .score .team {
		font-size: 15px;
		padding: 0.75em 1em;
		border-radius: 6px;
		margin: 0 0 25px;
	}
	.result-panel.panel-b .score .team .icon {
		width: 1.6em;
		height: 1.6em;
	}
}
/* ============================== */
/*  NEWS ARCHIVE */
/* ============================== */
section.news-archive {
	color: #fff;
}
.news-archive .news-archive-container {
	background: rgba(0, 0, 0, 0.22);
	border-radius: 8px;
	box-shadow: var(--box-shadow);
	padding: 20px 10px;
}
.news-archive .section-heading br {
	display: none;
}
.news-archive .section-body .archive-title {
	display: flex;
	align-items: center;
	font-size: 20px;
	font-family: var(--font-montserrat);
	margin: 0 0 16px;
}
.news-archive .section-body .archive-title::after {
	content: "";
	width: 3em;
	height: 1px;
	background: #fff;
	flex: 1 1 auto;
	margin-left: 0.5em;
}
@media screen and (min-width: 1200px), print {
	.news-archive .section-header {
		width: 18%;
		max-width: 230px;
	}
	.news-archive .section-heading br {
		display: block;
	}
	.news-archive .section-body {
		width: 82%;
		flex: 1 1 auto;
	}
	.news-archive .news-archive-container {
		padding: 45px 45px;
	}
}
/* ニュースリスト */
.news-archive .news-list {
	display: flex;
	flex-wrap: wrap;
	margin-top: -20px;
}
.news-archive .news-list .news-list-item {
	width: calc((100% - 4.878048780487805%) / 2);
	margin-top: 20px;
	margin-left: 4.878048780487805%;
}
.news-archive .news-list .news-list-item:nth-child(odd) {
	margin-left: 0;
}
.news-archive .news-list .news-thumb {
	height: calc((89.066666666vw - 20px) * 0.47560975609756098 * 152 / 228);
}
@media screen and (min-width: 1200px), print {
	.news-archive {
		display: flex;
	}
	.news-archive .news-list {
		display: flex;
		flex-wrap: wrap;
		margin-top: -40px;
	}
	.news-archive .news-list .news-list-item:nth-child(n) {
		width: calc((100% - 7.02576112412178% * 2) / 3);
		margin-top: 40px;
		margin-left: 7.02576112412178%;
	}
	.news-archive .news-list .news-list-item:nth-child(3n + 1) {
		margin-left: 0;
	}
	.news-archive .news-list .news-thumb {
		height: calc((72.395314787701318vw - 90px) * 0.28649492583918813 * 152 / 228);
	}
}
/* お問合せ */
.news-archive .contact-info {
	margin-top: 40px;
}
.news-archive .contact-info .contact-button a {
	background: #fff;
	font-size: 16px;
	padding: 0.5em 2.0em 0.5em 1.5em;
	border-radius: 5px;
	text-decoration: none;
	text-align: center;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #870E00;
	font-weight: 700;
	max-width: 404px;
}
.news-archive .contact-info .contact-button a::before {
	content: "";
	width: 1.5em;
	height: 1.5em;
	background: url("../images/common/ico_contact-red.png") no-repeat center;
	background-size: 100%;
	margin-right: 0.5em;
	position: relative;
	display: block;
}
.news-archive .contact-info .contact-button a::after {
	content: "";
	width: 0.6em;
	height: 0.6em;
	display: block;
	position: absolute;
	top: calc(50% - 0.3em);
	right: 0.8em;
	border-top: 1px solid #870E00;
	border-right: 1px solid #870E00;
	transform: rotate(45deg);
}
.news-archive .contact-info .contact-button a:hover {
	background-color: #111111;
	color: #fff;
}
.news-archive .contact-info .contact-button a:hover::before {
	background-image: url("../images/common/ico_contact.png");
}
.news-archive .contact-info .contact-button a:hover::after {
	border-top-color: #fff;
	border-right-color: #fff;
}
.news-archive .contact-info .contact-notice {
	font-size: 13px;
	margin-top: 20px;
}
/* ============================== */
/*  NEWS DETAIL */
/* ============================== */
section.news-detail {
	color: #fff;
	padding-top: calc(108px + 30px);
}
.page-section.news-detail::after {
	top: calc(108px + 30px);
	height: calc(100% - 108px - 30px);
}
.news-detail .section-body {
	background: #fff;
	color: var(--text-color);
	padding: 20px 12px 30px;
	box-shadow: var(--box-shadow);
	border-radius: 8px;
}
.news-detail .section-heading br {
	display: none;
}
.news-detail .article-header {
	border-bottom: 1px solid #707070;
	margin-bottom: 30px;
	padding-bottom: 15px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.news-detail .article-header .post-date {
	color: #444444;
	font-weight: 700;
	font-size: 14px;
	font-family: var(--font-helvetica);
}
.news-detail .article-header .category {
	font-size: 14px;
	position: relative;
	top: -0.1em;
}
.news-detail .article-title {
	font-size: 20px;
	font-weight: 700;
	width: 100%;
	margin-top: 15px;
}
.news-detail .article-photo {
	padding: 8px;
	box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
	margin-bottom: 25px;
}
.news-detail .article-text {
	font-size: 14px;
	line-height: 1.85;
}
@media screen and (min-width: 1200px), print {
	section.news-detail {
		display: flex;
		padding-top: 100px;
		margin-top: var(--global-header-height);
	}
	section.news-detail.side-border::after {
		top: 100px;
		height: calc(100% - 100px);
	}
	.news-detail .section-header {
		width: 18%;
		max-width: 230px;
		padding-right: 40px;
	}
	.news-detail .section-body {
		width: 82%;
		flex: 1 1 auto;
		padding: 45px 45px;
	}
	.news-detail .section-heading br {
		display: block;
	}
	.news-detail .article-header {
		margin-bottom: 40px;
		padding-bottom: 25px;
		justify-content: flex-start;
	}
	.news-detail .article-header .post-date {
		margin-right: 3em;
	}
	.news-detail .article-header .category {
		font-size: 14px;
	}
	.news-detail .article-title {
		font-size: 30px;
		margin-top: 30px;
		line-height: 1.6;
	}
	.news-detail .article-photo {
		margin-bottom: 25px;
	}
	.news-detail .article-text {
		font-size: 15px;
		line-height: 2.4;
	}
}
/* PAGER */
.article-pager {
	border-top: 1px solid #707070;
	font-size: 12px;
	padding-top: 30px;
	margin-top: 25px;
}
.article-pager ul {
	display: flex;
	justify-content: space-between;
	width: 90%;
	margin: 0 auto;
	max-width: 290px;
}
.article-pager a {
	display: block;
	position: relative;
	text-decoration: none;
}
.article-pager .prev a {
	padding-left: 1.25em;
}
.article-pager .next a {
	padding-right: 1.25em;
}
.article-pager .prev a::before, .article-pager .next a::before {
	content: "";
	position: absolute;
	display: block;
	border-top: 1px solid currentColor;
	border-left: 1px solid currentColor;
	transform: rotate(45deg);
	top: calc(50% - 0.3em);
	width: 0.6em;
	height: 0.6em;
}
.article-pager .prev a::before {
	left: 0;
	transform: rotate(-45deg);
}
.article-pager .next a::before {
	right: 0;
	transform: rotate(135deg);
}
.article-pager a:hover {
	text-decoration: underline;
}
@media screen and (min-width: 1200px), print {
	.article-pager {
		font-size: 12px;
		padding-top: 35px;
		margin-top: 60px;
	}
}
/* ============================== */
/*  PLAYER DETAIL */
/* ============================== */
/* コンテンツトップのナビゲーション */
.contents-top-nav ul.contents-pager {
	display: flex;
	position: absolute;
	font-size: 16px;
	top: calc(50% - 0.75em);
	right: 2.5em;
}
.contents-top-nav ul.contents-pager a {
	color: #fff;
	overflow: hidden;
	text-indent: -9999px;
	position: relative;
	width: 1.5em;
	height: 1.5em;
	display: block;
	margin-left: 2.5em;
}
.contents-top-nav ul.contents-pager a::before {
	content: "";
	display: block;
	width: 0.8em;
	height: 0.8em;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
	position: absolute;
	top: calc(50% - 0.4em);
}
.contents-top-nav ul.contents-pager .prev a::before {
	left: 0.6em;
	transform: rotate(-45deg)
}
.contents-top-nav ul.contents-pager .next a::before {
	right: 0.6em;
	transform: rotate(135deg)
}
@media screen and (max-width: 1199.98px) {
	.player-detail-page .contents-top-nav .back {
		display: none;
	}
	.player-detail-page .contents-top-nav, .player-detail-page .contents-top-nav ul.contents-pager {
		position: static;
	}
	.player-detail-page .contents-top-nav ul.contents-pager a {
		position: fixed;
		top: 45vw;
		margin: 0;
		z-index: 999;
	}
	.player-detail-page .contents-top-nav ul.contents-pager .prev a {
		left: 5px;
	}
	.player-detail-page .contents-top-nav ul.contents-pager .next a {
		right: 5px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1199.98px) {
	.player-detail-page .contents-top-nav ul.contents-pager a {
		top: 25vw;
	}
}
@media screen and (min-width: 1200px), print {
	.player-detail-page .contents-top-nav {
		display: block;
	}
}
section.player-detail {
	color: #fff;
	padding: 0;
	background: none;
}
.player-detail .player-hero {
	background-color: #c00000;
}
/* メインイメージ */
.player-detail .player-bg-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}
/* 顔写真 */
.player-detail .photo-face {
	display: none;
}
/* メインイメージにオーバーレイするテキスト */
.player-detail .player-hero-text {
	min-height: 165vw;
	padding: 89vw 25px 0;
	position: relative;
}
.player-detail .player-name-sub {
	display: flex;
	flex-direction: column;
	margin: 12px 0 10px;
}
.player-detail .player-name-ja {
	font-size: 16px;
	font-weight: 600;
}
.player-detail .player-name-nick {
	margin-left: 1.875em;
	font-size: 12px;
}
.player-detail .player-header .sns {
	display: flex;
	font-size: 15px;
	padding-top: 0.7em;
}
.player-detail .player-header .sns li {
	width: 1.2em;
	line-height: 1;
}
.player-detail .player-header .sns li:not(:first-child) {
	margin-left: 1em;
}
.player-detail .player-header .sns a:hover {
	opacity: 0.7;
}
.player-detail .player-data {
	padding: 18px 7px;
}
.player-detail .player-data .player-data-list {
	display: flex;
	flex-wrap: wrap;
}
.player-detail .player-data .player-data-list > div {
	width: calc((100% - 1.5em) / 2);
	font-size: 12px;
	font-weight: 500;
	display: flex;
	padding: 5.5px 0;
	margin-left: 1.5em;
}
.player-detail .player-data .player-data-list > div:nth-child(odd) {
	margin-left: 0;
}
.player-detail .player-data .player-data-list > div.player-data-w-100 {
	width: 100%;
}
.player-detail .player-data .player-data-list dt {
	font-size: 12px;
	border-left: 2px solid #fff;
	line-height: calc(13em / 8);
	padding-left: 1em;
	margin-right: 1em;
	min-width: calc(5em + 2px);
	flex: 0 0 auto;
}
.player-detail .player-data .player-data-list dd {
	text-align: left;
}
.player-detail .player-comment {
	font-size: 14px;
	margin-top: 14px;
	padding-bottom: 30px;
}
.player-detail .player-comment:empty {
	display: none;
}
@media screen and (min-width: 1200px), print {
	.player-detail.page-section {
		padding-top: var(--global-header-height);
		background-color: #a20000;
		overflow: hidden;
	}
	.player-hero {
		position: relative;
		background: none;
		overflow-x: hidden;
	}
	.player-detail .player-bg-image {
		position: relative;
		top: 0;
		left: 0;
		width: 100%;
		overflow-x: hidden;
	}
	.player-detail .player-bg-image img {
		width: 107.906295754026354%;
		margin-left: -3.953147877013177%;
	}
	/* 顔写真 */
	.player-detail .photo-face {
		display: block;
		position: fixed;
		top: var(--global-header-height);
		right: 0;
		width: 51%;
		width: 54%;
	}
	.player-detail .player-hero-text {
		padding: 0;
		z-index: 1;
		position: absolute;
		top: 12%;
		left: 36%;
		min-height: auto;
	}
	.player-detail .player-name img {
		width: 534px;
	}
	.player-detail .player-name-sub {
		margin: 20px 0 20px;
	}
	.player-detail .player-name-ja {
		font-size: 26px;
	}
	.player-detail .player-name-nick {
		font-size: 16px;
	}
	.player-detail .player-header .sns {
		font-size: 18px;
		padding-top: 0.25em;
	}
	.player-detail .player-data, .player-detail .player-comment {
		width: 534px;
	}
	.player-detail .player-data {
		padding: 33px 12px;
	}
	.player-detail .player-data .player-data-list {
		display: flex;
		flex-wrap: wrap;
	}
	.player-detail .player-data .player-data-list > div {
		font-size: 16px;
		padding: 9px 0;
	}
	.player-detail .player-data .player-data-list dt {
		font-size: 15px;
		border-left-width: 4px;
		line-height: calc(13em / 8);
		padding-left: 1em;
		margin-right: 2em;
		min-width: calc(5em + 3px);
	}
	.player-detail .player-comment {
		font-size: 14px;
		line-height: 2;
		margin: 18px 0;
	}
	/* LOAD時 ANIMATION PC-ONLY */
	.player-detail .photo-face {
		opacity: 0;
		transform: translateX(8vw);
		transition: 500ms 200ms;
	}
	.player-header {
		opacity: 0;
		transform: translateX(-4vw);
		transition: 500ms 200ms;
	}
	.player-detail .player-data {
		opacity: 0;
		transform: translateY(30px);
		transition: 500ms 200ms;
	}
	.player-detail .player-comment {
		opacity: 0;
		transform: translateY(30px);
		transition: 500ms 200ms;
	}
	body.js-onload .player-detail .photo-face {
		opacity: 1;
		transform: translateX(0);
	}
	body.js-onload .player-header {
		opacity: 1;
		transform: translateX(0);
	}
	body.js-onload .player-detail .player-data {
		opacity: 1;
		transform: translateY(0);
	}
	body.js-onload .player-detail .player-comment {
		opacity: 1;
		transform: translateY(0);
	}
}
@media screen and (min-width: 768px) and (max-width: 1199.98px) {
	.player-detail.page-section {
		background-color: #a20000;
	}
	.player-hero {
		position: relative;
		background: none;
	}
	.player-detail .player-bg-image {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		overflow-x: hidden;
	}
	.player-detail .player-bg-image img {
		width: 107.906295754026354%;
		margin-left: -3.953147877013177%;
	}
	/* 顔写真 */
	.player-detail .photo-face {
		display: block;
		position: fixed;
		top: 0;
		right: 0;
		width: 51%;
	}
	.player-detail .player-hero-text {
		position: relative;
		z-index: 1;
		padding: 0;
		padding-top: 12%;
		padding-left: 36%;
		min-height: auto;
	}
	.player-detail .player-name img {
		width: 420px;
	}
	.player-detail .player-data, .player-detail .player-comment {
		width: 420px;
	}
	.player-detail .player-data .player-data-list > div {
		font-size: 12px;
	}
	.player-detail .player-data .player-data-list dt {
		font-size: 11px;
	}
}
/* Q and A*/
.player-qanda {
	background: linear-gradient(#c00000, #AD0E0E);
	padding: 15px 16% 50px;
	font-size: 15px;
	line-height: 1.75;
	position: relative;
	z-index: 1;
}
.player-qanda-list > div:not(:first-child) {
	margin-top: 2em;
}
.player-qanda dt {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	border: 1px solid #fff;
	border-radius: 17px;
	font-weight: 300;
}
.player-qanda dd {
	margin-top: 1.0em;
	font-size: 17px;
	text-align: center;
	line-height: 1.5;
	font-weight: 600;
}
@media screen and (min-width: 1200px), print {
	.player-qanda {
		font-size: 15px;
		margin: -22.5vw auto 0;
		position: relative;
		z-index: 1;
		background: transparent;
		padding: 0 0 50px;
	}
	.player-qanda-list {
		display: flex;
		flex-wrap: wrap;
		width: 986px;
		margin: -45px auto 0;
	}
	.player-qanda-list > div:nth-child(n) {
		width: calc((100% - 5.5% * 2) / 3);
		margin-left: 5.5%;
		margin-top: 45px;
	}
	.player-qanda-list > div:nth-child(3n + 1) {
		margin-left: 0;
	}
}
@media screen and (min-width: 768px) and (max-width: 1199.98px) {
	.player-qanda {
		background: transparent;
		margin-top: 45px;
	}
	.player-qanda dt {
		display: inline-flex;
		min-width: 300px;
	}
	.player-qanda dd {
		text-align: left;
	}
}
/* 選手詳細下部のセクション */
.list-a1 li {
	line-height: 1.35;
}
.list-a1 li:not(:first-child) {
	margin-top: 1em;
}
.list-a1 li .date {
	opacity: 0.7;
	margin-bottom: 0.25em;
	font-size: 14px;
}
.list-a1 li a {
	text-decoration: none;
}
.list-a1 li a:hover {
	text-decoration: underline;
}
.list-a1 li h3 {
	font-weight: 500;
}
.list-a2 {
	line-height: 1.35;
}
.list-a2 dt {
	padding-left: 1em;
	text-indent: -1em;
	font-weight: 500;
}
.list-a2 dt::before {
	content: "・";
	width: 1em;
	text-align: center;
}
.list-a2 dt:not(:first-child) {
	margin-top: 1em;
}
.list-a2 dd {
	padding-left: 1em;
	font-weight: 500;
}
.list-a3 {
	line-height: 1.35;
}
.list-a3 li {
	padding-left: 1em;
	text-indent: -1em;
}
.list-a3 li::before {
	content: "";
	width: 1em;
	text-align: center;
}
.list-a3 li:not(:first-child) {
	margin-top: 1em;
}
.player-schedule, .player-game-result, .player-record {
	background: linear-gradient(to bottom left, #292929, #222222);
	color: #fff;
	font-size: 15px;
}
@media screen and (min-width: 1200px), print {
	.player-detail-section-wrapper {
		display: flex;
		position: relative;
		z-index: 1;
	}
	.player-detail-section-wrapper:after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: linear-gradient(to bottom left, #212121, #1A1919);
		opacity: 0.9;
	}
	.player-detail-section-wrapper > * {
		position: relative;
		z-index: 2;
	}
	.player-detail-section-wrapper .chapter-section {
		background: transparent;
	}
	.player-detail-section-wrapper .chapter-section.side-border::after {
		display: none;
	}
	.player-detail-section-wrapper .left-side, .player-detail-section-wrapper .right-side {
		width: 50%;
		position: relative;
	}
	.player-detail-section-wrapper .left-side::after, .player-detail-section-wrapper .right-side::after {
		content: "";
		position: absolute;
		top: 0;
		left: calc(var(--x-margin) - 40px);
		width: 1px;
		height: 100%;
		background: rgba(255, 255, 255, 0.35);
	}
}
/* フッター問い合わせボタン */
#global-footer .copyright {
	margin-top: 40px;
}
#global-footer .footer-title .text {
	display: block;
	padding-top: 20px;
}
#global-footer .copyright {
	margin-top: 40px;
}
.news-archive .contact-info {
	display: none;
}
@media screen and (min-width: 1200px), print {
	#global-footer {
		padding-bottom: 80px;
	}
	#global-footer .footer-title .text {
		padding-top: 12px;
	}
	#global-footer .copyright {
		margin-top: 0;
		margin-left: 0;
	}
	#global-footer .footer-address {
		display: block;
	}
	#global-footer .footer-regal {
		margin-left: 25px;
		position: relative;
		top: 5px;
	}
}
/* フッター問い合わせボタンここまで */

/* GAZOOSPORTS配下 全サイト共通 フッタバナーエリア style調整 */
.gs-allsites-common.footer-banner-area {
  overflow: hidden;
  background: #fff;
  position: relative;
}
/* GAZOOSPORTS配下 全サイト共通 フッタバナーエリア style調整 ここまで */