@charset "utf-8";

#hydration {
	max-width: 996px;
	margin: 0 auto;
	padding-top: 12px;
	text-align: center;
	font-feature-settings: "palt";
	letter-spacing: 0.8px;
}
#hydration h2 {
	margin: 73px 0 44px;
	padding: 14px 0 13px;
	background-color: #f0f0f0;
	font-size: 22px;
	letter-spacing: 2px;
}
#hydration h3 {
	margin: 60px 0 47px;
	padding: 10px 0 7px;
	border-bottom: 1px solid #323232;
	background-color: transparent;
	font-size: 22px;
	letter-spacing: 2.2px;
}
#hydration h4 {
	font-size: 20px;
	letter-spacing: 1.8px;
}
#hydration p {
	margin-bottom: 27px;
	line-height: 1.75;
}

/* スライド */
#hydration .mech-slide {
	display: flex;
	justify-content: space-between;
	padding-right: 2px;
}
#hydration .mech {
	width: 464px;
	outline: none;
}
#hydration .mech p {
	margin-bottom: 0;
	font-size: 16px;
	line-height: 1.45;
	letter-spacing: 1.6px;
}
#hydration .mech p::before {
	display: block;
	width: 100%;
	margin: 42px auto 20px;
	background: no-repeat 50% 50%;
	content: "";
}

/* ページ内ナビ */
#hydration .hydration-nav ul {
	display: flex;
	justify-content: center;
}
#hydration .hydration-nav li {
	width: 104px;
	margin: 0 14px;
	font-size: 12px;
	line-height: 1.2;
	text-align: center;
}
#hydration .hydration-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;
}
#hydration .hydration-nav li a:hover {
	opacity: 0.7;
}
#hydration .hydration-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";
}
#hydration .hydration-nav li a span {
	letter-spacing: 0.4px;
}

/* メインビジュアル */
#hydration #kv {
	padding: 82px 0 158px;
}
#hydration #kv h1 {
	height: 282px;
	padding: 118px 10px 0 0;
	background: url(../img/kv_bg.jpg) no-repeat 50% 50%;
	font-size: 24px;
	line-height: 1.4;
	text-align: center;
	letter-spacing: 0.4px;
}
#hydration #kv h1 span {
	padding-left: 10px;
	letter-spacing: 2.6px;
}

/* イントロ */
#hydration .intro {
	margin: -9px 0 104px;
	padding-top: 113px;
}
#hydration .intro h2 {
	margin: 0 0 44px;
	padding: 0 0 7px;
	border-bottom: 1px solid #323232;
	background-color: transparent;
	font-size: 22px;
	text-align: center;
	letter-spacing: 2px;
}
#hydration .intro > div {
	display: flex;
}
#hydration .intro > div::before {
	flex: 0 0 auto;
	width: 240px;
	height: 240px;
	margin: 6px 40px 0 158px;
	background: url(../img/water.jpg) no-repeat 50% 50%;
	background-size: 100% auto;
	content: "";
}
#hydration .intro > div div {
	width: 394px;
	margin-right: 20px;
}
#hydration .intro p {
	margin: 0 0 28px;
	text-align: justify;
	letter-spacing: 1.4px;
}

/* 肌悩みと水分量の関係 */
#hydration .relation h2 {
	margin: 0 0 44px;
	padding: 0 0 7px;
	border-bottom: 1px solid #323232;
	background-color: transparent;
	font-size: 22px;
	text-align: center;
	letter-spacing: 2px;
}
#hydration .relation p {
	padding: 0 86px 0 80px;
	text-align: justify;
	letter-spacing: 1.8px;
}
#hydration .relation .relation-factor {
	display: flex;
	justify-content: center;
	margin: 44px 0 42px;
}
#hydration .relation .relation-factor li {
	width: 122px;
	font-size: 16px;
	line-height: 1.2;
}
#hydration .relation .relation-factor li::before {
	display: block;
	height: 62px;
	margin-bottom: 16px;
	background: no-repeat 50% 50%;
	content: "";
}
#hydration .relation .relation-factor li.stress::before {
	background-image: url(../img/icon_stress.svg);
}
#hydration .relation .relation-factor li.uv::before {
	background-image: url(../img/icon_uv.svg);
}
#hydration .relation .relation-factor li.aircon::before {
	background-image: url(../img/icon_aircon.svg);
}
#hydration .relation picture {
	display: block;
	margin: 40px 0 0;
}

