
*{
font-family: 'Noto Sans JP', sans-serif;
}

body{
	padding: 81px 0 0;
}
header{
	background: #0E3160;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 102;
}
footer{
	background:#F7F7F8;
}

header{
	padding: 0 50px 0 20px;
}
header .headWrap{
	height:81px;
	display:flex;
	align-items: center;
	justify-content: space-between;
}
header .logo{
	display:flex;
	align-items: center;	
}
header .logo img{
	width:auto;
	height:100%;
}
header .logo2{
	margin-left:10px;
}
header .logo2 img{
	width: 70px;
	height: auto;
}


header .menu ul{
	display:flex;
}
header .menu ul li{
	margin:0 0 0 30px;
}
header .menu ul li a{
	color:#FFF;
	font-size:16px;
	font-weight: 500;
	text-decoration: none;
}
header .menu ul li a:hover{
	text-decoration: underline;
}



/***************************
　　TOPページ
****************************/


.mainVisual.top{
	height: 740px;
	background:no-repeat url("../image/top/mainvisual.jpg")center center / cover;
	display:flex;
	align-items: center;
	justify-content: center;
}
.mainVisual.top h1{
	color: #FFF;
	text-align: center;
 font-family: "Noto Serif JP", serif;
	font-size: 54px;	
	font-weight: 600;
	text-shadow: 3px 3px 10px rgba(0, 0, 0, 0.4), -3px 3px 10px rgba(0, 0, 0, 0.4), -3px -3px 10px rgba(0, 0, 0, 0.4), 3px -3px 10px rgba(0, 0, 0, 0.4);
}
.mainVisual.top h1 span{
 font-family: "Noto Serif JP", serif;
	font-size: 27px;
	font-weight: 600;
}
.mainVisual.top h1 span.sub{
	font-size: 40px;
	font-weight: 600;
}
.scheduleSet {
	padding: 36px 0;
	background: #F7F7F8;
}
.scheduleSet .wrap .flexBox01 {
	display:flex;
	justify-content: space-between;
}
.scheduleSet .box {
	width: 548px;
	border: 1px solid #B4A583;
	padding:10px 12px 15px;
	background: #FFF;
}
.scheduleSet .title {
	font-size: 22px;
	text-align: center;
	color: #88733C;
	border-bottom: 1px solid #88733C;
	padding: 0 0 7px;
}
.scheduleSet .title span {
	position: relative;
}
.scheduleSet .title span:before {
	display: inline-block;
	position: absolute;
	content: "";
	width: 23px;
	height: 23px;
	background: no-repeat url("../image/top/icon_schedule.svg")center center / contain;
	left: -33px;
	top: 6px;
}
.scheduleSet ul {
	padding: 6px 0 0;
}
.scheduleSet li {
	font-size: 16px;
	margin: 8px 16px 0;
}
.scheduleSet li a {
	text-decoration: none;
}
.scheduleSet li a:hover{
	text-decoration: underline;
}
.scheduleSet li a span {
	font-weight: 500;
}
.scheduleSet .link {
	display: block;
	text-align: center;	
	padding: 10px 0;
}
.scheduleSet .link a {
	color: #88733C;
	font-size: 16px;
	font-weight: 500;
}
.scheduleSet .link a:hover {
	text-decoration: none;
}


.about {
	padding: 100px 0;
}
.title-h2 {
	text-align: center;
}
.title-h2 > span {
 font-family: "Barlow", sans-serif;
	font-size: 18px;
	font-weight: 600;
	color: #88733C;
	letter-spacing: 0.15em;
	position: relative;
}
.title-h2 > span:before {
	position: absolute;
	content: "";
	width: 25px;
	height: 1px;
	background: #88733C;
	left:-34px;
	top: 11px;
}
.title-h2 h2 {
	font-size: 28px;
	font-weight: 700;
	color: #5F5F5F;
	margin: 6px 0 30px;
}
.title-h2 h2 span {
	font-size: 22px;
}
.txt01 {
	font-size: 18px;
	text-align: center;
}
.btn01 {
	text-align: center;
	margin: 30px 0 0;
}
.btn01 a,
a .btn01 span{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 216px;
	height: 50px;
	border: 1px solid #0E3160;
	background: #0E3160 no-repeat url("../image/common/icon-linkbtn.svg") top 20px right 10px / 25px 5px; ;
	color: #FFF;
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	margin: 0 auto;
	transition: 0.3s;
}
.btn01 a:hover,
 a:hover .btn01 span{
	background: #FFF no-repeat url("../image/common/icon-linkbtn-hover.svg") top 20px right 10px / 25px 5px; ;
	color: #0E3160;
	text-decoration: none;
}
.about .image {
	margin: 70px 0 0;
}
.about .imageMain {
	margin: 0 0 6px;
}
.about .sponly .imageMain {
	margin: 0;
}
.about .imageSub {
        display:flex;
}


