@charset "UTF-8";

/* -------------------------------------------------- */
/* PC*/
/* -------------------------------------------------- */
/* メインビジュアル */
/* ------------------------------------ */

#mv {
	width: 100%;
	height: auto;
	aspect-ratio: 3 / 2;
	display: flex;
	position: relative;
	overflow: hidden;

	& #contWrap {
		width: 100%;
		height: 100%;
		position: absolute;
		z-index: 11;


		& #icCc {
			width: 25%;
			position: absolute;
			top: 1em;
			left: 4em;
		}

		& #icPre {
			width: 15%;
			position: absolute;
			top: 2em;
			right: 0;
		}

		& #icNum {
			width: 40%;
			position: absolute;
			bottom: 1em;
			right: 0;
		}

	}

	& #imgWrap,
	#imgWrap .swiper-container,
	#imgWrap .swiper-wrapper,
	#imgWrap .swiper-slide {
		width: 100%;
		height: 100%;
	}

	& #imgWrap img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center center;
	}
}


#mvSlide .sp-mask {
	border-radius: 8px;
}

.sp-slides-container {
	transition: all 0.3s ease 0s;
}

.mvSlideLink {
	display: block;
	position: relative;
}

.mvSlideLink img {
	width: 100%;
	height: auto;
}

/* 左右のレイヤー */
.mvSlideLink::before,
.mvSlideLink::after {
	content: "";
	width: 10%;
	height: 100%;
	display: block;
	position: absolute;
	top: 0;
	z-index: 1;
}

.mvSlideLink::before {
	left: 0;
	background: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.3)), to(rgba(0, 0, 0, 0)));
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0) 100%);
	border-radius: 8px 0 0 8px;
}

.mvSlideLink::after {
	right: 0;
	background: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.3)), to(rgba(0, 0, 0, 0)));
	background: linear-gradient(270deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0) 100%);
	border-radius: 0 8px 8px 0;
}

/* 左右の矢印 */
.sp-arrows {
	z-index: 2;
}

#mvSlide .sp-previous-arrow:before,
#mvSlide .sp-next-arrow:before {
	content: none;
}

#mvSlide .sp-previous-arrow:after,
#mvSlide .sp-next-arrow:after {
	width: 28px;
	height: 26px;
	top: 0;
	-webkit-transform: none;
	transform: none;
}

#mvSlide .sp-previous-arrow:after {
	left: 0;
	background: transparent url(../../img/common/icon_prev_white.svg) no-repeat center center/contain;
}

#mvSlide .sp-next-arrow:after {
	right: 0;
	background: transparent url(../../img/common/icon_next_white.svg) no-repeat center center/contain;
}

/* ナビゲーション */
.sp-button {
	width: 5px;
	height: 5px;
	margin: 4px 8px;
	border-color: #535353;
	background-color: #535353;
}

.sp-selected-button {
	border-color: #009843;
	background-color: #009843;
}

#mvSearch {
	display: none;
}

/* 賃貸物件を探す */
/* ------------------------------------ */
#topSearch {
	margin-bottom: 70px;
}

/* 新着賃貸物件 */
/* ------------------------------------ */
.newSlideItem {
	border: none;
}

.newListSlide {
	margin-bottom: 80px;
}


/* 新着情報 */
/* ------------------------------------ */
.topicsBodyWrap {
	padding: 20px 25px 25px;
	background-color: #ffffff;
}

.topicsList {
	margin-bottom: 30px;
}

.topicsWrap {
	margin-bottom: 80px;
}

/* サービス */
/* ------------------------------------ */
#service {
	margin-bottom: 70px;
	display: flex;
	flex-wrap: wrap;
	gap: 2.5em 1%;

	& .secTtl {
		width: 100%;
		margin-bottom: 0;
	}

	& .serviceTit {
		width: 100%;
		margin-bottom: 0.5em;
		position: relative;
		padding: 0.5em 0;
		background: #fff;
		color: #009843;
		border-bottom: 2px solid;
		font-size: clamp(1.6rem, 2.4vw, 2.4rem);
		font-weight: bold;
		text-align: center;
		letter-spacing: 0.1em;
	}

	& .serviceTit::after {
		content: "";
		position: absolute;
		bottom: -23px;
		left: 50%;
		transform: translateX(-50%);
		width: 0;
		height: 0;
		border-left: 14px solid transparent;
		border-right: 14px solid transparent;
		border-top: 23px solid #fff;
	}

	& .serviceTit::before {

		content: "";
		position: absolute;
		bottom: -26px;
		left: 50%;
		transform: translateX(-50%);
		width: 0;
		height: 0;
		border-left: 16px solid transparent;
		border-right: 16px solid transparent;
		border-top: 26px solid #009843;
	}
}

