@charset 'utf-8';


#docbody > .inner {
	width: 100%;
	max-width: none;
	padding: 0;
}

.breadcrumb {
	display: none;
}

#shopinfobtn {
	margin: 0;
	position: absolute;
	top: 52px;
	left: 0;
	z-index: 30;
	display: none;
}


@media only screen and (min-width: 0px) and (max-width: 540px) {

	#shopinfobtn {
		top: 42px;
	}
}


#contentheader {
	display: none;
}


#mainvisual {
	width: 100%;
	background: url(../image/portal/keyvisual.jpg) no-repeat center center;
	background-size: cover;
	position: relative;
}

#mainvisual .inner {
	width: 100%;
	margin: 0 auto;
	padding: 50px 20px;
	position: relative;
}

#mainvisual h1 {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 70px;
	text-align: center;
}

#mainvisual h1 span,
#mainvisual h2 span {
	display: block;
	width: 100%;
}

#mainvisual h1 span img {
	width: 100%;
	height: auto;
}

#mainvisual h2 {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	margin-top: -100px;
	text-align: center;
}

@media only screen and (min-width: 0px) and (max-width: 1040px) {

	#mainvisual h1 {
		padding: 0 7%;
	}

	#mainvisual h2 {
		margin-top: -10%;
	}
}

@media only screen and (min-width: 541px) and (max-width: 768px) {

	#mainvisual h2 span img {
		width: 35%;
		height: auto;
	}
}

@media only screen and (min-width: 0px) and (max-width: 540px) {

	#mainvisual h1 {
		padding: 0;
	}

	#mainvisual h2 span img {
		width: 50%;
		height: auto;
	}
}


#hotyoga {
	width: 100%;
	background: url(../image/portal/back_hotyoga.jpg) no-repeat center bottom;
	background-size: cover;
	position: relative;
}

#hotyoga .inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 50px 20px;
	position: relative;
}

#hotyoga header {
	width: 100%;
	margin: 0 auto;
	margin-bottom: 100px;
	text-align: center;
}

#hotyoga header h1 {
	color: #fff;
}

#hotyoga ul {
	list-style: none;
	max-width: 1100px;
	margin: 0 auto;
	text-align: center;
}

#hotyoga li {
	list-style: none;
	display: inline-block;
	width: 240px;
	height: 240px;
	margin: 0 5px;
	margin-bottom: 40px;
	padding: 20px;
	padding-top: 72px;
	color: #fff;
	line-height: 1.8em;
	vertical-align: top;
	position: relative;
}

#hotyoga li:before {
	content: '';
	width: 240px;
	height: 240px;
	border-radius: 120px;
	background: #cf2d5a;
	opacity: 0.5;
	position: absolute;
	bottom: 0;
	left: 0;
}

#hotyoga li:after {
	content: '';
	width: 200px;
	height: 200px;
	border-radius: 100px;
	background: #cf2d5a;
	opacity: 0.8;
	position: absolute;
	bottom: 20px;
	left: 20px;
}

#hotyoga li h2 {
	margin-bottom: 20px;
	font-size: 1.8em;
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'HGS明朝E', 'ＭＳ Ｐ明朝', serif;
	white-space: nowrap;
	position: relative;
	z-index: 10;
}

#hotyoga li h2:before {
	content: '';
	width: 240px;
	height: 124px;
	background-image: url(../image/portal/hotyoga.png);
	background-repeat: no-repeat;
	position: absolute;
	bottom: 34px;
	left: -20px;
}

li#hotyoga2 h2:before {
	background-position: -250px 0;
}

li#hotyoga3 h2:before {
	background-position: -500px 0;
}

li#hotyoga4 h2:before {
	background-position: -750px 0;
}

#hotyoga li p {
	font-size: 1.3em;
	position: relative;
	z-index: 10;
}

#hotyoga .lead {
	margin-bottom: 40px;
	color: #fff;
	font-size: 1.8em;
	line-height: 1.8em;
	text-align: center;
}

#hotyoga .btn_large a {
	background: rgba(115,106,66,.7);
}

#hotyoga .btn_large a:hover,
#hotyoga .btn_large a.hover {
	background: rgba(161,153,125,.7);
}


@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {

	#hotyoga li h2:before {
		background-image: url(../image/portal/hotyoga@2x.png);
		background-size: auto 124px;
	}
}

@media only screen and (min-width: 0px) and (max-width: 768px) {

	#hotyoga .lead br {
		display: none;
	}
}

@media only screen and (min-width: 541px) and (max-width: 768px) {

	#hotyoga header {
		margin-bottom: 70px;
	}

	#hotyoga .lead {
		font-size: 1.6em;
	}
}

