@charset "utf-8";


/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {border: 0;font-family: inherit;font-size: 100%;font-style: inherit;font-weight: inherit;margin: 0;outline: 0;padding: 0;vertical-align: baseline;}
:focus {outline: 0;}

ol, ul {list-style: none;}
table {border-collapse: separate;border-spacing: 0;}
caption, th, td {font-weight: normal;text-align: left;}
blockquote:before, blockquote:after,q:before, q:after {content: "";}
blockquote, q {quotes: "" "";}
a img{border: 0;}
figure{margin:0}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}
/* -------------------------------------------------------------- */

body{
color:#333;
font:12px/1.5 "ＭＳ Ｐゴシック", Sans-Serif;
background:#f7f7f7;
-webkit-text-size-adjust: none;
}

html{
}


/* リンク設定
------------------------------------------------------------*/
a{color:#7d9313;text-decoration:none;}
a:hover{color:#b3dc2e;}
a:active, a:focus{outline:0;}


/* 全体
------------------------------------------------------------*/
#wrapper{
margin:0 auto;
padding:20px 1%;
width:98%;
position:relative;
background:#fff;
overflow:hidden;
}

* html #wrapper{background:#fff;}

.inner{
margin:0 auto;
width:100%;
}


/*************
/* ヘッダー
*************/
h1{
font-size:12px;
line-height:1.6;
font-weight:normal;
}

#header{
overflow:hidden;
padding:5px 0 0;
color:#fff;
background:#7d9313;
}

* html #header{height:1%;}


/*************
/* ロゴ
*************/
#header .logo{
float:left;
padding:20px 0 10px;
}

.logo a{
color:#fff;
font-size:20px;
font-weight:bold;
line-height:1;
}

.logo span{
font-size:12px;
font-weight:normal;
}

.info{ font-size: 14px; font-weight: bold; float:right; padding:30px 0 10px; }

.tel strong{
font-size:20px;
font-weight:bold;
}

/**************************
/* トップナビゲーション
**************************/
ul#topnav{
clear:both;
overflow:hidden;
margin:0 auto;
background:#5e8700;
border-radius:5px 5px 0 0;

