#skinvisiom {
	text-align:left;
}

#skinvisiom .main_contents h2,
#skinvisiom .main_contents h3,
#skinvisiom .main_contents h4 {
	font-weight: normal;
}

#skinvisiom #header_skinv{
	margin: 15px auto;
	position: relative;
	text-align: left;
	width: 960px;
	}

#skinvisiom #breadcrumbs ul {
	overflow: hidden;
	zoom: 1;
}

#skinvisiom #breadcrumbs .group ul {
	float: left;
}

#skinvisiom #breadcrumbs ul li {
	display: inline;
	margin-right: 5px;
	font-size: 83%;
	color: #666666;
}

#skinvisiom #breadcrumbs ul li span,
#skinvisiom #breadcrumbs ul li a {
	padding-right: 14px;
	background: url("/shared/navi/img/icon_breadcrumbs_navi.gif") no-repeat right 3px;
	zoom: 1;
}

#skinvisiom #breadcrumbs ul li a {
	color: #463937;
}

#skinvisiom #breadcrumbs ul li a:hover {
	color: #e95079;
}

#skinvisiom #breadcrumbs div.sns {
	position: relative;
	float: right;
	top: 0px;
	right: 0px;
}

#skinvisiom .page_ttl{
	width:960px;
	margin:auto;
	overflow:hidden;
}

#skinvisiom .page_ttl h1{
	float: left;
	margin-bottom: 0px;
	font-size: 166%;
	line-height: 1.2;
	margin: 0 0 15px;
}

#skinvisiom .main_contents {
	color: #000;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'メイリオ', Meiryo, sans-serif;
}

#skinvisiom .main_contents img {
	max-width: 100%;
	height: auto;
}

#skinvisiom .container {
	padding: 60px 0 70px;
	background-color: #f5f3ed;
}

.text-red {
	color: #ba0c2f;
}

.sec-inner {
	width: 960px;
	margin: 0 auto;
}

.shop-search__btn-wrap {
	display: flex;
	margin-top: 15px;
	justify-content: center;
}

.product-course__about-flex + .shop-search__btn-wrap {
	margin-top: 27px;
}

.product-course__slide + .shop-search__btn-wrap {
	margin-top: 25px;
}

.shop-search__btn {
	text-align: center;
	display: inline-block;
	min-width: 290px;
	font-size: 16px;
	padding: 12px 44px 12px 25px;
	color: #fff !important;
	text-decoration: none;
	position: relative;
	border-radius: 5px;
	background-color: #ba0c2f;
	box-sizing: border-box;
	transition: 0.4s;
}

.shop-search__btn--large {
	padding: 18px 44px 18px 25px;
}

.shop-search__btn:hover {
	background-color: #000;
}

.shop-search__btn::after {
	position: absolute;
	content: "";
	top: 50%;
	right: 8px;
	width: 10px;
  height: 10px;
  margin: 0 10px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}

.shop-search__btn .icon {
	position: relative;
	padding-left: 45px;
}