/* 肌の「水分量」を増やすには */
#hydration .increase {
	margin-bottom: 103px;
}
#hydration .increase h2 {
	margin-top: 105px;
}
#hydration .increase p {
	padding: 0 86px 0 80px;
	text-align: justify;
	letter-spacing: 1.7px;
}

/* 肌を心地よく水分で満たす技術 */
#hydration #a-technique {
	margin-top: -113px;
	padding-top: 113px;
}
#hydration #a-technique h2 {
	margin-top: 0;
}
#hydration .tech-lead {
	display: inline-block;
	padding-right: 25px;
}
#hydration .tech-lead p {
	text-align: left;
	letter-spacing: 1.8px;
}
#hydration .tech-block {
	margin-top: -113px;
	margin-bottom: 88px;
	padding-top: 113px;
}
#hydration .tech-block h3 {
	margin-top: 0;
}
/* 1）すばやく肌になじむこと */
#hydration #a-absorb {
	margin-top: -53px;
}
#hydration #a-absorb h3 {
	margin-bottom: 44px;
}
#hydration #a-absorb p::before {
	height: 223px;
}
#hydration .absorb1 p::before {
	background-image: url(../img/absorb1.png);
}
#hydration .absorb2 p::before {
	background-image: url(../img/absorb2.png);
}
/* 動画 */
#hydration #a-absorb .movie {
	width: 410px;
	margin: 0 auto 70px;
}
#hydration #a-absorb .movie p {
	margin-bottom: 44px;
	text-align: justify;
	letter-spacing: 1.6px;
}
#hydration #a-absorb .movie p.sup {
	margin-top: 24px;
	font-size: 11px;
	line-height: 1.27;
	letter-spacing: 1.2px;
}
#hydration #a-absorb .movie iframe {
	vertical-align: bottom;
}
/* 2）水分を肌にとどめ保つこと */
#hydration #a-keep p::before {
	height: 138px;
}
#hydration .keep1 p::before {
	background-image: url(../img/keep1.png);
}
#hydration .keep2 p::before {
	background-image: url(../img/keep2.png);
}
/* 3）べたつかず、心地よい使用感であること */
#hydration #a-comfort {
	margin-bottom: 106px;
}
#hydration #a-comfort p::before {
	height: 304px;
	margin-top: 32px;
}
#hydration .comfort1 p::before {
	background-image: url(../img/comfort1.png);
}
#hydration .comfort2 p::before {
	background-image: url(../img/comfort2.png);
}
#hydration #a-comfort p span.pad {
	display: block;
	padding-left: 12px;
}
/* 4）水分を抱え続ける成分を探すこと */
#hydration #a-inquiry {
	margin-top: -130px;
}
#hydration #a-inquiry p {
	margin-bottom: 46px;
	line-height: 1.45;
	letter-spacing: 1.6px;
}
#hydration #a-inquiry > div {
	width: 422px;
	margin: 40px auto 0;
}
#hydration #a-inquiry > div p {
	margin: 0 0 19px 1px;
	font-size: 11px;
	line-height: 1.27;
	text-align: left;
	letter-spacing: 1.2px;
}
#hydration #a-inquiry .movie {
	width: auto;
	margin: 0;
}
#hydration #a-inquiry .movie iframe {
	vertical-align: bottom;
}

