﻿@charset "UTF-8";

/*
ベースのサイズはtmplates.cssのbody設定で指定
30px //
    pc : font-size: 180%;
    sp : font-size: 120%;
25px //
    pc : font-size: 150%;
    sp : font-size: ;
20px //
    pc : font-size: 130%;
    sp : font-size: ;
18px //
    pc : font-size: 120%;
    sp : font-size: ;
15px //
    pc : font-size: auto;
    sp : font-size: auto;
13px //
    pc : font-size: 85%;
    sp : font-size: ;
12px //
    pc : font-size: 80%;
    sp : font-size: ;
*/

/***********************************
・body,ヘッダー,Gメニュー,フッター
(全ページに読み込みます)
************************************/

/***********************************
transition
************************************/
header,
h1,
h2,
p,
a,
strong,
span,
article {
  /*transition: all 1s ease-out;*/
}


/***********************************
html&body
************************************/
html {
	overflow-y: scroll;
  font-size: calc(100vw / 37.5);
}

html,body {
  height: auto;
  line-height: 1.7;
  /*文字詰め*/
  font-feature-settings: "palt";
  /*スマホの文字サイズ自動変更無効*/
	-webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  text-rendering: optimizeSpeed;
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
}

img {
  width: 100%;
  height: auto;
}

@media screen and (min-width: 769px) {  
    
  html {
    font-size: 62.5%;
  }
  
  body {
    font-size: 1.6rem;
  }
  
  #contentWrap {
    font-size: 1.6rem;
  }  
  
  #contentWrap.font_size_big {
    font-size: 120%;
  }
  
}

@media screen and (max-width:768px) {
  
  body {
    font-size: 1.4rem;
  }
  
}


/***********************************
Link Setting
************************************/
a:link {
  color: #0000FF;
}

a:visited,a:active {
}

/*電話番号リンク*/
a.tel {
  text-decoration: none;
}

/*ページトップコントローラー*/
#topcontrol {
  display: block;
  background-image: url("../images/scrollTopControl_arrow.svg");
  background-position: center center;
  background-size: 40% auto;
  background-repeat: no-repeat;
  background-color: #00A9E5;
  border-radius: 100px;
  -moz-border-radius: 100px;
  -webkit-border-radius: 100px;
  -khtml-border-radius: 100px;
  height: 60px;
  width: 60px;
  position:relative;
  transition: all 1s ease-out;
}

@media print,screen and (min-width:769px) {
  
  a:hover {
    opacity: .5;
  }
  
  /*ページトップコントローラー*/
  #topcontrol:hover {
    opacity: .5 !important;
  }
  
}

@media screen and (min-width:769px) and (max-width:1024px) {
}

@media screen and (max-width:768px) {
  
	a:hover {
		opacity: 1;
	}
	
	a.tel {
	}
  
  /*ページトップコントローラー*/
  #topcontrol {
    height: 45px;
    width: 45px;
  }  

}


/***********************************
main container
************************************/
.in-box {
	margin-left:auto;
	margin-right:auto;
	max-width:1000px;
	width:95%;
}

@media print,screen and (min-width:769px) {
  
  #contentWrap {
    margin-top: 90px;
  }  
	
	.pc {
		display:block;
	}

  .sp {
		display:none;
	}
  
}

@media screen and (max-width:768px) {
  
  #contentWrap {
    margin-top: 50px;
  }    
  
	.pc {
		display: none;
	}

	.sp {
		display: block;
	}
  
}


/***********************************
header
************************************/
header {
  position: fixed;
  width: 100%;
  background-color: #fff;
  top: 0;
  z-index: 10;
}

header .in-box {
  max-width: 2000px;
  width: 95%;
  position: relative;
}

header h1 {
  max-width: 333px;
  /*width: 45%;*/
  width: 22%;
  font-size: 0;
  z-index: 1;
}

/*会員登録数ボックス*/
header .reg_number {
  background-image: url("../images/icon_syach.svg");
  background-size: auto 70%;
  background-repeat: no-repeat;
  display: block;
  color: #fff;
  background-color: #00a9e5;
  border-radius: 5px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -khtml-border-radius: 5px;
  position:relative;
  text-align: center;
  font-size: 100%;
  font-weight: bold;
  max-width: 210px;
  width: 30%;
  position: absolute;
  right: 0;
  top: 17%;
}

