@charset "utf-8";

/* common
-------------------------------------------------------*/

* {
	box-sizing: border-box;
}
#wrapper {
	overflow: hidden;
}
.sp {
	display: none;
}
.area {
	padding: 70px 20px;
	box-sizing: border-box;
}
.sans {
	font-family: 'Noto Sans JP', sans-serif;
}
.inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	box-sizing: border-box;
}
.white {
	color: #fff;
}
.center {
	text-align: center;
}
.ub_y {
	background: linear-gradient(transparent 60%, #faee00 60%);
}
.ub_p {
	background: linear-gradient(transparent 60%, #e37ca0 60%);
}
.ttl01 {
	text-align: center;
	font-size: 3rem;
	font-weight: 700;
	margin-bottom: 30px;
}
.ttl02 {
	text-align: center;
}
@media screen and (min-width:768px) and ( max-width:1080px) {
	
}
@media screen and (max-width:768px) {
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}
	.area {
		padding: 30px 20px;
	}
	.inner {
		max-width: 100%;
	}
}

.list_btn li:not(:last-child) {
	margin-bottom: 10px;
}
.list_btn li a {
	display: block;
	background: #fff;
	border: 1px solid #000;
	padding: 10px 20px;
	position: relative;
	border-radius: 100px;
}
.list_btn li a::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/btn_arrow_b.png)no-repeat right center/10px 19px;
	width: 10px;
	height: 19px;
	right: 20px;
	top: 50%;
	transform: translate(0,-50%);
}

/* visual
-------------------------------------------------------*/
#visual {
	background:
	url(../img/visual_bg01.png)no-repeat center top/cover,
	url(../img/visual_bg02.png) no-repeat top center;
	position: relative;
	text-align: center;
	padding-top: 80px;
 background-blend-mode: multiply;
}


@media screen and (max-width:1000px) {
	#visual {
	background:
	url(../img/visual_bg01.png)no-repeat center top/cover,
	url(../img/visual_bg02.png) no-repeat top center/200%;
}
}


#visual.area {
	padding: 80px 20px 0;
}
.visual_top {
	position: absolute;
	top: 0;
	left: 0;
	text-align: left;
	width: 90%;
	z-index: 1;
}
.visual_top img {
	max-width: 1863px;
}
#visual .inner {
	position: relative;
	z-index: 2;
}
.visual_btm {
	position: absolute;
	bottom: -2px;
	left: 0;
	z-index: 3;
}
#visual .logo {
	margin: 0 auto 50px;
	max-width: 70%;
}
#visual .logo img {
	max-width: 786px;
}

@media screen and (max-width:768px) {
	#visual {
	background:
	url(../img/visual_bg01.png)no-repeat center top/cover,
	url(../img/visual_bg02.png) no-repeat top center/180%;
	padding-top: 40px;
	}
	#visual .logo {
  margin: 0 auto 25px;
  max-width: 70%;
}

}

/* lead
-------------------------------------------------------*/
#lead .ttl01 {
	margin-bottom: 50px;
}
#lead .ttl01 img {
	max-width: 641px;
}
#lead .sub_ttl {
	font-size: 2.4rem;
	font-weight: 500;
	margin-bottom: 20px;
}
#lead .top_txt {
	font-size: 1.8rem;
	line-height: 1.8;
	margin-bottom: 100px;
}
#lead .bg_bubble {
	background: url(../img/bg_bubble.png)no-repeat center/contain;
	padding: 50px 0;
	margin-bottom: 30px;
}
#lead .bg_bubble .ttl_box {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: center;
	margin-bottom: 10px;
}
#lead .bg_bubble .ttl_box dt {
	margin-right: 20px;
}
#lead .bg_bubble .ttl_box dt img {
	max-width: 162px;
}
#lead .bg_bubble .ttl_box dd {
	font-size: 3rem;
	font-weight: 700;
}
#lead .bg_bubble ul {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
}
#lead .bg_bubble ul li {
	width: 50%;
}
#lead .bg_bubble ul li .ttl {
	background: linear-gradient(to bottom,#9287c7,#c9c4e1);
	color: #fff;
	text-align: center;
	border-radius: 50px;
	font-weight: 700;
	font-size: 2.2rem;
	height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	width: 70%;
}
#lead .bg_bubble ul li:last-child .ttl {
	font-size: 1.7rem;
	max-width: 370px;
	font-weight: 400;
}
#lead .bg_bubble ul li:last-child .ttl span {
	margin-right: 5px;
}
#lead .bg_bubble ul li .number {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: center;
	margin-top: 10px;
}
#lead .bg_bubble ul li .number dt {
	margin-right: 10px;
}
#lead .bg_bubble ul li .number dt img {
	max-width: 83px;
}
#lead .bg_bubble ul li .number dd {
	font-size: 1.4rem;
	letter-spacing: 0.04em;
}

@media screen and (max-width:1000px) {

	#lead .bg_bubble ul li:last-child .ttl {
		font-size: 1.4rem;
	}
	#lead .bg_bubble ul li .number dt img {
  max-width: 60px;
}
#lead .bg_bubble ul li .number dd {
  font-size: 1.2rem;
}

#lead .bg_bubble {
	padding: 20px 0px;
}
}

@media screen and (max-width:768px) {


	#lead .ttl01 {
	margin-bottom: 25px;
}
#lead .ttl01 img {
	max-width: 240px;
	margin: 0 auto;
}

#lead .sub_ttl {
	font-size: 1.8rem;
	margin-bottom: 20px;
}
#lead .top_txt {
	font-size: 1.5rem;
	margin-bottom: 30px;
}

