/*
* fontawesomeセット
* content:'\○○○';
* font: var(--fa-font-solid);
*/
/*=====================================
*
*header
*
=======================================*/
body{
  background: #f8f8f8;
	word-break: break-all;
}
header{

}
header .header_inner{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
  position: relative;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
}
header .header_inner .global{

}
header .header_inner .global ol{
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
header .header_inner .global ol li{
  margin-right: 30px;
}
header .header_inner .global ol li:last-child{
  margin-right: 0;
}
header .header_inner .global ol li a{
  color: #111;
  font-size: 18px;
}
header .header_inner .global ol li a span{
  display: block;
  position: relative;
  padding-left: 20px;
  font-size: 14px;
  color: #444;
}
header .header_inner .global ol li a span::before{
  content: '';
  display: block;
  width: 10px;
  height: 1px;
  background: #111;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50% + 1px);
}
header .header_inner .global ol li.contact {
  height: 40px;
  width: 225px;
}
header .header_inner .global ol li.contact a{
  background: #0a4f9e;
  color: #fff;
  padding: 10px;
  text-align: center;
  width: 100%;
  border-radius: 500px;
  line-height: 1;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.menubtn{
	display: none;
}
@media screen and (max-width:1200px){
  header .header_inner .logo{
    width: 240px;
  }
  header .header_inner .global ol li a{
    font-size: 16px;
  }
}
@media screen and (max-width:960px){
  header .header_inner .global ol li {
    margin-right: 20px;
  }
  header .header_inner .global ol li a {
    font-size: 14px;
  }
  header .header_inner .global ol li.contact{
    width: 140px;
  }
}
@media screen and (max-width:760px){
  .front_title {
    font-size: 25px;
  }
  header .header_inner .global {
    position: fixed;
    top: 0;
    z-index: 99;
    height: 100vh;
    width: 70%;
    background: #fff;
    padding: 20px;
    padding-top: 60px;
    right: -70%;
    transition: ease all .4s;
  }
  header .header_inner .global.active{
    right: 0;
  }
  header .header_inner .global ol{
    display: block;
  }
  header .header_inner .global ol li{
    margin: 0;
  }
  header .header_inner .global ol li a {
    font-size: 16px;
    border-bottom: 1px solid #ccc;
    display: block;
    margin: 0;
    padding: 10px;
  }
  header .header_inner .global ol li.contact{
    width: 100%;
    margin-top: 40px;
    height: auto;
  }
  header .header_inner .global ol li.contact a{
    padding: 15px;
  }
  .menubtn{
    width: 40px;
    height: 40px;
    z-index: 999;
    position: fixed;
    right: 20px;
    top: 10px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }
  .menubtn span{
    display: block;
    width: 100%;
    height: 3px;
    background: #0a4f9e;
    position: relative;
    transition: ease all .4s;
    top: 0;
  }
  .menubtn.active span:nth-child(1){
    transform: rotate(45deg);
    top: 13px;
  }
  .menubtn.active span:nth-child(2){
    transform: rotate(-45deg);
  }
  .menubtn.active span:nth-child(3){
    opacity: 0;
    pointer-events: none;
  }
  .modal_bg{
    display: block;
    width: 100vw;
    height: 100vh;
    background: #000;
    opacity: 0;
    pointer-events: none;
    transition: ease all .4s;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 9;
  }
  .modal_bg.active{
    opacity: .3;
    pointer-events: all;
  }
}
a{
	transition: ease all .4s
}
a:hover{
	opacity: .7;
}
/*=====================================
*
*front
*
=======================================*/
.w12{
  max-width: 1200px;
  width: 100%;
  padding: 0 20px;
  margin: 0 auto;
}
.front_title{
  text-align: center;
  margin: 50px auto;
  font-size: 40px;
  font-weight: bold;
  color: #022b95;
}
.front_title span{
  font-size: 20px;
  display: block;
  font-weight: normal;
}
@media screen and (max-width:1200px){
  .front_title{
    font-size: 30px;
  }
}
@media screen and (max-width:960px){
  .front_title{
    font-size: 25px;
  }
  .front_title span {
    font-size: 18px;
  }
}
@media screen and (max-width:760px){

}
@media screen and (max-width:568px){
  .front_title {
    font-size: 20px;
    margin: 50px auto 20px;
  }
}
/*=====================================
*mv
=======================================*/
.mv{
  padding: 0 65px;
  position: relative;
}
.mv .text{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  max-width: 68%;
  min-width: 960px;
  width: 100%;
  padding: 0 20px;
  color: #fff;
  font-weight: bold;
  font-size: 30px;
}
.mv .text span{
  display: block;
  font-size: 45px;
}
@media screen and (max-width:1200px){
  .mv{
    padding: 0 20px;
  }
}
@media screen and (max-width:960px){
  .mv .text{
    min-width: 600px;
    font-size: 22px;
  }
  .mv .text span {
    font-size: 28px;
  }
}
@media screen and (max-width:760px){
  .mv .text {
    min-width: 85%;
    font-size: 18px;
    padding: 0;
  }
  .mv .text span {
    font-size: 21px;
  }
}
@media screen and (max-width:568px){
  .mv .text{
    min-width: 85%;
    font-size: 14px;
  }
  .mv .text span {
    font-size: 18px;
  }
}

/*=====================================
*section1
=======================================*/
.section1{
  position: relative;
  z-index: 2;
  margin-top: -140px;
}
.section1::before{
  content: '';
  display: block;
  width: 1200px;
  height: 600px;
  background: #f8f8f8;
  position: absolute;
  left: 50%;
  top: -50px;
  transform: translateX(-50%);
  border-radius: 50%;
  z-index: -1;
}
.section1 .sec1_flex{
  display: flex;
  justify-content: space-between;
  flex-flow: row-reverse;
  margin: 40px auto;
}
.section1 .sec1_flex .image{
  width: 40%;
}
.section1 .sec1_flex .text{
  width: 58%;
}
.section1 .sec1_flex .text h3{
  font-weight: bold;
  font-size: 40px;
  margin: 10px auto;
}
.section1 .sec1_flex .text .inner{
  margin-bottom: 40px;
}
.section1 .sec1_flex .text .inner .btn{
  display: flex;
  justify-content: flex-start;
}
.section1 .sec1_flex .text .inner .btn a{
  background: #0a4f9e;
  border-radius: 1px solid #022b95;
}
.section1 .sec1_flex .text .inner .btn a{
  width: 148px;
  color: #fff;
  text-align: center;
  margin-right: 10px;
  display: block;
  padding: 5px;
  border-radius: 500px;
}
.section1 .bottom_text{
  margin: 40px auto 80px;
}
.section1 .bottom_text h3{
  font-weight: bold;
  font-size: 30px;
  margin: 10px auto 25px;
}
.section1 .bottom_text{
}
.section1 .bottom_text .bot_flex{
  display: flex;
  justify-content: flex-start;
}
.section1 .bottom_text .bot_flex a{
  background: #fff;
  width: 470px;
  padding: 20px;
  margin-right: 35px;
  border: 1px solid #022b95;
  display: flex
  ;
      justify-content: space-between;
      align-items: center;
}
.section1 .bottom_text .bot_flex a span{
  font-size: 25px;
  font-weight: bold;
  color: #0a4f9e;
  display: block;
}
@media screen and (max-width:1200px){
  .section1{
    margin-top: -120px;
  }
  .section1::before {
    width: 70vw;
    height: 30vw;
    top: -20px;
  }
  .section1 .sec1_flex .text h3,
  .section1 .bottom_text h3{
    font-size: 28px;
  }
  .section1 .bottom_text .bot_flex a{
    width: 400px;
  }
  .section1 .bottom_text .bot_flex a span{
    font-size: 20px;
  }
}
@media screen and (max-width:960px){
  .section1::before{
    top: -15px;
  }
  .section1 .sec1_flex .text h3,
  .section1 .bottom_text h3{
    font-size: 22px;
  }
  .section1 .bottom_text .bot_flex{
    justify-content: space-between;
  }
  .section1 .bottom_text .bot_flex a{
    margin-right: 0;
    width: 48%;
  }
}
@media screen and (max-width:760px){
  .section1{
    margin-top: -60px;
  }
  .section1 .sec1_flex{
    display: block;
  }
  .section1 .sec1_flex .image{
    width: 100%;
    text-align: center;
  }
  .section1 .sec1_flex .text {
    width: 100%;
    margin-top: 40px;
  }
  .section1 .bottom_text .bot_flex{
    display: block;
  }
  .section1 .bottom_text .bot_flex a{
    width: 100%;
    margin: 40px auto;
  }
}
@media screen and (max-width:568px){
  .section1 .bottom_text .bot_flex a span {
    font-size: 16px;
  }
}
/*=====================================
*section2
=======================================*/
.section2 .table {
  width: 100%;
  min-height: 320px;
  display: flex;
  justify-content: space-between;
  margin: 40px auto;
  background: #fff;
  color: #022b95;
}
.section2 .table .inner01{
  padding: 20px;
  width: 490px;
  border: 1px solid #bfc9e4;
  border-right: none;
}
.section2 .table .inner02{
	width: 84px;
	border: 1px solid #bfc9e4;
	border-right: none;
	display: grid;
	grid-template-rows: 90px repeat(auto-fit, minmax(54px, 1fr));
}
.section2 .table .inner03,
.section2 .table .inner04{
	width: 210px;
	display: grid;
	grid-template-rows: 46.5px 43.5px repeat(auto-fit, minmax(54px, 1fr));
	border: 1px solid #bfc9e4;
	border-right: none;
}
.section2 .table .inner05{
  width: 180px;
  border: 1px solid #bfc9e4;
}
.section2 .table .inner02 .title{
  padding: 10px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 1px solid #bfc9e4;
  line-height: 1.5;
  font-weight: bold;
}
.section2 .table .inner03 .title,
.section2 .table .inner04 .title{
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 1px solid #bfc9e4;
  line-height: 1.5;
  font-weight: bold;
	height: 46.5px;
}
.section2 .table .inner03 .title_sub,
.section2 .table .inner04 .title_sub{
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #bfc9e4;
}
.section2 .table .inner03 .title_sub .title_sub_inner,
.section2 .table .inner04 .title_sub .title_sub_inner{
  width: calc( 100% / 3 );
  text-align: center;
  padding: 10px;
}
.section2 .table .inner03 .title_sub .title_sub_inner:nth-of-type(2),
.section2 .table .inner04 .title_sub .title_sub_inner:nth-of-type(2){
  border-right: 1px solid #bfc9e4;
  border-left: 1px solid #bfc9e4;
}
.section2 .table .inner01 .date {
  font-size: 20px;
}
.section2 .table .inner01 .title{
  font-weight: bold;
  font-size: 25px;
  margin: 20px auto;
}
.section2 .table .inner01 .people{
  font-size: 18px;
  font-weight: bold;
  margin: 20px auto;
}
.section2 .table .inner01 .place{
  font-size: 18px;
  font-weight: bold;
}
.section2 .table .inner02 .content .content_inner{
  height: 231px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  font-weight: bold;
}
.section2 .table .inner03 .content,
.section2 .table .inner04 .content{
  display: flex;
  justify-content: space-between;
}
.section2 .table .inner02 .content:nth-child(n + 4),
.section2 .table .inner03 .content:nth-child(n + 4),
.section2 .table .inner04 .content:nth-child(n + 4){
	border-top: 1px solid #bfc9e4;
}
.section2 .table .inner03 .content .content_inner,
.section2 .table .inner04 .content .content_inner{
  width: calc( 100% / 3 );
  text-align: center;
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  font-weight: bold;
}
.section2 .table .inner03 .content .content_inner:nth-of-type(2),
.section2 .table .inner04 .content .content_inner:nth-of-type(2){
  border-right: 1px solid #bfc9e4;
  border-left: 1px solid #bfc9e4;
}
.section2 .table .inner05 .content{
  padding: 10px;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.section2 .table .inner05 .content .btn{
  width: 100%;
  display: block;
}
.section2 .table .inner05 .content .btn a{
  width: 100%;
  margin: 20px auto;
  display: block;
  background: #022b95;
  color: #fff;
  padding: 10px;
  text-align: center;
}
.section2 .section_btn{
  text-align: center;
}
.section2 .section_btn a{
  color: #022b95;
  font-size: 20px;
  position: relative;
}
.section2 .section_btn a::before{
  content: '';
  display: block;
  background: #022b95;
  width: 80px;
  height: 1px;
  left: 50%;
  bottom: -5px;
  position: absolute;
  transform: translateX(-50%);
}
@media screen and (max-width:1200px){
  .section2 .table .inner01{
    width: calc( 100% - 670px );
  }
  .section2 .table .inner01 .date,
  .section2 .table .inner01 .people,
  .section2 .table .inner01 .place {
    font-size: 16px;
  }
  .section2 .table .inner01 .title{
    font-size: 20px;
  }
}
@media screen and (max-width:960px){
  .section2 .table {
    display: block;
    min-height: auto;
  }
  .section2 .table .inner01{
    width: 100%;
    border-right: 1px solid #bfc9e4;
    border-bottom: none;
  }
  .section2 .table .inner02{
    width: 100%;
  }
  .section2 .table .inner02 .title{
    text-align: center;
    height: auto;
    font-size: 20px;
    background: #bfc9e4;
  }
  .section2 .table .inner02 .title .spnone{
    display: none;
  }
  .section2 .table .inner02 .content .content_inner{
    height: auto;
    padding: 10px;
  }
  .section2 .table .inner03,
  .section2 .table .inner04{
    width: 100%;
  }
  .section2 .table .inner03 .title,
  .section2 .table .inner04 .title{
    font-size: 20px;
    background: #bfc9e4;
  }
  .section2 .table .inner03 .content .content_inner,
  .section2 .table .inner04 .content .content_inner{
    height: auto;
  }
  .section2 .table .inner02 .content .content_inner,
  .section2 .table .inner03 .title_sub .title_sub_inner:last-of-type,
  .section2 .table .inner04 .title_sub .title_sub_inner:last-of-type,
  .section2 .table .inner03 .content .content_inner:last-of-type,
  .section2 .table .inner04 .content .content_inner:last-of-type {
    border-right: 1px solid #bfc9e4;
  }
  .section2 .table .inner05{
    width: 100%;
    border-top: none;
  }
}

/*=====================================
*section3
=======================================*/
.section3{
  background: #bfc9e4;
  overflow: hidden;
  margin: 80px auto;
}
.section3 .sec3_list{
  margin: 60px auto;
}
.section3 .sec3_list ol{
  display: flex;
  flex-wrap: wrap;
}
.section3 .sec3_list ol li{
  width: 278px;
  background: #fff;
  border-radius: 10px;
  margin-right: 16px;
  margin-bottom: 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 86px;
	overflow: hidden;
}
.section3 .sec3_list ol li:nth-child(4n){
  margin-right: 0;
}
.section3 .sec3_list ol li a{
	display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
	position: relative;
	transition: ease all .4s;
}
.section3 .sec3_list ol li a:hover{
	opacity: .7;
}
@media screen and (max-width:1200px){
  .section3 .sec3_list ol li{
    width: 23.5%;
    margin-right: 2%;
    padding: 10px;
  }
}
@media screen and (max-width:960px){
  .section3 .sec3_list ol li,
  .section3 .sec3_list ol li:nth-child(4n){
    width: 32%;
    margin-right: 2%;
  }
  .section3 .sec3_list ol li:nth-child(3n){
    margin-right: 0;
  }
}

/*=====================================
*banner
=======================================*/
.banner{
  margin: 80px auto;
  position: relative;
}
.banner .image{
  text-align: center;
}
.banner .image a{
	transition: ease all .4s;
}
.banner .image a:hover{
	opacity: .7;
}
/*=====================================
*section5
=======================================*/

/*=====================================
*section6
=======================================*/

/*=====================================
*section7
=======================================*/

/*=====================================
*section8
=======================================*/

/*=====================================
*section9
=======================================*/

/*=====================================
*section10
=======================================*/


/*=====================================
*
*single
*
=======================================*/
#single{
	background: #fff;
}
#single .thumb{
	overflow: hidden;
	height: 350px;
	position: relative;
}
#single .thumb .image{
	overflow: hidden;
	height: 100%;
	position: relative;
}
#single .thumb .image img{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
}
#single .thumb .image::after{
	content: '';
    display: block;
    width: 100%;
    height: 100%;
    background: #000;
    position: absolute;
    left: 0;
    top: 0;
    opacity: .5;
}
#single .thumb h1{
	text-align: center;
	width: 100%;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	color: #fff;
	font-weight: bold;
	font-size: 40px;
}
#single .precautions{
	max-width: 1160px;
    width: calc( 100% - 40px );
    padding: 30px 40px;
    margin: 0 auto;
	background: #f8f7f6;
}
#single .contents ol,
#single .contents ul{
	padding: 0;
	background: none;
	border: none;
}
#single .contents ol li,
#single .contents ul li{
	margin: 10px auto;
}
#single .contents ol li::before,
#single .contents ul li::before{
	content: none;
}
#single .seminar_top_contents{
	text-align: center;
	color: #022b95;
	margin: 40px auto;
}
#single .seminar_top_contents h2{
	font-weight: bold;
	font-size: 40px;
}
#single .seminar_top_contents .en_title{
	font-size: 20px;
}
#single .seminar_bottom{
	margin: 40px auto;
	background: #bfc9e4;
	overflow: hidden;
}
#single .seminar_bottom .seminar_bottom_inner{
	max-width: 1160px;
    width: calc( 100% - 40px );
    margin: 40px auto;
	display: flex;
	justify-content: space-between;
}
#single .seminar_bottom .seminar_bottom_inner .text{
	width: 55%;
}
#single .seminar_bottom .seminar_bottom_inner .text h2{
	font-size: 40px;
	font-weight: 600;
}
#single .seminar_bottom .seminar_bottom_inner .text p{
	font-size: 16px;
	margin: 20px auto;
	line-height: 1.8;
}
#single .seminar_bottom .seminar_bottom_inner .requirement{
	width: 43%;
	background: #fff;
	padding: 40px;
	padding-bottom: 20px;
	font-weight: 500;
}
#single .seminar_bottom .seminar_bottom_inner .requirement .btn{
	background: #022b95;
	color: #fff;
	padding: 15px;
	text-align: center;
	margin: 30px auto;
	font-weight: 500;
}
#single .seminar_bottom .seminar_bottom_inner .requirement .btn span{
	color: #fff47a;
	display: block;
}
#single .single_banner_top{
	padding: 20px;
	text-align: center;
	margin: 20px auto;
	background: #f8f7f6;
}
#single .seminar_table .seminar_table_inner {
	color: #022b95;
}
#single .seminar_table .seminar_table_inner .date{
	font-weight: 600;
}
#single .seminar_banner_bottom{
    margin: 0 auto;
    text-align: center;
	padding-bottom: 60px;
}
@media screen and (max-width:768px){
	#single .thumb{
		height: 200px;
	}
	#single .thumb .image img{
		max-width: inherit;
		height: 100%;
		width: auto;
	}
	#single .thumb h1{
		font-size: 24px;
	}
	#single .precautions{
		padding: 20px;
    	margin: 20px auto;
	}
	#single .seminar_top_contents h2{
		font-size: 24px;
	}
	#single .seminar_top_contents .en_title{
		font-size: 18px;
	}
	#single .contents ol li,
	#single .contents ul li{
		margin: 10px auto;
		font-size: 14px;
	}
	#single .seminar_bottom .seminar_bottom_inner{
		display: block;
	}
	#single .seminar_bottom .seminar_bottom_inner .text{
		width: 100%;
	}
	#single .seminar_bottom .seminar_bottom_inner .text h2{
		font-size: 24px;
	}
	#single .seminar_bottom .seminar_bottom_inner .text p{
		font-size: 14px;
	}
	#single .seminar_bottom .seminar_bottom_inner .requirement{
		width: 100%;
		padding: 20px;
		padding-bottom: 0;
        overflow: hidden;
	}
	#single .seminar_bottom .seminar_bottom_inner .requirement .btn{
		margin: 10px auto 20px;
	}
}