header .reg_number span::before,
header .reg_number span::after {
  font-size: 85%;
  font-weight: normal;
}

header .reg_number span::before {
  content: "会員数";
  padding-right: 1%;
}

header .reg_number span::after {
  content: "団体";
  padding-left: 1%;
}

@media screen and (min-width:769px) and (max-width:1110px) {  
  
  header h1 {
    width: 25%;
    top: 35% !important;
  }
  
}

@media print,screen and (min-width:769px) {
  
  header .in-box {
    height: 90px;   
  }
  
	header h1 {
    position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }
  
  /*会員登録数ボックス*/
  header .reg_number {
    line-height: 2;
    background-position: center left 18%;
    padding-left: 1%;
  }
  
}

@media screen and (max-width:768px) {
  
	header .in-box {
    height: 50px;
	}
  
	header h1 {
    width: 160px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }
  
  /*会員登録数ボックス*/
  header .reg_number {
    right: 12%;
    padding-left: 7%;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    background-position: center left 10%;
  }
}


/***********************************
ドロワーメニュー
************************************/
.drawerMenu-fixd-body {
  position: fixed;
  overflow: hidden;
  width: 100%;
}

/*drawer menu navWrap*/
.navWrap {
  background-color: rgba(0,0,0,0.6);
  height: 100%;
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  display: none;
  z-index: 2;
}

@media print,screen and (min-width:769px) {
  
  /*pc時非表示*/
	.navWrap {
		display: none !important;
	}
  
}

/*drawer menu ボタン*/
@media print,screen and (min-width:769px) {
  
  /*pc時非表示*/
  #menu-btn {
		display: none !important;
	}
  
}

@media screen and (max-width:768px) {
	
	#menu-btn {
		border-radius: 5%;
		display: inline-block;
		height: 30px;
		position: absolute;
		right: 2.5%;
		top: 8px;
		width: 30px;
		z-index: 99999;
	}

	#menu-btn-icon {
		background-color: #000;
		display: block;
		height: 2px;
		left: 0;
		margin: 0px 0 0 0px;
		position: absolute;
		top: 50%;
		transition: .2s;
		width: 100%;
	}

	#menu-btn-icon::before,
	#menu-btn-icon::after {
		background-color: #000;
		display: block;
		content: "";
		height: 2px;
		left: 0;
		position: absolute;
		top: 50%;
		transition: .3s;
		width: 100%;
	}

	#menu-btn-icon::before {
		margin-top: -11px;
	}

	#menu-btn-icon::after {
		margin-top: 9px;
	}

	#menu-btn .close {
		background: transparent;
	}

	#menu-btn .close::before,
	#menu-btn .close::after {
		margin-top: 0;
	}

	#menu-btn .close::before {
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);		
	}

	#menu-btn .close::after {
		-webkit-transform: rotate(-135deg);
		transform: rotate(-135deg);		
	}	
}

/*main-nav-box 内*/
nav#main-nav-box .main-nav-inner {
  overflow: hidden;
}

nav#main-nav-box .main-nav-inner ul li a {
  text-decoration: none;
  color: #000;
}

/*テキストリサイズボタン*/
nav#main-nav-box .main-nav-inner ul li.font_size_change-box span {
  color: #fff;
  display: inline-block;
  cursor: pointer;
  background-color: #000064;
}

nav#main-nav-box .main-nav-inner ul li.font_size_change-box span.set {
  background-color: #999;
  cursor: default;
}

nav#main-nav-box .main-nav-inner ul li.font_size_change-box span.set:hover {
  opacity: 1 !important;
}

@media print,screen and (min-width:769px) { 
  
  nav#main-nav-box {
    position: absolute;
    right: 0;
    bottom: 18%;
    width: 100%;
  }
  
  /*pc時のメニュー表示*/
  nav#main-nav-box .main-nav-inner ul {
    text-align: right;
  }
  
  nav#main-nav-box .main-nav-inner ul li {
    display: inline-block;
    /*font-size: 85%;
    margin-right: 2%;*/
    font-size: 82%;
    margin-right: 1%;
  }
  
  nav#main-nav-box .main-nav-inner ul li span {
    padding: 0px 8px;
    display: inline-block;
  }  
  
  nav#main-nav-box .main-nav-inner ul li:last-child {
    margin-right: 0;
  }  
  
  nav#main-nav-box .main-nav-inner ul li.font_size_change-box span:hover {
    opacity: .5;
  }
  
}

