/*--------------------------------------------------------------
Reset
--------------------------------------------------------------*/
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, input, textarea {
	border: 0;
	font-size: 14px; /* ベースのフォントサイズを記述 */
	font-family: Meiryo, "メイリオ", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ＭＳ ゴシック", "Osaka‐等幅";
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
	color: #595757;
	line-height: 1.5;
}

html {
	font-size: 62.5%;
	overflow-y: scroll;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust:     100%;
}
*,
*:before,
*:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing:    border-box;
	box-sizing:         border-box;
}
body {
	background: #fff;
	min-width: 1045px; /* 基本の横幅を記述 */
}
ul , li {
	list-style: none;
}
table {
	border-collapse: collapse;
}
a:focus {
	outline: thin dotted;
}
a:hover,
a:active {
	outline: 0;
}
a img {
	border: 0;
}
img,
input[type="image"] {

}
input[type="submit"] {
	cursor: pointer;
}
strong {
	font-weight:bold;
}
a {
    text-decoration: none;
}
a:hover,
a:focus,
a:active {
	text-decoration: underline;
}
a:hover img,
input[type="image"]:hover {
	opacity: 0.7;
	filter: alpha(opacity=80);
	-moz-opacity: 0.7;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
/*--------------------------------------------------------------
 Layout/PageBase
--------------------------------------------------------------*/
#header {
	margin-bottom: 20px;
}
#footer {
	background-color: #6ebbc4;
}
#main {
	float: left;
	width: 798px;
	padding-right: 30px;
/*	margin-top: 413px;*/
}
#side {
	float: right;
	width: 247px;	
	margin-top: -12px;
}

/*--------------------------------------------------------------
 Component
--------------------------------------------------------------*/
.c_pgtop {
	/* PAGE TOP 右下固定時
	position:fixed;
	right:10%;
	bottom:10%; */
}

/*--------------------------------------------------------------
 Project
--------------------------------------------------------------*/

/* -------- header -------- */

.h_top {
	background-color: #f8f8f8;
/*	text-align: right;*/
	padding-right: 3px;		
}
.h_top > div {
	font-size: 0;
}
.h_top h1 {
	display: inline-block;
	color: #727171;
	font-size: 10px;
	vertical-align: 1.35em;
	margin-left: 5px;
	margin-right: 76px;
}
.h_top img {
	vertical-align: bottom;
}
.h_sec img {
	display: block;
}
.h_logo {
	float: left;
	margin-left: 8px;
	margin-top: 37px;
}
.h_nav {
	float: right;
	margin-top: 23px;
}
.h_nav ul {
	font-size: 0;
}
.h_nav li {
	display: inline-block;
}

/* -------- footer -------- */

.f_sec {
	padding: 2.5em 0;
}
.f_sec ._conts{
	display: inline-block;
}
.f_logo {
	vertical-align: middle;
	margin-left: 8px;
	margin-right: 87px;
}
.f_official {
	vertical-align: middle;
	margin-right: 68px;
}
.f_official ._name {
	border-bottom: 1px solid #85c6cd;
	padding-bottom: 11px;
}
.f_official ._tel {
	margin-top: 25px;
}
.f_official ._ttl, .f_official ._ontime {
	font-size: 12px;
	color: #fff;
}
.f_official ._ontime {
	margin-left: -0.6em;
	margin-top: 0.8em;
}
.f_info {
	vertical-align: middle;	
}
.f_info p, .f_info em {
	color: #fff;
	display: block;
	line-height: 1.2em;
}
.f_info em {
	font-weight: bold;
}
.f_info p + p em {
	margin-top: 0.6em
}
.f_copy {
	text-align: center;
	color: #fff;
	font-size: 12px;
	border-top: 1px solid #85c6cd;
	padding-bottom: 21px;
	padding-top: 14px;
}

/* -------- side bar -------- */

