@charset "EUC-JP";
/* =============================================================================

CSS Information

 File name:	layout.css

 Style Info:	レイアウト設定

============================================================================= */


html,body {
	height: 100%;
}

body {
    color: #313131;
    font-size: 15px;
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1.8;

}

/* for IE6 */
* html body {
	font-size: 75%;
}

/* for IE7 */
*:first-child+html body {
	font-size: 75%;
}

/* for IE8 */
html>/**/body {
  
    font-size/*\**/: 75%\9;
}

a {
	color: #457AB2;
	text-decoration: underline;
	border: none;
	cursor:pointer; 
	outline: none; 
}

a:hover {
    text-decoration: none;
    color: #606060;
}

a img { 
outline: none;
}

a[href^="tel:"] {
    pointer-events: none;
}
/* -------------------------------------------------------------------------------

共通

------------------------------------------------------------------------------- */
#header_inner,
#contents,
.inner_contents,
.swiper-container{
    width: 1140px;
    margin-left: auto;
    margin-right: auto;
}
#main_contents{
    width: 800px;
    float: left;
    padding-bottom: 80px;
}

p{
    margin-bottom: 20px;
}
.ul_contents{
    margin-bottom: 20px;
}

.title01{
    background-color: #457AB2;
    padding-top: 30px;
    padding-bottom: 30px;
	padding-left: 15px;
    padding-right: 15px;
    font-size: 26px;
    color: #FFFFFF;
}


.title02{
    margin-bottom: 20px;
    background-color: #f3f3f3;
    font-size: 20px;
    padding-top: 15px;
    padding-left: 15px;
    padding-bottom: 15px;
    border-top: 2px solid #457AB2;
}
.title03{
	font-size: 18px;
	 padding-top: 10px;
    padding-left: 15px;
    padding-bottom: 10px;
	border-bottom: 1px solid #E8E8E8;
	margin-bottom: 20px;
}
.title04{
	font-size: 18px;
	margin-bottom: 10px;
}
.title05{
    font-weight: bold;	
}

.one_btn{
    display: block;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-left: 15px;
    font-weight: normal;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
    width: 350px;
    text-align: center;
    text-decoration: none;
    font-size: 16px;
    background-repeat: no-repeat;
    background-position: 99% 15px;
    background-size: 25px 25px;
    background-image: url(../image/yajirushiW.png);
    line-height: 25px;
    height: auto;
    color: #FFFFFF;
    background-color: #003466;
	
}

.btn_back{
    height: auto;
    display: block;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-left: 15px;
    font-weight: normal;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
    width: 300px;
    text-align: center;
    text-decoration: none;
    font-size: 16px;
    background-repeat: no-repeat;
    background-position: 1% 15px;
    background-size: 25px 25px;
    background-image: url(../image/yajirushiRW.png);
    line-height: 25px;
    color: #FFFFFF;
    background-color: #656565;
}


#PageTopBtn {
    position: fixed; /*ボタンの配置場所を固定*/
    bottom: -10px; /*下からのボタンの配置場所を指定*/
    right: 10px; /*右からのボタンの配置場所を指定*/
    z-index: 9999;	
}
#PageTopBtn a {
    display: block; /*配置の調整*/
    text-decoration: none; /*文字の下線を消す*/
    color: #fff; /*文字の色*/
    background-color: #003466; /*ボタンの背景色*/
    text-align: center; /*文字を中央に配置*/
    border-radius: 5%; /*ボタンの角を少し丸くする*/
    outline: none; /*クリックしたときの黒い枠を消す*/
}
#PageTopBtn a:hover {
    text-decoration: none;
    background-color: #0C477F; /*マウスオーバー時の背景色*/
}

#PageTopBtn {
    font-size: 10px;
}
#PageTopBtn a {
    width: 70px;
    height: 40px;
    padding: 15px 0;
}




