@charset "UTF-8";

html {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	overflow-y: scroll;
	-webkit-text-size-adjust: 100%
}
*,:after,:before {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
	background-repeat: no-repeat
}
:after,:before {
	text-decoration: inherit;
	vertical-align: inherit
}
* {
	padding: 0;
	margin: 0
}
audio:not([controls]) {
	display: none;
	height: 0
}
hr {
	overflow: visible
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
	display: block
}
summary {
	display: list-item
}
small {
	font-size: 80%
}
[hidden],
template {
	display: none
}
abbr[title] {
	text-decoration: none;
	border-bottom: 1px dotted
}
a {
	background-color: transparent;
	-webkit-text-decoration-skip: objects
}
a:active,
a:hover {
	outline-width: 0
}
code,
kbd,
pre,
samp {
	font-family: monospace, monospace
}
b,
strong {
	font-weight: bolder
}
dfn {
	font-style: italic
}
mark {
	color: #000;
	background-color: #ff0
}
sub,
sup {
	position: relative;
	font-size: 75%;
	line-height: 0;
	vertical-align: baseline
}
sub {
	bottom: -0.25em
}
sup {
	top: -0.5em
}
input {
	border-radius: 0
}
[role=button],
[type=button],
[type=reset],
[type=submit],
button {
	cursor: pointer
}
[disabled] {
	cursor: default
}
[type=number] {
	width: auto
}
[type=search] {
	-webkit-appearance: textfield
}
[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
	-webkit-appearance: none
}
textarea {
	overflow: auto;
	resize: vertical
}
button,
input,
optgroup,
select,
textarea {
	font: inherit
}
optgroup {
	font-weight: 700
}
button {
	overflow: visible
}
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
	padding: 0;
	border-style: 0
}
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
	outline: 1px dotted ButtonText
}
[type=reset],
[type=submit],
button,
html [type=button] {
	-webkit-appearance: button
}
button,
select {
	text-transform: none
}
button,
input,
select,
textarea {
	color: inherit;
	background-color: transparent;
	border-style: none
}
select {
	-moz-appearance: none;
	-webkit-appearance: none
}
select::-ms-expand {
	display: none
}
select::-ms-value {
	color: currentColor
}
legend {
	display: table;
	max-width: 100%;
	color: inherit;
	white-space: normal;
	border: 0
}
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit
}
[type=search] {
	-webkit-appearance: textfield;
	outline-offset: -2px
}
img {
	border-style: none
}
progress {
	vertical-align: baseline
}
svg:not(:root) {
	overflow: hidden
}
audio,
canvas,
progress,
video {
	display: inline-block
}
@media screen {
	[hidden~=screen] {
		display: inherit
	}
	[hidden~=screen]:not(:active):not(:focus):not(:target) {
		position: absolute !important;
		clip: rect(0 0 0 0) !important
	}
}
[aria-busy=true] {
	cursor: progress
}
[aria-controls] {
	cursor: pointer
}
[aria-disabled] {
	cursor: default
}
::-moz-selection {
	color: #000;
	text-shadow: none;
	background-color: #b3d4fc
}
::selection {
	color: #000;
	text-shadow: none;
	background-color: #b3d4fc
}
button,
html,
input,
select,
textarea {
	color: #111
}
* {
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}
::-moz-selection {
	text-shadow: none;
	background: #000
}
hr {
	display: block;
	height: 1px;
	padding: 0;
	margin: 1em 0;
	border: 0;
	border-top: 1px solid #ccc
}
img {
	vertical-align: middle
}
li img {
	vertical-align: bottom
}
fieldset {
	padding: 0;
	margin: 0;
	border: 0
}
textarea {
	resize: vertical
}
body {
	position: relative;
	padding: 0;
	margin: 0;
	overflow-x: hidden;
	word-wrap: break-word
}
.clearfix::after {
	display: table;
	clear: both;
	content: ""
}
ul {
	padding: 0;
	margin: 0;
	list-style: none
}
ul li {
	padding: 0;
	margin: 0;
	list-style: none
}
body,
body>div,
button,
input,
select,
textarea {
	font-family: "游明朝", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
	line-height: 1.875;
	color: #555
}
h1 {
	margin: 0;
	font-size: 150%
}
h2 {
	margin: 0;
	font-size: 140%
}
h3 {
	margin: 0;
	font-size: 130%
}
h4 {
	margin: 0;
	font-size: 120%
}
h5 {
	margin: 0;
	font-size: 110%
}
p {
	padding: 0;
	margin: 0
}
a {
	color: #000;
	outline: 0 !important;
	-webkit-tap-highlight-color: transparent;
	tap-highlight-color: transparent
}
a:active,
a:focus,
a:hover {
	color: #333
}
a:hover {
	text-decoration: none
}
:focus {
	outline: 0
}
:placeholder-shown {
	opacity: .7
}
::-webkit-input-placeholder {
	opacity: .7
}
:-moz-placeholder {
	opacity: .7
}
::-moz-placeholder {
	opacity: .7
}
:-ms-input-placeholder {
	opacity: .7
}
.spOnly {
	display: none !important
}
@media(max-width:768px) {
	.spOnly {
		display: block !important
	}
}
.spOnlyIn {
	display: none !important
}
@media(max-width:768px) {
	.spOnlyIn {
		display: inline-block !important
	}
}
.spOnlyTb {
	display: none !important
}
@media(max-width:768px) {
	.spOnlyTb {
		display: table !important
	}
}
.pcOnly {
	display: block !important
}
@media(max-width:768px) {
	.pcOnly {
		display: none !important
	}
}
.pcOnlyIn {
	display: inline-block !important
}
@media(max-width:768px) {
	.pcOnlyIn {
		display: none !important
	}
}
.pcOnlyTb {
	display: table !important
}
@media(max-width:768px) {
	.pcOnlyTb {
		display: none !important
	}
}
html,
legend {
	color: #000
}
a,
a:hover {
	text-decoration: none
}
.clearfix:after,
q:after,
q:before {
	content: ""
}
body {
	width: 100%;
	padding: 0
}
html {
	background: #fff
}
blockquote,
body,
code,
dd,
div,
dl,
dt,
fieldset,
form,
h1,
h2,
h3,
h4,
h5,
h6,
input,
legend,
li,
ol,
p,
pre,
td,
textarea,
th,
ul {
	padding: 0;
	margin: 0
}
table {
	border-spacing: 0;
	border-collapse: collapse
}
fieldset,
img {
	border: 0
}
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
	font-style: normal;
	font-weight: 400
}
ol,
ul {
	list-style: none
}
caption,
th {
	text-align: left
}
.contents_ttl,
figcaption {
	text-align: center
}
h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: 100%;
	font-weight: 400
}
abbr,
acronym {
	-webkit-font-feature-settings: normal;
	font-feature-settings: normal;
	font-variant: normal;
	border: 0
}
sup {
	vertical-align: text-top
}
sub {
	vertical-align: text-bottom
}
input,
select,
textarea {
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit
}
html.modal_open {
	height: 100%
}
html.modal_open body {
	height: 100%;
	overflow-y: hidden
}
body {
	position: relative;
	font-size: 15px;
	color: #555;
	word-wrap: break-word;
	background: #fff;
	-webkit-text-size-adjust: none;
	-ms-text-size-adjust: none;
	-moz-text-size-adjust: none;
	text-size-adjust: none
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
	backface-visibility: hidden;
}
button,
input[type=submit],
label,
select {
	cursor: pointer
}
button,
input[type=submit],
input[type=text],
label,
select,
textarea {
	-webkit-appearance: none
}
a {
	color: #06f;
	outline: 0
}
em {
	font-style: normal;
	font-weight: 700
}
.clear {
	clear: both
}
.clearfix:after {
	display: table;
	clear: both
}
.ov:hover {
	opacity: .7
}
@media(max-width:768px) {
	body {
		font-size: 90%
	}
	img {
		line-height: 0;
		vertical-align: bottom
	}
	.ov:hover {
		opacity: 1
	}
}
.cmn_hover {
	-webkit-transition: opacity 0.3s;
	transition: opacity 0.3s
}
.cmn_hover:hover {
	opacity: .7
}
.nowrap {
	white-space: nowrap
}
figure {
	padding: 0
}
iframe[name=google_conversion_frame] {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 0;
	height: 0
}
@media(max-width:768px) {
	.cmn_hover:hover {
		opacity: 1
	}
}