/* コットンパックと水分量の関係 */
#hydration #a-cotton {
	margin-top: -91px;
	padding-top: 113px;
}
#hydration #a-cotton h2 {
	margin-top: 0;
}
#hydration #a-cotton h3 {
	margin: 0;
	padding: 0;
	border-bottom: none;
	font-size: 20px;
	white-space: nowrap;
}
#hydration #a-cotton .cotton1 h3 {
	letter-spacing: 1.8px;
}
#hydration #a-cotton > p {
	margin: 0 20px 37px 0;
	letter-spacing: 1.6px;
}
#hydration #a-cotton .cotton-block {
	display: flex;
}
#hydration #a-cotton .cotton1 {
	width: 300px;
}
#hydration #a-cotton .cotton2 {
	width: 320px;
	margin-left: 37px;
	margin-right: 49px;
}
#hydration #a-cotton .cotton3 {
	width: 290px;
}
#hydration #a-cotton .mech p::before {
	height: 205px;
	margin-top: 30px;
}
#hydration #a-cotton .cotton1 p::before {
	background-image: url(../img/cotton1.png);
}
#hydration #a-cotton .cotton2 p::before {
	background-image: url(../img/cotton2.png);
}
#hydration #a-cotton .cotton3 p::before {
	background-image: url(../img/cotton3.png);
}

/* 水分で満たされた肌の状態 */
#hydration .skin-status {
	margin-top: -3px;
	padding-top: 113px;
}
#hydration .skin-status h2 {
	margin-top: 0;
}
#hydration .skin-status > p {
	padding: 0 86px 0 80px;
	text-align: justify;
	letter-spacing: 1.8px;
}
#hydration .skin-status .mech-slide {
	margin-top: 38px;
	padding-right: 0;
}
#hydration .skin-status .mech {
	width: 468px;
}
#hydration .skin-status h3 {
	margin: 0;
	padding: 0;
	border-bottom: none;
	font-size: 20px;
}
#hydration .skin-status p::before {
	margin-bottom: 19px;
	height: 218px;
}
#hydration .status1 p::before {
	background-image: url(../img/status1.png);
}
#hydration .status2 p::before {
	background-image: url(../img/status2.png);
}

