@charset "utf-8";

/*-----
 * Default Layout
 */
@keyframes show {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

* {
	margin: 0;
	padding: 0;
}
html {
	overflow-y: scroll;
	height: 100%;
	background: url(../img/c_bg.jpg) no-repeat 50% 50% fixed;
	background-size: cover;
}
html.locked {
	overflow: hidden;
}
body {
	min-width: 988px;
	height: 100%;
	color: #000;
	font-family: "kozuka-mincho-pro", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "MS PMincho", serif;
	font-size: 62.5%; /* 10px */
	font-weight: 500;
	-webkit-text-size-adjust: none;
}
h1, h2, h3, h4, h5, h6 {
	font-size: 160%;
	line-height: 120%;
}
p, dt, dd, li, th, td {
	font-size: 140%;
}
img {
	border: none;
	vertical-align: bottom;
}
option {
	padding-right: 1em;
}
b, strong {
	font-weight: 700;
}
sup {
	vertical-align: top;
}
::selection {
	background-color: #fceaee;
}
img::selection {
	background-color: transparent;
}

/*
 * 共通
 */
/* 言語、SNS */
ul.lang,
ul.sns {
	list-style: none;
	overflow: hidden;
}
ul.sns li {
	float: left;
}
ul.sns li.sns-line {
	display: none;
}
ul.lang li span.c,
ul.lang li a,
ul.sns li a {
	overflow: hidden;
	display: block;
	text-decoration: none;
	text-indent: 110%;
	white-space: nowrap;
}
ul.lang li a:hover,
ul.sns li a:hover {
	opacity: 0.7;
}
/* 大文字表示 */
.upper {
	text-transform: uppercase;
}
/* PC非表示 */
.pc-none {
	display: none;
}

/*
 * ヘッダー
 */
#header {
	position: fixed;
	z-index: 100;
	top: 0;
	left: 0;
	width: 100%;
	background-color: #fff;
}
#header .c-inner {
	position: relative;
	width: 988px;
	height: 69px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
}
#logo a {
	overflow: hidden;
	display: block;
	width: 188px;
	height: 69px;
	margin: 0 auto;
	background: url(../img/c_logo.png) no-repeat 50% 50%;
	text-decoration: none;
	text-indent: 100%;
	white-space: nowrap;
}
#header p.menu {
	position: absolute;
	top: 0;
	left: 0;
}
#header p.menu a {
	overflow: hidden;
	display: block;
	width: 69px;
	height: 69px;
	background: url(../img/c_menu.png) no-repeat 50% 50%;
	text-decoration: none;
	text-indent: 100%;
	white-space: nowrap;
}
/* 言語 */
#header ul.lang {
	position: absolute;
	top: -2px;
	right: 0;
	width: 78px;
	border: 1px solid #e63556;
	border-width: 0 1px 1px;
	padding: 0 0 8px;
	background-color: #fff;
	transition: none .5s ease;
	transition-property: top, padding;
}
#header ul.lang:after {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 5px;
	width: 10px;
	height: 8px;
	margin: 0 auto;
	background: url(../img/c_lang_arrow.png) no-repeat 50% 100%;
	content: "";
}
#header ul.lang li {
	overflow: hidden;
}
#header ul.lang li:not(.current) {
	height: 0;
	transition: height .25s ease;
}
#header ul.lang li span.c,
#header ul.lang li a {
	height: 26px;
	background: url(../img/c_lang_pd.png) no-repeat 50% 0;
}
#header ul.lang li.lang-en span.c,
#header ul.lang li.lang-en a {
	background-position: 50% -30px;
}
#header ul.lang li.lang-cn span.c,
#header ul.lang li.lang-cn a {
	background-position: 50% -60px;
}
#header ul.lang li.lang-tw span.c,
#header ul.lang li.lang-tw a {
	background-position: 50% -90px;
}
/* ナビゲーション */
#nav {
	position: fixed;
	z-index: 200;
	top: 0;
	left: -100%;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	border: 6px solid #e63556;
	background-color: #fff;
	transition: left 0.5s ease;
}
#nav div.menu {
	overflow: hidden;
	width: 618px;
	margin: 0 auto;
}
#nav div.menu div {
	float: left;
	width: 470px;
}
#nav ul {
	list-style: none;
}
#nav a {
	color: #e63556;
	text-decoration: none;
}
#nav ul.nav {
	margin: 60px 0 40px;
}
#nav ul.nav li {
	margin-bottom: 22px;
	font-size: 240%;
	font-weight: 700;
	line-height: 120%;
	text-transform: uppercase;
}
#nav ul.nav li a {
	padding: 0 4px;
}
#nav ul.nav li.current a,
#nav ul.nav li a:hover {
	border-bottom: 1px solid #e63556;
}
#nav ul.nav li small {
	font-size: 83%;
}
/* SNS */
#nav ul.sns {
	display: inline-block;
	padding: 20px 0 50px;
}
#nav ul.sns li {
	margin: 0 6px;
}
#nav ul.sns li a {
	width: 48px;
	height: 48px;
	background: url(../img/c_header_sns.png) no-repeat 100% 0;
}
#nav ul.sns li.sns-tw a {
	background-position: -48px 0;
}
/* 言語 */
#nav ul.lang {
	float: right;
	width: 108px;
	margin-top: 56px;
	padding-right: 40px;
}
#nav ul.lang li {
	margin-bottom: 14px;
}
#nav ul.lang li a {
	width: 100%;
	height: 36px;
	background: url(../img/c_lang.png) no-repeat 0 0;
}
#nav ul.lang li.lang-en a {
	background-position: 0 -50px;
}
#nav ul.lang li.lang-cn a {
	background-position: 0 -100px;
}
#nav ul.lang li.lang-tw a {
	background-position: 0 -150px;
}
/* 閉じる */
#nav p.close {
	overflow: hidden;
	position: absolute;
	top: 0;
	right: 0;
	width: 80px;
	height: 78px;
	background: #e63556 url(../img/c_btn_close.png) no-repeat 50% 50%;
	text-align: left;
	text-indent: 100%;
	white-space: nowrap;
	cursor: pointer;
}
/* メニュー表示 */
#nav.open {
	left: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
