/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
@charset "UTF-8";
body {
	line-height: 2;
	font-size: 4vw;
	font-family: 'ヒラギノ角ゴシック','Hiragino Sans','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
	text-align: center;
	color: #716F71;
	font-weight: 200;
}
p{
	letter-spacing: 0.05em;
}

.pc-bl,
.pc-il {
	display: none;
}

/*-------------------*/
.inner,
.sp-inner {
	padding-left: 9.3vw;
	padding-right: 9.3vw;
}
em {
	font-style: normal;
	font-weight: bold;
}
img{
	width: 100%;
	height: auto;
	display: block;
}
.maxw {
	max-width: 640px;
	margin: 0 auto;
}
.effect {
    transition: 0.6s ease-in-out;
}

/* main ------------------------*/
/*----#gnav----*/
#gnav.inner {
    padding: 5vw;
}
#gnav ul li {
	float: left;
	box-sizing: border-box;
	border: 1px solid;
	background: #E1949A;
	width: 50%;
	height: 2.8em;
	line-height: 2.8em;
	text-align: center;
	color: #fff;
}
#gnav ul li a {
	display: block;
	color: #fff;
}
#gnav div {
    clear: both;
	border: 1px solid #fff;
	padding: 4vw 0;
}
/*----#scroll----*/
#scroll{
	background: url(../img/main-lesson-arrow.png) no-repeat top center /26px;
	font-size: 10px;
	padding-top: 43px;
	margin-bottom: 40px;
	font-weight: bold;
}
/*----#main-lesson----*/
#main-lesson{
	margin-bottom: 47px;
}
#lesson-drawing{
	width: 81.2vw;
	margin: 0 auto 23px;
	max-width: 522px;
}
#lesson-text{
	line-height: 1.87;
	text-align: left;
}
/*----#main-posture----*/
#main-posture{
	background-color: #E4A1A5;
	padding-top: 40px;
	padding-bottom: 45px;
	color: #fff;
	margin-bottom: 40px;
}
.posture-img{
	max-width: 640px;
	margin: 0 auto 28px;
}
#posture-title{
    width: 81.4vw;
	margin:10px auto 32px;
	max-width: 518px;
}
#posture-text-fi{
	width: 82.5vw;
	margin: 0 auto;
	margin-bottom: 20px;
	max-width: 530px;
}
#posture-text-se{
	text-align: left;
	line-height: 1.87;
	font-weight: 100;
}
/*----main-joint----*/
.h2{
	font-size: 6vw;
	letter-spacing: 0.1em;
	color: #DE8890;
	margin-bottom: 15px;
	font-family: 'Yu Mincho Light','YuMincho','Yu Mincho','游明朝体','ヒラギノ明朝 ProN','Hiragino Mincho ProN',sans-serif;
	font-weight: 200;
}
.h2 span{
	font-size: 16px;
	letter-spacing: 0.05em;
	margin-top: 10px;
	display: block;
}
.h2-content{
	line-height: 2.14;
	letter-spacing: 0.05em;
	text-align: left;
	margin-bottom: 30px;
}
.joint-img{
	max-width: 640px;
	margin: 0 auto 30px;
}
/*----main-distortion----*/
.distortion-img{
	margin: 50px auto;
	background-color: #E8AEB0;
}	
.distortion-img img{
	max-width: 640px;
	margin: 0 auto;
}
/*----main-Challenge----*/
#main-challenge{
	overflow: hidden;
}
#main-challenge-img{
	font-size: 0;
	margin-bottom:50px; 
}
#main-challenge-img p:nth-of-type(1),
#main-challenge-img p:nth-of-type(2){
	width: 40vw;
	display: inline-block;
	max-width: 320px;
}
/*main-profile*/
#main-profile{
	background: url(../img/profile_bg.jpg) no-repeat top center/100% 100%;
	padding-top:45px;
	padding-bottom: 45px;
}
.h3{
	font-size: 5vw;
	font-family: 'Amiri', serif;
	letter-spacing: 0.05em;
	margin-bottom: 22px;
	font-weight: 400;
}
#main-profile p:nth-of-type(1){
	max-width: 640px;
	margin: 0 auto;
}
#profile-name{
	font-family: 'Yu Mincho Light','YuMincho','Yu Mincho','游明朝体','ヒラギノ明朝 ProN','Hiragino Mincho ProN',sans-serif;
	letter-spacing: 0.05em;
	margin-bottom: 20px;
	margin-top: 20px;
	font-size: 6vw;
}
#profile-name span{
	font-size: 10px;
	display: block;
	margin-top: 8px;
}
#profile-content{
	letter-spacing: 0.05em;
	line-height: 1.87;
	text-align: left;
}
/*main-lessontp*/
.border{
	border: solid 1px #ABA4A3;
	padding: 20px;
}
#main-lessontp{
	max-width: 640px;
	margin: 0 auto 50px;
}
.lessontp-content-tlt{
	background-color: #ABA4A3;
	line-height: 40px;
	color: #fff;
	font-size: 16px;
	font-weight: 600;
}
.lessontp-content-desc{
	font-size: 12px;
	line-height: 24px;
	text-align:left;
	margin-bottom: 18px;
}
#lessontp-content-time{
	border: dashed 1px #ABA4A3;
	margin-bottom: 18px;
	padding: 16px 10px 11px;
}
#lessontp-content-time p:nth-of-type(1){
	font-weight: 600;
	margin-bottom: 10px;
}
#lessontp-content-time p:nth-of-type(1) span{
	color: #DE8890;
}
#lessontp-content-time p:nth-of-type(2),
#lessontp-content-time p:nth-of-type(3){
	font-size: 12px;
	margin-bottom: 5px;
}
#lessontp-content-time p:nth-of-type(2) span,
#lessontp-content-time p:nth-of-type(3) span{
	margin-left: 16px;
}
#lessontp-content-price-fi,
#lessontp-content-price-se{
	text-align:left;
	color: #DE8890;
	font-weight: 600;
}
#lessontp-content-price-fi p,
#lessontp-content-price-se p{
	background: url(../img/price-dot.png) no-repeat left center/6px;
	padding-left: 15px;
	margin-bottom: 8px;
}
#lessontp-content-price-se p{
	margin-bottom: 4px;
}
#lessontp-content-price-se p:nth-of-type(even){
	background: none;
	text-align: right;
	margin-bottom: 14px;
}
#lessontp-content-price-se p:last-of-type{
	margin-bottom: 7px;
}
.span-price{
	float:right;
	display: inline-block; 
}
.span-tax,
.span-only{
	font-size: 10px;
	font-weight: 200;
}
/*-----*/
#main-lessontp-caution{
	text-align:left; 
	color:#DE8890;
	font-size: 12px;
	font-weight: 600;
	line-height: 24px;
	margin: 15px 0 25px;
}
/*-----*/
#main-lessontp-thing{
	border: dashed 1px #ABA4A3;
	padding: 16px 10px 16px 20px;
}
#lessontp-thing-tlt{
	font-size: 16px;
	font-weight: normal;
	margin-bottom: 16px;
}
#main-lessontp-thing ul{
	text-align: left;
	font-size: 12px;
}
#main-lessontp-thing ul span{
	font-size: 10px;
}
#main-lessontp-thing ul li{
	background: url(../img/thing-dot.png) no-repeat left center/6px;
	padding-left: 18px;
	margin-bottom: 10px;
}
/*main-access*/
#main-access{
	background-color: #ABA4A3; 
	padding-top: 45px;
	padding-bottom: 45px;
	color: #fff;
	margin-bottom: 40px;
}
#main-access h3{
	color: #fff;
}
#access-mv{
	margin: 0 auto 22px;
	max-width: 640px;
	width: 81.2vw;
	height: 109.3vw;
	max-height: 860px;
}
#access-adress{
	margin-bottom: 25px;
}
#access-adress p{
	margin-bottom: 15px;
	font-weight: 100;
}
#access-adress .access-tel{
	font-size: 21px;
	color: #fff;
}
#access-root{
	width: 220px;
	margin: 0 auto;
	background: url(../img/access_root_lg.png) no-repeat center left 25px /16px;
}
#access-root a{
	border: solid 1px #fff;
	line-height: 50px;
	color: #fff;
	padding-left: 35px;
	font-size: 16px;
}
/* footer ----------------------*/
#footer{
	padding-bottom: 22vw;
}
#footer-content p{
	font-size: 12px;
	line-height: 24px;
}
#footer-content p span{
	color: #DE8890;
}
#footer-mv{
	width: 81.2vw;
	margin: 15px auto 40px;
	max-width: 640px;
}
#copy{
	font-size: 10px;
}
#fixed{
	position: fixed;
	width: 100%;
	bottom: 0;
	z-index: 9999;
}
#fixed ul {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
}
#fixed ul li {
	flex-grow： 1;
	flex:1
}
#reservation{
	position: fixed;
	width: 100%;
	bottom: 0;
	z-index: 9999;
}