#lead .bg_bubble {
	background: url(../img/bg_bubble_sp.png)no-repeat center/contain;
	padding: 20px 0;
	margin-bottom: 20px;
}

#lead .bg_bubble .ttl_box dt img {
  max-width: 80px;
}

#lead .bg_bubble .ttl_box dd {
	font-size: 1.5rem;
}

#lead .bg_bubble ul {
	display: block;
}
#lead .bg_bubble ul li {
  width: 90%;
  margin: 0 auto;
  margin-bottom: 20px;
}

#lead .bg_bubble ul li .ttl {
	font-size: 1.8rem;
}

#lead .bg_bubble ul li:last-child .ttl {
  font-size: 1.2rem;
  width: 80%;
}

#lead .bg_bubble ul li .number dt img {
  max-width: 50px;
}

#lead .bg_bubble ul li .number dd {
  font-size: 1rem;
}

}

/* new_color
-------------------------------------------------------*/
#new_color {
	background: linear-gradient(0deg,rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0) 100%),linear-gradient(to right,#7cc3d9,#aebbce,#dfb3c4);
}
#new_color .top_txt {
	font-size: 1.8rem;
	margin-bottom: 30px;
}
#new_color .new_color_box {
	position: relative;
}
#new_color .new_color_box .icon {
	width: 190px;
	height: 190px;
	min-width: 190px;
	color: #fff;
	text-align: center;
	letter-spacing: 0.1em;
	border-radius: 100%;
	background: #000;
	line-height: 1.4;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	left: 0;
	top: -130px;
}
#new_color .new_color_box .icon .size_l {
	font-size: 2.3rem;
}
#new_color .list_new_color {
	position: relative;
	z-index: 2;
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
}
#new_color .list_new_color li {
	width: 32%;
	text-align: center;
}
#new_color .list_new_color li .img_box {
	position: relative;
	margin-bottom: 20px;
}
#new_color .list_new_color li .main_img img {
	max-width: 234px;
}
#new_color .list_new_color li .sub_img {
	position: absolute;
	right: 0;
	bottom: -35px;
}
#new_color .list_new_color li .sub_img img {
	max-width: 123px;
}
#new_color .list_new_color li .ttl {
	font-size: 3rem;
	font-weight: 700;
	margin-bottom: 10px;
	letter-spacing: 0.06em;
	position: relative;
	z-index: 2;
}
#new_color .list_new_color li .txt {
	font-size: 1.3rem;
	letter-spacing: 0;
}
@media screen and (max-width:1200px) {
	#new_color .new_color_box .icon {
		width: 150px;
  height: 150px;
  min-width: 150px;
  left: 0px;
  top: -100px;
  font-size: 1rem;
	}
#new_color .new_color_box .icon .size_l {
  font-size: 1.5rem;
}
}

@media screen and (max-width:1000px) {
	#new_color .new_color_box .icon {
		top: -120px;
	}
}


@media screen and (max-width:768px) {
	.ttl01 {
  font-size: 2rem;
  margin-bottom: 15px;
}

#new_color .top_txt {
  font-size: 1.4rem;
  margin-bottom: 70px;
}

#new_color .list_new_color {
	display: block;
}

#new_color .list_new_color li {
	width: 80%;
	margin: 0 auto;
	margin-bottom: 30px;
}

#new_color .list_new_color li .ttl {
	font-size: 2.5rem;
}

#new_color .list_new_color li .main_img img {
  max-width: 180px;
}
#new_color .list_new_color li .sub_img img {
  max-width: 100px;
}

  #new_color .new_color_box .icon {
    top: -60px;
	left: 0px;
	width: 120px;
    height: 120px;
    min-width: 120px;
  }

  #new_color .list_new_color li .sub_img {
  position: absolute;
  right: inherit;
  bottom: -35px;
  left: 58%;
}

}

/* color layout_common
-------------------------------------------------------*/
.color_layout {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
}
.color_layout .txt_box {
	text-align: center;
	width: 50%;
	padding-bottom: 50px;
}
.color_layout .txt_box .ttl02 {
	font-size: 6rem;
	letter-spacing: 0;
	font-weight: 700;
	letter-spacing: 0.06em;
}
.color_layout .txt_box .sub_ttl {
	font-size: 1.7rem;
	margin-bottom: 30px;
}
.color_layout .txt_box .txt {
	font-size: 1.5rem;
	letter-spacing: 0.06em;
	margin-bottom: 40px;
}
.color_layout .txt_box dl {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-end;
	justify-content: center;
}
.color_layout .txt_box dl dt {
	width: 170px;
	height: 170px;
	color: #fff;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.8rem;
	font-weight: 700;
	border-radius: 100%;
	margin-right: 10px;
	margin-bottom: 20px;
	
}

.color_layout .txt_box dl dd {
	width: 100%;
	flex: 1;
}

.color_layout .txt_box dl img {
	max-width: 350px;
}
.color_layout .img_box {
	position: relative;
	width: 50%;
}
.color_layout .img_box .comment {
	position: absolute;
	font-weight: 500;
	bottom: 20%;
	width: 80%;
	right: 15%;
}
.color_layout .img_box .comment p {
	color: #fff;
	position: relative;
	padding: 25px 20px 25px 30px;
	z-index: 2;
	letter-spacing: 0.01em;
}
.color_layout .img_box .comment::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/com_border.png)no-repeat center/100% 100%;
	width: 98%;
	height: 107%;
	bottom: 5px;
	right: 50%;
	transform: translate(50%,0);
	z-index: 5;
}
.color_layout .img_box .comment::before {
	position: absolute;
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 30px;
	left: 0;
	top: 0;
	z-index: 1;
	mix-blend-mode: multiply;
}
@media screen and (max-width:1185px) {

	.color_layout .img_box .comment p {
		font-size: 1.3rem;

	}

}