.meeting-report {
	background: #F7F7F8;
	padding: 100px 0;
}
.meeting-report .flexBox02 {
	margin: 54px 0 0;
	display: flex;
	justify-content: space-between;
}
.meeting-report .box {
	width: 358px;
	background: #FFF;
}
.meeting-report .box a {
	text-decoration: none;
	transition: 0.3s;
}
.meeting-report .box a:hover {
	opacity: 0.8;
}
.meeting-report .txtBlock {
	padding: 24px 26px 50px;
}
.meeting-report .date {
	font-size: 16px;
}
.meeting-report .name {
	font-size: 16px;
	line-height: 1.6;
	font-weight: 500;
	margin: 12px 0 20px;
	padding: 0 0 15px;
	position: relative;
}
.meeting-report .name:after {
	position: absolute;
	content:"";
	width: 35px;
	height: 1px;
	background: #B4A583;
	left: 0;
	bottom: 0;
}
.meeting-report .name > span {
	font-size: 25px;
	letter-spacing: 0.08em;
}
.meeting-report .name > span > span {
	font-size: 20px;
}
.meeting-report .txt {
	font-size: 18px;
}



.activity-report {
	background: no-repeat url("../image/top/activity-report_bg.png")0 0 / cover;
	padding: 100px 0;
}


.activity-report .title-h2 > span {
	color: #B4A583;
}
.activity-report .title-h2 > span:before {
	background: #B4A583;
}
.activity-report .title-h2 h2 {
	color: #FFF;
}
.activity-report .txt01 {
	color: #FFF;
}
.activity-report .flexBox02 {
	margin: 54px 0 0;
	display: flex;
	justify-content: space-between;
}
.activity-report .box {
	width: 358px;
	background: #FFF;
}
.activity-report .box a {
	text-decoration: none;
	transition: 0.3s;
}
.activity-report .box a:hover {
	opacity: 0.8;
}
.activity-report .txtBlock {
	padding: 24px 26px 50px;
}
.activity-report .date {
	font-size: 16px;
}
.activity-report .flexBox02 .name {
	font-size: 22px;
	line-height: 1.6;
	font-weight: 500;
	margin: 12px 0 20px;
	padding: 0 0 15px;
	position: relative;
	letter-spacing: 0.08em;
}
.activity-report .name:after {
	position: absolute;
	content:"";
	width: 35px;
	height: 1px;
	background: #B4A583;
	left: 0;
	bottom: 0;
}
.activity-report .name > span {
	font-size: 25px;
	letter-spacing: 0.08em;
}
.activity-report .name > span > span {
	font-size: 20px;
}
.activity-report .txt {
	font-size: 18px;
}


.joinBlock .wrap {
	padding: 100px 0;
}
.joinBlock .information {
	width: 736px;
	border: 1px solid #B4A583;
	padding: 5px;
	margin: 0 auto 100px;
}
.joinBlock .information .box {
	border: 1px solid #B4A583;
	padding: 40px 26px 32px;
}
.joinBlock .title-h2b {
	text-align: center;
	margin: 0 0 30px;
}
.joinBlock .title-h2b h2 {
	display: inline-block;
	font-size: 36px;
	font-weight: 500;
	letter-spacing: 0.08em;
	color: #88733C;
	position: relative;
}
.joinBlock .title-h2b h2:before {
	position: absolute;
	left: -76px;
	top:-8px;
	content: "";
	width: 70px;
	height: 70px;
	background: no-repeat url("../image/top/icon_infotitle.png")center center / contain;
}
.joinBlock h3 {
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	margin: 0 0 18px;
}
.joinBlock p {
	font-size: 18px;
	margin: 0 0 40px;
}