@media screen and (min-width:769px) {
	body {
    line-height: inherit;
    font-size: 22px;
    overflow-x: hidden;
}
a:hover {
	opacity: .8;
	transition: opacity ease-in-out .3s;
}
	img {
    display: inline;
    width: auto;
    max-width: 100%;
    vertical-align: top;
}
	
	.inner,
	.pc-inner {
		margin: auto;
	    padding-left: 0;
	    padding-right: 0;
	    width: 96%;
	    max-width: 1000px;
	}
	.inner-800 {
	    max-width: 800px;
	}
	.sp-inner {
		padding-left: 0;
		padding-right: 0;
	}
	.maxw {
	    max-width: none;
	}
	.flex,
	.flex-start,
	.flex-end,
	.flex-center,
	.flex-space-between,
	.flex-space-around {
		display: flex;
	}
	.flex-start {justify-content: flex-start;}
	.flex-end { justify-content: flex-end; }
	.flex-center { justify-content: center; }
	.flex-space-around { justify-content: space-around;	}
	.flex-space-between { justify-content: space-between; }


	.pc-bl {
		display: block;
	}
	.pc-il {
		display: inline;
	}
	.sp {
		display: none;
	}

.h2 {
	text-align: left;
    font-size: 32px;
}
.h2 span {
    font-size: 31px;
    display: inline;
}
.h3 {
    font-size: 38px;
}

#header {
	position: fixed;
	z-index: 10;
    width: 100%;
	background-color: rgba(255,255,255,.9);
}
	#header .ic-logo{
		padding-top: 30px;
		max-width: 338px;
    width: 33.8%;
}
#header .nav {
    width: 61%;
    max-width: 610px;
}
.cv li {
    width: 300px;
}
	#header .cv img {
		vertical-align: top;
	}
	.gnav li {
	    margin: 20px;
	    height: 20px;
	}
	.gnav li a {
	    display: inline;
	}
	#header .gnav img {
	    height: 19px;
	    vertical-align: top;
	}



