@charset "utf-8";
/* CSS Document */

#open_menu {
	display: none;
}

#sp_box {
	display: block;
}

/**************************************
	ハンバーガーアイコン
***************************************/

#spicon {
	background-color: #8CA8CD;
	border-radius: 50%;
	box-shadow: 0 0 22.5px rgba(71, 76, 83, 0.08);
	cursor: pointer;
	height: 65px;
	position: fixed;
	right: 2%;
	top: 20px;
	width: 65px;
	z-index: 9999;
}

#spicon span {
	background-color: #FFFFFF;
	border-radius: 999px;
	height: 2px;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	transition: top 0.3s ease, transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease;
	width: 36px;
}

#spicon span:nth-child(1) {
	top: 21px;
}

#spicon span:nth-child(2) {
	top: 31px;
}

#spicon span:nth-child(3) {
	top: 41px;
}

#spicon.m_active {
	background-color: #FFFFFF;
}

#spicon.m_active span {
	background-color: #8CA8CD;
}

#spicon.m_active span:nth-child(1) {
	top: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
}

#spicon.m_active span:nth-child(2) {
	opacity: 0;
}

#spicon.m_active span:nth-child(3) {
	top: 50%;
	transform: translate(-50%, -50%) rotate(-45deg);
}

/**************************************
	メニューオープン
***************************************/

#open_menu {
	height: 100dvh;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 9990;
}

#center_box {
	background: #F5F8FB url("../images/body_bg.webp") center top / cover repeat-y;
	box-sizing: border-box;
	height: 100%;
	left: 0;
	overflow-y: auto;
	padding-bottom: clamp(70px, 6.25vw, 120px);
	padding-top: clamp(150px, 9.38vw, 180px);
	position: fixed;
	top: 0;
	width: 100%;
}

/**************************************
	MENUの中身
***************************************/

.spmenu_inner {
	position: relative;
}

.spmenu_logo {
	margin-left: auto;
	margin-right: auto;
	width: 120px;
}

.spmenu_logo img {
	width: 100%;
}

.spmenu_nav {
	display: grid;
	gap: 40px;
	grid-template-columns: repeat(3, 1fr);
	margin-top: clamp(50px, 4.17vw, 80px);
}

.spmenu_col {
	background-color: #FFFFFF;
	border-radius: 20px;
	box-shadow: 0 0 45px rgba(71, 76, 83, 0.08);
	padding-bottom: 30px;
	padding-left: clamp(24px, 2.08vw, 40px);
	padding-right: clamp(24px, 2.08vw, 40px);
	padding-top: 30px;
}

.spmenu_col p {
	border-bottom: 1px solid #D2D2D2;
}

.spmenu_col a {
	color: #4E5155;
	display: block;
	font-size: 18px;
	letter-spacing: 1.08px;
	line-height: 1.8;
	position: relative;
	padding: 15px 0;
}

.spmenu_col a::after {
	border-right: 1px solid #8CA8CD;
	border-top: 1px solid #8CA8CD;
	content: "";
	height: 7px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	width: 7px;
}

.spmenu_cta {
	background-color: #96B8E4;
	border-radius: 20px;
	box-shadow: 2px 4px 22.5px rgba(71, 76, 83, 0.12);
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	margin-top: clamp(50px, 4.17vw, 80px);
	max-width: 1152px;
	padding: 30px clamp(20px, 4.17vw, 80px);
	width: 100%;
}

.spmenu_cta_inner {
	display: flex;
	gap: 60px;
	justify-content: center;
}

.spmenu_cta_btn {
	width: 336px;
}

.spmenu_cta_btn_wide {
	width: 596px;
}

.spmenu_cta_btn a {
	align-items: center;
	background-color: #FFFFFF;
	border-radius: 40px;
	box-shadow: 2px 4px 12.5px rgba(90, 98, 108, 0.08);
	display: flex;
	gap: 40px;
	min-height: 84px;
	padding: 25px 30px 25px 40px;
	width: 100%;
}

.spmenu_cta_btn a::before {
	content: none;
	display: none;
}

