@charset "UTF-8";
/* CSS Document */

/* ==========================================================
 header 
========================================================== */

/* header
---------------------------------------------------------- */
.swiper-slide video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  aspect-ratio: 7 / 10
}
.kv {
	position: relative;
	max-width: 1260px;
	height: 100%;
	margin: 0 auto;
	z-index: 100;
}
.kv p {
	position: absolute;
	top: -170px;
	right: 50px;
	font-size: 64px;
	letter-spacing: 0.1em;
	line-height: 1.38;
	color: #fff;
	z-index: 100;
}

/* about
---------------------------------------------------------- */
#about {
	position: relative;
	padding-bottom: 0;
}
#about::before , 
#about::after {
	content: "";
	display: block;
	position: absolute;
	z-index: 1;
}
#about::after {
	background: url(../img/bg_about_01.png) no-repeat center center;
	width: 572px;
	height: 572px;
	background-size: contain;
	top: 120px;
	right: calc(50% - 835px);
}
#about::before {
	background: url(../img/bg_about_02.png) no-repeat center center;
	width: 532px;
	height: 532px;
	background-size: contain;
	bottom: 180px;
	left: calc(50% - 900px);
}
#about .sec-02 {
	max-width: 1400px;
	margin: 0 auto;
	grid-template-columns: 1fr 1.05fr;
	grid-template-rows: 300px auto;
	gap: 100px 8%;
	align-items: flex-start;
	position: relative;
	z-index: 100;
}
.sec-02.wrap div {
	grid-column: 1;
  	grid-row: 1;
}
.img-about-01 {
	grid-column: 2;
  	grid-row: 1;
	margin-top: 170px;
	max-width: 660px;
	height: auto;
}
.img-about-02 {
  grid-column: 1;
  grid-row: 2;
  max-width: 630px;
  height: auto;
}

@media (max-width: 1400px) {
  #about::after {
    right: -135px;
	width: 500px;
	height: 500px;
  }
  #about::before {
	left: -200px;
	bottom: 100px;
	width: 450px;
	height: 450px;
  }
}


/* concept
---------------------------------------------------------- */
#concept .sec-02 {
	position: relative;
}
#concept .ttl-01 {
	margin-left: 100px;
}
#concept .sec-02 .txt-box {
	margin-top: 90px;
	margin-bottom: 70px;
}
#concept .sec-02::before {
	content: "";
	display: block;
	position: absolute;
	background: url(../img/img_pattern.png) no-repeat center center;
	background-size: contain;
	width: 140px;
	height: 140px;
	top: -215px;
	right: -7px;
}
.philosophy {
	max-width: 960px;
	padding: 80px;
	margin: 0 auto;
	margin-bottom: 100px;
}
.philosophy .wrap {
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: 50px;
}
.philosophy li img {
	margin-bottom: 20px;
}
.shop .wrap.bg-03 {
	grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
}
.shop .wrap .shop-in {
	padding: 60px 70px 50px;
}
.shop .wrap .ttl-02 {
	margin-bottom: 50px;
}
.shop .wrap .ttl-02 .sub {
	font-size: 18px;
	margin-bottom: 20px;
}
.shop .btn-01 {
	width: 260px;
	height: 40px;
	padding: 10px;
}
.shop .wrap .shop-in .ttl-02 {
	margin-bottom: 20px;
}


/* product
---------------------------------------------------------- */
#product {
	position: relative;
	padding-top: 160px;
}
#product .intro::before {
	content: "";
	position: absolute;
	display: block;
	background: url(../img/img_cow.png) no-repeat center center;
	background-size: contain;
	width: 30vw;
	height: 20vw;
	max-height: 400px;
	top: -50px;
	right: calc(100% - 110px)
}
@media (max-width: 1400px) {
  #product .intro::before {
    width: 400px;
    height: 270px;
	left: calc(50% - 700px);
  }
}
#product .intro {
	position: relative;
	flex-direction: row-reverse;
	gap: 100px;
	margin-right: 80px;
}
#product .intro .txt-box {
	margin-top: 90px;
	margin-bottom: 100px;
}
#product .wrap-02 img {
	width: 480px;
}
#product .sec-02 .bg-04 {
	position: relative;
	padding-top: 80px;
	margin-bottom: 80px;
}
#product .sec-02 .bg-04::before ,
#product .sec-02 .bg-04 .left::after {
	content: "";
	display: block;
	position: absolute;
}
#product .sec-02 .bg-04::before {
	background: url(../img/sign_fukushima.svg) no-repeat center center;
	background-size: contain;
	width: 100px;
	height: 100px;
	top: -10px;
	right: 120px;
}
#product .sec-02 .bg-04 .left::after {
	background: url(../img/img_map.png) no-repeat center center;
	background-size: contain;
	width: 415px;
	height: 330px;
	top: 140px;
	right: -20px;
	clip-path: inset(0 20px 0 0);
}
#product .sec-02 .bg-04 h3 .ttl-sub {
	font-size: 12px;
	letter-spacing: 0.3em;
}
#product .sec-02 .bg-04 h3 {
	margin-left: 80px;
	margin-bottom: 50px;
}
#product .sec-02 .bg-04 .txt-box {
	width: 401px;
	margin: 0 80px 100px;
	z-index: 100;
    position: relative
}
#product .bg-04 .wrap-02 img {
	width: 320px;
}
#product .bg-04 .ttl-03 {
	margin-left: 80px;
	margin-bottom: 50px;
}
#product .sec-03 {
	position: relative;
	display: grid;
	grid-template-columns: 360px 1fr; 
	gap: 80px;
	align-items: center;
	padding-left: 80px;
}
#product .sec-03 .ttl-04 {
	position: absolute;
	left: 80px;
  	top: 80px;
	line-height: 1;
}
#product .sec-03 figure {
	order: 2;
}
#product .sec-03 .txt-box {
	order: 1;
	margin-top: 50px;
}
#product .sec-03 .txt-box h4 {
	font-weight: 700;
	font-size: 18px;
	margin-bottom: 20px;
}