.joinBlock .flexBtn {
	display: flex;
	justify-content: space-between;
}
.joinBlock .flexBtn .btn {
	width: 270px;
	background: #0D3160;
	padding: 8px;
	
}
.joinBlock .flexBtn .btn a {	
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #FFF;
	background: #0D3160;
	color: #FFF;
	height: 100px;
	text-align: center;
	text-decoration: none;
	line-height: 1.8;
}
.joinBlock .flexBtn .btn a:hover {	
	background: #FFF;
	color: #0D3160;
}




footer {
	background: #F7F7F8;
	padding: 40px 0 150px;
}
footer .flexFooter {
	display: flex;
	justify-content: space-between;
}
footer .menu li {
	float: left;
	padding: 0 0 5px 30px;
}
footer .menu li:nth-child(6) {
	clear: both;
}
footer .menu li a {
	font-size: 16px;
	font-weight: 500;
	color: #0E3160;
	text-decoration: none;
}
footer .menu li a:hover {
	text-decoration: underline;
}



/*ハンバーガー*/
.overlay-menu {
  display: none;
  position: fixed;
  width: 100%;
  height: 100vh;
  overflow: auto;
  background-color:#0E3160;
  z-index: 100;
  top: 0;
}
.overlay-menu-btn {
  position: fixed;
  top: 0;
  right: 4%;
  height: 81px;
  cursor: pointer;
  z-index: 101;
	 display:flex;
	 align-items: center;
}
.scroll-prevent {   
	position: fixed;  
	  z-index: -1;   
	  width: 100%;   
	  height: 100%;
	 }
.overlay-menu-inner {
  padding: 10px 4% 40px 4%;
}
.overlay-menu-header {
  width: 60%;
  /*height: 60px;
  line-height: 60px;
  color: #333333;
  font-size: 32px;*/
}
.overlay-menu-item ul {
  margin: 20px 0;
  padding: 0;
  list-style-type: none;
}
.overlay-menu-item ul li {
  border-top: 1px solid #555;
}
.overlay-menu-item ul li.normal {
  border:0;
  position: relative;
  padding-left: 15px;
  margin-top: 10px;
}
.layer2-wrap{
	text-align: center;
}
ul.layer2{
	display: inline-block;
	margin: 0 auto;
	text-align: left;
}
.overlay-menu-item ul li.normal a{
	padding-top: 0;
	padding-bottom: 0;
}
.overlay-menu-item ul li.normal::before{
	content:">";
	position: absolute;	
	color: #fff;
	left:0;
}
.overlay-menu-item ul li.menu-list.bdb {
  border-bottom: 1px solid #555;
}
.overlay-menu-item ul li a {
  display: block;
  width: 100%;
  padding: 10px 0;
  color: #fff;
  text-decoration: none;
  transition: 0.5s;
}
.overlay-menu-item ul li ul{
	margin:0 0 0 0%;
	width:100%;
	border-top:1px solid #555;
}
.overlay-menu-item ul li ul li{
	margin:0 0 0 5%;
    padding-left:20px;
	width:95%;
	background:url(../image/common/list-whiteline.svg) no-repeat left center;
}
.overlay-menu-item ul li ul li:first-child{
	border-top:none;
}
.overlay-menu-inner div.submenu{
	max-height: 0;
	overflow-y: hidden;
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    -ms-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
}
.overlay-menu-inner div.submenu.open{
	max-height:1000px;
    -webkit-transition: all 0.8s;
    -moz-transition: all 0.8s;
    -ms-transition: all 0.8s;
    -o-transition: all 0.8s;
    transition: all 0.8s;
}

.overlay-menu .btns ul{
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-left: 0;
	margin-top: 20px;
}
.overlay-menu .btns .btn{
	flex:1;
}
.overlay-menu .btns .btn a{
display: flex;
align-items: center;
justify-content: center;
width: 90%;
margin: 5%;
background:transparent;
border:1px solid #fff;
text-decoration: none;
padding: 5px;
border-radius: 100vh;
color: #fff;

}



@media only screen and (min-width: 970px) and (max-width: 1320px) {
	header .menu ul li {
    margin: 0 0 0 1.4vw;
}
header .menu ul li a{
	font-size: 1.2vw;
}
}

@media only screen and (max-width: 1040px) {
	header .menu {
		display: none;
}	
header {
	z-index: 99;
}
}

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

body{
	padding: 51px 0 0;
}
header {
    padding: 0 0px;
}
header .headWrap{
	padding:5px 2%;
	height: 51px;
}
header .logo img{
	height: 44px;
}
header .menu,
header .logo2{
		display:none;
}		

