@charset "UTF-8";

.secttl {
	margin-bottom: 70px;
}

.secttl .ja {
	display: block;
	font-weight: 700;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
	line-height: 1;
	padding-top: 1.6em;
	margin-top: 1em;
	position: relative;
}

.secttl .ja::before {
	content: "";
	width: 51px;
	height: 11px;
	background: url(../img/common/secttl.png) no-repeat center / auto 100%;
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	top: 0;
}

@media screen and (max-width: 768px) {
	.secttl {
		margin-bottom: 10vw;
	}

	.secttl .en img {
		width: auto;
		height: 7vw;
	}

	.secttl .ja {
		font-size: 3.6vw;
	}

	.secttl .ja::before {
		width: 10.26vw;
		height: 2.266vw;
	}

}

/* ------------------------------
    fv
------------------------------ */
#fv {
	width: 100%;
	background-size: cover;
	background-position: center top;
	position: relative;
	max-height: calc(100vh - 100px);
	overflow: hidden;
}

#fv .embedvideo {
	position: relative;
	width: 100%;
	padding-top: 56.2222%;
}

#fv .embedvideo video {
	position: absolute;
	z-index: 1;
	top: 50%;
	right: 0;
	width: 100% !important;
	height: 100% !important;
	transform: translateY(-50%);
}

#fv .scrollbtn {
	width: 47px;
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	bottom: 40px;
	z-index: 2;
}

#fv .scrollbtn a {
	display: block;
	color: #000;
	padding-top: 58px;
	transition: 0.3s ease;
}

#fv .scrollbtn a span {
	display: block;
	text-align: center;
	width: 100%;
}

#fv .scrollbtn a::before {
	content: "";
	display: block;
	width: 1px;
	height: 38px;
	background: #323232;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	margin: 0 auto;
	transition: 0.3s ease;
}


@media screen and (max-width: 768px) {
	#fv {
		max-height: calc(100vh - 50px);
	}

	#fv .embedvideo {
		padding-top: 92%;
	}

}


/* ------------------------------
    lead
------------------------------ */
#lead {
	padding: 60px 0 0;
	background-color: #ffe0e8;
	height: 426px;
	background-image: url(../img/index/lead_bg.png);
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: center;
}

#lead .txt {
	text-align: center;
	font-size: 1.6rem;
	line-height: 2.25;
	letter-spacing: 0.1em;
}

@media screen and (max-width: 768px) {
	#lead {
		padding: 35vw 0 0;
		height: 180vw;
		background-color: #ffe0e8;;
		background-image: url(../img/index/lead_bg_sp.png);
		background-size: cover;
	}

	#lead .txt {
		font-size: 3.7vw;
		line-height: 2;
	}
}

/* ------------------------------
    about
------------------------------ */
#about {
	padding: 28px 0 0;
	overflow: hidden;
	margin-bottom: 60px;
}

#about .ttlwrap {
	position: relative;
	padding: 50px 0 60px;
}

#about .ttlwrap .box + .box {
	margin-top: 50px;
}

#about .ttlwrap::before {
	content: "";
	width: calc(50% + 100px);
	height: 90%;
	background-color: #ffeff3;
	position: absolute;
	right: -100%;
	top: 8%;
	transition: 1s ease;
}

#about .ttlwrap.is-show::before {
	right: 0;
}

#about .ttlwrap .ttl {
	font-weight: 700;
	font-size: 2.4rem;
	letter-spacing: .05em;
	margin: 1.6em 0 .5em;
}

#about .ttlwrap .ttl span {
	font-size: 1.6rem;
}

#about .ttlwrap .txt {
	font-weight: 700;
	font-size: 1.6rem;
	letter-spacing: 0.15em;
	line-height: 2.25;
}

#about .ttlwrap .txt + .txt {
	margin-top: 2em;
}

#about .voice {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-top: 55px;
}

#about .voice .list {
	width: 615px;
}

#about .voice .list .item {
	width: 469px;
	height: 176px;
	padding: 30px 70px 0 40px;
	background-repeat: no-repeat;
	background-size: 100% auto;
	background-position: center;
}

#about .voice .list .item + .item {
	margin-top: 45px;
}

#about .voice .list .item:nth-child(1) {
	background-image: url(../img/index/about_voice_frame01.png);
}

