@charset "utf-8";

/*  common
--------------------------------------------------*/
picture,figure{
	display: block;
	position: relative;
}
.page-img picture{
	width: 100%;
	height: 100%;
}

.sec__conts{
	padding-block: 0 13.5rem;
	position: relative;
}
.sec__conts:after{
	content: '';
	width: 100%;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	z-index: -1;
}
.sec__conts:nth-child(odd):after{
	background: #E8F2F2;
}
.sec__conts:nth-child(even):after{
	background: #E8EFE1;
}
.sec__unit{
	position: relative;
	margin-top: 15.0rem;
}

.sec__heading{
	width: 60%;
	margin-left: 0;
}
.sec__ttl{
	margin-left: 7.291666666%;
	font-size: clamp(3.8rem, 5.625vw, 10.8rem);
	color: #CCD8CE;
	letter-spacing: 0;
	line-height: 1;
}
.sec__subTtl{
	margin-left: 14.583333333%;
	font-size: clamp(1.8rem, 1.875vw, 3.6rem);
	color: #46886B;
	letter-spacing: .2em;
	letter-spacing: 1;
	margin-top: 3.0rem;
}
.sec__txt{
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: .3em;
	text-align: justify;
}
.sec__txt--large{
	font-size: 2.0rem;
}

.sec__mainPhoto{
	width: 72.916666666%;
	margin-left: 0;
	margin-top: 8.0rem;
	margin-bottom: 10.0rem;
}

.sec__card{
	width: 25.9375%;
	position: absolute;
	top: 0;
	right: 14.0625%;
	z-index: 1;
}
.sec__card--large{
	width: 36.354166666%;
}

.sec__detail{
	align-items: flex-start;
	flex-direction: row-reverse;
}
.sec__list--voice{
	width: 33.823529411%;
}
.sec__item--voice + .sec__item--voice{
	margin-top: 3.0rem;
}
.sec__col{
	width: 61.764705882%;
}

@media screen and (max-width: 768px){
	.sec__conts{
		padding-block: 0 6.0rem;
	}
	.sec__unit{
		margin-top: 6.0rem;
	}

	.sec__heading{
		width: 100%;
	}
	.sec__ttl{
		margin-left: auto;
		text-align: center;
	}
	.sec__subTtl{
		margin-left: auto;
		margin-top: 1.5rem;
		text-align: center;
	}
	.sec__txt{
		font-size: 1.4rem;
		letter-spacing: .2em;
	}
	.sec__txt--large{
		font-size: 1.5rem;
	}

	.sec__mainPhoto{
		width: 100%;
		margin-left: 0;
		margin-top: 3.0rem;
		margin-bottom: 0;
	}

	.sec__card{
		width: 100%;
		position: static;
		top: 0;
		right: 0;
		margin-bottom: 4.0rem;
	}
	.sec__card--large{
		width: 100%;
	}

	.sec__detail{
		display: block;
	}
	.sec__list--voice{
		width: 100%;
		margin-top: 4.0rem;
	}
	.sec__item--voice + .sec__item--voice{
		margin-top: 2.0rem;
	}
	.sec__col{
		width: 100%;
	}
}


/*  l-intro
--------------------------------------------------*/
#l-intro{
	position: relative;
	width: 100%;
	padding-block: 11.0rem 0;
}
.intro-heading{
	font-size: 3.2rem;
	line-height: 1.75;
	letter-spacing: .3em;
	text-align: center;
}

@media screen and (max-width: 768px){
	#l-intro{
		padding-block: 5.0rem 0;
	}
	.intro-heading{
		font-size: 2.0rem;
		width: 100%;
		letter-spacing: .2em;
	}
}


/*  l-voice
--------------------------------------------------*/
#l-voice{
	padding-block: 14.0rem 7.0rem;
}
.sec__unit--voice{
	margin-top: 0;
	background: #E8EFE1;
	padding-block: 10.0rem 12.0rem;
}
.voice__ttl{
	font-size: 3.0rem;
	letter-spacing: .2em;
	text-align: center;
}
.voice__list{
	margin-top: 5.0rem;
}
.voice__item{
	width: 31.617647058%;
}
.voice__item--large{
	width: 48.529411764%;
	margin-top: 3.5rem;
}
.sec__unit--point{
	margin-top: 0;
	padding-block: 10.0rem 0;
}
.sec__txt--point{
	text-align: center;
}
.point__list{
	margin: 0 auto;
	max-width: 800px;
	width: 100%;
	padding-block: 6.0rem 5.0rem;
}
.point__item{
	width: 100%;
	line-height: 60px;
	background: #E8EFE1;
	color: #085431;
	font-size: 2.8rem;
	letter-spacing: 0;
	text-align: center;
}
.point__item + .point__item{
	margin-top: 2.0rem;
}

@media screen and (max-width: 768px){
	#l-voice{
		padding-block: 5.0rem;
	}
	.sec__unit--voice{
		margin-top: 0;
		padding-block: 5.0rem 6.0rem;
	}
	.voice__ttl{
		font-size: 2.2rem;
	}
	.voice__list{
		margin-top: 3.0rem;
	}
	.voice__item{
		width: 100%;
	}
	.voice__item--large{
		width: 100%;
		margin-top: 0;
	}
	.voice__item + .voice__item{
		margin-top: 2.0rem;
	}
	.sec__unit--point{
		margin-top: 0;
		padding-block: 5.0rem 0;
	}
	.sec__txt--point.sec__txt--large{
		text-align: center;
	}
	.sec__txt--point{
		text-align: justify;
	}
	.point__list{
		padding-block: 3.0rem;
	}
	
	.point__item{
		line-height: 50px;
		font-size: 2.0rem;
	}
}