.scroll-prevent {
	position: fixed;
	z-index: -1;
	width: 100%;
	height: 100%;
}

#header {
	position: absolute;
	top: 37px;
	right: 23px;
	z-index: 1000;
}
#header h1 a {
	width: 200px;
	display: block;
	transition: opacity .3s;
}
#header a:hover {
	opacity: .6;
}

@media(max-width:768px) {
	#header {
		top: 20px;
		right: 4.2666%;
	}
	#header h1 a {
		width: 121px;
	}
	#header a:hover {
		opacity: 1;
	}
}

.inview {
	opacity: 0;
	transform: translateY(100px);
	transition: opacity .8s, transform .8s;
}
.inview.show {
	opacity: 1;
	transform: translateY(0);
}

#mv {
	position: relative;
}
#mv img {
	display: block;
}
#mv figure img {
	width: 100%;
}
#mv h2 {
	position: absolute;
	left: 50%;
	top: 0;
	margin: 3.3333% 0 0 -20px;
}
.mv_copy {
	position: absolute;
	left: 50%;
	top: 0;
	margin: 42.6388% 0 0 -34.375%;
}

@media(max-width:768px) {
	#mv img {
		width: 100%;
	}
	#mv h2 {
		width: 65.0213%;
		left: auto;
		right: 5.8666%;
		margin-top: 9.1733%;
	}
	.mv_copy {
		width: 72.5333%;
		left: 6.0666%;
		top: 0;
		margin: 115.432% 0 0;
	}
}

#description {
	position: relative;
	padding: 70px 0 150px;
}
#description img {
	display: block;
}
#description .inner {
	width: 980px;
	margin: 0 auto;
	position: relative;
}
#description .inner p {
	font-size: 20px;
	line-height: 2;
	position: relative;
	z-index: 10;
}
#description .inner p + p {
	margin-top: 40px;
}
#description .inner p span {
	display: inline-block;
	position: relative;
}
#description .inner p span::before {
	content: '';
	display: block;
	position: absolute;
	left: 2px;
	right: 2px;
	bottom: 7px;
	height: 6px;
	background: #FFCBAA;
	z-index: -1;
}
.description_img figure:nth-child(1) {
	width: 401px;
	position: absolute;
	right: -67px;
	top: 10px;
	box-shadow: 5px 5px 0 #FFCBAA;
}
.description_img figure:nth-child(2) {
	width: 493px;
	position: absolute;
	left: 213px;
	bottom: 0;
	box-shadow: 5px 5px 0 #FFCBAA;
}
@media(max-width:768px) {
	#description {
		padding: 38px 5.3333% 44px;
	}
	#description .inner {
		width: auto;
		padding-bottom: 73px;
	}
	#description .inner p {
		font-size: 14px;
		line-height: 1.7;
	}
	#description .inner p + p {
		margin-top: 23px;
	}
	.description_img figure:nth-child(1) {
		width: 47.2405%;
		right: 5px;
		top: auto;
		bottom: 0;
		margin: 20px 0 0 auto;
	}
	.description_img figure img {
		width: 100%;
	}
	.description_img figure:nth-child(2) {
		width: 66.6666%;
		position: relative;
		left: auto;
		bottom: auto;
		margin: -16% 0 0 0;
	}
	#description .inner p span::before {
		left: 3px;
		right: 4px;
		bottom: 3px;
		height: 5px;
	}
}
@media(max-width:375px) {
	#description .inner p {
		font-size: 3.7333vw;
	}
}

.skincare {
	background: url(../img/skincare_bg.jpg) no-repeat center top / cover;
	padding: 67px 0 124px;
}
.skincare_product {
	width: 980px;
	margin: 0 auto;
	padding: 48px 0 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}