#nav.open > div {
	overflow: auto;
	height: 100%;
	-webkit-overflow-scrolling: touch;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

/*
 * コンテンツ
 */
.mincho {
	font-family: "kozuka-mincho-pro", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "MS PMincho", serif;
}
.gothic {
	font-family: "kozuka-gothic-pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.contents .c-inner {
	width: 988px;
	margin: 0 auto;
}
.contents p,
.contents li {
	line-height: 165%;
}
/* タイトル */
.contents #title {
	width: 298px;
	margin: 103px auto 0;
	padding: 46px 0 30px;
	border: 1px solid #a7a7a7;
	background-color: #fff;
	background-color: rgba(255,255,255,0.7);
	background-repeat: no-repeat;
	background-position: 50% 25px;
	font-size: 180%;
	font-weight: 500;
	text-align: center;
	letter-spacing: 1px;
}
/* クコ */
.contents span.ku,
.contents span.ko {
	position: relative;
}
.contents span.ku:before,
.contents span.ko:before {
	position: absolute;
	top: -11px;
	left: 0;
	right: 0;
	margin: 0 auto;
	font-size: 50%;
	text-align: center;
}
.contents span.ku:before {
	content: "ク";
}
.contents span.ko:before {
	content: "コ";
}
/* 白シャドウ */
.shadow {
	text-shadow: 2px 0 21px #fff, 0 2px 21px #fff, -2px 0 21px #fff, 0 -2px 21px #fff;
}
/* 葉 */
.bg-leaf {
	overflow: hidden;
	position: relative;
}
.bg-leaf:before,
.bg-leaf:after,
.bg-leaf > .c-inner:before,
.bg-leaf > .c-inner:after {
	position: absolute;
	z-index: 1;
	top: 0;
	width: 100%;
	min-width: 1088px;
	background-repeat: no-repeat;
	background-position: 0 0;
	content: "";
}
.bg-leaf:before {
	right: 0;
	height: 517px;
	background-image: url(../img/c_leaf_lt.png);
}
.bg-leaf:after {
	left: 0;
	min-width: 1288px;
	height: 371px;
	background-image: url(../img/c_leaf_rt.png);
	background-position: 100% 0;
}
.bg-leaf > .c-inner:before {
	top: 526px;
	right: 0;
	height: 716px;
	background-image: url(../img/c_leaf_lb.png);
}
.bg-leaf > .c-inner:after {
	top: 479px;
	left: 0;
	height: 499px;
	background-image: url(../img/c_leaf_rb.png);
	background-position: 100% 0;
}
/* オンラインショップ、定期お届けサービスボタン */
a.to-os,
a.to-rp {
	overflow: hidden;
	display: block;
	width: 266px;
	height: 59px;
	margin: 0 auto;
	background: #e63556 url(../img/c_btn_os.png) no-repeat 50% 50%;
	color: #fff;
	text-indent: 100%;
	white-space: nowrap;
	transition: background-color 0.5s ease;
}
a.to-os:hover,
a.to-rp:hover {
	background-color: #ed7188;
}
/* 定期お届けサービスボタン */
a.to-rp {
	margin-top: 12px; 
	background-image: url(../img/c_btn_rp.png);
}

