@charset "utf-8";

#regeneration {
	max-width: 996px;
	margin: 0 auto;
	padding-top: 12px;
	font-feature-settings: "palt";
	letter-spacing: 0.8px;
}
#regeneration h2 {
	margin: 0 0 44px;
	padding: 14px 0 13px;
	background-color: #f0f0f0;
	font-size: 22px;
	letter-spacing: 2px;
}
#regeneration h2 small {
	font-size: 19.25px;
	vertical-align: 1px;
}
#regeneration h2.has-sub small {
	padding-left: 10px;
}
#regeneration h2.has-sub small::before,
#regeneration h2.has-sub small::after {
	display: inline;
	content: "─";
}
#regeneration h2.has-sub small::before {
	padding-right: 5px;
}
#regeneration h2.has-sub small::after {
	padding-left: 5px;
}
#regeneration h3 {
	margin: 0 0 30px;
	padding: 0 0 7px;
	border-bottom: 1px solid #323232;
	background-color: transparent;
	font-size: 22px;
	text-align: center;
	letter-spacing: 2.2px;
}
#regeneration p {
	font-size: 16px;
	line-height: 1.75;
	text-align: justify;
	letter-spacing: 1.8px;
}

/* ページ内ナビ */
#regeneration .regeneration-nav ul {
	display: flex;
	justify-content: center;
}
#regeneration .regeneration-nav li {
	width: 104px;
	margin: 0 14px;
	font-size: 12px;
	line-height: 1.2;
	text-align: center;
}
#regeneration .regeneration-nav li a {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	width: 100%;
	height: 100%;
	padding: 2px 0 14px;
	border: 1px solid #000;
	border-radius: 5px;
	background-color: #fff;
	transition: opacity .2s ease;
}
#regeneration .regeneration-nav li a:hover {
	opacity: 0.7;
}
#regeneration .regeneration-nav li a::after {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 3px;
	width: 13px;
	margin: 0 auto;
	color: #000;
	font-family: icomoon;
	font-size: 13px;
	line-height: 1;
	content: "\e904";
}

/* メインビジュアル */
#regeneration #kv {
	padding: 103px 0 91px;
}
#regeneration #kv h1 {
	height: 330px;
	padding: 89px 0 0 0;
	background: url(../img/kv_bg.jpg) no-repeat 50% 0;
	font-size: 24px;
	line-height: 1.5;
	text-align: center;
	letter-spacing: 2px;
}
#regeneration #kv h1 span {
	font-size: 19px;
	letter-spacing: 2.6px;
}

/* イントロ */
#regeneration .intro {
	margin-bottom: 104px;
	padding-top: 104px;
}
#regeneration .intro h2 {
	padding: 0 0 7px;
	border-bottom: 1px solid #323232;
	background-color: transparent;
	text-align: center;
}
#regeneration .intro > div {
	display: flex;
}
#regeneration .intro > div::before {
	flex: 0 0 auto;
	width: 240px;
	height: 240px;
	margin: 6px 40px 0 158px;
	background: url(../img/potential.jpg) no-repeat 50% 50%;
	background-size: 100% auto;
	content: "";
}
#regeneration .intro > div div {
	width: 394px;
	margin-right: 20px;
}
#regeneration .intro p {
	margin-bottom: 28px;
	letter-spacing: 1.6px;
}

/* 美肌再生3つのポイント */
#regeneration #a-point h2 small {
	padding-right: 10px;
}
#regeneration #a-point p {
	position: relative;
	min-height: 203px;
	padding: 0 165px 0 438px;
	letter-spacing: 1.6px;
}
#regeneration #a-point p::before {
	display: block;
	position: absolute;
	top: 4px;
	left: 155px;
	width: 243px;
	height: 199px;
	background: url(../img/point.png) no-repeat 50% 50%;
	content: "";
}

/* 美肌の材料 */
#regeneration #a-material {
	margin-top: -3px;
	padding-top: 113px;
}
#regeneration #a-material p {
	position: relative;
	min-height: 191px;
	margin-bottom: 0;
	padding: 0 68px 0 532px;
}
#regeneration #a-material p::before {
	display: block;
	position: absolute;
	top: -27px;
	left: 69px;
	width: 424px;
	height: 218px;
	background: url(../img/material.png) no-repeat 50% 50%;
	content: "";
}