/* ==========================================================
 メディアクエリ
========================================================== */
@media screen and (max-width: 800px) {

/* ==========================================================
 header / footer
========================================================== */

/* header
---------------------------------------------------------- */
.kv {
	margin-top: 140px;
}
.kv p {
	font-size: 36px;
	top: auto;
	right: 20px;
	bottom: 0;
	text-align: end;
}
/* .swiper-slide video {
  aspect-ratio: 19 / 34
} */

/* about
---------------------------------------------------------- */
#about {
	padding-top: 90px;
}
#about .sec-02 {
	display: block;
	padding: 0;
	max-width: none;
}
.img-about-01 ,
.img-about-02 {
	max-width: none;
}
.img-about-01 {
	margin-top: 140px;
}
#about::before {
	display: none;
}
#about::after {
	background: url(../img/bg_about_sp.png) no-repeat center center;
	background-size: contain;
	width: 200px;
	height: 330px;
	top: 190px;
	right: -35px;
}
#about .sec-02.wrap div {
	line-height: 2.25;
}
#about .sec-02.wrap .txt-rl-pc {
	max-width: 450px;
	padding: 0 50px;
	margin: 0 auto;
}

/* concept
---------------------------------------------------------- */
#concept .sec-02::before {
	top: -100px;
	right: -15px;
}
#concept h2 {
	margin-left: 0;
}
#concept .sec-02 .txt-box {
	margin-bottom: 0;
}
#concept .sec-02 {
	max-width: 450px;
}
#concept .ttl-01 {
	margin-left: 0;
}

/* philosophy
---------------------------------------------------------- */
.philosophy {
	padding: 0;
	max-width: 450px;
}
.philosophy .ttl-02 {
	width: 280px;
	height: 280px;
	padding: 50px;
}
.philosophy .ttl-02 {
	line-height: 2;
}
.philosophy .ttl-en {
	margin-bottom: 20px;
}
.philosophy .wrap {
	gap: 40px;
	margin-left: 50px;
    margin-top: -50px;
}

/* shop
---------------------------------------------------------- */
.shop .ttl-02 .ttl-en {
	writing-mode: vertical-rl;
}
.shop .wrap {
	grid-template-columns: 5fr 1fr;
	align-items: flex-start;
}
.shop .wrap.bg-03 {
	grid-template-columns: auto;
	padding: 20px 50px 0;
	justify-content: center;
}
.shop .wrap .shop-in {
	padding: 0;
}
.shop .wrap .ttl-02 .sub {
	margin-bottom: 10px;
	font-weight: 20px;
}
.shop .wrap h2.ttl-02 {
	display: flex;
	justify-content: center;
	align-items: center;
}

/* product
---------------------------------------------------------- */
#product {
	padding-top: 200px;
}
#product .sec-02 {
	padding: 0;
}
#product .bg-04 .ttl-03 {
	margin-left: 50px;
	font-size: 30px
}
#product .intro {
	gap: 0;
	padding: 0 50px;
}
#product .intro::before {
	width: 270px;
	height: 180px;
	left: -45px;
	top: -110px;
}
#product .intro {
	margin-right: 0;
}
#product .intro .txt-box {
	margin-top: 60px;
	margin-bottom: 70px;
	width: 100%;
}
#product .wrap-02 img ,
#product .bg-04 .wrap-02 img {
	width: 350px;
}
#product .sec-02 .bg-04::before {
	right: 30px;
}
#product .sec-02 .bg-04 h3 {
	margin-left: 50px;
	writing-mode: vertical-lr;
	letter-spacing: 0.3em;
	text-align: center;
}
#product .sec-02 .bg-04 .left::after {
	width: 320px;
	height: 230px;
	right: -35px;
	top: 390px;
}
#product .sec-02 .bg-04 .txt-box {
	position: relative;
	width: auto;
	margin: 0 50px 220px;
	z-index: 100;
}
#product .sec-02 .bg-04 {
	margin-bottom: 130px;
}
#product .sec-03 {
	grid-template-columns: auto;
	gap: 0;
	padding: 0 50px;
	max-width: 450px;
}
#product .sec-03 figure {
  	grid-row: 1;
}
#product .sec-03 .ttl-04 {
	line-height: 1.6;
	letter-spacing: 0.08em;
	font-size: 30px;
	top: -55px;
	right: 20px;
}
#product .sec-03 .txt-box {
	margin-top: 20px;
}
#product .sec-02 figure.wrap-02 {
	margin-left: 50px;
}


}

@media screen and (max-width: 450px) {
	.img-about-01-sp, .img-about-02-sp {
		max-width: 250px;
	}
}