.shop-search__btn .icon::before {
	position: absolute;
	content: "";
	top: 50%;
	left: 0;
	width: 36px;
	height: 24px;
	transform: translateY(-50%);
	background-image: url('../img/icon_search_white.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100%;
}


/*  コンテンツ
-----------------------------------------------------------*/
/* mv ================ */
.mv {
	background-image: url('../img/mv_bg.jpg');
	background-repeat: no-repeat;
	background-position: center right;
	background-size: cover;
}

.mv__inner {
	position: relative;
	width: 960px;
	height: 420px;
	margin: 0 auto;
}

.mv__group {
	position: absolute;
	top: 10px;
	left: calc(-47 / 960 * 100%);
	width: 437px;
	height: 437px;
	color: #fff;
	padding-top: 84px;
	text-align: center;
	background-image: url('../img/mv_catch_bg.png');
	background-repeat: no-repeat;
	background-size: 100%;
}

.mv__text {
	display: inline-block;
	font-size: 18px;
	padding-bottom: 6px;
	margin-bottom: 15px;
	letter-spacing: 0.05em;
	line-height: calc(24 / 18);
	border-bottom: 1px solid #f25f7c;
}

.mv__catch {
	width: 100%;
	font-size: 37px;
	letter-spacing: 0.03em;
	line-height: calc(56 / 37);
}

/* 資生堂のお店 肌チェック ================ */
.check__heading {
	font-size: 36px;
	letter-spacing: 0.02em;
	text-align: center;
	line-height: calc(52 / 36);
}

.check__lead {
	font-size: 16px;
	text-align: center;
	margin-top: 20px;
}

.check__heading-sub {
	font-size: 26px;
	text-align: center;
	margin-top: 66px;
	letter-spacing: 0.02em;
}

.check__heading-sub .line {
	position: relative;
	display: inline-block;
	padding-bottom: 7px;
	border-bottom: 1px solid #707070;
}

.check__heading-sub .line::before,
.check__heading-sub .line::after {
	position: absolute;
	content: "";
	left: 50%;
	transform: translateX(-50%);
	border-style: solid;
}

.check__heading-sub .line::before {
	bottom: -19px;
	border-width: 18px 11px 0px 11px;
	border-color: #707070 transparent;
}

.check__heading-sub .line::after {
	bottom: -17px;
	border-width: 17px 10px 0px 10px;
	border-color: #f5f3ed transparent;
}

.check-products {
	display: flex;
	margin-top: 45px;
}

.check-product {
	flex: 1;
	padding: 43px 40px;
	border-radius: 10px;
	background-color: #fff;
	background-repeat: no-repeat;
}

.check-product--skinvisiom {
	background-image: url('../img/img_sokuteiki01.png');
	background-size: 200px;
	background-position: 92% 16px;
}

.check-product--handyskin {
	background-image: url('../img/img_sokuteiki02.png');
	background-size: 99px;
	background-position: 87% 16px;
}

.check-product + .check-product {
	margin-left: 30px;
}

.check-product__item {
	font-size: 20px;
	line-height: calc(30 / 20);
}

.check-product__logo {
	margin-top: 37px;
}

.check-product__logo--skinvisiom {
	width: 232px;
}

.check-product__logo--handyskin {
	width: 285px;
}

.check-product__lists {
	margin-top: 26px;
	display: flex;
	flex-wrap: wrap;
}

.check-product__list {
	font-size: 15px;
	padding: 7px 7px 6px;
	line-height: 1;
	margin: 5px 5px 0 0;
	text-align: center;
	border: 1px solid #ccc;
	background-color: #fff;
}

.check-product__list:nth-child(-n+4) {
	margin-top: 0;
}

.check-product__list:last-child {
	margin-right: 0;
}

.check-product__list--style {
	flex-grow: 1;
	margin-right: 0;
}

.check-product__more {
	font-size: 14px;
	text-align: center;
	margin-top: 24px;
}

.check-product__more a {
	color: #000;
	display: block;
	transition: 0.4s;
}

.check-product__more .arrow {
	position: relative;
	padding-left: 25px;
	display: inline-block;
}

.check-product__more .arrow::before {
	position: absolute;
	content: "";
	left: 0;
	width: 10px;
  height: 10px;
	margin-top: 2px;
  border-bottom: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
	transition: 0.4s;
}

.check-product__more:hover a {
	color: #ba0c2f;
}

.check-product__more:hover .arrow::before {
	border-bottom-color: #ba0c2f;
	border-right-color: #ba0c2f;
}

.check-product .shop-search__btn {
	margin-top: 25px;
	width: 100%;
}

/* 商品紹介 ================ */
.product__head {
	height: 460px;
	display: flex;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center right;
}

.product__head-inner {
	max-width: 1300px;
	padding: 158px 0 0 115px;
	box-sizing: border-box;
	transition: padding 0.3s;
}

@media screen and (max-width:1200px) {
	.product__head-inner {
		padding-left: 60px;
	}
}

.product__head-heading {
	color: #1e202b;
	font-size: 28px;
	letter-spacing: 0.075em;
	margin-top: 33px;
	line-height: calc(54 / 28);
}

.product__head-heading--indent {
	text-indent: -0.8em;
	padding-left: 0.8em;
}

.product__main {
	margin-top: 48px;
}

.product-about {
	display: flex;
}

.product-about__img {
	flex-shrink: 0;
}

.product-about__text {
	color: #1e202b;
	font-size: 16px;
	margin-top: 20px;
	line-height: calc(36 / 16);
	letter-spacing: 0.05em;
}

.product-about__text .note {
	font-size: 12px;
	line-height: calc(24 / 12);
	padding-left: 1em;
	text-indent: -1em;
	margin-top: 10px;
	letter-spacing: 0.05em;
}

.product-course {
	margin-top: 17px;
}

.product-course__lead {
	font-size: 24px;
	text-align: center;
	letter-spacing: 0.17em;
	margin-bottom: 22px;
}

.product-course__group {
	padding: 50px 80px 0;
	border-radius: 10px;
	background-color: #fff;
}

.product-course__group + .product-course__group {
	margin-top: 20px;
}

.product-course__heading-type01 {
	color: #ba0c2f;
	font-size: 32px;
	text-align: center;
	letter-spacing: 0.075em;
}

.product-course__heading-type01 span {
	width: 375px;
	position: relative;
	display: inline-block;
	padding: 5px 5px;
	margin: 0 auto;
	box-sizing: border-box;
}

.product-course__heading-type01 span::before,
.product-course__heading-type01 span::after {
	content: "";
	position: absolute;
	width: 25px;
	height: 25px;
}

.product-course__heading-type01 span::before {
	top: 0;
	left: 0;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
}

.product-course__heading-type01 span::after {
	right: 0;
	bottom: 0;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}

.product-course__heading-type02 {
	color: #ba0c2f;
	font-size: 24px;
	text-align: center;
	letter-spacing: 0.17em;
}

.product-course__heading-type03 {
	width: 213px;
	margin: 0 auto;
	position: relative;
	font-size: 22px;
	text-align: center;
}

.product-course__heading-type03::after {
	position: absolute;
	content: "";
	top: 50%;
	left: 0;
	width: 100%;
	height: 1px;
	transform: translateY(-50%);
	background-color: #000;
}

.product-course__heading-type03 span {
	position: relative;
	z-index: 2;
	padding: 0 13px;
	display: inline-block;
	background-color: #fff;
}

.product-course__about-lead {
	font-size: 18px;
	text-align: center;
	line-height: calc(28 / 18);
	margin-top: 35px;
}

.product-course__about-img {
	flex-shrink: 0;
}

.product-course__about-lists-wrap {
	width: 400px;
	margin: 11px auto 0;
}

.product-course__about-list {
	color: #333;
	position: relative;
	font-size: 14px;
	line-height: calc(24 / 14);
	padding-left: 15px;
}

.product-course__about-list + .product-course__about-list {
	margin-top: 10px;
}

.product-course__about-list::before {
	position: absolute;
	content: "";
	top: 8px;
	left: 0;
	width: 6.4px;
	height: 6.4px;
	background-color: #000;
	border-radius: 100%;
}

.product-course__about-flex {
	margin-top: 35px;
	display: flex;
	align-items: center;
}

.product-course__flow {
	margin-top: 86px;
}

.product-course__flow-lead {
	font-size: 24px;
	text-align: center;
	line-height: calc(42 / 24);
	letter-spacing: 0.17em;
}

.product-course__flow .product-course__heading-type03 {
	width: 250px;
	margin-top: 50px;
}

.product-course__flow-lists {
	display: flex;
	margin-top: 27px;
}

.product-course__flow-list {
	flex: 1;
	position: relative;
}

.product-course__flow-list::after {
	position: absolute;
	content: "";
	top: 60px;
	right: -28px;
	width: 12px;
	height: 50px;
	background-image: url('../img/flow_arrow.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100%;
}

.product-course__flow-list:last-child::after {
	display: none;
}

.product-course__flow-list + .product-course__flow-list {
	margin-left: 43px;
}

.product-course__flow-img {
	width: 170px;
	margin: 0 auto;
}

.product-course__flow-detail {
	margin-top: 20px;
}

.product-course__flow-text {
	color: #333;
	font-size: 14px;
	line-height: calc(24 / 14);
}

.product-course__flow-note {
	color: #333;
	font-size: 12px;
	padding-left: 1em;
	text-indent: -1em;
	margin-top: 10px;
}

/* 商品紹介 skinvisiom */
#product-skinvisiom {
	margin-top: 85px;
}

#product-skinvisiom .product__head {
	background-image: url('../img/product_skinvisiom_head_bg.jpg');
}