.skincare_product:last-child {
	padding-top: 53px;
	margin-bottom: 16px;
}
.skincare_product figure {
	width: 101px;
	margin: 1px 0 0 107px;
	position: relative;
}
.skincare_product figure img {
	position: relative;
}
.skincare_product figure::before {
	content: '';
	display: block;
	width: 0;
	height: 198px;
	background: url(../img/skincare_img_03.png) no-repeat left bottom / 260px auto;
	position: absolute;
	left: -109px;
	bottom: -115px;
	opacity: 0;
	transition: width .5s, opacity .5s;
	transition-delay: .5s;
}
.skincare_product figure.show::before {
	opacity: 1;
	width: 260px;
}
.skincare_product_info {
	width: 691px;
}
.skincare_product_point {
	position: relative;
	left: -2px;
	margin-bottom: 25px;
}
.skincare_product_name {
	font-size: 20px;
	font-weight: 500;
	line-height: 1.4;
	margin-left: -5px;
	letter-spacing: .01em;
	margin-bottom: 7px;
}
.skincare_product_price {
	font-weight: 500;
	font-size: 16px;
	line-height: 1.1;
	margin: -6px 0 0 -5px;
}
.skincare_product_price span {
	font-size: 40px;
	letter-spacing: -.03em;
}
.skincare_product_price span + span {
	font-size: 18px;
	letter-spacing: 0;
}
.skincare_product_btn {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	margin-top: 26px;
	margin-left: -5px;
}
.skincare_product_btn p {
	width: 335px;
}
.skincare_product_btn p + p {
	margin-left: 20px;
}
.skincare_product_btn p a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background: #555;
	color: #fff;
	border-radius: 30px;
	height: 60px;
	font-size: 20px;
	text-align: center;
	letter-spacing: .05em;
	box-shadow: 0 8px 10px rgba(0, 0, 0, .2);
	position: relative;
	transition: opacity .3s;
}
@media all and (-ms-high-contrast: none) {
	.skincare_product_btn p a {
		padding-top: 5px;
	}
}
.skincare_product_btn p a:hover {
	opacity: .6;
}
.skincare_product_btn p a::after {
	content: '';
	display: block;
	width: 30px;
	height: 30px;
	background: url(../img/icon_btn_arrow_01.svg) no-repeat;
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	transition: right .3s;
}
.skincare_product_btn p a:hover::after {
	right: 15px;
}
.skincare_product_link {
	text-align: center;
	font-size: 19.95px;
	margin-top: 27px;
	padding-left: 5px;
}
.skincare_product_link a {
	color: #555;
	border-bottom: 1px solid #555;
	padding-bottom: 2px;
	transition: opacity .3s;
}
.skincare_product_link a:hover,
.skincare_product_btn p a:hover {
	opacity: .6;
}

.skincare_trouble {
	background: #fff;
	text-align: center;
	width: 100%;
	margin: 141px 0 -124px;
	padding: 108px 0 130px;
}
.skincare_trouble h2 {
	font-size: 31.41px;
	letter-spacing: -.05em;
	padding-left: 13px;
}
.skincare_trouble h2 span {
	font-weight: bold;
	color: #FA987A;
}
.skincare_trouble ul {
	width: 748px;
	margin: 25px auto 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.skincare_trouble li {
	width: 230px;
	height: 230px;
	border-radius: 50%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background: #fff;
	border: 3px solid #9C8A76;
	font-weight: 500;
	font-size: 20px;
	line-height: 1.35;
	letter-spacing: -.1em;
}
.skincare_trouble li span {
	font-size: 32px;
	color: #FA987A;
	font-weight: bold;
	letter-spacing: -.2em;
}
.skincare_trouble li:first-child span {
	font-size: 28px;
}
.skincare_trouble_arrow {
	width: 455px;
	height: 104px;
	background: url(../img/skincare_arrow.svg) no-repeat left top / 100% auto;
	margin: 30px auto 41px;
	padding-top: 1px;
	color: #fff;
	font-size: 32px;
	letter-spacing: -.15em;
}
.skincare_trouble_about {
	width: 982px;
	margin: 0 auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.skincare_trouble_about figure {
	width: 480px;
	margin-right: 5px;
	position: relative;
}
.skincare_trouble_about figure img {
	display: block;
	box-shadow: 5px 5px 0 #FFCBAA;
}
.skincare_trouble_about_txt {
	flex: 1;
	font-size: 20px;
	line-height: 1.45;
	padding-right: 63px;
}
.skincare_trouble_about_txt strong {
	font-size: 32px;
	color: #FA987A;
	font-weight: bold;
}
.skincare_trouble_about_txt span {
	font-size: 32px;
	display: inline-block;
	position: relative;
}
.skincare_trouble_about_txt span::before {
	content: '';
	display: block;
	height: 8px;
	background: #FFCBAA;
	position: absolute;
	bottom: 6px;
	left: -4px;
	right: 4px;
	z-index: -1;
}

@media(max-width:768px) {
	.skincare {
		background-image: url(../img/skincare_bg_sp.jpg);
		padding: 58px 0 85px;
	}
	.skincare_product {
		width: auto;
		padding: 23px 5.3333% 0;
		display: block;
		position: relative;
	}
	.skincare_product:last-child {
		padding: 23px 5.3333% 0;
		margin-bottom: -8px;
	}
	.skincare_product figure {
		width: 13.6vw;
		margin: 0 0 0 21.3333vw;
	}
	.skincare_product figure::before {
		height: 34.4vw;
		background-image: url(../img/skincare_img_03_sp.png);
		background-size: 34.9333vw auto;
		left: -25.8666vw;
		bottom: 5.8666vw;
	}
	.skincare_product figure.show::before {
		width: 34.9333vw;
	}
	.skincare_product_info {
		width: auto;
	}
	.skincare_product_point {
		position: absolute;
		top: 23px;
		right: 10.6666vw;
		left: auto;
		width: 44vw;
		margin-bottom: 0;
	}
	.skincare_product_point img {
		width: 100%;
	}
	.skincare_product_name {
		font-size: 20px;
		margin-left: 0;
		font-feature-settings: "palt";
		margin-top: 11px;
		line-height: 1.6;
		letter-spacing: .05em;
	}
	.skincare_product_price {
		font-size: 18px;
		margin: -5px -10px 0 0;
		letter-spacing: -.04em;
	}
	.skincare_product_price span {
		font-size: 30px;
		margin-right: .08em;
	}
	.skincare_product_btn {
		display: block;
		margin-top: 34px;
		margin-left: 0;
	}
	.skincare_product_btn p {
		width: 100%;
	}
	.skincare_product_btn p + p {
		margin: 20px 0 0;
	}
	.skincare_product_btn p a {
		box-shadow: 0 4px 5px rgba(0, 0, 0, .2);
	}
	.skincare_product_btn p a:hover {
		opacity: 1;
	}
	.skincare_product_btn p a:hover::after {
		right: 20px;
	}
	.skincare_product_link {
		font-size: 20px;
		margin-top: 32px;
		text-align: center;
	}
	.skincare_product_link a:hover,
	.skincare_product_btn p a:hover {
		opacity: 1;
	}

	.skincare_trouble {
		margin: 77px 0 -85px;
		padding: 74px 0 85px;
	}
	.skincare_trouble h2 {
		font-size: 14px;
		padding-left: 0;
		letter-spacing: -.1em;
	}
	.skincare_trouble h2 span {
		font-weight: normal;
	}
	.skincare_trouble ul {
		width: 336px;
		margin: 15px auto 0;
	}
	.skincare_trouble li {
		width: 107px;
		height: 107px;
		border-width: 2px;
		letter-spacing: -.04em;
		font-size: 10px;
	}
	.skincare_trouble li span {
		font-size: 15px;
	}
	.skincare_trouble li:first-child span {
		font-size: 13px;
	}
	.skincare_trouble_arrow {
		width: 227px;
		height: 52px;
		margin: 19px auto 16px;
		padding-top: 1px;
		font-size: 16px;
		letter-spacing: 0;
	}
	.skincare_trouble_about {
		width: auto;
		display: block;
	}
	.skincare_trouble_about figure {
		width: 89.3333vw;
		margin: 40px auto 0;
	}
	.skincare_trouble_about_txt {
		font-size: 16px;
		line-height: 1.4;
		padding-right: 0;
	}
	.skincare_trouble_about_txt strong {
		font-size: 25px;
	}
	.skincare_trouble_about_txt span {
		font-size: 25px;
		font-weight: bold;
	}
	.skincare_trouble_about_txt span::before {
		height: 5px;
		bottom: 5px;
		left: -2px;
		right: 2px;
	}
}
@media(max-width:375px) {
	.skincare_product_name {
		font-size: 5.3333vw;
	}
	.skincare_product_price {
		font-size: 4.8vw;
		margin: -5px -2.6666vw 0 0;
	}
	.skincare_product_price span {
		font-size: 8vw;
	}
	.skincare_trouble h2 {
		font-size: 3.7333vw;
	}
	.skincare_trouble ul {
		width: 89.6vw;
	}
	.skincare_trouble li {
		width: 28.5333vw;
		height: 28.5333vw;
		font-size: 2.6666vw;
	}
	.skincare_trouble li span {
		font-size: 4vw;
	}
	.skincare_trouble li:first-child span {
		font-size: 3.4666vw;
	}
	.skincare_trouble_about_txt {
		font-size: 4.2666vw;
		line-height: 1.4;
		padding-right: 0;
	}
	.skincare_trouble_about_txt strong {
		font-size: 6.6666vw;
	}
	.skincare_trouble_about_txt span {
		font-size: 6.6666vw;
	}
}

#relax {
	background: #F9DFC8 url(../img/relax_bg.png) no-repeat center bottom / 1440px auto;
	padding: 136px 0 126px;
}
#relax .inner {
	width: 980px;
	margin: 0 auto;
}
#relax .inner > p,
#relax .inner > h2 {
	width: 470px;
	text-align: center;
	white-space: nowrap;
}
.relax_txt {
	font-size: 20px;
	font-weight: bold;
}
.relax_txt span {
	display: inline-block;
	background: #9C8A76;
	color: #fff;
	font-size: 26px;
	padding: 5px 17px 3px;
	line-height: 1.3;
	margin-bottom: 23px;
	margin-left: 20px;
	font-weight: normal;
	position: relative;
}
.relax_txt span::before {
	content: '';
	display: block;
	position: absolute;
	top: -5px;
	left: -5px;
	right: -5px;
	bottom: -5px;
	border: 1px solid #9C8A76;
}
#relax .inner > h2 {
	margin-top: 21px;
	font-size: 80px;
	line-height: 1.1;
}
#relax .inner > h2 span {
	position: relative;
	display: inline-block;
}
#relax .inner > h2 span::before {
	content: '';
	display: block;
	height: 8px;
	background: #FFCBAA;
	position: absolute;
	bottom: 11px;
	left: 13px;
	right: 12px;
	z-index: -1;
}
#relax .inner > h2 span:first-child:before {
	left: 0;
	right: -6px;
	bottom: 8px;
}

