:root {
	--team-primary-color: #E61E1E;
	--team-secondary-color: #0064D2;

	--president-background-color: #444444;
	--genre-color: #888;
	--shop-border-color: #DDD;
	--shop-title-color: #000;
	--shop-message-color: #000;
	--shop-site-color: #888;

	--float-background-color: #444444E6;
	--float-window-background-color: #444444E6;

	--float-window-z-index: 999;
	--float-president-z-index: 900;

	--responsive-1920-width: 1200px;
}


/* ショップのコメントのテキストエリアのサイズが固定されるのでリセット */
textarea:not([rows]) {
	min-height: unset;
}

.material_primary {
	color: var(--team-primary-color);
	display: inline-flex;
	vertical-align: middle;
}
/* デザインに沿ったレスポンシブ */
.responsive {
	padding-left: calc((100% - var(--responsive-1920-width)) / 2);
	padding-right: calc((100% - var(--responsive-1920-width)) / 2);
	width: var(--responsive-1920-width);
}
.responsive-fixed {
	padding-left: 60px;
	padding-right: 60px;
	width: calc(100% - 120px);
}
/* パディングは一定のレスポンシブ */
/*
.responsive {
	padding-left: 40px;
	padding-right: 40px;
	width: calc(100% - 80px);
}
*/

/* ヘッダーのハンバーガーボタン */
header figure {
	cursor: pointer;
}

.title {
	padding-bottom: 3px;

	font-family: Cabin;
	font-size: min(calc(2.25rem + ((1vw - 12.8px) * 1.0938)), 43px);
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: 4.3px;
}
.sub {
	padding-bottom: 20px;

	font-size: 21px;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 2.1px;
}
.sub2-container {
    display: flex;
    margin-bottom: 10px;
}
.sub2 {
    padding-bottom: min(calc(1.5rem + ((1vw - 12.8px) * 1.25)), 16px);
    padding-right: min(calc(1.5rem + ((1vw - 12.8px) * 1.25)), 16px);
    padding-left: 2px;

	font-family: Cabin;
	font-size: min(calc(1.5rem + ((1vw - 12.8px) * 1.25)), 32px);
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: 2.1px;

    background: url(../../assets/images/triangle_underline.svg) no-repeat left bottom;
    background-size: 100% min(calc(1.5rem + ((1vw - 12.8px) * 1.25)), 16px);
}
@media screen and (max-width: 1280px) {
	.responsive {
		padding-left: 60px;
		padding-right: 60px;
		width: calc(100% - 120px);
	}
	.title {
		font-size: 36px;
		line-height: 1.2;
		letter-spacing: 3.6px;
	}
	.sub {
		font-size: 18px;
		line-height: 1.5;
		letter-spacing: 1.8px;
	}
    .sub2-container {
        margin-bottom: 6px;
    }
	.sub2 {
		font-size: 24px;
		line-height: 1.5;
		letter-spacing: 1.8px;

        padding-bottom: 13px;
        padding-right: 6px;
        background-size: 100% 13px;
	}
}
@media screen and (max-width: 480px) {
	.responsive {
		padding-left: 20px;
		padding-right: 20px;
		width: calc(100% - 40px);
	}
	.responsive-fixed {
		padding-left: 20px;
		padding-right: 20px;
		width: calc(100% - 40px);
	}
	.responsive-president {
		padding-left: 40px;
		padding-right: 40px;
		width: calc(100% - 80px);
	}
	.title {
		padding-bottom: 4px;

		font-size: max(calc(1.3125rem + ((1vw - 3.75px) * 1.6575)), 21px);
		line-height: 1.2;
		letter-spacing: 2.1px;
	}
	.sub {
		font-size: 13px;
		line-height: 1.5;
		letter-spacing: 1.3px;
	}
    .sub2-container {
        margin-bottom: 4px;
    }
	.sub2 {
		font-size: min(calc(1rem + ((1vw - 3.75px) * 0.854)), 16px);
		line-height: 1.5;
		letter-spacing: 1.3px;

        padding-bottom: min(calc(1.5rem + ((1vw - 12.8px) * 1.25)), 9px);
        padding-right: 5px;
        background-size: 100% min(calc(1.5rem + ((1vw - 12.8px) * 1.25)), 9px);
	}
}


