@charset "utf-8";

/*
レイアウト
*/

html, body {
	width: 100%;
}
@media (max-width: 767.98px){
	html {
		font-size: 14px;
	}
}

body {
	font-family: 'メイリオ', Meiryo,'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
	position: relative;
	padding-top: 0;
	color: #000;
}
@media (max-width: 767.98px){
	body {
		padding-top: 3.8rem;	/* nav-bar用 */
	}
}

@media (min-width: 1200px){
	.container {
	    max-width: 1200px;
	}
	body.default #contents .container {
	    max-width: 930px;
	}
}
@media (max-width: 767.98px){
	.container {
	    width: 100%;
	    max-width: 100%;
	}
}
@media (max-width: 576px){
	.container {
	    width: 100%;
	}
}

@media (min-width: 768px){
  .col-md-pull-12 { right: 100%; }
  .col-md-push-12 { left: 100%; }
  .col-md-pull-11 { right: 91.66666667%; }
  .col-md-push-11 { left: 91.66666667%; }
  .col-md-pull-10 { right: 83.33333333%; }
  .col-md-push-10 { left: 83.33333333%; }
  .col-md-pull-9 { right: 75%; }
  .col-md-push-9 { left: 75%; }
  .col-md-pull-8 { right: 66.66666667%; }
  .col-md-push-8 { left: 66.66666667%; }
  .col-md-pull-7 { right: 58.33333333%; }
  .col-md-push-7 { left: 58.33333333%; }
  .col-md-pull-6 { right: 50%; }
  .col-md-push-6 { left: 50%; }
  .col-md-pull-5 { right: 41.66666667%; }
  .col-md-push-5 { left: 41.66666667%; }
  .col-md-pull-4 { right: 33.33333333%; }
  .col-md-push-4 { left: 33.33333333%; }
  .col-md-pull-3 { right: 25%; }
  .col-md-push-3 { left: 25%; }
  .col-md-pull-2 { right: 16.66666667%; }
  .col-md-push-2 { left: 16.66666667%; }
  .col-md-pull-1 { right: 8.33333333%; }
  .col-md-push-1 { left: 8.33333333%; }
}
@media (min-width: 576px){
  .col-sm-pull-12 { right: 100%; }
  .col-sm-push-12 { left: 100%; }
  .col-sm-pull-11 { right: 91.66666667%; }
  .col-sm-push-11 { left: 91.66666667%; }
  .col-sm-pull-10 { right: 83.33333333%; }
  .col-sm-push-10 { left: 83.33333333%; }
  .col-sm-pull-9 { right: 75%; }
  .col-sm-push-9 { left: 75%; }
  .col-sm-pull-8 { right: 66.66666667%; }
  .col-sm-push-8 { left: 66.66666667%; }
  .col-sm-pull-7 { right: 58.33333333%; }
  .col-sm-push-7 { left: 58.33333333%; }
  .col-sm-pull-6 { right: 50%; }
  .col-sm-push-6 { left: 50%; }
  .col-sm-pull-5 { right: 41.66666667%; }
  .col-sm-push-5 { left: 41.66666667%; }
  .col-sm-pull-4 { right: 33.33333333%; }
  .col-sm-push-4 { left: 33.33333333%; }
  .col-sm-pull-3 { right: 25%; }
  .col-sm-push-3 { left: 25%; }
  .col-sm-pull-2 { right: 16.66666667%; }
  .col-sm-push-2 { left: 16.66666667%; }
  .col-sm-pull-1 { right: 8.33333333%; }
  .col-sm-push-1 { left: 8.33333333%; }
}