.serviceLink {
	width: 49.5%;
	min-height: 320px;
	position: relative;
	transition: all 0.3s ease 0s;
}

.serviceLinkInner {
	width: 100%;
	height: 100%;
	position: relative;
	display: flex;
	/* flex-direction: column; */
	justify-content: flex-end;
	color: #333333;
	background-color: #ffffff;
	border: 3px solid #009843;
	border-radius: 8px;
	position: relative;
	overflow: hidden;
	transition: all 0.3s ease 0s;
}

/* .serviceLinkInner.service2, .serviceLinkInner.service5 {
	justify-content: flex-start;
} */

.serviceLinkInner::after {
	content: "";
	width: 5.6em;
	height: 5.6em;
	display: block;
	border-radius: 50%;
	position: absolute;
	bottom: -2em;
	right: -2em;
	/* -webkit-transform: translateY(-50%); */
	/* transform: translateY(-50%); */
	/* background: transparent url(../../img/top/icon_arrow.png) no-repeat center center / contain; */
	background: #fefe00 url(../../img/common/icon_btn-arrow_green.svg) no-repeat top 1.5em left 1.5em / 1.5em auto;
	background: #fefe00 url(../../img/top/icon_arrow.svg) no-repeat top 1.6em left 1.6em / 1.2em auto;
	z-index: 5;
	-webkit-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
}

.serviceLink:last-child {
	margin-bottom: 0;
}

.serviceImgLabel {
	padding: 5px 8px;
	display: inline-block;
	position: absolute;
	bottom: 20px;
	background-color: #ffffff;
	font-size: 1.1rem;
	font-weight: bold;
	z-index: 2;
}

.serviceImgLabel span {
	font-weight: normal;
	font-size: 1.5rem;
	/* font-size: 1.7rem; */
}

/* 
.serviceLink:nth-child(odd) .serviceImgLabel {
	left: 40px;
} */

/* .serviceLink:nth-child(odd) .serviceBody {
	margin-left: auto;
} */

.serviceImgLabel {
	/* left: 58%; */
	left: 1em;
	bottom: 1em;
}

.service2 .serviceImgLabel, .service5 .serviceImgLabel {
	left: auto;
	right: 6em;
}

.serviceBody {
	width: 62%;
	/* padding: 20px; */
	padding: 30px 1em 0 1em;
	position: relative;
	z-index: 2;
}

.serviceBody>*:last-child {
	margin-bottom: 0;
}

.serviceTtlLabel {
	width: 90%;
	/* margin-bottom: -1em; */
	padding: 5px 0;
	color: #ffffff;
	background-color: #009843;
	border-radius: 30px;
	font-size: 2.2rem;
	font-weight: 600;
	line-height: 1.6;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	top: -1em;
	right: 1em;
	left: 1em;
	z-index: 1;
}

/* .service2 .serviceTtlLabel, .service5 .serviceTtlLabel {
	right: auto;
	left: 1em;
} */

.serviceTtl {
	margin-bottom: 10px;
	color: #333333;
	/* font-size: 2.6rem; */
	font-size: 1.8rem;
	line-height: 1.3;
	letter-spacing: 0.04em;
}

.serviceListWrap {
	margin-bottom: 0.6em;
}

.serviceList {
	display: inline-block;
}

.serviceList li {
	padding: 0px 0 10px 1.5em;
	position: relative;
	color: #009843;
	font-size: clamp(1.2rem, 1.2vw, 1.4rem);
	font-weight: 700;
	line-height: 1.2;
	text-align: left;
	counter-increment: number;
}