/*  l-security
--------------------------------------------------*/
#l-security.sec__conts:after{
	height: 25%;
}
.sec__photo--security{
	margin-top: 6.0rem;
}
@media screen and (max-width: 768px){
	#l-security.sec__conts:after{
		height: 12%;
	}
	.sec__photo--security{
		margin-top: 4.0rem;
	}
}


/*  l-facade
--------------------------------------------------*/
#l-facade.sec__conts:after{
	height: 48%;
}
.sec__photo--facade02{
	width: 33.823529411%;
}
.sec__photo--facade03{
	width: 64.705882352%;
}
.sec__detail--facade{
	align-items: center;
	margin-top: 8.0rem;
	margin-bottom: 8.0rem;
}
@media screen and (max-width: 768px){
	#l-facade.sec__conts:after{
		height: 48%;
	}
	.sec__photo--facade02{
		width: 100%;
	}
	.sec__photo--facade03{
		width: 100%;
		margin-top: 1.0rem;
	}
	.sec__detail--facade{
		margin-top: 4.0rem;
		margin-bottom: 4.0rem;
	}
}


/*  l-garden
--------------------------------------------------*/
#l-garden.sec__conts:after{
	height: 34%;
}
.sec__detail--garden{
	align-items: center;
}
.sec__photo--garden{
	margin-bottom: 6.0rem;
}
@media screen and (max-width: 768px){
	#l-garden.sec__conts:after{
		height: 12%;
	}
	.sec__detail--garden{
	}
	.sec__photo--garden{
		margin-bottom: 3.0rem;
	}
}


/*  l-bright
--------------------------------------------------*/
#l-bright.sec__conts:after{
	height: 32%;
}
.sec__photo--bright{
	margin-bottom: 6.0rem;
}
.sec__detail--bright{
	align-items: center;
}

.scroll-hint-icon{
	background: rgba(0, 0, 0, .4);
	width: 258px;
	height: 68px;
	border-radius: 34px;
	box-shadow: none;
}
.scroll-hint-icon-wrap.is-active .scroll-hint-icon{
	opacity: 1;
}
.scroll-hint-icon:after{
	background: url(../img/icon_scroll_arrow.svg) no-repeat center center/contain;
	width: 170px;
	height: 40px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	margin-left: 0;
}
.scroll-hint-icon:before{
	background: url(../img/icon_scroll_hand.svg) no-repeat center center/contain;
	width: 170px;
	height: 40px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.scroll-hint-text{
	display: none;
}
@keyframes scroll-hint-appear {
	0% {
		transform: translate(-40% ,-50%);
		opacity: 0;
	}
	10% {
		opacity: 1;
	}
	50%,
	100% {
		transform: translateX(-80% ,-50%);
		opacity: 0;
	}
}
@media screen and (max-width: 768px){
	#l-bright.sec__conts:after{
		height: 14%;
	}
	.sec__photo--bright{
		margin-bottom: 3.0rem;
	}
	.photo__scroll{
		overflow-x: scroll;
		margin-right: calc(50% - 50vw);
	}
	.photo__scroll img{
		height: 200px;
		width: auto !important;
	}
	.sec__detail--bright{
		align-items: center;
	}
}


/*  l-bicycle
--------------------------------------------------*/
#l-bicycle.sec__conts:after{
	height: 48%;
}
.sec__detail--bicycle{
	align-items: center;
}
@media screen and (max-width: 768px){
	#l-bicycle.sec__conts:after{
		height: 16%;
	}
}


/*  l-car
--------------------------------------------------*/
#l-car.sec__conts{
	padding-block: 0;
}
.sec__photo--car02{
	width: 61.764705882%;
}
.sec__col--car{
	width: 33.823529411%;
}
.sec__photo--car03{
	margin-top: 6.0rem;
}

.sec__unit--topic{
	padding-block: 10.0rem;
	background: #E8EFE1;
}
.sec__unit--topic{
	margin-top: 10.0rem;
}
.sec__ttl--topic{
	margin-left: 0;
	font-size: clamp(4.0rem , 3.6vw, 7.0rem);
	color: #CCD8CE;
	margin-bottom: 6.0rem;
}
.sec__detail--topic{
	flex-direction: row-reverse;
}
.sec__photo--topic{
	width: 44.117647058%;
}
.sec__col--topic{
	width: 51.470588235%;
}
.sec__list--topic{
	width: 100%;
	margin-top: 6.0rem;
}
@media screen and (max-width: 768px){
	#l-car.sec__conts{
		padding-block: 0;
	}
	.sec__detail--car{
	}
	.sec__photo--car02{
		width: 100%;
		margin-top: 4.0rem;
	}
	.sec__col--car{
		width: 100%;
		margin-top: 4.0rem;
	}
	.sec__photo--car03{
		margin-top: 4.0rem;
	}

	.sec__unit--topic{
		padding-block: 10.0rem;
		background: #E8EFE1;
	}
	.sec__unit--topic{
		margin-top: 6.0rem;
		padding-block: 5.0rem 6.0rem;
	}
	.sec__ttl--topic{
		margin-bottom: 3.0rem;
	}
	.sec__photo--topic{
		width: 90%;
		margin: 0 auto;
		margin-bottom: 3.0rem;
	}
	.sec__col--topic{
		width: 100%;
	}
	.sec__list--topic{
		width: 100%;
		margin-top: 4.0rem;
	}
}



.bnr-suumo {
	padding-block: 10.0rem;
}
.bnr-suumo__inner {
	max-width: 1080px;
}
@media screen and (max-width: 768px){
	.bnr-suumo {
		padding-block: 4.0rem;
	}
}