@charset "utf-8";
/* CSS Document */


/* header
   ========================================================================== */
header{
	position: relative;
	background: #A3988D;
}

header h1{
	padding: 2vw;
	font-size: 2.5vw;
	line-height: 150%;
	color: #000;
	font-weight: bold;
	text-align: center;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif;
}

header h1 span{
	color: inherit;
	font-family: inherit;
}


/* main_view
   ========================================================================== */
.main_view{
	position: relative;
	background: #fff;
	line-height: 0;
	text-align: center;
}


/* experience
   ========================================================================== */
.experience{
	background: url("../images/common/bg01.jpg") repeat center top;
	background-size: 10vw;
	line-height: 0;
}

.experience h2{
	padding: 3vw 3vw;
	position: relative;
	background: #B38E4B;
	line-height: 0;
}

.experience h2::after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 27px 39px 0 39px;
	border-color: #B38E4B transparent transparent transparent;
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	top: 100%;
}

.experience .inner{
	padding: 15px 3vw 6vw;
	text-align: center;
}
.blinking{
		-webkit-animation:blink 1s ease-in-out infinite alternate;
    -moz-animation:blink 1s ease-in-out infinite alternate;
    animation:blink 1s ease-in-out infinite alternate;
}
@-webkit-keyframes blink{0% {opacity:0;}100% {opacity:1;}}
@-moz-keyframes blink{0% {opacity:0;}100% {opacity:1;}}
@keyframes blink{0% {opacity:0;}100% {opacity:1;}}


/* **************************************************************** */
/* ctaメールフォーム
*/
.cta_bloc {
	width: 100%;
		padding: 1em 0 0 0;
	margin-bottom: -30px;
    background: #fff;
}
.cta_bloc h2{
	color: #ff0000;
	font-size: 20px;
	margin: 20px 0 0 0;
}
.btn_seminar_bloc {
	width:100%;
}
.btn_seminar_bloc a {
    display: block;
    
}
.btn_seminar_bloc a img {
	width:100%;
}
.pub_form input {
  outline: 0;
  background: #f2f2f2;
  width:60%;
  border: 0;
  margin:30px 0 15px;
  padding: 15px;
  box-sizing: border-box;

}
.pub_form{
	font-size:25px;
	text-align:center;
	font-weight:bold;
	}
.swing {
 width:100%;
 max-width:900px;
 padding:0;
 text-align:center;
margin:10px auto;
-moz-animation: swing linear 0.2s infinite;
-moz-transform-origin: center -5px 0;
-webkit-animation: swing linear 0.2s infinite;
-webkit-transform-origin: center -5px 0;
-ms-animation: swing linear 0.2s infinite;
-ms-transform-origin: center -5px 0;
-o-animation: swing linear 0.2s infinite;
-o-transform-origin:center -5px 0;
animation: swing linear 0.2s infinite;
transform-origin: center -5px 0;
display: block;

}
@-moz-keyframes swing {
0% { -moz-transform: rotate(0deg) }
25% { -moz-transform: rotate(1deg); }
50% { -moz-transform: rotate(0deg); }
75% { -moz-transform: rotate(-1deg); }
100% { -moz-transform: rotate(0deg); }
}
@-webkit-keyframes swing {
0% { -webkit-transform: rotate(0deg); }
25% { -webkit-transform: rotate(1deg); }
50% { -webkit-transform: rotate(0deg); }
75% { -webkit-transform: rotate(-1deg); }
100% { -webkit-transform: rotate(0deg); }
}    
@-o-keyframes swing {
0% { -o-transform: rotate(0deg); }
25% { -o-transform: rotate(1deg); }
50% { -o-transform: rotate(0deg); }
75% { -o-transform: rotate(-1deg); }
100% { -o-transform: rotate(0deg); }
}
@keyframes swing {
0% { transform: rotate(0deg); }
25% { transform: rotate(1deg); }
50% { transform: rotate(0deg); }
75% { transform: rotate(-1deg); }
100% { transform: rotate(0deg); }
}
/* cv
   ========================================================================== */
.cv{
	margin: 8vw 0 0;
}

.cv .inner{
	padding: 0 3vw;
}

.cv ul{
	margin: 0 0 0;
}

.cv ul li{
	margin: 4vw 0 0;
	font-size: 0;
}

.cv ul li a{
	padding: 2.5vw 3vw 2vw;
	display: block;
	border-radius: 10px;
	background: #00B900;
	box-shadow: 0 5px 0 #037802;
}

.cv ul li:nth-child(2) a{
	background: #A4988C;
	box-shadow: 0 5px 0 #90847C;
}

.cv ul li a .icon{
	display: inline-block;
	vertical-align: middle;
	box-sizing: border-box;
	width: 15%;
	line-height: 0;
	text-align: center;
}

.cv ul li:nth-child(2) a .icon img{
	width: 80%;
}

.cv ul li a .text_box{
	padding: 0 0 0 1vw;
	display: inline-block;
	vertical-align: middle;
	box-sizing: border-box;
	width: 85%;
	font-size: 4vw;
	text-align: center;
}

.cv ul li a .text_box span{
	display: block;
	color: #fff;
	line-height: 1;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif;
}

.cv ul li:nth-child(1) a .text_box span{
	font-size: 6vw;
}

.cv ul li:nth-child(2) a .text_box span{
	font-size: 4vw;
}

.cv ul li:nth-child(2) a .text_box .no{
	margin: 1vw 0 0;
	font-size: 10vw;
}