@media(max-width:768px) {
	#relax {
		background: #fbe2cc url(../img/relax_bg_sp.jpg) no-repeat center bottom / 100% auto;
		padding: 83px 0 77.8666vw;
	}
	#relax .inner {
		width: auto;
	}
	#relax .inner > p,
	#relax .inner > h2 {
		width: auto;
	}
	.relax_txt {
		font-size: 20px;
		line-height: 1.25;
	}
	.relax_txt span {
		font-size: 16px;
		padding: 5px 18px;
		margin-left: 0;
		line-height: 1.1;
	}
	.relax_txt span::before {
		top: -3px;
		left: -3px;
		right: -3px;
		bottom: -3px;
	}
	.relax_age {
		font-size: 30px;
		margin: -2px 0 -10px;
	}
	.relax_age::before,
	.relax_age::after {
		vertical-align: 10px;
		width: 50px;
	}
	#relax .inner > h2 {
		margin-top: 12px;
		line-height: 1;
		letter-spacing: .05em;
		font-size: 50px;
	}
	#relax .inner > h2 span::before {
		bottom: 2px;
		left: 12px;
		right: 17px;
	}
	#relax .inner > h2 span:first-child:before {
		left: -1px;
		right: 7px;
		bottom: 2px;
	}
}

#scene {
	background: #EEE;
	padding: 117px 0 110px;
}
#scene img {
	display: block;
}
#scene .inner {
	width: 980px;
	margin: 0 auto;
}
#scene h2 {
	text-align: center;
	font-size: 70px;
	line-height: 1.3;
	font-weight: normal;
	letter-spacing: .05em;
	padding-left: .05em;
	margin-bottom: 21px;
}
#scene h2 span {
	display: block;
	font-size: 23.56px;
	letter-spacing: 0;
}
#scene ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
#scene ul li {
	width: 314px;
}
#scene .inner > p {
	width: 399px;
	margin: 50px auto 0;
}

@media(max-width:768px) {
	#scene {
		padding: 76px 0 79px;
	}
	#scene .inner {
		width: auto;
	}
	#scene h2 {
		font-size: 35px;
		margin-bottom: 21px;
	}
	#scene h2 span {
		font-size: 20px;
		margin-bottom: 4px;
	}
	#scene ul {
		display: block;
	}
	#scene ul li {
		width: 89.3333vw;
		margin: 0 auto;
		position: relative;
	}
	#scene ul li + li {
		margin-top: 30px;
	}
	#scene .inner > p {
		width: 89.3333vw;
		margin: 40px auto 0;
	}
	#scene .inner > p img {
		width: 100%;
	}
}