/* -------------------------------------------------------------------------------

ヘッダー

------------------------------------------------------------------------------- */

#header{
    border-bottom: 1px solid #E8E8E8;
    height: 130px;
}


#header h1{
    font-size: 11px;
    line-height: 30px;
    font-weight: normal;
    height: 30px;
	margin-left: 20px;
}


.header_logo a {
    float: left;
    color: #000000;
    text-decoration: none;
    font-size: 28px;
    height: 100px;
    line-height: 90px;
}

#gnavi {
	float: right;
	margin-top: 35px;
	text-align: center;	
}

#gnavi li {
    float: left;
    padding-left: 30px;
    padding-right: 30px;
   
}

#gnavi li a{
    font-weight: bold;
    text-decoration: none;
    color: #313131;
    padding-bottom: 15px;	
	
}

.home #gnavi li .top,
.page-id-7 #gnavi li .business,
.page-id-9 #gnavi li .machine,
.page-id-11 #gnavi li .about,
.page-id-42 #gnavi li .contact,
.page-id-45 #gnavi li .contact,
.page-id-47 #gnavi li .contact{
    border-bottom: 3px solid #07569e;
    color: #07569E;
}

/* -------------------------------------------------------------------------------

トップページ

------------------------------------------------------------------------------- */
#top_bnner{
    background-image: url(../image/page/main_bnr_back.jpg);
    background-repeat: no-repeat;
    background-position: 50% 0%;
}
.top_catch_copy{
    width: 80%;
    height: auto;
	margin-top: 30px;
    margin-bottom: 60px;
    margin-left: 10%;
    margin-right: 10%;
}
#three_bnr li{
    width: 30%;
    margin-right: 5%;
    float: left;
	margin-bottom: 50px;
}
#three_bnr li:nth-child(3){
	  margin-right:0%;
}

#three_bnr li img{
    width: 80%;
    height: auto;
    margin-bottom: 10px;
    border-radius: 50%;
    margin-left: 10%;
    margin-right: 10%;
}
#three_bnr li h4{
    margin-bottom: 10px;
    font-size: 24px;
    text-align: center;
    color: #07569E;
}
#three_bnr li p{
    margin-bottom: 10px;
	text-align: center;
}
#top_news_contents li{
    padding-top: 15px;
    padding-bottom: 15px;
    border-bottom: 1px dotted #8B8B8B;
}
#top_news_contents li div{
   margin-bottom: 10px;
}
#top_news_contents span{
    padding: 3px;
    background-color: #E7E7E7;
    font-size: 11px;
    margin-right: 10px;
}

/* -------------------------------------------------------------------------------

ページ

------------------------------------------------------------------------------- */

#page_three_bnr li{
    width: 30%;
    margin-right: 5%;
    float: left;
	margin-bottom: 30px;
}
#page_three_bnr li:nth-child(3){
	  margin-right:0%;
}

#page_three_bnr li .img01{
    width: 100%;
    height: auto;
	margin-bottom: 20px;
}
#page_three_bnr li .img02{
    width: 100%;
    height: auto;
    margin-bottom: 10px;
	border-radius: 50%;
}
#page_three_bnr li h4{
    margin-bottom: 20px;
    font-size: 22px;
    
    color: #07569E;
}
#page_three_bnr li p{
    margin-bottom: 10px;
	
}

table{
    border-top: 1px solid #E8E8E8;
}

tr{
    
}

td{
    border-bottom: 1px solid #E8E8E8;
	padding: 10px;
}

#company_contents dl{
    border-bottom: 1px solid #E8E8E8;
}
#company_contents dt{
    width: 25%;
    float: left;
	padding-left: 5%;
    padding-top: 15px;
    padding-bottom: 15px;
}
#company_contents dd{
    width: 70%;
    float: right;
	padding-top: 15px;
    padding-bottom: 15px;
}


/* -------------------------------------------------------------------------------

個人情報

------------------------------------------------------------------------------- */

