@charset "utf-8";

.top_ttl_h2 {
	font-weight: 700;
	font-size: 2.667rem;
	color: var(--green_color);
	letter-spacing: 0.05em;
	transform: skewX(-12deg);
}

@media screen and (max-width: 1439px) {
	.top_ttl_h2 {
		font-size: min(
			max(20px, calc(1.25rem + ((1vw - 3.75px) * 1.8779))),
			40px
		);
	}
}

/* ===========================================
	header
============================================== */
.header.change .header_logo {
	left: -5.2rem;
}

.header.change .header_logo_link {
	width: 32.4667rem;
	height: 23.334rem;
	background-image: url(../images/common/logo1.svg);
	background-position: center;
	background-size: contain;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1439px) {
	.header.change .header_logo {
		left: -2.6667rem;
	}

	.header.change .header_logo_link {
		width: 34vw;
		height: 24.3vw;
	}
}

@media screen and (max-width: 768px) {
	.header.change .header_logo {
		left: -1rem;
	}
}

@media screen and (max-width: 480px) {
	.header.change .header_logo_link {
		width: 55.5vw;
		height: 40vw;
	}
}

/* ===========================================
	hero
============================================== */
.hero_area,
.hero_inner {
	height: calc(100vh - 6.5334rem);
}

.hero_area {
	margin-top: 6.5334rem;
	background-image: url(../images/top/hero_pc.png);
	background-position: center;
	background-size: cover;
	border-radius: 3.334rem 3.334rem 0 0;
}

.hero_inner {
	position: relative;
}

.catch_txt {
	position: absolute;
	bottom: -4.2667rem;
	left: 2rem;
}

.scroll_wrap {
	position: absolute;
	left: -2.6rem;
	bottom: 0;
}

.scroll_txt {
	position: relative;
	padding-bottom: 17.4rem;
	font-weight: 700;
	color: var(--green_color);
	writing-mode: vertical-rl;
}

.scroll_txt::after {
	content: '';
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	width: 2px;
	height: 15.5334rem;
	background-color: var(--green_color);
	animation: elasticus 2.5s cubic-bezier(1, 0, 0, 1) infinite;
}

@keyframes elasticus {
	0% {
		transform-origin: 0% 0%;
		transform: scale(1, 0);
	}
	50% {
		transform-origin: 0% 0%;
		transform: scale(1, 1);
	}
	50.1% {
		transform-origin: 0% 100%;
		transform: scale(1, 1);
	}
	100% {
		transform-origin: 0% 100%;
		transform: scale(1, 0);
	}
}

.hero_inner .yellow_logo {
	right: -4.1334rem;
	bottom: -4.4667rem;
	z-index: 2;
}

.fix_btn {
	position: relative;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	justify-content: center;
	align-items: center;
	margin: auto;
	width: 8rem;
	height: 21.334rem;
	font-weight: 700;
	font-size: 1.2rem;
	color: #fff;
	line-height: 1.7;
	letter-spacing: 0.05em;
	writing-mode: vertical-rl;
	z-index: 48;
}

.fix_btn::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--green_color);
	transform: skewY(-10deg);
	z-index: -1;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1439px) {
	.catch_txt {
		bottom: -1.8rem;
		left: -0.9334rem;
	}

	.catch_txt > img {
		width: 51.5vw;
	}
}

@media screen and (max-width: 1024px) {
	.hero_area,
	.hero_inner {
		height: calc(100vh - 6.1334rem);
	}

	.hero_area {
		margin-top: 6.1334rem;
		background-image: url(../images/top/hero_sp.png);
		border-radius: 1.2667rem 1.2667rem 0 0;
	}

	.scroll_wrap {
		bottom: -13.334rem;
		left: auto;
		right: -0.5rem;
		z-index: 3;
	}

	.scroll_txt {
		padding-bottom: 16.0667rem;
	}

	.scroll_txt::after {
		height: 14.667rem;
	}

	.hero_inner .yellow_logo,
	.fix_btn {
		display: none;
	}
}