.cv p{
	margin: 8vw 0 0;
	font-size: 3.2vw;
	text-align: center;
}
.line_btn {
	text-align: center;
}
/* **************************************************************** */
/* sec02こんな悩み
*/
.sec02 {
		background: #fff;
}
.sec02_bloc {
		padding: 3em 0 2em;
    background: #fff;
}
.sec02_bloc h3 {
	font-size: 30px;
		margin-bottom:1em;
}
.sec02_bloc ul {
		width: 95%;
    font-size: 25px;
    line-height: 1.4em;
    color: #c91a34;
    font-weight: bold;
    
	margin: 0 auto;
}
.sec02_bloc ul li {
    text-align: left;
    position: relative;
	color: #c91a34;
    padding-left: 2em;
    padding-bottom: 0.4em;
    border-bottom: solid 1px #aaaaaa;
	margin: 0 auto;
}
.sec02_bloc ul li + li {
		margin-top: 0.5em;
}
.sec02_bloc ul li:before {
		content: "";
    width: 37px;
    height: 37px;
    display: block;
    background: url(../images/icon_check02.png);
    position: absolute;
    left: 0;
    top: 50%;
    margin-top: -24px;
}
@media screen and (max-width : 768px){
	.sec02 {
		background: #fff;
}
.sec02_bloc {
		padding: 3em 0 2em;
}
.sec02_bloc h3 {
	font-size: 20px;
		margin-bottom:1em;
}
.sec02_bloc ul {
		width: 95%;
    font-size: 15px;
    line-height: 1.4em;
    color: #c91a34;
    font-weight: bold;
    
	margin: 0 auto;
}
.sec02_bloc ul li {
    text-align: left;
    position: relative;
	color: #c91a34;
    padding-left: 42px;
    padding-bottom: 0.4em;
    border-bottom: solid 1px #aaaaaa;
	margin: 0 auto;
}
.sec02_bloc ul li + li {
		margin-top: 0.5em;
}
.sec02_bloc ul li:before {
		content: "";
    width: 37px;
    height: 37px;
    display: block;
    background: url(../images/icon_check02.png);
    position: absolute;
    left: 0;
    top: 50%;
    margin-top: -24px;
}
}
/* combination
   ========================================================================== */
.combination{
	margin: 8vw 0 0;
}

.combination h2{
	padding: 0 ;
	line-height: 0;
	text-align: center;
}
.combination h2 img{
	width: 100%;
}
.combination .experience .inner{
	padding-top: 46px;
}

.combination .experience h2{
	padding: 0;
	box-sizing: border-box;
	min-height: 15vw;
	display: flex;
	justify-content: center;
	align-items: center;
}

.combination .experience h2 span img{
	width: 95%;
}


/* premium4
   ========================================================================== */
.premium4{
	margin: 8vw 0 0;
}

.premium4 .inner{
	padding: 0 3vw;
}

.premium4 h2{
	margin: 0 0 0;
	line-height: 0;
	text-align: center;
}

.premium4 ul{
	margin: 0 0 0;
}

.premium4 ul li{
	margin: 6vw 0 0;
}

.premium4 ul li:first-child{
	margin-top: 0;
}

.premium4 ul li .photo{
	margin: 0 0 0;
	line-height: 0;
	position: relative;
	text-align: center;
}

.premium4 ul li .photo img{
	width: 70%;
}

.premium4 ul li .text_box{
	margin: 4vw 0 0;
}

.premium4 ul li:nth-child(2n+2) .text_box{
	text-align: right;
}

.premium4 ul li .text_box h3{
	line-height: 0;
}

.premium4 ul li .text_box h3 img{
	width: 100%;
}

.premium4 ul li .text_box h4{
	margin: 5vw 0 0;
	font-size: 4vw;
	line-height: 150%;
	color: #C4437B;
	display: inline-block;
}

.premium4 ul li .text_box p{
	margin: 5vw 0 0;
	font-size: 3.5vw;
	line-height: 150%;
	text-align: left;
}

.premium4 ul li .arrow{
	display: none;;
}

.premium4 ul li .text_box .pc{
	display: none;
}


/* decided
   ========================================================================== */
.decided{
	margin: 3vw 0 0;
	line-height: 0;
	text-align: center;
}


/* suggestion
   ========================================================================== */
.suggestion{
	margin: 8vw 0 10vw;
}

.suggestion .inner{
	padding: 0 3vw;
}

.suggestion h2{
	margin: 0 0 0;
	line-height: 0;
	text-align: center;
}

.suggestion h2 img{
	width: 80%;
}

.suggestion ul{
	margin: 10vw 0 0;
	text-align: center;
}

.suggestion ul li{
	margin: 10vw 0 0;
}

.suggestion ul li:first-child{
	margin-top: 0;
}

.suggestion ul li h3{
	margin: 0 0 0;
	line-height: 0;
}

.suggestion ul li h3 img{
	width: 80%;
}

.suggestion ul li .text_box{
	margin: 3vw 0 0;
	line-height: 0;
}


/* discount
   ========================================================================== */
.discount{
	margin: 3vw 0 0;
	line-height: 0;
	text-align: center;
}


/* merit
   ========================================================================== */
.merit{
	margin: 3vw 0 0;
}

.merit .top_bg{
	line-height: 0;
	text-align: center;
	position: relative;
}

.merit h2{
	line-height: 0;
	text-align: center;
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	top: 1vw;
}

.merit h2 span{
	line-height: 0;
	display: inline-block;
	position: relative;
	width: 90%;
}

.merit .main{
	padding: 0 0 4vw;
	background: url("../images/common/bg02.jpg") repeat;
	background-size: 15%;
	text-align: center;
}

.merit .main img{
	margin: -5vw auto 0;
	width: 95%;
	position: relative;
}


/* feedback4set
   ========================================================================== */
.feedback4set{
	margin: 10vw auto 0;
	width: 95%;
	line-height: 0;
	text-align: center;
}


/* essential
   ========================================================================== */
.essential{
	margin: 8vw 0 0;
}

.essential .inner{
	padding: 0 3vw;
}

.essential h2{
	margin: 0 0 0;
	line-height: 0;
	text-align: center;
}

.essential h2 img{
	width: 70%;
}

.essential ul{
	margin: 10vw 0 0;
}

.essential ul li{
	margin: 6vw 0 0;
}