#privacy_contents{
    background-color: #FFFFFF;
    padding-top: 40px;
    padding-right: 60px;
    padding-left: 60px;
    padding-bottom: 80px;
    margin-bottom: 40px;
    
}
#privacy_contents  p{
	margin-bottom: 20px;
    
}


/* -------------------------------------------------------------------------------

blog

------------------------------------------------------------------------------- */



#archive_list_contents .li_contents{
   padding: 30px;
	border-bottom: 1px solid #E8E8E8;
	
}

/* サムネイルがある場合 */

#archive_list_contents .archive_news_thumbnail{
    width: 150px;
    height: 150px;
    float: left;
    position: relative;
    color: #FFFFFF;	
	
}
#archive_list_contents .news_thumbnail_cat  ul{
    width: 150px;
    height: 150px;
    display: flex; /* 要素をflexboxに対応させる */
    align-items: center; /* 縦方向の中央揃え */
    justify-content: center; /* 横方向の中央揃え */
    flex-direction: column; /* 子要素の並びを上から下にする（要素の改行に対応） */
    position: absolute;
    top: 0px;
    left: 0px;
   
}
#archive_list_contents .news_thumbnail_cat .topics,
#archive_list_contents .news_thumbnail_cat .seminar_news{
	 background-color: rgba(250,202,204,0.90)
}
#archive_list_contents .news_thumbnail_cat .hatsumou-camp,
#archive_list_contents .news_thumbnail_cat .hatsumou{
    background-color: rgba(183,219,236,0.90);
}
#archive_list_contents .news_thumbnail_cat .products_news,
#archive_list_contents .news_thumbnail_cat .impressions{
    background-color: rgba(132,204,201,0.90);
}
#archive_list_contents .news_thumbnail_cat .parfaitline-study-session,
#archive_list_contents .news_thumbnail_cat .parfaitline-tv,
#archive_list_contents .news_thumbnail_cat .este,
#archive_list_contents .news_thumbnail_cat .dna,
#archive_list_contents .news_thumbnail_cat .intestinal-activity{
    background-color: rgba(245,224,192,0.90);	
}

/* サムネイルがない場合 */
#archive_list_contents .news_cat ul{
    width: 150px;
    height: 150px;
    color: #FFFFFF;
    float: left;
    display: flex; /* 要素をflexboxに対応させる */
    align-items: center; /* 縦方向の中央揃え */
    justify-content: center; /* 横方向の中央揃え */
    flex-direction: column; /* 子要素の並びを上から下にする（要素の改行に対応） */
    background-color: #959595;
}

#archive_list_contents .news_cat .topics,
#archive_list_contents .news_cat .seminar_news,
#top_news_contents .topics,
#top_news_contents .seminar_news{
    background-color: rgba(250,202,204,1.00);
}
#archive_list_contents .news_cat .hatsumou-camp,
#archive_list_contents .news_cat .hatsumou,
#top_news_contents .hatsumou-camp,
#top_news_contents .hatsumou{
    background-color: #B7DBEC;
}
#archive_list_contents .news_cat .products_news,
#archive_list_contents .news_cat .impressions,
#top_news_contents .products_news,
#top_news_contents .impressions{
	background-color: #84ccc9;
}
#archive_list_contents .news_cat .parfaitline-study-session,
#archive_list_contents .news_cat .parfaitline-tv,
#archive_list_contents .news_cat .este,
#archive_list_contents .news_cat .dna,
#top_news_contents .intestinal-activity,
#top_news_contents .parfaitline-study-session,
#top_news_contents .parfaitline-tv,
#top_news_contents .este,
#top_news_contents .dna,
#top_news_contents .intestinal-activity{
    background-color: #F5E0C0;
	
}

#archive_list_contents .archive_list_detail_contents{
	float: right;
	 width: 550px;
}
.archive_list_detail_contents h3{
    font-size: 22px;
    margin-bottom: 20px;    
	
}

