@charset "UTF-8";
/* CSS Document */
html{
	scroll-behavior: smooth;
}
.pc{
	display: block;
}
.sp{
	display: none;
}
body{
	font-family:"游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif;
	background-color: #FFF4E1;
	font-size: 16px;
}
img {
 	max-width: 100%;
  	height: auto;
}
.textcenter{
	text-align: center;
}
.textleft{
	text-align: left;
}
h2{
	background-color: #fff;
	text-align: center;
	padding: 16px;
	margin: 80px auto;
}
h3{
	font-weight: bold;
	font-size: 28px;
	line-height: 50px;
}
h3 span{
	color: #0274D8;
}
h4{
	font-size: 32px;
	padding-left: 20px;
	line-height: 64px;
}
ul{
	list-style:none;
	padding: 0;
}
hr{
	border-top: 2px solid #fff;    /* 上側の1本線 */
    border-bottom: 2px solid #fff; /* 下側の1本線 */
	border-right: 2px solid #fff;    /* 上側の1本線 */
    border-left: 2px solid #fff;
	margin: 30px 70px;
}

.shape{
	min-width: 100%;
  	min-height: 100%;
}
/* KV */	

.fv{
	background-color: #fff;
}
.kv{
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
}
.kv_logo{
	position: absolute;
	top: 24px;
	left: 24px;
}
.kv_side{
	display: flex;
	flex-direction: column;
	align-items:center;
	position: absolute;
	top:17%;
	left: 24px;
	width: 22vw;
}
.kv_free{
	display: inline-block;
	padding: 8px 32px;
	background-color: #1DA3E2;
	color: #fff;
	font-weight: bold;
	letter-spacing: 3px;
	border-radius: 17px;
	width: 12vw;
	text-align: center;
}
.kv_about{
	font-size: 16px;
	color: #224E80;
	line-height: 28px;
	font-weight: bold;
}
/* メイク・ア・ウィッシュカードについて */
.about_make{
	text-align: center;
	position: relative;
}
.about_make .shape{
	margin-top: -40px;
}
.make_detail{
	display: flex;
	max-width: 1000px;
	margin: 0 auto;
	align-items: center;
}
.make_detail p{
	text-align: left; 
	font-weight: bold;
	font-size: 22px;
	line-height: 40px;
	padding: 60px 20px 0 0;
}
.make_detail img{
	width:46%;
}
/* カード会員さまのご負担は一切なく */
.price{
	background-color: #EDC302;
	border-radius: 22px;
	max-width: 1000px;
	margin: 64px auto 32px;
	padding: 32px;
}
.price h3{
	font-size: 28px;
}
.price h3 b{
	text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-color: #fff;
    text-decoration-thickness: 6px;
	font-size: 28px;
}
/* 寄付吹き出し */
.donation {
    position: relative;
    display: inline-block;
    margin: 1.5em 0;
    padding: 24px 54px;
    font-size: 16px;
    background: #fff;
    border-radius: 15px;
}
.donation li{
	display: flex;
	align-items: center;
}
.donation:before {
    content: "";
    position: absolute;
    top: -30px;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-bottom: 15px solid #fff;
}
.donation li img{
	padding-right: 20px
}
/* 寄付金はこのようなことに使われています */
.use{
	background-color: #fff;
	border-radius: 22px;
	max-width: 1000px;
	margin: 64px auto 32px;
	padding: 32px;
	position: relative;
}
.use>p{
	margin: 0 auto;
	width: 88%;
	text-align: left;
	line-height: 32px;
}
.princess{
	width: 88%;
	display: flex;
	align-items: center;
	margin: 0 auto 20px;
	text-align: left;
	line-height: 32px;
}
.castle{
	position: absolute;
	top: 28%;
	left: 10%;	
}
/* CVボタン */
.cv_btn{
	margin: 80px auto 160px;
}

/* ライフカードが選ばれるわけ */
.cause{
	background-color: #9DDCDC;
	padding-bottom: 124px;
}
.cause img{
	margin: 0 auto;
}
.cause .shape{
	margin-top: -40px;
}
.cause p{
	padding-top: 32px;
}