#uv {
	background: #F9DFC8;
	padding: 108px 0 120px;
}
#uv h2 {
	text-align: center;
	font-size: 70px;
	line-height: 1.3;
	margin-bottom: 45px;
}
#uv h2 span {
	position: relative;
	display: inline-block;
}
#uv h2 span:first-child {
	font-size: 50px;
}
#uv h2 span.uv_line:before {
	content: '';
	height: 8px;
	background: #FFCBAA;
	display: block;
	position: absolute;
	bottom: 15px;
	left: 0;
	right: -8px;
	z-index: -1;
}
#uv h2 span:first-child:before {
	right: 0;
	left: -8px;
}
#uv ul {
	width: 980px;
	margin: 0 auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.uv_base {
	width: 313px;
	background: url(../img/uv_bg.jpg) no-repeat left bottom / cover;
	text-align: center;
	padding: 43px 0 24px;
}
.uv_base figure {
	width: 146.5px;
	margin: 30px 55px 0 auto;
	position: relative;
}
.uv_base figure img {
	position: relative;
}
.uv_base figure::before {
	content: '';
	display: block;
	width: 0;
	height: 161.5px;
	background: url(../img/uv_img_02.png) no-repeat left top / 163.5px auto;
	position: absolute;
	top: -2px;
	left: -58px;
	opacity: 0;
	transition: width .5s, opacity .5s;
	transition-delay: .5s;
}
.uv_base.show figure::before {
	opacity: 1;
	width: 163.5px;
}
.uv_base h3 img {
	margin: 0 auto;
}
.uv_powder {
	width: 647px;
	background: #fff;
	position: relative;
	text-align: center;
	padding: 18px 0 36px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	align-content: flex-start;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.uv_powder::before {
	content: '';
	display: block;
	width: 50px;
	height: 50px;
	background: url(../img/icon_plus.svg) no-repeat;
	position: absolute;
	left: -34px;
	top: 50%;
	margin-top: -25px;
}
.uv_powder h3 {
	width: 100%;
	font-size: 50px;
	font-feature-settings: "palt";
	letter-spacing: -.05em;
	position: relative;
	z-index: 10;
}
.uv_powder_spf {
	display: block;
	width: 75px;
	height: 75px;
	border-radius: 50%;
	background: #9C8A76;
	color: #fff;
	text-align: center;
	font-size: 16px;
	position: absolute;
	font-feature-settings: normal;
	letter-spacing: 0;
	line-height: 1.35;
	right: 20px;
	top: 3px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.uv_powder figure {
	width: 302px;
	margin: -34px -22px 0 -14px;
}
.uv_powder_txt {
	width: 275px;
	font-size: 20px;
	line-height: 1.65;
	padding-top: 5px;
	left: 5px;
	position: relative;
}
.uv_powder_info {
	display: inline-block;
	text-align: left;
	line-height: 1.3;
	margin-top: 30px;
	padding-left: 10px;
}
.uv_powder_price {
	font-size: 24px;
	margin-top: -4px;
	text-align: right;
}
.uv_powder_price span {
	font-size: 40px;
}
.uv_btn {
	width: 580px;
	margin-top: 2px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.uv_btn p {
	width: 280px;
}
.uv_btn p a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	align-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	height: 60px;
	background: #555;
	color: #fff;
	font-size: 18px;
	line-height: 1.3;
	border-radius: 30px;
	letter-spacing: .05em;
	padding-right: 10px;
	position: relative;
	box-shadow: 0 8px 10px rgba(0, 0, 0, .2);
	transition: opacity .3s;
}
@media all and (-ms-high-contrast: none) {
	.uv_btn p a {
		padding-top: 5px;
	}
}
.uv_btn p a:hover {
	opacity: .6;
}
.uv_btn p a::after {
	content: '';
	display: block;
	width: 30px;
	height: 30px;
	background: url(../img/icon_btn_arrow_01.svg) no-repeat;
	position: absolute;
	right: 15px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	transition: right .3s;
}
.uv_btn p a:hover::after {
	right: 10px;
}
.uv_btn p a span {
	font-size: 16px;
	width: 100%;
}

@media(max-width:768px) {
	#uv {
		padding: 74px 0 60px;
	}
	#uv h2 {
		font-size: 35px;
		line-height: 1.15;
		letter-spacing: -.1em;
		margin-bottom: 37px;
	}
	#uv h2 span.uv_line:before {
		bottom: 2px;
		left: 0;
		right: -3px;
	}
	#uv h2 span:first-child {
		font-size: 30px;
	}
	#uv ul {
		width: 89.3333%;
		display: block;
	}
	#uv ul img {
		width: 100%;
	}
	.uv_base {
		border-radius: 10px;
		width: 100%;
		height: 55.7333vw;
		padding: 18.9333vw 0 24px;
		position: relative;
	}
	.uv_base h3 {
		width: 51.7333vw;
		margin: 0 0 0 5.3333vw;
	}
	.uv_base figure {
		width: 24.976vw;
		margin: 0;
		position: absolute;
		top: 5.6vw;
		right: 4.5333vw;
	}
	.uv_base figure::before {
		height: 27.5573vw;
		top: -0.5333vw;
		left: -9.8666vw;
		background-size: 27.9066vw auto;
	}
	.uv_base.show figure::before {
		opacity: 1;
		width: 27.9066vw;
	}
	.uv_powder {
		width: 100%;
		border-radius: 10px;
		margin-top: 4vw;
		padding: 15px 0 42px;
		display: block;
	}
	.uv_powder::before {
		width: 10.6666vw;
		height: 10.6666vw;
		background-size: 100% auto;
		left: 50%;
		top: -7.2vw;
		margin-left: -5.3333vw;
		margin-top: 0;
		z-index: 10;
	}
	.uv_powder h3 {
		font-size: 8vw;
		line-height: 1.1;
		padding: 11.2vw 42.6666vw 0 0;
		position: relative;
	}
	.uv_powder_spf {
		width: 13.3333vw;
		height: 13.3333vw;
		font-size: 2.6666vw;
		letter-spacing: 0;
		line-height: 1.35;
		right: 2.6666vw;
		top: -1.0666vw;
	}
	.uv_powder figure {
		width: 40.2666vw;
		position: absolute;
		top: 2.1333vw;
		right: 6.6666vw;
		margin: 0;
	}
	.uv_powder_txt {
		width: auto;
		font-size: 3.7333vw;
		padding-top: 6.1333vw;
	}
	.uv_powder_info {
		width: 72vw;
		padding: 0;
		margin: 2.1333vw auto 0;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		-webkit-box-align: end;
		-ms-flex-align: end;
		align-items: flex-end;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.uv_powder_info p:first-child {
		width: 100%;
	}
	.uv_powder_info p:last-child {
		padding-bottom: .5333vw;
	}
	.uv_powder_price {
		font-size: 14px;
		margin-top: 4px;
		text-align: center;
		padding-right: 0;
	}
	.uv_powder_price span {
		font-size: 20px;
	}
	.uv_btn {
		width: 78.6666vw;
		margin: 22px auto 0;
		display: block;
	}
	.uv_btn p {
		width: auto;
	}
	.uv_btn p + p {
		margin-top: 20px;
	}
	.uv_btn p a {
		font-size: 20px;
		letter-spacing: 0;
		box-shadow: 0 4px 5px rgba(0, 0, 0, .2);
	}
	.uv_btn p a:hover {
		opacity: 1;
	}
	.uv_btn p a:hover::after {
		right: 15px;
	}
}
@media(max-width:375px) {
	#uv h2 {
		font-size: 9.3333vw;
	}
	#uv h2 span:first-child {
		font-size: 8vw;
	}
	.uv_btn p a {
		font-size: 5.3333vw;
	}
	.uv_btn p a span {
		font-size: 4.2666vw;
	}
	.uv_powder_price {
		font-size: 3.7333vw;
	}
}