@media screen and (max-width: 768px) {
	.hero_area,
	.hero_inner {
		height: 100%;
		aspect-ratio: 67 / 64;
	}

	.catch_txt > img {
		width: 86.1334vw;
	}
}

/* ===========================================
	team_about
============================================== */
.team_about_area {
	position: relative;
}

.team_about_inner {
	padding-top: 8.2rem;
	padding-bottom: 7.7334rem;
}

.team_cont .top_ttl_h2 {
	margin-bottom: 3.334rem;
}

.team_txt {
	margin-bottom: 4rem;
	font-weight: 500;
	font-size: 1.334rem;
	color: var(--navy_color);
	line-height: 1.8;
}

.team_photo_wrap {
	position: relative;
	position: absolute;
	top: -3.2667rem;
	right: -6.667rem;
	max-width: 53.334rem;
	width: 100%;
	aspect-ratio: 160 / 107;
	z-index: 1;
}

.team_photo_wrap::after {
	content: '';
	position: absolute;
	top: 3.334rem;
	left: -3.334rem;
	width: 50rem;
	height: 100%;
	background-image: url(../images/common/line.svg);
	background-position: center;
	background-size: cover;
	z-index: -1;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1439px) {
	.team_txt {
		margin-bottom: 2.667rem;
		font-size: min(
			max(15px, calc(0.9375rem + ((1vw - 3.75px) * 0.4699))),
			20px
		);
	}

	.team_photo_wrap {
		right: -4rem;
		max-width: none;
		width: 55.56vw;
	}

	.team_photo_wrap::after {
		width: 54.5vw;
	}
}

@media screen and (max-width: 1280px) {
	.team_cont .top_ttl_h2,
	.team_txt {
		margin-bottom: 2rem;
	}
}

@media screen and (max-width: 1024px) {
	.team_photo_wrap,
	.team_photo_wrap::after {
		top: 0;
	}

	.team_photo_wrap::after {
		left: -1.334rem;
		width: calc(100% - 2.7rem);
		height: calc(100% + 1.334rem);
	}
}

@media screen and (max-width: 840px) {
	.team_about_inner {
		justify-content: center;
		padding-top: 65vw;
		padding-bottom: 5.334rem;
	}

	.team_cont .top_ttl_h2,
	.team_txt {
		text-align: center;
	}

	.team_cont .more_btn {
		margin-right: auto;
		margin-left: auto;
	}

	.team_photo_wrap {
		width: 80vw;
		aspect-ratio: 3 / 2;
	}

	.team_photo_wrap::after {
		width: calc(100% - 0.7rem);
	}
}

@media screen and (max-width: 768px) {
	.team_photo_wrap {
		right: -2rem;
	}
}

@media screen and (max-width: 480px) {
	.team_about_inner {
		padding-top: 18.667rem;
	}

	.team_photo_wrap {
		right: -1.334rem;
	}

	.team_photo_wrap::after {
		width: 100%;
	}
}

/* ===========================================
	player
============================================== */
.player_area {
	position: relative;
	padding-top: 6.667rem;
	padding-bottom: 6.667rem;
	border-radius: 3.334rem;
}

.player_area .green_logo {
	top: -13.4rem;
	left: -13.4rem;
}

.player_area .top_ttl_h2 {
	margin-bottom: 3.5334rem;
	color: #fff;
	text-align: center;
}

.player_slider_wrap {
	position: relative;
	margin-bottom: 3.334rem;
}

.player_slider {
	margin-right: auto;
	margin-left: auto;
	max-width: 64.667rem;
	width: 100%;
}

.player_slider .swiper-slide {
	flex-shrink: 0;
	margin-right: 2rem;
}

/* player_link → common.css */

.position_txt > span {
	display: block;
}

.position_txt > span + span {
	margin-top: 5px;
}