/* こんな時にライフカードがオススメ */

/* オレンジ吹き出し */
.orng{
    position: relative;
    display: inline-block;
    margin: 1em 40px;
    padding: 16px 32px;
    font-size: 16px;
    background: #EDC302;
    border-radius: 8px;
	max-width: 650px;
}
.orng:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -30px;
    margin-top: -10px;
    border: 12px solid transparent;
    border-right: 19px solid #EDC302;
}

/* 白吹き出し*/
.wht {
    position: relative;
    display: inline-block;
    margin: 1em 40px;
    padding: 16px 32px;
    font-size: 16px;
    background: #fff;
    border-radius: 8px;
	max-width: 580px;
}

.wht:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  margin-top: -15px;
  border: 12px solid transparent;
  border-left: 19px solid #fff;
}

.osusume{
	background-color: #FEEBB7;
	padding-bottom: 88px;
}
.osusume .shape{
	margin-top: -40px;
}
.osusume_talk{
	background-color: #FFF4E1;
	border-radius: 22px;
	max-width: 1000px;
	margin: 0 auto 32px;
	padding: 24px 0;
	font-weight: bold;
}
.osusume_talk li{
	display: flex;
	justify-content: center;
	align-items: center;
}
.osusume_talk li p{
	font-size: 23px;
	text-align: left;
	line-height: 30px;
}
.osusume_talk span{
	color: #006CB8;
}
.osusume_lmall{
	position: relative;;
}
.osusume_lmall p{
	padding-bottom: 60px;
}
/* lmallとは*/
.osusume_lmall a{
	position: absolute;
	top: 55%;
	right: 30%;
}

/* アコーディオン */	
.menu {
  	padding: 80px 80px;
	max-width: 1000px;
	margin: 0 auto;
}
.menu input {
  	display: none; /*チェックボックスを隠す*/
}
/*バー部分*/
.menu label {
  	cursor :pointer;
  	display: block;
  	text-decoration: none;
  	color: #000;
  	font-weight: bold;
	font-size: 24px;
  	line-height: 1;
  	position: relative;
  	margin: 0 0 10px;
  	padding: 20px;
  	background-color: #fff;
}
/*開いたときに表示される部分*/
.menu ul {
  	margin: 0;
  	padding: 0;
  	list-style: none;
  	margin-bottom: 1px;
}
.menu li {
  	height: 0;
  	overflow: hidden;
  	/*transition: padding-bottom 0.5s, padding-top 0.5s; /*閉じるときのアニメーション
  	-webkit-transition: padding-bottom 0.5s, padding-top 0.5s;
  	-ms-transition: padding-bottom 0.5s, padding-top 0.5s;
  	-o-transition: padding-bottom 0.5s, padding-top 0.5s;*/
	transition: all 0.5s ease;
}
#menu_bar01:checked ~ #links01 li,
#menu_bar02:checked ~ #links02 li,
#menu_bar03:checked ~ #links03 li{
  	height: auto; /*開いたときに表示されるliの高さ*/
  	opacity: 1;
  	margin-top: -10px;
  	background: #fff;
  	padding: 0 10px;
}
 /*開いたときの下の余白*/
#menu_bar01:checked ~ #links01 li:last-child,
#menu_bar02:checked ~ #links02 li:last-child,
#menu_bar03:checked ~ #links03 li:last-child{
  	margin-bottom: 20px;
}
	