#single .seminar_table .seminar_table_inner {
  width: 100%;
  min-height: 320px;
  display: flex;
  justify-content: space-between;
  margin: 10px auto 40px;
  background: #fff;
  color: #022b95;
}
#single .seminar_table .seminar_table_inner .inner01{
  padding: 20px;
  width: 490px;
  border: 1px solid #bfc9e4;
  border-right: none;
}
#single .seminar_table .seminar_table_inner .inner02{
	width: 84px;
	border: 1px solid #bfc9e4;
	border-right: none;
	display: grid;
	grid-template-rows: 90px repeat(auto-fit, minmax(54px, 1fr));
}
#single .seminar_table .seminar_table_inner .inner03,
#single .seminar_table .seminar_table_inner .inner04{
	width: 210px;
	display: grid;
	grid-template-rows: 46.5px 43.5px repeat(auto-fit, minmax(54px, 1fr));
	border: 1px solid #bfc9e4;
	border-right: none;
}
#single .seminar_table .seminar_table_inner .inner05{
  width: 180px;
  border: 1px solid #bfc9e4;
}
#single .seminar_table .seminar_table_inner .inner02 .title{
  padding: 10px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 1px solid #bfc9e4;
  line-height: 1.5;
  font-weight: bold;
}
#single .seminar_table .seminar_table_inner .inner03 .title,
#single .seminar_table .seminar_table_inner .inner04 .title{
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 1px solid #bfc9e4;
  line-height: 1.5;
  font-weight: bold;
	height: 46.5px;
}
#single .seminar_table .seminar_table_inner .inner03 .title_sub,
#single .seminar_table .seminar_table_inner .inner04 .title_sub{
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #bfc9e4;
}
#single .seminar_table .seminar_table_inner .inner03 .title_sub .title_sub_inner,
#single .seminar_table .seminar_table_inner .inner04 .title_sub .title_sub_inner{
  width: calc( 100% / 3 );
  text-align: center;
  padding: 10px;
}
#single .seminar_table .seminar_table_inner .inner03 .title_sub .title_sub_inner:nth-of-type(2),
#single .seminar_table .seminar_table_inner .inner04 .title_sub .title_sub_inner:nth-of-type(2){
  border-right: 1px solid #bfc9e4;
  border-left: 1px solid #bfc9e4;
}
#single .seminar_table .seminar_table_inner .inner01 .date {
  font-size: 20px;
}
#single .seminar_table .seminar_table_inner .inner01 .title{
  font-weight: bold;
  font-size: 25px;
  margin: 20px auto;
}
#single .seminar_table .seminar_table_inner .inner01 .people{
  font-size: 18px;
  font-weight: bold;
  margin: 20px auto;
}
#single .seminar_table .seminar_table_inner .inner01 .place{
  font-size: 18px;
  font-weight: bold;
}
#single .seminar_table .seminar_table_inner .inner02 .content .content_inner{
  height: 231px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  font-weight: bold;
}
#single .seminar_table .seminar_table_inner .inner03 .content,
#single .seminar_table .seminar_table_inner .inner04 .content{
  display: flex;
  justify-content: space-between;
}
#single .seminar_table .seminar_table_inner .inner02 .content:nth-child(n + 4),
#single .seminar_table .seminar_table_inner .inner03 .content:nth-child(n + 4),
#single .seminar_table .seminar_table_inner .inner04 .content:nth-child(n + 4){
	border-top: 1px solid #bfc9e4;
}
#single .seminar_table .seminar_table_inner .inner03 .content .content_inner,
#single .seminar_table .seminar_table_inner .inner04 .content .content_inner{
  width: calc( 100% / 3 );
  text-align: center;
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  font-weight: bold;
}
#single .seminar_table .seminar_table_inner .inner03 .content .content_inner:nth-of-type(2),
#single .seminar_table .seminar_table_inner .inner04 .content .content_inner:nth-of-type(2){
  border-right: 1px solid #bfc9e4;
  border-left: 1px solid #bfc9e4;
}
#single .seminar_table .seminar_table_inner .inner05 .content{
  padding: 10px;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