#headerlogo img {
	width: 319px;
}
.navbar#gheader {
	border-bottom: 3px solid #ff9999;
	padding-top: 15px;
	padding-bottom: 15px;
    background-color: #fff!important;
}
#gheader .container {
    padding-left: 0;
    padding-right: 0;
}
#gheader .navbar-collapse {
  justify-content: flex-end;
  align-items: flex-end;
}
#gheader .globalnav .nav-item ,
#gfooter .globalnav .nav-item {
	position: relative;	/* 各アイテム両サイドの灰色の区切り線のために必要 */
}
@media (min-width: 768px){
	#gheader .globalnav .nav-item:first-child:before ,
	#gfooter .globalnav .nav-item:first-child:before {
		display: block;
		content: "";
		position: absolute;
		top: .5rem;
		bottom: .8rem;
		left: 0;
		border-right: 1px solid #ccc;
	}
	#gheader .globalnav .nav-item::after ,
	#gfooter .globalnav .nav-item::after {
		display: block;
		content: "";
		position: absolute;
		top: .5rem;
		bottom: .8rem;
		right: 0;
		border-right: 1px solid #ccc;
	}
}
#gheader .globalnav .nav-item a ,
#gfooter .globalnav .nav-item a {
	margin: 0 0.7em;
	padding-left: 0.8rem;
	padding-right: 0.8rem;
	color: #000;
}
#gheader .globalnav .nav-item a:hover ,
#gfooter .globalnav .nav-item a:hover {
	color: #666;
}
#gheader .globalnav .nav-item a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
#gheader .globalnav .nav-item a::after {
	position: relative;
	bottom: -0.5rem;
	content: "";
	display: block;
	width: 0;
	transition: width 0.3s;
	border-bottom: 3px solid transparent;
	width: 0;
}
#gheader .globalnav .nav-item.active a::after {
	width: -webkit-calc(100% + 1.6em);
	width: calc(100% + 1.6em);
}
#gheader .globalnav .nav-item a::after { border-bottom-color: #ff9999; }
#gheader .globalnav .nav-item.skincare a::after { border-bottom-color: #53c6e5; }
#gheader .globalnav .nav-item.bath_sanitary a::after { border-bottom-color: #79cc52; }
#gheader .globalnav .nav-item.supplement a::after { border-bottom-color: #eaa52a; }
#gheader .globalnav .nav-item.others a::after { border-bottom-color: #d873c5; }
#gheader .globalnav .nav-item.active a::after {
    animation-duration: 0.3s;
    animation-name: show_globalnav_border;
}
@keyframes show_globalnav_border {
    from {
        width: 0;
    }
    to {
		width: -webkit-calc(100% + 1.6em);
		width: calc(100% + 1.6em);
    }
}
#gheader .globalnav .nav-item a:hover::after {
	width: -webkit-calc(100% + 1.6em);
	width: calc(100% + 1.6em);
}

footer a { color: #000; }

#gfooter .globalnav {
	border: solid #ff9999;
	border-width: 3px 0;
}
#gfooter .globalnav {
	padding: 1.4rem 0;
}
#gfooter .footernav {
	padding: 0.35em 0;
	border-bottom: 2px solid #ccc;
	font-size: 0.9rem;
}
#gfooter .copyright {
	margin: 1em 0;
	font-size: 0.8rem;
	color: #999;
	text-align: center;
}

#gheader .globalnav .nav-item.feature ,
#gfooter .globalnav .nav-item.feature {
	display: none;
}

#headerglobalnav .navbar-close {
	display: none;
}

