@charset "utf-8";
/* CSS Document */


/*------------------------------------------------
Header
------------------------------------------------*/
@keyframes HeaderDownAnime{
  from {
  	opacity: 0;
		transform: translateY(-70px);
  }
  to {
  	opacity: 1;
		transform: translateY(0);
  }
}
.contact a {
  /*お問い合わせボタン*/
  background-color: var(--key-color);
  font-weight: 500;
  color: #fff;
}
.contact a:hover {
  	background-color: var(--key-color-50);
}
.contact a::before {
  content: '';
  display: block;
	margin:  0 auto 0.8rem auto;
  width: 15px;
  height: 11px;
  background-image: url("../img/common/mail.svg");
  background-repeat: no-repeat;
  background-size: contain;
}
.sub header,
.top header.HeightMin {
  box-shadow: 0px -4px 10px 0px rgba(192,192,192,0.8);
}
/* パソコン用 */
@media screen and (min-width: 1140px) {
	header {
		display: flex;
		justify-content: space-between;
		align-items: center;
		background-color: rgba(255,255,255,0.9);
		/*上部固定*/
		position: fixed;
		/*top: 0;*/
		top: -3px;
		z-index: 2000;
		width: 100%;
	}
	.top header {
		padding: 0 0 0 2rem;
	}
	.sub header,
	.top header.HeightMin {
		padding: 0 0 0 2rem;
	}
	.top header.HeightMin {
		/*TOPのみアニメーション表示*/
		animation: HeaderDownAnime 0.5s forwards;
	}
	header .logo {
		width: 10%;
	}
	header nav ul#g_nav {
		display: flex;
		justify-content: flex-end;
		align-items: flex-end;
	}
	.top header.HeightMin nav,
	.sub header nav {
		align-items: center;
	}
	header nav ul#g_nav li > span,
	header nav ul#g_nav li > span > a,
	header nav ul#g_nav li > a {
		display: block;
		padding: 1.5rem;
		line-height: 1.0;
		font-family: "Poppins", sans-serif;
		font-size: 14px;
		color: #666;
	}
	header nav ul#g_nav li > span:has(a) {
		padding: 0;
	}
	header nav ul#g_nav li.contact {
		margin-left: 0.5rem;
	}
	header nav ul#g_nav li.contact a {
		padding: 0.8rem 1.2rem;
		font-size: 13px;
		color: #fff;
	}
	.top header.HeightMin,
	.sub header {
		align-items: center;
	}
	header.HeightMin nav ul#g_nav li.contact a::before,
	.sub header nav ul#g_nav li.contact a::before {
		
	}
	.top header.HeightMin nav ul#g_nav li:not(.contact) a,
	.sub header nav ul#g_nav li:not(.contact) a {
	}
	header nav ul#g_nav > li.current:not(.contact) > a {
		color: var(--navy-color);
		font-weight: 600;
	}
	header nav ul#g_nav li a:hover {
		opacity: 0.5;
	}
	header nav ul#g_nav li.contact a:hover {
		color: #fff;
		background-color: var(--key-color-50);
		opacity: 1;
	}
	/* ドロップダウンメニュー */
	ul#g_nav li.drop-menu {
		position: relative;
	}
	ul#g_nav ul.drop-menu-list {
		position: absolute;
		top: 115%;
		left: 50%;
  		transform: translateX(-50%);
		z-index: 1;
		opacity: 0; /* 不透明度を最小に */
		transition: opacity .3s, visibility .3s; /* アニメーション設定 */
		visibility: hidden; /* 下層メニューを非表示 */
		width: max-content;
		background-color: var(--key-color-50);
		border-radius: 10px;
		padding: 0 1rem;
	}
	ul#g_nav ul.drop-menu-list li.drop-menu-item:not(:last-of-type) a {
		border-bottom: 1px solid #fff;
		text-align: center;
	}
	/* メニューアイテムのホバースタイル */
	ul#g_nav li.drop-menu:hover ul.drop-menu-list {
		opacity: 1; /* 不透明度を最大に */
		transition: opacity .3s, visibility .3s; /* アニメーション設定 */
		visibility: visible; /* 下層メニューを表示 */
	}
	ul#g_nav ul.drop-menu-list li.drop-menu-item a:hover {
		color: #fff;
		opacity: 1;
	}
}
/* ハンバーガー */
@media screen and (max-width:1140px) {
	header {
		/*上部固定*/
		position: sticky;
		top: 0;
		z-index: 100;
		min-height: 50px;
		display: flex;
		align-items: center;
		background-color: rgba(255,255,255,0.9);
	}
	header .logo a {
		display: block;
		padding-left: 20px;
	}
	ul#g_nav {
		overflow-y: scroll;
		height: 100vh;
		padding-top: 10%;
		padding-bottom: 80px;
		display: flex;
    	flex-direction: column;
    	align-items: center;
	}
	ul#g_nav li.current:not(.contact) {
		color: var(--key-color-10);
	}
	header nav ul#g_nav li.contact {
		margin-top: 1.5rem;
		text-align: center;
	}
	ul#g_nav li a  {
		display: block;
		padding: 20px 10px 5px;
		margin-bottom: 15px;
		font-weight: 500;
		font-size: 16px;
		letter-spacing: 0.1rem;
		text-align: center;
		color: #1c1c1c;
	}
	ul#g_nav li a:hover {
		color: var(--key-color);
	}
	ul#g_nav li.parent ul.down_menu li a {
		font-weight: normal;
		color: #1c1c1c;
		padding: 20px 10px;
        margin-bottom: 0;
	}
	ul#g_nav > li.current a {
		color: var(--key-color-10);
		font-weight: 600;
	}
	header nav ul#g_nav li.contact {
		margin-top: 0;
	}
	header nav ul#g_nav li.contact a::before {
		display: inline-block;
		margin:  0 0.5rem 0 auto;
	}
	header nav ul#g_nav li.contact a {
		/*お問い合わせ*/
		margin: 0 auto;
		padding: 0.8rem 2rem;
		color: #fff;
	}
	header nav ul#g_nav li.contact a:hover {
		background-color: #333;
	}
	.nav_wrapper {
		position: fixed;
		top: 0;
		right: -100%; /*メニュー幅*/
		width: 100%; /*メニュー幅*/
		z-index: 2;
		margin-top: 50px;
		background-color: rgba(255,255,255,0.96);
		border-top: 1px solid rgba(198,234,249,0.5);
		transition: all 0.2s;
	}
	.hamburger {
		position: absolute;
		z-index: 3;
		right: 10px;
		top: 0;
		width: 50px;
		height: 50px;
		padding: 10px;
		cursor: pointer;
	}
	.hamburger span {
		position: absolute;
		height: 2px;
		width: 30px;
		background-color: var(--key-color);
		transition: all 0.5s;
	}
	.hamburger_linetop {
		top: 15px;
	}
	.hamburger_linecenter {
		top: 24px;
	}
	.hamburger_linebottom {
		top: 33px;
	}
	.nav_open .nav_wrapper {
		right: 0;
		top: 0;
		height: 100vh;
	}
	.nav_open .hamburger_linetop {
		top: 26px;
		transform: rotate(45deg);
	}
	.nav_open .hamburger_linecenter {
		left: 50%;
		width: 0;
	}
	.nav_open .hamburger_linebottom {
		top: 26px;
		transform: rotate(-45deg);
	}
}
@media screen and (max-width:480px) {
	header .logo img {
		width: 90%;
	}
	header .logo a {
		padding-left: 1rem;
	}
	.hamburger {
		right: 5px;
	}
	ul#g_nav li a  {
		font-size: 15px;
	}
}