#single .seminar_table .seminar_table_inner .inner05 .content .btn{
  width: 100%;
  display: block;
}
#single .seminar_table .seminar_table_inner .inner05 .content .btn a{
  width: 100%;
  margin: 20px auto;
  display: block;
  background: #022b95;
  color: #fff;
  padding: 10px;
  text-align: center;
}
@media screen and (max-width:1200px){
  #single .seminar_table .seminar_table_inner .inner01{
    width: calc( 100% - 670px );
  }
  #single .seminar_table .seminar_table_inner .inner01 .date,
  #single .seminar_table .seminar_table_inner .inner01 .people,
  #single .seminar_table .seminar_table_inner .inner01 .place {
    font-size: 16px;
  }
  #single .seminar_table .seminar_table_inner .inner01 .title{
    font-size: 20px;
  }
}
@media screen and (max-width:960px){
  #single .seminar_table .seminar_table_inner {
    display: block;
    min-height: auto;
  }
  #single .seminar_table .seminar_table_inner .inner01{
    width: 100%;
    border-right: 1px solid #bfc9e4;
    border-bottom: none;
  }
  #single .seminar_table .seminar_table_inner .inner02{
    width: 100%;
  }
  #single .seminar_table .seminar_table_inner .inner02 .title{
    text-align: center;
    height: auto;
    font-size: 20px;
    background: #bfc9e4;
  }
  #single .seminar_table .seminar_table_inner .inner02 .title .spnone{
    display: none;
  }
  #single .seminar_table .seminar_table_inner .inner02 .content .content_inner{
    height: auto;
    padding: 10px;
  }
  #single .seminar_table .seminar_table_inner .inner03,
  #single .seminar_table .seminar_table_inner .inner04{
    width: 100%;
  }
  #single .seminar_table .seminar_table_inner .inner03 .title,
  #single .seminar_table .seminar_table_inner .inner04 .title{
    font-size: 20px;
    background: #bfc9e4;
  }
  #single .seminar_table .seminar_table_inner .inner03 .content .content_inner,
  #single .seminar_table .seminar_table_inner .inner04 .content .content_inner{
    height: auto;
  }
  #single .seminar_table .seminar_table_inner .inner02 .content .content_inner,
  #single .seminar_table .seminar_table_inner .inner03 .title_sub .title_sub_inner:last-of-type,
  #single .seminar_table .seminar_table_inner .inner04 .title_sub .title_sub_inner:last-of-type,
  #single .seminar_table .seminar_table_inner .inner03 .content .content_inner:last-of-type,
  #single .seminar_table .seminar_table_inner .inner04 .content .content_inner:last-of-type {
    border-right: 1px solid #bfc9e4;
  }
  #single .seminar_table .seminar_table_inner .inner05{
    width: 100%;
    border-top: none;
  }
}




