@charset "UTF-8";

/*main
----------------------------------------*/
.costume main {
	background: #fff;
}
.costume .ttl_page {
	background: #f8f9f8;
}

/*intro
----------------------------------------*/
.costume .intro {
	padding: 12.2rem 2rem 17.8rem;
	border-radius: 0 0 27rem;
	background: #f8f9f8;
}
.costume .intro::after {
	content: '';
	display: block;
	width: 66.4rem;
	position: absolute;
	right: 26.4rem;
	top: 19.8rem;
	bottom: 0;
	border-radius: 33.2rem 33.2rem 0 0;
	background: #718E5E;
	opacity: .06;
}
.costume .intro::before {
	content: '';
	display: block;
	width: 54.4rem;
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	border-radius: 0 0 27rem 27rem;
	background: #F2F2F2 url(../../img/common/intro_img_01.png) no-repeat right bottom / 30.7rem auto;
}
.costume .intro_txt {
	max-width: 93rem;
	margin: 0 auto;
	z-index: 2;
}
.costume .intro_txt h2 {
	font-weight: 400;
	font-size: 2.8rem;
	color: #7AA160;
	line-height: 1.4286;
	letter-spacing: .1em;
	margin-bottom: 2.5rem;
}
.costume .intro_txt p {
	font-size: 1.5rem;
	line-height: 1.9333;
	letter-spacing: .1em;
}
.costume .intro_txt p + p {
	margin-top: 1.3rem;
}
@media only screen and (max-width: 768px) {
	.costume .intro {
		padding: 5.1rem 4rem 6.3rem;
		border-radius: 0 0 12rem;
		overflow: hidden;
	}
	.costume .intro::after {
		width: 36.9rem;
		right: 12.5rem;
		height: 28.5rem;
		top: auto;
		bottom: -12rem;
		border-radius: 18.45rem 18.45rem 0 0;
	}
	.costume .intro::before {
		width: 25rem;
		border-radius: 0 0 12rem 12rem;
		background: #F2F2F2 url(../../img/dress/intro_img_01-sp.png) no-repeat right bottom / 12.4rem auto;
	}
	.costume .intro_txt {
		margin: 0;
	}
	.costume .intro_txt h2 {
		font-size: 2.2rem;
		margin-bottom: 1.7rem;
	}
	.costume .intro_txt p {
		font-size: 1.3rem;
		line-height: 1.6923;
		letter-spacing: .05em;
	}
	.costume .intro_txt p + p {
		margin-top: 1.7rem;
	}
}

