﻿@charset "UTF-8";

@import url('//fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;600;700;900&display=swap');
@import url('//fonts.googleapis.com/css?family=Quicksand:300,400,500,700');
@import url('//fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700;900&display=swap');
@import url('//fonts.googleapis.com/css2?family=Montserrat:wght@200;300;400;500;600&display=swap');
@import url('//fonts.googleapis.com/css2?family=Josefin+Sans:wght@400;500;600;700&display=swap');


/*========================
ヘッダー
========================*/
header {
  width:100%;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  position: relative;
  z-index: 1;
  background: #FFF;
  padding-top: 100px;
  padding: 124px 15px 0;
}
header h1 {
  position: absolute;
  top: 32px;
  left:24px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  color: #49A37E;
  font-size: 1.6em;
  line-height: 1.4;
}
header h1 span{
  font-size: 0.7em;
  margin-right: 8px;
}
header img {
  z-index: 2;
}
canvas{
  position: absolute;
  bottom: 0;
  left:0;
  width: 100%;
}
@media screen and (max-width: 640px) {
header {
  padding: 84px 12px 0;
  }
header h1 {
  position: absolute;
  top: 15px;
  left:18px;
  font-size: 1.3em;
  }
header h1 span{
  display: block;
  }
}


/*========================
お知らせ
========================*/
.newswrap {
  width: 90%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 32px 32px;
  background: #FFF;
  border-radius: 20px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
}
@media screen and (max-width: 640px) {
.newswrap {
  padding: 38px 24px 24px;
  border-radius: 12px;
  -webkit-border-radius: 12px;
  -moz-border-radius: 12px;
  }
}

/*中身*/
.newsinner {
  width:100%;
  max-width: 1000px;
  margin: auto;
  padding:0;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  justify-content: center;
  align-items:center;
}
.newsinner_title {
  width: 30%;
  max-width: 320px;
  margin: 0 30px 0 0;
  text-align: center;
}
.newsinner_detail {
  width: 70%;
  max-width: 640px;
}
.newstitle_eng {
  font-family: 'Josefin Sans', sans-serif;
  font-size: 3.4em;
  font-weight: 700;
  line-height: 100%;
  white-space: nowrap;
  margin-bottom: 8px;
  color: #49A37E;
}
.newstitle_jpn {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.2em;
  font-weight: 900;
  line-height: 100%;
  white-space: nowrap;
  color: #999;
}
article {
  padding: 15px 0;
  border-bottom: 1px solid #BBB;
  line-height: 1.6;
  font-size: 0.9em;
}
article .date {
  font-family: 'Josefin Sans', sans-serif;
  font-size: 1.3em;
  color: #AAA;
  line-height: 1.5;
  font-weight: 500;
}
article > strong {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.15em;
  color: #49A37E;
  font-weight: 700;
  display: block;
  margin-bottom: 6px;
}
@media screen and (max-width: 1000px) {
.newsinner_title {
  max-width: 240px;
  }
}
@media screen and (max-width: 840px) {
.newsinner {
  flex-direction: column;
  display:block;
  }
.newsinner_title {
  width: 100%;
  max-width: 100%;
  margin: 0 0 32px 0;
  }
.newsinner_detail {
  width: 100%;
  max-width: 100%;
  }
}
@media screen and (max-width: 640px) {
.newstitle_eng {
  font-size: 3em;
  }
}


/*========================
季刊冊子「セルフコントロール」
========================*/
.bookletinfo {
  width:100%;
  margin: auto;
  padding:0;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  justify-content: center;
  align-items:center;
}
.bookletinfo_detail {
  width: 100%;
  flex: 1;
  margin: 0 30px 0 0;
}
.bookletinfo_img {
  width: 100%;
  max-width: 320px;
}
.booklet_title {
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8em;
  font-weight: 900;
  line-height: 1.6;
  margin-bottom: 32px;
  color: #48A37E;
}
@media screen and (max-width: 960px) {
.bookletinfo {
  align-items: flex-start;
  }
.bookletinfo_img {
  max-width: 240px;
  }
.booklet_title {
  font-size: 1.5em;
  }
}
@media screen and (max-width: 767px) {
.bookletinfo {
  flex-direction: column;
  display:block;
  }
.bookletinfo_detail {
  margin: 0 0 32px 0;
  }
.bookletinfo_img {
  max-width: 100%;
  }
.bookletinfo_img img{
  max-width: 200px;
  }
}
@media screen and (max-width: 640px) {
.booklet_title {
  font-size: 1.5em;
  margin-bottom: 24px;
  }
}

