/* --------------------------------------------------------------------------------------
	ヘッダー
--------------------------------------------------------------------------------------- */

header {
	align-items: center;
	display: flex;
	justify-content: space-between;
	padding: 32px 40px;
	position: absolute;
	top: 0;
	transition: all .3s ease-in-out;
	width: 100%;
	z-index: 1000;
}

header.fixed {
	animation: fixed-animate .6s cubic-bezier(0, .8, .56, 1) both;
	background-color: #fff;
	box-shadow: 0 4px 0 #edeff4;
	left: 0;
	padding: 12px 16px;
	position: fixed;
	top: 0;
}

@keyframes fixed-animate {
	0% { transform: translateY(-150px); }
	100% { transform: translateY(0); }
}

header h1 { max-width: 117px; }

header .gnavi {
	align-items: center;
	display: flex;
}

header .gnavi .text-navigation {
	align-items: flex-end;
	display: flex;
	flex-direction: column;
}

header .gnavi .text-navigation > ul {
	align-items: center;
	display: flex;
}

header .gnavi .text-navigation .sub {
	font-size: 12px;
}

header .gnavi .text-navigation .sub li:nth-of-type(n+2) {
	border-left: 1px solid var(--color-text);
	margin-left: 16px;
	padding-left: 16px;
}

header .gnavi .text-navigation > ul li a {
	color: var(--color-text);
	display: block;
	line-height: 1;
}

header .gnavi .text-navigation .main { margin-top: 14px; }

header .gnavi .text-navigation .main li:nth-of-type(n+2) { margin-left: 20px; }

header .gnavi .text-navigation .main li a {
	font-size: 14px;
	font-weight: var(--Bold);
	transition: all .3s ease-in-out;
}

@media (any-hover: hover) {
	header .gnavi .text-navigation .main li a:hover {
		color: var(--color-magenta);
		text-decoration: none;
	}
}

header .gnavi .banner-navigation {
	display: flex;
	gap: 8px;
	margin-left: 24px;
}

header .panel-btn { display: none; }

@media (max-width: 1099px) {

	header,
	header.fixed { padding: 3.98vw 4.975vw; }

	header h1 {
		max-width: 21.642vw;
		position: relative;
		z-index: 100;
	}

	header .gnavi {
		background-color: #fff;
		display: block;
		height: 100vh;
		left: 0;
		padding: 18.876vw 4.975vw 0;
		position: fixed;
		top: 0;
		transform: translateX(100vw);
		transition: all .3s ease-in-out;
		width: 100%;
	}

	header .gnavi.nav-open { transform: translateX(0); }

	header .gnavi .text-navigation { align-items: flex-start; }

	header .gnavi .text-navigation > ul { width: 100%; }

	header .gnavi .text-navigation .main {
		display: block;
		margin-top: 0;
		order: 1;
		text-align: left;
	}

	header .gnavi .text-navigation .main li a {
		font-size: 3.98vw;
		padding: 3.98vw 0;
		position: relative;
	}

	header .gnavi .text-navigation .main li a::after {
		border-bottom: 2px solid var(--color-magenta);
		border-right: 2px solid var(--color-magenta);
		content: '';
		display: block;
		height: 8px;
		position: absolute;
		right: 0;
		top: 50%;
		transform: translateY(-50%) rotate(-45deg);
		transition: all .3s ease-in-out;
		width: 8px;
	}

	header .gnavi .text-navigation .main li:nth-of-type(n+2) {
		border-top: 1px solid var(--color-border);
		margin-left: 0;
	}

	header .gnavi .text-navigation .sub {
		font-size: 3.483vw;
		justify-content: center;
		margin-top: 7.96vw;
		order: 2;
	}

	header .gnavi .text-navigation .sub li:nth-of-type(n+2) {
		margin-left: 4.975vw;
		padding-left: 4.975vw;
	}

	header .gnavi .banner-navigation {
		flex-wrap: wrap;
		gap: 3.98vw;
		justify-content: center;
		margin-left: 0;
		margin-top: 11.94vw;
	}


	header .panel-btn {
		cursor: pointer;
		display: block;
		height: 6.965vw;
		position: relative;
		width: 7.96vw;
	}

	header .panel-btn-icon {
		background-color: var(--color-magenta);
		height: 0.995vw;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: 100%;
	}

	header .panel-btn-top,
	header .panel-btn-bottom {
		background-color: var(--color-magenta);
		height: 0.995vw;
		left: 0;
		position: absolute;
		/* 基点はセンターにする */
		transform-origin: center;
		transition: all .3s ease-in-out;
		width: 100%;
	}

	header .panel-btn-top { top: 0; }
	header .panel-btn-bottom { bottom: 0; }

	header .panel-btn.close .panel-btn-icon { background: transparent; }

	header .panel-btn.close .panel-btn-top {
		top: 50%;
		transform: translateY(-50%) rotate(45deg);
	}

	header .panel-btn.close .panel-btn-bottom {
		top: 50%;
		transform: translateY(-50%) rotate(-45deg);
	}


}

