@charset "UTF-8";



/* -------------------------------------------

layout

------------------------------------------- */
/* ---- right ---- */
.right {
	width: calc(80% - 600px);
	height: 100%;
	position: fixed;
	right: 0;
	top: 0;
}
.right > div {
	position: absolute;
	left: 0;
	top: 0;
	padding: 3.5rem;
	display: flex;
	flex-direction: column;
}
/* logo */
.right .logo {
	width: 10vw;
}
@media screen and (min-width: 1401px) {
	.right .logo {
		width: 16rem;
	}
}
/* nav */
.right nav {
	padding-left: 1rem;
	margin: 1vw 0 0.5vw 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.right nav ul li a {
	display: flex;
	align-items: center;
	font-weight: 500;
	font-size: 1.1vw;
}
.right nav ul li a i {
	color: var(--orange);
	font-size: 0.8vw;
	margin-top: 0.15rem;
	margin-right: 0.8rem;
}
.right nav ul li:not(:last-child) {
	margin-bottom: 0.4rem;
}
@media screen and (min-width: 1401px) {
	.right nav ul li a {
		font-size: 1.7rem;
	}
}
/* sns */
.right .sns {
	display: flex;
	margin-top: 1.5vw;
}
.right .sns li {
	width: 2vw;
}
.right .sns li:not(:last-child) {
	margin-right: 1rem;
}
/* cv */
.cv a {
	background: url(../img/arrow-1.png) no-repeat center right 1.5vw;
	background-size: 1.5vw;
	background-color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 18vw;
	height: 4.8vw;
	color: var(--orange);
	font-family: var(--font-shippori);
	font-size: 1.6vw;
	border-radius: 2.5vw 0 2.5vw 0;
	margin: 1.5rem 0 1rem 0;
	border: solid 0.1rem var(--orange);
}
.cv li:last-child a {
	box-shadow: 0.1rem 0.15rem 0.6rem rgba(0, 0, 0, 0.25);
	background: url(../img/arrow-2.png) no-repeat center right 1.5vw;
	background-size: 1.5vw;
	background-color: var(--orange);
	color: #fff;
}
@media screen and (min-width: 1401px) {
	.cv a {
		background: url(../img/arrow-1.png) no-repeat center right 2.5rem;
		background-size: 2.5rem;
		width: 30rem;
		height: 8rem;
		font-size: 2.4rem;
		border-radius: 4rem 0 4rem 0;
		background-color: #fff;
	}
	.cv li:last-child a {
		background: url(../img/arrow-2.png) no-repeat center right 2.5rem;
		background-size: 2.5rem;
		background-color: var(--orange);
	}
}
/* ---- contents ---- */
.contents {
	width: 600px;
	margin-left: 20%;
	position: relative;
	z-index: 10;
}
@media screen and (max-width: 1120px) {
	.right {
		display: none;
	}
	.contents {
		margin-left: calc((100% - 600px) / 2);
	}
}
@media screen and (max-width: 600px) {
	.contents {
		width: auto;
		margin-left: 0;
	}
}



/* -------------------------------------------

kv

------------------------------------------- */
.kv {
	position: relative;
}
/* ---- h1 ----  */
h1 {
	position: absolute;
	left: 3rem;
	top: 2rem;
	width: 20rem;
	z-index: 10;
}
@media screen and (max-width: 600px) {
	h1 {
		left: 1rem;
		top: 1rem;
		width: 14rem;
	}
}
.btn-purchase {
	position: fixed;
	left: calc(20% + (600px - 11rem));
	top: 1rem;
	width: 10rem;
	z-index: 999;
}
.btn-purchase a > img:nth-of-type(2) {
	display: none;
}
@media screen and (max-width: 1120px) {
	.btn-purchase {
		position: fixed;
		left: auto;
		right: calc(((100% - 600px) / 2) + 6rem);
		top: 0;
		width: 6rem;
		height: 6rem;
		z-index: 999;
	}
	.btn-purchase a > img:nth-of-type(1) {
		display: none;
	}
	.btn-purchase a > img:nth-of-type(2) {
		display: block;
	}
}
@media screen and (max-width: 600px) {
	.btn-purchase {
		left: auto;
		right: 6rem;
		top: 0;
		width: 6rem;
	}
}
/* ---- wrap-1 ---- */
.kv .wrap-1 {
	background: url(../img/kv-bg.jpg) no-repeat right top;
	background-size: auto 100%;
	background-color: #fff;
	padding-bottom: 1rem;
}
.kv .wrap-1 figure {
	width: 83%;
}
.kv .wrap-1 {
	position: relative;
	display: flex;
	flex-direction: column;
}

.kv .wrap-1  a {
	z-index: 1;
	position: absolute;
	align-self: center;
	transform: translateY(50%);
	bottom: 0;
	padding: 1.4rem 1.8rem;
	border-radius: 36px;
	background: #E96445;
	box-shadow: 0px 6px 6px 0px rgba(0, 0, 0, 0.25);
	
	color: #FFFEFA;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 2.5rem;
	line-height: 100%;
	font-style: normal;
	font-weight: 700;
	letter-spacing: 0.3rem;
}
@media screen and (max-width: 600px) {
	.kv .wrap-1 a {
		font-size: 1.8rem;
	}
}

.kv .wrap-1 p {
	font-size: 2.4rem;
	padding: 3rem 0 3rem 4rem;
}
@media screen and (max-width: 600px) {
	.kv .wrap-1 p {
		font-size: 2rem;
	}
}
/* ---- wrap-2 ---- */
.kv .wrap-2 {
	background: #fff;
	padding: 4rem 4rem 15rem 4rem;
}
.kv .wrap-2 ul {
	display: flex;
	justify-content: space-between;
	margin-bottom: 3rem;
}
.kv .wrap-2 ul li {
	width: 16rem;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.kv .wrap-2 ul li > div {
	width: 16rem;
	height: 16rem;
	border: solid 0.2rem var(--green);
	border-radius: 50%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.kv .wrap-2 ul li > div > span:nth-child(1) {
	font-size: 2.4rem;
	text-align: center;
	line-height: 1.2;
}
.kv .wrap-2 .num {
	color: var(--green);
	font-family: var(--font-shippori);
	font-size: 2.4rem;
	line-height: 1;
}
.kv .wrap-2 .num i {
	font-size: 4rem;
}
.kv .wrap-2 .note {
	text-align: center;
	margin-top: 0.5rem;
}
.kv .wrap-2 > div {
	background: var(--orange);
	color: #fff;
	border-radius: 4rem 0 4rem 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.4rem;
	line-height: 1;
	padding: 1.5rem 0;
	letter-spacing: 0.1em;
}
.kv .wrap-2 > div span {
	font-family: var(--font-shippori);
	font-size: 3.6rem;
	margin-bottom: 0.5rem;
}
@media screen and (max-width: 600px) {
	.kv .wrap-2 {
		background: #fff;
		padding: 4rem 0 15rem 0;
	}
	.kv .wrap-2 ul {
		padding: 0 1.5rem;
	}
	.kv .wrap-2 ul li {
		width: 12rem;
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	.kv .wrap-2 ul li > div {
		width: 12rem;
		height: 12rem;
	}
	.kv .wrap-2 ul li > div > span:nth-child(1) {
		font-size: 1.8rem;
	}
	.kv .wrap-2 .note {
		font-size: 1.1rem;
		line-height: 1.4;
	}
	.kv .wrap-2 > div {
		width: calc(100% - 4rem);
		margin: 0 auto;
		font-size: 2rem;
	}
}



/* -------------------------------------------

about

------------------------------------------- */
.about {
	position: relative;
	background: url(../img/about-bg.jpg) no-repeat center / cover;
	padding-bottom: 15rem;
}
/* ---- deco ---- */
.about .deco-1 {
	position: absolute;
	left: 12rem;
	top: -6rem;
	width: 8rem;
}
@media screen and (max-width: 600px) {
	.about .deco-1 {
		left: 2.5rem;
		top: -4rem;
	}
}
/* ---- h2 ---- */
.about h2 .jp {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}
.about h2 .jp img {
	width: 3rem;
	margin-top: -1rem;
	margin-left: 1rem;
}
/* ---- p ---- */
.about h2 + p {
	padding: 0 4rem;
	font-size: 2.8rem;
	text-shadow: 0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff;
	position: relative;
	z-index: 10;
}
@media screen and (max-width: 600px) {
	.about h2 + p {
		font-size: 2.4rem;
	}
}
/* ---- figure ---- */
.about > figure {
	width: 70%;
	margin-top: -4rem;
	margin-left: auto;
	margin-bottom: 5rem;
}
@media screen and (max-width: 600px) {
	.about > figure {
		width: 80%;
		margin-top: -6rem;
	}
}
/* ---- ul ---- */
.about > ul {
	padding: 0 4rem 4rem 4rem;
}
.about > ul li {
	background: #fff;
	position: relative;
	padding: 3rem 0;
	text-align: center;
	font-size: 2.8rem;
}
.about > ul li:not(:last-child) {
	margin-bottom: 3rem;
}
.about > ul li span {
	display: block;
	font-size: 2rem;
	margin-top: 0.5rem;
}
.about > ul li > img {
	display: block;
	position: absolute;
}
.about > ul li:first-child img {
	width: 10rem;
	right: -1rem;
	top: -2rem
}
.about > ul li:last-child img:nth-of-type(1) {
	width: 7rem;
	right: -2rem;
	top: -3rem
}
.about > ul li:last-child img:nth-of-type(2) {
	width: 10rem;
	left: -2rem;
	bottom: -2rem
}
@media screen and (max-width: 600px) {
	.about > ul {
		padding: 0 3rem 3rem 3rem;
	}
	.about > ul li {
		padding: 3rem 0;
		font-size: 2rem;
	}
	.about > ul li span {
		font-size: 1.6rem;
	}
	.about > ul li > img {
		display: block;
		position: absolute;
	}
	.about > ul li:last-child img:nth-of-type(2) {
		width: 8rem;
		left: -2rem;
		bottom: -2rem
	}
}
/* ---- slide ---- */
.about-slide > p {
	background: var(--bg-grey);
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 3rem 0 1rem 0;
	font-size: 1.8rem;
}
.about-slide > p img {
	width: 18rem;
	margin-bottom: 0.5rem;
}
.about-slide .wrap {
	padding: 4rem 0 4rem 4rem;	
	background: #dce5ea;
	margin: 4rem 0 4rem 4rem;
}
/* ---- div ---- */
.about-slide + div {
	position: relative;
	font-family: var(--font-shippori);
	font-size: 3.4rem;
	text-align: center;
	line-height: 1.4;
	padding-bottom: 6rem;
}
.about-slide + div > img {
	display: block;
	position: absolute;
	z-index: -1;
}
.about-slide + div > img:nth-of-type(1) {
	width: 12rem;
	left: 3rem;
	bottom: 4rem;
}
.about-slide + div > img:nth-of-type(2) {
	width: 5.5rem;
	right: 4rem;
	top: -2rem;
}
@media screen and (max-width: 600px) {
	.about-slide + div {
		font-size: 2.8rem;
	}
	.about-slide + div > img:nth-of-type(1) {
		width: 10rem;
		left: 1rem;
		bottom: 3rem;
	}
	.about-slide + div > img:nth-of-type(2) {
		width: 4.5rem;
		right: 1.5rem;
		top: -2rem;
	}
}



/* -------------------------------------------

point

------------------------------------------- */
.point {
	background: #fff;
}
/* ---- ul ---- */
.point ul {
	background: var(--bg-grey);
	padding: 7rem 0 15rem 0;
}
.point ul li {
	padding: 6rem 0 8rem 0;
}
@media screen and (max-width: 600px) {
	.point ul li {
		padding: 6rem 0 4rem 0;
	}
}
.point ul li:not(:last-child) {
	margin-bottom: 8rem;
}
@media screen and (max-width: 600px) {
	.point ul li:not(:last-child) {
		margin-bottom: 5rem;
	}
}
.point ul li::before {
	content: "";
	width: calc(100% - 4rem);
	height: 100%;
	background: #fff;
	position: absolute;
	top: 0;
	z-index: -1;
}
.point ul li:nth-child(odd)::before {
	right: 0;
	border-radius: 10rem 0 0 0;
}
.point ul li:nth-child(even)::before {
	left: 0;
	border-radius: 0 10rem 0 0;
}
/* ---- num ---- */
.point .num {
	position: absolute;
	line-height: 1;
	color: var(--green);
	font-family: var(--font-raleway);
	font-size: 10rem;
	top: -5.5rem;
	font-weight: 200;
	letter-spacing: 0.1em;
}
.point ul li:nth-child(odd) .num {
	left: 2.5rem;
}
.point ul li:nth-child(even) .num {
	right: 2.5rem;
}
@media screen and (max-width: 600px) {
	.point .num {
		font-size: 8rem;
		top: -3rem;
	}
}
/* ---- h3 ---- */
.point h3 {
	font-weight: normal;
	font-size: 3.8rem;
	font-family: var(--font-shippori);
	line-height: 1.4;
	position: relative;
	z-index: 10;
	margin-left: 11rem;
	text-shadow: 0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff;
}
@media screen and (max-width: 600px) {
	.point h3 {
		font-size: 2.8rem;
		margin-left: 8rem;
	}
}
/* ---- figure ---- */
.point figure {
	width: 83%;
	margin-top: -4.5rem;
	margin-bottom: 2rem;
}
.point li:nth-child(even) figure {
	margin-left: auto;
}
@media screen and (max-width: 600px) {
	.point figure {
		width: 90%;
		margin-top: -2.5rem;
	}
}
/* ---- dl ---- */
.point li:nth-child(odd) dl {
	padding-left: 7rem;
	padding-right: 17%;
}
.point li:nth-child(even) dl {
	padding-right: 7rem;
	padding-left: 17%;
}
.point dt {
	border: solid 0.2rem var(--green);
	color: var(--green);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	font-size: 2.8rem;
	height: 8.6rem;
	margin-bottom: 2rem;
	width: 100%;
	line-height: 1.2;
	padding-bottom: 0.15rem;
}
.point dd {
	font-size: 2.2rem;
}
@media screen and (max-width: 600px) {
	.point li:nth-child(odd) dl {
		padding-right: 3rem;
	}
	.point li:nth-child(even) dl {
		padding-left: 4rem;
	}
	.point dt {
		font-size: 2.4rem;
		height: 8rem;
		margin-bottom: 1.5rem;
	}
	.point dd {
		font-size: 2rem;
	}
}



/* -------------------------------------------

policy

------------------------------------------- */
.policy {
	background: url(../img/policy-bg.jpg) no-repeat center / cover;
	padding-bottom: 15rem;
}
/* ---- h2 ---- */
.policy h2 .jp {
	font-family: 'Noto Sans JP', sans-serif;
	display: flex;
	align-items: center;
	justify-content: center;
}
.policy h2 .jp::before,
.policy h2 .jp::after {
	content: "";
	width: 0.2rem;
	height: 10rem;
	background: var(--grey);
	margin-top: 2rem;
}
.policy h2 .jp::before {
	transform: rotate(-20deg);
	margin-right: 4rem;
}
.policy h2 .jp::after {
	transform: rotate(20deg);
	margin-left: 3.5rem;
}
.policy figure {
	padding: 0 2rem;
	margin-top: -7rem;
	margin-bottom: 4rem;
}


/* -------------------------------------------

voice

------------------------------------------- */
.voice {
	background: #fff;
	padding: 8rem 0;
}
/* ---- h2 ---- */
.voice h2 {
	padding: 0 4rem;
	text-shadow: 0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff;
	position: relative;
	z-index: 10;
}
.voice h2 .jp {
	position: relative;
}
.voice h2 .jp > img {
	display: block;
	position: absolute;
}
.voice h2 .jp > img:nth-of-type(1) {
	right: 2rem;
	top: 0;
	width: 10rem;
}
.voice h2 .jp > img:nth-of-type(2) {
	left: -2rem;
	bottom: -10rem;
	width: 12rem;
}
@media screen and (max-width: 600px) {
	.voice h2 {
		padding: 0 3rem;
	}
	.voice h2 .jp > img:nth-of-type(1) {
		right: -1rem;
		top: 0;
		width: 8rem;
	}
	.voice h2 .jp > img:nth-of-type(2) {
		left: -2rem;
		bottom: -8rem;
		width: 10rem;
	}
}
/* ---- ul ---- */
.voice ul {
	padding: 18rem 0 12rem 0;
	position: relative;
	margin-top: -8rem;
}
.voice ul::before {
	content: "";
	width: calc(100% - 4rem);
	height: 100%;
	border-radius: 10rem 0 0 0;
	background: var(--bg-grey);
	position: absolute;
	right: 0;
	top: 0;
}
.voice ul li {
	position: relative;
}
.voice ul li:not(:last-child) {
	margin-bottom: 14rem;
}
.voice ul li figure {
	position: absolute;
	width: 45%;
	top: -8rem;
}
.voice ul li:nth-child(odd) figure {
	right: 0;
}
.voice ul li > div {
	background: #fff;
	width: calc(100% - 4rem);
}
.voice ul li:nth-child(odd) > div {
	padding: 2rem 0 4rem 4rem;
}
.voice ul li:nth-child(even) > div {
	padding: 2rem 0 4rem 4rem;
	margin-left: auto;
}
.voice .num {
	color: var(--green);
	font-family: var(--font-raleway);
	font-size: 2.4rem;
	letter-spacing: 0.1em;
	padding-left: 3rem;
	margin-bottom: 1rem;
	display: block;
}
@media screen and (max-width: 600px) {
	.voice .num {
		padding-left: 0;
	}
}
.voice ul li:nth-child(even) .num {
	text-align: right;
	padding-left: 0;
	padding-right: 3rem;
}
.voice ul li:nth-child(even) dl {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	padding-right: 3rem;
}
.voice ul dl {
	border-top: solid 0.15rem #bbc0bb;
	border-bottom: solid 0.15rem #bbc0bb;
	padding: 2.5rem 0 2.5rem 3rem;
	margin-bottom: 3rem;
}
@media screen and (max-width: 600px) {
	.voice ul dl {
		padding: 2.5rem 0 2.5rem 0;
	}
}
.voice ul dl dt {
	font-size: 1.8rem;
	margin-bottom: 2rem;
	display: flex;
	justify-content: flex-start;
}
.voice ul dl dt > span {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.voice ul dl dd {
	font-weight: bold;
	font-size: 2.4rem;
}
@media screen and (max-width: 600px) {
	.voice ul dl dd {
		font-weight: bold;
		font-size: 2.2rem;
	}
}
.voice ul h3 {
	font-weight: normal;
	font-family: var(--font-shippori);
	font-size: 3.2rem;
	margin-bottom: 1rem;
	margin-left: 3rem;
}
.voice ul p {
	padding: 0 3rem;
	font-size: 2.2rem;
	line-height: 1.8;
}
@media screen and (max-width: 600px) {
	.voice ul h3 {
		font-size: 2.6rem;
		padding: 0 3rem 0 0;
		margin-left: 0;
	}
	.voice ul p {
		padding: 0 3rem 0 0;
		font-size: 2rem;
		line-height: 1.6;
	}
}



/* -------------------------------------------

insta

------------------------------------------- */
.insta {
	background: url(../img/insta-bg.jpg) no-repeat center / cover;
	padding: 8rem 0 8rem 0;
}
/* ---- h2 ---- */
.insta h2 {
	display: flex;
	flex-direction: column;
	margin-bottom: 2rem;
	font-weight: 500;
	font-size: 3rem;
	letter-spacing: 0.15em;
	padding: 0 4rem;
}
.insta h2 span {
	letter-spacing: 0;
	display: block;
	color: var(--green);
	font-family: var(--font-caveat);
	line-height: 1;
	font-size: 6.4rem;
	transform: rotate(-5deg);
	margin-bottom: 2rem;
	margin-left: -1rem;
}
.insta h2 + p {
	margin-bottom: 2.5rem;
	font-size: 2.2rem;
	padding: 0 4rem;
}
@media screen and (max-width: 600px) {
	.insta h2 + p {
		font-size: 1.8rem;
	}
}
/* ---- ul ---- */
.insta ul {
	margin-bottom: 4rem;
	padding: 0 4rem;
}
.insta ul li:not(:last-child) {
	margin-bottom: 4rem;
}
.insta ul li {
	background: #fff;
	border-radius: 2rem;
}
.insta ul li img {
	border-radius: 2rem 2rem 0 0;
}
.insta ul li p {
	padding: 3rem;
	font-weight: 500;
	font-size: 2.8rem;
}
@media screen and (max-width: 600px) {
	.insta ul li p {
		padding: 2.5rem;
		font-size: 2.4rem;
	}
}
/* ---- link ---- */
.insta ul + div {
	margin-bottom: 4rem;
}
.insta ul + div a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30rem;
	height: 10.5rem;
	background: #fff;
	border: 0.3rem var(--grey) solid;
	border-radius: 2.5rem;
	font-family: var(--font-raleway);
	font-size: 2.4rem;
	font-weight: bold;
	margin: 0 auto;
	box-shadow: 0 0 0.8rem rgba(0,0,0,0.4);
}
.insta ul + div a img {
	width: 6.5rem;
	margin-right: 1rem;
}


/* -------------------------------------------

interior

------------------------------------------- */
.interior {
	padding: 8rem 0 0 0; 
	background: #fff;
}
/* ---- h2 ---- */
.interior h2 {
	padding: 0 4rem;
}
/* ---- ul ---- */
.interior ul {
	margin-bottom: 8rem;
}
.interior ul li {
	display: flex;
	padding-bottom: 5rem;
	position: relative;
}
.interior ul li::before {
	content: "";
	width: 70%;
	height: 20rem;
	background: #e9f2e8;
	position: absolute;
	bottom: 0;
	z-index: -1;
}
.interior ul li:nth-child(odd)::before {
	right: 0;
	border-radius: 0 0 0 10rem;
}
.interior ul li:nth-child(even)::before {
	left: 0;
	border-radius: 0 0 10rem 0;
}
.interior ul li figure {
	width: 70%;
}
.interior ul li p {
	width: 30%;
	display: flex;
	align-items: center;
	font-family: var(--font-shippori);
	font-size: 4rem;
	letter-spacing: 0.1em;
	white-space: nowrap;
}
@media screen and (max-width: 600px) {
	.interior ul li p {
		font-size: 3.2rem;
		white-space: nowrap;
	}
}
.interior ul li p img {
	width: 8rem;
	height: 4.7rem;
	margin-bottom: 2.5rem;
}
@media screen and (max-width: 600px) {
	.interior ul li p img {
		width: 6rem;
		height: 3.5rem;
	}
}
.interior ul li:nth-child(odd) p {
	padding-right: 3rem;
}
.interior ul li:nth-child(even) p {
	padding-left: 3rem;
}
.interior ul li:nth-child(even) {
	flex-direction: row-reverse;
}
.interior ul li:not(:last-child) {
	margin-bottom: 8rem;
}



/* -------------------------------------------

gift

------------------------------------------- */
.gift {
	padding: 8rem 0 15rem 0;
	background: var(--bg-grey);
}
/* ---- wrap ---- */
.gift .wrap {
	display: flex;
}
.gift .wrap > h2 {
	width: 25%;
}
.gift .wrap >  div {
	width: 75%;
	position: relative;
}
.gift .wrap >  div > span {
	position: absolute;
	right: 2rem;
	top: 5rem;
	color: #fff;
	font-family: var(--font-shippori);
	font-size: 4rem;
	letter-spacing: 0.2em;
	text-shadow: 0 0 1rem rgba(0,0,0,1);
}
.gift .wrap >  div figure {
	position: relative;
}
.gift .wrap >  div > figure img:nth-of-type(2) {
	display: block;
	position: absolute;
	width: 14rem;
	left: -11rem;
	bottom: 10rem;
}
@media screen and (max-width: 600px) {
	.gift .wrap >  div > figure img:nth-of-type(2) {
		display: block;
		position: absolute;
		width: 8rem;
		left: -6rem;
		bottom: 4rem;
	}
}
.gift .wrap + p {
	padding: 0 4rem;
	text-shadow: 0 0 1rem var(--bg-grey),0 0 1rem var(--bg-grey),0 0 1rem var(--bg-grey),0 0 1rem var(--bg-grey);
	font-size: 3rem;
	line-height: 2;
	margin-top: -6rem;
	position: relative;
	margin-bottom: 4rem;
	padding-bottom: 5rem;
}
.gift .wrap + p img {
	position: absolute;
	right: 4rem;
	bottom: 0;
	width: 4.7rem;
}
@media screen and (max-width: 600px) {
	.gift .wrap + p {
		padding: 0 0 6rem 4rem;
		font-size: 2.3rem;
		margin-top: -3rem;
	}
}
/* ---- ul ---- */
.gift ul {
	padding: 0 4rem;
	margin-bottom: 8rem
}
.gift ul li:not(:last-child) {
	margin-bottom: 4rem;
}
.gift ul li {
	border-left: solid 0.3rem var(--green);
	padding-left: 2.5rem;
}
.gift ul li dt {
	display: flex;
	align-items: center;
	margin-bottom: 1.5rem;
}
.gift ul li dt img {
	width: 4rem;
	margin-top: 0.25rem;
}
.gift ul li dt span {
	width: calc(100% - 2.5rem);
	padding-left: 1.5rem;
	color: var(--green);
	font-weight: bold;
	font-size: 3.4rem;
}
.gift ul li dd {
	font-size: 2.2rem;
}
@media screen and (max-width: 600px) {
	.gift ul li {
		padding-left: 2rem;
	}
	.gift ul li dt img {
		width: 2.5rem;
	}
	.gift ul li dt span {
		width: calc(100% - 2.5rem);
		padding-left: 1.5rem;
		color: var(--green);
		font-weight: bold;
		font-size: 2.2rem;
	}
	.gift ul li dd {
		font-size: 1.8rem;
	}
}



/* -------------------------------------------

flow

------------------------------------------- */
.flow {
	background: url(../img/flow-bg.jpg) no-repeat center / cover;
}
/* ---- ul ---- */
.flow ul {
	padding: 0 4rem 8rem 4rem;
}
.flow ul li {
	display: flex;
	position: relative;
}
.flow ul li:not(:last-child):before {
	content: "";
	width: 10rem;
	height: calc(100% - 10rem);
	position: absolute;
	left: 0;
	bottom: 0;
	background: url(../img/dot.png) repeat-y center top;
	background-size:0.3rem auto;
} 
.flow ul li:not(:last-child) {
	padding-bottom: 6rem;
}
.flow .num {
	width: 10rem;
	height: 10rem;
	border: solid 0.2rem var(--green);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	font-family: var(--font-raleway);
	font-weight: 500;
	letter-spacing: 0.1em;
	font-size: 3rem;
	color: var(--green);
}
.flow li dl {
	width: calc(100% - 10rem);
	padding-left: 3rem;
	padding-top: 2.2rem;
}
.flow li dl dt {
	font-weight: 500;
	font-size: 3.4rem;
	margin-bottom: 1.5rem;
}
.flow li dl dd {
	font-size: 2.2rem;
}
.flow li dl dd span {
	display: block;
	margin-top: 1rem;
	color: #626262;
	font-size: 1.8rem;
}
@media screen and (max-width: 600px) {
	.flow ul {
		padding: 0 3rem 8rem 3rem;
	}
	.flow ul li:not(:last-child):before {
		width: 6rem;
		height: calc(100% - 6rem);
	} 
	.flow ul li:not(:last-child) {
		padding-bottom: 4rem;
	}
	.flow .num {
		width: 6rem;
		height: 6rem;	
		font-size: 2.4rem;
	}
	.flow li dl {
		width: calc(100% - 6rem);
		padding-left: 2rem;
		padding-top: 1rem;
	}
	.flow li dl dt {
		font-size: 2.4rem;
	}
	.flow li dl dd {
		font-size: 2rem;
	}
}



/* -------------------------------------------

price

------------------------------------------- */
.price {
	background: #fff;
	padding: 16rem 0 15rem 0;
}
@media screen and (max-width: 600px) {
	.price {
		padding: 14rem 0 0 0;
	}
}
/* ---- h2 ---- */
.price h2 {
	margin-bottom: 6rem;
}
@media screen and (max-width: 600px) {
	.price h2 {
		margin-bottom: 3rem;
	}
}
/* ---- dl ---- */
.price dl {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 43rem;
	margin: 0 auto 3rem auto;
}
.price dl dt {
	font-size: 2.4rem;
	font-weight: 500;
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: 1.5rem;
}
.price dl dt span {
	font-family: var(--font-shippori);
	font-size: 3.2rem;
}
.price dl dd {
	border-top: dotted 0.3rem var(--green);
	border-bottom: dotted 0.3rem var(--green);
	width: 100%;
	text-align: center;
	padding: 0.7rem 0 1.5rem 0;
	color: var(--green);
	font-family: var(--font-shippori);
	font-size: 2.4rem;
	line-height: 1;
}
.price dl dd i {
	font-size: 6rem;
}
@media screen and (max-width: 600px) {
	.price dl {
		width: 36rem;
	}
	.price dl dt span {
		font-family: var(--font-shippori);
		font-size: 2.5rem;
	}
}
/* ---- figure ---- */
.price figure {
	width: 40rem;
	margin: 0 auto 8rem auto;
}
.price figure img:nth-of-type(1) {
	margin-bottom: 2rem;
}
@media screen and (max-width: 600px) {
	.price figure {
		width: 36rem;
	}
}




/* -------------------------------------------

influencer

------------------------------------------- */
.influencer {
	background: var(--bg-grey);
	display: flex;
	padding: 8rem 0 10rem 0;
}
.influencer > h2 {
	width: 25%;
}
.influencer >  div {
	width: 80%;
	margin-left: -5%;
	position: relative;
}
.influencer p {
	font-family: var(--font-shippori);
	font-size: 3.8rem;
	margin-top: -5rem;
	text-shadow: 0 0 1.5rem var(--bg-grey),0 0 1.5rem var(--bg-grey),0 0 1.5rem var(--bg-grey),0 0 1.5rem var(--bg-grey),0 0 1.5rem var(--bg-grey),0 0 1.5rem var(--bg-grey);
	line-height: 1.4;
}
@media screen and (max-width: 600px) {
	.influencer > h2 {
		font-size: 2.6rem;
	}
	.influencer p {
		font-size: 3rem;
		margin-left: 1rem;
	}
}



/* -------------------------------------------

campaign

------------------------------------------- */
.campaign {
	background: var(--green);
	padding: 0 4rem 15rem 4rem;
}
@media screen and (max-width: 600px) {
	.campaign {
		padding: 0 3rem 15rem 3rem;
	}
}
/* ---- h2 ---- */
.campaign h2 {
	color: #fff;
}
.campaign h2 .en {
	color: #fff;
}
/* ---- wrap ---- */
.campaign .wrap {
	background: #fff;
	padding: 5rem 3rem;
}
@media screen and (max-width: 600px) {
	.campaign .wrap {
		padding: 2rem;
	}
}
.campaign section {
	border: dotted 0.2rem var(--green);
	padding: 2rem;
}
.campaign section h3 {
	font-weight: normal;
	font-family: var(--font-shippori);
	color: var(--green);
	font-size: 2.8rem;
	text-align: center;
	margin-bottom: 0.5rem;
}
.campaign section p {
	font-size: 2.2rem;
}
@media screen and (max-width: 600px) {
	.campaign section h3 {
		font-size: 2.2rem;
	}
	.campaign section p {
		font-size: 1.8rem;
	}
}
.campaign .wrap > div {
	margin: 2rem 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.campaign .wrap > div p {
	text-align: center;
	font-size: 2.2rem;
	margin-bottom: 1rem;
}
@media screen and (max-width: 600px) {
	.campaign .wrap > div p {
		font-size: 1.7rem;
	}
}
.campaign .wrap > div > div {
	border: solid 0.15rem var(--green);
	color: var(--green);
	font-weight: 500;
	font-size: 2rem;
	padding: 0.7rem 0 0.8rem 0;
	text-align: center;
	width: 90%;
}
.campaign dl dt {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--green);
	font-family: var(--font-shippori);
	font-size: 2.8rem;
	margin-bottom: 1rem;
}
.campaign dl dt::before,
.campaign dl dt::after {
	content: "";
	width: 4rem;
	height: 0.15rem;
	background: var(--green)
}
.campaign dl dt::before {
	margin-right: 1rem
}
.campaign dl dt::after {
	margin-left: 1rem
}
.campaign dl dd {
	font-size: 2.2rem;
	text-align: center;
}
.campaign dl dd span {
	display: block;
	color: #626262;
}
@media screen and (max-width: 600px) {
	.campaign dl dt {
		font-size: 2.2rem;
	}
	.campaign dl dt::before,
	.campaign dl dt::after {
		width: 2rem;
	}
	.campaign dl dt::before {
		margin-right: 0.5rem
	}
	.campaign dl dt::after {
		margin-left: 0.5rem
	}
	.campaign dl dd {
		font-size: 1.8rem;
		text-align: left;
	}
	.campaign dl dd span {
		display: block;
		color: #626262;
	}
}



/* -------------------------------------------

faq

------------------------------------------- */
.faq {
	background: #fff;
	padding: 0 4rem 15rem 4rem;
}
@media screen and (max-width: 600px) {
	.faq {
		padding: 0 3rem 8rem 3rem;
	}
}
/* ---- dl ---- */
.faq dt {
	display: flex;
	align-items: flex-start;
	padding: 2rem 2rem;
	color: #fff;
	background: #bbc0bb;
	font-weight: 500;
	font-size: 2.2rem;
}
@media screen and (max-width: 600px) {
	.faq dt {
		font-size: 2rem;
	}
}
.faq dt span:nth-child(1),
.faq dd span:nth-child(1) {
	font-size: 3.6rem;
	font-family: var(--font-shippori);
	font-weight: normal;
	line-height: 1;
	margin-top: -0.4rem
}
@media screen and (max-width: 600px) {
	.faq dt span:nth-child(1),
	.faq dd span:nth-child(1) {
		font-size: 3rem;
	}
}
.faq dd span:nth-child(1) {
	color: var(--green);
}
.faq dt span:nth-child(2),
.faq dd span:nth-child(2) {
	padding-left: 2rem;
}
.faq dd:not(:last-of-type) {
	margin-bottom: 3rem;
}
.faq dd {
	display: flex;
	padding: 2rem 2rem;
	font-size: 2.2rem;
}
@media screen and (max-width: 600px) {
	.faq dd {
		font-size: 1.8rem;
	}
}



/* -------------------------------------------

protection

------------------------------------------- */
.protection {
	background: url(../img/protection-bg.jpg) no-repeat center / cover;
	padding: 8rem 0;
}
.protection .wrap {
	display: flex;
}
.protection .wrap > h2 {
	width: 20%;
}
.protection .wrap > div {
	width: 80%;
}
.protection .wrap > div figure {
	position: relative;
	padding-left: 1rem;
}
.protection .deco-1,
.protection .deco-2 {
	display: block;
	position: absolute;
}
.protection .deco-1 {
	width: 13rem;
	left: -2rem;
	top: 0;
}
.protection .deco-2 {
	width: 6rem;
	right: 4rem;
	bottom: -10rem;
}
@media screen and (max-width: 600px) {
	.protection .deco-2 {
		width: 4rem;
		right: 1rem;
	}
}
/* ---- h3 ---- */
.protection h3 {
	font-weight: normal;
	font-family: var(--font-shippori);
	font-size: 3.8rem;
	line-height: 1.3;
	margin-top: -3rem;
	text-shadow: 0 0 15rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff,0 0 1.5rem #fff;
	margin-bottom: 2rem;
}
@media screen and (max-width: 600px) {
	.protection h3 {
		font-size: 3.2rem;
	}
}
/* ---- p ---- */
.protection p {
	font-size: 2.2rem;
	margin-bottom: 3rem;
}
@media screen and (max-width: 600px) {
	.protection p {
		font-size: 1.8rem;
		padding-right: 2rem;
	}
}


/* -------------------------------------------

cta

------------------------------------------- */
.cta {
	background: var(--orange);
	color: #fff;
	padding: 3rem 0;
	font-size: 2.2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.cta p {
	line-height: 1;
}
.cta p i {
	font-family: var(--font-raleway);
	font-weight: bold;
	font-size: 3.6rem;
}
.cta a {
	background: url(../img/arrow-1.png) no-repeat center right 3rem;
	background-size: 3.5rem;
	background-color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 80%;
	height: 11rem;
	color: var(--orange);
	font-family: var(--font-shippori);
	font-size: 3.6rem;
	border-radius: 5rem 0 5rem 0;
	margin: 1.5rem 0 1rem 0;
	box-shadow: 0.1rem 0.15rem 0.6rem rgba(0, 0, 0, 0.25);
}
.cta > div {
	font-size: 2.4rem;
	font-weight: bold;
	display: flex;
	flex-direction: column;
	align-items: center;
	color: #fff799;
	text-align: center;
	line-height: 1.4;
}
.cta > div i {
	font-size: 2.2rem;
	font-weight: normal;
	color: #fff;
	margin-top: 0.5rem;
}



/* -------------------------------------------

footer

------------------------------------------- */
footer {
	background-color: var(--green);
	color: #fff;
	padding: 4rem 0 2rem 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	font-size: 2.2rem;
}
@media screen and (max-width: 600px) {
	footer {
		font-size: 1.8rem;
	}
}
footer a {
	color: #fff;
}
footer nav {
	margin-bottom: 4rem;
}
footer ul {
	display: flex;
	flex-direction: column;
	align-items: center;
}
footer ul li:not(:last-child) {
	margin-bottom: 1rem;
}
footer ul li:last-child {
	margin-top: 2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
}
footer ul li:last-child a {
	border-bottom: solid 0.12rem #fff;
}
footer small {
	font-family: var(--font-raleway);
}