/*横線付き最新号見出し*/
.bookletinfo_detail h3{
  position: relative;
  padding: 0 1em;
  text-align: center;
  margin-bottom:8px ;
}
.bookletinfo_detail h4{
  padding: 0 12px 12px;
  border-bottom: 2px solid #49A37E;
}
.bookletinfo_detail h3:before {
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  width: 100%;
  height: 2px;
  content: '';
  background: #49A37E;
}
.bookletinfo_detail h3 span {
  position: relative;
  padding: 0 0.5em;
  background: #E0F1EA;
  font-weight: 900;
  font-size: 1.3em;
  letter-spacing: 0.03em;
  line-height: 100%;
}
@media screen and (max-width: 480px) {
.bookletinfo_detail h3 span {
  font-size: 1.2em;
  }
}

/*カバー風画像装飾 (季刊冊子)*/
.bookletcover {
  width: 100%;
  max-width: 320px;
  position: relative;
  box-shadow: 10px 15px 22px -5px rgba(0, 0, 0, 0.2),
  0 0 2px rgba(0, 0, 0, 0.15);
  border-radius: 8px 0 0 8px;
}
.bookletcover:after {    
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(
  -90deg,
  rgba(255, 255, 255, 0) 0%,
  rgba(255, 255, 255, 0.1) 80%,
  rgba(255, 255, 255, 0.4) 94%,
  rgba(255, 255, 255, 0.5) 96%,
  rgba(255, 255, 255, 0) 100%
  );
}
.bookletcoverimg {
  display: block;
  width: 100%;
  border-radius: 8px 0 0 8px;
}
@media screen and (max-width: 767px) {
.bookletcover {
  max-width: 200px;
  }
}


/*========================
定期研修会のご案内
========================*/
.workshopbox {
  width: 100%;
  margin: 0 auto;
  padding: 32px;
  background: #FFF;
  border-radius: 20px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
}
@media screen and (max-width: 767px) {
.workshopbox {
  padding: 24px;
  border-radius: 12px;
  -webkit-border-radius: 12px;
  -moz-border-radius: 12px;
  }
}
@media screen and (max-width: 480px) {
.workshopbox {
  padding: 18px 15px;
  }
}

details {
  transition: .5s;
}
summary {
  display: block;
  list-style: none;
  cursor: pointer;
}
summary::-webkit-details-marker {
  display:none;
}

.workshopbox h4{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  color: #777;
  font-size: 1.15em;
  line-height: 1.5;
  margin-bottom: 5px;
}
.workshopbox h3{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  color: #48A37E;
  font-size: 1.3em;
  line-height: 1.5;
}
.recomopen {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  color: #FFF;
  font-size: 1.05em;
  line-height: 1.5;
  margin: 20px 0 15px;
  text-align: center;
}
@media screen and (max-width: 767px) {
.workshopbox h4{
  font-size: 0.95em;
  margin-bottom: 2px;
  }
.workshopbox h3{
  font-size: 1.15em;
  }
.recomopen {
  font-size: 1em;
  margin: 18px 0 12px;
  }
}

/*GoogleMapリンク*/
.jumpmap {
  font-family: 'Josefin Sans', sans-serif;
  letter-spacing: 0.01em;
  font-weight: 700;
  font-size: 0.95em;
  text-decoration: none;
  white-space: nowrap;
  margin: 0;
  position: relative;
  display: inline-block;
  padding: 0 0.6em 0 0;
  vertical-align: middle;
  color: #D8982E;
  margin-left: 10px;
  line-height: 100%;
}
.jumpmap::after{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 0.5em;
  height: 0.5em;
  margin: auto;
  vertical-align: middle;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  border-top: 2px solid #D8982E;
  border-right: 2px solid #D8982E;
}


/*========================
定例会・催しのご案内
========================*/
.meetingbox {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  background: #FFF;
  border-radius: 20px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
}
@media screen and (max-width: 767px) {
.meetingbox {
  border-radius: 12px;
  -webkit-border-radius: 12px;
  -moz-border-radius: 12px;
  }
}