@media screen and (max-width:990px) {

	.color_layout .img_box .comment p {
		font-size: 1.2rem;

	}
	.color_layout .img_box .comment {
  width: 100%;
  right: 0%;
}

}
@media screen and (max-width:768px) {

	.color_layout {
		display: block;
	}

	.color_layout .txt_box {
	text-align: center;
	width: 100%;
	padding-bottom: 10px;
}

.color_layout .txt_box .ttl02 {
	font-size: 4rem;
}

.color_layout .txt_box .sub_ttl {
	margin-bottom: 20px;
}
.color_layout .img_box {
  width: 100%;
}

.color_layout .txt_box dl dt {
	width: 110px;
	height: 110px;
	font-size: 1.1rem;
	margin-right: 10px;
}

.color_layout .txt_box dl dd {
	width: 100%;
	flex: 1;
}

.color_layout .txt_box .txt {
	margin-bottom: 20px;
}


.color_layout .img_box .comment {
  bottom: 15%;
  width: 90%;
  right: 5%;
}

.color_layout .img_box .comment p {
	font-size: 1rem;
	padding: 10px 10px 15px 20px;
}

.color_layout .img_box .comment::before {
	border-radius: 20px;
}

.color_layout .img_box .comment::after {
	bottom: 3px;
}


}

.member_modal_area {
	margin-top: -6%;
	position: relative;
	z-index: 10;
}
.member_modal_area.area {
	padding: 0 20px 80px;
}
.member_modal_area .inner {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
}
.member_modal_area .icon {
	background: url(../img/arrow01.png)no-repeat left top/127px 78px;
	width: 127px;
	height: 78px;
	min-width: 127px;
	color: #fff;
	font-size: 1.3rem;
	line-height: 1.2;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 5%;
}
.member_modal_area .icon span {
	padding-right: 10px;
	letter-spacing: 0;
}
.member_modal_area .icon.finger {
	background: url(../img/arrow02.png)no-repeat left top/127px 78px;
	position: relative;
}
.member_modal_area .icon.finger span {
	padding-right: 0;
	padding-left: 10px;
}
.member_modal_area .icon.finger::after {
	position: absolute;
	content: "";
	background: url(../img/icon_finger.png) no-repeat;
	background-size: 100%;
	width: 54px;
	height: 64px;
	right: -25px;
	bottom: -45px;
}
.member_modal_list {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
	width: 100%;
	margin: 0 10px;
}
.member_modal_list li {
	text-align: center;
	width: 24%;
}
.member_modal_list li img {
	max-width: 204px;
}
.member_modal_list li span {
	display: block;
}

.member_modal_list a:hover {
	opacity: 1;
}

@media screen and (min-width:768px) and ( max-width:1080px) {
	
}
@media screen and (max-width:768px) {

	.member_modal_area .inner {
	display: block;
}

.member_modal_area .icon {
background-image: none;
background: #000;
border-radius: 100px;
  width: 60%;
  height: auto;
  min-width: inherit;
  font-size: 1.3rem;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  margin-bottom: 20px;
  padding: 10px;
}

.member_modal_area .icon span {
	padding-right: 0;
}

.member_modal_list {
	flex-wrap: wrap;
	width: 95%;
}

.member_modal_list li {
	width: 45%;
	margin-bottom: 20px;
}

.member_modal_area .icon.finger {
	background-image: none;
	background: #000;
}

}

.member_modal {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
	padding: 20px;
	padding-right: 40px;
	border-radius: 30px;
}
.member_modal .img {
	width: 45%;
	margin-right: 2%;
}
.member_modal .txt_box {
	width: 53%;
}
.member_modal .txt_box .name, .member_modal .txt_box .en {
	text-align: center;
}
.member_modal .txt_box .name {
	font-size: 4.5rem;
	font-weight: 700;
	letter-spacing: 0.065em;
}
.member_modal .txt_box .en {
	font-weight: 700;
	letter-spacing: 0.014em;
	margin-bottom: 20px;
}
.member_modal .txt_box dl {
	font-family: 'Noto Sans JP', sans-serif;
}
.member_modal .txt_box dl:not(:last-child) {
	margin-bottom: 30px;
}
.member_modal .txt_box dl dt {
	font-size: 1.7rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	position: relative;
	margin-bottom: 15px;
}
.member_modal .txt_box dl dt::after {
	position: absolute;
	display: block;
	content: "";
	width: 100%;
	height: 1px;
	background: #000;
	left: 0;
	top: 50%;
	transform: translate(0,50%);
	z-index: 1;
}
.member_modal .txt_box dl dt span {
	position: relative;
	z-index: 5;
	padding-right: 5px;
}
.member_modal .txt_box dl dt .icon_cart {
	position: relative;
	padding-right: 30px;
}
.member_modal .txt_box dl dt .icon_cart::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/icon_cart.png)no-repeat left center/22px 18px;
	width: 22px;
	height: 18px;
	right: 4px;
	top: 5px;
}
.member_modal .txt_box dl dd {
	letter-spacing: 0.075em;
}
.member_modal .purchase dd {
	display: flex;
	flex-flow: row nowrap;
	align-items: flex-start;
	justify-content: space-between;
}
.member_modal .purchase dd img {
	max-width: 161px;
	margin-right: 15px;
}
.member_modal .purchase dd .list_btn {
	width: 100%;
}
.member_modal .purchase dd .list_btn img {
	max-width: 70px;
}
.member_modal .purchase dd .list_btn a::after {
	background: url(../img/btn_arrow_b.png)no-repeat right center/8px 16px;
	width: 8px;
	height: 16px;
	right: 15px;
}

