@charset "utf-8";

/*============================
ヘッダー
============================*/
header {
	transition: transform 0.5s 0.3s;
	display: flex;
	justify-content: space-between;
	padding: 0.14rem 0;
	align-items: center;
	min-width: 1080px;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 10;
	background-color: #FFF;
}
@media screen and (max-width: 640px) {
	header {
		z-index: 1000;
		padding: 0;
		min-width: 100%;
		height: 0.60rem;
	}
}

header .logo {
	margin-left: calc((100% - 14rem) / 2);
}
@media screen and (max-width: 640px) {
	header .logo {
		width: 0.44rem;
		position: absolute;
		left: 0.11rem;
		top: 50%;
		transform: translateY(-50%);
		margin-left: 0;
	}
	header .logo img {
		display: block;
	}
}

header .glo_navi .list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	margin-right: 0.25rem;
}
@media screen and (max-width: 640px) {
	header .glo_navi {
		position: absolute;
		top: 0.59rem;
		left: 0;
		width: 100%;
		background-color: rgba(53, 177, 237, 0.9);
		-webkit-backdrop-filter: blur(10px);
		backdrop-filter: blur(10px);
		padding: 0.30rem;
		display: none;
	}
	header .glo_navi .list {
		display: block;
		margin-right: 0;
	}
}

header .glo_navi .list a {
	color: #000;
	font-weight: 600;
	font-size: 0.15rem;
}
@media screen and (max-width: 640px) {
	header .glo_navi .list a {
		font-size: 0.16rem;
		color: #FFF;
		position: relative;
		line-height: 2.5;
	}
	header .glo_navi .list a::before {
		content: "";
		width: 0.08rem;
		height: 1px;
		background-color: #FFF;
		display: inline-block;
		margin-right: 0.08rem;
		position: relative;
		top: -0.04rem;
	}
}

header .glo_navi .list a:hover {
	color: #35b1ed;
}
@media screen and (max-width: 640px) {
	header .glo_navi .list a:hover {
		color: #FFF;
	}
}

header .glo_navi .list .contact a {
	color: #fff;
	background: #35b1ed;
	padding: 0.15rem 0.4rem;
	box-sizing: border-box;
	border-radius: 0.4rem;
	border: 1px solid #35b1ed;
}
@media screen and (max-width: 640px) {
	header .glo_navi .list .contact a {
		background: transparent;
		padding: 0;
		border-radius: 0;
		border: 0;
	}
}

header .glo_navi .list .contact a:hover {
	background: #fff;
	color: #35b1ed;
}
@media screen and (max-width: 640px) {
	header .glo_navi .list .contact a:hover {
		background: transparent;
		color: #FFF;
	}
}

main {
	padding-top: 1.00rem;
}
@media screen and (max-width: 640px) {
	main {
		padding-top: 0.60rem;
	}
}

#SPnaviBtn {
	background-color: #35b1ed;
	width: 0.60rem;
	height: 0.60rem;
}

#SPnaviBtn span {
	background-color: #FFF;
}

.menu-trigger span:nth-of-type(1) {
	top: 36%;
}

.menu-trigger span:nth-of-type(2) {
	top: 49%;
}

.menu-trigger span:nth-of-type(3) {
	bottom: 36%;
}

@media screen and (max-width: 640px) {
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(0) rotate(45deg);
		transform: translateY(0) rotate(45deg);
		bottom: calc(50% - 1px);
	}
}

@media screen and (max-width: 640px) {
	.contact_btn {
		width: 0.80rem;
		height: 0.60rem;
		position: absolute;
		right: 0.60rem;
		top: 0;
	}
	.contact_btn a {
		display: block;
		width: 100%;
		height: 100%;
		position: relative;
	}
	.contact_btn a::before {
		content: "";
		width: 0.35rem;
		height: 0.25rem;
		background-image: url(../img/header_mail_btn_sp.svg);
		background-position: center;
		background-repeat: no-repeat;
		background-size: contain;
		position: absolute;
		top: 0.10rem;
		left: 50%;
		transform: translateX(-50%);
	}
	.contact_btn a span {
		display: block;
		padding-top: 0.40rem;
		font-size: 0.10rem;
		font-weight: 600;
		color: #35b1ed;
		text-align: center;
		letter-spacing: 0;
	}
}

/* --------- 以下、必要に応じて有効化 ---------- */

/* ヘッダーが上に消える
header.hide {
	transform: translateY(-1.50rem);
}
 */

/* スクロールで表示された状態
header.scr {
	background-color: rgba(255, 255, 255, 0.85);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
}
 */


 .hsfc-TextareaInput{
	height: 200px;
 }