@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");

:root {
	--weight-medium: 500;
}

html {
	font-size: 100%;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}


#FV .fv-img {
	position: relative;
	background-image: url(../image/about/about_kv.webp);
	background-size: cover;
	background-position: center center;
	width: 100%;
	height: auto;
	/* aspect-ratio: 480/111; */
	overflow: hidden;
	aspect-ratio: 1600/370;
}

#FV .fv-img .bread-crumbs {
	position: absolute;
	/* top: 1vw; */
	top: 0.156vw;
	left: 10.57%;
	font-size: 0.81rem;
	display: flex;
	gap: 10px;
	margin-block: 1rem;
}

#FV .fv-img .bread-crumbs a {
	text-decoration: underline;
	text-underline-offset: 0.313vw;
	padding-bottom: 0.104vw;
	transition: all 0.3s;
}

#FV .fv-img .bread-crumbs a:hover {
	opacity: 0.5;
}

#FV .sp {
	display: none;
}

#FV .fv-img h1 {
	position: absolute;
	top: 42%;
	left: 10.57%;
	word-break: keep-all;
	font-size: clamp(24px, 2.5vw, 48px)
}

#FV .fv-img h1::first-letter {
	color: #b1000e;
}

#FV nav {
	box-shadow: 0 0.156vw 0 #f5f5f5;
}

#FV nav .nav-ul-pc {
	display: block;
}

#FV nav .nav-ul-sp {
	display: none;
}

#FV nav .nav-ul-pc {
	width: 78.2%;
	height: 3.75vw;
	margin: 0 auto;
	display: flex;
	font-size: 1.2rem;
}

#FV nav .nav-ul-pc .nav-li {
	width: 33.3%;
	border-left: 0.052vw solid #f5f5f5;
	display: flex;
}

#FV nav .nav-ul-pc .nav-li li {
	border-bottom: 3px solid transparent;
}

#FV nav .nav-ul-pc .nav-li a {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	border-bottom: 3px solid #fff;
}

#FV nav .nav-ul-pc .nav-li a img {
	position: absolute;
	left: 0.052vw;
	margin-left: 1.042vw;
	width: 1.198vw;
	aspect-ratio: 1/1;
}

#FV nav .nav-ul-pc .nav-li a p {
	font-size: 0.833vw;
	font-weight: bold;
	line-height: 1.2vw;
	text-align: center;
}

#FV nav .nav-ul-pc .nav-li a p span {
	font-size: 0.781vw;
}

#FV nav .nav-ul-pc .nav-li:last-child {
	border-right: 0.052vw solid #f5f5f5;
}

#FV .fv-description {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin: 2.188vw 0;
	text-align: center;
}

#FV .fv-description p {
	font-size: 1.094vw;
	width: 80%;
	margin: 0 auto;
	line-height: 2.083vw;
}

#FV .fv-description img {
	margin: 1.771vw 0;
	width: 35%;
	height: auto;
	aspect-ratio: 1672/1636;
}

#FV nav .nav-ul-pc .nav-li a img {
	position: absolute;
	top: 1vw;
	left: 12vw;
	margin-left: 1.042vw;
	width: 1vw;
	aspect-ratio: 1/1;
}

.nav-ul-pc .nav-li a:hover img {
	opacity: 0;
}

.nav-ul-pc .nav-li a:hover {
	border-bottom: 3px solid #d70000 !important;
}

#FV .fv-img {
	background-image: url(../image/about/about_kv.webp);
}