.s_info img, .s_recruit img {
	display: block;
}
.s_recruit {
	margin-top: 13px;
}

/* -------- top -------- */

.top_bg {
	background: url('../img/img_top_top.jpg') repeat-x;
	background-color: #eef2df;
	background-position: top center;
}
.top_grid {
	margin-top: 474px;
}
.top_grid img {
	display: block;
}
.top_grid li {
	display: inline-block;
	width: 355px;
	margin-bottom: 78px;
}
.top_grid li p {
	font-size: 12px;	
	line-height: 1.5;
	margin: 1.2em 3px 1.6em;
}
.top_grid li + li {
	margin-left: 32px;
}

/* -------- shinkyu -------- */

.shinkyu_bg {
	background: url('../img/bg_snk_top.png') no-repeat;
	background-position: top center;
	background-size: 100% 195px;
}
.shinkyu_bg_img {
	background: url('../img/img_snk_top.jpg') no-repeat;
	background-position: top center;
}
.shinkyu {
	margin-bottom: 72px;
}
.shinkyu h2 {
	margin-top: 86px;
}
.shinkyu h3 {
	margin-top: 110px;
	margin-bottom: 16px;
}
.shinkyu h3 img {
	display: block;
	margin-top: 17px;
}
.shinkyu h3 em {
	background-color: #d64830;
	color: #fff;
	font-size: 16px;
	font-weight: bold;
	padding: 7px 15px 6px;
	display: inline-block;
	line-height: 1;
}
.shinkyu ._ttl {
	font-size: 18px;
	font-weight: bold;
	margin-top: 45px;
}
.shinkyu ._grid {
	font-size: 0;
	margin-left: -7px;
	margin-top: 12px;
	margin-bottom: 55px;
}
.shinkyu ._grid li {
	width: 148px;
	height: 46px;
	display: inline-block;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
	background-color: #608435;
	color: #fff;
	border-radius: 4px;
	padding-top: 0.55em;
	margin-left: 7px;
}
.shinkyu ._grid ._item2 {
	width: 303px;
}
.shinkyu ._grid ._item3 {
	width: 458px;
	margin-top: 8px;
}
.shinkyu h4 {
	font-size: 24px;
	font-weight: bold;
	border-left: 4px solid #498700;
	line-height: 1;
	padding: 6px 0 0 8px;
	margin-bottom: 0.7em;
}
.shinkyu h4 em {
	font-size: 24px;
	color: #498700;
	line-height: 1;
}
.shinkyu h4 span {
	display: block;
	line-height: 1;
	font-size: 12px;
	margin-top: 7px;
	padding-bottom: 9px;
	padding-left: 8em;
}
.shinkyu ._txt2 {
	margin-bottom: 3em;
}
.shinkyu ._trial {
	margin-top: 70px;
}

/* -------- recruit -------- */

.recruit_bg {
	background: url('../img/bg_rec_top.png') no-repeat;
	background-position: top center;
	background-size: 100% 195px;
}
.recruit_bg_img {
	background: url('../img/img_rec_top.jpg') no-repeat;
	background-position: top center;
}
.recruit {
	margin-bottom: 106px;
}
.recruit h2 {
	margin-top: 85px;
}
.recruit h3 {
	margin-top: 123px;
	margin-bottom: 1em
}
.recruit h4 {
	font-size: 16px;
	font-weight: bold;
	background-color: #afd02a;
	color: #fff;
	padding: 0.7em 1em 0.6em;
	line-height: 1;
	margin-top: 3em;
}
.recruit ._info_list {
	margin-top: 0.8em;
}
.recruit ._info_list p {
	border-bottom: 1px dotted #7c7c7c;
	padding: 0.8em 1em 0.8em;
}
.recruit ._info_list p span {
	display: inline-block;
	width: 9em;
}
.recruit ._contact {
	background: url('../img/bn_rec_contact.png') no-repeat;
	height: 155px;
	margin-top: 53px;	
}
.recruit ._contact > div {
	display: inline-block;
	margin-top: 45px;
	margin-left: 400px;
}