/*閉じた状態の矢印描画*/
.menu label:after{
  	content:"";
  	display:block;
  	width:10px;
  	height:10px;
  	border-top: #000 4px solid;
  	border-right: #000 4px solid;
  	-webkit-transform: rotate(135deg);
  	-ms-transform: rotate(135deg);
  	transform: rotate(135deg);
  	position:absolute;
  	right: 5%;
  	top: 0;
  	bottom: 15%;
  	margin: auto;
}
/*開いた状態の矢印描画*/
.menu input[type=checkbox]:checked + label:after{
  	content:"";
  	display:block;
  	width:10px;
  	height:10px;
  	border-top: #000 4px solid;
  	border-right: #000 4px solid;
  	-webkit-transform: rotate(-45deg);
  	-ms-transform: rotate(-45deg);
  	transform: rotate(-45deg);
  	position:absolute;
  	right: 5%;
  	top: 7%;
  	bottom: 0;
  	margin: auto;
}
.menu h3{
	background-color: #EDC302;
}
.point_program{
	background-color: #FFF4E1;
	border-radius: 22px;
	max-width: 900px;
	margin: 32px auto;
	padding: 24px 0;
}
.point_program p{
	padding: 0 20px;
}
.point{
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 4px;
}
.menu .detail_btn{
	margin-left: 60%;
}

.first p{
	font-size: 24px;
	font-weight: normal;
	text-align: left;
	padding: 0 40px;
}
.p_stage{
	margin: 0 auto;
}
.limit{
	background-color: #FFF;
	border-radius: 22px;
	max-width: 700px;
	margin: 32px auto;
	padding: 24px 40px;
}
.limit_list{
	display: flex;
	align-items: center;
}
.limit p{
	text-align: left;
}
/* グレー吹き出し */
.gry{
    position: relative;
    display: inline-block;
    margin: 1em 40px;
    padding: 8px 32px;
    font-size: 16px;
    background: #F0F0F0;
    border-radius: 8px;
	max-width: 650px;
}
.gry:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -30px;
    margin-top: -10px;
    border: 12px solid transparent;
    border-right: 19px solid #F0F0F0;
}
.point_icon{
	padding-right: 24px;
}
/*  ポイントご利用方法 */
.point_use{
	background-color: #F2F2F2;
	border-radius: 22px;
	max-width: 900px;
	margin: 32px auto;
	padding: 24px 0;
}
.point_use a{
	padding: 0 20px;
	text-align: left;
}
.point_use .textleft{
	padding: 30px;
}
/*  年会費無料詳細 */
.free{
	margin: 0 auto;
}
.point img{
	width: 40%;
	padding-bottom: 40px;
}
.point h4 span{
	font-size: 76px;
}
.support{
	display: flex;
	align-items: center;
	background-color: #F0F0F0;
	border-radius: 22px;
	margin: 32px 100px;
	padding: 18px 40px;
	text-align: left;
}
.support img{
	padding-right: 30px;
}
.support b{
	font-size: 24px;
}
/*  L-Mall詳細 */
.lmall h4 span{
	font-size: 76px;
}
.lmall_detail{
	margin: 0 auto;
	text-align: left;
	width: 70%;
	line-height: 32px;
	padding-bottom: 32px;
}
.lmall img{
	margin: 0 auto;
	padding-bottom: 32px;
}
.lmall_flow{
	background-color: #FFF4E1;
	border-radius: 22px;
	max-width: 800px;
	margin: 32px auto;
	padding: 24px 0px;
}
.lmall_flow h3{
	color: #000;
	background-color: #9DDCDC;
}
.lmall_flow img{
	width: 90%;
}
.shop_list{
    position: relative;
    display: inline-block;
    margin: 1em 40px;
    padding: 32px 32px 24px 32px;
    font-size: 16px;
    background: #fff;
    border-radius: 22px;
	max-width: 650px;
	text-align: left;
}
.shop_list:before {
    content: "";
    position: absolute;
    top: -30px;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-bottom: 15px solid #fff;
}
.shop_list ul{
    padding-top: 40px;
	column-count: 2;
}
.shop_list li{
    color: #000;
    margin: 32px;
	padding: 100px;
}
.shop_list p{
	text-align: right;
	padding-top: 10px;
}
/*  ナビゲーター */
.navi{
	margin: 0 auto;
	text-align: left;
	width: 70%;
	line-height: 32px;
	padding:  24px 0px;
	position: relative;
}
.navi img{
	position: absolute;
	top: -20%;
	right: -10%;
	
}
.navi b{
	font-size: 24px;
}
.navi h4{
	line-height: 0px;
	padding: 0;
	text-align: center;
}
.navi ul li{
	list-style:　disc;
}
/*  リボ払いご利用上の注意 */
.ribo{
	max-width: 1000px;
	background-color: #FFF;
	border-radius: 22px;
	margin: 0 auto 80px;
	padding: 24px;
	font-weight: bold;
}
.ribo p{
	font-weight: normal;
}
.btn_list{
	text-align: center;
	padding: 24px 0;
}
.btn_list a{
	color: #306BB2;
	border-radius: 100vh;
	border: 2px solid #306BB2;
	padding: 16px;
	text-decoration: none;
	margin: 10px;
	font-size: 14px;
}
/*  追従ボタン */
.cv{
    margin: 0 calc(50% - 50vw);
	width: 100vw;
	position: fixed;
	bottom: 0px;
	padding: 16px 0;
	background-color:rgba(255,255,255,0.8);
}
/*  フッター */
footer{
	background-color: #9DDCDC;
	padding-top: 24px;
	padding-bottom: 80px;
}
.footer_info{
	margin-top: 32px;
	background-color: #FEEBB7;
	padding:16px 0px;
	text-align: center;
}
h5{
	background-color: #fff;
	padding: 16px;
	font-size: 20px;
}
.footer_info a{
	text-decoration: none;
	font-size: 34px;
	color: #000;
	font-weight: bold;
	padding-left: 24px;
}

