/* ----------------------------------------
	main_visual
-------------------------------------------*/

#main_visual{
	position: relative;
	width: 90%;
	margin: 8% auto 0;
}
.main_copy{
	z-index: 1;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	text-align: left;
}
.main_copy div p{
	display: inline;
	padding: 0 1.2%;
	font-size: 32px;
	line-height: 1.8;
	border-radius: 4px;
	letter-spacing: .1em;
	color: var(--brown);
	background-color: #fff;
}
.mv,
#main_visual .text_area{
	width: 92%;
	margin: 0 auto;
}
.mv{
	z-index: 0;
	padding-top: 12%;
}
.mv img{
	border-radius: 60px;
	object-fit: cover;
}
#main_visual .text_area{
	padding: 8% 0;
	display: flex;
	justify-content: space-between;
}
#main_visual .text_area .text{
	width: calc(100% - 350px);
	text-align: justify;
}

@media screen and (max-width: 960px){
	.main_copy{
		top: 52%;
	}
	.mv{
		padding-top: 16%;
	}
	.mv img{
		border-radius: 40px;
	}
	#main_visual .text_area{
		display: block;
		padding-bottom: 0;
	}
	#main_visual .text_area .text{
		width: 100%;
		padding: 8% 0;
	}
}
@media screen and (max-width: 768px){
	.main_copy{
		top: 48%;
	}
	
}
@media screen and (max-width: 650px){
	
	#main_visual{
		width: 92%;
		margin-top: 40%;
	}
	.main_copy{
		top: 38%;
		left: 2%;
	}
	.main_copy div p{
		font-size: 24px;
	}
	.mv,
	#main_visual .text_area{
		width: 100%;
	}
	.mv{
		padding-top: 0;
	}
	.mv img{
		width: 100%;
		height: auto;
		min-height: 260px;
		border-radius: 20px;
	}
	#main_visual .text_area{
		width: 92%;
	}
	#main_visual .text_area .text{
		padding: 8% 0;
		margin-top: 20%;
	}
}

/* loop */

.loop{
	position: relative;
}
.loop_text{
	display: flex;
	width: 100%;
}
.loop__item{
	flex: 0 0 auto;
	white-space: nowrap;
	overflow: hidden;
	font-size: 200px;
	line-height: 1;
	font-weight: bold;
	color: var(--bg-sub-color);
	font-family: var(--font-en);
	width: 1400px; /*文字幅に合わせる*/
}
.loop__item:nth-child(odd){
	animation: loop 50s -25s linear infinite;
}
.loop__item:nth-child(even){
	animation: loop2 50s linear infinite;
}
@keyframes loop{
	0%{
		transform: translateX(100%);
	}to{
		transform: translateX(-100%);
	}
}
@keyframes loop2{
	0%{
		transform: translateX(0%);
	}to{
		transform: translateX(-200%);
	}
}
@media screen and (max-width: 650px){
	
	.loop__item{
		font-size: 140px;
		width: 1000px; /*文字幅に合わせる*/
	}
}


/* ----------------------------------------
	intro
-------------------------------------------*/

#top_intro{
	width: 100%;
	color: #fff;
	background-color: var(--green);
	padding: 16% 0;
}
#top_intro .title{
	font-size: 28px;
	font-weight: bold;
}
#top_intro .list ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	row-gap: 20px;
	padding: 8% 0;
}
#top_intro .list ul li{
	position: relative;
	width: 32%;
	border-radius: 20px;
	background-color: #fff;
}
#top_intro .list ul li .num{
	position: absolute;
	top: 0;
	left: 0;
	width: 70px;
	height: auto;
}
#top_intro .list ul li .icon{
	width: 52%;
	margin: 0 auto;
	padding-top: 8%;
}
#top_intro .list .text_area{
	width: 90%;
	margin: 0 auto;
	padding-bottom: 12%;
}
#top_intro .list .text_area .title{
	font-size: 20px;
	line-height: 2.4;
	font-weight: bold;
	color: var(--brown);
}
#top_intro .list .text_area .text{
	font-size: 14px;
	line-height: 1.6;
	color: var(--text-color);
}

