@charset "utf-8";
/* ===================================================================

 file name  :one-eco.css
 style info : OneEcoシリーズ

=================================================================== */

/* =============================

	overwrite

=============================== */
#pageHeader{
	background: url(../images/one-eco/mv.png) no-repeat 50% 50% / cover;
	height: 0;
	padding: 0 0 54.266%;
	position: relative;
	z-index: 0;
  overflow: hidden;
}
#pageHeader::before {
	content: "";
	display: block;
	width: 50vw;
	height: 100%;
	position: absolute;
	top: 0;
	left: 50vw;
	backdrop-filter: blur(5px);
}

.oneeco-header {
	position: absolute;
	top: 0;
	left: 50vw;
	width: 50vw;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	padding-top: 10%;
	padding-inline: 6%;
}

.oneeco-header p {
	font-size: min(31px,1.612vw);
	font-weight: bold;
	color: #fff;
	border-bottom: 1px solid #fff;
	padding-bottom: 1rem;
	margin-bottom: min(10rem,5.202vw);
	display: inline-block;
	text-shadow: 0 0 2px rgba(0,0,0,0.3),
		0 0 4px rgba(0,0,0,0.3),
		0 0 8px rgba(0,0,0,0.3),
		0 0 12px rgba(0,0,0,0.3),
		0 0 16px rgba(0,0,0,0.3),
		0 0 20px rgba(0,0,0,0.3);
}

.oneeco-header h1 {
	display: block;
	font-size: min(81px,4.214vw);
	font-weight: bold;
	color: #fff!important;
	letter-spacing: -.01em!important;
	margin: 0!important;
}

.oneeco-header h1 span {
	display: block;
	font-size: min(40px,2.081vw);
	margin-bottom: min(20px,1.04vw);;
}


.oneeco-header-spimg {
	display: none;
}


@media screen and (max-width: 767px) {
	#pageHeader{
		height: auto;
		background: none;
		padding-bottom: 0;
	}
	#pageHeader::before {
	display: none;
}
	.oneeco-header-spimg {
		display: block;
	}
	.oneeco-header {
		position: relative;
		top: 0;
		left: 0;
		width: 100%;
		height: auto;
		display: block;
		padding: 3rem 2rem;
		margin-bottom: 5rem;
	}

.oneeco-header p {
	font-size: 15px;
	border-bottom: 1px solid #111;
	padding-bottom: .5rem;
	margin-bottom: 4rem;
	text-shadow:none;
	color: #111;
}

.oneeco-header h1 {
	font-size: 35px;
	color: #111!important;
	text-shadow:none!important;
}

.oneeco-header h1 span {
	font-size: 18px;
	margin-bottom: 10px;
	text-shadow:none!important;
}
}

#main{
	padding-bottom: 0;
}

/* =================================== */
/*
	common
-----------------------------------------------------*/


#main .ttl{
	margin: 0 0 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
	line-height: 1.2;
}
#main .ttl::before,
#main .ttl::after{
	content: "";
	width: 30px;
	height: 6px;
	border-top: solid 2px #161616;
	border-bottom: solid 2px #161616;
}
#main .ttl::before{
	margin: 0 21px 0 0;
}
#main .ttl::after{
	margin: 0 0 0 21px;
}

#main .txt{
	color: #111;
}

#main .f-block{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}


@media screen and (max-width: 767px){
	#main .ttl{
		margin: 0 0 30px;
		font-size: 1.8rem;
		text-align: center;
	}
	#main .ttl::before,
	#main .ttl::after{
		width: 20px;
		height: 3px;
		border-top: solid 1px #161616;
		border-bottom: solid 1px #161616;
	}
	#main .ttl::before{
		margin: 0 10px 0 0;
	}
	#main .ttl::after{
		margin: 0 0 0 10px;
	}

}