/* 美肌のスイッチを入れるには */
#regeneration #a-switch {
	margin-top: -5px;
	padding-top: 113px;
}
#regeneration #a-switch > div {
	margin: 0 88px;
}
#regeneration #a-switch .slide-block {
	display: flex;
	justify-content: space-between;
	margin: 37px 0 45px;
}

/* 美肌をつくるためのエネルギー */
#regeneration #a-energy {
	margin-top: -10px;
	padding-top: 113px;
}
#regeneration #a-energy p {
	position: relative;
	min-height: 304px;
	padding: 0 110px 0 491px;
	letter-spacing: 1.6px;
}
#regeneration #a-energy p::before {
	display: block;
	position: absolute;
	top: -14px;
	left: 115px;
	width: 348px;
	height: 318px;
	background: url(../img/energy.png) no-repeat 50% 50%;
	content: "";
}

/* アウトロ */
#regeneration .outro {
	margin: 100px 0 95px;
	text-align: center;
}
#regeneration .outro p {
	margin-bottom: 103px;
	text-align: center;
}
#regeneration .outro li {
	margin-bottom: 10px;
}
#regeneration .outro li a {
	display: block;
	position: relative;
	width: 300px;
	margin: 0 auto;
	padding: 12px;
	color: inherit;
	border: 1px solid #000;
	background-color: #fff;
	text-decoration: none;
	letter-spacing: 1.6px;
}
#regeneration .outro li a::after {
	position: absolute;
	top: 0;
	right: 5px;
	bottom: 0;
	height: 13px;
	margin: auto 0;
	color: #000;
	font-family: "icomoon";
	font-size: 13px;
	font-weight: bold;
	line-height: 1;
	opacity: 1 !important;
	content: "\e906";
}