#about .voice .list .item:nth-child(2) {
	margin-left: auto;
	background-image: url(../img/index/about_voice_frame02.png);
}

#about .voice .list .item:nth-child(3) {
	background-image: url(../img/index/about_voice_frame03.png);
}

#about .voice .list .item .txt {
	font-size: 2rem;
	line-height: 2;
	letter-spacing: 0.1em;
}

#about .voice .list .item .txt {
	font-size: 2rem;
	line-height: 2;
	letter-spacing: 0.1em;
	opacity: 0;
	transition: opacity 1s ease;
}

#about .voice .list .item:nth-child(1) .txt {
	transition-delay: .5s;
}

#about .voice .list .item:nth-child(2) .txt {
	transition-delay: 1.5s;
}


#about .voice .list .item:nth-child(3) .txt {
	transition-delay: 2.5s;
}


#about .voice.is-show .list .item .txt {
	opacity: 1;
}

#about .voice .imgwrap .box {
	width: 435px;
	height: 275px;
	background: url(../img/index/about_voice_frame04.png) no-repeat center / 100% auto;
	padding: 45px 70px 0 50px;
	margin-left: auto;
	margin-bottom: 26px;
}

#about .voice .imgwrap .box .txt {
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.15em;
	text-align: justify;
}

#about .voice .img_anime {
	margin-bottom: 16px;
	margin-right: 22px;
}

@media screen and (max-width: 768px) {
	#about {
		padding: 3vw 0 13vw;
		margin-bottom: 13vw;
	}

	#about .wrap {
		width: 84%;
	}

	#about .ttlwrap {
		padding: 0 0 11vw;
	}


	#about .ttlwrap::before {
		width: 81vw;
		height: 110vw;
		top: 12.2vw;
		bottom: 0;
	}

	#about .ttlwrap .ttl_en {
		width: 43vw;
	}

	#about .ttlwrap .ttl {
		font-size: 4.8vw;
		line-height: 1.66;
	}

	#about .ttlwrap .txt {
		font-size: 3.1vw;
	}

	#about .voice {
		display: block;
		margin-top: 12vw;
	}

	#about .voice .list {
		width: 100%;
	}

	#about .voice .list .item {
		width: 98%;
		height: 38.5333vw;
		padding: 5.6vw 8vw 0 8vw;
	}

	#about .voice .list .item + .item {
		margin-top: 3.33vw;
	}

	#about .voice .list .item:nth-child(1) {
		background-image: url(../img/index/about_voice_frame01_sp.png);
	}

	#about .voice .list .item:nth-child(2) {
		margin-left: 0;
		background-image: url(../img/index/about_voice_frame02_sp.png);
	}

	#about .voice .list .item:nth-child(3) {
		background-image: url(../img/index/about_voice_frame03_sp.png);
	}

	#about .voice .list .item .txt {
		font-size: 3.7vw;
	}


	#about .voice .imgwrap .box {
		width: 88.26vw;
		height: 93.06vw;
		background: none;
		padding: 10vw 9vw 0 13vw;
		margin-left: -4vw;
		margin-bottom: 0;
		margin-top: 5vw;
		position: relative;
	}

	#about .voice .imgwrap .box::before {
		content: "";
		width: 100%;
		height: 100%;
		background: url(../img/index/about_voice_frame04_sp.png) no-repeat center / 100% auto;
		position: absolute;
		left: 0;
		top: 0;
		z-index: 1;
	}

	#about .voice .imgwrap .box .txt {
		font-size: 3.2vw;
		line-height: 2;
	}

	#about .voice .img_anime {
		margin-bottom: 0;
		margin-right: 0;
	}

	#about .ttlwrap .box + .box {
		margin-top: 0;
	}
}



/* ------------------------------
    campaign
------------------------------ */
#campaign {
	padding: 85px 0 140px;
	background-color: #ffe0e8;
	background-image: url(../img/index/campaign_bg.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

#campaign .ttl {
	position: relative;
	margin-bottom: 10px;
}

#campaign .ttl::before {
	content: "";
	width: 1077px;
	height: 304px;
	background-repeat: no-repeat;
	background-image: url(../img/index/campaign_ttl_bg.png);
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	top: 0;
	opacity: 0;
	transform: scale(.75);
	transition: 2s ease;
}