/*=====================================
*
*page
*
=======================================*/
#page{
	background: #fff;
	overflow: hidden;
}
#page .news .w12{
	position: relative;
	z-index: 2;
}
#page .news_logo{
	text-align: center;
	padding: 10px;
}
#page .news_header {
    padding: 0 65px;
    position: relative;
}
#page .news_header figure{
	position: relative;
}
#page .news_header figure::after{
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: #444;
    opacity: .3;
}
#page h1{
    font-size: 40px;
    text-align: center;
	margin: 60px auto;
}
#page .business-profile{
	
}
#page .business-profile ol{
	margin: 20px auto 40px;
}
#page .business-profile ol li{
	margin: 15px 0;
	list-style: none;
}
#page .news_header h1{
	position: absolute;
    left: 50%;
    top: 40%;
    font-size: 40px;
    font-weight: bold;
    color: #fff;
    text-align: center;
    width: 100%;
    transform: translate(-50%, -50%);
}
#page .news_header h1 span{
	font-size: 30px;
}
#page .news_list{
	position: relative;
    margin-top: -140px;
    padding: 40px 0;
    text-align: center;
	z-index: 2;
}
#page .news_list::before{
content: '';
    display: block;
    width: 1060px;
    max-width: 90%;
    height: 600px;
    background: #fff;
    position: absolute;
    left: 50%;
    top: 0;
    transform: translate(-50%, 0);
    border-radius: 50%;
	z-index: -1;
}
#page .news_list h2{
	font-size: 40px;
	font-weight: bold;
	color: #3f9457;
	margin-bottom: 20px;
}
#page .news_list ul{
	width: 100%;
	max-width: 760px;
	margin: 0 auto;
}
#page .news_list ul li{
	padding: 10px;
	position: relative;
	color: #3f9457;
	font-size: 20px;
	border-bottom: 3px solid #3f9457;
}
#page .news_btn{
	display: flex;
	justify-content: space-between;
	margin: 40px auto;
}
#page .news_btn .wp-block-button{
	width: 32%;
	margin-right: 2%;
}
#page .news_btn .wp-block-button:last-child{
	margin-right: 0;
}
#page .news_btn .wp-block-button a{
	background: #f8f8f8;
	border-radius: 0;
	color: #3f9457;
	font-weight: bold;
	font-size: 20px;
}
#page .news_about{
	background: #3f9457;
	color: #fff;
	padding: 40px;
    border-radius: 50px;
}
#page .news_contents{
	margin: 40px auto;
	border: 1px solid #323232;
	padding: 40px;
}
#page .news_about h2,
#page .news_contents h2{
	font-weight: bold;
	font-size: 40px;
	margin-bottom: 40px;
}
#page .news_contents h3{
	font-weight: bold;
	font-size: 30px;
	margin: 40px auto 20px;
}
#page .news_about p,
#page .news_contents p{
	margin: 20px auto;
    font-size: 18px;
    line-height: 1.8;
}
#page .news_about p.has-text-align-right{
	margin-top: 40px;
}
#page .news_sns > div{
	display: flex;
	justify-content: space-between;
	margin: 40px auto;
}
#page .news_sns > div figure{
	max-width: 45%;
}
.business-profile,
.company-profile {
  max-width: 900px;
  margin: 3em auto;
  padding: 2em;
  background-color: #f9f9f9;
  border-radius: 12px;
  box-shadow: 0 0 10px rgba(0,0,0,0.05);
}