.archive_list_detail_contents .time{
    margin-bottom: 5px; 
}
.blog_list_detail_contents p{
    height: 6em;
}




/*詳細 */

.blog_detail_contents{
	margin-bottom: 30px;
	background-color: #ffffff;
    box-shadow: 4px 10px 20px rgba(0,0,0,0.15);
	
}

.blog_title{
    z-index: 0;
    overflow: hidden;
	width: 100%;
    height: 300px;
	object-fit: cover; /* 正方形に切り抜き */
	position: relative;
    
}
.blog_title::before{
  content: '';
  background: inherit;/*.bgImageで設定した背景画像を継承する*/
  -webkit-filter: blur(5px);
  -moz-filter: blur(5px);
  -o-filter: blur(5px);
  -ms-filter: blur(5px);
  filter: blur(5px);
  position: absolute;
  /*ブラー効果で画像の端がボヤけた分だけ位置を調整*/
  top: -5px;
  left: -5px;
  right: -5px;
  bottom: -5px;
  z-index: -1;/*重なり順序を一番下にしておく*/
	background-size: 100% auto;
	
	
}
.blog_detail_contents h2{
    font-size: 28px;
    color: #FFFFFF;
    text-align: center;
    text-shadow: 0px 0px 2px #999999;
    margin-top: 80px;
    margin-bottom: 20px;
    padding-left: 20px;
    padding-right: 20px;
}

.blog_title_staff_contents {
	position: relative;
	height:60px;
	margin-bottom: 30px;
}
.blog_title_staff_contents .inner{
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
 
}


.blog_title_staff_contents img {
    border-radius: 30px;
    float: left;
    width: 60px;
    height: 60px;
    margin-right: 10px;
}
.blog_title_staff_contents p{
    line-height: 60px;
    font-size: 18px;
    text-shadow: 0px 0px 2px #999999;
    color: #FFFFFF;
    font-weight: bold;
}


.blog_detail_contents .time{
    font-size: 15px;
    text-shadow: 0px 0px 2px #999999;
    color: #FFFFFF;
    font-weight: bold;
    text-align: center;
}

.blog_detail_contents .blog_contents{
    font-size: 16px;
    margin-bottom: 30px;
    padding: 60px;	
}
.blog_detail_contents .blog_contents img{
	max-width: 740px;
    height: auto;	
	margin-bottom: 20px;
}


.blog_detail_contents .blog_contents p{
	margin-bottom: 20px;
}



/*SNSボタン*/
.fa-hatena:before {
  font-family: Verdana;
  font-weight: bold;
  content: 'B!';
}
 
.share {
  margin-top: 40px;
  margin-bottom: 40px;
}
 
.share ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
 
.share ul:after {
  display: block;
  clear: both;
  content: '';
}
 
.share li {
  float: left;
  width: 25%;
  margin: 0;
  margin-top: 15px;
}
 
.share li a {
  font-size: 14px;
  display: block;
  padding: 10px;
  text-align: center;
  text-decoration: none;
  color: #fff;
}
 
.share li a:hover {
  opacity: .8;
}
 
.share li a:visited {
  color: #fff;
}
 
.tweet a {
  background-color: #55acee;
}
 
.facebook a {
  background-color: #315096;
}
 
.googleplus a {
  background-color: #dd4b39;
}
 
.hatena a {
  background-color: #008fde;
}
 
@media(max-width: 599px) {
  .share li {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    padding: 3px;
  }
  .share li i {
    font-size: 1.3em;
    padding-top: 3px;
  }
  .share li span {
    display: none;
  }
}

/*前へ次へボタン*/

#prev_next {
    border-top: 1px solid #E8E8E8;
    border-bottom: 1px solid #E8E8E8;
    padding-top: 20px;
    padding-bottom: 20px;
	margin-bottom: 50px;
  }