@media screen and (max-width: 768px) {
	#FV .fv-img {
		position: relative;
		background-image: url(../image/about/about_kv.webp);
		/* width: 119%; */
		width: 100%;
		overflow: hidden;
		/* 枠からはみ出した部分を隠す */
		object-fit: cover;
		object-position: 50% 50%;
		/* 画像の中心を基準に表示 */
		background-repeat: no-repeat;
		/* 画像の繰り返しをしない */
		height: auto;
		aspect-ratio: 480/111;
	}

	#FV .fv-img .bread-crumbs {
		position: absolute;
		top: -5px;
		left: 4.57%;
		font-size: 2.5vw;
	}

	#FV .fv-img .bread-crumbs a {
		text-decoration: underline;
		text-underline-offset: 6px;
		padding-bottom: 2px;
		transition: all 0.3s;
	}

	#FV .fv-img .bread-crumbs a:hover {
		opacity: 0.5;
	}

	#FV .sp {
		display: block;
	}

	#FV .fv-img h1 {
		position: absolute;
		top: 30%;
		left: 3.9%;
		word-break: keep-all;
		/* font-size: 39.5px; */
		font-size: 5.5vw;
	}

	#FV .fv-img h1::first-letter {
		color: #b1000e;
	}

	#FV nav {
		box-shadow: 0 3px 0 #f5f5f5;
	}

	#FV nav .nav-ul-pc {
		display: none;
	}

	#FV nav .nav-ul-sp {
		display: block;
		/* width: 78.2%; */
		width: 100%;
		/* height: 72px; */
		/* height: 15.5vw; */
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
		padding-block: 0.8rem;
		font-size: 1rem;
	}

	#FV nav .nav-ul-sp .nav-li {
		width: 33.3%;
		border-left: 1px solid #f5f5f5;
	}

	#FV nav .nav-ul-sp .nav-li a {
		/* position: relative; */
		display: flex;
		flex-direction: row-reverse;
		justify-content: center;
		align-items: center;
		gap: 5%;
	}

	#FV nav .nav-ul-sp .nav-li a img {
		/* position: absolute; */
		left: 44%;
		/* bottom: -3.4vw; */
		bottom: -1.6vw;
		/* margin-left: 20px; */
		width: 2vw;
		aspect-ratio: 1 / 1;
		margin-bottom: 1vw;
	}

	#FV nav .nav-ul-sp .nav-li a p {
		/* font-size: 16px; */
		font-size: 1.14rem;
		font-weight: bold;
		line-height: 1.2rem;
		text-align: center;
		margin-bottom: 1vw;
	}

	#FV nav .nav-ul-sp .nav-li a p span {
		/* font-size: 2.6vw;
		line-height: 2.3rem; */
		font-size: 2.6vw;
		line-height: 1;
	}

	#FV nav .nav-ul-sp .nav-li:hover {
		background-color: #b1000e;

		a {
			color: #fff;
		}
	}

	/* #FV nav .nav-ul-pc .nav-li a:hover {
        color: initial !important;
        background-color: initial !important;
    } */
	#FV nav .nav-ul-sp .nav-li:last-child {
		border-right: 1px solid #f5f5f5;
	}

	#FV .fv-description {
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		/* margin: 42px 0; */
		/* margin: 35px 0; */
		margin: 18px 0;
		text-align: center;
		padding: 0 3.8%;
	}

	#FV .fv-description p {
		font-size: 21px;
		/* width: 80%; */
		width: 100%;
		margin: 0 auto;
		line-height: 40px;
		text-align: justify;
	}

	#FV .fv-description img {
		/* margin: 34px 0;
		width: 35%; */
		/* margin: 16px 0; */
		margin: 1vw 0 4vw 0;
		width: 61%;
		height: auto;
		aspect-ratio: 1672/1636;
	}

	.pc {
		display: none;
	}

}

/* ーーーーーー
中のコンテンツのCSS
ーーーーーーーー */
.about__wrapper {
	max-width: 1080px;
	width: 90%;
	margin-inline: auto;
	letter-spacing: 0.05em;
	padding-inline: 20px;
	padding-top: 7.18vw;
}

#area {
	margin-bottom: 60px;
}

#mission {
	margin-bottom: 100px;
}

.area-img {
	width: 44%;
}

.about-subtitle {
	font-size: 1.5rem;
	color: #006d79;
	line-height: 1.33;
	font-weight: 500;
	margin-bottom: 30px;
}

.area-wrapper,
.mission-top {
	display: flex;
	align-items: flex-start;
	gap: 4%;
}

.mission-top img {
	aspect-ratio: 550 / 340;
	object-fit: contain;
	width: 43%;
}

.about__border {
	background-color: #e2e2e2;
	max-width: 1250px;
	height: 1px;
	margin-block: 40px;
}

.about-title img {
	margin-right: 20px;
}

.about-title span {
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 0.9;
}