/* -------- concept -------- */

.concept_bg {
	background: url('../img/bg_conc_top.png') no-repeat;
	background-position: top center;
	background-size: 100% 195px;
}
.concept_bg_img {
	background: url('../img/img_conc_top.jpg') no-repeat;
	background-position: top center;
}
.concept {
	margin-bottom: 78px;
}
.concept h2 {
	margin-top: 89px;
}
.concept h3 {
	margin-top: 118px;
}
.concept ._txt01 {
	background: url('../img/img_conc01.jpg') no-repeat;
	background-position: right bottom;
	margin-top: 2.1em;
}
.concept ._txt01 p {
	font-size: 18px;
	font-weight: bold;
	line-height: 2em;
	padding-bottom: 15.5em;
}

/* -------- care_person -------- */

.care_bg {
	background: url('../img/bg_med_top.png') no-repeat;
	background-position: top center;
	background-size: 100% 195px;
}
.care_bg_img {
	background: url('../img/img_med_top.jpg') no-repeat;
	background-position: top center;
}

.care {
	margin-bottom: 78px;
}
.care h2 {
	margin-top: 86px;
}
.care h3 {
	margin-top: 122px;
	margin-bottom: 1em;
}
.care h4 {
	font-size: 16px;
	font-weight: bold;
	color: #fff;
	padding: 0.63em 1.5em;
	line-height: 1;
}
.care ._ttl01 {
	background-color: #b7d226;
	text-align: center;
	margin-top: 60px;
}
.care ._ttl02 {
	background-color: #d64830;
	margin-top: 67px;
}
.care ._flow_list {
	margin-top: 32px;
	font-size: 0;
	margin-left: 7px;
}
.care ._flow_list li {
	display: inline-block;
	vertical-align: top;
	width: 200px;
}
.care ._flow_list li div {
	text-align: center;
}
.care ._flow_list img {
	margin-left: 20px;	
}
.care ._flow_list ._item01 {
	margin-right: 62px;
}
.care ._flow_list ._item02 {
	margin-right: 53px;
}
.care ._flow_list h5 {
	color: #b7d226;
	font-size: 18px;
	font-weight: bold;
	margin-top: 9px;
	margin-bottom: 5px;
}
.care ._report {
	margin-top: 1em;
}
.care ._report p {
	padding: 0.8em 1em;
	border-bottom: 1px dotted #7c7c7c;
}
.care ._case {
	margin-left: 1.2em;
	margin-top: 2em;
}
.care ._case h5 {
	font-weight: bold;
/*	margin-bottom: 0.5em;*/
}
.care ._case li {
	border-bottom: 1px solid #7c7c7c;
	line-height: 1.2;
	margin-top: 0.65em;
	display: inline-block;
}
.care ._rem {
	padding: 1.6em 2.2em;
	background-color: #fbedea;
	margin-top: 34px;
}
.care ._rem p {
	line-height: 1.7;
}

/* -------- massage -------- */