.essential ul li:first-child{
	margin-top: 0;
}

.essential ul li .photo{
	margin: 0 0 0;
	line-height: 0;
	position: relative;
	text-align: center;
}

.essential ul li .photo img{
	width: 90%;
}

.essential ul li .text_box{
	margin: 0 0 0;
	padding: 2vw 0 0;
}

.essential ul li:nth-child(2) .text_box{
	margin-top: -5vw;
}

.essential ul li .text_box h3{
	font-size: 4.5vw;
	line-height: 150%;
}

.essential ul li .text_box p{
	margin: 3vw 0 0;
	font-size: 3.5vw;
	line-height: 150%;
	text-align: left;
}

.essential .bottom_text{
	margin: 6vw 0 0;
	line-height: 0;
	text-align: center;
}

.essential .bottom_text img{
	width: 95%;
}

.essential ul li .text_box .pc{
	display: none;
}


/* instagram
   ========================================================================== */
.instagram{
	margin: 0 auto 0;
	width: 98%;
	line-height: 0;
	text-align: center;
}


/* age
   ========================================================================== */
.age{
	margin: 8vw 0 0;
}

.age .inner{
	padding: 0;
}

.age h2{
	margin: 0 0 0;
	line-height: 0;
	text-align: center;
}

.age h2 img{
	width: 90%;
}

.age .graph_block{
	margin: 4vw 1vw 0;
	text-align: center;
	font-size: 0;
}
	
.age .graph_block .graph{
	line-height: 0;
	display: inline-block;
	vertical-align: middle;
	box-sizing: border-box;
	width: 35%;
}

.age .graph_block .graph img{
	width: 100%;
}

.age .graph_block .text{
	margin: 4vw 0 0;
	line-height: 0;
	padding: 0 0 0 2vw;
	display: inline-block;
	vertical-align: middle;
	box-sizing: border-box;
	width: 65%;
}

.age .graph_block .text img{
	width: 100%;
}

.age .photo_list{
	margin: 10vw 0 0;
	text-align: center;
}

.age .photo_list h3{
	margin: 0 0 0;
	text-align: center;
}

.age .photo_list h3 img{
	width: 80%;
}

.age ul{
	margin: 4vw 0 0;
	font-size: 0;
}

.age ul li{
	margin: 0 0 0;
	display: inline-block;
	vertical-align: top;
	box-sizing: border-box;
	width: 50%;
	line-height: 0;
}


/* review
   ========================================================================== */
.review{
	margin: 8vw 0 0;
	padding: 2vw 0;
	box-sizing: border-box;
	background: #e5e5e5;
}

.review .scroll{
	box-sizing: border-box;
	height: 110vw;
	overflow-y: scroll;
}
.review .kuchikomi{
	width: 100%;
}
.review .kuchikomi img{
	width: 100%;
}

/* price
   ========================================================================== */
.price{
	width: 100%
}
.price img{
	width: 100%
}

/* shop_info
   ========================================================================== */
.shop_info{
	margin: 8vw 0;
}

.shop_info .inner{
	padding: 0;
}

.shop_info h2{
	margin: 0 0 8vw;
	line-height: 0;
	text-align: center;
}

.shop_info h2 img{
	width: 80%;
}

.shop_info .box{
	margin: 4vw 0 0;
	padding: 0 3vw;
	text-align: center;
}

.box_title{
	margin: 0 0 4vw;
	text-align: center;
	position: relative;
}

.box_title::after{
	content: "";
	background: #231815;
	width: 100%;
	height: 1px;
	position: absolute;
	margin: auto;
	top: 0;
	bottom: 0;
	left: 0;
}

.box_title span{
	padding: 0 2vw;
	background: #fff;
	display: inline-block;
	font-size: 3.5vw;
	line-height: 150%;
	color: #231815;
	font-weight: bold;
	position: relative;
	z-index: 1;
}

.shop_info .box p{
	font-size: 3.2vw;
	line-height: 150%;
	color: #231815;
	font-weight: bold;
}

.shop_info .box.infomation p{
	text-align: center;
}

.shop_info .box p .pink{
	color: #C4437B;
}

.shop_info .box .map{
	margin: 4vw 0 0;
	line-height: 0;
}

.shop_info .box .map iframe{
	width: 100%;
	height: 50vw;
}

.shop_info .box .text_photo{
	margin: 0 0 6vw;
	line-height: 0;
}

.shop_info .pc{
	display: none;
}


/* footer
   ========================================================================== */
footer{
	margin: 12vw 0 0;
}

footer .photo{
	text-align: center;
	line-height: 0;
}

footer .logo{
	margin: 8vw 0 0;
	text-align: center;
	line-height: 0;
}

footer .logo a{
	display: inline-block;
}

footer .logo a img{
	width: 60%;
}

footer .add{
	margin: 8vw 0 0;
	padding: 0 3vw;
	text-align: center;
	font-size: 2.5vw;
}

footer #page-top{
	margin: 8vw 0  0;
	text-align: center;
	border-top: 2px solid #E978AD;
}

footer #page-top a{
	padding: 3vw 3vw;
	display: block;
	text-align: center;
	font-size: 3.5vw;
	letter-spacing: 0.10em;
}

footer address{
	font-size: 4vw;
	background: #E978AD;
	color: #FFF;
	padding: 5vw 2vw;
	text-align: center;
}


/* support_decision01
   ========================================================================== */
.support_decision01{
	margin: 5vw 0 8vw;
}

.support_decision01 .bg{
	position: relative;
}

.support_decision01 .inner{
	padding: 0 3vw;
}

.support_decision01 .photo{
	margin: auto;
	line-height: 0;
	width: 50%;
	position: relative;
}

.support_decision01 .photo::after{
	content: "";
	background: #F8F7F5;
	width: 1000%;
	height: 30vw;
	position: absolute;
	margin: auto;
	top: 0;
	bottom: 0;
	left: -100%;
	z-index: -1;
}

