@charset "utf-8";
/* smart.css */
/**********************************************
　共通 
**********************************************/
.pc{
	display: none;
}
.sp{
	display: block;
}
section > div.wrap {
	max-width: 1000px;
	width: 95%;
	margin: 0 auto;
}
a:hover{
	opacity: .8;
}
.note{
	margin-bottom: 10px;
}
.bnr{
	position: relative;
}
.bnr img{
	width: 100%;
}
.bnr a{
	position: absolute;
    bottom: 11%;
    right: inherit;
    left: calc( 50% - 260px );
    width: 520px;
}
.pagetop {
    display: none;
    position: fixed;
    bottom: 30px;
    right: 15px;
}
.pagetop a {
    display: block;
    background-color: #116242;
	height: 40px;
    width: 40px;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    text-align: center;
    color: #fff;
    font-size: 20px;
    text-decoration: none;
    padding: 30px;
	filter:alpha(opacity=80);
    -moz-opacity: 0.8;
    opacity: 0.8;
	display: flex;
    justify-content: center;
    align-items: center;
}
.pagetop a:hover {
    opacity: 0.5;
}
@media screen and (max-width: 660px){
	.bnr a{
        bottom: 7%;
	}
}
@media screen and (max-width: 590px){
	.bnr a{
		left: calc( 50% - 235px );
        width: 470px;
	}
}
@media screen and (max-width: 545px){
	.bnr a{
		    left: calc( 50% - 200px );
    width: 400px;
	}
}
@media screen and (max-width: 480px){
	.s_sp{
		display: block;
	}
	.bnr a{
		    left: calc( 50% - 190px );
    width: 380px;
	}
}
@media screen and (max-width: 440px){
	.bnr a{
        left: calc( 50% - 190px );
        width: 380px;
        bottom: 8%;
	}
}
@media screen and (max-width: 430px){
	.bnr a{
		left: calc( 50% - 160px );
        width: 320px;
        bottom: 8%;
	}
}
@media screen and (max-width: 370px){
	.bnr a{
		left: calc( 50% - 140px );
		width: 280px;
	}
}
/**********************************************
　メインビジュアル
**********************************************/
section.mv{
	background: url("../img/mv/sp_mv.jpg")no-repeat;
	background-position: bottom;
    background-size: contain;
	padding-bottom: 20%!important;
	position: relative;
}
section.mv div.wrap {
    position: inherit;
}
section.mv h1 img{
	width: 180px;
}
section.mv .upper{
	flex-flow: column-reverse;
	text-align: center;
}
section.mv .upper p:nth-of-type(1){
	width: 100%;
    font-size: 36px;
	margin-top: 20px;
}
section.mv .upper p:nth-of-type(1) span{
	font-size: 52px;
    letter-spacing: -3px;
}
section.mv .upper p:nth-of-type(2){
	width: 100%;
}
section.mv .upper img{
	width: 200px;
}
section.mv .under{
	margin: 0 auto;
    display: block;
}
section.mv .under img{
	width: 100%;
}
section.mv .under p{
	bottom: 0;
	left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
}
section.mv .under p a{
	font-size: 22px;
	padding: 3%;
	display: block;
	background: #fff;
}
section.mv ul{
	position: inherit;
	margin-top: 20px;
	width: 100%;
    left: inherit;
    bottom: 0;
    justify-content: center;
    flex-wrap: wrap;
}
section.mv ul li{
    width: 20vw;
    height: 20vw;
    margin-bottom: 15px;
    margin: 0 5px 15px 5px;
}