#prev_next #prev {
    width: 45%;
    float: left;
	border-right: 1px solid #E8E8E8;
	padding-right: 5%;
	
  }
#prev_next #next{
    width: 44%;
    float: right;
    text-align: right;
    padding-left: 5%;
}
#prev_next #prev_title,#prev_next #next_title{
    border: 1px solid #E8E8E8;
    padding-top: 5px;
    padding-right: 15px;
    padding-bottom: 5px;
    padding-left: 15px;
    margin-bottom: 10px;
    display: inline-block;
}
/* -------------------------------------------------------------------------------

サイド

------------------------------------------------------------------------------- */
#side{
    width: 300px;
    float: right;
	margin-bottom: 40px;
}


#side .side_bnr{
    margin-bottom: 40px;
}
#side .side_bnr li,
#side .side_bnr p{
    margin-bottom: 20px;
}
#side .side_bnr li img{
    width: 100%;
    height: auto;
}

#side .side_ul_contents {
    margin-bottom: 40px;
}


#side .side_ul_contents li {
    padding-top: 10px;
    padding-right: 10px;
    padding-bottom: 10px;
    padding-left: 10px;
	border-bottom: 1px solid #E8E8E8;
}




/* -------------------------------------------------------------------------------

コンタクトフォーム

------------------------------------------------------------------------------- */
#contact_contents{
   
}

#contact_contents .step_img{
    width: 86%;
    margin-bottom: 20px;
    margin-top: 20px;
    margin-left: 7%;
    margin-right: 7%;
}
#contact_contents .main_text{

    font-weight: bold;
    color: #003567;
}

#contact_contents p{
    margin-bottom: 20px;
    
}

.entry_privacy_contents{
	width: 90%;
	height: 90px;
	margin-bottom: 30px;
	padding: 5%;
	border: 1px solid #003567;
	overflow: auto;
	
 }



#contact_form_contents{
	margin-top: 30px;
    margin-bottom: 30px;
    margin-left: 60px;
    margin-right: 60px;
}
#contact_form_contents dl{
    margin-bottom: 30px;
}
#contact_form_contents dt{
    margin-bottom: 10px;
    font-size: 15px;
	
}
#contact_form_contents dd{
	margin-bottom: 20px;
	font-size: 15px;
}

#contact_form_contents .hissu{
    color: #BE0E0E;
    font-weight: bold;
    background-color: #E7CACA;
    padding-top: 5px;
	padding-bottom: 5px;
	padding-left: 10px;
	padding-right: 10px;
    margin-left: 10px;
    font-size: 10px;
}



#contact_form_contents p{
	margin-top: 20px;
    line-height: 18px;
    clear: left;
	padding-left: 20px;
	padding-right: 40px;
}

/* フォームのボーダーカラー*/
#contact_form_contents .textbox input[type=text],
#contact_form_contents .textbox input[type=email],
#contact_form_contents .textbox textarea,
.mwform-radio-field-text::before,
.mwform-checkbox-field-text::before{
border: 2px solid #6390a7;
}

/* フォームの選択時カラー*/
#contact_form_contents .textbox input:focus,
#contact_form_contents .textbox textarea:focus {
background: #daecf5;
outline: 0;
}
.mwform-radio-field input:checked + .mwform-radio-field-text,
.mwform-checkbox-field input:checked + .mwform-checkbox-field-text{
  color: #3C74A3;
}
.mwform-radio-field input:checked + .mwform-radio-field-text::after,
.mwform-checkbox-field input:checked + .mwform-checkbox-field-text::after{
  border-bottom: 3px solid #3C74A3;
  border-right: 3px solid #3C74A3;
}

#contact_form_contents .textbox input[type=text],
#contact_form_contents .textbox input[type=email]{
	width: 100%;
	height: 30px;
	border-radius: 4px;
	
}