/* 中身*/
.meetinginner {
  width:100%;
  height: auto;
  margin: auto;
  padding:0;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  justify-content: center;
  align-items:stretch;
}
.meetinginner_img {
  width: 30%;
  height: auto;
  border-radius: 20px 0 0 20px;
  -webkit-border-radius: 20px 0 0 20px;
  -moz-border-radius: 20px 0 0 20px;
}
.meetinginner_detail {
  width: 70%;
  flex: 1;
  height: auto;
  padding: 32px;
}
.meetingbox h3{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  color: #48A37E;
  font-size: 1.3em;
  line-height: 1.5;
}
@media screen and (max-width: 1000px) {
.meetinginner_img {
  width: 28%;
  }
.meetinginner_detail {
  width: 72%;
  padding: 24px;
  }
}
@media screen and (max-width: 767px) {
.meetinginner {
  flex-direction: column;
  display:block;
  }
.meetinginner_img {
  width: 100%;
  height: 240px;
  border-radius: 12px 12px 0 0;
  -webkit-border-radius: 12px 12px 0 0;
  -moz-border-radius: 12px 12px 0 0;
  }
.meetinginner_detail {
  width: 100%;
  }
.meetingbox h3{
  font-size: 1.15em;
  }
}
@media screen and (max-width: 480px) {
.meetinginner_img {
  height: 160px;
  }
.meetinginner_detail {
  padding: 18px 15px;
  }
}