#main {
    padding-top: 120px;
    overflow-x: hidden;
}

#title {
	position: relative;
}
	.mv {
		width: 1500px;
	    left: 50%;
	    transform: translateX(-50%);
	    position: relative;
	}
	.ameba_bnr {
		width: 82.4%;
	    max-width: 824px;
	    position: absolute;
	    bottom: 90px;
	    left: 50%;
		transform: translateX(-50%);
	}


#main-posture {
    background-color: #FBF3F3;
    padding-top: 90px;
    padding-bottom: 70px;
    color: inherit;
}
#posture-title {
	widows: 71.5%;
    max-width: 715px;
    margin: auto;
}

#main-joint {
    padding-top: 60px;
}
#main-distortion {
    padding-bottom: 80px;
}
#main-distortion .h2 {
    margin-top: 50px;
}
#lesson-container {
	align-items: center;
}

	#lesson-drawing {
		margin: 0;
	    max-width: 360px;
	}
	#lesson-content {
	    max-width: 587px;
	}
		#posture-text-fi {
		    width: auto;
		    max-width: none;
		}

		#posture-text-se {
		    width: auto;
		}


#joint-image {
	float: right;
	max-width: 322px;
	margin: 0 0 1em 1em;
}

.h2-content {
    margin-left: 0;
    margin-bottom: 0;
}

.distortion-img {
	margin: auto;
    background-color: #F7F7F7;
    padding: 100px 0;
}

.distortion-img img {
    max-width: 800px;
}


#main-challenge {
    background: #E7AEB1;
    padding: 90px 0;
}
#main-challenge .h2 {
	text-align: center;
    font-size: 38px;
    color: #fff;
}
#main-challenge .h2-content {
	margin-top: 30px;
    margin-bottom: 0;
	text-align: center;
    color: #fff;
}


#main-profile {
	background: none;
	padding-top: 90px;
    padding-bottom: 80px;
    max-width: 800px;
}
#main-profile .h3 {
    margin-bottom: 70px;
}
	#main-profile .profile-photo {
	    max-width: 270px;
	}
	#main-profile .profile-text {
	    max-width: 450px;
	}

	#main-profile #profile-content {
    margin: -24px 0 0;
    text-align: justify;
    background-color: #fff;
    background-image: linear-gradient(90deg, rgba(200, 200, 202, 0) 0%, rgba(200, 200, 202, 0) 50%, #fff 0%, #fff 100%), linear-gradient(180deg, rgba(100, 100, 100, 0) 0%, rgba(100, 100, 100, 0) 97.5%, #C8C8CA 100%);
    background-size: 8px 100%,100% 70px;
    line-height: 70px;
}


		#profile-name {
			margin-top: 40px;
		    line-height: 30px;
		    text-align: right;
		    font-size: 30px;
		    color: #D79699;
		}

		#profile-name span {
		    display: inline;
		    margin-left: 20px;
		    vertical-align: 4px;
		    line-height: 19px;
		    font-family: 'ヒラギノ角ゴシック','Hiragino Sans','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
		    font-size: 19px;
			color: #7C7D80;
		}

#main-access {
    padding: 80px 0 100px;
    margin-bottom: 0;
}
	#main-access h3 {
	    margin-bottom: 80px;
	}
	#access-mv {
		margin: 0 auto 40px;
	    max-width: none;
	    width: 100%;
	    height: 350px;
	}

#access-adress p {
    text-align: left;
}

#access-root {
    width: 106px;
    background: none;
}

#access-root a {
    border: none;
    padding-left: 0;
}
#footer {
    padding-bottom: 0;
}
	#footer-content {
		margin: 80px auto;
	    flex-direction: row-reverse;
	    align-items: center;
	}
		#footer-content p {
			margin: 0;
		    line-height: 1.9;
		    text-align: left;
		    font-size: inherit;
		}
		#footer-content p#footer-mv {
		    margin: 0 5% 0 0;
		    width: auto;
		    max-width: none;
		}

	#copy {
	    background-color: #7C7D80;
	    line-height: 60px;
	    font-size: 20px;
	    color: #fff;
	}






}



@media screen and (min-width:1501px) {
	body {
    overflow-x: inherit;
}

	.mv {
		width: 100%;
	    left: 0;
	    transform: none;
	}
	.mv img {
		width: 100%;
	}
	.ameba_bnr {
	    bottom: 8vw;
	}