@media only screen and (min-width: 0px) and (max-width: 540px) {

	#hotyoga header {
		margin-bottom: 50px;
	}

	#hotyoga .lead {
		font-size: 1.4em;
	}
}

#program {
	width: 100%;
	min-height: 620px;
	margin: -42px auto;
	padding: 42px 0;
	background: url(../image/portal/back_program.png) no-repeat center top;
	position: relative;
	z-index: 10;
}

#program .inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	position: relative;
}

#program .sentence {
	width: 100%;
	padding: 60px 20px 40px 380px;
	position: relative;
}

#program header {
	margin-bottom: 40px;
}

#program header h1 {
	color: #736a42;
}

#program .lead {
	margin-bottom: 70px;
	color: #a1997d;
	font-size: 1.8em;
	line-height: 1.8em;
}

#program .btn_large {
	margin: 0;
}

@media only screen and (min-width: 0px) and (max-width: 1100px) {

	#program .sentence {
		padding-left: 34.55%;
	}
}

@media only screen and (min-width: 769px) and (max-width: 940px) {

	#program {
		background-position: -200px 0;
	}
}

@media only screen and (min-width: 541px) and (max-width: 768px) {

	#program {
		background-size: 120% auto;
	}

	#program header {
		margin-bottom: 30px;
		padding-right: 10px;
	}

	#program .lead {
		margin-bottom: 50px;
		padding-right: 10px;
		font-size: 1.6em;
	}

	#program .btn_large,
	#program .btn_large a {
		width: 100%;
	}
}

@media only screen and (min-width: 0px) and (max-width: 540px) {

	#program {
		min-height: 0;
		margin: 0 auto;
		padding: 0;
		background-position: -70px bottom;
		background-size: auto 300px;
	}

	#program:before {
		content: '';
		display: block;
		width: 100%;
		height: 100%;
		background: rgba(255,255,255,.6);
		position: absolute;
		top: 0;
		left: 0;
	}

	#program .sentence {
		padding: 50px 20px;
		position: relative;
		z-index: 1;
	}

	#program header {
		margin-bottom: 20px;
		padding: 0 10px;
	}

	#program .lead {
		margin-bottom: 30px;
		padding: 0 10px;
		font-size: 1.4em;
	}

	#program .btn_large,
	#program .btn_large a {
		width: 100%;
	}
}



#instructor {
	width: 100%;
	padding-top: 40px;
	background: #e5e3db;
	position: relative;
}

#instructor .inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 40px 20px;
	position: relative;
}

#instructor header {
	margin-bottom: 50px;
}

#instructor header h1 {
	color: #736a42;
}

#instructor .tmp span {
	display: block;
	max-width: 640px;
	margin: 0 auto;
	margin-bottom: 30px;
}

#instructor .tmp span img {
	width: 100%;
	height: auto;
}

#instructor .tmp p {
	color: #a1997d;
	font-size: 1.8em;
	text-align: center;
	line-height: 1.8em;
}

@media only screen and (min-width: 0px) and (max-width: 768px) {

	#instructor {
		padding: 0;
	}
}

@media only screen and (min-width: 541px) and (max-width: 768px) {

	#instructor {
		padding: 0;
	}

	#instructor header {
		margin-bottom: 30px;
		padding: 0 10px;
	}

	#instructor .tmp p {
		font-size: 1.6em;
	}
}

@media only screen and (min-width: 0px) and (max-width: 540px) {

	#instructor {
		padding: 0;
	}

	#instructor header {
		margin-bottom: 20px;
		padding: 0 10px;
	}

	#instructor .tmp p {
		font-size: 1.4em;
	}
}


#rebeau {
	width: 100%;
	background: #a1997d;
	position: relative;
}

#rebeau .inner {
	width: 100%;
	margin: 0 auto;
	padding: 40px 30px;
	color: #fff;
	text-align: center;
	font-size: 1.8em;
	line-height: 2em;
	position: relative;
}

#rebeau h1 {
	display: inline-block;
	margin: 0 auto;
	margin-bottom: 50px;
}

#rebeau ul {
	list-style: none;
	margin-bottom: 2em;
}

#rebeau li {
	list-style: none;
	font-size: 1.1em;
	font-weight: bold;
	position: relative;
}

#rebeau li:before {
	content: '●';
	position: relative;
}

#rebeau p {
	margin-bottom: 2em;
}

@media only screen and (min-width: 541px) and (max-width: 768px) {

	#rebeau .inner {
		padding: 30px;
		font-size: 1.6em;
	}

	#rebeau h1 {
		margin-bottom: 40px;
	}
}