@media screen and (max-width: 650px){
	
	#top_intro{
		padding: 28% 0;
	}
	#top_intro .title{
		font-size: 20px;
	}
	#top_intro .list ul li{
		width: 48%;
		border-radius: 10px;
	}
	#top_intro .list ul li .num{
		width: 50px;
	}
	#top_intro .list ul li .icon{
		padding-top: 20%;
	}
	#top_intro .list .text_area .title{
		font-size: 16px;
	}
	#top_intro .list .text_area .text{
		font-size: 12px;
	}
	#top_intro .text br{
		display: none;
	}
}


/* ----------------------------------------
	top_bnr_area
-------------------------------------------*/

.top_bnr_area{
	width: 100%;
	background-color: var(--sub-green);
}
.top_bnr_area ul{
	width: 90%;
	margin: 0 auto;
	padding: 8% 0;
	display: flex;
	justify-content: space-between;
}
.top_bnr_area ul li{
	width: 48%;
	overflow: hidden;
	border-radius: 20px;
	background-color: #fff;
}
.top_bnr_area ul li a{
	display: block;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 4%;
}
.top_bnr_area ul li a .text{
	width: 60%;
	padding-left: 4%;
	font-size: 16px;
	text-align: left;
	font-weight: bold;
}
.top_bnr_area ul li a .button__label{
	padding-right: 16%;
	background: url(../img/common/ic_circle_arrow_green.svg) right center / 20px auto no-repeat;
}
.top_bnr_area ul li a .img{
	width: 40%;
	text-align: right;
}
.top_bnr_area ul li a img{
	width: 120px;
	height: 120px;
	border-radius: 10px;
}
.top_bnr_area ul li a:hover img{
	opacity: 1;
}
.top_bnr_area ul li a:hover{
	background-color: var(--bg-sub-color);
}

@media screen and (max-width: 960px){
	
	.top_bnr_area ul{
		width: 100%;
	}
}
@media screen and (max-width: 650px){
	
	.top_bnr_area ul{
		width: 90%;
		padding: 16% 0;
		flex-wrap: wrap;
		row-gap: 16px;
	}
	.top_bnr_area ul li{
		width: 100%;
		border-radius: 10px;
	}
	.top_bnr_area ul li a{
		padding: 2%;
	}
	.top_bnr_area ul li a img{
		width: 100px;
		height: 100px;
	}
	.top_bnr_area ul li a .text{
		font-size: 14px;
	}
	.top_bnr_area ul li a .button__label{
		padding: 1% 0;
		padding-right: 16%;
	}
}

/* ----------------------------------------
	top_news
-------------------------------------------*/

#top_news,
#top_event{
	width: 100%;
	padding: 16% 0;
}
#top_news h2,
#top_event h2{
	font-size: 28px;
	text-align: left;
}
#top_news ul,
#top_event ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 8% 0;
}
#top_news li,
#top_event li{
	display: flex;
	flex-direction: column;
	text-align: justify;
}
#top_news li{
	width: 48%;
}
#top_news li a,
#top_event li a{
	flex-grow: 1;	/*縦の比率を揃えて高さを合わせる*/
	display: flex;
	flex-direction: column;
	font-weight: bold;
}
#top_news li a{
	border-bottom: 1px solid;
	border-color: var(--bg-sub-color);
}
#top_news li a:hover,
#top_event li a:hover{
	opacity: var(--hover);
}
#top_news li a .head,
#top_event li a .head{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	column-gap: 20px;
	font-size: 14px;
	line-height: 1.8;
}
#top_news li a .head .cat,
#top_event li a .head .cat{
	color: var(--green);
}
#top_news li a .tit,
#top_event li a .tit{
	flex-grow: 1;	/*縦の比率を揃えて高さを合わせる*/
	padding: 4% 0;
	transition: .2s;
}
#top_news .more_link a,
#top_event .more_link a{
	margin: 0 0 0 auto;
}
#top_news .more_link a:hover,
#top_event .more_link a:hover{
 background-color: var(--sub-green);
}
#top_event{
	background-color: var(--bg-sub-color);
}
#top_event li{
	width: 22%;
}
#top_event li a .photo{
	width: 100%;
	height: auto;
	margin-top: 4%;
}
#top_event li a .photo img{
	object-fit: cover;
	width: 100%;
	height: 124px;
	border-radius: 8px;
	background-color: #fff;
}
#top_event li a:hover img{
	opacity: 1;
}