/*
	#secLead
-----------------------------------------------------*/
#secLead{
	padding: 0 0 120px;
	text-align: center;
}
#secLead .txt-lead{
	margin: 0 0 100px;
	font-size: 1.6rem;
	line-height: 2.5;
}
#secLead h2{
	margin: 0 0 96px;
	font-size: 3.6rem;
	line-height: 1.7;
}
#secLead h2 span{
	font-size: 6rem;
}
#secLead .pagelink{
	display: flex;
	justify-content: space-between;
}
#secLead .pagelink li{
	width: 33.3333%;
	padding: 30px 0 20px;
	border-right: solid 1px #ccc;
}
#secLead .pagelink li:first-child{
	border-left: solid 1px #ccc;
}
#secLead .pagelink li dl dt{
	margin: 0 0 26px;
	font-size: 8rem;
	line-height: 1;
}
#secLead .pagelink li dl dt::after{
	content: "";
	display: block;
	width: 36px;
	height: 3px;
	margin: 28px auto 0;
	background: #161616;
}
#secLead .pagelink li dl .txt{
	margin: 0 0 40px;
	font-size: 3.2rem;
	letter-spacing: 0.05em;
}
#secLead .pagelink li dl .link{
	max-width: 300px;
	margin: 0 auto;
}
#secLead .pagelink li dl .link a{
	display: block;
	font-size: 1.6rem;
	line-height: 40px;
	background: #efefef;
	position: relative;
}
#secLead .pagelink li dl .link a:hover{
	background: #919191;
	color: #fff;
}
#secLead .pagelink li dl .link a::before{
	content: "";
	display: block;
	width: 10px;
	height: 10px;
	border-top: solid 1px #656565;
	border-right: solid 1px #656565;
	transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 20px;
	margin: -5px 0 0;
}
#secLead .pagelink li dl .link a:hover::before{
	border-color: #fff;
}

@media screen and (max-width: 767px){
	#secLead{
		padding: 0 0 50px;
	}
	#secLead .txt-lead{
		margin: 0 0 50px;
		font-size: 1.4rem;
		line-height: 1.7;
	}
	#secLead h2{
		margin: 0 0 40px;
		font-size: 1.8rem;
		line-height: 1.7;
	}
	#secLead h2 span{
		display: inline-block;
		font-size: 3rem;
		margin: -0.3em 0 0;
	}
	#secLead .pagelink{
		display: flex;
		justify-content: space-between;
	}
	#secLead .pagelink li{
		width: 33.3333%;
		padding: 15px 0 0;
		border-right: solid 1px #ccc;
	}
	#secLead .pagelink li:first-child{
		border-left: solid 1px #ccc;
	}
	#secLead .pagelink li dl dt{
		margin: 0 0 10px;
		font-size: 4rem;
	}
	#secLead .pagelink li dl dt::after{
		width: 18px;
		height: 2px;
		margin: 5px auto 0;
	}
	#secLead .pagelink li dl .txt{
		margin: 0 0 15px;
		font-size: 1.8rem;
		white-space: nowrap;
		letter-spacing: 0;
	}
	#secLead .pagelink li dl .link{
		max-width: 300px;
		margin: 0 auto;
	}
	#secLead .pagelink li dl .link a{
		padding: 20px 0 30px;
		font-size: 1.4rem;
		line-height: 1.5;
	}
	#secLead .pagelink li dl .link a::before{
		width: 5px;
		height: 5px;
		border-top: solid 1px #656565;
		border-right: solid 1px #656565;
		transform: rotate(135deg);
		position: absolute;
		top: auto;
		right: 50%;
		bottom: 15px;
		margin: 0 -2px 0 0;
	}
}

/*
	.sec-wrap
-----------------------------------------------------*/
#main .sec-wrap{
	background: #161616;
	color: #fff;
}
#main .sec-wrap section .f-block{
	align-items: center;
	justify-content: flex-start;
}
#main .sec-wrap section.even .f-block{
	flex-direction: row-reverse;
}
#main .sec-wrap section .f-block figure{
	width: 50%;
}
#main .sec-wrap section .f-block .txt-block{
	width: 600px;
}
#main .sec-wrap section.odd .f-block .txt-block{
	padding: 0 0 0 3.9%;
}
#main .sec-wrap section.even .f-block .txt-block{
	padding: 0 3.9% 0 0;
}
#main .sec-wrap section .f-block .txt-block h2{
	margin: 0 0 40px;
	font-size: 3rem;
}
#main .sec-wrap section .f-block .txt-block h2::before{
	content: "";
	display: block;
	width: 36px;
	height: 3px;
	background: #fff;
	margin: 0 0 22px;
}

@media screen and (max-width: 1430px){
	#main .sec-wrap section .f-block figure{
		overflow: hidden;
	}
	#main .sec-wrap section .f-block figure img{
		width:715px !important;
		max-width: none;
	}
}
@media screen and (max-width: 767px){
	#main .sec-wrap{
		background: #161616;
		color: #fff;
	}
	#main .sec-wrap section .f-block{
		display: block;
	}
	#main .sec-wrap section .f-block figure{
		width: 100%;
	}
	#main .sec-wrap section .f-block .txt-block{
		width: 100%;
		padding: 30px 20px !important;
	}
	#main .sec-wrap section .f-block .txt-block h2{
		margin: 0 0 20px;
		font-size: 2rem;
		line-height: 1.2;
	}
	#main .sec-wrap section .f-block .txt-block h2::before{
		width: 18px;
		height: 2px;
		margin: 0 0 10px;
	}
	#main .sec-wrap section .f-block figure img{
		width:100% !important;
	}
}