/* セクションタイトル */
.business-profile h2,
.company-profile h2 {
  font-size: 1.8em;
  color: #2c3e50;
  border-left: 6px solid #3498db;
  padding-left: 0.5em;
  margin-bottom: 1em;
}

.business-profile h3 {
  font-size: 1.2em;
  margin-top: 1.5em;
  color: #34495e;
}

/* リストスタイル */
.business-profile ul {
  padding-left: 1.4em;
  margin-bottom: 1.5em;
	margin-top: 20px;
}

.business-profile li {
  margin-bottom: 0.5em;
  list-style-type: disc;
}

/* 事務局・医師会の番号リスト風表示を整える */
.business-profile h2 + div,
.business-profile h2 + p {
  margin-bottom: 2em;
  white-space: pre-line;
  font-size: 0.95em;
  line-height: 1.8;
}

/* テーブルスタイル */
.company-profile table {
  width: 100%;
  border-collapse: collapse;
}

.company-profile th,
.company-profile td {
  padding: 12px 16px;
  border-bottom: 1px solid #ddd;
  vertical-align: top;
  text-align: left;
}

.company-profile th {
  width: 25%;
  background-color: #f0f0f0;
  font-weight: bold;
  color: #555;
}

/* モバイル対応 */
@media (max-width: 600px) {
  .company-profile table,
  .company-profile tr,
  .company-profile th,
  .company-profile td {
    display: block;
    width: 100%;
  }

  .company-profile th {
    background: none;
    padding-top: 1em;
    color: #888;
  }

  .company-profile td {
    padding-top: 0.3em;
  }
}
@media screen and (max-width: 1200px) {
    #page .news_header {
        padding: 0 20px;
    }
}
@media screen and (max-width: 968px){
	#page .news_header h1{
		font-size: 30px;
	}
	#page .news_header h1 span {
		font-size: 20px;
	}
	#page .news_list{
		margin-top: -80px;
		padding: 20px 0;
	}
	#page .news_list h2{
		font-size: 25px;
	}
	#page .news_list::before{
		height: 400px;
	}
	#page .news_list ul{
		padding: 0 20px;
	}
	#page .news_list ul li{
		font-size: 16px;
	}
	#page .news_btn .wp-block-button a{
		font-size: 18px;
    	padding: 15px 10px;
	}
	#page .news_about h2,
	#page .news_contents h2{
		font-size: 25px;
	}
	#page .news_contents h3{
		font-size: 20px;
	}
	#page .news_contents{
		padding: 20px;
	}
	#page .news_about p,
	#page .news_contents p{
		margin: 20px auto;
		font-size: 16px;
	}
}
@media screen and (max-width: 768px){
	#page h1{
		font-size: 30px;
		margin: 40px auto;
	}
	#page .news_logo img{
		width: 140px;
	}
	#page .news_list{
		margin-top: -30px;
	}
	#page .news_header h1 {
        font-size: 24px;
		top: 35%;
    }
	#page .news_header h1 span {
        font-size: 16px;
    }
	#page .news_list::before {
        height: 200px;
    }
	#page .news_list h2 {
        font-size: 20px;
		margin-bottom: 5px;
    }
	#page .news_list ul li {
        font-size: 14px;
    }
	#page .news_btn{
		display: block;
		margin: 20px auto;
	}
	#page .news_btn .wp-block-button{
		width: 100%;
    	margin: 10px auto;
	}
	#page .news_about {
		padding: 20px;
		border-radius: 20px;
	}
	#page .news_about h2,
	#page .news_contents h2 {
        font-size: 20px;
        margin-bottom: 20px;
    }
	#page .news_contents h3 {
        font-size: 18px;
    }
	#page .news_about p,
	#page .news_contents p {
        margin: 20px auto;
        font-size: 14px;
    }
	.business-profile h2,
	.company-profile h2{
		font-size: 1.4em;
	}
}