@media screen and (min-width:768px) and ( max-width:1080px) {
	
}
@media screen and (max-width:768px) {

}


.member_modal_bg01 {
	background: #f1c9d4;
}

.member_modal_bg01 .txt_box dl dt span {
	display: inline-block;
	background: #f1c9d4;
}


.member_modal_bg02 {
	background: #f9f1cd;
}

.member_modal_bg02 .txt_box dl dt span {
	display: inline-block;
	background: #f9f1cd;
}

.member_modal_bg03 {
	background: #d3dfec;
}

.member_modal_bg03 .txt_box dl dt span {
	display: inline-block;
	background: #d3dfec;
}

/* color01_girly
-------------------------------------------------------*/
#color01_girly {
	background: 
	url("../img/bg_girly01.png") no-repeat left top / auto 100%,
	url("../img/bg_girly02.png") no-repeat right top / auto 100%;
	background-color: #cfe9e9;
}
#color01_girly.area {
	padding: 0 20px;
}
#color01_girly .color_layout .txt_box dl dt {
	background-color: #e7b8c8;
}
#color01_girly .color_layout .img_box .comment::before {
	background: #e7b8c8;
}
@media screen and (max-width:1280px) {
#color01_girly.area {
	padding-top: 30px;
}

#color01_girly {
	background: 
	url("../img/bg_girly01.png") no-repeat 15% top/ auto 100%,
	url("../img/bg_girly02.png") no-repeat right bottom/ auto 100%;
	background-color: #cfe9e9;
	background-size: 150%;
}
}



@media screen and (max-width:768px) {
#color01_girly.area {
	padding-top: 30px;
}

#color01_girly {
	background: 
	url("../img/bg_girly01.png") no-repeat 15% top/ auto 100%,
	url("../img/bg_girly02.png") no-repeat right bottom/ auto 100%;
	background-color: #cfe9e9;
	background-size: 300%;
}
}

/* color01_girly_member
-------------------------------------------------------*/
#color01_girly_member .member_modal {
	background: #f1c9d4;
}
#color01_girly_member .member_modal .txt_box dl dt span {
	background: #f1c9d4;
}
@media screen and (min-width:768px) and ( max-width:1080px) {
	
}
@media screen and (max-width:768px) {

}

/* color02_natural
-------------------------------------------------------*/
#color02_natural {
	background: 
	url("../img/bg_natural01.png") no-repeat left top / auto 100%,
	url("../img/bg_natural02.png") no-repeat right top / auto 100%;
	background-color: #f9f8f4;
}
#color02_natural.area {
	padding: 0 20px;
}
#color02_natural .color_layout .txt_box dl dt {
	background-color: #a1cad3;
	letter-spacing: -1px;
}
#color02_natural .color_layout .img_box .comment::before {
	background: #a1cad3;
}
@media screen and (max-width:1280px) {
#color02_natural.area {
	padding-top: 30px;
}

#color02_natural {
	background: 
	url("../img/bg_natural01.png") no-repeat 15% top/ auto 100%,
	url("../img/bg_natural02.png") no-repeat right bottom/ auto 100%;
	background-color: #f9f8f4;
	background-size: 150%;
}
}
@media screen and (max-width:768px) {
#color02_natural.area {
	padding-top: 30px;
}

#color02_natural {
	background: 
	url("../img/bg_natural01.png") no-repeat 15% top/ auto 100%,
	url("../img/bg_natural02.png") no-repeat right bottom/ auto 100%;
	background-color: #f9f8f4;
	background-size: 300%;
}
}
/* color02_natural_member
-------------------------------------------------------*/
#color02_natural_member .member_modal {
	background: #f9f1cd;
}
#color02_natural_member .member_modal .txt_box dl dt span {
	background: #f9f1cd;
}
@media screen and (min-width:768px) and ( max-width:1080px) {
	
}
@media screen and (max-width:768px) {

}

/* color03_cool
-------------------------------------------------------*/
#color03_cool {
	background: 
	url("../img/bg_cool01.png") no-repeat left top / auto 100%,
	url("../img/bg_cool02.png") no-repeat right top / auto 100%;
	background-color: #e3ebf3;
}
#color03_cool.area {
	padding: 0 20px;
}
#color03_cool .color_layout .txt_box dl dt {
	background-color: #8699b2;
	letter-spacing: -2px;
}
#color03_cool .color_layout .img_box .comment::before {
	background: #8699b2;
}
@media screen and (max-width:1280px) {
#color03_cool .area {
	padding-top: 30px;
}

#color03_cool  {
	background: 
	url("../img/bg_cool01.png") no-repeat 15% top/ auto 100%,
	url("../img/bg_cool02.png") no-repeat right bottom/ auto 100%;
	background-color: #e3ebf3;
	background-size: 150%;
}
}

@media screen and (max-width:768px) {
#color03_cool .area {
	padding-top: 30px;
}