.serviceList li::before {
	content: counter(number);
	width: 15px;
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
	/* font-size: 3.2rem; */
	font-size: clamp(1.4rem, 1.5vw, 1.8rem);
	line-height: 1;
	text-align: center;
	font-family: "Pathway Gothic One", sans-serif;
	-webkit-transform: translateY(0.1em);
	transform: translateY(0.1em);
}

.serviceTxt {
	width: 100%;
	margin-bottom: 10px;
}

.serviceDetailList {
	width: 100%;
	/* margin-bottom: -9px; */
	display: flex;
	flex-wrap: wrap;
}

.serviceDetailList li {
	/* width: calc(33.3% - 6px); */
	width: 100%;
	height: 2em;
	/* margin-right: 9px; */
	margin-bottom: 0.5em;
	padding: 4px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: clamp(1.0rem, 1.1vw, 1.2rem);
	font-weight: 700;
	letter-spacing: 0;
}

.serviceDetailList li:nth-child(3n) {
	margin-right: 0;
}

.serviceDetail {
	background-color: #ffff00;
	border: 1px solid #1b1b1b;
	border-radius: 6px;
}

.service1 .serviceDetail {
	max-width: 400px;
	/* height: 74px; */
	height: 3.6em;
	display: flex;
	justify-content: center;
	align-items: center;
}

.service1 .serviceDetail span {
	height: 100%;
	/* padding-left: 100px; */
	padding-left: 5em;
	display: flex;
	align-items: center;
	position: relative;
	font-size: 1.4rem;
	line-height: 1.4;
	font-weight: 700;
}

.service1 .serviceDetail span::before {
	content: "";
	width: 54px;
	height: 60px;
	display: inline-block;
	position: absolute;
	left: 0;
	bottom: 0;
	background: transparent url(../../img/top/service_illust01.png) no-repeat center center/contain;
}

.serviceDetailBottom {
	width: 100%;
	margin-top: -0.5em;
	font-size: 1.2rem;
	text-align: right;
}

.serviceMessageHead {
	margin-bottom: 20px;
	font-size: 2.6rem;
	line-height: 1.33;
}

.serviceMessageHead .position {
	font-size: 1.6rem;
}

.serviceMessageTxt {
	width: 91%;
	line-height: 1.7;
}

/* 個別の背景・写真設定 */
.serviceLinkInner::before {
	content: "";
	width: 300px;
	height: 420px;
	position: absolute;
	bottom: 0;
	-webkit-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
}

a.service1 .serviceLinkInner {
	background: #ffffff url(../../img/top/service_bg01.png) no-repeat bottom left/64.8%;
}

a.service1 .serviceLinkInner::before {
	width: 168px;
	height: 290px;
	left: 0;
	background: transparent url(../../img/top/service_person01.png) no-repeat bottom center/contain;
}

a.service2 .serviceLinkInner {
	/* padding-top: 1em; */
	background: #ffffff url(../../img/top/service_bg02.png) no-repeat bottom right/60.6%;
	justify-content: flex-start;
}

a.service2 .serviceLinkInner::before {
	width: 150px;
	height: 300px;
	right: 0.5em;
	bottom: -1em;
	background: transparent url(../../img/top/service_person06.png) no-repeat bottom center / contain;

}

a.service2 .serviceLinkInner .serviceBody {
	width: 62%;
}

a.service3 .serviceLinkInner {
	background: #ffffff url(../../img/top/service_bg03.png) no-repeat top left/46.1%;
}

a.service3 .serviceLinkInner::before {
	width: 152px;
	height: 288px;
	left: 0.5em;
	background: transparent url(../../img/top/service_person03.png) no-repeat bottom center/contain;
}

a.service4 .serviceLinkInner {
	padding-top: 40px;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	background: #ffffff url(../../img/top/service_bg04.png) no-repeat bottom right/51%;
}

a.service4 .serviceLinkInner::before {
	width: 250px;
	height: 440px;
	right: 8%;
	background: transparent url(../../img/top/service_person04.png) no-repeat bottom center/contain;
}