.support_decision01 .text{
	margin: 4vw auto 0;
	line-height: 0;
	width: 100%;
}


/* support_decision02
   ========================================================================== */
.support_decision02{
	margin: 5vw 0 10vw;
}

.support_decision02 .bg{
	position: relative;
}

.support_decision02 .inner{
	padding: 0 3vw;
}

.support_decision02 .photo{
	margin: auto;
	line-height: 0;
	width: 70%;
	position: relative;
}

.support_decision02 .photo::after{
	content: "";
	background: #e2a121;
	width: 1000%;
	height: 30vw;
	position: absolute;
	margin: auto;
	top: 0;
	bottom: 0;
	left: -100%;
	z-index: -1;
}

.support_decision02 .text{
	margin: 4vw auto 0;
}

.support_decision02 .text p.big_text{
	margin: 2vw 0 0;
	font-size: 4.3vw;
	font-weight: bold;
	color: #c4437b;
}


@media screen and (min-width : 500px){


	/* header
	   ========================================================================== */
	header h1{
		padding: 10px;
		font-size: 10px;
	}
	
	header h1 .sp{
		display: none;
	}
	
	
	/* main_view
	   ========================================================================== */
	.main_view{
		position: relative;
	}
	/* premium4
	   ========================================================================== */
	.premium4{
		margin: 8vw 0 0;
	}
	
	.premium4 .inner{
		padding: 0 3vw;
	}
	
	.premium4 h2{
		margin: 0 0 0;
		line-height: 0;
		text-align: center;
	}
	
	.premium4 ul{
		margin: 0 0 0;
	}
	
	.premium4 ul li{
		margin: 6vw 0 0;
	}
	
	.premium4 ul li:first-child{
		margin-top: 0;
	}
	
	.premium4 ul li .photo{
		margin: 0 0 -25vw;
		line-height: 0;
		position: relative;
		text-align: left;
	}
	
	.premium4 ul li:nth-child(2n+1) .photo{
		text-align: right;
	}
	
	.premium4 ul li .photo img{
		width: 45%;
	}
	
	.premium4 ul li .text_box{
		margin: 0 0 0;
	}
	
	.premium4 ul li:nth-child(2n+2) .text_box{
		text-align: right;
	}
	
	.premium4 ul li .text_box h3{
		line-height: 0;
	}
	
	.premium4 ul li .text_box h3 img{
		width: 100%;
	}
	
	.premium4 ul li .text_box h4{
		margin: 5vw 0 0;
		font-size: 4vw;
		line-height: 150%;
		color: #C4437B;
		width: 54%;
		display: inline-block;
	}
	
	.premium4 ul li .text_box p{
		margin: 5vw 0 0;
		font-size: 3.5vw;
		line-height: 150%;
		text-align: left;
	}
	
	.premium4 ul li .arrow{
		margin: 5vw 0 0;
		line-height: 0;
		text-align: center;
		display: block;
	}
	
	.premium4 ul li .arrow img{
		width: 30%;
	}
	
	.premium4 ul li .text_box .pc{
		display: none;
	}
	

	/* suggestion
	   ========================================================================== */
	.suggestion{
		margin: 25px 0 50px;
	}
	
	.suggestion .inner{
		padding: 0 20px;
	}
	
	.suggestion h2{
		margin: 0 0 0;
		line-height: 0;
		text-align: center;
	}
	
	.suggestion h2 img{
		width: 50%;
	}
	
	.suggestion ul{
		margin: 30px 0 0;
		text-align: center;
	}
	
	.suggestion ul li{
		margin: 20px 0 0;
		font-size: 0;
	}
	
	.suggestion ul li h3{
		margin: 0 0 0;
		display: inline-block;
		vertical-align: top;
		box-sizing: border-box;
		width: 43%;
	}
	
	.suggestion ul li h3 img{
		width: auto;
	}
	
	.suggestion ul li .text_box{
		margin: 10px 0 0;
		padding-left: 20px;
		display: inline-block;
		vertical-align: top;
		box-sizing: border-box;
		width: 57%;
	}
 

	/* discount
	   ========================================================================== */
	.discount{
		margin: 20px 0 0;
	}


	/* merit
	   ========================================================================== */
	.merit{
		margin: 15px 0 0;
	}

	.merit .top_bg{
		line-height: 0;
		text-align: center;
		position: relative;
	}
	
	.merit h2{
		line-height: 0;
		text-align: center;
		position: absolute;
		margin: auto;
		left: 0;
		right: 0;
		top: 1vw;
	}
	
	.merit h2 span{
		line-height: 0;
		display: inline-block;
		position: relative;
		width: 80%;
	}
	
	.merit h2 span::before,
	.merit h2 span::after{
		content: "";
		background: url("../images/merit/border.png") repeat-x left center;
		background-size: 30%;
		width: 100%;
		height: 100%;
		position: absolute;
		margin: auto;
		top: 0;
		bottom: 0;
	}
	
	.merit h2 span::before{
		left: 103%;
	}
	
	.merit h2 span::after{
		right: 101%;
	}
	
	.merit .main{
		padding: 0 0 4vw;
		background: url("../images/common/bg02.jpg") repeat;
		background-size: 15%;
		text-align: center;
	}
	
	.merit .main img{
		margin: -10vw auto 0;
		width: 95%;
		position: relative;
	}
	

	/* feedback4set
	   ========================================================================== */
	.feedback4set{
		margin: 70px auto 0;
		width: 95%;
	}


	/* essential
	   ========================================================================== */
	.essential{
		margin: 8vw 0 0;
	}


	/* instagram
	   ========================================================================== */
	.instagram{
		margin: 0 auto 0;
	}


	/* age
	   ========================================================================== */
	.age{
		margin: 30px 0 0;
	}
	
	.age .inner{
		padding: 0;
	}
	
	.age h2 img{
		width: 90%;
	}
	
	.age .graph_block{
		margin: 35px 0 0;
		padding: 20px;
		font-size: 0;
	}
	
	.age .graph_block .graph{
		display: inline-block;
		vertical-align: middle;
		box-sizing: border-box;
		width: 35%;
	}
	
	.age .graph_block .graph img{
		width: 100%;
	}
	
	.age .graph_block .text{
		margin: 0 0 0;
		padding: 0 0 0 20px;
		display: inline-block;
		vertical-align: middle;
		box-sizing: border-box;
		width: 65%;
	}
	
	.age .graph_block .text img{
		width: 100%;
	}
	
	.age .photo_list{
		margin: 40px 0 0;
		text-align: center;
	}
	
	.age .photo_list h3 img{
		width: 80%;
	}
	
	.age ul{
		margin: 15px 0 0;
		font-size: 0;
	}
	
	.age ul li{
		width: calc(100%/3);
	}


	/* review
	   ========================================================================== */
	.review{
		margin: 4vw 0 0;
		padding: 2vw 0;
	}
	
	.review .scroll{
		height: 50vw;
	}
	

	/* shop_info
	   ========================================================================== */
	.shop_info{
		margin: 8vw 0;
	}
	
	.shop_info h2{
		margin: 0 0 8vw;
	}
	
	.shop_info h2 img{
		width: 60%;
	}
	
	.shop_info .box{
		margin: 4vw 0 0;
		padding: 0 3vw;
	}
	
	.box_title{
		margin: 0 0 4vw;
	}
	
	.box_title span{
		padding: 0 2vw;
		font-size: 3.5vw;
	}
	
	.shop_info .box p{
		font-size: 3vw;
	}
	
	.shop_info .box.infomation p{
		text-align: center;
	}
	
	.shop_info .box .map{
		margin: 4vw 0 0;
	}
	
	.shop_info .box .map iframe{
		width: 100%;
		height: 30vw;
	}
	
	.shop_info .box .text_photo{
		margin: 0 0 7vw;
		line-height: 0;
	}
	
	.shop_info .pc{
		display: none;
	}


	/* footer
	   ========================================================================== */
	footer{
		margin: 80px 0 0;
	}
	
	footer .logo{
		margin: 60px 0 0;
	}
	
	footer .logo a img{
		width: 50%;
	}
	
	footer .add{
		margin: 35px 0 0;
		padding: 0 20px;
		font-size: 18px;
	}
	
	footer .add .sp{
		display: none;
	}
	
	footer #page-top{
		margin: 40px 0  0;
	}
	
	footer #page-top a{
		padding: 20px 20px;
		font-size: 20px;
	}
	
	footer address{
		font-size: 14px;
		padding: 20px 20px;
	}


	/* support_decision01
	   ========================================================================== */
	.support_decision01{
		margin: 5vw 0 8vw;
	}
	
	.support_decision01 .bg{
		position: relative;
	}
	
	.support_decision01 .bg::after{
		content: "";
		background: #F8F7F5;
		width: 100%;
		height: 20vw;
		position: absolute;
		margin: auto;
		top: 0;
		bottom: 0;
		left: 0;
		z-index: -1;
	}
	
	.support_decision01 .inner{
		padding: 0 3vw;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	
	.support_decision01 .photo{
		width: 30%;
	}
	
	.support_decision01 .photo::after{
		display: none;
	}
	
	.support_decision01 .text{
		margin: 0 auto 0;
		padding-left: 4vw;
		width: 70%;
	}
	
	
	/* support_decision02
	   ========================================================================== */
	.support_decision02{
		margin: 5vw 0 0;
	}
	
	.support_decision02 .bg{
		position: relative;
	}
	
	.support_decision02 .bg::after{
		content: "";
		background: #F8F7F5;
		width: 100%;
		height: 25vw;
		position: absolute;
		margin: auto;
		top: 0;
		bottom: 0;
		left: 0;
		z-index: -1;
	}
	
	.support_decision02 .inner{
		padding: 0 3vw !important;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	
	.support_decision02 .photo{
		width: 40%;
	}
	
	.support_decision02 .photo::after{
		display: none;
	}
	
	.support_decision02 .text{
		margin: 0 auto 0;
		padding-left: 4vw;
		width: 60%;
	}
	
	.support_decision02 .text p{
		font-size: 2.3vw;
	}
	
	.support_decision02 .text p.big_text{
		margin: 2vw 0 0;
		font-size: 2.5vw;
	}
	    

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


	/* experience
	   ========================================================================== */
	.experience{
		background-size: auto;
	}
	
	.experience h2{
		padding: 0 20px;
		height: 80px;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.experience h2::after{
		border-width: 37px 59px 0 59px;
	}
	
	.experience .inner{
		padding: 40px 20px 42px;
	}


	/* cv
	   ========================================================================== */
	.cv{
		margin: 50px 0 0;
	}
	
	.cv .inner{
		padding: 0 20px;
	}
	
	.cv ul{
		margin: 0 0 0;
		font-size: 0;
	}
	
	.cv ul li{
		margin: 0 0 0;
		display: inline-block;
		vertical-align: top;
		box-sizing: border-box;
		width: 48%;
	}
	
	.cv ul li:nth-child(1){
		margin-right: 4%;
	}
	
	.cv ul li a{
		padding: 28px 15px 20px;
		box-sizing: border-box;
		height: 98px;
	}
	
	.cv ul li:nth-child(2) a{
		padding-top: 20px;
	}
	
	.cv ul li a .icon{
		width: 15%;
	}
	
	.cv ul li:nth-child(2) a .icon img{
		width: 80%;
	}
	
	.cv ul li a .text_box{
		padding: 0 0 0 10px;
		width: 85%;
	}
	
	.cv ul li:nth-child(1) a .text_box span{
		font-size: 23px;
	}
	
	.cv ul li:nth-child(2) a .text_box span{
		font-size: 18px;
	}
	
	.cv ul li:nth-child(2) a .text_box .no{
		margin: 5px 0 0;
		font-size: 40px;
	}
	
	.cv p{
		margin: 30px 0 0;
		font-size: 20px;
	}
	
	.cv p .sp{
		display: block;
	}


	/* combination
	   ========================================================================== */
	.combination{
		margin: 50px 0 0;
	}

	.combination h2{
		padding: 0;
	}

	.combination .experience h2{
		min-height: 80px;
	}

	.combination .experience h2 span img{
		width: 70%;
	}

	.combination .experience .inner{
		padding-top: 46px;
	}

	.combination .experience .inner img{
		width: 80%;
	}


	/* premium4
	   ========================================================================== */
	.premium4{
		margin: 47px 0 0;
	}
	
	.premium4 .inner{
		padding: 0 20px;
	}

	.premium4 h2 img{
		width: 70%;
	}
	
	.premium4 ul{
		margin: 20px 0 0;
	}
	
	.premium4 ul li{
		margin: 0 0 0;
	}
	
	.premium4 ul li .photo{
		margin: 0 0 -190px;
	}
	
	.premium4 ul li .photo img{
		width: 33%;
	}
	
	.premium4 ul li .text_box{
		margin: 0 0 0;
	}
	
	.premium4 ul li .text_box h3 img{
		width: 70%;
	}
	
	.premium4 ul li .text_box h4{
		margin: 15px 0 0;
		font-size: 20px;
		width: 70%;
	}
	
	.premium4 ul li .text_box p{
		margin: 15px 0 0;
		font-size: 18px;
		text-align: inherit;
	}
	
	.premium4 ul li .arrow{
		margin: 30px 0 -40px;
	}
	
	.premium4 ul li .arrow img{
		width: 20%;
	}
	
	.premium4 ul li .text_box .pc{
		display: block;
	}


	/* decided
	   ========================================================================== */
	.decided{
		margin: 10px 0 0;
	}


	/* suggestion
	   ========================================================================== */
	.suggestion{
		margin: 25px 0 50px;
	}
	
	.suggestion .inner{
		padding: 0 20px;
	}
	
	.suggestion h2{
		margin: 0 0 0;
	}
	
	.suggestion h2 img{
		width: 40%;
	}
	
	.suggestion ul{
		margin: 50px 0 0;
	}
	
	.suggestion ul li{
		margin: 40px 0 0;
	}
	
	.suggestion ul li h3{
		margin: 0 0 0;
		width: 43%;
	}
	
	.suggestion ul li .text_box{
		margin: 10px 0 0;
		padding-left: 20px;
		width: 57%;
	}
 

	/* discount
	   ========================================================================== */
	.discount{
		margin: 20px 0 0;
	}


	/* merit
	   ========================================================================== */
	.merit{
		margin: 15px 0 0;
	}


	/* feedback4set
	   ========================================================================== */
	.feedback4set{
		margin: 70px auto 0;
	}


	/* essential
	   ========================================================================== */
	.essential{
		margin: 50px 0 40px;
	}
	
	.essential .inner{
		padding: 0;
	}
	
	.essential h2 img{
		width: 50%;
	}
	
	.essential ul{
		margin: 100px 0 0;
	}
	
	.essential ul li{
		margin: 90px 0 0;
		position: relative;
	}
	
	.essential ul li:nth-child(2n+1){
		padding-left: 33%;
	}
	
	.essential ul li:nth-child(2n+2){
		padding-right: 34%;
	}
	
	.essential ul li .photo{
		position: absolute;
		top: -35px;
		text-align: left;
	}

	.essential ul li:nth-child(2n+2) .photo{
		text-align: right;
	}
	
	.essential ul li:nth-child(2n+1) .photo{
		left: 0;
	}
	
	.essential ul li:nth-child(2n+2) .photo{
		right: 0;
	}
	
	.essential ul li .photo img{
		width: 60%;
	}
	
	.essential ul li .text_box{
		margin: 0 0 0;
		padding: 10px 10px 10px 110px;
		background: url("../images/essential/no01.png") no-repeat left top;
		background-size: 90px;
	}
	
	.essential ul li:nth-child(2) .text_box{
		margin-top: -50px;
		background: url("../images/essential/no02.png") no-repeat left top;
		background-size: 90px;
	}
	
	.essential ul li:nth-child(3) .text_box{
		background: url("../images/essential/no03.png") no-repeat left top;
		background-size: 90px;
	}
	
	.essential ul li:nth-child(4) .text_box{
		background: url("../images/essential/no04.png") no-repeat left top;
		background-size: 90px;
	}
	
	.essential ul li .text_box h3{
		font-size: 24px;
	}
	
	.essential ul li .text_box p{
		margin: 5px 0 0;
		font-size: 20px;
	}
	
	.essential .bottom_text{
		margin: 45px 0 0;
	}
	
	.essential .bottom_text img{
		width: 95%;
	}
	
	.essential ul li .text_box .pc{
		display: block;
	}


	/* instagram
	   ========================================================================== */
	.instagram{
		margin: 0 auto 0;
	}


	/* age
	   ========================================================================== */
	.age{
		margin: 30px 0 0;
	}


	/* review
	   ========================================================================== */
	.review{
		margin: 30px auto 0;
		padding: 15px 0;
		width: 78%;
	}
	
	.review .scroll{
		height: 700px;
	}


	/* shop_info
	   ========================================================================== */
	.shop_info{
		margin: 40px 0 50px;
	}
	
	.shop_info h2{
		margin: 0 0 55px;
	}
	
	.shop_info h2 img{
		width: 60%;
	}
	
	.shop_info .box{
		margin: 50px 0 0;
		padding: 0 20px;
	}
	
	.box_title{
		margin: 0 0 30px;
	}
	
	.box_title span{
		padding: 0 20px;
		font-size: 20px;
	}
	
	.shop_info .box p{
		font-size: 18px;
	}
	
	.shop_info .box.infomation p .sp{
		display: block;
	}
	
	.shop_info .box .map{
		margin: 45px 0 0;
	}
	
	.shop_info .box .map iframe{
		width: 100%;
		height: 300px;
	}
	
	.shop_info .box .text_photo{
		margin: 0 0 45px;
	}
	
	.shop_info .pc{
		display: none;
	}
	
	.shop_info .text_photo .pc{
		display: inline-block;
	}
    

}
@media screen and (min-width : 769px){


	/* cv
	   ========================================================================== */
	.cv ul li a{
		padding: 23px 15px 0;
	}
	
	.cv ul li:nth-child(1) a .text_box span{
		font-size: 3vw;
	}
	
	.cv ul li:nth-child(2) a .text_box span{
		font-size: 2vw;
	}
	
	.cv ul li:nth-child(2) a .text_box .no{
		margin: 5px 0 0;
		font-size: 5vw;
	}


}
@media screen and (min-width : 1025px){


	/* header
	   ========================================================================== */
	header{
		
	}
	
	header h1{
		padding: 9px 0;
		font-size: 18px;
	}
	
	header h1 .inner{
		display: block;
	}
	
	
	/* main_view
	   ========================================================================== */
	.main_view{
		position: relative;
	}
 

	/* experience
	   ========================================================================== */
	.experience{
		background-size: auto;
	}
	
	.experience h2{
		padding: 0;
	}
	
	.experience .inner{
		padding: 15px 0 42px;
	}
	
	.experience .inner img{
		margin-left: -15px;
	}


	/* cv
	   ========================================================================== */
	.cv{
		margin: 50px 0 0;
	}
	
	.cv .inner{
		padding: 0;
	}
	
	.cv ul{
		margin: 0 0 0;
		text-align: center;
	}
	
	.cv ul li{
		margin: 0 0 0;
		width: 545px;
	}
	
	.cv ul li:nth-child(1){
		margin-right: 37px;
	}
	
	.cv ul li a{
		padding: 18px 15px 20px;
		height: 98px;
	}
	
	.cv ul li:nth-child(2) a{
		padding-top: 11px;
	}
	
	.cv ul li a .icon{
		width: 13.5%;
	}
	
	.cv ul li:nth-child(2) a .icon img{
		width: 86.5% !important;
	}
	
	.cv ul li a .text_box{
		padding: 0 0 0 10px;
		width: 85%;
	}
	
	.cv ul li:nth-child(1) a .text_box span{
		font-size: 37px;
	}
	
	.cv ul li:nth-child(2) a .text_box span{
		font-size: 22px;
	}
	
	.cv ul li:nth-child(2) a .text_box .no{
		margin: 2px 0 0;
		font-size: 58px;
	}
	
	.cv p{
		margin: 30px 0 0;
		text-align: center;
		line-height: 200%;
	}
	
	.cv p .sp{
		display: none;
	}


	/* premium4
	   ========================================================================== */
	.premium4{
		margin: 47px 0 0;
	}
	
	.premium4 .inner{
		padding: 0 20px;
	}
	
	.premium4 ul{
		margin: 20px 0 0;
	}
	
	.premium4 ul li{
		margin: 0 0 0;
	}
	
	.premium4 ul li .photo{
		margin: 0 0 -350px;
	}
	
	.premium4 ul li .text_box{
		margin: 0 0 0;
	}
	
	.premium4 ul li .text_box h4{
		margin: 20px 0 0;
		font-size: 28px;
		width: 62%;
	}
	
	.premium4 ul li .text_box p{
		margin: 10px 0 0;
		font-size: 20px;
		line-height: 180%;
		text-align: inherit;
	}
	
	.premium4 ul li .arrow{
		margin: 30px 0 -40px;
	}
	
	.premium4 ul li:nth-child(2n+2) .arrow{
		margin-bottom: -20px;
	}


	/* decided
	   ========================================================================== */
	.decided{
		margin: 10px 0 0;
	}


	/* suggestion
	   ========================================================================== */
	.suggestion{
		margin: 25px 0 100px;
	}
	
	.suggestion .inner{
		padding: 0;
	}
	
	.suggestion h2{
		margin: 0 0 0;
	}
	
	.suggestion ul{
		margin: 50px auto 0;
		width: 1050px;
	}
	
	.suggestion ul li{
		margin: 40px 0 0;
	}
	
	.suggestion ul li h3{
		margin: 0 0 0;
		width: 42%;
		text-align: left;
	}
	
	.suggestion ul li .text_box{
		margin: 10px 0 0;
		padding-left: 19px;
		width: 58%;
		text-align: right;
	}
 

	/* discount
	   ========================================================================== */
	.discount{
		margin: 20px 0 0;
	}


	/* merit
	   ========================================================================== */
	.merit{
		margin: 15px 0 0;
	}
	
	.merit .top_bg{
		position: relative;
	}
	
	.merit h2{
		top: 8px;
	}
	
	.merit h2 span{
		width: auto;
	}
	
	.merit h2 span::before,
	.merit h2 span::after{
		background: url("../images/merit/border.png") repeat-x left center;
		background-size: auto;
	}
	
	.merit h2 span::before{
		left: 103%;
	}
	
	.merit h2 span::after{
		background: url("../images/merit/border.png") repeat-x right center;
		right: 101%;
	}
	
	.merit .main{
		padding: 0 0 35px;
		background: url("../images/common/bg02.jpg") repeat;
		background-size: auto;
	}
	
	.merit .main img{
		margin: -118px auto 0;
		width: auto;
	}


	/* feedback4set
	   ========================================================================== */
	.feedback4set{
		margin: 70px auto 0;
		width: 100%;
	}


	/* essential
	   ========================================================================== */
	.essential{
		margin: 50px 0 37px;
	}
	
	.essential .inner{
		padding: 0;
	}
	
	.essential ul{
		margin: 100px 0 0;
	}
	
	.essential ul li{
		margin: 90px 0 0;
		position: relative;
	}
	
	.essential ul li:nth-child(2n+1){
		padding-left: 33%;
	}
	
	.essential ul li:nth-child(2n+2){
		padding-right: 440px;
	}
	
	.essential ul li:nth-child(2){
		margin-top: 170px;
	}
	
	.essential ul li:nth-child(3){
		margin-top: 150px;
	}
	
	.essential ul li:nth-child(4){
		margin-top: 150px;
	}
	
	.essential ul li .photo{
		position: absolute;
		top: -55px;
	}
	
	.essential ul li:nth-child(2n+1) .photo{
		left: 0;
		top: -55px;
	}
	
	.essential ul li:nth-child(2n+2) .photo{
		right: 0;
	}
	
	.essential ul li:nth-child(2) .photo{
		top: -150px;
	}
	
	.essential ul li:nth-child(4) .photo{
		top: -100px;
	}
	
	.essential ul li .text_box{
		margin: 0 0 0;
		padding: 10px 10px 10px 150px;
		background-size: auto !important;
	}
	
	.essential ul li:nth-child(2) .text_box{
		margin-top: 0;
	}
	
	.essential ul li .text_box h3{
		font-size: 32px;
	}
	
	.essential ul li .text_box p{
		margin: 10px 0 0;
		font-size: 21px;
		line-height: 180%;
	}
	
	.essential .bottom_text{
		margin: 45px 0 0;
	}
 

	/* instagram
	   ========================================================================== */
	.instagram{
		margin: 0 auto 0;
		width: 100%;
	}


	/* age
	   ========================================================================== */
	.age{
		margin: 60px 0 0;
	}
	
	.age .inner{
		padding: 0;
	}
	
	.age .graph_block{
		margin: 35px 0 0;
		padding: 0 23px 0 58px;
		font-size: 0;
	}
	
	.age .graph_block .graph{
		width: 35%;
	}
	
	.age .graph_block .text{
		margin: 0 0 0;
		padding: 0 0 0 20px;
		width: 65%;
	}
	
	.age .photo_list{
		margin: 80px 0 0;
	}
	
	.age ul{
		margin: 30px 0 0;
	}


	/* shop_info
	   ========================================================================== */
	.shop_info{
		margin: 50px 0 90px;
	}
	
	.shop_info h2{
		margin: 0 0 55px;
	}
	
	.shop_info .box{
		margin: 50px 0 0;
		padding: 0;
	}
	
	.box_title{
		margin: 0 0 50px;
	}
	
	.box_title span{
		padding: 0 30px;
		font-size: 20px;
	}
	
	.shop_info .box p{
		font-size: 20px;
	}
	
	.shop_info .box.infomation p{
		text-align: center;
	}
	
	.shop_info .box.infomation p .sp{
		display: none;
	}
	
	.shop_info .box .map{
		margin: 50px 0 0;
	}
	
	.shop_info .box .map iframe{
		width: 964px;
		height: 500px;
	}
	
	.shop_info .box .text_photo{
		margin: 0 0 45px;
	}
	
	.shop_info .sp{
		display: none;
	}
	
	.shop_info .pc{
		display: block;
	}


	/* footer
	   ========================================================================== */
	footer{
		margin: 80px 0 0;
	}
	
	footer .logo{
		margin: 60px 0 0;
	}
	
	footer .add{
		margin: 35px 0 0;
		padding: 0;
	}
	
	footer #page-top{
		margin: 40px 0  0;
	}
	
	footer #page-top a{
		padding: 20px;
		font-size: 20px;
	}
	
	footer address{
		font-size: 16px;
		padding: 20px;
	}


	/* support_decision01
	   ========================================================================== */
	.support_decision01{
		margin: 30px 0 35px;
	}
	
	.support_decision01 .bg::after{
		height: 200px;
	}
	
	.support_decision01 .inner{
		padding: 0;
	}
	
	.support_decision01 .photo{
		margin: 0;
		width: auto;
	}
	
	.support_decision01 .text{
		margin: 0;
		padding-left: 30px;
		width: auto;
	}
	
	
	/* support_decision02
	   ========================================================================== */
	.support_decision02{
		margin: 15px 0 52px;
	}
	
	.support_decision02 .bg::after{
		height: 250px;
	}
	
	.support_decision02 .inner{
		padding: 0 !important;
	}
	
	.support_decision02 .photo{
		margin: 0;
		width: auto;
	}
	
	.support_decision02 .text{
		margin: 0 ;
		padding-left: 37px;
		width: auto;
	}
	
	.support_decision02 .text p{
		font-size: 18px;
	}
	
	.support_decision02 .text p.big_text{
		margin: 15px 0 0;
		font-size: 25px;
	}

	
}

/* company
*/
.company {
    background: #fff;
    padding: 4em 0;
}
.company h2 {
		font-size: 48px;
    line-height: 1em;
    margin-bottom: 1em;
}
.company table {
		width: 100%;
    border-bottom: solid 1px #000000;
}
.company table th {
		padding: 0.5em;
    text-align: left;
    width: 100%;
    display: block;
    box-sizing: border-box;
		background:#eeeeee;
		font-size:28px;
    border-top: solid 1px #000000;
    border-bottom: solid 1px #000000;
}
.company table td {
		padding: 0.5em;
    text-align: left;
    width: 100%;
    display: block;
    box-sizing: border-box;
		font-size:24px;
}
.company table tr {

}


/* **************************************************************** */
/* privacy
*/
.privacy {
    background: #fff;
    padding: 4em 0;
}
.privacy h2 {
		font-size: 48px;
    line-height: 1em;
    margin-bottom: 1em;
}

.privacy_bloc {
	
}
.privacy_bloc h3 {
    text-align: left;
    font-size: 18px;
}
.privacy_bloc p {
    text-align: left;
    font-size: 18px;
}
.privacy_bloc + .privacy_bloc {
		margin-top: 2em;
}