#color03_cool  {
	background: 
	url("../img/bg_cool01.png") no-repeat 15% top/ auto 100%,
	url("../img/bg_cool02.png") no-repeat right bottom/ auto 100%;
	background-color: #e3ebf3;
	background-size: 300%;
}
}

/* color03_cool_member
-------------------------------------------------------*/
#color03_cool_member .member_modal {
	background: #d3dfec;
}
#color03_cool_member .member_modal .txt_box dl dt span {
	background: #d3dfec;
}
@media screen and (min-width:768px) and ( max-width:1080px) {
	
}
@media screen and (max-width:768px) {

}


/* colorbox個別調整
-------------------------------------------------------*/


/*
@media screen and (max-width:1080px) {

	#colorbox {
		width: 100% !important;
	}

	#cboxWrapper {
		width: 100% !important;
	}

	#cboxContent {
		width: 100% !important;
	}

	#cboxLoadedContent {
		width: 95% !important;
	}

	.member_modal {
		display: block;
	}

	.member_modal .txt_box {
		width: 100%;
	}

	.member_modal .txt_box .name {
		font-size: 2.5rem;
	}

	.member_modal .txt_box .en {
		font-size: 1.2rem;
	}
	
	#cboxClose {
		right: 12% !important;
	}

	.member_modal .img {
		width: 70%;
		margin: 0 auto;
		margin-bottom: 20px;
	}

	.member_modal {
		padding-right: 20px;
	}

}
	

@media screen and (max-width:500px) {
	#cboxLoadedContent {
		width: 89.5% !important;
	}
	#cboxClose {
		right: 15% !important;
	}
}
	*/

/* NGだった指定は消す（コメント化）して、下の“置き換え”を使う */
/*
@media screen and (max-width:1080px) {

  #colorbox,
  #cboxWrapper,
  #cboxContent {
    width: auto !important;
    height: auto !important;
    max-width: 100vw;
  }

  #cboxLoadedContent {
    width: auto !important;
    max-width: 100vw !important; 
    max-height: calc(100vh - 80px);
    overflow: auto; 
    box-sizing: border-box;
    padding: 0 10px; 
  }

  #cboxOverlay {
    position: fixed !important;
    inset: 0 !important;
  }

  #cboxClose {
    right: 10px !important;
    top: 10px !important;
  }

  .member_modal { display:block; padding-right:20px; }
  .member_modal .img { width:70%; margin:0 auto 20px; }
  .member_modal .txt_box { width:100%; }
  .member_modal .txt_box .name { font-size:2.5rem; }
  .member_modal .txt_box .en { font-size:1.2rem; }
}
*/
@media screen and (max-width:1080px) {

	.member_modal {
	max-width: 600px;
  }

  
  #cboxLoadedContent {
    overflow: auto; 
    box-sizing: border-box;
    padding: 0 10px; 
  }

  #cboxClose {
    right: 10px !important;
    top: 10px !important;
  }

  .member_modal { display:block; padding-right:20px; }
  .member_modal .img { width:70%; margin:0 auto 20px; }
  .member_modal .txt_box { width:100%; }
  .member_modal .txt_box .name { font-size:2.5rem; }
  .member_modal .txt_box .en { font-size:1.2rem; }
}

@media screen and (max-width:500px) {
	.member_modal {
	max-width: 320px;
  }
}



/* visual_card
-------------------------------------------------------*/
#visual_card {
	background: url(../img/bg01.png)no-repeat center/cover;
}
#visual_card.area {
	padding: 100px 20px 0;
}
#visual_card .inner {
	max-width: 1800px;
}
#visual_card .visual_card_ttl {
	text-align: center;
	max-width: 1000px;
	margin: 0 auto;
	background: url(../img/bg_ribbon.png)no-repeat center/100% 100%;
	font-size: 3.5rem;
	padding: 70px 20px;
	box-sizing: border-box;
	font-weight: 700;
	line-height: 1.4;
	position: relative;
	letter-spacing: 0;
	z-index: 2;
}
#visual_card .visual_card_ttl::before {
	position: absolute;
	display: block;
	content: "";
	width: 150px;
	height: 150px;
	background: url(../img/limited.png)no-repeat left top/150px 150px;
	left: 7%;
	top: -25%;
}
#visual_card .visual_card_ttl::after {
	position: absolute;
	display: block;
	content: "";
	width: 240px;
	height: 157px;
	background: url(../img/cam_card.png)no-repeat left top;
	background-size: 100%;
	right: -7%;
	bottom: -15%;
}

.visual_card_ttl_sub {
	font-weight: 700;
	text-align: center;
	margin-bottom: 20px;
	font-size: 2.4rem;
}

.txt_pk {
	color: #e37ca0;
}

#visual_card .visual_card_box {
	max-width: 1190px;
	margin: -100px auto 0;
	background: #7CC3D9;
background: linear-gradient(90deg, rgba(124, 195, 217, 1) 0%, rgba(223, 179, 196, 1) 100%);
padding: 8px;
border-radius: 30px;
margin-bottom: 50px;
}
#visual_card .visual_card_box .in {
	background: #fff;
	border-radius: 30px;
	padding: 120px 30px 50px;
	position: relative;
}

#visual_card .visual_card_box .in::after {
	position: absolute;
	content: "";
	background: url(../img/arrow_bottom.png) no-repeat;
	background-size: 100%;
	width: 111px;
	height: 110px;
	bottom: -107px;
	left: 50%;
	transform: translateX(-50%);
}


#visual_card .visual_card_box .img_area {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
	margin-top: 30px;
	margin-bottom: 20px;
}