.massage_bg {
	background: url('../img/bg_msg_top.png') no-repeat;
	background-position: top center;
	background-size: 100% 195px;
}
.massage_bg_img {
	background: url('../img/img_msg_top.jpg') no-repeat;
	background-position: top center;
}
.massage {
	margin-bottom: 56px;
}
.massage h2 {
	margin-top: 86px;
}
.massage h3 {
	margin-top: 110px;
	margin-bottom: 16px;
}
.massage h3 img {
	display: block;
	margin-top: 17px;
}
.massage h3 em {
	background-color: #d64830;
	color: #fff;
	font-size: 16px;
	font-weight: bold;
	padding: 7px 15px 6px;
	display: inline-block;
	line-height: 1;
}
.massage h4 {
	font-size: 16px;
	font-weight: bold;
	background-color: #afd02a;
	color: #fff;
	padding: 0.7em 1em 0.6em;
	line-height: 1;
	margin-top: 2.5em;
}
.massage h5 {
	font-size: 24px;
	font-weight: bold;
	border-left: 4px solid #64c4cf;
	line-height: 1;
	padding: 6px 0 0 8px;
	margin-bottom: 0.7em;
}
.massage h5 em {
	font-size: 24px;
	color: #64c4cf;
	line-height: 1;
}
.massage h5 span {
	display: block;
	line-height: 1;
	font-size: 12px;
	margin-top: 7px;
	padding-bottom: 9px;
	padding-left: 8em;
}
.massage ._sec01 ul {
	margin-top: 0.5em;
}
.massage ._sec01 li {
	border-bottom: 1px dotted #7c7c7c;
	padding: 1.05em 1em;
}
.massage ._sec01 li span {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.2em;
	display: inline-block;	
	vertical-align: middle;
}
.massage ._sec01 li img {
	vertical-align: -0.9em;
	margin-right: 2em;
}
.massage ._sec02 p {
	margin: 1.5em 0;
}
.massage ._sec02 ul {
	font-size: 0;
	margin-left: -21px;
}
.massage ._sec02 li {
	display: inline-block;
	margin-left: 21px;
}
.massage ._sec03 h5 {
	margin-top: 1em;
}
.massage ._sec03 ul {
	font-size: 0;
}
.massage ._sec03 ul li {
	display: inline-block;
	margin-bottom: 1.5em;
}
.massage ._sec03 ._list_item02 p {
	width: 50%;
	display: inline-block;
	vertical-align: top;
}
.massage ._tbl01 {
	display: inline-block;
	margin-top: -42px;
	margin-left: 24px;
}
.massage ._tbl01 th {
	background-color: #afd02a;
	border: 1px solid #fff;
	font-weight: bold;
	color: #fff;
	text-align: center;
	width: 177px;
	padding: 0.25em 0;
}
.massage ._tbl01 td {
	text-align: center;
	font-size: 12px;
	color: #000;
	padding: 0.25em 0;
	background-color: #e9f2c3;
	border: 1px solid #fff;
}
.massage ._tbl01 ._odd td {
	background-color: #f7fae9;
}
.massage ._sec03 ._list_item03 {
	width: 50%;
}
.massage ._sec03 ._list_item04 {
	width: 50%;
	padding-left: 1.8em;
}
.massage ._sec03 ._list_item05 {
	width: 50%;
}
.massage ._sec03 ._list_item06 {
	width: 50%;
	padding-left: 1.8em;
}
.massage ._sec03 ._list_item07 {
	width: 50%;
}

/* -------- contact -------- */