@media screen and (min-width:769px) and (max-width:1110px) {  
  
  nav#main-nav-box .main-nav-inner ul li {
    font-size: 76%;
  }
  
}

@media screen and (max-width:768px) {
  
  nav#main-nav-box {
    -webkit-overflow-scrolling: touch;
    background-color: #fff;
    left: 0;
  } 
  
	nav#main-nav-box .main-nav-inner ul {		
		z-index: 9999;
	}
  
	nav#main-nav-box .main-nav-inner ul li {
    border-bottom: 1px solid #333;
	}
  
	nav#main-nav-box .main-nav-inner ul li a {
    display: block;
    padding: 15px;
    position: relative;
	}
  
	nav#main-nav-box .main-nav-inner ul li a::before {
    content: ">";
    padding-right: 10px;    
	}
  
  /*テキストリサイズボタン*/
  nav#main-nav-box .main-nav-inner ul li.font_size_change-box {
    display: none;
  }
  
}


/***********************************
footer
************************************/
footer {
  background-color: #f2f2f2;
}

footer h2 {
  display: block;
  text-align: center;
  background-color: #3a3a3a;
  color: #fff;
  font-size: 150%;
  line-height: 2.5;
}

footer .in-box {
  padding: 3% 0;
}

/*コンタクトボックス*/
footer dl {
  display: flex;
  margin-bottom: 3%;
}

footer dl dd strong {
  display: block;
  font-size: 120%;
}

footer dl dd ul.contact li {
  margin-top: 0;
}

footer dl dd ul.contact li a:link {
  color: #000;
  text-decoration: none;
}

footer dl dd ul.contact li a:visited,
footer dl dd ul.contact li a:active {
  color: #000;
}

footer dl dd ul.contact li span::before {
  content: "：";
  padding-right: .5em;
}

footer dl dd ul.contact li::before {
  width: 4.5em;
  display: inline-block;
}

footer dl dd ul.contact li:nth-child(1)::before {
  content: "住所"
}

footer dl dd ul.contact li:nth-child(2)::before {
  content: "電話番号"
}

footer dl dd ul.contact li:nth-child(3)::before {
  content: "E-mail"
}

/*
footer dl dd ul.contact li:nth-child(3)::before {
  content: "FAX番号"
}

footer dl dd ul.contact li:nth-child(4)::before {
  content: "E-mail"
}
*/

/*リンクボックス*/
footer ul.link-box {
  display: block;
}

/*コピーライト*/
footer small {
  display: block;
  text-align: center;
  background-color: #fff;
  line-height: 5;
  font-size: 80%;
}

@media print,screen and (min-width:769px) {
  
  /*コンタクトボックス*/
  footer dl dt {
    display: block;
    width: 100%;
    padding-right: 3%;
    margin-right: 3%;
    max-width: 160px;
    border-right: 1px solid #000;
  }  
  
  /*リンクボックス*/
  footer ul.link-box {
    text-align: right;
  }

  footer ul.link-box li {
    display: inline-block;
    margin-left: 3%;
  }
  
}

@media screen and (max-width:768px) {
  
  footer .in-box {
    padding: 5% 0;
  }  
  
  /*コンタクトボックス*/
  footer dl dt {
    display: none;
  }    
  
  footer dl dd strong {
    margin-bottom: 3%;
  }
  
  /*リンクボックス*/
  footer ul.link-box {
    display: block;
    text-align: left;
  }

  footer ul.link-box li {
    display: block;
  }
  
}

/************************************
** お問い合わせフォームの入力
************************************/
#cf-tbl{
width: 100%;
}