#campaign .ttl.is-show::before {
	transform: scale(1);
	opacity: 1;
}

#campaign .ttl span {
	display: block;
	padding-top: 10px;
	position: relative;
}

#campaign .date {
	text-align: center;
	margin-bottom: 36px;
}

#campaign .datewrap {
	display: inline-block;
	position: relative;
	padding: 38px 82px 0;
}

#campaign .datewrap::before,
#campaign .datewrap::after {
	content: "";
	width: 68px;
	height: 74px;
	background-repeat: no-repeat;
	background-size: 100% auto;
	background-image: url(../img/index/campaign_date_bg.png);
	position: absolute;
	top: 0;
	opacity: 0;
	transition: opacity .3s ease;
	transition-delay: 1s;
}

#campaign .datewrap::before {
	left: 0;
}

#campaign .datewrap::after {
	right: 0;
	transform: scale(-1, 1);
}

#campaign .is-show .datewrap::before,
#campaign .is-show .datewrap::after {
	opacity: 1;
}

#campaign .date span {
	width: 155px;
	height: 41px;
	line-height: 41px;
	background-color: #323232;
	color: #fff;
	text-align: center;
	font-size: 1.6rem;
	position: relative;
	display: inline-block;
	margin-right: 20px;
	vertical-align: middle;
}

#campaign .date span::before {
	content: "";
	width: calc(100% - 6px);
	height: calc(100% - 6px);
	border: 1px solid #fff;
	position: absolute;
	left: 3px;
	top: 3px;
}


#campaign .txtwrap .txt {
	font-size: 1.8rem;
	line-height: 2;
	letter-spacing: 0.15em;
}

#campaign .txtwrap .note {
	font-size: 1.4rem;
	line-height: 1.7;
	letter-spacing: 0.15em;
	margin-top: 1.5em;
}


@media screen and (max-width: 768px) {
	#campaign {
		padding: 3.7vw 0 20vw;
	}

	#campaign .ttl {
		margin-bottom: 2.6vw;
		height: 73.33vw;

	}

	#campaign .ttl::before {
		width: 94.8vw;
		height: 73.33vw;
		background-image: url(../img/index/campaign_ttl_bg_sp.png);
		background-size: 100% auto;
		left: -.4vw;
	}

	#campaign .ttl span {
		padding-top: 9.6vw;
	}

	#campaign .date {
		margin-bottom: 6vw;
	}

	#campaign .datewrap {
		display: block;
		padding: 4vw 4vw 0;
	}

	#campaign .datewrap::before,
	#campaign .datewrap::after {
		width: 10.4vw;
		height: 11.2vw;
	}

	#campaign .datewrap::before {
		left: 16vw;
	}

	#campaign .datewrap::after {
		right: 16vw;
	}


	#campaign .date span {
		width: 31vw;
		height: 8.2vw;
		line-height: 8.2vw;
		font-size: 3.2vw;
		margin: 0 auto 4vw;
		display: block;
	}

	#campaign .date span::before {
		width: calc(100% - 2vw);
		height: calc(100% - 2vw);
		left: 1vw;
		top: 1vw;
	}

	#campaign .date img {
		width: 100%;
	}


	#campaign .txtwrap .txt {
		font-size: 3.6vw;
	}

	#campaign .txtwrap .note {
		font-size: 2.8vw;
		text-align: left;
	}

}






/* ------------------------------
    sec_app
------------------------------ */
#sec_app {
	height: 667px;
	background: url(../img/index/app_bg.jpg) no-repeat center / cover;

}

#sec_app .frame {
	position: relative;
	margin: 0 auto;
	padding: 63px 0 32px;
	top: -78px;
}

#sec_app .frame::before,
#sec_app .frame::after {
	content: "";
	width: 100%;
	position: absolute;
	background-repeat: no-repeat;
	background-size: 100% auto;
	left: 0;
}

#sec_app .frame::before {
	height: 63px;
	background-image: url(../img/index/app_frame_top.png);
	top: 0;
	z-index: 1;
}

#sec_app .frame::after {
	height: 32px;
	background-image: url(../img/index/app_frame_bottom.png);
	bottom: 0;
	z-index: 1;
}