footer p {
  	color: #000;
 	font-weight: bold;
  	text-align: center;
	line-height: 30px;
  	font-size: 100%;
}
.footer_under{
	max-width: 1000px;
	margin: 0 auto;
}
.footer_box1 {
    padding-top: 2em;
    line-height: 3em;
	margin-right: 20px;
}
.footer_box1 img{
    width: 30%;
    padding-top:24px;
}

.footer_box1 p {
    text-align: left;
	margin-top: 0px;
}

.footer_box {
    padding-bottom: 10em;
    line-height: 3em;
}

.footer_box p,
.footer_box aside {
    text-align: right;
}

.footer_box a {
    color: #000;
    font-weight: bold;
}

.footer_box aside a {
    padding-left: 1em;
    padding-right: 1em;
    border-left: solid 3px #000;
    text-decoration: none;
}

.footer_box aside a:first-child {
  	border-left: none;
}

 /*************************************SP********************************/


@media screen and (max-width:767px) {
.pc{
	display: none !important;
}
.sp{
	display: block !important;
}

body{
	font-size: 10px;
}
h2{
	margin: 40px auto;
}
h3{
	font-size: 18px;
	line-height: 24px;
}
h3 span{
	color: #0274D8;
}
h4{
	font-size: 18px;
	padding-left: 0px;
	line-height: 27px;
}
hr{
	margin: 15px;
}
/* KV */	
.kv{
	max-width: 767px;
}
.kv_logo{
	top: 12px;
	left: 8px;
	width: 16%;
}
.kv_side{
    position: static;
    width: 100%;
    padding: 0px 16px 40px;
    box-sizing: border-box;
    flex-direction:row-reverse;
}
.kv_free {
    padding: 4px;
	display: inline-block;
	font-size: 14px;
	width: 30vw;
}
.kv_side div {
    width: 40%;
    text-align: center;
}
.kv_side .kv_about {
    width: 60%;
	font-size: 15px;
	line-height: 24px;
	margin-right: 8px;
}

/* メイク・ア・ウィッシュカードについて */
.about_make .shape{
	margin-top: -40px;
}
.make_detail{
	display: inherit;
	max-width: 767px;
}
.make_detail p{
	font-size: 15px;
	line-height: 28px;
	padding: 40px 20px;
	width: 80%;
	margin: 0 auto;
}
.make_detail img{
	width:60%;
}
/* カード会員さまのご負担は一切なく */
.price{
	border-radius: 7px;
	max-width: 750px;
	width: 75%;
	margin: 3px auto 24px;
	padding: 32px;
}	
.price h3{
	line-height: 32px;
	font-size: 4vw;
}

.price h3 b {
	font-size: 4vw;
}
/* 寄付吹き出し */
.donation {
    position: relative;
    display: inline-block;
    margin: 2em 0 1em;
    padding: 24px 32px;
    font-size: 13px;
	text-align: left;
}

/* 寄付金はこのようなことに使われています */
.use{
	border-radius: 7px;
	max-width: 750px;
	width: 75%;
	margin: 40px auto 24px;
	padding: 24px 32px;
}
.use>p{
	margin: 0 auto;
	width: 100%;
	text-align: left;
	line-height: 19px;
}
.princess{
	width: 100%;
	line-height: 19px;
}
.princess img{
	width: 30%;
}
.castle{
	width: 20%;
}
/* CVボタン */
.cv_btn_sp{
	margin: 64px auto 80px;
	width: 90%;
}
/* ライフカードが選ばれるわけ */
.cause{
	padding-bottom: 80px;
}
.cause h3{
	font-size: 19px;
	line-height: 32px;
}
.cause img{
	margin: 0 auto;
	width: 80%;
}

/* こんな時にライフカードがオススメ */

/* オレンジ吹き出し */
.orng{
    margin: 1em 0px 1em 24px;
    padding: 16px;
    font-size: 14px;
}
.orng:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -30px;
    margin-top: -10px;
    border: 12px solid transparent;
    border-right: 19px solid #EDC302;
}