@media screen and (max-width: 768px) {
	#regeneration {
		max-width: none;
		padding: 0 22px;
	}
	#regeneration section {
		padding-left: 8px;
		padding-right: 8px;
	}
	#regeneration h2 {
		margin-bottom: 24px;
		padding: 6px 0;
		font-size: 16px;
		font-size: 4.27vw;
		letter-spacing: 1.6px;
	}
	#regeneration h2 small {
		display: block;
		font-size: 14px;
		font-size: 3.73vw;
		vertical-align: baseline;
	}
	#regeneration h2.has-sub small {
		padding-left: 0;
	}
	#regeneration h2.has-sub small::before {
		padding-right: 0;
	}
	#regeneration h2.has-sub small::after {
		padding-left: 0;
	}
	#regeneration h3 {
		margin: 0 0 28px;
		padding: 0 0 1px;
		font-size: 17px;
		font-size: 4.53vw;
		letter-spacing: 1.8px;
	}
	#regeneration p {
		margin-bottom: 0;
		font-size: 14px;
		font-size: 3.73vw;
		line-height: 1.9;
	}
	
	/* ページ内ナビ */
	#regeneration .regeneration-nav ul {
		flex-direction: column;
		justify-content: flex-start;
		flex-wrap: wrap;
		width: auto;
		margin: 0 -1.33vw;
	}
	#regeneration .regeneration-nav li {
		width: 100%;
		margin: 0 0 2.67vw;
		padding: 0 1.33vw;
		font-size: 14px;
		font-size: 3.73vw;
		letter-spacing: 1.2px;
		white-space: nowrap;
	}
	#regeneration .regeneration-nav li a {
		padding: 0.8em 12px;
		border-radius: 6px;
		opacity: 1 !important;
		transition: none;
	}
	#regeneration .regeneration-nav li a::after {
		top: 0;
		left: auto;
		right: 6px;
		bottom: 0;
		width: auto;
		height: 4vw;
		margin: auto 0;
		font-size: 4vw;
		content: "\e906";
	}
	#regeneration .regeneration-nav li br {
		display: none;
	}
	
	/* メインビジュアル */
	#regeneration #kv {
		margin-left: -22px;
		margin-right: -22px;
		padding: 95px 0 72px;
	}
	#regeneration #kv h1 {
		height: 57.6vw;
		padding-top: 15.2vw;
		background-image: url(../img/sp_kv_bg.jpg);
		background-size: auto 100%;
		font-size: 17.5px;
		font-size: 4.67vw;
		line-height: 1.5;
		letter-spacing: 0.8px;
	}
	#regeneration #kv h1 span {
		font-size: 14px;
		letter-spacing: 1.8px;
	}
	
	/* イントロ */
	#regeneration .intro {
		margin: 58px 0 63px;
		padding: 0 8px;
	}
	#regeneration .intro h2 {
		margin: 0 -8px 29px;
		padding-bottom: 3px;
		font-size: 17px;
		font-size: 4.53vw;
		line-height: 1.2;
		letter-spacing: 1.4px;
	}
	#regeneration .intro > div {
		flex-direction: column;
	}
	#regeneration .intro > div::before {
		width: 100%;
		height: 84vw;
		margin: 0;
	}
	#regeneration .intro > div div {
		width: auto;
		margin-right: 0;
	}
	#regeneration .intro p {
		margin: 24px 0 0;
		letter-spacing: 1.2px;
	}
	
	/* 美肌再生3つのポイント */
	#regeneration #a-point h2 {
		margin: 0 -30px 42px;
	}
	#regeneration #a-point h2 small {
		padding-right: 0;
	}
	#regeneration #a-point p {
		min-height: 0;
		padding: 0;
	}
	#regeneration #a-point p::before {
		position: static;
		width: calc(100% + 16px);
		height: 68vw;
		margin: 0 -8px 35px;
		background-image: url(../img/sp_point.png);
		background-size: auto 100%;
	}
	
	/* 美肌の材料 */
	#regeneration #a-material {
		margin-top: -4.3478vw;
		padding-top: 19.3236vw;
	}
	#regeneration #a-material h2 {
		margin: 0 -30px 28px;
	}
	#regeneration #a-material p {
		min-height: 0;
		padding: 0;
		letter-spacing: 1.4px;
	}
	#regeneration #a-material p::before {
		position: static;
		width: calc(100% + 16px);
		height: 44vw;
		margin: 0 -8px 22px;
		background-image: url(../img/sp_material.png);
		background-size: auto 100%;
	}
	
	/* 美肌のスイッチを入れるには */
	#regeneration #a-switch {
		margin-top: -4.3478vw;
		padding-top: 19.3236vw;
	}
	#regeneration #a-switch h2 {
		margin-left: -30px;
		margin-right: -30px;
	}
	#regeneration #a-switch > div {
		margin: 0;
	}
	#regeneration #a-switch .slide-block {
		width: auto;
		margin: 58px -8px 23px;
	}
	#regeneration #a-switch .slide-block img {
		width: 100%;
		height: auto;
	}
	#regeneration #a-switch p {
		letter-spacing: 1.2px;
	}
	#regeneration #a-switch .slick-prev,
	#regeneration #a-switch .slick-next {
		margin: 0;
		top: 28.4vw;
		width: 50px;
		padding: 30px 0;
		opacity: 1 !important;
	}
	#regeneration #a-switch .slick-prev {
		left: 0;
		padding-left: 5px;
	}
	#regeneration #a-switch .slick-next {
		right: 0;
		padding-right: 5px;
	}
	#regeneration #a-switch .slick-prev::before,
	#regeneration #a-switch .slick-next::before {
		color: #323232;
		font-size: 14px;
		opacity: 1 !important;
	}
	#regeneration #a-switch .slick-prev::before {
		float: left;
	}
	#regeneration #a-switch .slick-next::before {
		float: right;
	}
	
	/* 美肌をつくるためのエネルギー */
	#regeneration #a-energy {
		margin-top: -4.3478vw;
		padding-top: 19.3236vw;
	}
	#regeneration #a-energy h2 {
		margin: 0 -30px 28px;
	}
	#regeneration #a-energy p {
		min-height: 0;
		padding: 0;
		letter-spacing: 1.2px;
	}
	#regeneration #a-energy p::before {
		position: static;
		width: calc(100% + 16px);
		height: 71.2vw;
		margin: 0 -8px 19px;
		background-image: url(../img/sp_energy.png);
		background-size: auto 100%;
	}
	
	/* アウトロ */
	#regeneration .outro {
		margin: 58px 0 45px;
		padding-left: 7px;
		padding-right: 7px;
	}
	#regeneration .outro p {
		margin-bottom: 63px;
		text-align: justify;
		letter-spacing: 0.4px;
	}
	#regeneration .outro ul.btn {
		margin-left: -7px;
		margin-right: -7px;
	}
	#regeneration .outro li a {
		width: 100%;
		padding: 0.9em 12px;
		font-size: 14px;
		font-size: 3.73vw;
		opacity: 1 !important;
	}
	#regeneration .outro li a::after {
		right: 9px;
	}
}