#sec_app .frame .inner {
	padding: 10px 76px;
	background-image: url(../img/index/app_frame.png);
	background-repeat: repeat-y;
}

#sec_app .frame .inner > .ttl {
	text-align: center;
	margin-bottom: 30px;
}

#sec_app .frame .inner .ttl .logo {
	width: 396px;
}

#sec_app .frame .inner .ttl .txt {
	font-weight: 700;
	font-size: 3.8rem;
	letter-spacing: 0.1em;
	margin-left: .5em;
}


#sec_app .app_info {
	display: flex;
	align-items: center;
	margin-bottom: 2.5rem;
}

#sec_app .app_info .img {
	margin-left: -40px;
	margin-bottom: -10px;
}

#sec_app .app_info .txtwrap {
	flex: 1;
}

#sec_app .app_info .txtwrap .infottl {
	position: relative;
	text-align: center;
	font-weight: 700;
	font-size: 2.8rem;
	letter-spacing: 0.16em;
	line-height: 1;
	margin-bottom: .7em;
}

#sec_app .app_info .txtwrap .infottl::before,
#sec_app .app_info .txtwrap .infottl::after {
	content: "";
	width: 48px;
	height: 1em;
	background: url(../img/common/application_ttl.png) no-repeat center / 100% auto;
	position: absolute;
	bottom: 0;
}

#sec_app .app_info .txtwrap .infottl::before {
	left: 0;
}

#sec_app .app_info .txtwrap .infottl::after {
	right: 0;
}

#sec_app .app_info .txtwrap .list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#sec_app .app_info .txtwrap .list li {
	display: flex;
	align-items: center;
	width: 358px;
}

#sec_app .app_info .txtwrap .ico {
	margin-right: 13px;
}

#sec_app .app_info .txtwrap .detail {
	flex: 1;
}


#sec_app .app_info .txtwrap .detail .ttl {
	font-weight: 700;
	font-size: 2.2rem;
	letter-spacing: 0.2em;
	margin-bottom: .4em;
}


#sec_app .app_info .txtwrap .detail .ttl span {
	font-weight: 500;
	color: #cccccc;
	font-size: 4.4rem;
	letter-spacing: 0.08em;
}

#sec_app .app_info .txtwrap .detail .txt {
	font-size: 1.6rem;
	line-height: 1.625;
	letter-spacing: 0.1em;
}


#sec_app .benefits .benefitsttl {
	position: relative;
	text-align: center;
	font-weight: 700;
	font-size: 2.8rem;
	letter-spacing: 0.1em;
	line-height: 1;
	margin-bottom: .7em;
	margin-bottom: .35em;
}

#sec_app .benefits .benefitsttl::before,
#sec_app .benefits .benefitsttl::after {
	content: "";
	width: 287px;
	height: 1em;
	background: url(../img/common/application_ttl2.png);
	background-repeat: no-repeat;
	background-position: left center;
	position: absolute;
	bottom: 0;
}

#sec_app .benefits .benefitsttl::before {
	left: 0;
}

#sec_app .benefits .benefitsttl::after {
	right: 0;
}

#sec_app .benefits > .flex {
	align-items: center;
	justify-content: space-between;
}

#sec_app .benefits .imgwrap {
	width: 488px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#sec_app .benefits .imgwrap .txt {
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.05em;
}

#sec_app .benefits .download {
	display: flex;
	width: 420px;
	justify-content: space-between;
}

#sec_app .benefits .download .app_list li + li {
	margin-top: 13px;
}


#sec_app .benefits .note {
	display: flex;
	align-items: center;
	width: 480px;
}

#sec_app .benefits .note .notettl {
	width: 52px;
	height: 70px;
	text-align: center;
	font-size: 1.6rem;
	letter-spacing: 0.08em;
	margin-right: .8em;
	display: flex;
	align-items: center;
	justify-content: center;
	border-top: 1px solid #323232;
	border-bottom: 1px solid #323232;
}

#sec_app .benefits .note .txt {
	flex: 1;
	font-size: 1.4rem;
	line-height: 1.57;
	letter-spacing: 0.08em;
}

@media screen and (min-width: 769px) {
	#sec_app .app_info .txtwrap .list li:nth-child(n + 3) {
		margin-top: 20px;
	}
}