.position_txt > span + span::before {
	content: none;
}

.player_area .taiko_img {
	right: -4.8rem;
	bottom: -14.6rem;
}

.player_swiper_btn_prev,
.player_swiper_btn_next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}

.player_swiper_btn_prev {
	left: -1.334rem;
	transform: scale(-1, 1);
}

.player_swiper_btn_next {
	right: -1.334rem;
}

.player_area .more_btn {
	position: relative;
	margin-right: auto;
	margin-left: auto;
	width: 21.4rem;
	z-index: 1;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1024px) {
	.player_area {
		padding-top: 5.334rem;
		padding-bottom: 4.667rem;
		border-radius: 1.2667rem;
	}

	.player_area .green_logo {
		top: -5.0667rem;
		left: -5.2rem;
	}

	.player_area .top_ttl_h2 {
		margin-bottom: 2.667rem;
	}

	.player_slider_wrap {
		margin-bottom: 1.334rem;
	}

	.player_slider {
		margin-bottom: 1.2667rem;
	}

	.player_slider .swiper-slide {
		margin-right: 9px;
	}

	.player_area .taiko_img {
		right: -2.1334rem;
		bottom: -2.8667rem;
		width: 13.7334rem;
		height: 9.9rem;
	}

	.player_swiper_btn_wrap {
		justify-content: center;
		column-gap: 2rem;
	}

	.player_swiper_btn_prev,
	.player_swiper_btn_next {
		position: static;
		transform: translateY(0);
	}

	.player_swiper_btn_prev {
		transform: scale(-1, 1);
	}

	.player_area .more_btn {
		width: 16.4667rem;
	}
}

/* ===========================================
	instagram
============================================== */
.instagram_area {
	position: relative;
	padding-top: 7.0667rem;
	padding-bottom: 6.667rem;
	z-index: 1;
}

.line_cont {
	position: absolute;
	z-index: -1;
}

.line_cont_top {
	top: 0;
	right: 0;
}

.instagram_area .top_ttl_h2 {
	margin-bottom: 3.9334rem;
}

#sb_instagram #sbi_images {
	margin-bottom: 3.334rem;
	padding: 0;
	column-gap: 4rem;
}

.instagram_wrap .more_btn {
	margin-left: auto;
}

.line_cont_bottom {
	bottom: 0;
	left: 0;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1024px) {
	.instagram_area {
		padding-top: 4.2rem;
		padding-bottom: 7.9334rem;
	}

	.line_cont {
		width: 9.5rem;
		height: 9.5rem;
	}

	.instagram_area .top_ttl_h2 {
		margin-bottom: 3.1334rem;
	}

	#sb_instagram #sbi_images {
		gap: 2rem;
		margin-bottom: 2.667rem;
	}
}

@media screen and (max-width: 768px) {
	#sb_instagram #sbi_images {
		gap: 0.667rem;
	}
}

@media screen and (max-width: 640px) {
	.instagram_area .top_ttl_h2 {
		text-align: center;
	}

	.instagram_wrap .more_btn {
		margin-right: auto;
	}
}

/* ===========================================
	contact
============================================== */
.contact_area {
	position: relative;
	padding-top: 6.667rem;
	padding-bottom: 6.667rem;
	border-radius: 3.334rem;
	z-index: 2;
}

.contact_area::before,
.contact_area::after {
	content: '';
	position: absolute;
	right: 0;
	left: 0;
	margin: auto;
	width: 2px;
	height: 4.667rem;
	z-index: 1;
	animation: elasticus 2.5s cubic-bezier(1, 0, 0, 1) infinite;
}

.contact_area::before {
	top: -4.667rem;
	background-color: var(--green_color);
}

.contact_area::after {
	top: 0;
	background-color: var(--white_color);
}