@media only screen and (min-width: 0px) and (max-width: 540px) {

	#rebeau .inner {
		padding: 30px;
		padding-bottom: 20px;
		font-size: 1.4em;
	}

	#rebeau h1 {
		width: 50%;
		margin-bottom: 30px;
	}

	#rebeau h1 img {
		width: 100%;
		height: auto;
	}

	#rebeau p br {
		display: none;
	}
}

.campaign {
	width: 100%;
	padding: 45px 0 30px 0;
	position: relative;
}

.campaign header {
	margin: 0 auto;
	margin-top: 20px;
}

.campaign header h1 {
	color: #fff;
	font-size: 2em;
}

.campaign .inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 20px;
	text-align: center;
	position: relative;
}

.campaign .inner img.imgBnr{
display: block;
 width: 1040px;
 margin: 0 auto;
}


.qaBox{background:#d4d3b3; padding:45px 0 105px;}

.campaign .inner img.bnr_campaign{margin-bottom:70px;}
.campaign .inner img.ttl_kaatsu{margin-bottom:40px;}
.campaign .inner img.img_kaatsu{margin-bottom:65px;}
.campaign .inner img.img_Kinesis{margin-bottom:165px;}
.campaign .inner img.img_personal_training_flow{margin-bottom:100px;}
.campaign .inner img.img_ideal{margin-bottom:90px;}
.campaign .inner img.img_5large_effect{margin-bottom:90px;}

.campaign .inner img.img_qa{margin:0px auto; width: 860px;}

.campaign .inner img.img_price{margin-bottom:75px; width: 860px;}


.campaign .inner p {
	color: #fff;
	font-size: 1.3em;
	margin-bottom: 15px;
}

.campaign .inner a,
.campaign .inner a span {
	display: block;
	width: 100%;
	text-align: center;
	text-decoration: none;
	position: relative;
	font-size: 1.3em !important;
	color: #F7EEF0;
	margin-bottom: 10px;

}

.campaign .inner a:hover span:after,
.campaign .inner a.hover span:after {
	content: '\f0a9';
	width: 100px;
	height: 100px;
	margin: -50px 0 0 -50px;
	opacity: 0.8;
	color: #fff;
	font-size: 100px;
	font-family: 'FontAwesome';
	font-weight: normal !important;
	text-indent: 0;
	line-height: 100px;
	position: absolute;
	top: 50%;
	left: 50%;
}

@media only screen and (min-width: 0px) and (max-width: 1040px) {

.campaign {
	width: 100%;
	padding: 23px 0 15px 0;
	position: relative;
}

	.campaign .inner a span img {
		width: 100%;
		height: auto;
	}

	.campaign .inner img.imgBnr{
	display: block;
	width: 100%;
	}


.qaBox{background:#d4d3b3; padding:22px 0 52px;}

.campaign .inner img.bnr_campaign{margin-bottom:35px;}
.campaign .inner img.ttl_kaatsu{margin-bottom:20px;}
.campaign .inner img.img_kaatsu{margin-bottom:32px;}
.campaign .inner img.img_Kinesis{margin-bottom:82px;}
.campaign .inner img.img_personal_training_flow{margin-bottom:50px;}
.campaign .inner img.img_ideal{margin-bottom:45px;}

.campaign .inner img.img_qa{margin:0px;}

.campaign .inner img.img_price{margin-bottom:37px;}

}

@media only screen and (min-width: 0px) and (max-width: 540px) {

.campaign {
	width: 100%;
	padding: 12px 0 8px 0;
	position: relative;
}

	.campaign .inner a:hover span:after,
	.campaign .inner a.hover span:after {
		content: '\f0a9';
		width: 50px;
		height: 50px;
		margin: -25px 0 0 -25px;
		font-size: 50px;
		line-height: 50px;
	}

	.campaign .inner img.imgBnr{
	display: block;
	width: 100%;
	}

.qaBox{background:#d4d3b3; padding:11px 0 26px;}

.campaign .inner img.bnr_campaign{margin-bottom:18px;}
.campaign .inner img.ttl_kaatsu{margin-bottom:10px;}
.campaign .inner img.img_kaatsu{margin-bottom:16px;}
.campaign .inner img.img_Kinesis{margin-bottom:41px;}
.campaign .inner img.img_personal_training_flow{margin-bottom:25px;}
.campaign .inner img.img_ideal{margin-bottom:22px;}

.campaign .inner img.img_qa{margin:0px;}

.campaign .inner img.img_price{margin-bottom:18px;}

}