/* 白吹き出し*/
.wht {
    margin: 1em 24px 1em 0px;
    padding: 16px;
}
.wht:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  margin-top: -15px;
  border: 12px solid transparent;
  border-left: 19px solid #fff;
}
.osusume{
	padding-bottom: 80px;
}
.osusume_talk{
	border-radius: 7px;
	max-width: 750px;
	width: 75%;
	margin: 40px auto 24px;
	padding: 24px 32px;
}
.osusume_talk img{
	width: 30%;
}
.osusume_talk li p{
	font-size: 14px;
	line-height: 20px;
}
.osusume_lmall p{
	padding-bottom: 20px;
}
.osusume_lmall{
	padding-bottom: 40px;
}
/* lmallとは*/
.osusume_lmall a{
	position: absolute;
	top: 80%;
	right: 10%;
}
.osusume_lmall a img{
	width: 100%;
}

/* アコーディオン */	
.menu {
  	padding: 40px 10px;
	max-width: 767px;
}
/*バー部分*/
.menu label {
	font-size: 16px;
}
	
/*閉じた状態の矢印描画*/
.menu label:after{
  	width:8px;
  	height:8px;
  	border-top: #000 2px solid;
  	border-right: #000 2px solid;
}
/*開いた状態の矢印描画*/
.menu input[type=checkbox]:checked + label:after{
  	width:8px;
  	height:8px;
  	border-top: #000 2px solid;
  	border-right: #000 2px solid;
}
.menu h3{
	font-size: 16px;
	padding: 10px;
}
.point_program{
	border-radius: 8px;
	max-width: 700px;
	margin: 32px 10px 0px;
	padding: 24px 0;
}
.point_program p{
	padding: 0 20px;
}
.point{
	display: block;
	padding: 0px;
}
.point img{
	width: 70%;
	padding-bottom: 0px;
}
.menu .detail_btn{
	margin-left: 0px;
}
.first p{
	font-size: 14px;
	font-weight: normal;
	text-align: left;
	padding: 0px 32px 10px;
}
.p_stage{
	width: 80vw;
	margin: 0 auto;
}
/* 有効期限が伸びると*/
.limit{
	border-radius: 8px;
	max-width: 700px;
	margin: 32px 16px;
	padding: 10px 0px 10px 10px;
	font-size: 11px;
}
/* グレー吹き出し */
.gry{
    margin: 10px 25px;
    padding: 4px;
    font-size: 12px;
    background: #F0F0F0;
    border-radius: 8px;
	max-width: 650px;
	width: 90%;
}
.point_icon{
	padding-right: 24px;
	width: 130%;
}
/*  ポイントご利用方法 */
.point_use{
	background-color: #F2F2F2;
	border-radius: 22px;
	max-width: 700px;
	margin: 32px auto;
	padding: 24px 0;
}
.point_use p{
	padding: 0 20px;
	text-align: left;
}
/*  年会費無料詳細 */
.free_detail .point{
	display: flex;
	align-items: center;
}
.free_detail .point img{
	width: 50%;
}
.free{
	margin-top: 32px;
	width: 90%;
}
.point h4 span{
	font-size: 28px;
}
.support{
	border-radius: 8px;
	margin: 24px 8px;
	padding: 8px;
}
.support img{
	padding-right: 30px;
	width: 25%;
}
.support b{
	font-size: 16px;
}
/*  L-Mall詳細 */
.lmall h4 span{
	font-size: 28px;
}
.lmall_detail{
	width: 90%;
	line-height: 20px;
}
.lmall img{
	margin: 0 auto;
	width: 90%;
	padding-bottom: 32px;
}
.lmall a img{
	width: 70%;
}
.lmall_flow{
	background-color: #FFF4E1;
	border-radius: 8px;
	max-width: 700px;
	margin: 24px 8px;
	padding:24px 0 24px 0;
}
.shop_list{
    margin: 0em 8px;
    padding: 10px;
    font-size: 10px;
    border-radius: 8px;
}
.shop_list ul{
    padding-top: 32px;
	column-count: 1;
}
.shop_list li{
    margin: 16px 0px;
}
.shop_list p{
	padding-top: 0px;
}
.shop_list b{
	font-size: 14px;
}