@media screen and (max-width: 768px) {
	#sec_app {
		height: auto;
		background: url(../img/index/app_bg_sp.jpg) repeat-y center / 100% auto;
	}

	#sec_app::after {
		content: "";
		width: 100%;
		height: 28vw;
		background-color: #fff;
		position: absolute;
		left: 0;
		bottom: -1px;
		z-index: 1;
	}

	#sec_app .frame {
		padding: 11.866vw 0 6.8vw;
		top: -16.53vw;
		z-index: 2;
	}


	#sec_app .frame::before {
		height: 11.866vw;
		background-image: url(../img/index/app_frame_top_sp.png);
		background-size: 100% auto;
	}

	#sec_app .frame::after {
		height: 6.8vw;
		background-image: url(../img/index/app_frame_bottom_sp.png);
		background-size: 100% auto;
	}

	#sec_app .frame .inner {
		padding: 1.8vw 5.4vw;
		background-image: url(../img/index/app_frame_sp.png);
		background-size: 100% auto;
	}

	#sec_app .frame .inner > .ttl {
		margin-bottom: 10vw;
	}

	#sec_app .frame .inner .ttl .logo {
		display: block;
		width: 73vw;
		margin: 0 auto 4.5vw;
	}

	#sec_app .frame .inner .ttl .txt {
		font-size: 6.93vw;
		display: block;
		margin-left: 0;
	}


	#sec_app .app_info {
		display: block;
		position: relative;
		padding: 6vw 0 0;
		margin-bottom: 0;
	}

	#sec_app .app_info .img {
		width: 43.7vw;
		margin-left: -3vw;
		margin-bottom: 0;
		position: absolute;
		left: 0;
		top: 0;
	}


	#sec_app .app_info .txtwrap .infottl {
		width: 42vw;
		margin-left: 37vw;
		font-size: 5.6vw;
		line-height: 1.47;
		margin-bottom: 17vw;
		padding: 5.6vw 0;
		text-align: left;
		white-space: nowrap;
	}

	#sec_app .app_info .txtwrap .infottl::before,
	#sec_app .app_info .txtwrap .infottl::after {
		width: 100%;
		height: 2.8vw;
		background: url(../img/common/application_ttl.png) repeat-x center / auto 100%;
		bottom: 0;
	}

	#sec_app .app_info .txtwrap .infottl::before {
		bottom: auto;
		top: 0;
	}


	#sec_app .app_info .txtwrap .list {
		display: block;
		padding: 0 5vw;
	}

	#sec_app .app_info .txtwrap .list li {
		width: 100%;
	}

	#sec_app .app_info .txtwrap .list li + li {
		margin-top: 6.66vw;
	}

	#sec_app .app_info .txtwrap .ico {
		width: 19.33vw;
		margin-right: 2vw;
	}

	#sec_app .app_info .txtwrap .detail .ttl {
		font-size: 4.4vw;
	}


	#sec_app .app_info .txtwrap .detail .ttl span {
		font-size: 8.8vw;
	}

	#sec_app .app_info .txtwrap .detail .txt {
		font-size: 3.2vw;
	}


	#sec_app .benefits {
		padding: 0 1vw;
	}

	#sec_app .benefits .benefitsttl {
		font-size: 5vw;
	}

	#sec_app .benefits .benefitsttl::before,
	#sec_app .benefits .benefitsttl::after {
		width: 7vw;
		height: .66em;
		background: url(../img/common/application_ttl2.png);
		background-size: auto 100%;
		top: .22em;
	}

	#sec_app .benefits .benefitsttl::before {
		left: 2vw;
	}

	#sec_app .benefits .benefitsttl::after {
		right: 2vw;
	}

	#sec_app .benefits > .flex {
		display: block;
	}

	#sec_app .benefits .imgwrap {
		width: 100%;
		margin-top: 5.3vw;
	}

	#sec_app .benefits .imgwrap .img {
		width: 32vw;
		margin-right: 2vw;
	}

	#sec_app .benefits .imgwrap .txt {
		font-size: 3.2vw;
		flex: 1;
		letter-spacing: 0;
	}

	#sec_app .benefits .download {
		margin-top: 8vw;
		width: 100%;
	}

	#sec_app .benefits .download .app_list li {
		width: 31vw;
	}

	#sec_app .benefits .download .app_list li + li {
		margin-top: 2vw;
	}

	#sec_app .benefits .download .qr {
		width: 46.2vw;

	}


	#sec_app .benefits .note {
		margin-top: 5vw;
	}

	#sec_app .benefits .note .notettl {
		width: 10.4vw;
		font-size: 3.2vw;
	}

	#sec_app .benefits .note .txt {
		font-size: 2.8vw;
		letter-spacing: 0.05em;
	}

	#sec_app .benefits .note {
		width: 100%;
	}

}