#point {
	padding: 117px 0 129px;
}
.point_ttl {
	text-align: center;
	font-size: 23.98px;
	line-height: 1.25;
	margin-bottom: 41px;
}
.point_ttl h2 {
	font-size: 70px;
	font-feature-settings: "palt";
	letter-spacing: -.09em;
}
.point_ttl h2 > span {
	color: #FA987A;
	font-feature-settings: normal;
	letter-spacing: 0;
	margin-left: -5px;
	vertical-align: 4px;
}
.point_ttl h2 > span span {
	font-size: 50px;
	display: inline-block;
	margin-left: -18px;
	letter-spacing: -.05em;
}
#point img {
	display: block;
}
.point_item {
	width: 752px;
	margin: 0 auto;
}
.point_item + .point_item {
	margin-top: 51px;
}
.point_item + .point_item + .point_item {
	margin-top: 89px;
}
.point_item h3 {
	width: 146.5px;
	margin: 0 auto 38px;
}
.point_item + .point_item h3 {
	width: 155px;
	margin-bottom: 44px;
}
.point_item + .point_item + .point_item h3 {
	width: 153px;
	margin-bottom: 36px;
}
.point_catch {
	text-align: center;
	font-size: 24px;
	line-height: 1.15;
}
.point_catch p:last-child {
	font-size: 50px;
	margin-top: 1px;
}
.point_catch p:last-child span {
	font-size: 80px;
}
.point_item + .point_item .point_catch p:last-child {
	margin-top: 13px;
}
.point_item ul {
	margin: 21px auto 25px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.point_item ul li {
	width: 142px;
	height: 142px;
	border-radius: 50%;
	background: url(../img/point_bg_01.png) no-repeat left top  / 100% auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-weight: 500;
	font-size: 20px;
	text-align: center;
	line-height: 1.3;
	font-feature-settings: "palt";
}
.point_ingredient {
	position: relative;
	text-align: center;
	margin-bottom: 119px;
}
.point_ingredient::after {
	content: '';
	display: block;
	width: 219px;
	height: 50px;
	background: url(../img/point_arrow.svg) no-repeat;
	position: absolute;
	bottom: -80px;
	left: 50%;
	margin-left: -109px;
}
.point_ingredient::before {
	content: '';
	display: block;
	height: 1px;
	background: #9C8A76;
	position: absolute;
	left: 0;
	right: 0;
	top: 50%;
}
.point_ingredient > span {
	display: inline-block;
	background: #fff;
	padding: 0 15px;
	position: relative;
	z-index: 2;
}
.point_ingredient > span span {
	display: inline-block;
	border: 1px solid #9C8A76;
	border-radius: 15px;
	font-size: 16px;
	color: #9C8A76;
	line-height: 1.4;
	padding: 4px 22px 2px;
}
.point_item_inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	position: relative;
}
.point_catch + .point_item_inner {
	margin-top: 34px;
}
.point_item_inner figure {
	width: 440px;
}
.point_item_inner figure img {
	display: block;
	box-shadow: 5px 5px 0 #FFCBAA;
}
.point_icon {
	position: absolute;
	top: 39px;
	right: 39px;
	width: 226px;
}
.point_txt {
	width: 388px;
	background: #C9E1BD;
	position: absolute;
	top: 180px;
	right: 2px;
	line-height: 1.4;
	padding: 20px 25px;
	font-size: 16px;
}
.point_test {
	margin: 20px 0 0 -2px;
	font-size: 16px;
}
.point_test span {
	font-size: 12px;
}

@media(max-width:768px) {
	#point {
		padding: 77px 0 81px;
	}
	.point_ttl {
		font-size: 20px;
		margin-bottom: 25px;
	}
	.point_ttl h2 {
		font-size: 50px;
		line-height: 1.05;
		margin-top: 10px;
	}
	.point_ttl h2 > span {
		margin-left: -5px;
		vertical-align: 4px;
	}
	.point_ttl h2 > span span {
		font-size: 35px;
		margin-left: 0;
	}
	.point_item {
		width: auto;
	}
	.point_item + .point_item {
		margin-top: 55px;
	}
	.point_item + .point_item + .point_item {
		margin-top: 59px;
	}
	.point_item h3 {
		width: 103px;
		margin: 0 auto 18px;
	}
	.point_item + .point_item h3 {
		width: 109px;
		margin-bottom: 17px;
	}
	.point_item + .point_item + .point_item h3 {
		width: 107px;
		margin-bottom: 17px;
	}
	.point_catch {
		font-size: 20px;
	}
	.point_catch p:last-child {
		font-size: 35px;
		margin-top: 4px;
	}
	.point_catch p:last-child span {
		font-size: 50px;
	}
	.point_item + .point_item .point_catch p:last-child {
		margin-top: 13px;
	}
	.point_item ul {
		width: 375px;
		margin: 38px auto 24px;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.point_item ul li {
		width: 106px;
		height: 106px;
		margin: 0 4px 4px;
		font-size: 15px;
	}
	.point_item ul li:nth-child(1) {
		margin-left: 50px;
	}
	.point_item ul li:nth-child(2) {
		margin-right: 50px;
	}
	.point_ingredient {
		width: 90.6666%;
		margin: 0 auto 141px;
	}
	.point_ingredient::after {
		width: 164px;
		height: 38px;
		background-size: 100% auto;
		bottom: -61px;
		margin-left: -82px;
	}
	.point_ingredient > span span {
		border-radius: 15px;
		font-size: 14px;
		padding: 3px 10px 1px;
	}
	.point_item_inner {
		display: block;
	}
	.point_catch + .point_item_inner {
		margin-top: 76px;
	}
	.point_item_inner figure {
		width: 100%;
	}
	.point_item_inner figure img {
		width: 100%;
		box-shadow: none;
	}
	.point_icon {
		top: -52px;
		right: auto;
		left: 50%;
		margin-left: -90px;
		width: 180px;
	}
	.point_txt {
		width: 89.3333vw;
		position: relative;
		top: auto;
		right: auto;
		margin-top: -36px;
		line-height: 1.45;
		padding: 18px 20px 15px;
		font-size: 14px;
	}
	.point_test {
		margin: 13px 5.0666% 0;
		font-size: 12px;
		line-height: 1.6;
	}
	.point_test span {
		display: block;
		font-size: 10px;
		margin-left: -.5em;
	}
}