#contact_form_contents .textbox textarea{
	width: 100%;
	border-radius: 4px;
	height: 150px;
	
}
#contact_form_contents .disabled input {
	background: #ffffff;
	-moz-user-select: none;
	-khtml-user-select: none;
	-webkit-user-select: none;
	border: 2px solid #FFFFFF;
	width: 100%;	
	
 }

.mwform-radio-field input,
.mwform-checkbox-field input{
 display: none;
}
.mwform-radio-field-text,
.mwform-checkbox-field-text{
  padding-left: 30px;
  position:relative;
  margin-right: 10px;
	
}
.mwform-radio-field-text::before,
.mwform-checkbox-field-text::before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 20px;
	height: 20px;
	border-radius: 4px;
	background-color: #FFFFFF;
}

.mwform-radio-field input:checked + .mwform-radio-field-text::after,
.mwform-checkbox-field input:checked + .mwform-checkbox-field-text::after{
  content: "";
  display: block;
  position: absolute;
  top: -5px;
  left: 5px;
  width: 12px;
  height: 18px;
  transform: rotate(40deg);
}



select::-ms-expand {
	display: none;
}

#contact_form_contents select {
	width: 100px;
	border: 1px solid #999;
	padding: 8px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: #eee;
	background: url(../image/arrow01.png) right 50% no-repeat, -webkit-linear-gradient(top, #fff 0%,#e5e5e5 100%);
	background: url(../image/arrow01.png) right 50% no-repeat, linear-gradient(to bottom, #fff 0%,#e5e5e5 100%);
	background-size: 20px, 100%;
}



#completed_contents {
	padding-top: 60px;
	padding-bottom: 60px;
}

#completed_contents h3 {
    text-align: center;
    font-variant: normal;
    font-size: 22px;
    margin-bottom: 20px;
}

#completed_contents p{
	text-align: center;
	margin-bottom: 40px;
}

#completed_contents {
	padding-top: 60px;
	padding-bottom: 60px;
}

#completed_contents h3 {
    text-align: center;
    font-variant: normal;
    font-size: 22px;
    margin-bottom: 20px;
}

#completed_contents p{
	text-align: center;
	margin-bottom: 40px;
}

/* -------------------------------------------------------------------------------

フッター

------------------------------------------------------------------------------- */


#footer{
    padding-top: 40px;
    background-color: #07569e;
    padding-bottom: 40px;
    color: #FFFFFF;
}
#footer a{
    color: #FFFFFF;
}

#footer img {
    float: left;
    margin-bottom: 30px;   
}

#fnavi {
	float: right;
	margin-top: 20px;
	text-align: center;	
}

#fnavi li {
    float: left;
    padding-left: 30px;
    padding-right: 30px;
   
}

#fnavi li a{
    font-weight: bold;
    text-decoration: none;
	
}

address{
    border-top: 1px solid #E8E8E8;
    font-family: 'Noto Sans JP', sans-serif;
    padding-top: 40px;
    text-align: center;
    font-size: 12px;
    clear: both;
}
/* -------------------------------------------------------------------------------

404

------------------------------------------------------------------------------- */

#not_found_contents{
    margin-left: 200px;
    margin-right: 200px;
    margin-top: 100px;
    margin-bottom: 100px;
    padding-top: 100px;
    padding-bottom: 100px;
    border: 1px solid #C4C4C4;
}
#not_found_contents p{
    text-align: center;
    padding-bottom: 30px;
    font-size: 18px;
}


/* -------------------------------------------------------------------------------

ipad用  CSS

------------------------------------------------------------------------------- */

@media only screen and (min-width:768px) and (max-width:1040px) {
	

.home_logo {
	height: 60vh; 
}

.home_top_img {
   height: 50vh; 
}
.home_logo img{
    width: 180px;
    height: auto;
    margin-bottom: 20px;
    margin-left: 10px;    
}
.home_logo h2{
    font-size: 20px;
    line-height: 35px;
    
	
}

}