.about__text {
	font-family: "Noto Sans JP", sans-serif;
	/* font-size: clamp(10px, 1.1vw, 24px); */
	font-size: 1rem;
	font-weight: 400;
	line-height: 2;
}

#about__vision {
	margin-bottom: 8vw;
}

.about__slogan--copy {
	color: #006d79;
	font-weight: var(--weight-medium);
	/* font-size: clamp(10px, 2vw, 48px); */
	font-size: 2rem;
	line-height: 1.3;
	margin-bottom: 133px;
}

.about__slogan--copy br {
	display: none;
}

#about__value,
#about__branch,
#about__history {
	margin-bottom: 9vw;
}

#about__branch h4 {
	margin-bottom: min(2.5vw, 40px);
}

.about__branch--title {
	width: 12.5%;
}

.about__branch--head {
	display: block;
	background-color: #f1f1f1;
	color: #2f2f2f;
	padding: 15px 0 14px 30px;
	/* font-size: clamp(10px, 1.5vw, 24px); */
	font-size: 1.5rem;
	line-height: 1.08;
	font-weight: bold;
	margin-bottom: 40px;
}

.about__branch--list {
	padding-inline: 5px;
}

.about__branch--list li {
	display: flex;
	justify-content: flex-start;
	/* gap: 7.5vw; */
}

.about__branch--place {
	/* font-size: clamp(10px, 1.1vw, 24px); */
	font-size: 1rem;
	font-weight: bold;
	line-height: 2;
	width: 40%;
}

.about__branch--address {
	/* font-size: clamp(10px, 1.1vw, 24px); */
	font-size: 1rem;
	font-weight: 400;
	line-height: 2;
	color: #000;
	width: 60%;
}

.about__branch--link {
	font-size: clamp(10px, 0.8vw, 21px);
	line-height: 2.57;
}

.about__branch--to-map {
	border-bottom: 1px solid #000;
	padding-bottom: 5px;
}

.about__history--border {
	margin-bottom: 35px;
}

.about__history--list {
	list-style: none;
	/* font-size: clamp(10px, 1.1vw, 24px); */
	font-size: 1rem;
	line-height: 1.44;
}

.about__history--year {
	margin-right: 3.1vw;
}

.about__history--year,
.about__history--month {
	letter-spacing: 0.025em;
	font-weight: 600;
	color: #2f2f2f;
	flex-shrink: 0;
}

.about__history--event {
	font-weight: 400;
	letter-spacing: 0.05em;
	color: #000;
	margin-left: 7.5vw;
}

.about__history--list li {
	display: grid;
	/* grid-template-columns: 10% 5% 1fr; */
	grid-template-columns: 120px 50px 1fr;
}

.about__branch--link {
	margin-bottom: -5px;
}

/* --------
footer
-------- */



/* ーーーーーーーー
レスポンシブ
ーーーーーーーー */

@media screen and (max-width: 768px) {
	.about__wrapper {
		width: 100%;
		padding-inline: 3%;
	}
	.area-wrapper,
	.mission-top {
		flex-direction: column-reverse;
		gap: 4%;
	}

	.area-wrapper img {
		margin-bottom: 6%;
	}

	.area-img {
		width: 100%;
	}

	.mission-top img {
		width: 100%;
	}

	.mission-top-text img {
		margin-bottom: 6%;
	}

	.about__branch--list li {
		flex-direction: column;
	}

	.about__branch--list li {
		gap: 3vw;
	}

	.about__history--list li {
		display: grid;
		grid-template-columns: 20% 80%;
		grid-template-rows: auto auto;
		grid-template-areas:
		"year year"
		"month event";
	}
	
	.about__history--year {
		grid-area: year;
		margin-right: 0;
		margin-bottom: 3%;
	}
	
	.about__history--month {
		grid-area: month;
		margin-right: 0;
	}
	
	.about__history--event {
		grid-area: event;
		margin-left: 0;
	}

	.about-br-pc {
		display: none;
	}

	.about__border {
		margin-block: 5vw;
	}

	.about__slogan--copy br {
		display: block;
	}

	.about__branch--address {
		width: 100%;
	}

	.about__branch--place {
		width: 100%;
	}

}