@keyframes elasticus {
	0% {
		transform-origin: 0% 0%;
		transform: scale(1, 0);
	}
	50% {
		transform-origin: 0% 0%;
		transform: scale(1, 1);
	}
	50.1% {
		transform-origin: 0% 100%;
		transform: scale(1, 1);
	}
	100% {
		transform-origin: 0% 100%;
		transform: scale(1, 0);
	}
}

@keyframes stretchBar {
	0% {
		transform: scaleY(0);
	}
	50% {
		transform: scaleY(1);
	}
	100% {
		transform: scaleY(0);
	}
}

.contact_area .green_logo {
	top: -3.1334rem;
	left: -15.4667rem;
}

.contact_area .top_ttl_h2,
.contact_txt {
	margin-bottom: 3.2rem;
	color: #fff;
	text-align: center;
}

.contact_txt {
	font-weight: 500;
	line-height: 2;
}

.form_cont {
	position: relative;
	padding: 6.667rem;
	font-weight: 500;
	color: var(--navy_color);
	background-color: var(--white_color);
	z-index: 2;
}

.smf-form--simple-table .smf-item {
	flex-direction: column;
	padding: 0;
}

.smf-form--simple-table .smf-item__col--label {
	flex: 0;
}

.smf-form--simple-table .smf-item__col--label,
.smf-form--simple-table .smf-item__col--controls,
.smf-form .smf-text-control__control,
.smf-form .smf-textarea-control__control {
	max-width: none;
	width: 100%;
}

.smf-item + .smf-item {
	margin-top: 1.8667rem;
}

.smf-item__col--label {
	margin-bottom: 1.2rem;
}

.smf-item__label__text {
	display: flex;
	align-items: center;
}

.smf-item__label__text > mark {
	margin-top: 3px;
	margin-left: 0.667rem;
	padding: 3px;
	font-weight: 600;
	font-size: 0.667rem;
	color: var(--white_color);
	background-color: var(--green_color);
	border-radius: 3px;
}

.smf-radio-control {
	display: flex;
	column-gap: 3.334rem;
}

.smf-form .smf-textarea-control__control {
	height: 15rem;
}

.smf-form .smf-radio-button-control__control {
	margin-top: 0;
	border: solid 2px #e6e6e6;
	box-shadow: none;
}

.smf-form .smf-text-control__control,
.smf-form .smf-textarea-control__control {
	padding: 1.1334rem 2.1334rem;
	border: solid 2px #e6e6e6;
	border-radius: 0;
	box-shadow: none;
}

.smf-form .smf-textarea-control__control {
	line-height: 1.5;
}

.smf-form .smf-text-control__control::placeholder {
	color: #969691;
}

.custom-error-message {
	margin-top: var(--_margin-2);
}

.pp_txt_area {
	margin-top: 4rem !important;
	margin-bottom: 3.4rem !important;
	padding: 2rem !important;
	height: 20rem;
	background-color: #eee;
	overflow: scroll;
}

.pp_txt_area p {
	line-height: 1.8;
}

.pp_checkbox {
	margin-bottom: 3.4rem !important;
	text-align: center;
}

.smf-form .smf-checkbox-control {
	align-items: center;
}

.smf-placeholder[data-name='プライバシーポリシー'] {
	text-align: center;
}

.smf-form .smf-checkbox-control__control {
	margin-top: 0;
	width: 0.9334rem;
	height: 0.9334rem;
	border: solid 1px var(--navy_color);
	border-radius: 0;
}

.smf-action {
	display: flex;
	flex-direction: column-reverse;
	justify-content: center;
	align-items: center;
}

button[data-action='confirm'],
button[data-action='complete'] {
	width: 18rem;
	height: 4rem;
	font-weight: 700 !important;
	font-size: 1.334rem;
	color: var(--white_color) !important;
	letter-spacing: 0.05em;
	background-color: var(--navy_color) !important;
	background-image: none !important;
	border: none !important;
	border-radius: 0 !important;
	transform: skewX(-10deg);
	transition: all 0.4s;
}