#visual_card .visual_card_box .img_area .img {
	width: 42%;
}

#visual_card .visual_card_box .list_product {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
	width: 55%;
}

#visual_card .visual_card_box .txt {
	font-size: 1.8rem;
	letter-spacing: 1px;
}
#visual_card .visual_card_box .txt span {
	letter-spacing: 0;
}

#visual_card .visual_card_box .list_product {
	text-align: center;
}

#visual_card .visual_card_box .list_product p {
	font-weight: 700;
	margin-top: -10px;
	font-size: 1.8rem;
	letter-spacing: 0;
}

.caution {
	text-align: center;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 1.5rem;
	font-weight: 400;
	letter-spacing: 0;
}

.btm_txt {
	text-align: center;
	font-size: 2.4rem;
	font-weight: 700;
	margin-top: -40px;
	margin-bottom: 20px;
}

.btm_txt span:first-child {
	margin-right: 60px;
}
.btm_txt span:last-child {
	margin-left: 60px;
}

.btm_img {
	max-width:1804px;
	margin: 0 auto;
}

@media screen and (max-width:1070px) {

	#visual_card .visual_card_ttl::after {
  width: 200px;
  height: 157px;
  right: -2%;
  bottom: -22%;
}
}

@media screen and (max-width:980px) {

	#visual_card .visual_card_ttl::after {
  width: 170px;
  height: 157px;
  right: -2%;
  bottom: -35%;
}
}

@media screen and (max-width:880px) {

#visual_card .visual_card_ttl::before {
  width: 120px;
  height: 120px;
  background-size: 100%;
  left: 7%;
  top: -20%;
}
}


@media screen and (max-width:768px) {

	#visual_card .visual_card_ttl {
		font-size: 1.8rem;
		padding: 40px 30px;
		max-width: auto;
		width: 85%;
		margin: 0 auto;
	}

	#visual_card.area {
  padding: 50px 20px 0;
}

	#visual_card .visual_card_ttl::before {
		background-size: 100%;
	width: 80px;
	height: 80px;
	left: 2%;
	top: -20%;
}
#visual_card .visual_card_ttl::after {
	width: 120px;
	height: 77px;
	right: -15%;
	bottom: -10%;
}

#visual_card .visual_card_box {
	margin: -100px auto 0;
padding: 4px;
border-radius: 20px;
margin-bottom: 50px;
}
#visual_card .visual_card_box .in {
	background: #fff;
	border-radius: 20px;
	padding: 100px 15px 20px;
}

.visual_card_ttl_sub {
  margin-bottom: 20px;
  font-size: 1.8rem;
}
#visual_card .visual_card_box .txt {
  font-size: 1.4rem;
  text-align: left;
}

#visual_card .visual_card_box .img_area {
	display: block;
}

#visual_card .visual_card_box .img_area .img {
	width: 100%;
	margin-bottom: 20px;
}

#visual_card .visual_card_box .list_product {
	width: 100%;
	display: block;
}

#visual_card .visual_card_box .list_product li {
	width: 80%;
	margin: 0 auto;
}

#visual_card .visual_card_box .list_product li:first-child {
	margin-bottom: 20px;
}

#visual_card .visual_card_box .list_product p {
	font-size: 1.4rem;
	margin-top: -20px;
}

.caution {
	text-align: left;
	font-size: 1.2rem;
}

#visual_card .visual_card_box .in::after {
	display: none;
}


.btm_txt {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 700;
  margin-top: -40px;
  margin-bottom: 20px;
}

.btm_txt span:first-child {
	margin-right: 0px;
}
.btm_txt span:last-child {
	margin-left: 0px;
}


}

/* new_product
-------------------------------------------------------*/

#new_product.area {
	padding:120px 20px;
}

#new_product .ttl01 {
	margin-bottom: 70px;
	font-weight: 500;
}

.list_new_prpduct {
	display: flex;
	justify-content: space-between;
	margin-bottom: 50px;
}

.list_new_prpduct li:first-child {
	width: 55%;
}
.list_new_prpduct li:last-child {
	width: 40%;
}

.list_new_prpduct .img_box {
	display: flex;
	justify-content: space-between;
}

.list_new_prpduct .img_box {
	text-align: center;
}

.list_new_prpduct .img_box span {
	display: block;
	font-weight: 700;
	margin-top: 20px;
	letter-spacing: 0;
	font-size: 2rem;
}


.list_new_prpduct .img_box img {
	max-height: 205px;
	width: auto;
}

.list_new_prpduct .ttl {
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	padding:10px 0;
	font-weight: 700;
	font-size: 2rem;
	letter-spacing: 0;
	margin-top: 30px;
}


#new_product .ttl02 {
	margin-top: 50px;
	margin-bottom: 30px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
}

#new_product .ttl02::after {
	display: block;
	position: absolute;
	content: "";
	height: 1px;
	width: 100%;
	background: #000;
	left: 0;
	top: 50%;
}

#new_product .ttl02 span {
	display: inline-block;
	background: #fff;
	position: relative;
	z-index: 2;
	letter-spacing: 0;
}

#new_product .ttl02 span:first-child {
	padding-right: 10px;
	font-weight: 700;
	font-size: 1.8rem;
}
#new_product .ttl02 span:last-child {
	padding-left: 10px;
}


#new_product .ttl02 .size_s {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 1.4rem;
	font-weight: 400;
}

#new_product .list_btn {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 30px;
}

#new_product .list_btn li {
	width: 19%;
	margin-bottom: 0;
}