@media(max-width:375px) {
	.point_ttl {
		font-size: 5.3333vw;
	}
	.point_ttl h2 {
		font-size: 13.3333vw;
	}
	.point_ttl h2 > span span {
		font-size: 9.3333vw;
	}
	.point_catch {
		font-size: 5.3333vw;
	}
	.point_catch p:last-child {
		font-size: 9.3333vw;
	}
	.point_catch p:last-child span {
		font-size: 13.3333vw;
	}
	.point_item ul {
		width: 100%;
	}
	.point_item ul li {
		width: 28.2666vw;
		height: 28.2666vw;
		margin: 0 1.0666vw 1.0666vw;
		font-size: 4vw;
	}
	.point_item ul li:nth-child(1) {
		margin-left: 13.3333vw;
	}
	.point_item ul li:nth-child(2) {
		margin-right: 13.3333vw;
	}
}

#step {
	width: 796px;
	margin: 0 auto;
	text-align: center;
	padding: 90px 0 116px;
}
#step img {
	display: block;
}
#step h2 {
	font-size: 60px;
	font-feature-settings: "palt";
	margin-bottom: 30px;
}
#step h2 span {
	height: auto;
	display: inline-block;
	background: -moz-linear-gradient(top, rgba(255,203,170,0) 0%, rgba(255,203,170,0) 65%, rgba(255,203,170,1) 65%, rgba(255,203,170,1) 73%, rgba(255,203,170,0) 73%);
	background: -webkit-linear-gradient(top, rgba(255,203,170,0) 0%,rgba(255,203,170,0) 65%,rgba(255,203,170,1) 65%,rgba(255,203,170,1) 73%, rgba(255,203,170,0) 73%);
	background: linear-gradient(to bottom, rgba(255,203,170,0) 0%,rgba(255,203,170,0) 65%,rgba(255,203,170,1) 65%,rgba(255,203,170,1) 73%, rgba(255,203,170,0) 73%);
}
#step ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	padding-right: 5px;
}
#step ul li {
	width: 360px;
	position: relative;
}
#step ul li + li::before {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 14.5px 0 14.5px 26px;
	border-color: transparent transparent transparent #9C8A76;
	position: absolute;
	top: 105px;
	left: -46px;
}
#step ul li figure {
	position: relative;
}
#step ul li figure img {
	position: relative;
	box-shadow: 5px 5px 0 #C9E1BD;
}
#step ul li p {
	font-size: 20px;
	line-height: 1.5;
	margin-top: 29px;
}

@media(max-width:768px) {
	#step {
		width: 90.6666%;
		padding: 60px 0 66px;
	}
	#step h2 {
		font-size: 40px;
		margin-bottom: 22px;
	}
	#step h2 span {
		background: -moz-linear-gradient(top, rgba(255,203,170,0) 0%, rgba(255,203,170,0) 65%, rgba(255,203,170,1) 65%, rgba(255,203,170,1) 75%, rgba(255,203,170,0) 75%);
		background: -webkit-linear-gradient(top, rgba(255,203,170,0) 0%,rgba(255,203,170,0) 65%,rgba(255,203,170,1) 65%,rgba(255,203,170,1) 75%, rgba(255,203,170,0) 75%);
		background: linear-gradient(to bottom, rgba(255,203,170,0) 0%,rgba(255,203,170,0) 65%,rgba(255,203,170,1) 65%,rgba(255,203,170,1) 75%, rgba(255,203,170,0) 75%);
	}
	#step ul {
		display: block;
	}
	#step ul li {
		width: auto;
	}
	#step ul li p {
		margin-top: 26px;
	}
	#step ul li + li {
		margin-top: 60px;
	}
	#step ul li + li::before {
		content: '';
		display: block;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 25px 14.5px 0 14.5px;
		border-color: #9C8A76 transparent transparent transparent;
		position: absolute;
		top: -46px;
		left: 50%;
		margin-left: -14.5px;
	}
	#step ul li figure img {
		margin: 0 auto;
	}
}

#banner {
	padding: 60px 0 40px;
	text-align: center;
}
#banner ul {
	width: 978px;
	margin: 0 auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}
#banner ul li {
	width: 469px;
}
#banner ul li a {
	display: block;
	font-size: 20px;
	color: #555;
	transition: opacity .3s;
}
#banner ul li a:hover {
	opacity: .6;
}
#banner ul li p + p {
	margin-top: 13px;
}
#banner ul li a[target="_blank"] p + p::after {
	content: '';
	display: inline-block;
	width: 20px;
	height: 20px;
	background: url(../img/icon_external.svg) no-repeat left top;
	vertical-align: -1px;
	margin-left: 13px;
}

@media(max-width:768px) {
	#banner {
		padding: 60px 0 43px;
	}
	#banner ul {
		width: 89.3333%;
		display: block;
	}
	#banner ul li {
		width: auto;
	}
	#banner ul li + li {
		margin-top: 31px;
	}
	#banner ul li a {
		font-size: 16px;
	}
	#banner ul li a:hover {
		opacity: 1;
	}
	#banner ul li a[target="_blank"] p + p::after {
		width: 15px;
		height: 15px;
		background-size: 15px auto;
		margin-left: 10px;
	}
	#banner ul li p + p {
		margin-top: 9px;
	}
}

#sns {
	width: 980px;
	margin: 0 auto;
	padding: 42px 0 47px;
	border-top: 1px solid #CCC;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: 20px;
}
#sns img {
	display: block;
}
#sns ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin-left: 58px;
}
#sns ul a {
	color: #555;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	transition: opacity .3s;
}
#sns ul a:hover {
	opacity: .6;
}
#sns ul li + li {
	margin-left: 40px;
}
#sns ul a img {
	margin-right: 10px;
}
#sns ul a img[src*="instagram"] {
	width: 30px;
}

@media(max-width:768px) {
	#sns {
		width: 89.3333vw;
		padding: 32px 0 28px;
		display: block;
		font-size: 16px;
		text-align: center;
	}
	#sns ul {
		margin-left: 0;
		margin-top: 4px;
	}
	#sns ul a:hover {
		opacity: 1;
	}
	#sns ul li + li {
		margin-left: 15px;
	}
	#sns ul a img {
		margin-right: 4px;
	}
	#sns ul a img[src*="facebook"],
	#sns ul a img[src*="youtube"] {
		width: 25px;
		margin-bottom: 3px;
	}
	#sns ul a img[src*="instagram"] {
		width: 23px;
	}
}

