@charset "utf-8";
/* CSS Document */


/*==========
Googleフォント
==========*/
@import url('https://fonts.googleapis.com/css2?family=Geologica:wght@900&family=Noto+Sans+JP:wght@400;900&display=swap');


/*==========
共通
==========*/
:root {
	--a_color: #235eff;
	--main_color: #3ac3f2;
	--bg_gray: #f2f2f2;
	--line_color: #c7c3c3;
}

html {
	font-size: 62.5%;
	scroll-behavior: smooth;
	scroll-padding-top: 0.5rem;
}

body {
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
	font-size: 1.5rem;
	line-height: 1.57;
	color: #000;
	background-color: #FFF;
	position: relative;
	overflow-x: hidden;
	font-feature-settings: "palt"1;
}

a {
	transition: .3s;
}

a:hover {
	transition: .3s;
}

.wrap {
	width: 100%;
	margin: 0 auto;
}

.container {
	width: 96%;
	margin: 0 auto;
}

.text_red {
	color: #fb1818;
}

.main_color {
	color: var(--main_color);
}

.bold {
	font-weight: 900;
}


@media (min-width: 768px) {
	body {
		font-size: 1.7rem;
		line-height: 1.67;
	}

	.wrap {
		width: 900px;
		margin: 0 auto;
	}

	.container {
		max-width: 720px;
	}

}



/* ==========
ヘッダー
========== */
.site_header {
	position: fixed;
	z-index: 9999;
	top: 0;
	right: 0;
	width: 100%;
	background-color: rgba(255, 255, 255, 0.9);
}

.site_header .container {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
}

.site_header_title {
	width: 78%;
}

.site_header_title a {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 9px;
	text-decoration: none;
}

.site_header_title img {
	height: 66px;
	width: auto;
}

.site_header_title h1 {
	font-size: 1.25rem;
	width: 60%;
	line-height: 1.4;
	transform: translateY(-3px);
	text-shadow: #FFF 1px 1px 3px;
}

.site_header_title h1 span {
	display: block;
	font-size: 1.2rem;
	font-weight: 400;
}

.site_header_btn_wrap {
	width: 22%;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: center;
}

.site_header_sns {
	margin-right: 69px;
}

.site_header_sns svg {
	height: 42px;
	fill: #06c755;
}

@media (min-width: 768px) {
	.site_header .container {
		max-width: 900px;
	}

	.site_header_title a {
		gap: 15px;
	}

	.site_header_title img {
		height: 90px;
		margin-left: 12px;
	}

	.site_header_title h1 {
		font-size: 2.4rem;
		line-height: 1.3;
		transform: translateY(-5px);
	}

	.site_header_title h1 span {
		font-size: 1.6rem;
	}

	.site_header_sns {
		margin-right: 80px;
	}

	.site_header_sns svg {
		height: 54px;
	}
}



/*==========
ハンバーガーメニュー
===========*/
.openbtn1 {
	position: fixed;
	z-index: 9999;
	top: 6px;
	cursor: pointer;
	width: 66px;
	height: 60px;
}

#g-nav {
	position: fixed;
	z-index: 999;
	top: 0;
	right: -120%;
	width: 100%;
	height: 100vh;
	/*ナビの高さ*/
	background-color: #e2e6ea;
	transition: all 0.3s;
}

/*アクティブクラスがついたら位置を0に*/
#g-nav.panelactive {
	right: 0;
}

/*ナビゲーションの縦スクロール*/
#g-nav.panelactive #g-nav-list {
	/*ナビの数が増えた場合縦スクロール*/
	position: fixed;
	z-index: 999;
	width: 100%;
	height: 100vh;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}

/*ナビゲーション*/
#g-nav ul {
	position: absolute;
	z-index: 999;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#g-nav li {
	margin-bottom: 24px;
}

#g-nav li a {
	font-size: 2rem;
	color: #000;
	font-weight: 900;
	text-align: center;
	display: block;
	text-decoration: none;
}

/*×に変化*/
.openbtn1 span {
	display: inline-block;
	transition: all .4s;
	position: absolute;
	left: 15px;
	height: 2px;
	background-color: #000;
	width: 55%;
}

.openbtn1 span:nth-of-type(1) {
	top: 14px;
}

.openbtn1 span:nth-of-type(2) {
	top: 23px;
}

.openbtn1 span:nth-of-type(3) {
	top: 32px;
}