@media screen and (max-width: 480px){
	section.mv .upper p:nth-of-type(1){
		font-size: 27px;
	}
	section.mv .upper p:nth-of-type(1) span{
		font-size: 36px;
	}
	section.mv .under p a{
		font-size: 18px;
		padding: 7px;
	}
    section.mv ul{
        justify-content: center;
    }
	section.mv ul li{
        width: 20.5vw;
        height: 20.5vw;
        margin: 0 5px 10px 5px;
	}
	section.mv ul li:nth-child(5) img,
	section.mv ul li:nth-child(6) img{
		width: 88%;
	}
}
/**********************************************
　プレミアムプラン
**********************************************/
section.premium_plan{
	padding: 30px 0;
}
section.premium_plan .sub_title span{
	font-size: 20px;
	font-weight: 600;
	color: #116242;
}
section.premium_plan h2 {
	font-size: 27px;
	margin: 15px 0 30px 0;
}
section.premium_plan h2 span{
	font-size: 40px;
}
section.premium_plan div.wrap p img{
	width: 100%;
}
section.premium_plan div.wrap > div{
	padding: 10px 10px 30px 10px;
}
section.premium_plan div.wrap > div ul{
	flex-flow: column;
}
section.premium_plan div.wrap > div ul:after{
	content: none;
}
section.premium_plan div.wrap > div ul li{
	width: 100%;
}
section.premium_plan div.wrap > div ul li:nth-of-type(n+4){
	margin-bottom: 15px;
}
section.premium_plan div.wrap > div ul li:last-of-type{
	margin-bottom: 0;
	margin-top: 20px;
}
section.premium_plan div.wrap > div ul li p{
	font-size: 14px;
	font-weight: 600;
	line-height: 1.6;
    margin-top: 10px;
}
/**********************************************
　体験談
**********************************************/
section.experience{
    background: url(../img/experience/sp_bg_hand.jpg) no-repeat;
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top;
    background-color: #F1F7FA;
}
section.experience div.wrap{
	padding: 30px 0 0 0;
}
section.experience div.wrap .check{
	text-align: center;
}
section.experience div.wrap .check img{
	width: 45px;
}
section.experience .sub_title{
	font-size: 20px;
	line-height: 1.4;
    margin: 20px 0;
}
section.experience h2{
	font-size: 40px;
	margin-bottom: 30px;
}
section.experience .experience_box{
	padding: 20px 10px;
    margin: 0 auto 20px;
	flex-flow: column;
	width: auto;
}
section.experience .experience_box .text_wrap{
	width: 100%;
}
section.experience .experience_box .img_wrap{
	width: 100%;
	margin-left: 0;
	margin-top: 20px;
}
section.experience .experience_box .img_wrap img{
	width: 100%;
}
section.experience .experience_box .title01{
	font-size: 23px;
	padding-bottom: 5px;
    margin-bottom: 15px;
}
section.experience .experience_box .title02{
	font-size: 22px;
	margin-bottom: 15px;
}
section.experience .experience_box .title03{
	font-size: 16px;
	margin: 30px 0 10px 0;
}
section.experience .experience_box .text{
	font-size: 16px;
	line-height: 1.6;
}
section.experience .other_title{
	font-size: 28px;
	margin-top: 30px;
	line-height: 1.4;
}
section.experience ul{
	width: 100%;
	margin: 30px auto;
}
section.experience ul:after{
	content: "";
	display: block;
	width: 49%;
}
section.experience ul li{
	width: 49%;
	margin-bottom: 20px;
}
section.experience ul li:nth-of-type(n+5){
	margin-bottom: 20px;
}
section.experience ul li:nth-of-type(n+5){
	margin-bottom: 0;
}
section.experience ul li img{
	width: 100%;
}
@media screen and (max-width: 480px){
	section.experience .sub_title{
		font-size: 18px;
		line-height: 1.4;
		margin: 20px 0;
	}
	section.experience h2{
		font-size: 30px;
		margin-bottom: 20px;
	}
	section.experience .other_title{
		font-size: 22px;
	}
}
/**********************************************
　体験談
**********************************************/
section.elected div.wrap{
	padding: 30px 0;
}
section.elected div.wrap > p img{
	width: 200px;
}
section.elected div.wrap > p:nth-of-type(2){
	font-size: 25px;
	margin: 20px 0 15px 0;
}
section.elected div.wrap > p:nth-of-type(3){
	font-size: 30px;
	margin-bottom: 30px;
}
section.elected div.wrap dl{
	flex-flow: column;
    width: 100%;
	margin: 0 auto 15px;
}
section.elected div.wrap dl img{
	width:  100%;
}
/**********************************************
　プレミアムプランメニュー
**********************************************/
section.menu div.wrap{
	padding: 70px 0 35px 0;
}
section.menu div.wrap img{
	width: 100%;
}
section.menu div.wrap h2{
	font-size: 30px;
	margin-bottom: 40px;
	line-height: 1.3;
}
section.menu div.wrap h2 span{
	font-size: 42px;
}
section.menu div.wrap .menu_box .inner{
	padding: 20px 10px;
}
section.menu div.wrap .menu_box h3{
	font-size: 19px;
	line-height: 1.4;
	padding: 15px 10px;
}
section.menu div.wrap .menu_box .inner p:nth-of-type(1){
	font-size: 23px;
}
section.menu div.wrap .menu_box .inner p:nth-of-type(2){
	font-size: 40px;
	margin: 10px 0 25px 0;
}
section.menu div.wrap .menu_box .inner dl{
	width: 100%;
	margin-bottom: 25px;
	flex-wrap: wrap;
}
section.menu div.wrap .menu_box .inner dl dt{
	width: 100%;
    font-size: 18px;
    padding-left: 120px;
}
section.menu div.wrap .menu_box .inner dl dd{
	font-size: 14px;
	margin-left: 0;
	margin-top: 15px;
	line-height: 1.4;
	width: 100%;
}
section.menu div.wrap h4{
	font-size: 30px;
	margin-bottom: 20px;
}
section.menu div.wrap h4:after{
	width: 80%;
}
section.menu div.wrap h4 span{
	font-size: 25px;
}
section.menu .triangle {
    width: 100%;
    height: auto;
    border-left: 47vw solid transparent;
    border-right: 47vw solid transparent;
    border-top: 10vw solid #fff;
}
@media screen and (max-width: 480px){
	section.menu div.wrap h2{
		font-size: 20px;
		margin-bottom: 20px;
	}
	section.menu div.wrap h2 span{
		font-size: 30px;
	}
	section.menu div.wrap .menu_box .inner p:nth-of-type(1){
		font-size: 18px;
	}
	section.menu div.wrap .menu_box .inner p:nth-of-type(2){
		font-size: 28px;
		margin: 10px 0 25px 0;
	}
	section.menu div.wrap .menu_box .inner dl dt {
    	font-size: 16px;
		/*height: 55px;
        padding-left: 90px;*/
	}
	section.menu div.wrap .menu_box .inner dl dt:before {
		/*width: 90px;
		height: 55px;*/
	}
	section.menu div.wrap h4{
		font-size: 25px;
	}
	section.menu div.wrap h4 span{
		font-size: 20px;
	}
}
@media screen and (max-width: 350px){
	section.menu div.wrap .menu_box .inner dl dt {
    	font-size: 16px;
		/*height: 55px;*/
	}
}
/**********************************************
　こんな方におすすめ
**********************************************/
section.recommended{
	/*position: inherit;*/
}
section.recommended .wrap{
	padding: 60px 0 30px 0;
}
section.recommended .recommended_box{
	flex-flow: column;
	padding: 30px 20px 20px 20px;
}
section.recommended h2{
	font-size: 23px;
    padding: 0 20px;
    position: absolute;
    top: -13px;
    left: calc( 50% - 158px );
}
section.recommended .recommended_box ul li{
	font-size: 15px;
	margin-left: 34px;
}
section.recommended .recommended_box ul li:before{
	width: 24px;
	height: 24px;
	margin-left: -24px;
    background-size: contain;
}
section.recommended .recommended_box ul li{
	position: relative;
	padding-top: 7px;
}
section.recommended .recommended_box ul li:before{
	position: absolute;
	top: 6px;
	left: -10px;
}
section.recommended .recommended_box ul:nth-of-type(2) li:nth-child(2):before{
	top: 6px;
	left: -10px;
}
section.recommended .bnr{
	position: relative;
	margin-top: 30px;
	bottom: inherit;
}
@media screen and (max-width: 480px){
	section.recommended h2 {
		font-size: 19px;
		padding: 0 10px;
		position: absolute;
		top: -10px;
		left: calc( 50% - 124px );
	}
}
/**********************************************
　選ばれる理由
**********************************************/
section.reason .wrap{
	padding: 30px 0;
}
section.reason .title_wrap{
	flex-flow: column;
	margin-bottom: 20px;
}
section.reason .title_wrap p img{
	width: 200px;
}
section.reason .title_wrap h2{
	font-size: 37px;
    margin-left: 0;
    margin-top: 20px;
}
section.reason .reason_box .tab{
	left: 8px;
    width: 72px;
}
section.reason .reason_box .reason_text{
	display: none;
}
section.reason .teacher_box{
    padding: 20px 10px;
    flex-flow: column;
}
section.reason .teacher_box figure{
	width: 100%;
}
section.reason .teacher_box figure p{
	text-align: center;
}
section.reason .teacher_box > p{
	width: 100%;
	font-size: 15px;
	margin-top: 15px;
}
section.reason .teacher_box figcaption{
	margin-left: 0;
}
section.reason .teacher_box figcaption p:nth-of-type(1){
	font-size: 16px;
	margin: 10px auto 5px;
}
section.reason .teacher_box figcaption p:nth-of-type(2){
	font-size: 23px;
}
section.reason .teacher_box figcaption p:nth-of-type(2) span{
	font-size: 18px;
}
section.reason .detail_box .count_box{
	flex-flow: column;
    padding: 20px 10px;
}
section.reason .detail_box .count_box > p{
	width: 100%;
	text-align: center;
}
section.reason .detail_box .count_box > div{
	width: 100%;
}
section.reason .detail_box .count_box > div p:nth-of-type(1){
	margin: 15px 0;
}
section.reason .detail_box .count_box > div p:nth-of-type(1) img{
	width: 150px;
}
section.reason .detail_box .count_box > div p:nth-of-type(2){
	font-size: 25px;
    margin-bottom: 10px;
}
section.reason .detail_box .count_box > div p:nth-of-type(3){
	font-size: 16px;
	line-height: 1.4;
}
section.reason .bnr{
	position: relative;
	margin-top: 30px;
	bottom: inherit;
}
@media screen and (max-width: 480px){
	section.reason .title_wrap h2{
		font-size: 25px;
	}
	section.reason .detail_box .count_box > p img{
		width: 100%;
	}
}
/**********************************************
　プレミアムプラン気になる内容を大公開！
**********************************************/
section.flow .wrap{
	padding: 30px 0;
}
section.flow .title_wrap{
	flex-flow: column;
	text-align: center;
}
section.flow .title_wrap > p img{
	width: 200px;
}
section.flow .title_wrap > div span{
	font-size: 20px;
	margin: 20px 0 10px 0;
}
section.flow .title_wrap > div h2{
	font-size: 50px;
}
section.flow .title_wrap > div p{
	font-size: 42px;
}
section.flow .intro{
	margin: 10px auto 0;
}
section.flow .intro p{
	font-size: 18px;
}
section.flow .intro:after{
	content: "";
	background: url(../img/flow/arrow.svg) no-repeat;
	background-size: contain;
	width: 100%;
	/*height: 37px;*/
	display: block;
	margin: 25px auto 0;
}
section.flow .flow_wrap{
	width: 100%;
    margin: 20px auto 0;
	padding: 0 10px;
}
section.flow .flow_box{
	flex-flow: column;
	margin-bottom: 60px;
}
section.flow .flow_box:after{
	left: calc( 50% - 21px );
	bottom: -38px;
}
section.flow .flow_box:last-of-type:after{
	content: none;
}
section.flow .flow_box:last-of-type{
	margin-bottom: 0;
}
section.flow .flow_box > p{
	margin-left: 0;
    text-align: center;
}
section.flow .flow_box > p .icon{
	left: 0;
    top: -27px;
}
section.flow .flow_box > div{
	width: 100%;
	margin-top: 20px;
}
section.flow .flow_box > div p:nth-of-type(1){
	margin-bottom: 10px;
}
section.flow .flow_box > div p:nth-of-type(2){
	font-size: 22px;
	margin-bottom: 10px;
	font-weight: 600;
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "KozGoPro-Light", "小塚ゴシック Pro L", "メイリオ", Meiryo, sans-serif;
}
section.flow .flow_box > div p:nth-of-type(3){
	font-size: 16px;
	line-height: 1.6;
}
@media screen and (max-width: 480px){
	section.flow .title_wrap > p img{
		width: 150px;
	}
	section.flow .title_wrap > div span{
		font-size: 18px;
	}
	section.flow .title_wrap > div h2{
		font-size: 33px;
	}
	section.flow .title_wrap > div p{
		font-size: 25px;
	}
	section.flow .intro p {
		font-size: 16px;
	}
	section.flow .flow_box > div p:nth-of-type(2){
		font-size: 20px;
	}
}
/**********************************************
　満足のいく結果へ
**********************************************/
section.result .title_wrap{
	padding: 30px 10px;
}
section.result .title_wrap p{
	font-size: 20px;
	width: 100%;
    margin: 0 auto 20px;
}
section.result .title_wrap p span{
	font-size: 25px;
}
section.result .title_wrap h2{
	font-size: 30px;
	width: 100%;
}
section.result .triangle{
	width: 10vw;
    height: 5vw;
    border-left: 5vw solid transparent;
    border-right: 5vw solid transparent;
    border-top: 5vw solid #FCEBF3;
    position: absolute;
    bottom: -5vw;
    left: calc( 50% - 5vw );
}
section.result .wrap{
	padding: 20px 0 30px 0;
}
section.result .img_box{
	margin: 0 0 20px 0;
	text-align: center;
}
section.result .img_box img{
	width: 100%;
}
section.result h3{
	font-size: 24px;
    padding-bottom: 10px;
    margin: 0 auto 20px;
    width: auto;
}
section.result .sub_title{
	font-size: 18px;
    line-height: 1.4;
    width: auto;
    margin: 0 auto 20px;
}
section.result ul{
	flex-wrap: wrap;
	width: auto;
	margin: 0 auto 30px;
}
section.result ul li{
	width: 49%;
	font-size: 16px;
    padding: 20px 0;
	margin-bottom: 10px;
}
section.result ul li:nth-of-type(n+3){
	margin-bottom: 0;
}
@media screen and (max-width: 480px){
	section.result .title_wrap p{
		font-size: 18px;
		margin-bottom: 20px;
	}
	section.result .title_wrap p span{
		font-size: 23px;
	}
	section.result .title_wrap h2{
		font-size: 25px;
	}
}
/**********************************************
　各プランの料金
**********************************************/
section.price .wrap{
	padding: 30px 0;
}
section.price .wrap .title_wrap{
	text-align: center;
}
section.price .title_wrap h2{
	font-size: 30px;
	position: inherit;
	display: block;
	padding: 0;
}
section.price .title_wrap h2:before,
section.price .title_wrap h2:after {
	content: none;
}
section.price .intro{
	font-size: 16px;
	margin: 20px auto;
	width: auto;
}
section.price .price_wrap{
	display: flex;
	overflow-x: scroll;
}
section.price .price_box{
	width: 320px;
	margin-right: 20px;
}
section.price .price_box:last-of-type{
	margin-right: 0;
}
section.price .price_box h3{
	font-size: 29px;
    margin-bottom: 30px;
}
section.price .price_box p{
	font-size: 16px;
}
section.price .price_box ul li{
	font-size: 14px
}
section.price .bnr{
	position: relative;
	margin-top: 40px;
	bottom: inherit;
}
section.price .triangle{
	margin: 20px auto 0;
}
@media screen and (max-width: 480px){
	section.result .title_wrap p{
		font-size: 18px;
		margin-bottom: 20px;
	}
	section.result .title_wrap p span{
		font-size: 23px;
	}
	section.result .title_wrap h2{
		font-size: 25px;
	}
}
/**********************************************
　美容鍼ならではのアプローチ
**********************************************/
section.approach .wrap{
	padding: 50px 0;
}
section.approach .approach_box{
	padding: 30px 10px;
}
section.approach .approach_box .sub_title{
	font-size: 28px;
    padding: 0 20px;
    top: -16px;
    left: calc( 50% - 132px );
}
section.approach .approach_box h2{
	font-size: 36px;
	margin-bottom: 30px;
}
section.approach .sp_scrool{
	overflow-x: scroll;
}
@media screen and (max-width: 480px){
	section.approach .sp_scrool img{
		width: 170%;
	}
	section.approach .approach_box .sub_title{
		font-size: 22px;
		top: -12px;
		left: calc( 50% - 108px );
	}
	section.approach .approach_box h2{
		font-size: 26px;
	}
}
/**********************************************
　体験談2回目
**********************************************/
section.experience .no1 img{
	width: 200px;
}
section.experience h2.thanks{
	font-size: 34px;
    margin-top: 30px;
	line-height: 1.4;
}
@media screen and (max-width: 480px){
	section.experience h2.thanks{
		font-size: 24px;
		margin-top: 20px;
		text-shadow: 
		white 1px 1px 10px, white -1px 1px 10px,
		white 1px -1px 10px, white -1px -1px 10px;
	}
}
/**********************************************
　HaRickの紹介
**********************************************/
section.introduction .wrap{
	padding: 60px 0 30px 0;
	position: relative;
}
section.introduction .image_picture{
	position: absolute;
	bottom: 0;
	left: -25px;
	display: none;
}
section.introduction .sub_title{
	font-size: 20px;
    margin-bottom: 20px;
}
section.introduction .sub_title span {
    font-size: 27px;
}
section.introduction h2{
	font-size: 40px;
	margin-bottom: 30px;
}
section.introduction .introduction_box{
	width: 100%;
	padding: 20px 10px;
}
section.introduction .introduction_box p:nth-of-type(1){
	font-size: 38px;
	text-align: center;
}
section.introduction .introduction_box p:nth-of-type(2){
	width: auto;
	font-size: 20px;
	margin: 20px auto;
	text-align: center;
}
section.introduction .introduction_box p:nth-of-type(3){
	width: auto;
	font-size: 20px;
	margin: 0 auto 20px;
	text-align: center;
}
section.introduction .introduction_box p:nth-of-type(4){
	text-align: center;
}
section.introduction .logo img{
	width: 170px;
}

@media screen and (max-width: 480px){
	section.introduction .sub_title{
		font-size: 18px;
	}
	section.introduction .sub_title span {
		font-size: 23px;
	}
	section.introduction h2{
		font-size: 28px;
		margin-bottom: 20px;
	}
	section.introduction .introduction_box p:nth-of-type(1){
		font-size: 25px;
	}
	section.introduction .introduction_box p:nth-of-type(2){
		font-size: 18px;
	}
	section.introduction .introduction_box p:nth-of-type(3){
		font-size: 20px;
	}
	.s_sc{
		display: block;
	}
}





