.contact h1{
	text-align: center;
	margin: 40px auto;
	font-size: 40px;
	font-weight: bold;
}
.contact .contact_table{
	width: 820px;
    max-width: calc(100% - 20px);
    padding: 40px;
    margin: 40px auto;
    border: 1px solid #323232;
}
.contact .contact_table table{
	width: 100%;
	position: relative;
}
.contact .contact_table table th{
	width: 25%;
    text-align: left;
    padding: 20px 10px;
    position: relative;
    vertical-align: top;
}
.contact .contact_table table th span{
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	font-size: 12px;
	color: #cf2e2e;
}
.contact .contact_table table td{
	width: 75%;
    text-align: left;
    padding: 20px 10px;
    position: relative;
}
.contact .contact_table table td input,
.contact .contact_table table td textarea{
	padding: 5px;
    display: block;
    width: 100%;
	resize: none;
	overflow: hidden;
	border: 1px solid #ccc;
	font-size: 16px;
}
.contact .contact_table .submit{
	text-align: center;
}
.contact .contact_table .submit input{
	background: #0a4f9e;
    color: #fff;
    padding: 15px 10px;
    text-align: center;
    width: 100%;
    max-width: 300px;
    border-radius: 500px;
    line-height: 1;
    height: 100%;
    font-size: 20px;
    border: none;
	transition: ease all .4s;
}
.contact .contact_table .submit input:hover{
	opacity: .7;
}
.contact .has-text-align-center{
	margin: 40px auto;
}
@media screen and (max-width:768px){
	.contact .contact_table{
		padding: 20px;
	}
}
@media screen and (max-width:568px){
	.contact .contact_table{
		padding: 20px 10px;
	}
	.contact .contact_table table th{
		width: 100%;
		display: block;
		padding-bottom: 0;
	}
	.contact .contact_table table th span{
		right: 10px;
	}
	.contact .contact_table table td{
		width: 100%;
		display: block;
		padding-top: 5px;
	}
}
/*=====================================
*
*archive
*
=======================================*/
#archive h1{
	text-align: center;
    font-weight: 600;
    font-size: 30px;
    margin: 40px auto;
}
#archive .looplist{
	margin: 40px auto;
}
#archive .looplist ol{
	max-width: 1160px;
    width: calc( 100% - 40px );
    margin: 40px auto;
	display: flex;
	flex-wrap: wrap;
}
#archive .looplist ol li{
	width: 32%;
	margin: 20px 0;
	margin-right: 2%;
}
#archive .looplist ol li:nth-child(3n){
	margin-right: 0;
}
#archive .looplist ol li a{
	color: #333;
	transition: ease all .4s;
}
#archive .looplist ol li a time{
	margin-top: 10px;
	display: block;
}
#archive .looplist ol li a h2{
	font-weight: bold;
}
#archive .looplist ol li a:hover{
	opacity: .7;
}
#archive .page-numbers{
	display: flex;
	justify-content: center;
}
#archive .page-numbers li{
	margin: 0 5px;
}
#archive .page-numbers li span{
	width: 40px;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #0a4f9e;
	color: #fff;
}
#archive .page-numbers li a{
	width: 40px;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #ccc;
	color: #333;
	transition: ease all .4s;
}
#archive .page-numbers li a:hover{
	background: #eaeaea;
}
@media screen and (max-width:768px){
	#archive .looplist ol li,
	#archive .looplist ol li:nth-child(3n){
		width: 100%;
		margin-right: 0;
		margin: 20px auto;
	}
}