#new_product .list_btn li a {
	display: flex;
	align-items: center;
	min-height: 50px;
}

.list_btn .amazon img {
	max-width: 78px;
}
.list_btn .rakuten img {
	max-width: 78px;
}
.list_btn .yahoo img {
	max-width: 78px;
}
.list_btn .multiverse img {
	max-width: 154px;
}
.list_btn .qoo10 img {
	max-width: 73.5px;
}


@media screen and (max-width:1150px) {
	#new_product .list_btn {
		flex-wrap: wrap;
		position: relative;
	}

	#new_product .list_btn::after {
		content: "";
		width: 32%;
	}

	#new_product .list_btn li {
		width: 32%;
		margin-bottom: 10px;
	}
}

@media screen and (max-width:1180px) {
	.list_new_prpduct .img_box img {
	max-height: 170px;
}
}

@media screen and (max-width:900px) {
	.list_new_prpduct .img_box img {
	max-height: 130px;
}
}

@media screen and (max-width:768px) {

	#new_product.area {
	padding:40px 20px;
}
#new_product .ttl01 {
	margin-bottom: 30px;
}
.list_new_prpduct {
	display: block;
	margin-bottom: 20px;
}
.list_new_prpduct li:first-child {
	width: 100%;
	margin-bottom: 40px;
}
.list_new_prpduct li:last-child {
	width: 100%;
}
.list_new_prpduct .img_box img {
	max-height: inherit;
	width: 100%;
}

.list_new_prpduct .img {
	width: 32%;
}
.list_new_prpduct .img_box span {
  margin-top: 5px;
  font-size: 1.4rem;
}
.list_new_prpduct .ttl {
  padding: 10px 0;
  font-size: 1.5rem;
  margin-top: 20px;
}


#new_product .ttl02 {
	display: block;
	margin-top:30px;
  margin-bottom: 20px;
}
#new_product .ttl02 span:first-child {
	padding-right: 0px;
	font-weight: 700;
	font-size: 1.8rem;
}
#new_product .ttl02 span:last-child {
	display: block;
	padding-left: 0px;
}

#new_product .list_btn {
	display: block;
}

#new_product .list_btn li {
	width: 100%;
	margin-bottom: 10px;
}

}

/* member_slider
-------------------------------------------------------*/

#member_slider {
	background: #9287C7;
background: linear-gradient(180deg, rgba(146, 135, 199, 1) 0%, rgba(201, 196, 225, 1) 100%);
}

#member_slider .ttl01 {
	max-width: 775px;
	margin: 0 auto;
}

#member_slider.area {
	padding: 100px 0;
}

#member_slider .inner {
	max-width: 100%;
}

.slick-slide {
	margin: 0 30px;
}

.slick-dots {
	bottom: -40px !important;
}

.slick-dots li button {
	width: 10px !important;
	height: 10px !important;
	margin: 0 3px !important;
}

#member_slider .btn01 {
	text-align: center;
	margin-top: 120px;
}

#member_slider .btn01 a {
  display:block;
  background: #fff;
  border: 1px solid #9287c7;
  padding: 10px 20px;
  position: relative;
  border-radius: 100px;
  max-width: 400px;
  margin: 0 auto;
  color: #9287c7;
  letter-spacing: 0;
  font-size: 1.8rem;
}

#member_slider .btn01 a::after {
  position: absolute;
  display: block;
  content: "";
  background: url(../img/btn_arrow.png)no-repeat right center/10px 19px;
  width: 10px;
  height: 19px;
  right: 20px;
  top: 50%;
  transform: translate(0,-50%);
}
@media screen and (max-width:768px) {

#member_slider.area {
	padding: 50px 0;
}

#member_slider .ttl01 {
	max-width: auto;
	width: 90%;
	margin: 0 auto;
}

.slick-slide {
	margin: 0 10px;
}

#member_slider .btn01 {
	margin-top: 80px;
}

#member_slider .btn01 a {

  padding: 10px 10px;
  max-width: 280px;
  font-size: 1.5rem;
}

}

/* benefits
-------------------------------------------------------*/

#benefits.area {
  padding: 120px 20px 60px 20px;
}

#benefits .ttl01 {
  margin-bottom: 70px;
  font-weight: 500;
}

.list_benefits {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.list_benefits li {
	width: 30%;
	position: relative;
	background: #fcf2f6;
	padding: 10px;
	padding-bottom: 20px;
	margin-bottom: 50px;
}

.list_benefits li:last-child {
	width: 65%;
}

.list_benefits .num {
	position: absolute;
	width: 56px;
	top: -20px;
	left: 50%;
	transform: translateX(-50%);
}

.list_benefits li .img {

}

.list_benefits li .ttl {
	text-align: center;
	margin-top: 20px;
	margin-bottom: 10px;
	font-weight: 700;
	letter-spacing: 0;
}

.list_benefits li .txt {
	text-align: center;
	font-weight: 400;
	font-size: 1.4rem;
	letter-spacing: 0;
}

.list_benefits li .img_box {
	background: #fff;
	display: flex;
	padding: 30px;
	padding-left: 0;
	padding-top: 50px;
}

.list_benefits li .img_box span {
	display: block;
	line-height: 1.2;
	letter-spacing: 0;
	margin-top: 15px;
}

@media screen and (max-width:1050px) {
	.list_benefits li .img_box span {
	font-size: 1.2rem;
}
}

@media screen and (max-width:768px) {
	#benefits.area {
  padding: 50px 20px;
}

.list_benefits {
	display: block;
}

.list_benefits li {
	width: 90%;
	margin: 0 auto;
	margin-bottom: 40px;
}

.list_benefits li:last-child {
	width: 90%;
	margin: 0 auto;
}

.list_benefits li .img_box {
	display: block;
	padding: 30px;
	padding-top: 50px;
}

.list_benefits li .img_box .img {
	margin-bottom: 20px;
}

.list_benefits li .txt {
	font-size: 1.2rem;
}

.list_benefits li .img_box span {
	font-size: 1.2rem;
}

}