/*
 * コンテンツフッター
 */
#cont-footer {
	position: relative;
	z-index: 90;
}
#os-block .c-inner,
#other-block .c-inner {
	overflow: hidden;
	width: 988px;
	margin: 0 auto;
	padding: 0;
}
#os-block a,
#other-block a {
	text-decoration: none;
}
/* オンラインショップ */
#os-block {
	padding: 60px 0 104px;
	background-color: #fff;
	text-align: center;
}
#os-block h2 {
	padding-top: 32px;
	background: url(../img/c_os_h.png) no-repeat 50% 0;
	font-size: 180%;
}
#os-block ul {
	list-style: none;
	display: inline-block;
	padding-top: 38px;
	vertical-align: bottom;
}
#os-block ul:after {
	clear: both;
	display: block;
	content: "";
}
#os-block li {
	float: left;
	width: 358px;
	padding-top: 258px;
	background: url(../img/c_os_products.png) no-repeat -225px 0;
	font-size: 190%;
	line-height: 120%;
}
#os-block li:first-child {
	background-position: 133px 0;
}
#os-block li small {
	display: block;
	margin: 6px 0 8px;
	font-size: 68%;
	letter-spacing: 1px;
}
/* その他コンテンツ */
#other-block {
	overflow: hidden;
	padding: 107px 0 152px;
}
#other-block .c-inner {
	display: flex;
	justify-content: space-between;
	width: auto;
	max-width: 1002px;
}
#other-block a:hover {
	opacity: 0.7;
}
#other-block .c-inner > div {
	overflow: hidden;
	flex: 0 0 auto;
	box-sizing: border-box;
	width: 482px;
	height: 188px;
	border: 1px solid #eff0f2;
	background-color: #fff;
}
/* お問い合わせ先 */
#other-block #ob-contact {
	padding-top: 35px;
	text-align: center;
}
#other-block #ob-contact h2 {
	margin-bottom: 20px;
	font-size: 220%;
}
#other-block #ob-contact p {
	font-size: 180%;
	line-height: 180%;
}
#other-block #ob-contact a {
	color: inherit;
}
#other-block #ob-contact p span.tel {
	display: inline-block;
	padding-left: 55px;
	background: url(../img/c_other_fd.png) no-repeat 0 4px;
	font-size: 200%;
}
/* SNS */
#other-block #ob-sns {
	background: #fff url(../img/c_other_share.png) no-repeat 134px 50%;
}
#other-block #ob-sns ul {
	margin: 67px 0 0 245px;
}
#other-block #ob-sns li {
	margin-right: 10px;
}
#other-block #ob-sns li a {
	width: 46px;
	height: 46px;
	background: url(../img/c_other_sns.png) no-repeat 0 0;
	background-position: 2px 0;
}
#other-block #ob-sns li.sns-fb a {
	background-position: 100% 0;
}
/* ページの先頭に戻る */
#pagetop {
	display: none;
}

/*
 * 資生堂フッター
 */
#footer {
	position: absolute;
	z-index: 99;
	width: 100%;
	min-width: 988px;
}

/*
 * 外部タグ
 */
img[src*="doubleclick.net/"] {
	position: absolute;
	z-index: -1;
	bottom: 0;
}
/* Default Layout */


/*-----
 *  PC Layout: 768px
 */
@media screen and (min-width:768px) {
	/*
	 * ヘッダー
	 */
	/* 言語 */
	#header ul.lang:hover {
		top: 0;
		padding: 11px 0 27px;
	}
	#header ul.lang:hover:after {
		background-position: 50% 0;
	}
	#header ul.lang:hover li {
		height: 30px;
	}
} /* PC Layout */


/*-----
 *  Mobile Layout: 480px, 320px
 */