/*=====================================
*
*breadcrumb
*
=======================================*/
.breadcrumb{
	margin: 10px auto;
}
.breadcrumb ul{
	display: flex;
	align-items: center;
}
.breadcrumb ul li{
	position: relative;
}
.breadcrumb ul li::after{
	content: '>';
	margin: 0 5px;
}
.breadcrumb ul li:last-child::after{
	content: none;
}
.breadcrumb ul li a{
	color: #333;
	font-size: 14px;
}
@media screen and (max-width:768px){
	.breadcrumb ul{
		flex-wrap: wrap;
	}
	.breadcrumb ul li a{
		font-size: 12px;
	}
}

/*=====================================
*
*toc
*
=======================================*/

/*=====================================
*
*footer
*
=======================================*/
footer{
  background: #45454d;
  position: relative;
  overflow: hidden;
}
footer .footer_inner{
  margin: 60px auto 20px;
  color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
footer .footer_inner .timeline{
  width: 40%;
}
footer .footer_inner .text{
  text-align: right;
}
footer .footer_inner .text p{
  margin: 10px auto;
}
footer .footer_inner .text .footer_logo{
  margin-top: 40px;
}
footer .copyright{
  text-align: center;
  color: #fff;
  margin-bottom: 10px;
}
@media screen and (max-width:960px){
  footer .footer_inner{
    display: block;
  }
  footer .footer_inner .timeline{
    width: 100%;
    margin-bottom: 20px;
  }
}

/*=====================================
*
*sidenav
*
=======================================*/

/*=====================================
*
*pc&tablet&spのnone処理
*
=======================================*/
/*=====================================
*pcのみ
=======================================*/
@media screen and (min-width: 1025px){
  .pcnone{
    display: none;
  }
}
/*=====================================
*tablet用
=======================================*/
@media screen and (max-width: 1024px) and (min-width: 415px){
  .tabnone{
    display: none;
  }
}
/*=====================================
*sp用
=======================================*/
@media screen and (max-width:414px){
  .spnone{
    display: none;
  }
}