/* ------------------------------
    shop
------------------------------ */
.shop {
	padding: 140px 0 0;
}

.shop .shop_wrap {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 0;
}

.shop .shop_wrap .img {
	width: 542px;
}

.shop .shop_wrap .txtwrap {
	width: 510px;
}

.shop .shop_wrap .txtwrap .name {
	font-weight: 700;
	font-size: 2rem;
	letter-spacing: 0.14em;
	position: relative;
	line-height: 1.4;
	padding-top: .2em;
	padding-bottom: .6em;
	margin-bottom: .2em;
}

.shop .shop_wrap .txtwrap .name::before {
	content: "";
	width: 0;
	height: 1px;
	background-color: #323232;
	position: absolute;
	left: -100px;
	bottom: 0;
	transition: .5s ease;
}

.shop .shop_wrap .txtwrap.is-show .name::before {
	width: 610px;
}


.shop .shop_wrap .txtwrap .name .ico {
	margin-left: 8px;
	position: relative;
	top: -3px;
}

.shop .shop_wrap .txtwrap .name .ico img {
	vertical-align: middle;
	width: 25px;
}

.shop .shop_wrap .txtwrap .info {
	display: flex;
	flex-wrap: wrap;
}

.shop .shop_wrap .txtwrap .info dt,
.shop .shop_wrap .txtwrap .info dd {
	font-size: 1.6rem;
	line-height: 1.625;
	letter-spacing: 0.15em;
	margin-top: .65em;
}

.shop .shop_wrap .txtwrap .info dt {
	width: 5.5em;
}


.shop .shop_wrap .txtwrap .info dd {
	width: calc(100% - 5.5em);
}

.shop .shop_wrap .txtwrap .info dd .maplink {
	display: inline-block;
	color: #eb9ab4;
	text-decoration: underline;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	padding-right: 1.5em;
	position: relative;
	transition: .3s ease;
}

.shop .shop_wrap .txtwrap .info dd .maplink::before {
	content: "";
	width: 12px;
	height: 12px;
	background: url(../img/index/ico_blank.png) no-repeat;
	position: absolute;
	right: 0;
	top: .4em;
	transition: .3s ease;
}


.shop .shop_wrap .txtwrap .info dd .maplink:hover {
	color: #e26b91;
}


.shop .shop_wrap .txtwrap .info dd .maplink:hover::before {
	background: url(../img/index/ico_blank_hover.png) no-repeat;
}

.shop .box-shop:not(:first-child) .shop_wrap {
	margin-top: 100px;
}

@media screen and (min-width: 769px) {
	.shop .secttl {
		margin-bottom: -28px;
	}
	.shop .shop_wrap {
		margin-bottom: 60px;
	}
}

@media screen and (max-width: 768px) {
	.shop {
		padding: 0;
	}

	.shop .wrap {
		width: 100%;
	}

	.shop .shop_wrap {
		display: block;
		padding-bottom: 0;
		margin-bottom: 12vw;
	}

	.shop .shop_wrap + .shop_wrap {
		margin-top: 0;
	}

	.shop .shop_wrap .img {
		width: 100%;
		margin-bottom: 2.8vw;
	}

	.shop .shop_wrap .txtwrap {
		width: 100%;
		padding: 0 8vw;
	}

	.shop .shop_wrap .txtwrap .name {
		font-size: 4vw;
		line-height: 1.66;
		padding: 2.5vw 0;
		position: relative;
	}

	.shop .shop_wrap .txtwrap .name::before {
		left: -8vw;
	}

	.shop .shop_wrap .txtwrap.is-show .name::before {
		width: calc(100% + 8vw);
	}


	.shop .shop_wrap .txtwrap .name .ico {
		width: 7.7vw;
		margin-left: 0;
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%);
	}

	.shop .shop_wrap .txtwrap .name .ico img {
		width: 100%;
	}

	.shop .shop_wrap .txtwrap .info dt,
	.shop .shop_wrap .txtwrap .info dd {
		font-size: 3.2vw;
	}


	.shop .shop_wrap .txtwrap .info dd .maplink {
		font-size: 2.8vw;
	}

	.shop .shop_wrap .txtwrap .info dd .maplink::before {
		width: 2.4vw;
		height: 2.4vw;
		background-size: 100% auto;
		top: .5em;
	}

	.shop .shop_wrap--amu {
		padding-top: 13vw;
	}
	.shop .box-shop:not(:first-child) .shop_wrap {
		margin-top: 16vw;
	}
}