.service5 .serviceLinkInner {
	justify-content: flex-start;
	align-items: center;
	background: #ffffff url(../../img/top/service_bg05.png) no-repeat center right 5%/230px;
	font-size: 1.4rem;

	& .serviceBody {
		width: 68%;
		padding-top: 0;
		display: flex;
		flex-direction: column;
		gap: 0.5em 0;
		align-items: flex-start;

		& a {
			width: 90%;
			padding: 0.5em 0;
			display: inline-block;
			color: #009843;
			background: #fefe00 url(../../img/common/icon_btn-arrow_green.svg) no-repeat center right 1em / 1.3em auto;
			background-size: 1em;
			border-radius: 30px;
			-webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
			box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
			font-size: clamp(1.2rem, 1.2vw, 1.5rem);
			font-weight: 700;
			text-align: center;
			transition: all 0.3s ease 0s;
		}

		& a:nth-child(2) {
			margin-bottom: 1em;
		}


		& a:hover {
			-webkit-box-shadow: none;
			box-shadow: none;
			-webkit-transform: translate(4px, 4px);
			transform: translate(4px, 4px);
		}
	}
}

.service5 .serviceLinkInner::before {
	width: 154px;
	height: 290px;
	right: -0.5em;
	background: transparent url(../../img/top/service_person04.png) no-repeat bottom center/contain;
}

.service5 .serviceLinkInner::after {
	content: none;
}


.serviceDetailImg {
	display: none;
}

/* 採用情報 */
/* ------------------------------------ */
#recruit {
	margin-bottom: 30px;
}

#topRecruitImg a {
	display: block;
	-webkit-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
}

#topRecruitImg img {
	width: 100%;
}

/* add 20250510 */
#areaMap {
	padding-bottom: 30px;
}

#areaMap img {
	width: 100%;
	height: auto;
}

.searchArea {
	padding: 20px;
	border-radius: 10px;
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	border: 2px solid #dcdcdc;
}

.searchArea a {
	color: #009843;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	font-size: 1.5rem;
	gap: 3px;
}

.searchArea a:hover {
	text-decoration: underline;
}


.searchArea a.fukuoka {
	color: #5ca90a;
}

.searchArea a.kasuga {
	color: #a90c4a;
}

.searchArea a.onojo {
	color: #0650ac;
}

.searchArea a.dazaifu {
	color: #026341;
}

.searchArea a.chikushino {
	color: #321484;
}

.searchArea a.nakagawa {
	color: #0094bc;
}

.searchArea a.ogori {
	color: #0008ad;
}

.searchArea a.kasuya {
	color: #bf5600;
}

.searchArea.num a::before {
	content: attr(data-num);
	width: 18px;
	height: 18px;
	color: #FFF;
	background: #009843;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	border-radius: 100vw;
	font-size: 1rem;
	font-weight: bold;
	letter-spacing: 0;
}

.searchArea.num a.fukuoka::before {
	background: #5ca90a;
}

.searchArea.num a.kasuga::before {
	background: #a90c4a;
}

.searchArea.num a.onojo::before {
	background: #0650ac;
}

.searchArea.num a.dazaifu::before {
	background: #026341;
}

.searchArea.num a.chikushino::before {
	background: #321484;
}

.searchArea.num a.nakagawa::before {
	background: #0094bc;
}

.searchArea.num a.ogori::before {
	background: #0008ad;
}

.searchArea.num a.kasuya::before {
	background: #bf5600;
}

/* MV */
#mv {
	margin-bottom: 40px;
}

.sp-buttons {
	width: auto;
	text-align: center;
	padding-top: 0;
	position: absolute;
	bottom: 0;
	left: 50%;
	-webkit-transform: translate(-50%, 0);
	transform: translate(-50%, 0);
}

#fvBnr .secTtl {
	text-align: center;
}

/* BnrBtn */
#fvBnr {
	padding-bottom: 70px;
}

.bnrWrap {
	margin-bottom: 0;
}

#bnrAreaLinkBtn.sp {
	display: none;
}