/*  ナビゲーター */
.navi{
	width: 90%;
	line-height: 17px;
	padding-bottom: 24px;
	position: relative;
}
.navi img{
	width: 24%;
	position: absolute;
	top: -3%;
	right: -2%;
}
.navi b{
	font-size: 14px;
}
.navi h4{
	font-size: 19px;
	padding: 10px;
}
.navi li{
	list-style-type:disc;
	margin: 10px 0px;
}
/*  リボ払いご利用上の注意 */
.ribo{
	border-radius: 7px;
	max-width: 750px;
	width: 75%;
	margin: 0px auto 24px;
	padding: 24px;
}
.ribo p{
	font-weight: normal;
}
.btn_list{
	display: flex;
	flex-direction: column;
	text-align: center;
	padding: 2px 0;
}
.btn_list a{
	color: #306BB2;
	border-radius: 100vh;
	border: 2px solid #306BB2;
	padding: 14px;
	text-decoration: none;
	margin: 10px;
}
/*  追従ボタン */
.cv{
	width: 100vw;
	position: fixed;
	bottom: 0px;
	padding: 10px 0;
	background-color:rgba(255,255,255,0.8);
}
.cv img{
	width: 90%;
}
/*  フッター */
footer{
	background-color: #9DDCDC;
	padding-top: 8px;
	padding-bottom: 32px;
}
.footer_info{
	margin-top: 24px;
	padding:8px 0px;
}
h5{
	padding: 8px;
	font-size: 14px;
}
.footer_info a{
	font-size: 28px;
	padding-left: 16px;
}

footer p {
	line-height: 15px;
}
.footer_under{
	max-width: 767px;
	margin: 0 auto;
}
.footer_box1 {
    padding-top: 2em;
    line-height: 3em;
	margin-left: 20px;
}
.footer_box1 img{
    width: 50%;
    padding-top:24px;
}

.footer_box1 p {
    text-align: left;
	margin-top: 0px;
}

}

@media screen and (min-width:768px) and ( max-width:860px){
	
/* KV */	
.kv{
	max-width: 767px;
}
.kv_logo{
	top: 12px;
	left: 8px;
	width: 16%;
}
.kv_side{
    position: static;
    width: 100%;
    padding: 0px 16px 40px;
    box-sizing: border-box;
    flex-direction:row-reverse;
}
.kv_free {
    padding: 4px;
	display: inline-block;
	font-size: 14px;
	width: 30vw;
}
.kv_side div {
    width: 40%;
    text-align: center;
}
.kv_side .kv_about {
    width: 60%;
	font-size: 15px;
	line-height: 24px;
	margin-right: 8px;
}

}