/* --------------------------------------------------------------------------------------
	ボックス
--------------------------------------------------------------------------------------- */

.box {
	margin-left: auto;
	margin-right: auto;
	max-width: 1100px;
	position: relative;
	text-align: left;
	transition: all .3s ease-in-out;
	width: 100%;
	z-index: 1;
}

.bg-cobalt-blue { background-color: var(--color-cobalt-blue); }

.wrapper {
	overflow-x: hidden;
	width: 100%;
}

.box-padding {
	padding-left: 60px;
	padding-right: 60px;
}

.circle-design {
	border-radius: var(--border-radius);
	overflow: hidden;
}

.is-more-transition {
	max-height: 1000px;
	transition: all .3s ease-in-out;
}

.is-more-hidden {
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	padding: 0 !important;
	visibility: hidden;
}

.fadeIn { opacity: 1; }
.fadeOut { opacity: 0; }

@media (max-width: 1099px) {

	.box { width: auto; }

	.box-padding {
		padding-left: 0;
		padding-right: 0;
	}
}



/* --------------------------------------------------------------------------------------
	バナー
--------------------------------------------------------------------------------------- */

.banner { display: inline-block; }

.banner a,
.banner button {
	align-items: center;
	appearance: none;
	background: linear-gradient(90deg, #CB064A 0%, #A770F0 100%);
	border-radius: 100vw;
	color: #fff;
	cursor: pointer;
	display: flex;
	font-size: 14px;
	font-weight: var(--Bold);
	justify-content: center;
	min-height: 56px;
	min-width: 184px;
	outline: none;
	overflow: hidden;
	padding: 16px 18px 16px 24px;
	position: relative;
	transition: all .3s ease-in-out;
	width: 100%;
	z-index: 0;
}

.banner a:before,
.banner button::before {
	background-color: #ff2d77;
	content: '';
	display: block;
	height: 0px;
	left: 0px;
	position: absolute;
	top: 0px;
	transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
	width: 100%;
	z-index: -1;
}

.banner a::after,
.banner button::after {
	border-bottom: 2px solid #fff;
	border-right: 2px solid #fff;
	content: '';
	display: block;
	height: 8px;
	margin-left: 4px;
	transform: rotate(-45deg);
	transition: all .3s ease-in-out;
	width: 8px;
}

.banner.border a,
.banner.border button {
	background: linear-gradient(#fff, #fff) padding-box,
		linear-gradient(90deg, #CB064A 0%, #A770F0 100%) border-box;
	border: 1px solid transparent;
	color: var(--color-magenta);
}

.banner.border a::before,
.banner.border button::before { background: linear-gradient(90deg, #CB064A 0%, #A770F0 100%); }

.banner.border a::after,
.banner.border button::after { border-color: var(--color-magenta); }

.banner.large a,
.banner.large button {
	font-size: 22px;
	min-height: 76px;
	min-width: 400px;
}

.banner.icon-arrow a::after,
.banner.icon-arrow button::after {
	background: url(../images/common/icon-banner-arrow.png) no-repeat;
	background-size: 100% auto;
	border: none;
	height: 42.8%;
	position: absolute;
	right: 23px;
	top: 50%;
	transform: translateY(-50%);
	width: 8%;
}

.banner.border.black a,
.banner.border.black button {
	border-color: var(--color-text);
	color: var(--color-text);
	justify-content: flex-start;
}

.banner.black a::before,
.banner.black button::before { background-color: var(--color-text); }

.banner.small a,
.banner.small button {
	min-height: 48px;
	min-width: 171px;
	padding-bottom: 10px;
	padding-top: 12px;
}

.banner.small a::after,
.banner.small button::after {
	position: absolute;
	right: 13px;
}

.banner.medium a,
.banner.medium button {
	font-size: 16px;
	min-height: 64px;
	min-width: 256px;
	padding-bottom: 0;
	padding-top: 0;
}

.banner.medium a::after,
.banner.medium button::after {
	position: absolute;
	right: 23px;
}

.text-arrow-link a,
.text-arrow-link button {
	align-items: center;
	color: var(--color-text);
	display: inline-flex;
	font-weight: var(--Bold);
	position: relative;
}

.text-arrow-link a::after,
.text-arrow-link button::after {
	border-bottom: 2px solid var(--color-magenta);
	border-right: 2px solid var(--color-magenta);
	content: '';
	display: block;
	height: 8px;
	margin-left: 5px;
	transform: rotate(-45deg);
	transition: all .3s ease-in-out;
	width: 8px;
}

.banner-location {
	align-items: center;
	background-color: #fff;
	border: none;
	border-radius: var(--border-radius);
	cursor: pointer;
	display: flex;
	font-weight: var(--Bold);
	justify-content: center;
	min-height: 54px;
	min-width: 322px;
	outline: none;
	transition: all .3s ease-in-out;
}

.banner-location span {
	background: url(../images/common/icon-room-search.svg) no-repeat left center;
	background-size: contain;
	display: inline-block;
	padding-left: 32px;
}

.more-btn {
	align-items: center;
	background: url(../images/common/icon-plus.svg) no-repeat calc(100% - 13px) center;
	border: 1px solid var(--color-border);
	border-radius: 100vw;
	cursor: pointer;
	display: inline-flex;
	font-size: 14px;
	font-weight: var(--Bold);
	justify-content: flex-start;
	min-height: 48px;
	min-width: 136px;
	padding-left: 24px;
	position: relative;
}

.banner-fixed {
	background: linear-gradient(180deg, rgba(48, 201, 236, 0.7) 0%, rgba(68, 175, 246, 0.7) 100%);
	bottom: 0;
	display: none;
	gap: 24px;
	justify-content: center;
	left: 0;
	padding: 24px 0;
	position: fixed;
	width: 100%;
	z-index: 10;
}
@media (max-width: 1099px) {
	.banner-fixed {
		display: flex;
	}
	.banner-fixed.act {
		display: none;
	}
	.banner-fixed.act.on {
		display: flex;
		animation: fixed-animate-foot .6s cubic-bezier(0, .8, .56, 1) both;
	}
}
@keyframes fixed-animate-foot {
	0% { transform: translateY(300px); }
	100% { transform: translateY(0); }
}


.over { transition: all .3s ease-in-out; }

@media (any-hover: hover) {

	.banner a:hover,
	.banner button:hover {
		background-color: transparent;
		text-decoration: none;
	}

	.banner a:hover:before,
	.banner button:hover:before {
		bottom: 0%;
		height: 100%;
		top: auto;
	}

	.banner.border a:hover,
	.banner.border button:hover {
		border-color: var(--color-magenta);
		color: #fff;
	}

	.banner.border a:hover::before,
	.banner.border button:hover::before { background: var(--color-magenta); }

	.banner.border a:hover::after,
	.banner.border button:hover::after { border-color: #fff; }

	.banner-location:hover { color: var(--color-blue); }

	.over:hover {
		opacity: .6;
		text-decoration: none;
	}

}

@media (max-width: 768px) {

	.banner a,
	.banner button {
		padding-bottom: 2.985vw;
		padding-top: 2.985vw;
	}

	.banner.large a,
	.banner.large button {
		font-size: 3.98vw;
		justify-content: flex-start;
		min-height: 11.94vw;
		min-width: 54.726vw;
		padding-left: 8.458vw;
	}

	.banner.medium a,
	.banner.medium button {
		font-size: 3.98vw;
		min-height: 15.92vw;
		min-width: 63.682vw;
	}

	.banner.medium a::after,
	.banner.medium button::after { right: 5.721vw; }

	.banner.small a,
	.banner.small button {
		min-height: 11.94vw;
		min-width: inherit;
		padding-bottom: 2.488vw;
		padding-right: 8.333vw;
		padding-top: 2.985vw;
	}

	.banner.icon-arrow a::after,
	.banner.icon-arrow button::after {
		height: 5.224vw;
		right: 2.488vw;
		width: 5.224vw;
	}

	.banner-location {
		font-size: 3.483vw;
		justify-content: center;
		min-height: 13.433vw;
		min-width: 80.1vw;
	}

	.banner-location span {
		background-size: 5.97vw auto;
		padding-left: 7.333vw;
	}

	.text-arrow-link a::after,
	.text-arrow-link button::after {
		height: 6px;
		width: 6px;
	}

	.banner-fixed {
		gap: 2.488vw;
		padding: 4.975vw 2.985vw;
	}

	.banner-fixed .banner {
		display: block;
		width: 100%;
	}

	.banner-fixed .banner.medium a {
		font-size: 3.483vw;
		min-height: 13.93vw;
		min-width: 100%;
		padding-bottom: 0;
		padding-top: 0;
	}

	.banner-fixed .banner.medium a::after { right: 4.478vw; }
}



/* --------------------------------------------------------------------------------------
	パンくず
--------------------------------------------------------------------------------------- */

.breadcrumb { padding-top: 48px; }

.breadcrumb ul {
	align-items: center;
	display: flex;
	font-size: 12px;
}

.breadcrumb li {
	display: block;
	line-height: 1;
	position: relative;
}

.breadcrumb li:nth-of-type(n+2) { margin-left: 20px; }

.breadcrumb li:nth-of-type(n+2):before {
	border-bottom: 1px solid var(--color-text);
	border-right: 1px solid var(--color-text);
	content: '';
	display: block;
	height: 5px;
	left: -13px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
	width: 5px;
}

.breadcrumb li a { color: var(--color-text); }

@media (max-width: 1099px) {

	.breadcrumb { padding-top: 4.975vw; }

	.breadcrumb ul { font-size: 2.985vw; }

	.breadcrumb li { white-space: nowrap; }

	.breadcrumb li:nth-of-type(n+2):before { left: -3.367vw; }

	.breadcrumb li:last-of-type span {
		-webkit-box-orient: vertical;
		display: -webkit-box;
		-webkit-line-clamp: 1;
		overflow: hidden;
		text-align: left;
		text-overflow: ellipsis;
		white-space: normal;
		width: unset;
	}
}

/* --------------------------------------------------------------------------------------
	デバイス切り替え
--------------------------------------------------------------------------------------- */

.sp { display: none; }

@media (max-width: 1099px) {

	.pc { display: none; }
	.sp { display: block; }
}


/* --------------------------------------------------------------------------------------
	フッター
--------------------------------------------------------------------------------------- */

footer .corporate-training {
	padding-bottom: 64px;
	padding-top: 64px;
}

footer .corporate-training .logo-list {
	align-items: center;
	display: flex;
	gap: 20px;
	justify-content: center;
	margin-top: 32px;
}

footer .corporate-training .logo-list li {
	align-items: center;
	display: flex;
	justify-content: center;
}

footer .corporate-training .logo-list li img { width: 100%; }

footer .corporate-training .logo-list .bridgestone img { max-height: 24px; }
footer .corporate-training .logo-list .mizuho img { max-height: 22px; }
footer .corporate-training .logo-list .nitta img { max-height: 29px; }
footer .corporate-training .logo-list .toppan img { max-height: 12px; }
footer .corporate-training .logo-list .nisshin-seifun img { max-height: 15px; }
footer .corporate-training .logo-list .sekisui img { max-height: 17px; }
footer .corporate-training .logo-list .ngk img { max-height: 21px; }

footer .corporate-training .text {
	font-weight: var(--Bold);
	margin-top: 32px;
}

footer .corporate-training .banner {
	margin-top: 32px;
	min-width: 213px;
}

footer .details-wrap {
	background-color: #1e1e1e;
	color: #fff;
	padding-bottom: 32px;
	padding-top: 40px;
}

footer .details-wrap .logo {
	max-width: 109px;
	width: 100%;
}

footer .details-wrap li a { color: #fff; }

footer .details-wrap .fnavi {
	display: flex;
	justify-content: space-between;
	margin-top: 24px;
}

footer .details-wrap .fnavi nav ul {
	align-items: center;
	display: flex;
	gap: 24px;
}

footer .details-wrap .fnavi nav ul:nth-of-type(1) li a { font-weight: var(--Bold); }
footer .details-wrap .fnavi nav ul:nth-of-type(2) { margin-top: 8px; }
footer .details-wrap .fnavi nav ul:nth-of-type(2) li a { font-size: 14px; }

footer .details-wrap .fnavi .address { text-align: right; }

footer .details-wrap .fnavi .address dt {
	align-items: center;
	display: flex;
}

footer .details-wrap .fnavi .address dt span {
	border: 1px solid #fff;
	border-radius: 4px;
	font-size: 14px;
	font-weight: var(--Bold);
	padding: 4px 11px;
}

footer .details-wrap .fnavi .address dt a {
	color: #fff;
	font-family: var(--font-poppins);
	font-size: 28px;
	line-height: 1;
	margin-left: 10px;
	pointer-events: none;
}

footer .details-wrap .fnavi .address dd {
	font-size: 14px;
	font-weight: var(--Bold);
	margin-top: 8px;
}

footer .details-wrap .sub {
	align-items: center;
	border-top: 1px solid #fff;
	display: flex;
	justify-content: space-between;
	margin-top: 24px;
	padding-top: 16px;
}

footer .details-wrap .sub small { font-size: 12px; }

footer .details-wrap .sub ul {
	align-items: center;
	display: flex;
}

footer .details-wrap .sub li:nth-of-type(n+2) {
	border-left: 1px solid #fff;
	margin-left: 6px;
	padding-left: 6px;
}

footer .details-wrap .sub li a {
	display: block;
	font-size: 12px;
	line-height: 1;
}

@media (max-width: 1099px) {

	footer .corporate-training { padding: 9.95vw 4.975vw; }

	footer .corporate-training .logo-list {
		flex-wrap: wrap;
		gap: 4.975vw;
		margin-top: 5.97vw;
	}

	footer .corporate-training .logo-list .bridgestone img { max-height: 5.473vw; }
	footer .corporate-training .logo-list .mizuho img { max-height: 5.473vw; }
	footer .corporate-training .logo-list .nitta img { max-height: 7.214vw; }
	footer .corporate-training .logo-list .toppan img { max-height: 2.985vw; }
	footer .corporate-training .logo-list .nisshin-seifun img { max-height: 3.731vw; }
	footer .corporate-training .logo-list .sekisui img { max-height: 4.229vw; }
	footer .corporate-training .logo-list .ngk img { max-height: 5.224vw; }

	footer .corporate-training .text {
		font-size: 3.483vw;
		margin-top: 7.96vw;
	}

	footer .corporate-training .banner {
		margin-top: 5.97vw;
		min-width: 52.985vw;
	}

	footer .details-wrap { padding: 9.95vw 9.95vw 7.96vw; }

	footer .details-wrap .logo { max-width: 27.114vw; }

	footer .details-wrap .fnavi {
		flex-wrap: wrap;
		margin-top: 5.97vw;
	}

	footer .details-wrap .fnavi nav ul {
		align-items: flex-start;
		flex-wrap: wrap;
		gap: 0;
	}

	footer .details-wrap .fnavi nav ul:nth-of-type(1) { gap: 2.488vw 0; }

	footer .details-wrap .fnavi nav ul:nth-of-type(1) li { width: 50%; }

	footer .details-wrap .fnavi nav ul:nth-of-type(2) {
		display: block;
		margin-top: 2.488vw;
	}

	footer .details-wrap .fnavi nav ul:nth-of-type(2) li:nth-of-type(n+2) { margin-top: 2.488vw; }

	footer .details-wrap .fnavi .address {
		margin-top: 6.468vw;
		text-align: left;
	}

	footer .details-wrap .fnavi .address dt span {
		border-radius: 0.995vw;
		font-size: 3.483vw;
		padding: 1.488vw 2.985vw;
	}

	footer .details-wrap .fnavi .address dt a {
		font-size: 6.965vw;
		margin-left: 2.488vw;
		pointer-events: inherit;
	}

	footer .details-wrap .fnavi .address dd {
		font-size: 3.483vw;
		margin-top: 1.99vw;
	}

	footer .details-wrap .sub {
		align-items: center;
		border-top: none;
		flex-direction: column;
		justify-content: flex-start;
		margin-top: 5.97vw;
		padding-top: 0;
	}

	footer .details-wrap .sub ul {
		justify-content: center;
		order: 1;
		width: 100%;
	}

	footer .details-wrap .sub li:nth-of-type(n+2) {
		margin-left: 1.093vw;
		padding-left: 1.093vw;
	}

	footer .details-wrap .sub small {
		border-top: 1px solid #fff;
		display: block;
		font-size: 2.985vw;
		margin-top: 2.99vw;
		order: 2;
		padding-top: 1.99vw;
		text-align: center;
		width: 100%;
	}
}