/* -------------------------------------------------- */
/* PC調整 */
/* -------------------------------------------------- */
@media screen and (min-width: 1025px) and (max-width: 1279px) {
	/* .serviceLink:not(.service1) .serviceBody {
		width: 60%;
	} */

	/* .serviceList li {
		font-size: 1.5rem;
	}

	.serviceList li::before {
		font-size: 2.8rem;
	} */

	.serviceImgLabel .spbr {
		display: block;
	}

	.serviceDetailList li {
		font-size: 1rem;
	}

	.serviceLink.service1 {
		background-position: bottom left -100%;
		background-size: 75%;
	}

	/* .serviceImgLabel {
		font-size: 1.3rem;
	} */

	a.service2::before, .service5::before {
		right: -1.5em;
	}
}

/* ------------------------------------ */
/* ホバーエフェクト */
/* ------------------------------------ */
@media screen and (min-width: 1025px) {
	#mvSlide .sp-slides-container:hover {
		opacity: 0.7;
	}

	a.serviceLink .serviceLinkInner:hover::before {
		-webkit-transform: scale(1.02) translateY(-1%);
		transform: scale(1.02) translateY(-1%);
	}

	a.serviceLink .serviceLinkInner:hover::after {
		transform: scale(1.3);
	}

	#topRecruitImg a:hover {
		opacity: 0.7;
	}
}

/* -------------------------------------------------- */
/* PC調整 */
/* -------------------------------------------------- */
@media screen and (min-width: 1025px) and (max-width: 1120px) {
	.serviceBody {
		width: 66%;
	}

	a.service1::before {
		width: 160px;
		height: 274px;
	}

	a.service3::before {
		width: 150px;
		height: 280px;
		left: 0;
	}

	a.service2::before {
		width: 150px;
		height: 298px;
		right: -0.5em;
	}

	.service5::before {
		width: 160px;
		height: 300px;
		right: -1em;
	}
}

/* -------------------------------------------------- */
/* TAB&SP */
/* -------------------------------------------------- */
@media screen and (max-width: 1024px) {
	.serviceListWrap {
		text-align: left;
	}
}

/* -------------------------------------------------- */
/* TAB(調整) */
/* -------------------------------------------------- */
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.serviceLink:not(.service1) .serviceBody {
		width: 60%;
	}

	/* .serviceTtlLabel {
		font-size: 1.2rem;
	} */

	/* .serviceTtl {
		font-size: 2.2rem;
	} */

	/* .serviceList li {
		font-size: 1.5rem;
	} */

	.serviceLink.service5 {
		background-position: center right 100px;
	}
}