/* パソコン用 */
@media screen and (min-width: 1140px) {
	ul#g_nav li.drop_menu {
		position: relative;
	}
	ul#g_nav li.drop_menu ul.down_menu {
			position: absolute;
			top: 115%;
			left: 50%;
			transform: translateX(-50%);
			z-index: 1;
			opacity: 0; /* 不透明度を最小に */
			transition: opacity .3s, visibility .3s; /* アニメーション設定 */
			visibility: hidden; /* 下層メニューを非表示 */
			width: max-content;
			background-color: var(--grey-color);
			border-radius: 10px;
			padding: 0 1rem;
		}
	ul#g_nav li.drop_menu ul.down_menu li.accordion-content a {
		padding: 1.1rem 1.2rem;
		font-size: 14px;
		text-align: center;
		font-weight: 400;
		color: var(--key-color);
		opacity: 1;
	}
	ul#g_nav li.drop_menu ul.down_menu li.accordion-content:not(:last-of-type) a {
		border-bottom: 1px solid var(--key-color);
		text-align: center;
	}
	/* メニューアイテムのホバースタイル */
	ul#g_nav li.drop_menu:hover ul.down_menu {
		opacity: 1; /* 不透明度を最大に */
		transition: opacity .3s, visibility .3s; /* アニメーション設定 */
		visibility: visible; /* 下層メニューを表示 */
	}
	ul#g_nav li.drop_menu ul.down_menu li.accordion-content a:hover,
	ul#g_nav li.drop_menu ul.down_menu li.current a {
		color: var(--navy-color);
	}
	ul#g_nav li.drop_menu.current > span,
	ul#g_nav li.drop_menu.current > a,
	ul#g_nav li.drop_menu span.title.current a {
		color: var(--navy-color);
		font-weight: 600;
	}
}
@media screen and (max-width:1140px) {
	ul#g_nav li.drop_menu {
		position: relative;
	}
	ul#g_nav li.drop_menu span.title {
		position: relative;
		display: block;
		padding: 1rem 4rem;
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 0.1rem;
		cursor: pointer;
	}
	/* 縦線 */
	ul#g_nav li.drop_menu span.title::before {
		background: var(--key-color); /* 線の色 */
		content: "";
		height: 2px; /* 線の太さ */
		position: absolute;
		right: 25px;
		top: 50%; /* 線の位置を縦中央に */
		transform: rotate(90deg); /* 線を縦に */
		transition: transform .3s ease-in-out;
		width: 15px; /* 線の幅 */
	}
	/* 横線 */
	ul#g_nav li.drop_menu span.title::after {
		background: var(--key-color); /* 線の色 */
		content: "";
		height: 2px; /* 線の太さ */
		position: absolute;
		right: 25px;
		top: 50%; /* 線の位置を縦中央に */
		transition: opacity .3s ease-in-out;
		width: 15px; /* 線の幅 */
	}
	/* 縦線(クリック後) */
	ul#g_nav li.drop_menu span.title.open::before {
		transform: rotate(180deg);
	}
	/* 横線(クリック後) */
	ul#g_nav li.drop_menu span.title.open::after {
		opacity: 0;
	}
	ul#g_nav li.drop_menu span.title > span {
		line-height: 1.0;
	}
	ul#g_nav li.drop_menu span.title a {
		padding: 0;
	}
	ul#g_nav li.drop_menu span.title.current a {
		color: var(--key-color);
	}
	ul#g_nav li.drop_menu ul.down_menu {
		display: none;
		margin-bottom: 0.5rem;
		background-color: var(--grey-color);
		border-radius: 4px;
	}
	ul#g_nav li.drop_menu ul.down_menu li:not(:last-of-type) a {
		border-bottom: 1px solid #fff;
	}
	ul#g_nav li.drop_menu ul.down_menu li.accordion-content.current a {
		color: var(--key-color-10);
		border-bottom: 1px solid #fff;
	}
}