button[data-action='confirm']:hover,
button[data-action='complete']:hover {
	color: var(--navy_color) !important;
	background-color: var(--white_color) !important;
	border: solid 1px var(--navy_color) !important;
	transition: all 0.4s;
}

button[data-action='back'] {
	margin-top: 2.25rem;
	padding-left: 0 !important;
	padding-right: 0 !important;
	border-top: solid 1px transparent !important;
	border-right: solid 1px transparent !important;
	border-bottom: solid 2px var(--navy_color) !important;
	border-left: solid 1px transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	color: var(--navy_color) !important;
	font-size: 1rem;
	text-align: center;
	transition: 0.4s;
}

button[data-action='back']:hover {
	opacity: 0.7;
}

.contact_area .yellow_logo {
	right: -10.667rem;
	bottom: 14.9334rem;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1439px) {
	.contact_area {
		border-radius: 3.334rem 3.334rem 0 0;
		z-index: 1;
	}
}

@media screen and (max-width: 1280px) {
	.form_cont {
		padding: 2.667rem 4rem;
	}
}

@media screen and (max-width: 1024px) {
	.contact_area {
		padding-top: 5.334rem;
		padding-bottom: 6.667rem;
		border-radius: 1.2667rem 1.2667rem 0 0;
	}

	.contact_area::before {
		top: -2.667rem;
	}

	.contact_area::before,
	.contact_area::after {
		height: 2.667rem;
	}

	.contact_area .green_logo {
		top: -8.2667rem;
		left: -6.667rem;
		width: 13.5334rem;
		height: 13.4667rem;
	}

	.contact_area .top_ttl_h2,
	.contact_txt {
		margin-bottom: 2.667rem;
	}

	.smf-form .smf-text-control__control,
	.smf-form .smf-textarea-control__control {
		padding: 0.8667rem 1.2667rem;
	}

	.pp_txt_area {
		margin-top: 2.667rem !important;
	}

	.pp_txt_area,
	.pp_checkbox {
		margin-bottom: 2.667rem !important;
	}

	button[type='submit'] {
		width: 13.8rem;
		height: 3.0667rem;
		font-size: 1rem;
	}

	.contact_area .yellow_logo {
		right: -5.1334rem;
		bottom: 15.1334rem;
		width: 10.2rem;
		height: 10.1334rem;
	}
}

@media screen and (max-width: 768px) {
	.form_cont {
		padding-right: 2rem;
		padding-left: 2rem;
	}

	.smf-radio-control {
		flex-direction: column;
		row-gap: 1.334rem;
	}

	.smf-form .smf-textarea-control__control {
		height: 18rem;
	}

	.pp_txt_area {
		padding-right: 1.25rem !important;
		padding-left: 1.25rem !important;
	}

	.smf-checkbox-control__label {
		font-size: 0.8667rem;
	}
}

@media screen and (max-width: 640px) {
	.smf-radio-buttons-control__control {
		display: flex;
		flex-direction: column;
		row-gap: 1.334rem;
	}

	.smf-form--simple-table .smf-item__col--label {
		padding-bottom: 0;
	}
}

@media screen and (max-width: 480px) {
	.form_cont {
		padding-right: 1.334rem;
		padding-left: 1.334rem;
	}
}

/* ===========================================
	thanks
============================================== */
.thanks_ttl {
	justify-content: center;
	margin-bottom: 2.5rem;
	font-weight: 600;
	font-size: 2.2rem;
	color: var(--green_color);
	letter-spacing: 0.025em;
}

.thanks_txt {
	margin-left: auto;
	margin-right: auto;
	max-width: 51rem;
	width: 100%;
}

.thanks_txt .cont_txt {
	margin-bottom: 0;
	line-height: 1.8;
}

.thanks_txt .cont_txt + .cont_txt {
	margin-top: 1.5rem;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1024px) {
	.thanks_ttl {
		margin-bottom: 2rem;
		font-size: 1.7rem;
		line-height: 1.43;
	}
}