.mainVisual.top{
	height: 200px;
	background:no-repeat url("../image/top/mainvisual-sp.jpg")center center / cover;
}
.mainVisual.top h1{
	font-size: 27px;	
}
.mainVisual.top h1 span{
	font-size: 13px;
}
.mainVisual.top h1 span.sub{
	font-size: 20px;	
}

.scheduleSet {
	padding: 28px 0;
}
.scheduleSet .wrap .flexBox01 {
	display:block;
}
.scheduleSet .box {
	width: 100%;
	padding:6px 10px 10px;
}
.scheduleSet .box:first-child {
	margin: 0 0 20px;
}
.scheduleSet .title {
	font-size: 18px;
	padding: 0 0 4px;
}
.scheduleSet .title span:before {
	width: 18px;
	height: 18px;
	background: no-repeat url("../image/top/icon_schedule.svg")center center / contain;
	left: -28px;
	top: 5px;
}
.scheduleSet ul {
	padding: 6px 0 0 10px;
}
.scheduleSet li {
	font-size: 14px;
	list-style: disc;
}
.scheduleSet .link a {
	font-size: 14px;
}


.about {
	padding: 50px 0;
}
.title-h2 {
	text-align: left;
}
.title-h2 > span {
	font-size: 14px;
	margin: 0 0 0 20px;
}
.title-h2 > span:before {
	position: absolute;
	content: "";
	width: 14px;
	height: 1px;
	background: #88733C;
	left:-20px;
	top: 7px;
}
.title-h2 h2 {
	font-size: 26px;
	margin: 6px 0 20px;
}
.title-h2 h2 span {
	font-size: 22px;
}
.txt01 {
	font-size: 17px;
	text-align: left;
	margin: 20px 0 0;
}
.about .image {
	margin: 0 calc(50% - 50vw);
	width: 100vw;
}


.meeting-report {
	padding: 50px 0;
}
.meeting-report .flexBox02 {
	margin: 30px 0 0;
	display: block;
}
.meeting-report .box {
	width: 100%;
}
.meeting-report .box:not(:last-child) {
	margin: 0 0 20px;
}

.activity-report {
	padding: 50px 0;
}
.activity-report .flexBox02 {
	margin: 30px 0 0;
	display: block;
}
.activity-report .box {
	width: 100%;
	background: #FFF;
}
.activity-report .box:not(:last-child) {
	margin: 0 0 20px;
}


.joinBlock .wrap {
	padding: 50px 0 10px;
}
.joinBlock .information {
	width: 90%;
	padding: 5px;
	margin: 0 5% 50px;
}
.joinBlock .information .box {
	padding: 20px;
}
.joinBlock .title-h2b {
	margin: 0 0 20px;
}
.join .title-h2b h2 {
	font-size: 29px;
}
.joinBlock .title-h2b h2:before {
	left: -64px;
	top:-4px;
	width: 56px;
	height: 56px;
	background: no-repeat url("../image/top/icon_infotitle.png")center center / contain;
}
.joinBlock h3 {
	font-size: 20px;
	margin: 0 0 18px;
}
.joinBlock p {
	font-size: 16px;
	margin: 0 0 20px;
}

.joinBlock .flexBtn {
	display: block;
}
.joinBlock .flexBtn .btn {
	width: 100%;	
}
.joinBlock .flexBtn .btn:not(:last-child) {
	margin: 0 0 10px;
}
.joinBlock .flexBtn .btn a {
	font-size: 22px;
}


footer {
	background: #F7F7F8;
	padding: 40px 0 50px;
}
footer .flexFooter {
	display: block;
}
footer .menu ul {
	display: flex;
	flex-wrap: wrap;
	padding: 30px 0 0;
}
footer .menu li {
	float: none;
	width: calc(50% - 20px);
	padding: 0;
	list-style: disc;
	margin-left: 20px;
}

.overlay-menu-btn {
  height: 51px;
}

}



.nolink {
	cursor: default;
}
a.nolink:hover {
	opacity: 1.0;
}
a.nolink img:hover {
	opacity: 1.0;
}
.meeting-report .box a.nolink:hover,
.activity-report .box a.nolink:hover,
.flexBox02 .box a.nolink:hover{
	opacity: 1.0;
}