/* アウトロ */
#hydration .outro {
	margin: 103px 0 95px;
	text-align: center;
}
#hydration .outro p {
	margin-bottom: 103px;
	letter-spacing: 1.8px;
}
#hydration .outro li {
	margin-bottom: 10px;
}
#hydration .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;
}
#hydration .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) {
	#hydration {
		max-width: none;
		padding: 0 22px;
	}
	#hydration section {
		padding-left: 8px;
		padding-right: 8px;
	}
	#hydration h2 {
		margin: 54px 0 24px;
		padding: 17px 0;
		font-size: 16px;
		font-size: 4.27vw;
		letter-spacing: 0.4px;
	}
	#hydration h3 {
		margin: 48px -8px 15px;
		padding: 0 0 1px;
		font-size: 17px;
		font-size: 4.53vw;
		letter-spacing: 1.8px;
	}
	#hydration h4 {
		font-size: 17px;
		font-size: 4.53vw;
		letter-spacing: 1.2px;
	}
	#hydration p {
		margin-bottom: 0;
		font-size: 14px;
		font-size: 3.73vw;
		line-height: 1.9;
	}
	
	/* スライド */
	#hydration .mech-slide {
		padding-right: 0;
	}
	#hydration .mech-slide .mech {
		width: auto;
	}
	#hydration .mech-slide p {
		font-size: 14px;
		font-size: 3.73vw;
		line-height: 1.5;
		letter-spacing: 1.2px;
	}
	#hydration .mech p::before {
		width: 84vw;
		margin: 21px auto 25px;
		background-size: 100% auto;
	}
	#hydration .mech-slide .slick-prev,
	#hydration .mech-slide .slick-next {
		margin: 0;
		top: 27vw;
		width: 50px;
		padding: 30px 0;
		opacity: 1 !important;
	}
	#hydration #a-keep .mech-slide .slick-prev,
	#hydration #a-keep .mech-slide .slick-next {
		top: 18.6vw;
	}
	#hydration #a-comfort .mech-slide .slick-prev,
	#hydration #a-comfort .mech-slide .slick-next {
		top: 36.6vw;
	}
	#hydration .skin-status .mech-slide .slick-prev,
	#hydration .skin-status .mech-slide .slick-next {
		top: 21.2vw;
	}
	#hydration .mech-slide .slick-prev {
		left: 0;
		padding-left: 5px;
	}
	#hydration .mech-slide .slick-next {
		right: 0;
		padding-right: 5px;
	}
	#hydration .mech-slide .slick-prev::before,
	#hydration .mech-slide .slick-next::before {
		color: #323232;
		font-size: 14px;
		opacity: 1 !important;
	}
	#hydration .mech-slide .slick-prev::before {
		float: left;
	}
	#hydration .mech-slide .slick-next::before {
		float: right;
	}
	
	/* ページ内ナビ */
	#hydration .hydration-nav ul {
		flex-direction: column;
		justify-content: flex-start;
		flex-wrap: wrap;
		width: auto;
		margin: 0 -1.33vw;
	}
	#hydration .hydration-nav li {
		width: 100%;
		margin: 0 0 2.67vw;
		padding: 0 1.33vw;
		font-size: 14px;
		font-size: 3.73vw;
		letter-spacing: 1.2px;
	}
	#hydration .hydration-nav li a {
		padding: 0.8em 12px;
		border-radius: 6px;
		opacity: 1 !important;
		transition: none;
	}
	#hydration .hydration-nav li a::after {
		top: 0;
		left: auto;
		right: 6px;
		bottom: 0;
		width: auto;
		height: 4vw;
		margin: auto 0;
		font-size: 4vw;
		content: "\e906";
	}
	#hydration .hydration-nav li br {
		display: none;
	}
	#hydration .hydration-nav li a span {
		letter-spacing: inherit;
	}
	
	/* メインビジュアル */
	#hydration #kv {
		margin-left: -22px;
		margin-right: -22px;
		padding: 57px 0 68px;
	}
	#hydration #kv h1 {
		height: 54.93vw;
		padding-top: 22.4vw;
		background-image: url(../img/sp_kv_bg.jpg);
		background-size: auto 100%;
		font-size: 17.5px;
		font-size: 4.67vw;
		line-height: 1.4;
		letter-spacing: 0.4px;
	}
	#hydration #kv h1 span {
		letter-spacing: 1.8px;
	}
	
	/* イントロ */
	#hydration .intro {
		margin: -4px 0 57px;
		margin-top: -5.7971vw;
		padding: 60px 8px 0;
		padding-top: 19.3236vw;
	}
	#hydration .intro h2 {
		margin: 0 -8px 29px;
		padding-bottom: 1px;
		font-size: 17px;
		font-size: 4.53vw;
		letter-spacing: 0.8px;
	}
	#hydration .intro > div {
		flex-direction: column;
	}
	#hydration .intro > div::before {
		width: 100%;
		height: 84vw;
		margin: 0;
		background-image: url(../img/sp_water.jpg);
	}
	#hydration .intro > div div {
		width: auto;
		margin-right: 0;
	}
	#hydration .intro p {
		margin: 24px 0 27px;
		letter-spacing: 0.8px;
	}
	#hydration .intro p:last-of-type {
		margin-bottom: 0;
	}
	
	/* 肌悩みと水分量の関係 */
	#hydration .relation h2 {
		margin: 0 -8px 24px;
		padding-bottom: 1px;
		font-size: 17px;
		font-size: 4.53vw;
		letter-spacing: 0;
	}
	#hydration .relation p {
		padding: 0;
		letter-spacing: 1.6px;
	}
	#hydration .relation .relation-factor {
		margin: 21px 0 22px;
	}
	#hydration .relation .relation-factor li {
		width: 26.4vw;
		font-size: 14px;
		font-size: 3.73vw;
		line-height: 1.15;
	}
	#hydration .relation .relation-factor li::before {
		height: 14vw;
		margin-bottom: 3.2vw;
	}
	#hydration .relation .relation-factor li.stress::before {
		background-size: auto 91.5%;
	}
	#hydration .relation .relation-factor li.uv::before {
		background-size: 100% 100%;
	}
	#hydration .relation .relation-factor li.aircon::before {
		background-size: auto 74.5%;
	}
	#hydration .relation picture {
		margin-top: 20px;
	}
	#hydration .relation picture img {
		width: 100%;
	}
	
	/* 肌の「水分量」を増やすには */
	#hydration .increase {
		margin-bottom: 63px;
	}
	#hydration .increase h2 {
		margin-top: 77px;
		margin-left: -30px;
		margin-right: -30px;
	}
	#hydration .increase p {
		padding: 0;
		text-align: justify;
		letter-spacing: 1.1px;
	}
	
	/* 肌を心地よく水分で満たす技術 */
	#hydration #a-technique {
		margin-top: -19.3236vw;
		padding-top: 19.3236vw;
	}
	#hydration .technique h2 {
		margin-left: -30px;
		margin-right: -30px;
	}
	#hydration .tech-lead {
		display: block;
		padding-left: 12px;
		padding-right: 0;
	}
	#hydration .tech-lead p {
		letter-spacing: 1px;
	}
	#hydration .tech-block {
		margin: -29px -8px 0;
		padding-top: 60px;
	}
	#hydration .tech-block h3 {
		margin: 0 0 25px;
	}
	#hydration #a-comfort h3 {
		letter-spacing: 1.4px;
	}
	/* 1）すばやく肌になじむこと */
	#hydration #a-absorb {
		margin-top: -2px;
	}
	#hydration #a-absorb h3 {
		margin-top: 0;
		margin-bottom: 24px;
	}
	#hydration #a-absorb p::before {
		height: 49.2vw;
	}
	#hydration .absorb1 p::before {
		background-image: url(../img/sp_absorb1.png);
	}
	#hydration .absorb2 p::before {
		background-image: url(../img/sp_absorb2.png);
	}
	/* 動画 */
	#hydration #a-absorb .movie {
		width: auto;
		margin-bottom: 42px;
		padding: 0 8px;
	}
	#hydration #a-absorb .movie p {
		margin-bottom: 24px;
		letter-spacing: 1px;
	}
	#hydration #a-absorb .movie p.sup {
		margin: 18px -8px 0;
		font-size: 10px;
		font-size: 2.67vw;
		line-height: 1.5;
		letter-spacing: 0.8px;
	}
	#hydration #a-absorb .movie > div {
		overflow: hidden;
		position: relative;
		height: 0;
		padding-top: 100%;
	}
	#hydration #a-absorb .movie iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
	/* 2）水分を肌にとどめ保つこと */
	#hydration #a-keep p::before {
		height: 30.93vw;
		margin-top: 24px;
	}
	#hydration .keep1 p::before {
		background-image: url(../img/sp_keep1.png);
	}
	#hydration .keep2 p::before {
		background-image: url(../img/sp_keep2.png);
	}
	/* 3）べたつかず、心地よい使用感であること */
	#hydration #a-comfort {
		margin-bottom: 0;
	}
	#hydration #a-comfort p::before {
		height: 67.33vw;
		margin-top: 24px;
	}
	#hydration .comfort1 p::before {
		background-image: url(../img/sp_comfort1.png);
	}
	#hydration .comfort2 p::before {
		background-image: url(../img/sp_comfort2.png);
	}
	#hydration #a-comfort p span.pad {
		padding-left: 0;
	}
	/* 4）水分を抱え続ける成分を探すこと */
	#hydration #a-inquiry {
		margin-top: -29px;
	}
	#hydration #a-inquiry h3 {
		letter-spacing: 1.2px;
	}
	#hydration #a-inquiry p {
		margin-bottom: 26px;
		letter-spacing: 1.2px;
	}
	#hydration #a-inquiry > div {
		width: auto;
		margin-top: 23px;
	}
	#hydration #a-inquiry > div p {
		margin: -2px 8px 23px;
		font-size: 9px;
		font-size: 2.4vw;
		line-height: 1.55;
		letter-spacing: 0.9px;
	}
	#hydration #a-inquiry img {
		width: 100%;
	}
	#hydration #a-inquiry .movie {
		margin: 0 8px;
	}
	#hydration #a-inquiry .movie > div {
		overflow: hidden;
		position: relative;
		height: 0;
		padding-top: 100%;
	}
	#hydration #a-inquiry .movie iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
	
	/* コットンパックと水分量の関係 */
	#hydration #a-cotton {
		margin-top: -2.4154vw;
		padding-top: 19.3236vw;
	}
	#hydration #a-cotton h2 {
		margin-left: -30px;
		margin-right: -30px;
		letter-spacing: 1.2px;
	}
	#hydration #a-cotton h3 {
		font-size: 17px;
		font-size: 4.53vw;
		letter-spacing: 1.2px;
	}
	#hydration #a-cotton .cotton1 h3 {
		letter-spacing: 1.6px;
	}
	#hydration #a-cotton > p {
		margin: 0;
		text-align: justify;
		letter-spacing: 1px;
	}
	#hydration #a-cotton .cotton-block {
		flex-direction: column;
	}
	#hydration #a-cotton .mech {
		width: auto !important;
		margin-top: 61px;
	}
	#hydration #a-cotton .cotton1 {
		margin-top: 58px;
	}
	#hydration #a-cotton .cotton2 {
		margin-left: 0;
		margin-right: 0;
	}
	#hydration #a-cotton .mech p {
		font-size: 14px;
		font-size: 3.73vw;
		line-height: 1.5;
	}
	#hydration #a-cotton .mech p::before {
		margin-top: 22px;
	}
	#hydration #a-cotton .cotton1 p::before {
		height: 41.6vw;
		background-image: url(../img/sp_cotton1.png);
	}
	#hydration #a-cotton .cotton2 p::before {
		height: 44.4vw;
		background-image: url(../img/sp_cotton2.png);
	}
	#hydration #a-cotton .cotton3 p::before {
		height: 34vw;
		background-image: url(../img/sp_cotton3.png);
	}
	
	/* 水分で満たされた肌の状態 */
	#hydration .skin-status {
		margin-top: 7px;
		margin-top: -3.1400vw;
		padding: 60px 0 0;
		padding-top: 19.3236vw;
	}
	#hydration .skin-status h2 {
		margin-top: 0;
		margin-left: -30px;
		margin-right: -30px;
		letter-spacing: 1.2px;
	}
	#hydration .skin-status > p {
		margin-left: 8px;
		margin-right: 8px;
		padding: 0;
		text-align: justify;
		letter-spacing: 1px;
	}
	#hydration .skin-status .mech-slide {
		margin-top: 59px;
	}
	#hydration .skin-status .mech {
		width: auto;
	}
	#hydration .skin-status h3 {
		font-size: 17px;
		font-size: 4.53vw;
	}
	#hydration .skin-status p::before {
		margin-top: 21px;
		margin-bottom: 24px;
	}
	#hydration .status1 p::before {
		height: 35.2vw;
		background-image: url(../img/sp_status1.png);
	}
	#hydration .status2 p::before {
		height: 47.2vw;
		background-image: url(../img/sp_status2.png);
	}
	
	/* アウトロ */
	#hydration .outro {
		margin: 57px 0 45px;
		padding-left: 7px;
		padding-right: 7px;
	}
	#hydration .outro p {
		margin-bottom: 63px;
		text-align: justify;
		letter-spacing: 0;
	}
	#hydration .outro ul.btn {
		margin-left: -7px;
		margin-right: -7px;
	}
	#hydration .outro li a {
		width: 100%;
		padding: 0.9em 12px;
		font-size: 14px;
		font-size: 3.73vw;
		opacity: 1 !important;
	}
	#hydration .outro li a::after {
		right: 6px;
	}
}