/*item
----------------------------------------*/
.costume .item {
	margin: -7.9rem 0 0;
	padding: 0 0 10.5rem;
	z-index: 3;
}
.costume .item:nth-child(2n) + .fair::before,
.costume .item:nth-child(2n) + .fair::after {
	content: '';
	display: block;
	width: 25rem;
	height: 25rem;
	background: #E4EBDF;
	pointer-events: none;
	position: absolute;
	top: -25rem;
	right: 0;
}
.costume .item:nth-child(2n) + .fair::after {
	background: #F5F5F5;
	border-radius: 0 0 21rem;
}
.costume .item + .item {
	margin-top: 0;
	z-index: 0;
}
.costume .item:nth-child(2n) {
	background: #F5F5F5;
	padding-bottom: 11.9rem;
}
.costume .item_head {
	display: flex;
	align-items: flex-end;
	margin-bottom: 4.4rem;
}
.costume .item + .item .item_head {
	align-items: center;
}
.costume .item + .item:nth-child(2n) .item_head {
	align-items: center;
	justify-content: flex-end;
}
.costume .item_head figure {
	width: calc(50% + 10.6rem);
	border-radius: 0 16rem 0 0;
	overflow: hidden;
}
.costume .item:nth-child(2n) figure {
	order: 1;
	border-radius: 16rem 0 0;
}
.costume .item_head_txt {
	width: 44rem;
	padding: 0 0 5.4rem 11.1rem;
}
.costume .item + .item .item_head_txt {
	padding: 5.4rem 0 0 11.1rem;
}
.costume .item + .item:nth-child(2n) .item_head_txt {
	padding: 5.4rem 8.7rem 0 0;
}
.costume .item_head_txt h2 {
	font-size: 1.3rem;
	letter-spacing: .15em;
	font-weight: 400;
	color: #7AA160;
	line-height: 1.39;
	margin-bottom: 1.8rem;
}
.costume .item_head_txt h2 .en {
	font-size: 2.8rem;
	letter-spacing: .15em;
	display: block;
}
.costume .item_head_txt p {
	font-size: 1.3rem;
	line-height: 2.0769;
	letter-spacing: .07em;
}
.costume .item_head_txt p + p {
	margin-top: .9rem;
}
.costume .item_btn {
	display: block;
	width: 25.3rem;
	background: #7AA160;
	color: #fff;
	font-size: 1.3rem;
	letter-spacing: .01em;
	border-radius: 2.1rem;
	padding: 1.2rem 2.2rem;
	margin: 2.2rem 0 0;
}
.costume .item + .item .item_btn {
	margin-top: 3.2rem;
}
.costume .item_btn::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: .5rem 0 .5rem .8rem;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 1.6rem;
	margin: auto 0;
	transition: transform .3s;
}
.costume .item_slider {
	width: calc(50% + 41.7rem);
	margin: 0 0 0 auto;
	overflow: hidden;
}
.costume .item:nth-child(2n) .item_slider {
	margin: 0;
}
.costume .item_slider .slick-list::after,
.costume .item_slider::after {
	content: '';
	display: block;
	clear: both;
}
.costume .item_slider figure {
	float: left;
	width: 27.5rem;
}
.costume .item_slider .slick-prev,
.costume .item_slider .slick-next {
	content: '';
	display: block;
	appearance: none;
	outline: none;
	border: 0;
	width: 3.6rem;
	height: 3.6rem;
	overflow: hidden;
	text-indent: -99rem;
	background: url(../../img/common/icon_arrow_01.svg) no-repeat left top / 100% auto;
	position: absolute;
	top: 16.6rem;
	right: 6.9rem;
	z-index: 10;
	filter: brightness(0) invert(1);
	cursor: pointer;
}
.costume .item_slider .slick-disabled {
	display: none !important;
}
.costume .item_slider .slick-prev {
	transform: scale(-1, 1);
	left: 6.9rem;
	right: auto;
}
.costume .item_slider .slick-dots {
	display: flex;
	gap: .8rem;
	justify-content: center;
	margin-top: 4.5rem;
	z-index: 2;
}
.costume .item_slider .slick-dots li {
	width: .6rem;
	height: .6rem;
}
.costume .item_slider .slick-dots button {
	display: block;
	appearance: none;
	width: .6rem;
	height: .6rem;
	border-radius: 50%;
	background: #D9D9D9;
	overflow: hidden;
	text-indent: -99rem;
	border: 0;
}
.costume .item_slider .slick-dots .slick-active button {
	background: #7AA160;
}
@media (hover:hover) {
	.costume .item_btn:hover::after {
		transform: translateX(.5rem);
	}
}
@media only screen and (max-width: 768px) {
	.costume .item {
		margin: 0;
		padding: 0 0 7rem;
	}
	.costume .item:nth-child(2n) + .fair::before,
	.costume .item:nth-child(2n) + .fair::after {
		display: none;
	}
	.costume .item:nth-child(2n) {
		padding-bottom: 7rem;
	}
	.costume .item_head {
		display: block;
		padding-top: 14.9rem;
		margin-bottom: 4rem;
	}
	.costume .item + .item:nth-child(2n) .item_head {
		padding-top: 14.2rem;
	}
	.costume .item_head figure {
		width: 35.5rem;
		border-radius: 0 7rem 0 0;
	}
	.costume .item:nth-child(2n) figure {
		margin: 0 0 0 auto;
		border-radius: 7rem 0 0;
	}
	.costume .item_head_txt {
		width: 29.5rem;
		margin: 0 auto;
		padding: 2.5rem 0 0;
		position: static;
	}
	.costume .item + .item .item_head_txt,
	.costume .item + .item:nth-child(2n) .item_head_txt {
		padding: 2.5rem 0 0;
	}
	.costume .item_head_txt h2 {
		position: absolute;
		top: 7.3rem;
		left: 0;
		right: 0;
		text-align: center;
		line-height: 1.38;
	}
	.costume .item_head_txt h2 .en {
		font-size: 2.4rem;
	}
	.costume .item + .item:nth-child(2n) .item_head_txt h2 {
		top: 6.2rem;
	}
	.costume .item_head_txt p {
		line-height: 1.6923;
		letter-spacing: .05em;
	}
	.costume .item_btn {
		width: 29.5rem;
		font-size: 1.4rem;
		letter-spacing: .1em;
		border-radius: 2.4rem;
		padding: 1.35rem 3rem;
		margin: 2.2rem auto 0;
	}
	.costume .item + .item .item_btn {
		margin-top: 2.2rem;
	}
	.costume .item_slider {
		width: auto;
	}
	.costume .item_slider figure {
		width: 22.6rem;
	}
	.costume .item_slider .slick-prev,
	.costume .item_slider .slick-next {
		width: 2.8rem;
		height: 2.8rem;
		top: 13.7rem;
		right: 1.6rem;
	}
	.costume .item_slider .slick-prev {
		left: 1.6rem;
		right: auto;
	}
	.costume .item_slider .slick-dots {
		gap: .5rem;
		margin-top: 1.5rem;
	}
	.costume .item_slider .slick-dots li {
		width: .4rem;
		height: .4rem;
	}
	.costume .item_slider .slick-dots button {
		width: .4rem;
		height: .4rem;
	}
}