@charset "UTF-8";


/*=======================================================*/
/*      	　			フッターCSS   			  		  */
/*=======================================================*/

/* フッター */
.footer {
	padding: 40px 0 0px 0;
	background-color: #FFF;
	color: #222;
	font-size: 14px;
	position: relative;
	z-index: 1;
}

.footer-container {
	/*SNSを使用する時*/
	/*display: grid;*/

	/*gap: 50px;*/
	
	/*SNSを使用しない時*/
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
} 

@media (min-width: 767px) {
	/*.footer-container {
		grid-template-columns: auto auto;
		grid-template-rows: auto auto auto;
		gap: 20px;
	}*/

	.footer-container > .footer-site {
		/*margin-top: 15px;*/	/*SNSを使用するとき*/
		margin-bottom: 35px;
	}

	.footer-container > *:not(.footer-sns) {
		justify-self: start;
	}
	
	.footer-container > .footer-sns {
		grid-column: 2;
		grid-row: 1 / 4;
		justify-self: end;
		/*align-self: center;*/
	}
}


/* フッター：SNSメニュー */
.footer-sns {
	display: flex;
	gap: 24px;
	font-size: 24px;
}

.footer-sns a {
	display: grid;
	place-items: center;
	width: 36px;
	aspect-ratio: 1 / 1;
	background-color: #8972b2;
	color: #ffffff;
	clip-path: circle(50%);
}

@supports not (aspect-ratio: 1 / 1) {
	.footer-sns a {
		height: 36px;
	}
}


/* フッター：テキストメニュー */
.footer-menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 15px;
}
.footer-menu li a:hover{
	/*display:block;*//*初期値*/
	display:inline-block;
	text-decoration: underline;
	color: var(--accent-color2);
}


/*フッター：会社情報*/
.footer-company{
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-bottom: 30px;	/*エリアがない場合に使用*/
	padding-top: 10px;
}

.footer-company p{
	line-height: 1.2;
}
/* フッターTEL全体 */
.footer-tel {
	display: flex;
	align-items: center;
	gap: 3px; /* アイコンと番号の間隔 */
	font-weight: bold;
	font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN",
		"Hiragino Sans", Meiryo, sans-serif;
}

/* アイコン */
.footer-tel_ico {
	display: inline-flex;
	width: 20px;
	height: 23px;
}

.footer-tel_ico img {
	width: 100%;
	height: auto;
}

/* 電話番号 */
.footer-tel_num {
	font-size: 25px;
	font-weight: bold;
	text-decoration: none;
	color: inherit;
}

/* フッターメニューコンテナ */
.footer-menu-container {
	/* padding-top: 30px; */
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	grid-column-gap: 0px;
	margin-bottom: 15px;
}

/* --- 1570px 以下 --- */
@media only screen and (max-width: 1570px) {
	.footer-menu-container {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		grid-auto-rows: auto; /* ← 高さを自動で詰める */
		grid-column-gap: 0px;
		grid-row-gap: 0px;
	}

}

/* --- 920px 以下 --- */
@media only screen and (max-width: 920px) {
	.footer-menu-container {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		grid-auto-rows: auto; /* ← 自動高さ */
		grid-column-gap: 0px;
		grid-row-gap: 0px;
	}

}

/* --- 700px 以下 --- */
@media only screen and (max-width: 700px) {
	.footer-menu-container {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-auto-rows: auto; /* ← 自動高さ */
		grid-column-gap: 0px;
		grid-row-gap: 0px;
	}	

.div1 { grid-area: 1 / 1 / 2 / 2; }
.div2 { grid-area: 1 / 2 / 2 / 3; }
.div3 { grid-area: 2 / 1 / 3 / 3; }
.div4 { grid-area: 3 / 1 / 4 / 3; }
.div5 { grid-area: 4 / 1 / 5 / 2; }
.div6 { grid-area: 4 / 2 / 5 / 3; }
.div7 { grid-area: 5 / 1 / 6 / 3; }

}