/*
	.sec
-----------------------------------------------------*/
#main .sec{
	margin: 160px 0 0;
	padding: 160px 0 0;
}
#main .sec .sec-bg{
	padding: 0 0 1px;
	background: linear-gradient(to bottom,#fff 0%,#fff 20%,#F6F6F6 20%,#F6F6F6 100%);
}
#main .sec .sec-head{
	margin: -160px 0 58px;
	display: flex;
	justify-content: space-between;
}
#main .sec .sec-head.reverse{
	flex-direction: row-reverse;
}
#main .sec .sec-head .txt-block{
	width: 520px;
}
#main .sec .sec-head .txt-block h2{
	margin: 0 0 87px;
	display: flex;
	align-items: center;
	line-height: 1;
}
#main .sec .sec-head .txt-block h2 .num{
	padding: 10px 0 0;
	font-size: 6.4rem;
}
#main .sec .sec-head .txt-block h2 .ja{
	margin: 0 0 0 30px;
	padding: 7px 0 7px 32px;
	font-size: 2.4rem;
	border-left: solid 3px #161616;
}

@media screen and (max-width: 767px){
	#main .sec{
		margin: 70px 0 0;
		padding: 70px 0 0;
	}
	#main .sec .sec-bg{
		padding: 1px 0 50px;
	}
	#main .sec .sec-head{
		margin: -70px 0 0;
		display: block;
	}
	#main .sec .sec-head .txt-block{
		width: 100%;
		margin: 0 0 30px;
	}
	#main .sec .sec-head .txt-block h2{
		margin: 0 0 50px;
	}
	#main .sec .sec-head .txt-block h2 .num{
		padding: 5px 0 0;
		font-size: 4.5rem;
	}
	#main .sec .sec-head .txt-block h2 .ja{
		margin: 0 0 0 15px;
		padding: 4px 0 4px 15px;
		font-size: 2.4rem;
		border-left: solid 2px #161616;
	}
}




.row {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 3.5rem;
}

.row--wide {
	grid-template-columns:4fr 5fr;
	gap: 7.2rem;
}

.row--03 {
	grid-template-columns: repeat(3,1fr);
	gap: 4.8rem;
}


.row--04 {
	grid-template-columns: repeat(4,1fr);
	gap: 6.6rem;
}


@media screen and (max-width: 767px) {
	.row {
		grid-template-columns: 1fr;
		gap: 4rem;
	}
}



.dog-title {
	display: block;
	margin: 70px 0 50px;
	text-align: center;
	font-size: 32px;
	line-height: 1.3;
	font-weight: normal;
	position: relative;
}

.dog-title--mt {
	margin-top: 200px;
}

.dog-title--mb {
	margin-bottom: 100px;
}

.dog-title:first-child {
	margin-top:0;
}

.dog-title::before {
	content: "";
	display: block;
	width: 37px;
	height: 28px;
	margin: 0 auto 19px;
	background: url(/parts/images/one-eco/icon-nikukyu.png)0 0/contain no-repeat;
}

.dog-title--icon-left {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
}

.dog-title--left {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 12px;
}

.dog-title--left::before,
.dog-title--icon-left::before {
	margin: 0;
}

.dog-title--rich::after {
	content: "";
	display: block;
	width: 232px;
	height: 180px;
	background: url(/parts/images/one-eco/img-nikukyu.png)0 0/contain no-repeat;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate(0,-50%);
}

.dog-title--wt {
	color: #fff;
}

.dog-title--wt::before {
	background-image: url(/parts/images/one-eco/icon-nikukyu_wt.png);
}

.dog-title + p {
	text-align: center;
}

.bk-block {
	background: #111111;
	padding: 90px;
	margin-top: 180px;
}

.bk-block * {
	color: #fff;
}

.bk-block .row {
	gap: 3rem 5rem;
}

.bk-block .row__item:last-child {
	grid-column: 1/3;
}

.section {
	padding: 140px 0;
}
.section--bg {
	background: #F6F6F6;
}


@media screen and (max-width: 767px) {
.dog-title {
	margin: 35px 0 25px;
	font-size: 20px;
}

.dog-title--mt {
	margin-top: 100px;
}

.dog-title--mb {
	margin-bottom: 50px;
}

.dog-title::before {
	margin-bottom: 10px;
}

.dog-title--icon-left::before {
	margin-bottom: 0;
}

.dog-title--rich::after {
	width: 81px;
	height: 63px;
}

.bk-block {
	padding: 40px 20px;
	margin-top: 100px;
}

.bk-block .row {
	gap: 3rem;
}

.bk-block .row__item:last-child {
	grid-column: 1/2;
}

.section {
	padding: 80px 0;
}
}