.spmenu_cta_btn_wide a {
	gap: 20px;
}

.spmenu_cta_btn_text {
	align-items: center;
	display: flex;
	flex-shrink: 0;
	gap: 15px;
}

.spmenu_cta_icon {
	flex-shrink: 0;
	width: 40px;
}

.spmenu_cta_copy {
	color: #84A6D3;
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.5;
	white-space: nowrap;
}

.spmenu_cta_arrow {
	background-color: #84A6D3;
	border-radius: 50%;
	flex-shrink: 0;
	height: 31px;
	position: relative;
	width: 31px;
}

.spmenu_cta_arrow::before {
	border-right: 2px solid #FFFFFF;
	border-top: 2px solid #FFFFFF;
	content: "";
	height: 7px;
	left: 46%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	width: 7px;
}

@media only screen and (max-width: 1024px) {
	#spicon {
		height: 60px;
		top: 18px;
		width: 60px;
	}

	#spicon span {
		width: 32px;
	}

	#spicon span:nth-child(1) {
		top: 20px;
	}

	#spicon span:nth-child(2) {
		top: 29px;
	}

	#spicon span:nth-child(3) {
		top: 38px;
	}

	.spmenu_nav {
		gap: 0;
		grid-template-columns: repeat(1, 1fr);
		background-color: #FFF;
		border-radius: 20px;
		padding: 35px;
		box-shadow: 0 0 45px rgba(71, 76, 83, 0.08);
	}
	.spmenu_col {
		background: none;
		padding: 0;
		box-shadow: 0 0 0 rgba(71, 76, 83, 0);
	}

	.spmenu_cta {
		padding-left: 24px;
		padding-right: 24px;
	}

	.spmenu_cta_inner {
		gap: 20px;
	}

	.spmenu_cta_btn {
		max-width: 336px;
		width: 40%;
	}

	.spmenu_cta_btn_wide {
		max-width: 596px;
		width: 50%;
	}

	.spmenu_cta_btn a {
		gap: 20px;
		height: 100%;
		min-height: 74px;
		padding: 18px 20px 18px 22px;
		position: relative;
	}

	.spmenu_cta_copy {
		white-space: normal;
	}

	.spmenu_cta_icon {
		width: 34px;
	}

	.spmenu_cta_arrow {
		height: 28px;
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
		width: 28px;
	}
}

@media only screen and (max-width: 768px) {
	#spicon {
		height: 52px;
		width: 52px;
	}

	#spicon span {
		width: 26px;
	}

	#spicon span:nth-child(1) {
		top: 17px;
	}

	#spicon span:nth-child(2) {
		top: 25px;
	}

	#spicon span:nth-child(3) {
		top: 33px;
	}

	#center_box {
		padding-bottom: 70px;
		padding-top: 120px;
	}

	.spmenu_logo {
		width: 96px;
	}

	.spmenu_nav {
		gap: 0;
		grid-template-columns: 1fr;
		margin-top: 40px;
	}

	.spmenu_col {
		gap: 14px;
		padding-bottom: 0;
		padding-left: 0;
		padding-right: 0;
		padding-top: 0;
	}

	.spmenu_col a {
		font-size: 17px;
		letter-spacing: 1.02px;
	}

	.spmenu_cta {
		margin-top: 40px;
		padding: 18px 14px 20px;
	}

	.spmenu_cta_inner {
		flex-direction: column;
		gap: 15px;
	}

	.spmenu_cta_btn {
		max-width: none;
		width: 100%;
	}

	.spmenu_cta_btn_wide {
		max-width: none;
		width: 100%;
	}

	.spmenu_cta_btn a {
		min-height: 70px;
		padding: 16px 25px;
		position: relative;
	}

	.spmenu_cta_btn_text {
		gap: 10px;
	}

	.spmenu_cta_icon {
		margin-right: 20px;
		width: 28px;
	}

	.spmenu_cta_copy {
		font-size: 18px;
	}

	.spmenu_cta_arrow {
		height: 24px;
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
		width: 24px;
	}

	.spmenu_cta_arrow::before {
		height: 5px;
		width: 5px;
	}
}