/*------------------------------------------------
Footer
------------------------------------------------*/
footer .contact_area {
	padding: 4em 0;
	background-color: var(--grey-color);
	text-align: center;
}
.advantage footer .contact_area {
	background-color: #fff;
}
footer .contact_area .en {
	font-family: "Poppins", sans-serif;
	font-weight: 200;
	font-size: 26px;
}
footer .contact_area .en::after {
	display: block;
	content: "";
	width: 1px;
	height: 35px;
	margin: 0 auto;
	background-color: var(--key-color);
}
footer .contact_area .text {
	margin-bottom: 30px;
	font-size: 20px;
	font-weight: 400;
}
footer .contact_area .flex_box {
	display: flex;
	justify-content: center;
	gap: 2rem;
	flex-direction: column;
}
footer .contact_area .tel a {
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: "Poppins", sans-serif;
	font-weight: 200;
	font-size: 40px;
	color: var(--key-color);
	line-height: 1;
}
footer .contact_area .tel a img {
	width: 50px;
	margin-right: 0;
}
footer .contact_area .tel p {
	font-size: 14px;
	color: var(--key-color-50);
	letter-spacing: 0.1rem;
}
footer .contact_area .banar {
}
footer .contact_area .banar a {
	width: 350px;
	text-align: center;
	margin: 0 auto;
	padding: 15px;
	background-color: #fff;
	border: 1px solid var(--key-color);
	color: var(--key-color);
	display: flex;
	align-items: center;
	justify-content: center;
}
footer .contact_area .banar a:hover {
	background-color: var(--key-color-50);
	border: 1px solid var(--key-color-50);
}
footer .contact_area .banar a span {
	font-size: 18px;
	letter-spacing: 0.05rem;
}
footer .contact_area .banar img {
	width: 20px;
	margin-right: 10px;
}
footer .bottom {
	display: flex;
	justify-content: space-between;
	padding: 1.5rem 5%;
	background-color: #dcdcdc;
	color: #000;
}
footer .name {
	margin-right: 3rem;
}
footer .name img {
	width: 200px;
}
footer .address {
	text-align: right;
}
footer .address p {
	color: #000;
	line-height: 1.6;
}
footer .address a {
	color: #000;
}
footer p.copyright small {
	letter-spacing: 0;
	color: #9a9a9a;
}
@media screen and (max-width: 1000px) {
	footer .address p,
	footer .address a {
		font-size: 0.9rem;
	}
}
@media screen and (max-width: 900px) { 
	footer .contact_area {
		padding: 2rem 0;
	}
	footer .contact_area .text {
		margin-bottom: 0;
		font-size: 28px;
	}
	footer .contact_area .tel a {
		font-size: 40px;
	}
	footer .contact_area .banar a {
		padding: 0 4rem;
	}
}
@media screen and (max-width: 768px) { 
	footer .contact_area .flex_box {
		flex-direction: column;
		align-items: center;
		gap: 1rem;
	}
	footer .contact_area .banar {
		width: 70%;
	}
	footer .contact_area .banar a {
		padding: 1.0rem 4rem;
	}
	footer .contact_area .banar a span {
		font-size: 16px;
		letter-spacing: 0.08rem;
	}
	footer .name {
		margin-right: 2rem;
	}
}
@media screen and (max-width: 640px) {
	footer .contact_area .en::after {
		height: 30px;
	}
	footer .contact_area .flex_box {
		gap: 0.5rem;
	}
	footer .contact_area .text {
		font-size: 24px;
	}
	footer .contact_area .tel a {
		font-size: 36px;
	}
	footer .bottom {
		flex-direction: column;
		align-items: center;
	}
	footer .name {
		margin-right: 0;
	}
	footer .name img {
		width: 200px;
		margin-bottom: 1rem;
	}
	footer .address {
		text-align: center;
		margin-bottom: 40px;
	}
	footer p.copyright small {
		line-height: 1;
	}
}
@media screen and (max-width: 480px) { 
	footer .contact_area .en::after {
		height: 25px;
	}
	footer .contact_area .text {
		font-size: 18px;
	}
	footer .contact_area .tel a {
		font-size: 30px;
	}
	footer .contact_area .tel p {
		font-size: 12px;
		color: #999;
	}
	footer .contact_area .banar a {
		padding: 0.8rem 1.0rem;
	}
	footer p.copyright small {
		font-size: 70%;
	}
}