.contact_bg {
	background: url('../img/bg_cont_top.png') no-repeat;
	background-position: top center;
	background-size: 100% 195px;
}
.contact_bg_img {
	background: url('../img/img_cont_top.jpg') no-repeat;
	background-position: top center;
}
.contact {
	margin-bottom: 78px;
}
.contact h2 {
	margin-top: 6em;		
}
.contact ._form_body {
	margin-top: 110px;
}
.contact ._form_body caption {
	text-align: left;
	margin-bottom: 1em;
}
.contact ._form_body caption em {
	color: #fcb900;
	font-weight: bold;	
}
.contact ._form_body input[type="text"],
.contact ._form_body input[type="email"],
.contact ._form_body textarea {
	border: 1px solid #d9d9d9;
	padding: 0.7em;
	font-size: 12px;
	width: 526px;
}
.contact ._form_body input[type="radio"] {
	vertical-align: -11%;
	margin: 11px 0 12px 0;
}
.contact ._form_body tbody em {
	color: #c5126f;
/*	font-size: 16px;*/
}
.contact ._form_body th {
	font-size: 12px;
	width: 185px;
	text-align: left;
	border-bottom: 1px dotted #8c7a7a;
	padding-left: 2em;
	padding-top: 3.1em;
	vertical-align: top;	
}
.contact ._form_body td {
	border-bottom: 1px dotted #8c7a7a;
	padding: 2.2em 0 2.2em 4em;
}
.contact ._form_body tr:first-child th,
.contact ._form_body tr:first-child td {
	border-top: 1px dotted #8c7a7a;
}
.contact ._form_body label {
	font-size: 12px;
	padding-right: 0.8em;
}
.contact ._address {
	position: relative;
}
.contact ._address input[name="postcode"] {
	width: 210px;
}
.contact ._address:first-child {
	margin-bottom: 18px;
}
.contact ._form_body span {	
	position: absolute;
	font-size: 12px;
	width: 2em;
	top: 0.75em;
	left: -4em;
}
.contact input[type="submit"]{
	background-color: #afd02a;
	font-size: 18px;
	color: #fff;
	letter-spacing: 2px;
	padding: 0.7em 6.6em;
}
.contact input[type="submit"]:hover {
	opacity: 0.7;
	filter: alpha(opacity=80);
	-moz-opacity: 0.7;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
.contact ._personal_info {}
.contact ._personal_info p {
	font-size: 12px;
}
.contact ._personal_info h3 {
	text-align: center;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 3px;
	margin: 1em 0;
}
.contact ._personal_info dt,
.contact ._personal_info dd {
	font-size: 12px;
}
.contact ._personal_info ._textbox {
	height: 210px;
	overflow-y: scroll;
	padding-left: 2em;
}
.contact ._personal_info ._textbox dt {
	margin: 1em 0;
}
.contact ._submit {
	text-align: center;
	margin-top: 54px;
}
.contact ._send_end {
	padding: 2.2em 2.2em 2em;
	background-color: #fbedea;
	line-height: 1;
	margin-bottom: 2em;
	font-weight: bold;
	border: 1px dotted #8c7a7a;
}
.contact td {
	position: relative;
}
.contact label.error {
	color: red;
	position: absolute;
	top: 8px;
	left: 55px;
}
.contact ._address label.error {
	top: -17px;
	left: 0;
}
.send_end {
	text-align: center;
	margin: 5em 0 8em;
	color: #afd02a;
}

/*--------------------------------------------------------------
 Utility
--------------------------------------------------------------*/
.u_container {
/*	width: 1313px;*/
	margin: 0 auto;
}
.u_inner {
	width: 1045px; /* 基本の横幅を記述 */
	margin:0 auto;
}
.u_clearfix:after,
.u_clearfix > li:after {
	height: 0;
	visibility: hidden;
	content: ".";
	display: block;
	clear: both;
}
* html .u_clearfix,
* html .u_clearfix > li {
	zoom: 1;
}
*+html .u_clearfix,
*+html .u_clearfix li {
	zoom: 1;
}
.u_clear {
	clear:both;
}
.u_hide {
	display: none;
}
/* 透過画像、文字などでリンクマップ時、HOVERモーションを追加  */
a.u_hvr,
.u_hvr a {
	color:transparent;
}
a.u_hvr:hover,
.u_hvr a:hover {
	background: #fff;
	opacity: 0.3;
	filter: alpha(opacity=80);
	-moz-opacity: 0.3;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;	
}
.u_aln-center {
	text-align: center;
}
.u_aln-center img {
	margin: 0 auto;
	display: block;
}
.u_aln-right {
	text-align: right;
}
.u_fl-left {
    float:left;
    width:48%;
}
.u_fl-right {
    float:right;
    width:48%;
}
.u_lnk-right {
    text-align: right;
}
.u_lnk-right a {
    display: inline-block;
}

/*--------------------------------------------------------------
 Context
--------------------------------------------------------------*/
@media all and (max-width: 640px) {
}