/* ------------------------------
    instagram
------------------------------ */
.instagram {
	padding: 48px 0 65px;
	background-color: #ffe0e8;
	background-image: url(../img/index/instagram_bg.png);
	background-position: center top;
}

.instagram .ico img {
	width: 25px;
	height: 25px;
	margin-right: 15px;
}

.instagram .ico a {
	font-size: 2rem;
	display: flex;
	align-items: center;
	font-weight: bold;
	color: #323232;
}

.instagram .ico a span {
	margin-top: -.3em;
	letter-spacing: .15em;
}

.instagram .ico a {
	transform: translateY(-2px);
}

.instagram .txtwrap {
	width: 670px;
	margin: 0 auto;
	position: relative;
}

.instagram .txtwrap .shop_name {
	font-size: 1.6rem;
	letter-spacing: 0.02em;

}

.instagram .txtwrap .ttl {
	font-weight: 700;
	font-size: 5.5rem;
	letter-spacing: 0.1em;
	line-height: 1;
	margin: .3em 0 .5em;
}

.instagram .txtwrap .ttl .ico {
	margin-right: .4em;
	position: relative;
	top: .1em;
}

.instagram .txtwrap .fukidashi {
	position: absolute;
	width: 129px;
	height: 53px;
	right: 40px;
	top: -10px;
	padding-top: 17px;
	text-align: center;
}

.instagram .txtwrap .fukidashi::before {
	content: "";
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-size: 100% auto;
	background-image: url(../img/index/fukidashi.png);
	position: absolute;
	left: 0;
	top: 0;
	transform: scale(0);
	transition: .5s ease;
	transform-origin: center;
	transition-delay: 1s !important;
}

.instagram .txtwrap.is-show .fukidashi::before {
	transform: scale(1);
}

.instagram .txtwrap .subttl {
	font-weight: 700;
	font-size: 2.4rem;
	letter-spacing: 0.1em;
	margin-bottom: .8em;
}


.instagram .txtwrap .txt {
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.1em;
}

.instagram .list {
	width: 100%;
	margin: 36px auto 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.instagram .list li {
	width: 257px;
	height: 257px;
}

.instagram .list li a {
	display: block;
	width: 100%;
	height: 100%;
	transition: .4s ease;
}

.instagram .list li a:hover {
	opacity: .8;
}

.instagram .list li figure {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
}

.instagram .btn {
	margin-top: 70px;
}

@media screen and (max-width: 768px) {
	.instagram {
		padding: 8.9vw 0 6vw;
		background-size: 38.66vw auto;
		background-position: -27vw 10vw;
	}

	.instagram .wrap {
		padding: 0 8vw;
	}

	.instagram .txtwrap {
		width: 100%;
		padding: 0 4vw;
	}

	.instagram .txtwrap .shop_name {
		font-size: 3.2vw;

	}

	.instagram .txtwrap .ttl {
		font-size: 9vw;
		letter-spacing: 0.05em;
	}

	.instagram .txtwrap .ttl .ico {
		display: inline-block;
		width: 9vw;
		margin-right: .2em;
	}

	.instagram .txtwrap .fukidashi {
		position: relative;
		top: 0;
		right: 0;
		width: 25vw;
		height: 10.4vw;
		margin: 0 auto 3vw;
		padding-top: 3vw;
		text-align: center;
	}

	.instagram .txtwrap .fukidashi img {
		width: 18vw;
	}

	.instagram .txtwrap .subttl {
		font-size: 4.8vw;
		line-height: 1.55;
	}


	.instagram .txtwrap .txt {
		font-size: 3.2vw;
	}

	.instagram .list {
		width: 100%;
		margin: 6.66vw auto 0;
	}


	.instagram .list li {
		width: 48%;
    	height: 39vw;
		margin-bottom: 4%;
	}

	.instagram .btn {
		margin-top: 9.33vw;
	}

	.instagram .ico span {
		font-size: 1.6rem;
		letter-spacing: .025em !important;
	}

	.instagram .ico img {
		width: 20px;
		height: 20px;
		margin-right: 10px;
	}
}


/* ------------------------------
    brand
------------------------------ */
#brand {
	padding: 86px 0 120px;
	background-color: #fff6f8;
}

