@charset "utf-8";
/*--------------------------------------------------------------------------
汎用
--------------------------------------------------------------------------*/
a {
	transition: .5s ease;
}
img {
	vertical-align: top;
}

/*------------------------------------
改行
------------------------------------*/
.br-sp {
	display: none;
}
@media screen and (max-width: 1080px) {
	.br-pc {
		display: none;
	}
	.br-sp {
		display: inline-block;
	}
}

/*------------------------------------
アニメーション
------------------------------------*/
/*.snow*/
.snow {
  /*雪の色*/
  color: snow;
  /*雪の大きさ*/
  font-size: 10px;
  /*初期位置*/
  position: fixed;
  top: -5%;
  /*雪を適当な幅で降らせる*/
  text-shadow:
  5vw   -100px 2px,
  10vw  -400px 3px,
  20vw  -500px 4px,
  30vw  -580px 1px,
  39vw  -250px 2px,
  42vw  -340px 5px,
  56vw  -150px 2px,
  63vw  -180px 0,
  78vw  -220px 4px,
  86vw  -320px 9px,
  94vw  -170px 7px;
  /*雪アニメーション1*/
  animation: roll 5s linear infinite;
}
  /*2つめの雪アニメーション*/
.snow2nd{animation: anim 8s linear infinite;}

@keyframes roll {
    0% {transform:rotate(0deg);}
   90% {opacity:1;}
   100% {transform:rotate(20deg);top:100%;opacity:0;}
}
@keyframes anim {
  100% {color:transparent;top:150%;}
}


/*--------------------------------------------------------------------------
サイドファニチャ
--------------------------------------------------------------------------*/
.winter2025-2026 .contents {
	font-family: futura-pt, "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
	font-size: 16px;
	line-height: 1.8;
	padding-top: 20px;
}
.winter2025-2026 .contents > section {
	padding: 160px 0;
}
.winter2025-2026 .contents > section:nth-child(odd) {
	background-color: #f5f5f5;
}
.winter2025-2026 .contents > section .inner {
	max-width: 1200px;
	width: calc(100% - 80px);
	margin: 0 auto;
}
@media screen and (max-width: 768px) {
	.winter2025-2026 .contents {
		font-size: 14px;
	}
	.winter2025-2026 .contents > section {
		padding: 80px 0;
	}
	.winter2025-2026 .contents > section .inner {
		width: calc(100% - 40px);
	}
}


/*------------------------------------
.mv
------------------------------------*/
.mv picture {
	display: block;
	margin-bottom: 50px;
}
.mv .inner {
	max-width: 920px;
	width: calc(100% - 80px);
	margin: auto;
}
.mv h1 {
	font-size: 70px;
	font-weight: 300;
	line-height: 1.2;
	margin-bottom: 50px;
}
.mv span {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #00754a;
	width: fit-content;
	height: 50px;
	font-size: 25px;
	letter-spacing: .08em;
	line-height: 1;
	color: #fff;
	margin-top: 20px;
	margin-inline: auto;
	padding: 0 28px;
	transform: skew(-15deg);
}
.mv strong {
	display: inline-block;
	transform: skew(15deg);
}
.mv p {
	font-size: 20px;
}
@media screen and (max-width: 768px) {
	.mv h1 {
		font-size: 36px;
		margin-bottom: 30px;
	}
	.mv span {
		height: 40px;
		font-size: 20px;
		margin-top: 10px;
		padding: 0 20px;
	}
	.mv p {
		font-size: 14px;
		text-align: left;
	}
}


/*------------------------------------
.ttl
------------------------------------*/
.ttl {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 40px;
	letter-spacing: .05em;
	line-height: 1.4;
	margin-bottom: 30px;
}
.ttl:before,
.ttl:after {
	content: "";
	background-color: #e5e5e5;
	width: 80px;
	height: 8px;
}
.ttl:before {
	margin-right: 20px;
}
.ttl:after {
	margin-left: 20px;
}
.ttl span {
	display: block;
	font-size: 25px;
}
.ttl span::before {
	content: "＼";
}
.ttl span::after {
	content: "／";
}
.ttl strong {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	background-color: #00754a;
	height: 40px;
	font-size: 25px;
	font-weight: normal;
	line-height: 1;
	color: #fff;
	margin-left: 10px;
	padding: 0 10px;
}
@media screen and (max-width: 768px) {
	.ttl {
		font-size: 25px;
		margin-bottom: 20px;
	}
	.ttl:before,
	.ttl:after {
		width: 40px;
		height: 4px;
	}
	.ttl:before {
		margin-right: 10px;
	}
	.ttl:after {
		margin-left: 10px;
	}
	.ttl span {
		font-size: 16px;
	}
	.ttl strong {
		height: 30px;
		font-size: 16px;
		margin-left: 5px;
	}
}


/*------------------------------------
共通テキスト
------------------------------------*/
.item__txt {
	margin-bottom: 50px;
}
.item__txt p:not(:last-child) {
	margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
	.item__txt {
		margin-bottom: 30px;
	}
}