.product__head-logo--skinvisiom {
	width: 401px;
}

.product-about__img--skinvisiom {
	width: calc(610px / 2);
	margin: 8px 40px 0 18px;
}

.product-course__about-img--totalskin {
	width: calc(800px / 2);
	margin: 17px auto 0;
}

.product-course__about-img--alacarte {
	width: calc(520px / 2);
	margin: -5px 38px 0 12px;
}

#product-skinvisiom .product-course__group {
	padding-bottom: 40px;
}

#product-skinvisiom .product-about__text {
	margin-top: 40px;
}

/* 商品紹介 Handy Skin Sensor */
#product-handyskin {
	margin-top: 64px;
}

#product-handyskin .product__head {
	background-image: url('../img/product_handyskin_head_bg.jpg');
}

.product__head-logo--handyskin {
	width: 550px;
}

.product-about__img--handyskin {
	width: calc(360px / 2);
	margin: 12px 95px -34px 75px;
}

#product-handyskin .product-course__group {
	padding-bottom: 85px;
}

/*  ご予約はコチラ
-----------------------------------------------------------*/
.search-area__block {
	width: 960px;
	padding: 30px 70px 39px;
	margin: 20px auto 0;
	border-radius: 10px;
	box-sizing: border-box;
	background-color: #fff;
}