#brand .brand_list {
	display: flex;
	flex-wrap: wrap;
	position: relative;
}

#brand .brand_list .item {
	width: 251px;
}

#brand .brand_list .item .logo {
	margin-bottom: 10px;
	min-height: 150px;
}

#brand .brand_list .item .logo img {
	box-shadow: 0 0 20px rgba(0, 0, 0, .2);
}

#brand .brand_list .item .info {
	opacity: 0;
	transition: opacity 1s;
}

#brand .brand_list.is-show .item .info {
	opacity: 1;
}


#brand .brand_list .item .info .name {
	font-weight: 500;
	font-size: 2rem;
	line-height: 1.77;
	letter-spacing: 0.15em;
	font-feature-settings: "palt";
	padding-bottom: .3em;
	margin-bottom: .3em;
	border-bottom: 1px solid #323232;
}

#brand .brand_list .item .info .txt {
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.18em;
	font-feature-settings: "palt";
}

#brand .brand_list .item .info .txt span {
	font-size: 1.3rem;
}

#brand .brand_list .img {
	margin-left: auto;
	margin-top: auto;
	margin-right: 15px;
	margin-bottom: 24px;
}

/* #brand .brand_list .img {
	position: absolute;
	right: 12px;
	bottom: 54px;
} */

#event-personal-color {
	padding-top: 70px;
}

#event-personal-color .wrap {
	background: url(../img/index/event-personal_pc.png) no-repeat center top;
	height: 0;
  padding-top: 890px;
	overflow: hidden;
}

@media screen and (min-width: 769px) {
	#brand .brand_list .item + .item:not(:nth-child(4n + 1)) {
		margin-left: 32px;
	}

	#brand .brand_list .item:nth-child(n + 5) {
		margin-top: 40px;
	}

	#brand .brand_list .item:nth-child(1) {}
}

@media screen and (max-width: 768px) {
	#brand {
		padding: 13vw 0;
	}

	#brand .brand_list {
		padding: 0 4vw;
	}

	#brand .brand_list .item {
		width: 47%;
		min-height: 60vw;
	}

	#brand .brand_list .item:nth-child(7) {
		min-height: initial;
	}

	#brand .brand_list .item:nth-child(even) {
		margin-left: 6%;
	}

	#brand .brand_list .item:nth-child(n + 3) {
		margin-top: 8vw;
	}

	#brand .brand_list .item .logo {
		box-shadow: 0 0 2.6vw rgba(0, 0, 0, .2);
		margin-bottom: 2.6vw;
		min-height: initial;
	}

	#brand .brand_list .item .info .name {
		font-size: 3.9vw;
	}

	#brand .brand_list .item .info .txt {
		font-size: 3.2vw;
		letter-spacing: 0.19em;
	}

	#brand .brand_list .item .info .txt span {
		font-size: 2.8vw;
		letter-spacing: 0.1em;
		line-height: 1.5;
        display: inline-block;
	}

	#brand .brand_list .img {
		width: 31vw;
        right: 6vw;
        margin-left: auto;
        margin-top: auto;
        margin-right: 3vw;
		margin-bottom: 0;
	}

	#brand .secttl {
		margin-bottom: 13vw;
	}

	#brand .item.delay6 {
		margin-top: 0;
	}

	#brand .item .second-line-indent {
		text-indent: 1em;
		display: inline-block; /* text-indentを適用するために必要 */
	}

	#event-personal-color {
		padding-top: 35px;
	}
	#event-personal-color .wrap {
		background: url(../img/index/event-personal_sp.png) no-repeat center top;
		background-size: 100%;
		padding-top: 333vw;
	}
}