/* SNS系グラデーション */
.sns_block {
	background: transparent linear-gradient(180deg, #FFFFFF 0%, #EFE5E5 100%) 0% 0% no-repeat padding-box;
}

/* スペシャルムービー */
.special {
	padding-top: 40px;
	margin: 0px;
	color: #FFFFFF;
	background: var(--team-primary-color);
	height: 200px;
}


/* highlight */
.highlight {
	padding-top: 40px;
	padding-bottom: 40px;
	margin: 0px;
	color: var(--team-primary-color);
}
/* TEAM */
.team {
	padding-top: 40px;
	padding-bottom: 15px;
	margin: 0px;
	color: var(--team-primary-color);
}
/* PLAYER */
.player {
	padding-top: 40px;
	padding-bottom: 15px;
	margin: 0px;
	color: var(--team-primary-color);
}
.team_instagram, .team_youtube, .player_instagram, .player_x {
	padding-bottom: 25px;
}
.sns_end {
	padding-bottom: 40px;
}
@media screen and (max-width: 480px) {
	.team_instagram, .team_youtube, .player_instagram, .player_x {
		padding-bottom: 25px;
	}
	.sns_end {
		padding-bottom: 20px;
	}
}


/* サポート */
.support {
	padding-top: 40px;
	margin: 0px;
	color: #FFFFFF;
	background: var(--team-primary-color);
	height: 200px;
}


/* ムービー */
.movie_item {
	width: 100px;
	height: 50px;
}




.expand_space {
	padding: 8px;
	margin: 0px;
	color: #FFF;
	background: #FFF;
	height: 100px;
}




/* ダイアログ */
dialog {
	margin: 0px;
	padding: 0px;
	z-index: var(--float-window-z-index);
	background-color: var(--float-window-background-color);
	box-shadow: 0 0 0 10vmax var(--float-window-background-color);
/*
	background-color: var(--shadow-color);
*/
    width: 100%;
    height: 100%;
	color: #FFF;
	border-style: none;
	border-width: 0px;
}
/*
// ::backdrop では古い safari で表示されなかった。
// dialog > box-shadow で代用
dialog::backdrop {
	-webkit-background-color: var(--float-window-background-color);
	background-color: var(--float-window-background-color);
}
*/
.float_top_block {
	padding-top: 30px;
	padding-bottom: 60px;
	overflow: hidden;
	user-select: none;
	-webkit-user-select: none;
}
.float_close {
	top: 30px;
	left: 30px;
    position: fixed;
	font-size: 0px;
}
.float_close_r {
	top: 30px;
	right: 30px;
    position: fixed;
	font-size: 0px;
}
.float_close img,
.float_close_r img {
	width: 40px;
	height: 40px;
	cursor: pointer;
}
.float_title_block {
	float: right;
	padding-top: 0px;
	padding-right: 40px;
	text-align: right;
}
.float_title {
	padding-bottom: 10px;
	font-size: 36px;
	letter-spacing: 3.6px;
	line-height: 1.0;
	font-weight: 700;
}
.float_sub {
	font-size: 18px;
	letter-spacing: 1.8px;
}

/*
.float_contents {
}
*/
.float_shop_googlemap {
	width: 100%;
	height: 400px;
	padding-bottom: 20px;
}
.float_shop_title {
	padding-left: 10%;
	padding-right: 10%;
	padding-bottom: 20px;
	font-size: 32px;
}
.float_shop_comment {
	padding-left: 10%;
	padding-right: 10%;
	padding-bottom: 4px;
	width: 80%;
	font-size: 24px;
	border-style: none;
	background-color: #0000;
	color: #FFF;
}
.float_message_title {
	padding-bottom: 20px;	
	font-size: 43px;
}
.float_message_comment {
	padding-bottom: 26px;
	font-size: 16px;
}
.float_message_form {
	width: 100%;
	height: 500px;
}
@media screen and (max-width: 1280px) {
	.float_message_title {
		padding-bottom: 16px;	
		font-size: 38px;
	}
	.float_message_comment {
		padding-bottom: 23px;
		font-size: 16px;
	}
}
@media screen and (max-width: 480px) {
/*
	.float_top_block {
		padding-top: 20px;
		padding-bottom: 20px;
	}
*/
	.float_title_block {
		padding-top: 0px;
		padding-right: 20px;
	}
	.float_title {
		font-size: 21px;
		letter-spacing: 2.1px;
	}
	.float_sub {
		font-size: 12px;
		letter-spacing: 1.2px;
	}
	.float_contents {
		padding-left: 0%;
		padding-right: 0%;
	}
	.float_googlemap {
		width: 100%;
		height: 300px;
	}
	.float_shop_title {
		padding-bottom: 10px;	
		font-size: 24px;
	}
	.float_shop_comment {
		font-size: 20px;
	}
	.float_message_title {
		padding-bottom: 11px;	
		font-size: 24px;
	}
	.float_message_comment {
		padding-bottom: 17px;
		font-size: 11px;
	}
}


/* フロートボタン */
.float_button_president, .float_button_president2 {
    top: 320px;
	left: initial;
    width: 50px;
    height: 240px;
    position: fixed;
    right: 0px;
    z-index: var(--float-president-z-index);
	cursor: pointer;
	user-select: none;
	-webkit-user-select: none;
}

.float_button_president a, .float_button_president2 a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	font-size: 14px;
	text-decoration: none;
	background-color: var(--float-background-color);
	color: #fff;
	writing-mode: vertical-rl;
	text-orientation: upright;
}

.float_button_president a.close, .float_button_president2 a.close {
	color: var(--team-primary-color);
}

.float_button_divide {
	width: 0px;
	height: 0px;
	background-color: #707070;
}