.box {
	border: 1px solid #AEAEAE;
	height: 100%;
}

.box--02 {
	padding: 2rem 3rem;
	border: 2px solid rgba(#606060,.78);
	box-shadow: none;
	background: #fff;
}

.box--simple {
	border: none;
	box-shadow: none;
}

.box--simple .box-title {
	text-align: left;
	padding: 0;
	margin: 3rem 0 2rem;
}
.box--simple .box-img img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%!important;
	object-fit: cover;
	font-family: "object-fit: cover;";
}

.box-title {
	text-align: center;
	padding: 5px 0;
	font-size: 24px;
	font-weight: 500;
}

.box-texts {
	padding: 20px 80px;
	line-height: 1.3;
}

.box-texts p + p {
	margin-top: 3rem;
}

.img-responsive {
	width: 100%;
	height: auto;
}

.box-img {
	width: 100%;
	height: 0;
	padding-bottom: 70.977%;
	position: relative;
}

.underline-title {
	position: relative;
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	line-height: 1.3;
	margin: 1.5rem 0 3rem;
}

.underline-title::after {
	content: "";
	display: block;
	margin: 1rem auto 0;
	width: 60%;
	height: 1px;
	background: #000;
}

@media screen and (max-width: 767px) {
	.box {
	height: auto;
	}

	.box--02 {
		padding: 2rem 1.5rem;
	}

	.box--02 .box-img {
		height: auto;
		padding-bottom: 0;
	}

	.box--simple .box-title {
		margin: 2rem 0 1rem;
	}


	.box-title {
		font-size: 18px;
		padding-block: 2rem;
	}

	.box-texts {
		padding: 3rem 2rem;
	}

	.underline-title {
		font-size: 18px;
		margin: 1.5rem 0 2rem;
	}

	.underline-title::after {
		margin: 1rem auto 0;
	}

}

@media screen and (min-width: 768px) {
	.box-title {
		padding-block: 3rem;
	}

	.box-texts {
		padding-block: 5rem;
	}

	.box--02 {
		padding: 4rem;
	}
}

.flow {
	display: flex;
	flex-direction: column;
	gap: 10rem;
	list-style: none;
	position: relative;
	padding-top: 114px;
	margin-top: 130px;
}

.flow::before {
	content: "";
	display: block;
	width: 9px;
	height: 87%;
	background: #EBEBEB;
	z-index: -1;
	position: absolute;
	top: 0;
	left: 18px;
}

.flow li {
	display: grid;
	grid-template-columns: 330px 1fr;
	gap: 0 94px;
}

.flow-title {
	display: block;
	position: relative;
	padding-left: 126px;
	font-size: 34px;
	font-weight: 600;
	line-height: 1;
}

.flow-title span {
	display: block;
	font-size: 14px;
	font-weight: 500;
	margin-top: 1.5rem;
}

.flow-title::before {
	content: "";
	display: block;
	width: 47px;
	height: 35px;
	background: url(/parts/images/one-eco/icon-nikukyu.png)0 0/contain no-repeat;
	position: absolute;
	top: 0;
	left: 0;
}
.flow-title::after {
	content: "";
	display: block;
	width: 89px;
	height: 1px;
	border-bottom: 1px dashed #000;
	position: absolute;
	top:18px;
	left: 20px;
}

.flow-desc {
	display: flex;
	flex-direction: column;
	gap: 42px;
}

@media screen and (max-width: 767px) {
	.flow {
		gap: 7rem;
		padding-top: 30px;
		margin-top: 0;
	}

	.flow::before {
		width: 5px;
		height: 87%;
		left: 0;
	}

	.flow li {
		grid-template-columns: 1fr;
		gap: 20px 0;
	}

	.flow-title {
		padding-left: 126px;
		font-size: 20px;
		margin-left: -20px;
	}

	.flow-title span {
		margin-top: 1rem;
	}

	.flow-desc {
		padding-left: 30px;
		gap: 20px;
	}

}