/* -------------------------------------------------- */
/* SP(調整) */
/* -------------------------------------------------- */
@media screen and (max-width: 767px) {

	/* メインビジュアル */
	/* ------------------------------------ */
	#mv, #mvSearch {
		width: 100vw;
		margin: 0 calc(50% - 50vw) 0;
		border-radius: 0;
	}

	#mv {
		height: auto;
		aspect-ratio: 7/6;

		& #contWrap {

			& #icCc {
				width: 30%;
				top: 0;
				left: 1em;
			}

			& #icPre {
				width: 20%;
				top: 1em;
			}

			& #icNum {
				width: 60%;
			}
		}

		& #imgWrap {
			width: 100%;
			height: 100%;

			& img {
				width: 100%;
				height: 100%;
				object-fit: cover;
			}

		}
	}

	.topFadeSlider {
		width: 100%;
		height: 100%;
	}

	.topFadeSlider img {
		width: 100%;
		display: block;
	}

	.mvSlideLink::before {
		border-radius: 6px 0 0 6px;
	}

	.mvSlideLink::after {
		border-radius: 0 6px 6px 0;
	}

	#mvSlide .sp-mask {
		border-radius: 0;
	}

	#mvSlide .sp-previous-arrow:after,
	#mvSlide .sp-next-arrow:after {
		width: 20px;
		height: 18px;
	}

	.sp-horizontal .sp-previous-arrow {
		left: 10%;
	}

	.sp-horizontal .sp-next-arrow {
		right: 10%;
	}

	.sp-button {
		margin: 4px 12px;
	}

	#mvSearch {
		display: block;
		margin-bottom: 30px;
		padding: 1em 0 1.5em;
		background: #009843;
		color: #fff;
		text-align: center;

		& p {
			margin-bottom: 0.5em;
		}
	}

	/* バナーリスト */
	/* ------------------------------------ */
	#bannerList {
		width: 100vw;
		margin: 0 -15px 30px;
	}

	.bannerListSlide {
		margin-bottom: 8px !important;
	}

	/* 賃貸物件を探す */
	/* ------------------------------------ */
	#topSearch {
		margin-bottom: 30px;
	}

	/* サービス */
	/* ------------------------------------ */
	#service {
		margin-bottom: 50px;

		& .secTtl {
			margin-bottom: -0.5em;
			text-align: center;
		}

		& .serviceTit::after {
			content: "";
			position: absolute;
			bottom: -17px;
			right: 3.12em;
			left: auto;
			/* transform: translateX(-50%); */
			width: 0;
			height: 0;
			border-left: 7px solid transparent;
			border-right: 7px solid transparent;
			border-top: 20px solid #fff;
		}

		& .serviceTit::before {
			content: "";
			position: absolute;
			bottom: -22px;
			left: auto;
			right: 3em;
			/* transform: translateX(-50%); */
			width: 0;
			height: 0;
			border-left: 8px solid transparent;
			border-right: 8px solid transparent;
			border-top: 22px solid #009843;
		}
	}

	.serviceLink {
		min-height: 220px;
		/* margin-bottom: 40px; */
	}

	/* a.serviceLink::after {
		width: 1.5em;
		height: 1.5em;
		top: 50%;
		bottom: 50%;
		right: 0.5em;
	} */

	.serviceLinkInner::after {
		width: 4.0em;
		height: 4.0em;
		top: 50%;
		right: -2em;
		background: #fefe00 url(../../img/top/icon_arrow.svg) no-repeat center left 1.0em / 0.8em auto;
		transform: translateY(-50%);
	}

	.serviceBody {
		padding: 2em 2.5em 1em 1em;
	}

	.serviceImgLabel {
		font-size: 0.7rem;
		letter-spacing: 0;
	}

	.serviceImgLabel span {
		font-size: 1rem;
	}

	/* .serviceLink:nth-child(odd) .serviceImgLabel {
		left: 10px;
	} */

	.serviceLink:nth-child(even) .serviceImgLabel {
		/* left: unset;
		right: 10px; */
	}

	/* .serviceLink.service3 .serviceImgLabel {
		bottom: 80px;
	} */

	.serviceTtlLabel {
		margin-bottom: 5px;
		padding: 4px 15px;
		font-size: 1.6rem;
	}

	.serviceTtl {
		font-size: 1.6rem;
	}

	.serviceListWrap {
		/* width: 80%; */
		margin-bottom: 1em;
	}

	.serviceList li {
		padding: 4px 0 4px 12px;
		/* font-size: 1rem; */
		letter-spacing: 0.01em;
	}

	.serviceList li::before {
		width: 10px;
		/* font-size: 1.4rem; */
		line-height: normal;
	}

	.serviceTxt {
		/* margin-bottom: 0; */
		font-size: 1rem;
		line-height: 1.3;
	}

	.serviceMessageHead {
		font-size: 1.5rem;
		margin-bottom: 10px;
	}

	.serviceMessageHead .position {
		font-size: 1.2rem;
	}

	.serviceMessageTxt {
		font-size: 1rem;
		line-height: 1.3;
		width: 100%;
	}

	a.service1 {
		background-size: 320px;
		background-position: bottom left -140px;
	}

	a.service1 .serviceLinkInner::before {
		width: 146px;
		height: 220px;
		left: 0;
		background: transparent url(../../img/top/service_person01_sp.png) no-repeat bottom center/contain;
	}

	a.service1 .serviceLinkInner .serviceBody {
		width: 60%;
	}

	.service1 .serviceLinkInner .serviceDetail {
		width: 100%;
		height: 40px;
		border-radius: 3px;
	}

	.service1 .serviceLinkInner .serviceDetail span {
		padding-left: 4.5em;
		font-size: 1.2rem;
		line-height: 1.14;
	}

	.service1 .serviceLinkInner .serviceDetail span::before {
		width: 46px;
		height: 50px;
	}

	a.service2 .serviceLinkInner {
		background-size: 250px;
		background-position: bottom right -80px;
	}

	a.service2 .serviceLinkInner::before {
		/*
		width: 140px;
		height: 250px;
		right: 3%;
		background: transparent url(../../img/top/service_person02_sp.png) no-repeat bottom center/contain;
*/
		width: 108px;
		height: 214px;
		right: 3em;
		bottom: 0;
		/* background: transparent url(../../img/top/service_person04_sp.png) no-repeat bottom center/contain; */
	}

	a.service2 .serviceLinkInner .serviceBody {
		width: 68%;
	}

	a.service3 .serviceLinkInner {
		background-size: 180px;
		background-position: top left -20px;
	}

	a.service3 .serviceLinkInner::before {
		width: 98px;
		height: 220px;
		left: 4%;
		bottom: -1em;
		background: transparent url(../../img/top/service_person03_sp.png) no-repeat bottom center/contain;
	}

	a.service3 .serviceTtl {
		font-size: 1.5rem;
	}

	a.service3 .serviceTtl span {
		font-size: clamp(1.2rem, 1.4vw, 1.5rem);
	}

	a.service3 .serviceLinkInner .serviceBody {
		width: 64%;
	}

	/* .serviceDetailList,
	.serviceDetailBottom {
		display: none;
	} */

	.serviceDetailImg {
		width: 260px;
		margin: 0 auto 15px;
		display: block;
		position: relative;
	}

	.serviceDetailImg img {
		max-width: 100%;
	}

	a.service4 .serviceLinkInner {
		padding-top: 0px;
		background-size: 250px;
		background-position: bottom right -50px;
	}

	a.service4 .serviceLinkInner::before {
		width: 123px;
		height: 270px;
		right: 8%;
		background: transparent url(../../img/top/service_person04_sp.png) no-repeat bottom center/contain;
	}

	a.service4 .serviceLinkInner .serviceBody {
		width: 62%;
	}

	.service5 .serviceLinkInner {
		padding-top: 0px;
		background-size: 140px;
		/*		background-position: center left -10px;*/
		background-position: center right 30px;
	}

	.service5 .serviceLinkInner::before {
		/*
		width: 122px;
		height: 250px;
		left: 2%;
		background: transparent url(../../img/top/service_person05_sp.png) no-repeat bottom center/contain;
*/
		width: 108px;
		height: 200px;
		right: 2em;
		/* background: transparent url(../../img/top/service_person05_sp.png) no-repeat bottom center/contain; */
	}

	.service5 .serviceLinkInner .serviceBody {
		width: 60%;
		padding: 1em;
	}

	.service2 .serviceImgLabel, .service5 .serviceImgLabel {
		right: 1em;
	}

	.newListSlide {
		margin-bottom: 60px;
	}

	/* 新着情報 */
	/* ------------------------------------ */
	.topicsBodyWrap {
		padding: 10px 10px 30px;
	}

	.topicsWrap {
		margin-bottom: 60px;
	}

	/* add20250510 */
	.searchArea {
		display: grid;
		grid-template-columns: 50% 1fr;
		padding: 5%;
	}

	.searchArea a {
		font-size: 1.4rem;
	}

	#bnrAreaLinkBtn {
		width: 100%;
	}

	#fvBnr {
		padding-bottom: 30px;
	}

	.bnrWrap {
		margin-bottom: 0;
	}


	#bnrAreaLinkBtn.sp {
		width: 100%;
		margin: 20px auto 10px;
		display: flex;
		/* flex-wrap: wrap; */
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
		gap: 1% 0;
	}

	#bnrAreaLinkBtn li {
		width: 49.5%;
	}


	#bnrAreaLinkBtn a.btnNarrow {
		padding: 0.6em 1em;
		font-size: 1.2rem;
	}

	#bnrAreaLinkBtn a {
		width: 100%;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 15px 10px;
		font-size: 1.2rem !important;
		background: #009843 url(../../img/common/icon_btn-arrow_white.svg) no-repeat center right 10px / 10px auto;
		color: #fff;
	}

}

@media screen and (max-width: 717px) {
	.serviceLink {
		width: 100%;
	}
}