.float_button_message {
    top: 570px;
	left: initial;
    width: 50px;
    height: 240px;
    position: fixed;
    right: 0px;
    z-index: var(--float-president-z-index);
	cursor: pointer;
	user-select: none;
	-webkit-user-select: none;
}

.float_button_message a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	font-size: 14px;
	text-decoration: none;
	background-color: var(--float-background-color);
	color: #fff;
	writing-mode: vertical-rl;
	text-orientation: upright;
}

.float_goto_top {
	display: flex;
	justify-content: center;
	top: initial;
	width: 100%;
	position: fixed;
	bottom: 150px;
	z-index: var(--float-president-z-index);
	opacity: 0;
    transition: all 2s ease;
}

.float_button_goto_top {
	background-color: #FFFFFFE6;
	width: 55px;
	height: 44px;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}


/* 480px以下に適用されるCSS（スマホ用） */
@media screen and (max-width: 480px) {
	.float_button_president, .float_button_president2 {
		top: initial;
		left: 0px;
		width: 50%;
		height: 55px;
		position: fixed;
		bottom: 0px;
		z-index: var(--float-president-z-index);
	}
	
	.float_button_president a, .float_button_president2 a {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 100%;
		height: 100%;
		text-decoration: none;
		background-color: var(--float-background-color);
		color: #fff;
		writing-mode: horizontal-tb;
		text-align: center;
	}
	
	.float_button_president a.close, .float_button_president2 a.close {
		color: var(--team-primary-color);
	}

	.float_button_divide {
		top: initial;
		left: 50%;
		width: 1px;
		height: 55px;
		position: fixed;
		bottom: 0px;
		z-index: var(--float-president-z-index);

		background-color: #707070;
	}
	
	.float_button_message {
		top: initial;
		left: 50%;
		padding-left: 1px;
		width: 50%;
		height: 55px;
		position: fixed;
		bottom: 0px;
		z-index: var(--float-president-z-index);
	}
	
	.float_button_message a {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 100%;
		height: 100%;
		text-decoration: none;
		background-color: var(--float-background-color);
		color: #fff;
		writing-mode: horizontal-tb;
		text-align: center;
	}

	.float_goto_top {
		bottom: 60px;
	}

	.float_button_goto_top {
		width: 35px;
		height: 28px;
	}
}


/* 背面スクロール禁止 */
html:has(dialog[open]) {
	overflow: hidden;
}
/* body タグを開いたタイミングでスクロール禁止 */
.scrollNone {
	height: 100%;
	overflow: hidden;
}


/*
.dn {
	display: none !important;
}
*/
.modal {
	z-index: var(--float-window-z-index);
	background-color: var(--float-window-background-color);
	display: none;
	opacity: 0;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	color: #FFF;
	overflow-y: scroll;
}
.modal.isOpen {
	background-color: var(--float-window-background-color);
	display: block;
	opacity: 1;
	animation: scaleUp 0.3s linear;
	-webkit-animation: scaleUp 0.3s linear;
}
/*
.modal.isStatic {
	position: static;
}
*/
.modal.isClose {
	display: block;
	animation: scaleDown 0.3s linear;
	-webkit-animation: scaleDown 0.3s linear;
}
@keyframes scaleUp {
	0% {
		opacity: 0;
		transform: scale(0, 0);
	}
	100% {
		opacity: 1;
		transform: scale(1, 1);
	}
}
@-webkit-keyframes scaleUp {
	0% {
		opacity: 0;
		transform: scale(0, 0);
	}
	100% {
		opacity: 1;
		transform: scale(1, 1);
	}
}
@keyframes scaleDown {
	0% {
		opacity: 1;
		transform: scale(1, 1);
	}
	100% {
		opacity: 0;
		transform: scale(0, 0);
	}
}
@-webkit-keyframes scaleDown {
	0% {
		opacity: 1;
		transform: scale(1, 1);
	}
	100% {
		opacity: 0;
		transform: scale(0, 0);
	}
}
.modalHeader {
	position: relative;
}
.modalTitle {
	font-size: 15px;
	padding: 5px;
	background-color: #3F51B5;
	color: #FFFFFF;
}
.btnClose {
	position: absolute;
	cursor: pointer;
	top: 0;
	right: 0;
	text-align: center;
	width: 33px;
	height: 100%;
	color: #FFF;
}
.btnClose:before,
.btnClose:after {
	position: absolute;
	display: block;
	margin-top: -6px;
	top: 50%;
	content: "";
	width: 10px;
	height: 10px;
	border-color: #FFF;
	border-style: solid;
}
.btnClose:before {
	left: 4px;
	border-width: 2px 2px 0 0;
	transform: rotate(45deg);
}
.btnClose:after {
	right: 3px;
	border-width: 2px 0 0 2px;
	transform: rotate(-45deg);
}


/* フェードイン */
.fadein-block {
    opacity: 0;
    transition: all 2s ease;
}
.fadein-state {
    opacity: 1;
}