@media (min-width: 992px) and (max-width: 1199.98px){
	#headerlogo img {
		width: 12em;
	}
	#gheader .globalnav .nav-item {
		font-size: 0.8rem;
	}
	#gheader .globalnav .nav-item ,
	#gfooter .globalnav .nav-item {
		margin: 0;
		padding-left: 0rem;
		padding-right: 0rem;
	}
}
@media (min-width: 768px) and (max-width: 991.98px){
	#headerlogo img {
		width: 9em;
	}
	#gheader .globalnav .nav-item a {
		font-size: 0.8rem;
	}
	#gheader .globalnav .nav-item a ,
	#gfooter .globalnav .nav-item a {
		margin: 0 0.3em;
		padding-left: 0.3rem;
		padding-right: 0.3rem;
	}
	#gheader .globalnav .nav-item.active a::after {
		width: -webkit-calc(100% + 0.6em);
		width: calc(100% + 0.6em);
	}
	@keyframes show_globalnav_border {
	    from {
	        width: 0;
	    }
	    to {
			width: -webkit-calc(100% + 0.6em);
			width: calc(100% + 0.6em);
	    }
	}
	#gheader .globalnav .nav-item a:hover::after {
		width: -webkit-calc(100% + 0.6em);
		width: calc(100% + 0.6em);
	}
}
@media (max-width: 767.98px){

	.navbar {
	  position: fixed;
	  top: 0;
	  right: 0;
	  z-index: 1030;
	  width: 100%;
	}

	.navbar#gheader {
		padding: 0;
	}
	#gheader .navbar-title {
	    display: -webkit-flex;
	    display: flex;
	    -webkit-justify-content: space-between;
	    justify-content: space-between;
	    width: 100%;
		border-bottom: 1px solid #ccc;
	}
	#headerlogo {
		width: auto;
		height: 3.8rem;
		padding: 0.7rem 0;
		margin: 0 0 0 0.5rem;
	}
	#headerlogo img {
		width: auto;
		height: 100%;
	}
	.navbar-toggler {
		width: 5rem;
		display: flex;
		justify-content: center;
		align-items: center;
		font-size: 2rem;
		margin: 0;
		border: none;
		padding: 0;
		text-align: center;
	}
	button.navbar-toggler:visited ,
	button.navbar-toggler:active ,
	button.navbar-toggler:hover {
		outline: none;
	}

	.navbar .navbar-collapse {
	  position: fixed;
	  top: 3.8rem;  /* nav-bar用 */
	  right: 0;
	  bottom: 0;
	  z-index: 1030;
	  overflow-y: scroll;
	}
	.navbar .navbar-collapse-inner {
		position: relative;
		z-index: 1030;
		background: #ebebeb;
	}

	#gheader .navbar-collapse {
	    width: 100%;
	}
	#gheader .navbar-collapse a.nav-link:hover {
		opacity: 0.6;
	}

	#gheader .navbar-toggler {
		text-align: center;
	}
	#gheader .navbar-toggler i {
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#gheader .navbar-toggler[aria-expanded="false"] .fa-bars { display: flex; }
	#gheader .navbar-toggler[aria-expanded="true"] .fa-bars { display: none; }
	#gheader .navbar-toggler[aria-expanded="false"] .fa-times { display: none; }
	#gheader .navbar-toggler[aria-expanded="true"] .fa-times { display: flex; }

	.navbar#gheader {
		border: 0;
	}
	#gheader #headerglobalnav {
		border-top: 1px solid #ccc;
	}
	#gheader .globalnav .nav-item {
		border: 0;
		border-bottom: 1px solid #ccc;
	}
	#gheader .globalnav .nav-item a {
		display: block;
		margin: 0;
		padding: 1rem 20px;
	}
	#gheader .globalnav .nav-item a::after { display: none; }
	#gheader .globalnav .dropdown-menu {
		background-color: #f5f5f5;
	    padding: 0 0 0 30px;
	    border: 0;
	    border-top: solid 1px #ccc;
	    border-radius: 0;
	}
	#gheader .globalnav .dropdown-menu .nav-item:last-child {
		border-bottom: 0;
	}
	#gheader .globalnav .dropdown-menu .nav-item a {
		padding-left: 0;
	}
	#gheader .globalnav .nav-item.active a {
		border: 0;
	}
	#headerglobalnav .navbar-close {
		display: block;
		width: 100%;
		color: #000;
		font-size: 1rem;
		text-align: center;
	}
	#headerglobalnav .navbar-close a {
		color: #000;
		display: block;
		width: 100%;
		height: 2.5rem;
	}

	#headerglobalnav .navbar-close a {
		padding: 0.5rem 0;
		background-image: url(../img/navclose.png);
		background-repeat: no-repeat;
		background-position: center center;
		background-size: auto;
	}
	#headerglobalnav .navbar-close a .txt {
		display: none;
	}

	#gfooter .globalnav {
	    padding: 0.5rem 0;
	    border: 0;
	    background: #ebebeb;
	}
	#gfooter .globalnav .nav-item a {
		padding-top: 0.1rem;
		padding-bottom: 0.1rem;
	}
	#gfooter .globalnav {
		margin: 0;
		border-top: 1px solid #ccc;
		padding: 0;
	}
	#gfooter .globalnav .nav-item {
		width: 50%;
		margin: 0;
		padding: 0;
	}
	#gfooter .globalnav .nav-item:first-child ,
	#gfooter .globalnav .nav-item:last-child {
		width: 100%;
	}
	#gfooter .globalnav .nav-item a {
		margin: 0;
		padding: 0.5rem 0;
		border-left: 1px solid #ccc;
		border-bottom: 1px solid #ccc;
		text-align: center;
	}
	#gfooter .globalnav .nav-item.leftend a {
		border-left: 0;
	}

	#gfooter .footernav {
		margin: 1rem 0;
		border-bottom: 0;
		padding: 0;
	}
	#gfooter .footernav .nav-item {
		display: inline-block;
	}
	#gfooter .footernav .nav-item::before ,
	#gfooter .footernav .nav-item::after {
		content: "";
		display: inline-block;
		height: 1rem;
		border: 0;
		border-left: 1px solid #ccc;
		margin: 0;
	}
	#gfooter .footernav .nav-item::before {
		margin-left: -1px;
		margin-right: 0.25rem;
	}
	#gfooter .footernav .nav-item::after {
		margin-left: 0.25rem;
	}
	#gfooter .footernav .nav-link {
		display: inline-block;
	}
	#gfooter .footernav .nav-item {
	    display: -webkit-flex;
	    display: flex;
	    -webkit-justify-content: center;
	    justify-content: center;
	    -webkit-align-items: center;
	    align-items: center;
	}

	#gfooter .copyright {
		margin: 1rem 0;
	}
}

.breadcrumb {
	margin-bottom: 0;
    padding: 0.5rem 1rem 0.6rem;
	background-color: transparent;
	font-size: 0.8rem;
}
.breadcrumb-item.active ,
.breadcrumb a {
	color: #000;
	text-decoration: underline;
}
.breadcrumb a:hover ,
.breadcrumb-item.active {
	text-decoration: none;
}
.breadcrumb-item+.breadcrumb-item::before {
    content: ">";
    color: #000;
}
@media (max-width: 767.98px){
	.breadcrumb-wrapper {
		padding-left: 0.8rem;
		padding-right: 0.8rem;
	}
	.breadcrumb {
		/*border-bottom: 2px solid #53c6e5;/**/
		padding-left: 0.1em;
		padding-right: 0.1em;
	}
}