/*------------------------------------
商品リスト
------------------------------------*/
.item-list {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
}
.item-list a {
	display: block;
}
.item-list .txt {
	text-align: left;
	margin-top: 30px;
}
.item-list h3 {
	font-size: 25px;
	line-height: 1.4;
	margin-bottom: 10px;
}
.item__tag {
	display: flex;
	gap: 5px;
}
.item__tag > li {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #00754a;
	height: 30px;
	font-size: 14px;
	line-height: 1;
	color: #fff;
	padding: 0 10px;
}
.item-list p {
	font-size: 18px;
	line-height: 1.4;
	margin-top: 20px;
}
.item-list strong {
	font-size: 22px;
	color: #dc1111;
}
@media screen and (max-width: 768px) {
	.item-list {
		gap: 30px 20px;
	}
	.item-list h3 {
		font-size: 16px;
	}
	.item__tag > li {
		height: 28px;
		font-size: 12px;
		padding: 0 8px;
	}
	.item-list p {
		font-size: 14px;
	}
	.item-list strong {
		font-size: 16px;
	}
}


/*------------------------------------
#sale
------------------------------------*/
#sale .inner {
	max-width: 1260px;
}
#sale .item-list > li {
	width: calc((100% - 80px) / 3);
}
@media screen and (max-width: 768px) {
	#sale .item-list > li {
		width: calc((100% - 20px) / 2);
	}
}


/*------------------------------------
#recommend
------------------------------------*/
#recommend .inner {
	max-width: 1600px;
}
#recommend .item-list > li {
	width: calc((100% - 120px) / 4);
}
@media screen and (max-width: 768px) {
	#recommend .item-list > li {
		width: calc((100% - 20px) / 2);
	}
}


/*------------------------------------
.link-squ
------------------------------------*/
.link-squ {
	display: block;
	max-width: 320px;
	text-align: center;
}
.link-squ a {
	background-color: #00754a;
	border-radius: 4px;
	color: #fff;
	box-shadow: 0px 0px 4px 0px rgba(0,0,0,0.16);
	transition: .5s ease;
}
.link-squ a:hover {
	background-color: #00754a;
	opacity: .6;
}
.link-squ a:after {
	background-image: url(../../../img/common/arrow_cream.svg);
}
@media screen and (max-width: 768px) {}


/*------------------------------------
#present
------------------------------------*/
#present .inner {
	max-width: 1400px;
}
.present-list li {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
.present-list li:nth-child(even) {
	flex-direction: row-reverse;
}
.present-list li:not(:last-child) {
	margin-bottom: 80px;
}
.present-list .img {
	width: 64%;
}
.present-list .txt {
	width: 32%;
	text-align: left;
}
.present-list h3 {
	font-size: 30px;
	line-height: 1.4;
	margin-bottom: 20px;
}
.present-list li .txt h3 strong {
	display: block;
	font-size: 20px;
	color: #dc1111;
}
.present-list li .txt p:not(:last-of-type) {
	margin-bottom: 20px;
}
.present-list li .txt .link-squ {
	margin-top: 32px;
}
@media screen and (max-width: 768px) {
	.present-list li:not(:last-child) {
		margin-bottom: 50px;
	}
	.present-list li .img,
	.present-list li .txt {
		width: 100%;
	}
	.present-list li .img {
		margin-bottom: 30px;
	}
	.present-list li .txt h3 {
		font-size: 20px;
	}
	.present-list li .txt .link-squ {
		margin-left: auto;
		margin-right: auto;
	}
}


/*------------------------------------
#outlet
------------------------------------*/
#outlet .inner > p {
	margin-bottom: 40px;
}
#outlet .link-squ {
	margin: 64px auto 0;
}
@media screen and (max-width: 768px) {
	#outlet .inner > p {
		text-align: left;
		margin-bottom: 24px;
	}
	#outlet .link-squ {
		margin-top: 40px;
	}
}


/*------------------------------------
#point
------------------------------------*/
#point {
	padding: 100px 0;
}
#point .item__txt {
	margin: 0;
}
#point p {
	font-size: 20px;
}
#point strong {
	color: #dc1111;
}
@media screen and (max-width: 768px) {
	#point {
		padding: 70px 0;
	}
	#point p {
		font-size: 14px;
		text-align: left;
	}
}


/*------------------------------------
#about
------------------------------------*/
#about {
	padding-bottom: 0;
}
.winter2025-2026 .contents > section#about .inner {
	max-width: 944px;
}
#about .block:not(:last-of-type) {
	margin-bottom: 64px;
}
#about .block img {
	margin-bottom: 40px;
}
#about .block h3 {
	font-size: 28px;
	line-height: 1.6;
	margin-bottom: 32px;
}
#about .block .link-squ {
	margin: 64px auto 0;
}
@media screen and (max-width: 768px) {
	#about .block h3 {
		font-size: 16px;
	}
	#about .block p {
		text-align: left;
	}
	#about .block .link-squ {
		margin-top: 40px;
	}
}


/*------------------------------------
#shop
------------------------------------*/
#shop {
	background-color: transparent;
}
#shop p {
	line-height: 2;
	margin-top: 56px;
}
#shop .link-squ {
	margin: 64px auto 0;
}
@media screen and (max-width: 768px) {
	#shop p {
		text-align: left;
		margin-top: 32px;
	}
	#shop .link-squ {
		margin-top: 40px;
	}
}


/*------------------------------------
#expo2025
------------------------------------*/
#expo2025 p {
	font-size: 20px;
	margin-bottom: 40px;
}
#expo2025 .link-squ {
	margin: 80px auto 0;
}
@media screen and (max-width: 768px) {
	#expo2025 p {
		font-size: 14px;
		text-align: left;
	}
	#expo2025 img {
		max-width: 240px;
	}
	#expo2025 .link-squ {
		margin-top: 56px;
	}
}