background: -webkit-gradient(linear, 0 0, 0 bottom, from(#5e8700), to(#7EB207));
background: -moz-linear-gradient(#5e8700, #7EB207);
background: linear-gradient(#5e8700, #7EB207);
-ms-filter: "progid:DXImageTransform.Microsoft.Gradient(StartColorStr=#5e8700, EndColorStr=#7EB207)";
-pie-background: linear-gradient(#5e8700, #7EB207);



}

* html ul#topnav{height:1%;}

ul#topnav li{
float:left;
text-align:center;
}

ul#topnav a{ width:156px; font-size:14px; display:block; padding:10px 0; color:#fff; font-weight: normal; line-height:1.2; border-left:1px solid #b3dc2e; }

ul#topnav a span{font-size:12px;}

ul#topnav li:first-child a{border:0;}

ul#topnav li:last-child a{width:155px;}

ul#topnav li.active a,ul#topnav a:hover{background:#b3dc2e;
background: -webkit-gradient(linear, 0 0, 0 bottom, from(#97C30B), to(#b3dc2e));
background: -moz-linear-gradient(#97C30B, #b3dc2e);
background: linear-gradient(#97C30B, #b3dc2e);
-ms-filter: "progid:DXImageTransform.Microsoft.Gradient(StartColorStr=#97C30B, EndColorStr=#b3dc2e)";
-pie-background: linear-gradient(#97C30B, #b3dc2e);




}


/**************************
/* メイン画像（トップページ+サブページ）
**************************/
#mainBanner{
clear:both;
line-height:0;
background:#7d9313;
}

#mainBanner .inner{position:relative;}

#mainBanner img{
max-width:100%;
height:auto;
}

.slogan{
position:absolute;
max-width:100%;
height:auto;
bottom:10px;
left:10px;
padding:5px 10px;
line-height:1.4;
z-index:100;
}

.slogan h2{ color: #f03; padding-bottom:5px; font-size:20px; font-weight: bolder; }

.slogan h3{ color: #f03; font-size:14px; }


/**************************
/* グリッド
**************************/
.gridWrapper{
padding-bottom:20px;
clear:both;
overflow:hidden;
}

* html .gridWrapper{height:1%;}
	
.grid{
float:left;
padding-bottom:10px;
border:1px solid #dbdbdb;
border-radius:5px 5px 0 0;
}

.grid h3{
padding:5px;
font-size:13px;
color:#fff;
text-align:center;
border-radius:5px 5px 0 0;
background:#5e8700;

background: -webkit-gradient(linear, 0 0, 0 bottom, from(#5e8700), to(#7EB207));
background: -moz-linear-gradient(#5e8700, #7EB207);
background: linear-gradient(#5e8700, #7EB207);
-ms-filter: "progid:DXImageTransform.Microsoft.Gradient(StartColorStr=#5e8700, EndColorStr=#7EB207)";
-pie-background: linear-gradient(#5e8700, #7EB207);
}

.grid p{
padding:10px 10px 0;
}

.grid ul{margin:5px 10px 3px;}

.grid li{
padding:5px 0 4px;
border-bottom:1px solid #ccc;
}

.grid li:first-child{border-top:0;}
.grid li:last-child{border-bottom:0;}

.gridWrapper img{
max-width:100%;
height:auto;
}

/* フッター内のグリッド(3カラム) */
#footer .grid{
color:#fff;
border:0;
background:transparent;
}

#footer .col3 ul{margin:0 0 10px 5px;}

#footer .col3 li{
padding:0 7px 0 5px;
margin-bottom:3px;
list-style:none;
border-bottom:0;
display:inline-block;
border:0;
border-right:1px solid #fff;
}


/*************
メイン コンテンツ
*************/
section.content{
margin-bottom:20px;
font-size:14px;
overflow:hidden;
}

* html section.content{height:1%;}

section.content p{margin-bottom:5px;}
section.content img{margin-top:5px;}
section.content li{display: inline-block;vertical-align: top;}
section.content li h3{ font-weight: bold; padding: 7px 0 7px 10px; }
section.content li p{ padding-top: 5px; padding-bottom: 5px; padding-left: 10px; }

section.content li:first-child {  width: 24%; margin-right: 1%;}
section.content li:nth-child(2) {  width: 24%; margin-right: 1%;}
section.content li:nth-child(3) {  width: 24%; margin-right: 1%;}
section.content li:nth-child(4) {  width: 25%; margin-right: 0;}
section.content li:first-child h3{ background-color: #ffe100; }
section.content li:nth-child(2) h3{ background-color: #ffe733; }
section.content li:nth-child(3) h3{ background-color: #ffed66; }
section.content li:nth-child(4) h3{ background-color: #fff399; }

section.content img.proad{max-width:100%; }
	

h3.heading{
padding:5px 10px;
margin-bottom:10px;
font-size:16px;
color:#fff;
background:#5e8700;
border-radius:4px;

background: -webkit-gradient(linear, 0 0, 0 bottom, from(#5e8700), to(#7EB207));
background: -moz-linear-gradient(#5e8700, #7EB207);
background: linear-gradient(#5e8700, #7EB207);
-ms-filter: "progid:DXImageTransform.Microsoft.Gradient(StartColorStr=#5e8700, EndColorStr=#7EB207)";
-pie-background: linear-gradient(#5e8700, #7EB207);

}

p.pro{ border-radius:4px; background-color: #d7eaf7; padding: 3px 10px; border: solid 1px #afdaf7; }
p.mode { font-size: 16px; font-weight: bold; padding: 3px 0 3px 3px; border: solid 0 #afdaf7; border-radius: 4px; }
img.pro{ margin-bottom: 5px; }
.guide{ margin-top: 10px; margin-bottom: 10px; }
.guide img{ margin-right: 10px; margin-bottom: 10px; }

.real{ padding: 10px; border: solid 1px gray;overflow: hidden; }
.alignleft { margin: 3px 10px 10px 1px; float: left; clear: left; }
.alignright{
float:right;
clear:right;
margin:3px 1px 10px 10px;
}

img.frame,#gallery img{
border:solid 0 #555;
}

#gallery .gridWrapper{padding:0;}
#gallery .grid{border:0;}


/*************
テーブル
*************/
table.table{
border-collapse:collapse;
margin:10px auto;
}

table.table th,table.table td{
padding:5px;
border:1px solid #b3dc2e;
}

table.table tr:first-child th,table.table tr:first-child td{
border-top:#b3dc2e 4px solid
}

table.table th{
font-weight:bold;
letter-spacing:1px;
white-space:nowrap;
color:#fff;
background:#5e8700;
}


/*************
/* フッター
*************/
#footer .inner{
clear:both;
margin-bottom:20px;
padding:20px 0;
overflow:hidden;
background:#5e8700;
border-radius:0 0 10px 10px;
}

* html #footer{height:1%;}

#footer a{color:#fff;}

#footer .copyright{font-size:11px;}


/* PC用 */
@media only screen and (min-width:960px){
	#wrapper,.inner,ul#topnav{
	width:940px;
	padding:0;
	}
	
	#wrapper{padding:20px 0;}
	
	#main{
	float:right;
	width:680px;
	padding-right:10px;
	}
	
	#subpage #sub{
	float:left;
	width:235px;
	overflow:hidden;
	}
	
	/* グリッド */
	.gridWrapper{
	width:954px;
	margin-left:-14px;
	padding:0 9px 20px;
	}
	.grid{width:218px;margin:0 0 0 14px;}
	.col2{width:452px;}
	.col3{width:682px;}
	
	#gallery .gridWrapper{width:694px;}
	#gallery .grid{width:217px;}
	#subpage #sub .grid{
	float:none;
	margin-bottom:30px;
	}
	
}


/* モニター幅960px以下 */
@media only screen and (max-width:960px){
	h1{padding:0 1%;width:98%}
	#header .logo{padding-left:10px;}
	#header .info{padding-right:10px;}
	
	ul#topnav{
	clear:both;
	width:100%;
	border-radius:0;
	}

	ul#topnav li{
	width:33%;
	border-right:1px solid #b3dc2e;
	border-bottom:1px solid #b3dc2e;
	box-sizing:border-box;
  -webkit-box-sizing:border-box;
  -moz-box-sizing:border-box;
	}

	ul#topnav li:nth-child(3n){border-right:0;width:34%;}

	ul#topnav li a{
	width:100%;
	border:0;
	}

	ul#topnav li:first-child a,ul#topnav li:last-child a{width:100%;}
	
	.grid{
	width:45%;
	margin:2px 2% 10px;
	}
	
	.col2{
	float:none;
	width:94%;
	margin:0 2% 20px;
	}
	
	.grid img{
	float:left;
	margin-right:5px;
	}
	
	#gallery .grid{
	width:31%;
	margin:0 1%;
	padding:0;
	}
	
	#gallery .grid img{
	float:none;
	}
	
	section.content{padding:0 10px;}
	
	section.content img{
  max-width:90%;
	height:auto;
	}
	
	#sub .grid{padding-bottom:20px;}
	#subpage #sub .grid{
	float:none;
	margin:0 auto 20px;
	width:98%;
	}
	
	#footer{padding:0;}
	
	#footer .grid{
	float:none;
	width:100%;
	margin-bottom:5px;
	text-align:center;
	}
	
	.sp{ display: none; }
	
}


/* スマートフォン 横(ランドスケープ) */
@media only screen and (max-width:640px){
	.grid img{
	float:none;
	margin:20px auto 10px;
	}
	
	.grid p{text-align:left;}
	
	img.frame,#gallery img{border-width:2px;}

  .alignleft,.alignright{
	float:none;
	display:block;
	margin:0 auto 10px;
	}
	
	#footer .grid p{text-align:center;}
	
	
	section.content img.pro{ max-width:100%;text-align: center; float: none; clear: both; margin-top:5px; }
	
}

.gym img{ margin: 0 10px 10px 0; }
/* スマートフォン 縦(ポートレート) */
@media only screen and (max-width:480px){
	#header .logo{padding-top:10px;}
  .info{padding:10px 0;}
	ul#topnav li{width:50%;}

	ul#topnav li:nth-child(3n){
	border-right:1px solid #b3dc2e;
	width:50%;
	}	
	ul#topnav li:nth-child(2n),ul#topnav li:nth-child(6n){border-right:0;}
	
	#mainBanner h2,#mainBanner h3{font-size:80%;}
	
	.grid{width:96%;}
	
	section.content li:first-child {  width: 49%; margin-right: 1%;}
	section.content li:nth-child(2) {  width: 50%; margin-right: 0%;}
	section.content li:nth-child(3) {  width: 49%; margin-right: 1%;}
	section.content li:nth-child(4) {  width: 50%; margin-right: 0;}
	
	.guide{ text-align: center; margin-right: auto; margin-left: auto; }
	.gym img{ width: 100%; height: auto;}
	.gym{text-align: center;}
	
}

.insta_btn2{/*ボタンの下地*/
  color: #fff;/*文字・アイコン色*/
  
  position: relative; display: block; height: 50px;/*高さ*/
  width: 200px;/*幅*/
  text-align: center;/*中身を中央寄せ*/
  font-size: 25px;/*文字のサイズ*/
  line-height: 53px;/*高さと合わせる*/
  background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat; background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat url('(EmptyReference!)');/*グラデーション①*/
  overflow: hidden;/*はみ出た部分を隠す*/
  text-decoration:none; margin-top: 10px; margin-right: auto; margin-left: auto;/*下線は消す*/
}

.insta_btn2:before{/*グラデーション②*/
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;/*全体を覆う*/
  height: 100%;/*全体を覆う*/
  background: -webkit-linear-gradient(15deg, #ffdb2c, rgb(249, 118, 76) 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
  background: linear-gradient(15deg, #ffdb2c, rgb(249, 118, 76) 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
}

.insta_btn2 .fa-instagram{/*アイコン*/
  font-size: 35px;/*アイコンサイズ*/
  position: relative;
  top: 4px;/*アイコン位置の微調整*/
}

.insta_btn2 span {/*テキスト*/
  display:inline-block;
  position: relative;
  transition: .5s
}

.insta_btn2:hover span{/*ホバーで一周回転*/
	color: #fff;
  -webkit-transform: rotateX(360deg);
  -ms-transform: rotateX(360deg);
  transform: rotateX(360deg);
}

.insta_btn2:hover{
	color: #fff;
}


.insta_btn {
  display: inline-block;
  text-align: center;/*中央揃え*/
  color: #2e6ca5;/*文字色*/
  font-size: 20px;/*文字サイズ*/
  text-decoration: none;/*下線消す*/
}

.insta_btn:hover {/*ホバー時*/
  color:#668ad8;/*文字色*/
  transition: .5s;/*ゆっくり変化*/
}

.insta_btn .insta{/*アイコンの背景*/
  position: relative;/*相対配置*/
  display: inline-block;
  width: 50px;/*幅*/
  height: 50px;/*高さ*/
  background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;/*グラデーション①*/
  overflow: hidden;/*はみ出た部分を隠す*/
  border-radius: 13px;/*角丸に*/

}

.insta_btn .insta:before{/*グラデーションを重ねるため*/
  content: '';
  position: absolute;/*絶対配置*/
  top: 23px;/*ずらす*/
  left: -18px;/*ずらす*/
  width: 60px;/*グラデーションカバーの幅*/
  height: 60px;/*グラデーションカバーの高さ*/
  background: -webkit-radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);
  background: radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);/*グラデーション②*/
}

.insta_btn .fa-instagram {/*アイコン*/
  color: #FFF;/*白に*/
  position: relative;/*z-indexを使うため*/
  z-index: 2;/*グラデーションより前に*/
  font-size: 35px;/*アイコンサイズ*/
  line-height: 50px;/*高さと合わせる*/
}

.insta_str{
 display: inline-block;
 font-size: 18px;
 vertical-align: bottom;
 height: 44px;
}

.grid a.insta{color: #2e6ca5; font-size: 16px; }