.openbtn1.active span:nth-of-type(1) {
	top: 18px;
	left: 18px;
	transform: translateY(6px) rotate(-45deg);
	width: 55%;
	background-color: #000;
}

.openbtn1.active span:nth-of-type(2) {
	opacity: 0;
}

.openbtn1.active span:nth-of-type(3) {
	top: 30px;
	left: 18px;
	transform: translateY(-6px) rotate(45deg);
	width: 55%;
	background-color: #000;
}

@media (min-width: 768px) {
	.openbtn1 {
		top: 15px;
		width: 78px;
	}

	#g-nav li a {
		font-size: 3rem;
	}
}


/*==========
セクションタイトル
==========*/
.section_title {
	margin-bottom: 30px;
	line-height: 1;
}

.section_title span {
	font-family: 'Geologica', sans-serif;
	font-size: 4.2rem;
}

.section_title h2 {
	font-size: 1.4rem;
	color: var(--main_color);
}

@media (min-width: 768px) {
	.section_title {
		margin-bottom: 48px;
	}

	.section_title span {
		font-size: 6.6rem;
	}

	.section_title h2 {
		font-size: 2rem;
	}
}


/*==========
LINEボタン
==========*/
.line_btn {
	width: 90%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 9px;
	padding: 12px 0;
	background-color: #06c755;
	text-decoration: none;
	margin: 30px auto 0;
	border-radius: 60px;
	box-shadow: 3px 3px 0px #053d1c;
}

.line_btn svg {
	height: 42px;
	fill: #FFF;
}

.line_btn p {
	font-weight: 600;
	color: #FFF;
}

.line_btn p span {
	font-size: 2rem;
}

@media (min-width: 768px) {
	.line_btn {
		max-width: 540px;
		margin: 42px auto 0;
	}

	.line_btn svg {
		height: 54px;
	}

	.line_btn span {
		font-size: 2.2rem;
	}
}


/*==========
サイトフッター
==========*/
.site_footer {
	padding: 48px 0 12px;
	background-color: #e2e6ea;
}

.site_footer_logo {
	text-align: center;
	margin-bottom: 30px;
}

.site_footer_logo img {
	width: 120px;
	margin: 0 auto;
}

.site_footer_logo p {
	font-weight: 700;
}

.site_footer_link {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	width: 84%;
	margin: 0 auto 30px;
}

.site_footer_link li {
	width: calc((100% - 12px *1)/2);
}

.site_footer_link li:nth-child(odd) {
	text-align: right;
}

.site_footer_link li a {
	font-size: 1.4rem;
	text-decoration: none;
}

.site_footer_link li a:hover {
	color: var(--btn_hover_color);
}

.site_footer_copy {
	font-size: 1.25rem;
	text-align: center;
}

@media (min-width: 768px) {
	.site_footer {
		padding-top: 60px;
	}

	.site_footer_logo {
		margin-bottom: 36px;
	}

	.site_footer_logo img {
		width: 150px;
	}

	.site_footer_link {
		margin-bottom: 36px;
	}

	.site_footer_copy {
		font-size: 1.35rem;
	}
}


.footer_sns {
	position: fixed;
	bottom: 66px;
	right: 6px;
	z-index: 9999;
	text-align: right;
}

.footer_sns p {
	font-size: 1.25rem;
	font-weight: 600;
	background-color: #ffffff;
	padding: 3px 12px;
	border-radius: 15px;
	border: solid 2px #06c755;
}

.footer_sns svg {
	height: 60px;
	fill: #06c755;
	filter: drop-shadow(0px 0px 6px #FFF);
}

@media (min-width: 768px) {
	.footer_sns {
		right: calc((100vw - 900px)/2);
		bottom: 90px;
	}

	.footer_sns svg {
		height: 78px;
	}
}


.top_scroll {
	position: fixed;
	bottom: 6px;
	right: 6px;
	z-index: 9999;
}

.top_scroll a {
	text-decoration: none;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 60px;
	height: 60px;
	background-color: rgb(113 150 169 / 90%);
	border-radius: 3px;
	box-shadow: 0px 0px 6px #FFF;
}

.top_scroll a span {
	color: #FFF;
}

.top_scroll a svg {
	height: 12px;
	fill: #FFF;
}

@media (min-width: 768px) {
	.top_scroll {
		right: calc((100vw - 900px)/2);
		bottom: 12px;
	}

	.top_scroll a {
		width: 72px;
		height: 72px;
	}
}