@media screen and (max-width: 960px){
	#top_event ul{
		row-gap: 40px;
	}
	#top_event li{
		width: 48%;
	}
	#top_event li a .photo img{
		height: 200px;
	}
}
@media screen and (max-width: 650px){
	
	#top_news,
	#top_event{
		padding: 28% 0;
	}
	#top_news h2,
	#top_event h2{
		font-size: 20px;
	}
	#top_news li,
	#top_event li{
		width: 100%;
		margin-bottom: 4%;
	}
	#top_news li a .head,
	#top_event li a .head{
		font-size: 13px;
	}
	#top_event li a{
		flex-wrap: wrap;
		flex-direction: row;
		justify-content: space-between;
	}
	#top_event li a .head{
		width: 100%;
	}
	#top_event li a .tit{
		flex-grow: initial;
		width: 58%;
	}
	#top_event li a .photo{
		width: 36%;
		margin-top: 0;
	}
	#top_event li a .photo img{
		object-fit: contain;
		width: 100%;
		height: auto;
		max-height: 120px;
		border-radius: 4px;
		background-color: var(--bg-sub-color);
		border: 1px solid;
		border-color: var(--beige);
	}
}

/* ----------------------------------------
	top_article_area
-------------------------------------------*/

#top_article_area .sec{
	padding: 16% 0;
}
#top_article_area .sec:nth-child(even){
	background-color: var(--bg-sub-color);
}
#top_article_area .sec h3{
	font-size: 28px;
	line-height: 1.6;
	padding-bottom: 8%;
	color: var(--green);
}
#top_article_area .sec .article_wrap{
	display: flex;
	justify-content: space-between;
}
#top_article_area .sec .article_wrap .text_area{
	width: 52%;
	text-align: justify;
}
#top_article_area .sec .article_wrap .img_area{
	display: flex;
	flex-direction: column;
	row-gap: 4%;
	width: 44%;
}
#top_article_area .sec .article_wrap .img_area img{
	width: 100%;
	border-radius: 20px;
}

.compare_list ul{
	display: flex;
	justify-content: space-between;
}
.compare_list li .head{
	font-weight: bold;
	padding: 2%;
	border-radius: 8px;
}
.compare_list li .img{
	padding: 8% 0;
}
.compare_list li img{
	width: 100%;
	border-radius: 10px;
}
.compare_list li dl{
	text-align: justify;
}
.compare_list li dt{
	line-height: 1.6;
	font-weight: bold;
	text-align: center;
	padding-bottom: 4%;
}
.compare_list li dd{
	font-size: 14px;
	padding-bottom: 12%;
}
.compare_list li.outdoor{
	width: 50%;
	padding-right: 5%;
	border-right: 1px dashed;
	border-color: var(--bg-sub-color);
}
.compare_list li.outdoor .head{
	color: var(--brown);
	background-color: #fff;
}
.compare_list li.outdoor dt{
	color: var(--brown);
}
.compare_list li.noufukudo{
	width: 45%;
}
.compare_list li.noufukudo .head{
	color: #fff;
	background-color: var(--green);
}
.compare_list li.noufukudo dt{
	color: var(--green);
}
.feature .text_area{
	width: 90%;
	margin: 0 auto;
}
.feature .point{
	padding: 8% 0;
}
.feature .point ul{
	display: flex;
	justify-content: space-between;
}
.feature .point li{
	position: relative;
	width: 32%;
	padding: 20px;
	border-radius: 12px;
	background-color: var(--bg-color);
}
.feature .point li .num{
	position: absolute;
	top: 0;
	left: 0;
	width: 70px;
}
.feature .point li .img img{
	border-radius: 12px;
}
.feature .point li .text_box{
	line-height: 1.8;
	padding: 12% 0;
}
.feature .point li .text_box .tit{
	font-weight: bold;
	color: var(--brown);
	padding-bottom: 8%;
	letter-spacing: .15em;
}
.feature .point li .text_box .text{
	font-size: 14px;
	text-align: justify
}
.taste h4{
	text-align: left;
	font-size: 24px;
	color: var(--brown);
}
.taste h4 span{
	display: inline-block;
	border-bottom: 1px solid;
	border-color: var(--brown);
}
.taste p{
	padding: 8% 0;
	text-align: justify;
}
.taste .brand{
	display: flex;
	align-item: center;
	justify-content: space-between;
	padding: 4%;
	border-radius: 20px;
	border: 4px solid;
	border-color: var(--green);
	background-color: #fff;
}
.taste .brand .text_area{
	width: 56%;
}
.taste .brand .text_area .title{
	font-size: 24px;
	padding: 0 0 4%;
	font-weight: bold;
	color: var(--green);
}
.taste .brand .text_area .list dl{
	display: flex;
	justify-content: space-between;
	padding: 2% 0;
	text-align: left;
	border-bottom: 1px dashed;
	border-color: var(--bg-sub-color);
}
.taste .brand .text_area .list dt{
	width: 40%;
}
.taste .brand .text_area .list dd{
	width: 60%;
}
.taste .brand .img_area{
	width: 40%;
}
.taste .brand .img_area img{
	width: 100%;
	object-fit: cover;
}