/* size
-------------------------------------------------------*/

.size_box {
	border: 5px solid #cacfe1;
	border-radius: 20px;
	background: #fff;
	padding: 100px 80px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.size_box .img {
	width: 35%;
}

.size_box .txt_box {
	width: 55%;
}

.size_box .txt_box table {
	width: 100%;
	font-size: 2rem;
	margin-bottom: 30px;
}

.size_box .txt_box tr {
	border-bottom: 1px solid #000;
}

.size_box .txt_box tr:first-child {
	border: none;
}
.size_box .txt_box tr:last-child {
	border: none;
}

.size_box .txt_box th {
	background: #8c9ac1;
	color: #fff;
	text-align: center;
	padding-top: 10px;
	padding-bottom: 10px;
}
.size_box .txt_box th:first-child {
	background: none;
}
.size_box .txt_box th:last-child {
	border-left: 10px solid #fff;
}

.size_box .txt_box td {
	text-align: center;
	padding-top: 15px;
	padding-bottom: 15px;
}

.size_box .txt_box td:first-child {
	text-align: left;
	color: #8c9ac1;
}

#size .txt {
	color:#8c9ac1;
	font-size: 2rem;
	letter-spacing: 0;
	margin-bottom: 15px;
}

#size .caution {
	text-align: left;
}

@media screen and (max-width:950px) {
	.size_box .txt_box table {
	font-size: 1.5rem;
}

}

@media screen and (max-width:768px) {
	.size_box {
	border: 3px solid #cacfe1;
	padding: 20px;
	display: block;
}
.size_box .img {
	width: 70%;
	margin: 0 auto;
	margin-bottom: 30px;
}

.size_box .txt_box {
	width: 100%;
}

.size_box .txt_box table {
	font-size: 1.22rem;
	letter-spacing: 0;
	vertical-align: middle;
	margin-bottom: 15px;
}

.size_box .txt_box th {
	vertical-align: middle;
	padding: 5px 0;
}
.size_box .txt_box td {
	vertical-align: middle;
	padding: 10px 0;
}

#size .txt {
	font-size: 1.6rem;
	margin-bottom: 15px;
}


}

/* introduction
-------------------------------------------------------*/

#introduction .txt {
	font-weight: 600;
	margin-top: 30px;
	line-height: 2;
	letter-spacing: 0;
	font-size: 1.8rem;
}

@media screen and (max-width:1000px) {
	#introduction .txt {
		font-size: 1.6rem;
	}
}
@media screen and (max-width:768px) {

	#introduction .txt {
		font-size: 1.4rem;
	}

}

/* footer
-------------------------------------------------------*/
#footer {
	background: #95BFD4;
background: linear-gradient(90deg, rgba(149, 191, 212, 1) 0%, rgba(210, 181, 199, 1) 100%);
position: relative;
padding: 0;
padding-bottom: 50px;
}

.footer_bg {
	background: url(../img/footer_top.png) no-repeat;
	background-position: top center;
	background-size: contain;
	padding-top: 150px;
	padding-left: 20px;
	padding-right: 20px;
	position: relative;
	top: -2px;
}

#footer .in {
	display: flex;
	justify-content: space-between;
}

#footer .logo {
	max-width: 243px;
}

#footer .btn_box .ttl {
	color: #fff;
	margin-bottom: 10px;
}

#footer .btn_box .list_btn li a {
	border: none;
}

#footer .btn_box .list_btn {
	min-width: 350px;
}

#footer .btn_box .list_btn .multiverse img {
	vertical-align: middle;
}

.copy {
	text-align: center;
	margin-top: 80px;
}

.copy small {
	color: #fff;
	font-size: 1.2rem;
	letter-spacing: 0;
	font-weight: 400;
}

@media screen and (max-width:768px) {
	.footer_bg {
		padding-top: 50px;
	}
	#footer .in {
		display: block;
	}
	#footer .logo {
	max-width: 160px;
	margin: 0 auto;
	margin-bottom: 30px;
}

}


.comingsoon_wrap {
  background: linear-gradient(90deg, rgba(149, 191, 212, 1) 0%, rgba(210, 181, 199, 1) 100%);
  position: relative;
  min-height: 100vh;        /* 画面全体の高さを確保 */
  display: flex;            /* Flexboxを有効化 */
  justify-content: center;  /* 水平方向の中央寄せ */
  align-items: center;      /* 垂直方向の中央寄せ */
}

.comingsoon {
  max-width: 600px;
  margin: 0 auto;
  background: rgba(255,255,255,0.7);
  padding: 30px;
  border-radius: 30px;
}


@media screen and (max-width:768px) {

	.comingsoon {
		max-width: inherit;
		width: 80%;
	}
}




.sp_two_l {
		letter-spacing: 0 !important;

	}
	.sp_two_r {
		letter-spacing: 0 !important;
	}

@media screen and (max-width:768px) {
	.sp_two {
		display: flex;
		justify-content: center;
		text-align: left;
		word-break: keep-all;
		
	}

	
}