@media screen and (max-width:767px) {
	html {
		overflow-y: visible;
		height: auto;
		background: none;
	}
	body {
		min-width: inherit;
		height: auto;
	}
	body:before {
		position: fixed;
		z-index: -1;
		width: 100%;
		height: 100%;
		background: url(../img/sp_c_bg.jpg) no-repeat 0 50%;
		background-size: cover;
		content: "";
	}
	
	/*
	 * 共通
	 */
	/* 言語、SNS */
	ul.sns li.sns-line {
		display: block;
	}
	ul.lang li a:hover,
	ul.sns li a:hover {
		opacity: 1;
	}
	/* PC非表示 */
	.pc-none {
		display: block;
	}
	br.pc-none {
		display: inline;
	}
	/* スマホ非表示 */
	.sp-none {
		display: none;
	}
	
	/*
	 * ヘッダー
	 */
	#header {
		transition: background-color .3s ease;
	}
	#header .c-inner {
		width: 100%;
		height: 48px;
	}
	#logo {
		animation: show .3s ease;
	}
	#logo a {
		width: 112px;
		height: 48px;
		background-image: url(../img/sp_c_logo.png);
		background-size: contain;
	}
	#header p.menu a {
		width: 68px;
		height: 48px;
		background-image: url(../img/sp_c_menu.png);
		background-size: auto 48px;
	}
	#header ul.lang {
		position: absolute;
		top: -4px;
		width: 65px;
		border: none;
		padding: 0 0 4px;
		cursor: pointer;
	}
	#header ul.lang:after {
		bottom: 3px;
		width: 7px;
		height: 9px;
		background-image: url(../img/sp_c_lang_arrow.png);
		background-size: 7px auto;
		transition: bottom .5s ease;
	}
	#header ul.lang li span.c,
	#header ul.lang li a {
		height: 30px;
		background-image: url(../img/sp_c_lang_pd.png);
		background-size: 65px auto;
	}
	#header ul.lang.open {
		top: 0;
		padding: 5px 0 35px;
	}
	#header ul.lang.open:after {
		bottom: 12px;
		background-position: 50% 0;
	}
	#header ul.lang.open li {
		height: 30px;
	}
	#header.top {
		background-color: transparent;
		transition-duration: 0s;
	}
	#header.top #logo {
		display: none;
	}
	/* ナビゲーション */
	#nav {
		border-width: 5px;
		text-align: center;
	}
	#nav div.menu {
		width: auto;
	}
	#nav div.menu div {
		float: none;
		width: auto;
	}
	#nav ul.nav {
		margin: 43px 0 0;
	}
	#nav ul.nav li {
		margin-bottom: 17px;
		font-size: 150%;
	}
	#nav ul.nav li:not(.current) a:hover {
		border-bottom: none;
	}
	/* SNS */
	#nav ul.sns {
		padding: 20px 0 25px;
	}
	#nav ul.sns li a {
		width: 40px;
		height: 40px;
		background-image: url(../img/sp_c_header_sns.png);
		background-size: auto 40px;
	}
	#nav ul.sns li.sns-line a {
		background-position: 0 0;
	}
	#nav ul.sns li.sns-tw a {
		background-position: -40px 1px;
	}
	/* 言語 */
	#nav ul.lang {
		float: none;
		display: -webkit-flex;
		display: flex;
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
		width: 182px;
		margin: 0 auto;
		padding-right: 0;
	}
	#nav ul.lang li {
		width: 75px;
		margin-bottom: 10px;
		padding: 0 8px;
	}
	#nav ul.lang li a {
		height: 25px;
		background-image: url(../img/sp_c_lang.png);
		background-size: 166px auto;
	}
	#nav ul.lang li.lang-en a {
		background-position: 100% 0;
	}
	#nav ul.lang li.lang-cn a {
		background-position: 0 -35px;
	}
	#nav ul.lang li.lang-tw a {
		background-position: 100% -35px;
	}
	/* 閉じる */
	#nav p.close {
		top: -5px;
		right: -5px;
		width: 50px;
		height: 50px;
		background-image: url(../img/sp_c_btn_close.png);
		background-size: contain;
	}

	/*
	 * コンテンツ
	 */
	.contents .c-inner {
		width: auto;
	}
	/* タイトル */
	.contents #title {
		width: 248px;
		margin-top: 82px;
		padding: 38px 0 24px;
		background-color: rgba(255,255,255,0.5);
		background-position: 50% 21px;
		background-size: auto 12px;
		font-size: 150%;
	}
	/* 白シャドウ */
	.shadow {
		text-shadow: 2px 0 10px #fff, 0 2px 10px #fff, -2px 0 10px #fff, 0 -2px 10px #fff;
	}
	/* 葉 */
	.bg-leaf:before,
	.bg-leaf:after,
	.bg-leaf > .c-inner:before,
	.bg-leaf > .c-inner:after {
		min-width: inherit !important;
		background-position: 0 0 !important;
		background-size: contain !important;
	}
	.bg-leaf:before {
		top: 420px;
		left: -15px;
		right: auto;
		width: 124px;
		height: 253px;
		background-image: url(../img/sp_c_leaf_lt.png);
	}
	.bg-leaf:after {
		left: auto;
		right: 0;
		width: 151px;
		height: 153px;
		background-image: url(../img/sp_c_leaf_rt.png);
	}
	.bg-leaf > .c-inner:before {
		top: auto;
		left: 0;
		right: auto;
		bottom: 0;
		width: 98px;
		height: 124px;
		background-image: url(../img/sp_c_leaf_lb.png);
	}
	.bg-leaf > .c-inner:after {
		top: auto;
		left: auto;
		right: -45px;
		bottom: 140px;
		width: 106px;
		height: 215px;
		background-image: url(../img/sp_c_leaf_rb.png);
	}
	/* オンラインショップ、定期お届けサービスボタン */
	a.to-os,
	a.to-rp {
		width: 201px;
		height: 45px;
		background-image: url(../img/sp_c_btn_os.png);
		background-size: contain;
		transition: none;
	}
	a.to-rp:hover,
	a.to-os:hover {
		background-color: #e63556;
	}
	/* 定期お届けサービスボタン */
	a.to-rp {
		margin-top: 10px; 
		background-image: url(../img/sp_c_btn_rp.png);
	}
	
	/*
	 * コンテンツフッター
	 */
	#cont-footer {
		padding-bottom: 30px;
	}
	#os-block .c-inner,
	#other-block .c-inner {
		width: 100%;
	}
	/* オンラインショップ */
	#os-block {
		padding: 38px 0 0;
	}
	#os-block h2 {
		padding-top: 27px;
		background-image: url(../img/sp_c_os_h.png);
		background-size: 115px auto;
		font-size: 150%;
	}
	#os-block ul {
		display: block;
		padding-top: 56px;
	}
	#os-block li {
		float: none;
		width: 100%;
		margin-bottom: 42px;
		padding-top: 200px;
		background: url(../img/sp_c_os_products.png) no-repeat 50% -375px;
		background-size: 90px auto;
		font-size: 150%;
	}
	#os-block li:first-child {
		margin-bottom: 54px;
		background-position: 50% 0;
	}
	#os-block li small {
		font-size: 73%;
	}
	/* その他コンテンツ */
	#other-block {
		padding: 0;
		background: none;
	}
	#other-block .c-inner {
		flex-direction: column;
		justify-content: flex-start;
		max-width: none;
	}
	#other-block a:hover {
		opacity: 1;
	}
	#other-block .c-inner > div {
		width: 100%;
		height: auto;
		margin: 0;
		border-width: 1px 0 0;
		border-color: #e6e6e6;
	}
	/* お問い合わせ先 */
	#other-block #ob-contact {
		padding: 25px 0;
	}
	#other-block #ob-contact h2 {
		margin-bottom: 14px;
		font-size: 150%;
	}
	#other-block #ob-contact p {
		font-size: 120%;
	}
	#other-block #ob-contact p span.tel {
		padding-left: 37px;
		background: url(../img/sp_c_other_fd.png) no-repeat 0 2px;
		background-size: 31px auto;
	}
	/* SNS */
	#other-block #ob-sns {
		padding: 24px 0 20px;
		background-color: transparent;
		background-image: none;
		text-align: center;
	}
	#other-block #ob-sns ul {
		display: inline-block;
		margin: 0 auto;
	}
	#other-block #ob-sns li {
		margin: 0 4px;
	}
	#other-block #ob-sns li a {
		width: 40px;
		height: 40px;
		background-image: url(../img/sp_c_other_sns.png);
		background-size: auto 40px;
	}
	#other-block #ob-sns li.sns-tw a {
		background-position: -42px 1px;
	}
	/* ページの先頭に戻る */
	#pagetop {
		display: block;
	}
	#pagetop a {
		overflow: hidden;
		display: block;
		width: 100%;
		height: 45px;
		background: url(../img/sp_c_pagetop.png) no-repeat 50% 7px;
		background-size: 47px auto;
		text-indent: 100%;
		white-space: nowrap;
	}
	
	/*
	 * 資生堂フッター
	 */
	#footer {
		min-width: inherit;
	}
} /* Mobile Layout */


/*-----
 *  Print
 */
@media print {
	html {
		overflow-y: visible;
	}
}