.search-area__head {
	display: flex;
	align-items: center;
}

.search-area__head-icon {
	width: 66px;
	height: 47px;
	margin-right: 16px;
}

.search-area__head-text {
	font-size: 15px;
}

#skinvisiom .search-area {
	margin-top:11px;
}

#skinvisiom .search-area h2 {
    background:#ba0c2f;
	line-height:42px;
	text-align:left;
	padding-left:20px;
	font-size:14px;
	color:#fff;
}

#skinvisiom .search-area .pinkBoxFooter{
	background:#f3f1f1;
}

#skinvisiom .search-area .naviButton.red {
	background:#fff;
	border:solid 1px #000;
	padding-left: 35px;
	padding-right: 30px;
}

#skinvisiom .search-area .block{
	border-left:1px solid #e0f4ff;
	border-right:1px solid #e0f4ff;
}

#skinvisiom .search-area .reserveSearch dl dt {
    margin-bottom: 5px;
    color: #000;
}

#skinvisiom .search-area .pinkBoxFooter{
	position: relative;
    padding: 11px;
}

#skinvisiom .search-area .pinkBoxFooter p {
	position: absolute;
    bottom: 16px;
    right: 50%;
    margin-right: 130px;
}

#skinvisiom .naviButton {
    display: table;
    border-collapse: separate;
    padding: 0px 0px 0px 8px;
    color: #ffffff;
    text-decoration: none;
    background: #888888;
    border: 0px;
    border-radius: 3px;
    cursor: pointer;
}

#skinvisiom .naviButton.center {
    margin: auto;
}

#skinvisiom .naviButton span {
    display: table-cell;
    height: 28px;
    padding: 0px 8px 0px 8px;
    color: #000 !important;
    vertical-align: middle;
}

#skinvisiom .naviButton.search span {
	font-size: 14px;
	position:relative;
	height: 35px;
	padding-left: 23px;
	padding-right: 10px;
	background-image: url('../img/icon_search_black.svg');
	background-repeat: no-repeat;
	background-position: center left;
}

#skinvisiom .naviButton.search span::after {
	position: absolute;
    content: "";
    top: 13px;
    left: 161px;
    width: 7px;
    height: 7px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    transform: rotate(45deg);
}

/* IE10以降 */
@media all and (-ms-high-contrast: none) {
    #skinvisiom .naviButton.search span::after {
			left: 145px;
    }
}

#skinvisiom .reserveSearch dl.line {
    float: none;
    width: 100%;
}

#skinvisiom .reserveSearch dl.line dt {
    display: inline-block;
    min-width: 8em;
}

#skinvisiom .reserveSearch dl.line dd {
	display: inline-block;
}

#skinvisiom .reserveSearch .block {
    padding: 18px;
}

#skinvisiom .reserveSearch dl dd.areaSelect span {
    margin-left: 10px;
    margin-right: 10px;
}