#contents {
	margin: 5em 0;
	padding: 0;
	line-height: 1.8;
}
.item #contents {
	margin-top: 0;
	margin-bottom: 0;
	padding: 2em 0;
	background: #f1f1f1;
}
@media (max-width: 575.98px){
	#contents {
		margin-bottom: 2em;
	}
}

#footer_bnr_area {
	box-sizing: border-box;
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	padding: 1em 8%;
	background: rgba(0,0,0,0.5);
	text-align: center;
	z-index: 2000;
}
#footer_bnr_area .bnr a {
	display: block;
	margin: 1em;
	background: #ccc;
}
#footer_bnr_area .bnr img {
	margin: 0.5em;
	width: 100%;
	max-width: 728px;
	height: auto;
}
#footer_bnr_area .hide {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 1.5em;
    padding: 0.25em 0.2em 0;
    background: none;
    color: #dcdcdc;
    text-align: center;
    vertical-align: middle;
    border: none;
    font-size: 1.2em;
    border-radius: 0.5em 0.5em 0 0;
    font-family: FontAwesome;
    content: "\f00d";
    cursor: pointer;
}

#gototop {
	display: none;
	position: fixed;
	right: 1rem;
	bottom: 3.15rem;
	z-index: 1000;
	padding: 0;
	width: 2.5rem;
	height: 2.5rem;	
	border-radius: 3rem;
	background: rgba(0,0,0,0.5);
	color: #fff;
	font-size: 2.5em;
	cursor: pointer;
	text-align: center;
	vertical-align: middle;
	line-height: 3rem;
}
#gototop .txt {
	display: none;
}

/*
小さな部品
*/

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
	line-height: 1.3;
}
#contents .h {
	line-height: 1.4;
}

@media (min-width: 768px){
	.w-md-15 { width: 15%; }
	.w-md-20 { width: 20%; }
	.w-md-25 { width: 25%; }
	.w-md-50 { width: 50%; }
	.w-md-60 { width: 60%; }
	.w-md-70 { width: 70%; }
	.w-md-75 { width: 75%; }
	.w-md-80 { width: 80%; }
	.w-md-90 { width: 90%; }
}

.mt-0 { margin-top: 0;  }
.mt-1 { margin-top: 1em !important; }
.mt-2 { margin-top: 2em !important; }
.mt-3 { margin-top: 3em !important; }
.mt-4 { margin-top: 4em !important; }
.mt-5 { margin-top: 5em !important; }

.mr-0 { margin-right: 0;  }
.mr-1 { margin-right: 1em !important; }
.mr-2 { margin-right: 2em !important; }
.mr-3 { margin-right: 3em !important; }
.mr-4 { margin-right: 4em !important; }
.mr-5 { margin-right: 5em !important; }

.mb-0 { margin-bottom: 0;  }
.mb-1 { margin-bottom: 1em !important; }
.mb-2 { margin-bottom: 2em !important; }
.mb-3 { margin-bottom: 3em !important; }
.mb-4 { margin-bottom: 4em !important; }
.mb-5 { margin-bottom: 5em !important; }

.ml-0 { margin-left: : 0;  }
.ml-1 { margin-left: 1em !important; }
.ml-2 { margin-left: 2em !important; }
.ml-3 { margin-left: 3em !important; }
.ml-4 { margin-left: 4em !important; }
.ml-5 { margin-left: 5em !important; }

@media (min-width: 768px){
	.mt-md-0 { margin-top: 0 !important; }
	.mt-md-1 { margin-top: 1em !important; }
	.mt-md-2 { margin-top: 2em !important; }
	.mt-md-3 { margin-top: 3em !important; }
	.mt-md-4 { margin-top: 4em !important; }
	.mt-md-5 { margin-top: 5em !important; }

	.mr-md-0 { margin-right: 0 !important; }
	.mr-md-1 { margin-right: 1em !important; }
	.mr-md-2 { margin-right: 2em !important; }
	.mr-md-3 { margin-right: 3em !important; }
	.mr-md-4 { margin-right: 4em !important; }
	.mr-md-5 { margin-right: 5em !important; }

	.mb-md-0 { margin-bottom: 0 !important; }
	.mb-md-1 { margin-bottom: 1em !important; }
	.mb-md-2 { margin-bottom: 2em !important; }
	.mb-md-3 { margin-bottom: 3em !important; }
	.mb-md-4 { margin-bottom: 4em !important; }
	.mb-md-5 { margin-bottom: 5em !important; }

	.ml-md-0 { margin-left: 0 !important; }
	.ml-md-1 { margin-left: 1em !important; }
	.ml-md-2 { margin-left: 2em !important; }
	.ml-md-3 { margin-left: 3em !important; }
	.ml-md-4 { margin-left: 4em !important; }
	.ml-md-5 { margin-left: 5em !important; }
}