.qa-parts {
  list-style: none;
	counter-reset: number 0;
}
.qa-parts__item {
  border-bottom: 1px solid #ccc;
	counter-increment: number 1;
}
.qa-parts__item + .qa-parts__item {
  margin-top: 4.4rem;
}
.qa-parts__label {
	display: flex;
	justify-content: space-between;
	align-items: center;
  gap: 2rem;
  font-size: 1.4rem;
  color: var(--color-font);
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: 0.2s ease-out;
  cursor: pointer;
	padding-bottom: 2.2rem;
}
.qa-parts__label::after {
  content: "＋";
	font-weight: 400;
  display: inline-block;
  font-size: 3.5rem;
  color: var(--color-primary);
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  -webkit-transition: 0.2s ease-out;
  transition: 0.2s ease-out;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.qa-parts__title {
  display: grid;
	grid-template-columns: 75px 1fr;
	font-size: 24px;
}
.qa-parts__title::before {
	content: "Q";
  display: grid;
	place-content: center;
	aspect-ratio: 1;
	color: #fff;
	line-height: 1;
	background: #161616;
	border-radius: 50%;;
  margin-right: 2.7rem;
      flex-shrink: 0;
}
.qa-parts__content {
  height: 0;
  padding: 0 1.5rem;
  overflow: hidden;
  backface-visibility: hidden;
  transition: 0.2s ease-out;
  color: var(--color-font);
  font-size: 1.6rem;
  display: flex;
  gap: 1rem;
	padding-left: 75px;
}

.qa-parts__toggle {
  display: none;
}
.qa-parts__toggle:checked + .qa-parts__label + .qa-parts__content {
  height: auto;
  padding: 0 1.5rem 2rem;
	padding-left: 75px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.qa-parts__toggle:checked + .qa-parts__label::after {
          transform: rotate(-180deg) !important;
	content: "－";
}


@media screen and (max-width: 767px) {

	.qa-parts__item + .qa-parts__item {
		margin-top: 2.2rem;
	}
	.qa-parts__label {
		gap: 1rem;
	}
	.qa-parts__label::after {
		font-size: 2.5rem;
	}

	.qa-parts__title {
		grid-template-columns: 50px 1fr;
		font-size: 16px;
	}
	.qa-parts__title::before {
		margin-right: 1rem;
	}
	.qa-parts__content {
		padding: 0 1.5rem;
		font-size: 1.4rem;
		gap: 1rem;
		padding-left: 50px;
	}


	.qa-parts__toggle:checked + .qa-parts__label + .qa-parts__content {
		padding: 0 1.5rem 2rem;
		padding-left: 50px;
	}
}

.project-card-wrap {
	display: grid;
	gap: 22px;
}
.project-card {
	border: 1px solid #C5C5C5;
	position: relative;
	transition: .2s ease-out;
}

.project-card a {
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
}

.project-card figure{
	width: calc(100% + 2px);
	margin-top: -1px;
	margin-left: -1px;
	height: 0;
	padding-bottom: 65.526%;
	position: relative;
}

.project-card figure img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%!important;
	object-fit: cover;
	font-family: "object-fit: cover;";
}

.project-card__texts {
	border-top: none;
	padding: 27px 17px;
}

.project-card .project-info {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 17px 16px;
	margin-top: 25px;
}

@media screen and (min-width: 768px) {

	.project-card__texts {
		padding: 35px;
	}

	.project-card-wrap {
		grid-template-columns: 1fr 1fr;
		gap: 40px;
	}

	.project-card:hover {
		opacity: 0.6!important;
	}

}


/*
	#pageLink
---------------------------------------------------*/
#pageLink{
	margin: 0 0 80px;
}
#pageLink ul{
	display: grid;
	grid-template-columns: repeat(3,1fr);
	gap: 9px 16px;
}

#pageLink li{
	text-align: center;
}
#pageLink li a{
	display: block;
	padding: 20px 0;
	line-height: 1;
	border: solid 1px #aaa;
	position: relative;
	font-size: 1.6rem;
}
#pageLink li a:hover{
	background: #161616;
	color: #fefefe;
	border: solid 1px #161616;
}
#pageLink li a::before{
	content: "";
	display: block;
	width: 7px;
	height: 7px;
	border-left: solid 1px #727272;
	border-bottom: solid 1px #727272;
	transform: rotate(-45deg);
	position: absolute;
	top: 50%;
	right: 19px;
	margin: -3px 0 0;
}
#pageLink li a:hover::before{
	border-left: solid 1px #fefefe;
	border-bottom: solid 1px #fefefe;
}
@media screen and (max-width: 767px){
	#pageLink{
		margin: 0 0 20px;
	}
	#pageLink ul{
		grid-template-columns: repeat(2,1fr);
	}
	#pageLink li a{
		padding: 10px 0 20px;
		font-size: 1.3rem;
		height: 100%;
	}
	#pageLink li a::before{
		width: 5px;
		height: 5px;
		top: auto;
		left: 50%;
		right: auto;
		bottom: 6px;
		margin: 0 0 0 -2px;
	}
}