/* 下部固定お問い合わせボタン
------------------------------------*/
#contact_box {
	position: fixed;
	z-index: 1000;
	top: 45%;
	right: 0;
	transform: translateY(-50%);
	text-align: center;
}
#contact_box {
	overflow: hidden;
	transform: translateX(61%);
  	transition: transform 0.5s;
}
#contact_box:hover{
	transform: translateX(0);
}
#contact_box a {
	padding-right: 20px;
	display: flex;
	align-items: center;
	background-color: var(--key-color);
}
#contact_box a img {
	width: 35px;
	margin: 20px;
}
#contact_box a p {
	color: #fff;
	font-size: 16px;
	margin-bottom: 5px;
}

@media (min-width: 640px) {
    #contact_box_sp {
		display: none;
	}
}
@media only screen and (max-width:640px) {
	#contact_box {
		display: none!important;
	}
	#contact_box_sp {
		position: fixed;
		width: 100%;
		bottom: 0;
		left: 0;
		z-index: 1000;
		background-color: #fff;
		padding-bottom: env(safe-area-inset-bottom);
	}
	#contact_box_sp a {
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 10px;
		background-color: var(--key-color);
	}
	#contact_box_sp a img {
		width: 20px;
		margin-right: 10px;
	}
	#contact_box_sp a p {
		color: #fff;
		font-size: 16px;
	}
}

/* TOPへ戻るボタン
------------------------------------*/
#page_top {
	position: fixed;
	z-index: 1000;
  	right: 0;
  	bottom: 20px;
  	width: 70px;
  	text-align: center;
	/*はじめは非表示*/
	opacity: 0;
	transform: translateY(100px);
}
#page_top a {
  display: block;
}
#page_top a img {
	width: 50px;
	margin: 0 auto;
}
#page_top a p {
	font-weight: 500;
	font-size: 0.9rem;
	letter-spacing: 0;
}
/*　上に上がる動き　*/
#page_top.UpMove {
	animation: PagetopUpAnime 0.5s forwards;
}
@keyframes PagetopUpAnime{
  from {
    opacity: 0;
	transform: translateY(100px);
  }
  to {
    opacity: 1;
	transform: translateY(0);
  }
}
/*　下に下がる動き　*/
#page_top.DownMove {
	animation: PagetopDownAnime 0.5s forwards;
}
@keyframes PagetopDownAnime{
  from {
  	opacity: 1;
	transform: translateY(0);
  }
  to {
  	opacity: 1;
	transform: translateY(100px);
  }
}
@media only screen and (max-width:640px) {
	#page_top {
		right: 10px;
	}
}