.mr-2-5 { margin-right: .8rem; }

.bg-pink { background: #ff9999; }
.bg-blue { background: #53c6e5; }
.bg-green { background: #79cc52; }
.bg-orange { background: #eaa52a; }
.bg-purple { background: #d873c5; }

.c-pink { color: #ff9999; }
.c-blue { color: #53c6e5; }
.c-green { color: #79cc52; }
.c-orange { color: #eaa52a; }
.c-purple { color: #d873c5; }

.font-size-06em { font-size: 0.6em;  }
.font-size-07em { font-size: 0.7em;  }
.font-size-08em { font-size: 0.8em;  }
.font-size-09em { font-size: 0.9em;  }
.font-size-1em { font-size: 1em;  }
.font-size-2em { font-size: 2em;  }

#contents a {
	color: #333;
	text-decoration: underline;
}
#contents a:hover {
	text-decoration: none;
}
#contents a.btn ,
#contents .btn a {
	text-decoration: none;
}
footer a:hover ,
#contents a:hover {
	color: #888;
}

body .featurelist .btn ,
.btn ,
.default .btn ,
body .categorylist .default .btn ,
.default .badge { background-color: #ff9999; }
.skincare .btn ,
body .categorylist .skincare .btn ,
.skincare .badge { background-color: #53c6e5; }
.bath_sanitary .btn ,
body .categorylist .bath_sanitary .btn ,
.bath_sanitary .badge { background-color: #79cc52; }
.supplement .btn ,
body .categorylist .supplement .btn ,
.supplement .badge { background-color: #eaa52a; }
.others .btn ,
body .categorylist .others .btn ,
.others .badge { background-color: #d873c5; }
.badge.badge-ttl {
    padding: 0.45em 0.8em 0.25em;
    font-size: 0.9em;
    font-weight: normal;
    margin-right: 0.5em;
   	color: #fff;
}

.btn {
	padding: 0.8rem 3em;
	border-radius: 3rem;
	color: #fff;
	white-space: normal;
}
.btn:hover {
	opacity: 0.7;
	color: #fff;
}

#contents h1 ,
#contents h2 ,
#contents h3 ,
#contents h4 ,
#contents h5 ,
#contents h6 {
    margin: 1.8em 0 0.6em;
}
#contents .h {
    margin: 1.8em 0 0.8em;
}
@media (max-width: 767.98px){
	#contents h1 ,
	#contents h2 ,
	#contents h3 ,
	#contents h4 ,
	#contents h5 ,
	#contents h6 ,
	#contents .h {
		margin-top: 1em;
		margin-bottom: 1em;
	}
}

#contents h2 {
	margin: 3em 0 1.1em;
    border: 0;
    padding: 0;
    font-size: 1.5em;
}
#contents h2::after {
	display: block;
	content: "";
	width: 2em;
	padding-top: 0.7em;
    border-bottom: 3px solid #ff9999;
}

#contents h3 {
    border: 0;
    border-left: 5px solid #ff9999;
    padding: 0.25em 0 0.25em 0.6em;
    font-size: 1.5em;
}
.default #contents h2::after ,
.default #contents h3 { border-color: #ff9999; }
.skincare #contents h2::after ,
.skincare #contents h3 { border-color: #53c6e5; }
.bath_sanitary #contents h2::after ,
.bath_sanitary #contents h3 { border-color: #79cc52; }
.supplement #contents h2::after ,
.supplement #contents h3 { border-color: #eaa52a; }
.others #contents h2::after ,
.others #contents h3 { border-color: #d873c5; }

#contents h4 {
	border: 0;
	padding: 0;
	font-size: 1.2em;
}
#contents .h {
	border: 0;
	padding: 0;
	font-size: 1.15em;
}
.default .list-cat-color, .list-cat-color.default ,
.default .color, .default #contents h4 , .default #contents .h { color: #d66969; }
.skincare .list-cat-color, .list-cat-color.skincare ,
.skincare .color, .skincare #contents h4 , .skincare #contents .h { color: #0285a8; }
.bath_sanitary .list-cat-color, .list-cat-color.bath_sanitary ,
.bath_sanitary .color, .bath_sanitary #contents h4 , .bath_sanitary #contents .h { color: #3d960e; }
.supplement .list-cat-color, .list-cat-color.supplement ,
.supplement .color, .supplement #contents h4 , .supplement #contents .h { color: #935203; }
.others .list-cat-color, .list-cat-color.others ,
.others .color, .others #contents h4 , .others #contents .h { color: #9b3a8d; }

form.border-yoko .form-group ,
form.border-yoko .form-check {
	margin-bottom: 0;
	border-top: 1px solid #ddd;
	padding-top: 0.7em;
	padding-bottom: 0.7em;
}
form.border-yoko .form-group .col-form-label {
	padding-left: 0;
}
form.border-yoko .form-check .form-check-input {
	width: 1.2em;
	height: 1.2em;
}
form.border-yoko .form-check .form-check-label {
	margin-left: 0.4em;
	padding-left: 0;
}
form.border-yoko .form-control {
	background: #ffffea;
	border-color: #666465;
}
form.border-yoko .row.form-group > [class*="col-"] {
	padding-right: 0;	
}
form.border-yoko .btn {
	margin: 1em 0;
	border:0 ;
    padding: 0.6em 2.6em;
    font-size: 0.96em;
}
@media (max-width: 575.98px){
	form.border-yoko .row.form-group > [class*="col-"] {
		padding-left: 0;	
	}
}

@media (max-width: 575.98px){

	form.form .form-check {
		padding-left: 0;
		padding-right: 0;
		text-align: center;
	}
	form.form .form-check .form-check-input {
		position: relative;
		left: 50%;
		display: block;
		width: 2em;
		height: 2em;
		margin: 1em 0 1em -1em;
	}
	form.form .form-check .form-check-label {
		display: block;
		margin: 0;
		line-height: 3;
	}
	form.form .submit {
		margin: 1em 0 4em;
		text-align: center;
	}
	form.form .submit .btn {
		margin: 0 !important;
	    padding: 1em 4em;
	    font-size: 1em;
	}
}

.table {
	margin: 1.5em 0;
	border-bottom: 1px solid #dee2e6;
	border-color: #ccc;
}
.table th {
	background-color: #f2f2f2;
	border-color: #ccc;
	font-weight: normal;
}
.table td {
	border-color: #ccc;
}

#contents .container .row img {
  width: 100%;
  height: auto;
}

img.w100p {
	width: 100%;
	height: auto;
}

img.greyout {
	width: 200px;
	height: 150px;
	background: #ccc;
}

ol.list-none ,
ul.list-none {
	margin: 0;
	padding: 0;
	list-style-type: none;
}
ol.list-none li ,
ul.list-none li {
	margin: 0;
	padding: 0;
}

ul.deco-circle ,
ul.list-maru {
	margin-left: 1.5em;
	margin-right: 0;
	padding: 0;
	list-style: none;
}
ul.deco-circle li ,
ul.list-maru li {
	margin-left: 0;
	margin-right: 0;
	padding: 0;

}
ul.deco-circle li::before ,
ul.list-maru li::before {
	display: inline-block;
	content: "●";
	margin: 0 0.5em 0 -1em;
	color: #e09292;
}
.default #cheader .item .deco-circle.blue li::before ,
.default ul.list-maru li::before { color: #e09292; }
.skincare #cheader .item .deco-circle.blue li::before ,
.skincare ul.list-maru li::before { color: #7dbbcc; }
.bath_sanitary #cheader .item .deco-circle.blue li::before ,
.bath_sanitary ul.list-maru li::before { color: #90c170; }
.supplement #cheader .item .deco-circle.blue li::before ,
.supplement ul.list-maru li::before { color: #bf8d51; }
.others #cheader .item .deco-circle.blue li::before ,
.others ul.list-maru li::before { color: #b270ac; }

ul.list-kome {
	margin: 0 0 0 2em;
	padding: 0;
	list-style: none;
}
ul.list-kome li {
	margin-left: 0;
	margin-right: 0;
	padding: 0;
}
ul.list-kome li::before {
	display: inline-block;
	content: "※";
	margin: 0 0.5em 0 -1.5em;
}

/*
likelist-marun と .likeli　：　liの間にh4など他のエレメントを置きたいときに使用します。
例：/skincare/pso/index.html
通常は ol.list-marun と li を使用します。
例：/skincare/puv/index.html
*/

.likelist-marun ,
ol.list-marun {
	margin: 0;
	padding: 0;
	counter-reset: my-counter;
	list-style: none;
}
.likelist-marun .likeli ,
ol.list-marun li {
 	position: relative;
	margin: 0 0 0.5em 2em;
	padding: 0;
}
.likelist-marun .likeli::before ,
ol.list-marun li::before {
	content: counter(my-counter);
	counter-increment: my-counter;
	display: block;
	float: left;
	height: 1.5em;
	width: 1.5em;
	margin-left: -2em;
	border-radius: 50%;
	line-height: 1.5em;
	color: #fff;
	text-align: center;
}
.default .likelist-marun .likeli::before ,
.default ol.list-marun li::before { background-color: #ff9999; }
.skincare .likelist-marun .likeli::before ,
.skincare ol.list-marun li::before { background-color: #53c6e5; }
.bath_sanitary .likelist-marun .likeli::before ,
.bath_sanitary ol.list-marun li::before { background-color: #79cc52; }
.supplement .likelist-marun .likeli::before ,
.supplement ol.list-marun li::before { background-color: #eaa52a; }
.others .likelist-marun .likeli::before ,
.others ol.list-marun li::before { background-color: #d873c5; }
@media (max-width: 767.98px){
	.likelist-marun .likeli ,
	ol.list-marun li {
			margin-left: 3.5em;
	}
	.likelist-marun .likeli::before ,
	ol.list-marun li::before {
		height: 1.5em;
		width: 1.5em;
		margin-left: -1.85em;
		line-height: 1.6;
		font-size: 1.8em;
	}
}

#contents .likelist-marun h1 ,
#contents .likelist-marun h2 ,
#contents .likelist-marun h3 ,
#contents .likelist-marun h4 ,
#contents .likelist-marun h5 ,
#contents .likelist-marun h6 ,
#contents .likelist-marun .h {
	margin-top: 1em;
	margin-bottom: 1em;
}

dl.nostyle {
	margin: 0;
	padding: 0;
}
dl.nostyle dt {
	margin: 0 0 1rem;
	padding: 0;
	font-size: 1em;
	font-weight: normal;
}
dl.nostyle dd {
	margin: 0 0 1rem;
	font-size: 1em;
}

.dl-horizontal::after {
  content: "";
  display: block;
  clear: both;
}
.dl-horizontal dt {
	clear: left;
	float: left;
	margin-right: 1em;
}
.dl-horizontal dd {
	float: left;
}
.default .dl-horizontal dt { color: #d66969; }
.skincare .dl-horizontal dt { color: #0285a8; }
.bath_sanitary .dl-horizontal dt { color: #3d960e; }
.supplement .dl-horizontal dt { color: #935203; }
.others .dl-horizontal dt { color: #9b3a8d; }

.kome {
	margin-left: 2em;
	padding: 0;
}
.kome:before {
	display: inline-block;
	content: "※";
	margin: 0 0.15em 0 -1.5em;
}

.fig a {
	display: block;
	position: relative;
}
.fig a img {
	width: 100%;
}
.fig i.kakudai {
	position: absolute;
	bottom: 0;
	right: 0;
	display: block;
	padding: 0.4em;
	background: rgba(0,0,0,0.7);
	color: #fff;
}
@media (max-width: 767.98px){
	.fig {
		margin-top: 0;
		margin-bottom: 0.5em;
		padding-left: 0;
		padding-right: 0;
	}
}

i.list-arw-pink-r {
	display: inline-block;
	width: 1em;
	height: 1em;
	margin-left: 0.8em;
	background: url(../img/list-arw-pink-r.png) no-repeat top center;
	background-size: 0.6em;
	vertical-align: middle;
}
.cartbutton {
	margin: 1rem 0;
	border: 3px solid #ff9999;
	border-radius: 3rem;
	padding: 1rem 4.8rem;
	color: #ff6666 !important;
	text-align: center;
	text-decoration: none;
	background: #fff !important;
	opacity: 1;
}
.cartbutton i {
	position: relative;
	right: -2em;
	color: #ff9999 !important;
}
.cartbutton:hover {
	border-color: #ff9999;
	background: #ff9999 !important;
	color: #fff !important;
}
.cartbutton:hover i {
	color: #fff !important;
}
.cartbutton.medium{
	padding: 0.8rem 3.2rem;
	font-size: 1rem;
}
.cartbutton.large {
	padding: 1rem 4.8rem;
	font-size: 1.25rem;
}
@media (max-width: 767.98px){
	.cartbutton {
	    margin: 1.5rem 0 2rem;
	}
	.cartbutton.small ,
	.cartbutton.medium ,
	.cartbutton.large ,
	.cartbutton {
		width: 100%;
		padding-left: 0;
		padding-right: 0;
		font-size: 1rem;
	}
}

/*
大きな部品
*/

.kakomi {
	margin: 1em 0;
	border: 2px solid #ccc;
	border-radius: 0.5rem;
	padding: 1.5em 2rem;
}

/* 動画のスタイル決まったら書き換え */
.block-movie {
    width: 100%;
    height: 15em;
    margin: 2em 0 0.5em;
    background: #e3e3e3;
    border: 1px solid #ccc;
    text-align: center;
}
.block-movie p strong {
	margin: 2em 0;
	color: #000;
	font-style: italic;
}
/* /動画のスタイル決まったら書き換え */

/* categorylist, featurelist 共通 */
.categorylist ,
.featurelist {
	position: relative;
	margin: 0 0 3.5rem;
	padding: 3.5rem 0 0;
}
.categorylist .bg ,
.featurelist .bg {
	width: 100%;
	height: 65px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	margin: 0 0 3rem;
	background: linear-gradient(#f1f1f1, #fff);
}
.categorylist .imgwrap ,
.featurelist .imgwrap {
	width: 100%;
}
.categorylist .imgwrap img ,
.featurelist .imgwrap img {
	width: 100%;
	height: auto;
}
.categorylist .list-title ,
.featurelist .list-title {
	margin: 0 0 3rem;
	font-size: 1.5rem;
	text-align: center;
}
.categorylist .btn ,
.featurelist .btn ,
.btn-arw-r {
	background-image: url("../img/list-arw-r.png");
	background-repeat: no-repeat;
	background-position: center right 15px;
}
@media (max-width: 575.98px){
	.categorylist ,
	.featurelist {
		padding-top: 3rem;
	}
	.categorylist .list-title ,
	.featurelist .list-title {
		font-size: 1.4rem;
	}
}

/* categorylist */
.categorylist .row > div {
	text-align: center;
}
.categorylist p br {
	display: none;	/* PCでは bootstrap の class である d-md-block で表示する */
}
.categorylist p.txt {
	text-align: center;
	font-size: 0.9em;
	font-weight: normal;
}
.categorylist .btnwrapper {
	padding: 0 15px;
}
.categorylist .btn {
	width: 100%;
	padding: 0.8rem 0;
}
.categorylist .imgwrap {
    display: block;
	width: 100%;
    margin-bottom: 0.8em;
}
.categorylist .imgwrap img {
	width: 100%;
	height: auto;
}
@media (max-width: 991.98px){
	.categorylist .btnwrapper {
		padding: 0;
	}
	.categorylist .btn {
		margin-bottom: 2rem;
	}
	.categorylist .row > div:last-child .btn {
		margin-bottom: 0;
	}
}
@media (min-width: 621px) and (max-width: 991.98px){
	.categorylist .row > div {
	    flex: 0 0 34%;
	    max-width: 34%;
		margin-left: 8%;
		margin-right: 8%;
	}
}
@media (max-width: 767.98px){
	.categorylist .list-title {
		margin: 0 0 1.5rem;
	}
	.categorylist {
		margin-bottom: 1rem;
	}
	.categorylist p.txt {
		text-align: left;
	}
	.categorylist .btn {
		margin-bottom: 1rem;
	}
}
@media (min-width: 576px) and (max-width: 620px){
	.categorylist .row > div {
	    flex: 0 0 40%;
	    max-width: 40%;
		margin-left: 5%;
		margin-right: 5%;
	}
}
@media (max-width: 575.98px){
	.categorylist .list-title {
		margin: 0 0 1.2rem;
	}
	.categorylist:not(.itemlist) .btn {
		font-size: 0.85rem;
	}
}

.featurelist {
	display: none;
}

/* featurelist */
.featurelist .imgwrap {
	overflow: hidden;
}
.featurelist .imgwrap .img {
	width: 100%;
	height: auto;
}
.featurelist .ttl {
	margin-top: 0;
}
.featurelist .date {
	margin: -0.4em 0 0;
	color: #999;
	font-size: 0.9em;
}
.featurelist .txt {
	margin: 0.6em 0;
	font-size: 0.9em;
}
.featurelist .btnwrapper {
	margin: 1em 0;
}
.featurelist .btn {
	padding: 0.6rem 3em;
}
@media (min-width: 992px){
	.featurelist .imgwrap {
		padding-left: 0;
		padding-right: 5px;
	}
}
@media (min-width: 768px) and (max-width: 991.98px){
	.featurelist .row > div {
		margin-bottom: 2rem;
	}
	.featurelist .row > div:last-child {
		margin-bottom: 0;
	}
}
@media (max-width: 767.98px){
	.featurelist {
		margin-bottom: 0;
	}
	.featurelist .col-md-12 {
		padding-left: 0;
		padding-right: 0;
	}
	.featurelist .btnwrapper {
		margin: 1.5em 0 2em;
	}
	.featurelist .btn {
	    width: 50%;
		margin: 0;
	}
	.featurelist  .row > div:last-child .btn {
		margin-bottom: 0;
	}
}
@media (max-width: 575.98px){
	.featurelist .btn {
	    width: 100%;
	}
	.featurelist .imgwrap {
		margin-bottom: 1em;
		padding-left: 0;
		padding-right: 0;
	}
}

/* #cheader カテゴリ、商品ページ で使う */

#cheader .title {
	border-top: 1px dashed #ccc;
	background: #f6dbdb;
	text-align: center;
	padding: 2rem 1rem;
}
.default #cheader .title { background: #f6dbdb; }
.skincare #cheader .title { background: #e8f6fc; }
.bath_sanitary #cheader .title { background: #e5ffd7; }
.supplement #cheader .title { background: #ffedd4; }
.others #cheader .title { background: #f9e0f7; }

#cheader .title h1 {
	margin-bottom: 0;
	font-size: 1.9rem;
}
/* #cheader ここまで */

@media (max-width: 767.98px){
	#cheader .title {
		padding: 1.2rem 0;
		margin-bottom: 1rem;
	}
	#cheader .title h1 {
		font-size: 1.4rem;
	}
}