@media(max-width:375px) {
	#sns {
		padding: 8.5333vw 0 7.4666vw;
		font-size: 4.2666vw;
	}
	#sns ul li + li {
		margin-left: 4vw;
	}
	#sns ul a img {
		margin-right: 1.0666vw;
	}
	#sns ul a img[src*="facebook"],
	#sns ul a img[src*="youtube"] {
		width: 6.6666vw;
		margin-bottom: .8vw;
	}
	#sns ul a img[src*="instagram"] {
		width: 6.1333vw;
	}
}

#footer_area {
	background: #555;
	color: #fff;
}
.footer_sns {
	padding: 52px 0 32px;
}
.footer_sns h2 {
	font-size: 20px;
	margin-bottom: 21px;
	text-align: center;
}
.footer_sns ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.footer_sns ul li {
	margin: 0 12px;
	position: relative;
}
.footer_sns ul li iframe {
	position: absolute!important;
	display: block;
	width: 100%!important;
	height: 100%!important;
	cursor: pointer;
	opacity: 0;
}
.footer_sns ul li a {
	display: block;
}
@media(min-width:769px) {
	.footer_sns ul li:hover {
		position: relative;
	}
	.footer_sns ul li:hover::before {
		content: '';
		display: block;
		background: #fff;
		width: 46px;
		height: 46px;
		border-radius: 50%;
		position: absolute;
		left: 1px;
		right: 1px;
		top: 1px;
		bottom: 1px;
	}
	.footer_sns ul li:hover a {
		position: relative;
	}
	#footerSns_facebook:hover {
		background: url(../img/footer_facebook_on.svg) no-repeat;
	}
	#footerSns_twitter:hover {
		background: url(../img/footer_twitter_on.svg) no-repeat;
	}
	#footerSns_line:hover {
		background: url(../img/footer_line_on.svg) no-repeat;
	}
	#footerSns_email:hover {
		background: url(../img/footer_mail_on.svg) no-repeat;
	}
	#footerSns_facebook:hover img,
	#footerSns_twitter:hover img,
	#footerSns_line:hover img,
	#footerSns_email:hover img {
		visibility: hidden;
	}
}
@media(max-width:768px) {
	.footer_sns {
		padding: 25px 0 34px;
	}
	.footer_sns h2 {
		font-size: 16px;
		margin-bottom: 10px;
	}
	.footer_sns ul li {
		width: 30px;
		margin: 0 7.5px;
	}
	.copyArea {
		font-size: 12px;
		padding: 0 10px 22px;
		letter-spacing: .05em;
	}
}

.copyArea {
	text-align: center;
	font-size: 16px;
	padding: 0 10px 54px;
}
.icon_linkArrow:after {
	width: 8px;
	height: 15px;
	margin-right: 5px;
	background-image: url(https://www.kissme-ferme.jp/common/img/common/arrow_right_small.png);
}
.icon:after {
	content: '';
	display: inline-block;
	vertical-align: middle;
	background-size: auto;
	background-repeat: no-repeat;
	background-position: 0 0;
}
.companyInfo {
	width: 100%;
	padding: 30px 0 0;
	background: #eaeaea;
	font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", 'ヒラギノ角ゴ', 'Hiragino Kaku Gothic', meiryo, sans-serif;
	font-size: 16px;
	line-height: 1.7;
}
.pagetop_wrap {
	width: 100%;
	margin: 0 auto;
	position: fixed;
	left: 0;
	bottom: 0;
}
.pagetop {
	width: 980px;
	margin: 0 auto;
	position: relative;
}
.pagetop a {
	display: block;
	width: 40px;
	height: 40px;
	position: absolute;
	right: -50px;
	bottom: 10px;
}
.pagetop a:hover {
	opacity: .8;
}
.pagetop img {
	width: 40px;
	height: auto;
}
@media all and (max-width: 719px) {
	.pagetop {
		width: 100%;
	}
	.pagetop a {
		right: 5px;
		bottom: 5px;
	}
	.icon_linkArrow:after {
		width: 6px;
		height: 13px;
		background-image: url(https://www.kissme-ferme.jp/common/img/common/arrow_right.png);
		background-size: cover;
	}
}
.companyInfo a {
	color: #333;
	text-decoration: none;
}
.companyInfo .company_holder {
	-js-display: flex;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-bottom: 20px;
	width: 100%;
}
.companyInfo .companyLogo {
	-webkit-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}
.companyInfo .companyLogo a {
	display: block;
	width: 102px;
}
.companyInfo .companyLogo img {
	max-width: 100%;
	vertical-align: bottom;
}
.companyInfo .inlineList {
	width: 850px;
	text-align: center;
	position: relative;
}
.companyInfo .inlineList .inlineList_item {
	margin: 0 15px;
	font-size: 14px;
	-webkit-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}
.companyInfo .inlineList .inlineList_item:hover {
	opacity: 0.8;
}
.companyInfo .copyright {
	display: block;
	width: 100%;
	padding: 20px 0;
	background: url('https://www.kissme-ferme.jp/common/img/common/bottom_line_pc.png') repeat-x center 0;
	text-align: center;
}
.companyInfo .copyright small {
	font-size: 12.8px;
}
.inlineList .inlineList_item {
	display: inline-block;
}
@media all and (max-width: 719px) {
	.companyInfo {
		padding-top: 15px;
		font-size: 12px;
	}
	.companyInfo .company_holder {
		display: block;
	}
	.companyInfo .company_holder .companyLogo {
		margin-bottom: 15px;
	}
	.companyInfo .company_holder .companyLogo a {
		width: 32%;
		margin: 0 auto;
	}
	.companyInfo .inlineList {
		width: 100%;
		margin-bottom: 15px;
		right: 0;
	}
	.companyInfo .inlineList .inlineList_item {
		margin: 0 5px;
		font-size: 11px;
	}
	.companyInfo .companyGroup {
		text-align: center;
	}
	.companyInfo .copyright {
		padding: 10px;
		font-size: 10px;
	}
	.companyInfo .copyright small {
		font-size: 8px;
	}
}

.footer_inner {
	width: 1000px;
	padding: 0 10px;
	margin: 0 auto;
	position: relative;
}
@media all and (max-width: 719px) {
	.footer {
		padding-top: 35px;
	}
	.footer_inner {
		width: 100%;
		padding: 0;
	}
}