@media screen and (max-width: 768px){
	
	.feature .point ul{
		flex-wrap: wrap;
		row-gap: 28px;
	}
	.feature .point li{
		display: flex;
		justify-content: space-between;
		width: 100%;
		padding: 4%;
		border-radius: 12px;
	}
	.feature .point li .img{
		width: 40%;
	}
	.feature .point li .img img{
		width: 100%;
		border-radius: 12px;
	}
	.feature .point li .text_box{
		width: 56%;
		padding: 0;
		text-align: justify
	}
	.feature .point li .text_box .tit{
		padding-bottom: 4%;
	}
	.taste .brand{
		flex-direction: column;
		row-gap: 40px;
		padding: 4% 8% 8%;
	}
	.taste .brand .text_area{
		width: 100%;
	}
	.taste .brand .text_area .list dl{
		padding: 1% 0;
	}
	.taste .brand .text_area .list dt{
		width: 32%;
	}
	.taste .brand .text_area .list dd{
		width: 68%;
	}
	.taste .brand .img_area{
		width: 90%;
		margin: 0 auto;
	}
}

@media screen and (max-width: 650px){
	
	#top_article_area .sec{
		padding: 28% 0;
	}
	#top_article_area .sec h3{
		font-size: 20px;
	}
	#top_article_area .sec .article_wrap{
		flex-direction: column;
	}
	#top_article_area .sec .article_wrap .text_area{
		width: 100%;
	}
	#top_article_area .sec .article_wrap .img_area{
		width: 100%;
		padding-top: 4%;
	}
	#top_article_area .sec .article_wrap .img_area img{
		width: 100%;
		border-radius: 10px;
	}
	.compare_list ul{
		flex-direction: column;
	}
	.compare_list li{
		padding: 4% 0;
	}
	.compare_list li .head{
		border-radius: 4px;
		font-size: 16px;
	}
	.compare_list li .img{
		padding: 4% 0 8%;
	}
	.compare_list li dt{
		font-size: 16px;
		text-align: left;
	}
	.compare_list li.outdoor,
	.compare_list li.noufukudo{
		width: 100%;
	}
	.compare_list li.outdoor{
		padding-right: 0;
		border-right: none;
	}
	#top_article_area .sustainable .article_wrap .img_area{
		justify-content: space-between;
		flex-direction: row;
	}
	#top_article_area .sustainable .article_wrap .img_area img{
		width: 48%;
		margin: 0 auto;
	}
	.feature .text_area{
		width: 100%;
	}
	.feature .text_area br{
		display: none;
	}
	.feature .point{
		padding: 12% 0;
	}
	.feature .point ul{
		row-gap: 28px;
	}
	.feature .point li{
		flex-direction: column;
		align-items: center;
		padding: 8%;
	}
	.feature .point li{
		border-radius: 20px;
	}
	.feature .point li .img img{
		border-radius: 4px;
	}
	.feature .point li .num{
		width: 50px;
	}
	.feature .point li .img{
		width: 70%;
		padding-bottom: 6%;
	}
	.feature .point li .text_box{
		width: 100%;
	}
	.feature .point li .text_box .tit{
		font-size: 16px;
		text-align: center;
		letter-spacing: 0.05em;
	}
	.feature .point li .text_box .text{
		font-size: 13px;
	}
	.taste h4{
		font-size: 16px;
	}
	.taste .brand{
		padding: 8%;
	}
	.taste .brand .text_area .title{
		font-size: 18px;
		text-align: center;
	}
	.taste .brand .text_area .list dl{
		padding: 2% 0;
	}
	.taste .brand .text_area .list dt{
		width: 36%;
	}
	.taste .brand .text_area .list dd{
		width: 62%;
	}
}