#cf-tbl table{
width: 100%;
border-collapse: collapse;
border: solid #CCC;
border-width: 1px;
color: #444;
}
#cf-tbl table tr th,
#cf-tbl table tr td{
padding: 0.5em;
text-align: left;
vertical-align: top;
border: solid #CCC;
border-width: 1px;
vertical-align: middle;
}
#cf-tbl table tr th{
width: 35%;
background: #eee;
}
@media screen and (max-width:768px){
#cf-tbl{
width: 95%;
}

#cf-tbl table,
#cf-tbl table tbody,
#cf-tbl table tr,
#cf-tbl table tr th,
#cf-tbl table tr td{
display: block;
}

#cf-tbl table{
width: 97%;
border-width: 0 0 1px 0;
}

#cf-tbl table tr th,
#cf-tbl table tr td{
width: 100%;
padding: 3% 5%;
}

#cf-tbl table tr td{
border-width: 0px 1px 0px 1px;
}
}
/*「必須」文字デザイン*/
.required{
font-size:.8em;
padding: 5px;
background: #F57500;
color: #fff;
border-radius: 3px;
margin-right: 5px;
}

/*「任意」文字デザイン*/
.optional{

}

/* 入力項目を見やすく */
input.wpcf7-form-control.wpcf7-text,
textarea.wpcf7-form-control.wpcf7-textarea {
	width: 93%;
	padding: 8px 15px;
	margin-right: 10px;
	margin-top: 10px;
	border: 1px solid #d0d5d8;
	border-radius: 3px;
	background-color: #eff1f5;
}
textarea.wpcf7-form-control.wpcf7-textarea {
	height: 200px;
}

/* 「送信する」ボタン */
input.wpcf7-submit {
    display: block;
    padding: 15px;
    width: 400px;
    background: #ffaa56;
    color: #fff;
    font-size: 18px;
    font-weight: 700;
    border-radius: 2px;
    margin: 15px auto 0
}
@media screen and (max-width:768px){
input.wpcf7-submit {
width: 250px;
}
}

input.wpcf7-submit:hover {
	box-shadow: 0 15px 30px -5px rgba(0,0,0,.15), 0 0 5px rgba(0,0,0,.1);
	transform: translateY(-4px);
	opacity:0.7;
}
/* エラーメッセージを見やすく */
span.wpcf7-not-valid-tip,
.wpcf7-response-output.wpcf7-validation-errors {
	color: red;
	font-weight: 600;
}
/************************************
** お問い合わせフォームの確認用
************************************/
/* テーブル */
#wpcf7cpcnf table {
width: 100%;
border-collapse: collapse;
border: solid #CCC;
border-width: 1px;
color: #444;
}
#wpcf7cpcnf table th {
padding: 0.5em;
text-align: left;
vertical-align: top;
border: solid #CCC;
border-width: 1px;
background: #eee;
vertical-align: middle;
}
#wpcf7cpcnf table td {
padding: 0.5em;
text-align: left;
vertical-align: top;
border: solid #CCC;
border-width: 1px;
vertical-align: middle;
}
/* ボタン */
#wpcf7cpcnf button {
    display: block;
    padding: 15px;
    width: 400px;
    background: #ffaa56;
    color: #fff;
    font-size: 18px;
    font-weight: 700;
    border-radius: 2px;
    margin: 15px auto 0
}

/* reCAPTCHA消す */
.grecaptcha-badge { visibility: hidden; }

/* アンケート */
/* センター */
.ancontact_item {
	margin-left:auto;
	margin-right:auto;
	max-width:1000px;
	width:95%;
}
/*  フォームの幅（自由に変えてOK） */
.ancontactForm {
	max-width: 700px;
	margin: 0 auto;
}
/* 項目名 */
.anlabel {
	display: block;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0.05em;
	margin-top: 4rem;
	margin-bottom: .6rem;
	font-weight: bold;
}
/* 必須タグと任意タグ共通のスタイル */
.anlabel_tag {
	font-size: 1.5rem;
	color: #ffffff;
	border-radius: .3rem;
	margin-right: 1rem;
	padding: 5px 10px;
}
/* 必須タグ */
.anlabel_must {
	background-color: #C84772;
}
/* CF7チェックボックスとラジオボタンを縦並びに */
span.wpcf7-list-item {
margin-top:5px;
display: block;
}