/* イメージ画像*/
.meetingimg01 {
  background-image: url(../img/meeting_img01.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center bottom;
}
.meetingimg02 {
  background-image: url(../img/meeting_img02.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
.meetingimg03 {
  background-image: url(../img/meeting_img03.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
.meetingimg04 {
  background-image: url(../img/meeting_img04.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
}
.meetingimg05 {
  background-image: url(../img/meeting_img05.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: left center;
}
.meetingimg06 {
  background-image: url(../img/meeting_img06.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}


/*========================
当協会について
========================*/
/*丸数字リスト*/
#ABOUTUS ol{
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
}
#ABOUTUS ol > li{
  padding-left: 2em;
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  margin-bottom: 12px;
}
#ABOUTUS ol > li:before{
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #49A37E;
  color: #FFF;
  display: block;
  float: left;
  line-height: 36px;
  margin-left: -2em;
  text-align: center;
  height: 32px;
  width: 32px;
  border-radius: 50%;
  font-family: 'Josefin Sans', sans-serif;
  font-weight: 600;
  font-size: 22px;
}
@media screen and (max-width: 640px) {
#ABOUTUS ol > li{
  padding-left: 1.8em;
  margin-bottom: 12px;
  }
#ABOUTUS ol > li:before{
  line-height: 27px;
  margin-left: -1.8em;
  height: 24px;
  width: 24px;
  font-size: 18px;
  }
}

/*賛助会費テーブル*/
.fee{
  width: 100%;
  border-collapse: collapse;
  line-height: 1.6;
  margin: 15px 0 0;
}
.fee tr{
  border: 1px solid #999;
  margin: 0 0 -1px;
}
.fee th{
  width: 50%;
  padding: 12px 12px;
  text-align:center;
  vertical-align: middle;
  background-color: #EEE;
  font-weight: 500;
  font-size: 1em;
}
.fee td{
  width: 50%;
  padding: 12px 12px;
  background-color: #FFF;
  text-align:right;
  vertical-align: middle;
  font-size: 1.1em;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 480px) {
.fee {
  margin: 12px 0 0;
  }
.fee th{
  padding: 2px 8px 5px;
  text-align:left;
  font-size: 0.85em;
  }
.fee td{
  padding: 5px 8px 8px;
  font-size: 0.9em;
  }
}

/* 関連書籍*/
.publication {
  width:100%;
  margin: auto;
  padding:0;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  justify-content: center;
  align-items:flex-start;
}
.publication_img {
  width: 100%;
  max-width: 240px;
  margin: 0 30px 0 0;
}
.publication_detail {
  width: 100%;
  flex: 1;
  padding: 10px 0 0;
}
.publication h4 {
  font-size: 1.8em;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 12px;
  color: #222;
}
.publication h4 span{
  font-size: 0.65em;
  font-weight: 600;
  line-height: 0.4;
  color: #222;
}
@media screen and (max-width: 767px) {
.publication {
  flex-direction: column;
  display:block;
  }
.publication_img {
  max-width: 100%;
  margin: 0 0 18px 0;
  }
.bookletinfo_img img{
  max-width: 200px;
  }
.publication_detail {
  padding: 0;
  }
}
@media screen and (max-width: 480px) {
.publication h4 {
  font-size: 1.6em;
  text-align: center;
  }
.publication h4 span{
  display: block;
  line-height: 1.4;
  margin-top: 5px;
  text-align: center;
  }
}

/*カバー風画像装飾 (関連書籍)*/
.bookcover {
  width: 100%;
  max-width: 240px;
  position: relative;
  box-shadow: 10px 15px 22px -5px rgba(0, 0, 0, 0.2),
  0 0 2px rgba(0, 0, 0, 0.15);
  border-radius: 3px;
}
.bookcover:after {    
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(
  -90deg,
  rgba(255, 255, 255, 0) 0%,
  rgba(255, 255, 255, 0.1) 80%,
  rgba(255, 255, 255, 0.4) 94%,
  rgba(255, 255, 255, 0.5) 96%,
  rgba(255, 255, 255, 0) 100%
  );
}
.bookcoverimg {
  display: block;
  width: 100%;
  border-radius: 3px;
}
@media screen and (max-width: 767px) {
.bookcover {
  max-width: 200px;
  }
}

/* 書店バナー並び*/
.bookstore {
  width:100%;
  margin: 12px 0;
  padding:0;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  justify-content: flex-start;
  align-items:flex-start;
}
.bookstore li{
  margin:0 10px 0 0;
}
.bookstore li img{
  width:100%;
  max-width: 140px;
}
.bookstore li:last-child{
  margin:0 0 0 0;
}
@media screen and (max-width: 480px) {
.bookstore li img{
  max-width: 120px;
  }
}


/*========================
お問い合わせ・お申し込み
========================*/
.contacttable {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0 0;
}
.contacttable tr{
  border: 1px solid #666;
  margin-bottom: -1px;
}
.contacttable th{
  width: 35%;
  padding: 15px 20px;
  text-align:left;
  vertical-align: middle;
  background-color: #EEE;
  font-weight:normal;
  line-height: 1.6;
}
.contacttable td{
  width: 65%;
  padding: 15px 20px;
  background-color: #FFF;
  text-align:left;
  vertical-align: middle;
}
@media screen and (max-width: 767px) {
.contacttable th,
.contacttable td {
  display:block;
  width:100%;
  }
.contacttable th{
  padding: 10px 15px;
  }
.contacttable td{
  padding: 10px 15px;
  }
}

/* 必須項目アイコン */
.hissu {
  font-size:0.75em;
  line-height:100%;
  color:#FFF;
  background-color:#CC3300;
  padding:2px 5px;
  margin-left:8px;
  font-weight:500;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

/*-------------------------
フォームスタイリング
--------------------------*/
/* 入力・選択欄 */
input[type='text'],
input[type='search'],
input[type='tel'],
input[type='url'],
input[type='email'],
input[type='password'],
input[type='datetime'],
input[type='datetime-local'],
input[type='date'],
input[type='month'],
input[type='week'],
input[type='time'],
input[type='number'],
select {
  -webkit-appearance:none;
  -moz-appearance:none;
  -ms-appearance:none;
  -o-appearance:none;
  appearance:none;
  width:100%;
  outline: none;
  border: 1px solid #AAA;
  background:#FFF;
  padding:0.5em;
  font-size:1.1em;
}
select::-ms-expand {
  display: none;
}
textarea{
  -webkit-appearance:none;
  -moz-appearance:none;
  -ms-appearance:none;
  -o-appearance:none;
  appearance:none;
  width:100%;
  outline: none;
  border: 1px solid #AAA;
  background:#FFF;
  padding:0.5em;
  font-size:1.1em;
  height:160px;
}
input::placeholder,
textarea::placeholder {
	color: #CCC;
}
/* Edge */
input::-ms-input-placeholder,
textarea::-ms-input-placeholder {
	color: #CCC;
}
/* IE11 & IE10 */
input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
	color: #CCC;
}
/* ラジオボタン・チェックボックス */
input[type="radio"] , 
input[type="checkbox"]{
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  margin:10px 6px 8px 0;
}
label {
  margin-right:1em;
  cursor:pointer;
  display: inline-block;
}
/* ボタン */
/* @import url('http://fonts.googleapis.com/earlyaccess/notosansjapanese.css'); */
input[type='submit'],
input[type='reset'],
input[type='button'],
.formbtn button{
  -webkit-appearance:none;
  -moz-appearance:none;
  -ms-appearance:none;
  -o-appearance:none;
  appearance:none;
  width: 100%;
  font-size:1.4em;
  cursor: pointer;
  padding: 20px 42px 24px;
  text-decoration: none;
  color: #FFF;
  text-align: center;
  font-weight: 700;
  background: rgb(102,102,102);
  background: linear-gradient(180deg, rgba(102,102,102,1) 0%, rgba(51,51,51,1) 100%);
  line-height: 100%;
  border: 0;
  letter-spacing: 0.06em;
  margin:0;
  font-family: "Noto Sans JP", sans-serif;
  border-radius: none;
}