/* --- 360px 以下 --- */
@media only screen and (max-width: 360px) {
	.footer-menu-container {
		display: grid;
		grid-template-columns: repeat(1, 1fr);
		grid-auto-rows: auto; /* ← 自動高さ */
		grid-column-gap: 0px;
		grid-row-gap: 0px;
	}

	.div1 { grid-area: 1 / 1 / 2 / 2; }
	.div2 { grid-area: 2 / 1 / 3 / 2; }
	.div3 { grid-area: 3 / 1 / 4 / 2; }
	.div4 { grid-area: 4 / 1 / 5 / 2; }
	.div5 { grid-area: 5 / 1 / 6 / 2; }
	.div6 { grid-area: 6 / 1 / 7 / 2; }
	.div7 { grid-area: 7 / 1 / 8 / 2; }
}


/* フッター：テキストメニュー */

.footer-heading {
	position: relative;/*相対位置*/
	line-height: 1.4;/*行高*/
	display: inline-block;
	font-size:14px;
	margin: 10px 0 10px 0;
	width: 99%;
	line-height: 1.3;
	border-bottom: 2px dotted #cacaca;
}
.footer-heading:before { 
	position: relative;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	display: inline-block;
	font-size: 1.0em;
	color: var(--accent-color1);
}
.footer-heading::before {
	content: "";
	display: inline-block;
	position: relative; /* これを追加 */
	top: -2px; /* 上に2pxずらす */
	width: 1em; /* 大きさを調整 */
	height: 1em;
	margin-right: 0.5em;
	vertical-align: middle;
	background-color: var(--accent-color2); /* 親要素の文字色を反映 */
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'><path fill='black' d='M311.1 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L243.2 256 73.9 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z'/></svg>") no-repeat center / contain;
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'><path fill='black' d='M311.1 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L243.2 256 73.9 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z'/></svg>") no-repeat center / contain;
}
.footer-heading:hover{
	color:var(--accent-color2);
}

/* フッターメニュー */
ul.footer-menu li a{
	line-height: 1.2;
	vertical-align: middle;
	display: inline-block;
	/* white-space: nowrap; */
	font-weight:400;
}

.footer-menu {
	gap: 0%;
	margin-bottom: 10px;
	padding-left: 22px;
}

.footer-menu li a:hover{
	display:inline-block;
	text-decoration: underline;
	color: var(--accent-color2);
}

.footer-menu li {
	/*line-height:1;*/
	display:inline-block;
	width: 100%;
}
.footer-menu li a{
	display:inline-block;
}



/*コピーライト*/

.footer-copy {
	display:flex;
	justify-content: center;
	background-color: var(--accent-color2);
	align-items: center;
	height:30px;
	/* border-top: 4px solid var(--accent-color1); */
}
.footer-copy p {
	/*color: #666;*/
	color: #fff;    
	font-size: 11px;
}
/* フッター */
.footer-details{
	font-size: 13px;
	padding-bottom: 10px;
}

/*フッターバナー*/
.footerbnr {
	padding: 50px 0 50px 0;
	position: relative;
	z-index: 1;
	background-color: #f4faff;
	background-size: 6px 6px;
	background-image: repeating-linear-gradient(0deg, #d7e6f5, #d7e6f5 1px, #f4faff 1px, #f4faff);
}

/*対応エリア(footer)*/
.area {
	padding: clamp(5px, 7vw, 10px) 0 clamp(15px, 7vw, 20px) 0;
	background-color: #f7f7f7;
}

h4.areaTitle {
	font-size: clamp(17px,1.4vw,18px);
	font-weight:600;
	line-height: 1.4;
	border-bottom: 2px dotted var(--accent-color2);
	padding: 2px;
	margin: 10px 0;
	color: var(--accent-color2);
	text-align: center;
}
.afooter {
	color: var(--accent-color2);	
	font-size: 13px;
	text-align: center;
}


/*フッターロゴ*/
img.f-logo{
	width: 350px;
}
@media (max-width: 680px) {
	img.f-logo{
		width: 280px;
	}
}
@media (max-width: 372px) {
	img.f-logo{
		width: 60%;
		margin: 0 auto;
	}
}