/*
Theme Name: basstemplate
Theme URI:
Author: the WordPress team
Author URI: https://wordpress.org/
Description: Twenty Sixteen is a modernized take on an ever-popular WordPress layout — the horizontal masthead with an optional right sidebar that works perfectly for blogs and websites. It has custom color options with beautiful default color schemes, a harmonious fluid grid using a mobile-first approach, and impeccable polish in every detail. Twenty Sixteen will make your WordPress look beautiful everywhere.
Version: 1.4
License: GNU General publish License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: one-column, two-columns, right-sidebar, accessibility-ready, custom-background, custom-colors, custom-header, custom-menu, editor-style, featured-images, flexible-header, microformats, post-formats, rtl-language-support, sticky-post, threaded-comments, translation-ready, blog
Text Domain: twentysixteen

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/

:root {
  --vw: 1vw;
}
:root {
  --vh: 1vh;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
    list-style:none;
}

table{
    border-collapse: collapse;
    border-spacing:0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline:none;
}
.both{
	clear:both;
}
p {
    display: block;
    -webkit-margin-before:0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
	letter-spacing: 0px;
}
.inline_block {
	display: inline-block;
	*display: inline;
	*zoom: 1;
}
html{
/*font-family: 'Noto Serif JP', serif;*/
font-family: 'Noto Sans JP', sans-serif,"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
font-size:16px;
line-height:1.6;
color:#494949;;
}


img{
	display:block;
	max-width:100%;
	height:auto;
}
a,
a:hover,
a:active,
a:visited,
a:link{
	text-decoration:none;
	color:inherit;
}
ol, ul{
    list-style:none;
}

.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.both{
	clear:both;
}

.inline_block {
	display: inline-block;
	*display: inline;
	*zoom: 1;
}
a.mypagebtn{
	position: fixed;
	display: block;
	right:0;
	top: 150px;
	z-index: 200;
	width: 44px;
	background: #45b035;
	padding-left: 10px;
	padding-right: 10px;
	box-sizing: border-box;
	padding-top: 20px;
	padding-bottom: 20px;
}
span{
	display:inline-block;
	font-weight: inherit;
}

p{margin-bottom:1em;
}
p:last-child{margin-bottom:0px;
}


@media (min-width: 701px){

.twocolumn{
	margin:auto;
	width:100%;
	display:flex;
	justify-content:flex-start;
	flex-wrap:wrap;
	gap:20px;
}
.twocolumn li{
	width:calc(50% - 10px);
	box-sizing:border-box;
}
.twocolumn li img{
	max-width:100%;
	display:block;
	margin:0;
}
.twocolumn li p{
}



.threecolumn{
	display:flex;
	margin:auto;
	justify-content:flex-start;
	flex-wrap:wrap;
	gap:50px;

}
.threecolumn li{
	width:calc(33.33% - 100px / 3);
	box-sizing:border-box;
}
.threecolumn li img{
	max-width:100%;
	display:block;
	margin:0;
}
}

@media (max-width: 640px){
}

.error404.content-area{
	float:none;
	margin:auto;
}
.error404.content-area main{
	text-align:center;
	margin-right:auto;
}

.error404 h1 {
    font-size: 70px;
}
@media screen and (max-width: 800px){
.error404 h1 span {
    display: block;
    font-size: 36px;
    margin-bottom: 20px;
}
}




.headerlogo img{
	width: 560px;
	max-width: inherit;
}
.header_right{
	width: calc(100% - 600px );
	
}

.pcnavi ul{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: 0px;
	
}
.pcnavi{display: block;width: 100%;}

@media screen and (max-width: 900px){

	body .is-layout-flex{
		display: block;
	}
}
.pcnavi ul li{
	width: 32%;
	padding-top: 10px;
}
.pcnavi ul li a{
	
	
	display: block;
	padding-left: 1em;
    padding-right: 1em;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: 0.4s;
	cursor: pointer;
	
	background: #f4faf3;
	border-radius: 10px 10px 0 0;
	position: relative;
	height: 70px;
	padding-bottom: 10px;
}
.pcnavi ul li a:before{
	content: "";
	background: url("../images/header_sitaarrow.svg");
	width: 20px;
	height: 12px;
	background-repeat: no-repeat;
	position: absolute;
	bottom: 20px;
}
.pcnavi ul li a:hover{
	background: #f4faf3;
	font-weight: 600;
	background: #C6E9C2;
}
.pcnavi ul li a.active{
	background: #C6E9C2;
}

.inner{
	max-width: 1200px;
	margin: auto;
	padding-left: 20px;
	padding-right: 20px;
}
.inner.single{
	max-width: 900px;
	margin: auto;
	padding-left: 20px;
	padding-right: 20px;
}
.pankz{
	background: #45b035;
	line-height: 1;
	color: #ffffff;
	height: 20px;
	display: flex;
	align-items: center;
}
.pankz .inner{
	max-width: 1200px;
	margin: auto;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size:12px;
	width: 100%;
	gap:15px;
	flex-wrap: wrap;
	align-items: center;
}
.pankz .inner a{
	font-weight: 700;
}
.pankz_arrow{
	display: block;
	width: 4px;
}
#sanjonews{
	background: #e5f4e3;
	
	padding-top: 2em;
	padding-bottom: 2em;
}
#sanjoabout{
	padding-top:  4em;
}
#kenshukaiabout{
	padding-top:  4em;
}
#kenshukaiabout .greenbox{
	margin-top: 4em;
}

@media screen and (min-width: 901px) {
    body #kenshukaiabout .is-layout-flex {
	flex-basis:36% !important;
    }
    body #kenshukaiabout .is-layout-flex > div:first-child {
	flex-basis:64% !important;
    }
}
@media screen and (max-width: 900px) {
    body #kenshukaiabout .is-layout-flex > div:first-child {
    margin-bottom: 2em;
    }
	
}
#kenshukaimoushikomi{
	padding-top:  4em;
	padding-bottom:  4em;
}
#list{
	padding-top:  4em;
	padding-bottom:  4em;
}
#contents3{
	padding-top:  4em;
	padding-bottom:  4em;
}

#sanjokojin{
	padding-top:  4em;
	margin-bottom: 4em;
}
#sanjohojin{
	padding-top:  4em;
}
#list{
	background: #6ac05d;
	 background-image: linear-gradient(90deg, rgba(106, 192, 93, 1), rgba(69, 176, 53, 1) 50%, rgba(106, 192, 93, 1));
	position: relative;
}
#list:before{
	content: "";
    background: url(../images/list-left.svg);
    width: 60vw;
    background-repeat: no-repeat;
    height: 95vw;
    box-sizing: border-box;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
}
#list:after{
	content: "";
    background: url(../images/list-right.svg);
    width: 80vw;
    background-repeat: no-repeat;
    height: 100vw;
    box-sizing: border-box;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 0;
    background-position: right bottom;
}
#contact{
	margin-top: 4em;
}
#contact h2{
	font-size:22px;
	font-weight: 600;
    color: #45b035;
}
#contact h3{
	font-size:18px;
	font-weight: 600;
    color: #45b035;
}

#topmainimage img{display: block;
	width: 100%;
}


.wp-block-columns .wp-block-buttons > .wp-block-button{
	width: 100%;
}
.wp-block-columns .wp-block-buttons > .wp-block-button a{
	width: 100%;
}
.newsinner{
	display: flex;
	max-width: 1200px;
	width: calc(100% - 40px);
	margin: auto;
}
.newsinner .left{
	width: 200px;
	border-right: 2px solid  #45b035;
	border-left: 2px solid  #45b035;
	display: flex;
    align-items: center;
	justify-content: center;
}
.newsinner .left h2:after{
	content: none;
}
.newsinner .left h2{
	margin: 0;
	text-align: center;
	font-size: 42px;
}
.newsinner .left h2 em{
	font-size:16px;
	margin-top: 8px;
}
.newsinner .center{
	width: calc(100% - 400px);
	
	padding-left: 20px;
	box-sizing: border-box;
	display: flex;
    align-items: center;
}
.newsinner .right{
	width: 190px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	border-left: 2px solid #45b035;
}
.newsinner .right .osirasebtn a{
	background: #45b035;
    color: #FFFFFF;
    width: 170px;
    display: block;
    height: 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-left: 15px;
    padding-right: 15px;
	padding-top: 0;
	padding-bottom: 0;
    font-weight: 600;
    font-size: 16px;
	border-radius: 6px;
	transition: 0.5s;
	text-decoration: none;
	box-sizing: border-box;
	cursor: pointer;
}
.newsinner .right .osirasebtn a:after{
	content: "";
	background: url("../images/icon-link.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
}
.newsinner .center li a{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	text-decoration: none;
}
.newsinner .center .date{
	font-size:12px;
	color: #a1a1a1;
	display: block;
	font-weight: 600;
	margin-right: 1em;
}
.newsinner .center h3{
	font-weight: 700;
	color: #45b035;
}
.newsinner .center p{
	font-size:0.9em;
	margin-bottom: 1em;
	padding-right: 2em;
}
.newsinner .center a:hover h3{
	font-weight: 800;
}
.is-style-rounded{
	border-radius: 10px;
	overflow: hidden;
}
.greenbox{
	background: #e5f4e3;
	border-radius: 20px;
	padding: 30px;
}
.sitecontents a{
	color: #45b035;
	text-decoration: underline;
	font-weight: 600;
}
.nakami{
	border-top:1px solid #45b035;
	margin-top: 20px;
	padding-top: 20px;
}

.sitecontents h2{
	color:#45b035;
	font-size:30px;
	font-weight: 600;
	line-height: 1.2;
	position: relative;
	margin-bottom: 60px;
}
.sitecontents h2 em{
	font-size:19px;
	display: block;
}
.sitecontents h2:after{
	content: "";
	background: url("../images/h2arrow.svg");
	height: 16px;
	width: 150px;
	bottom: -30px;
	position: absolute;
	left: 0;
	background-repeat: no-repeat;
}
.sitecontents h2.has-text-align-center:after,h2.nintei:after{
	content: "";
	background: url("../images/h2arrow.svg");
	height: 16px;
	width: 150px;
	bottom: -30px;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	background-repeat: no-repeat;
}
.sitecontents #list h2 {
    color: #ffffff;
    font-size: 30px;
    font-weight: 600;
    line-height: 1.2;
    position: relative;
    margin-bottom: 60px;text-align: center;
}
.sitecontents #list h2:after{
	content: "";
	background: url("../images/h2arrow2.svg");
	height: 16px;
	width: 150px;
	bottom: -30px;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	background-repeat: no-repeat;
}
.sitecontents #sanjoabout h2{
	margin-top: 0px;
}
.inner.kenshunews{
	max-width: 900px;
	
}
.kenshu .content{
	background: #e5f4e3;
	padding: 10px;
	border-radius: 5px;
	
	
}
.kenshu .postcat{
	display: none;
}
li.kenshu {margin-bottom: 2em;}
.kenshu h4{
	color: #45b035;
	font-size:16px;
	font-weight: 600;
	margin-bottom: 0.7em;
}
.borderbox{
	border:1px solid #cccccc;
	padding: 10px;
	margin-top: 1rem;
	
}
.modalbox h2{
	font-size:30px;
	font-weight: 600;
	line-height: 1.2;
	color: #45b035;
	margin-bottom: 1em;
}
.sitecontents .greenbox h3,
.modalbox h3{
	border-left: 5px solid #45b035;
	color:#494949;
	font-size:20px;
	font-weight: 600;
	line-height: 1.2;
	padding-left: 8px;
	margin-bottom: 0.5em;margin-top: 1em;
}
.sitecontents .greenbox h4,
.modalbox h4{
	color:#494949;
	font-size:18px;
	font-weight: 600;
	line-height: 1.2;
	margin-bottom: 0.5em;margin-top: 1em;
}
.sitecontents .greenbox strong,
.modalbox strong{
	font-weight: 800;
}

.sitecontents .greenbox ul,.modalbx ul{
	margin-bottom: 1em;
}
.sitecontents .greenbox h3:first-child,
.modalbox h3:first-child{
	margin-top: 0;
}
.sitecontents .greenbox ul li,
.modalbox ul li{
	position: relative;
	padding-left: 1em;
}
.sitecontents .greenbox ul li:before,
.modalbox ul li:before{
	content: "";
	width: 10px;
	height: 10px;
	border-radius: 20px;
	background: #45b035;
	display: block;
	position: absolute;
    top: 0.5em;
	left: 0;
}
.sitecontents .whitebox{
	background: #ffffff;
	padding: 20px;
}

.sitecontents table{
	border: none;
	border-top:1px solid #414141;
	border-left: 1px solid #414141;
	background: #ffffff;
	margin-bottom: 0.5em;
}
.sitecontents table td{
	border: none;
	border-bottom:1px solid #414141;
	border-right: 1px solid #414141;
	padding: 10px;
	vertical-align: middle;
}
.footnav{
	background: #e5f4e3;
	/*background: #45b035;*/
	margin-top: 6em;
	padding: 40px 0;
}
.footnav .inner{
	display: flex;
	justify-content: space-between;
	margin: auto;
	gap:30px;
	column-gap: 0;
}

.footnav .inner .left{
	flex-shrink: 1;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.footnav_logo{
	max-width: 170px;
	width: 90%;
	display: block;
	
}
.footnav .inner .right{
	display: flex;
	justify-content: space-between;
	margin: auto;
	gap:30px;
	flex-shrink: 0;
}
.footnav .inner .right ul{
}
.footnav .inner .right ul li:first-child a{
	border-top: 1px solid #45b035;
}
.footnav .inner .right ul a{
	display: block;
	font-weight: 700;
	width: 17em;
	box-sizing: border-box;
	
	padding: 10px 5px;
	border-bottom: 1px solid #45b035;
}

.footnav .inner .right ul a.gaibu_link{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.footnav .inner .right ul a.gaibu_link:after{
	content:"";
	display: block;
	width: 1em;
	height: 1em;
	background-size: contain;
	background-position: center;
	background: url("../images/gaibumidori.svg");
	background-repeat: no-repeat;
}
/*
.footnav .inner .left{
	border-left: 1px solid #45b035;
	width: 20%;
	border-right: 1px solid #45b035;
	padding: 0 20px;
	box-sizing: border-box;
}
.footnav .inner .center{
	width: 55%;
	padding: 0 20px;
	box-sizing: border-box;
}
.footnav .inner .right{
	width: 25%;
	padding: 0;
	box-sizing: border-box;
}*/
.fbtn a{
	color:#494949;
	font-size:15px;
	font-weight: 600;
	display: flex;
    align-items: center;
	transition: 0.5s;
}
.left .fbtn a{
	
}
.fbtn a:hover{
	opacity: 0.4;
}
.fbtn a:before{
	content: "";
	background: url("../images/icon-link2.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
	margin-right: 10px;
}
.footlinkbtn a{
	border: 1px solid #45b035;
    width: 100%;
   display: flex;
    align-items: center;
    margin: auto;
    background: #ffffff;
    padding: 10px 15px;
    box-sizing: border-box;
    color: #45b035;
    font-weight: 700;
    font-size: 16px;
	transition: 0.5s;
}
.spnavi li .footlinkbtn a{
	border: 1px solid #45b035;
	 display: flex;
    align-items: center;
}
.footlinkbtn a:hover{
	 background:#87DC7A;
	color: #ffffff;
}
.spnavi li .footlinkbtn a:hover{
	 background:#87DC7A;
	color: #ffffff;
}
.footlinkbtn a:before{
	content: "";
	background: url("../images/gaibumidori.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
	margin-right: 10px;
}
.footlinkbtn + .footlinkbtn{
	margin-top: 10px;
}
footer{
	background: #ffffff;
	font-size:14px;
}
footer .inner{
	justify-content: space-between;
	display: flex;
	gap:20px;
	align-items: stretch;
	padding: 20px;
}
.footer_hr{
	width: 1px;
	background-color: #494949;
	display: block;
	border: none;
	padding: 0;
	margin: 0;
}
.copyright{
	display: flex;
    align-items: center;
}

footer .left{
	display: flex;
	margin: 0;
    justify-content: center;
    align-items: center;
	padding:0;
    min-width: 28em;
}
footer .fle{
	display: flex;
	margin: auto;
    justify-content: center;
    align-items: center;
	padding: 20px 0;
}
footer .fle img{
	width: 100px;
	display: block;
	margin-right: 10px;
}
footer .fle div{
	width: calc(100% -110px);
}



@media (max-width: 1200px){
	
.footnav .inner {
	flex-direction: column;
	}
	.footnav .inner .right ul a {
		width: auto;
	}
	
	.footnav .inner .right {
		width: 100%;
	}
	.footnav_center,
	.footnav_right,
	.footnav_left{
		flex-shrink: 1;
		width: calc(33.33% - 20px / 2 * 3);
	}
}
@media (max-width: 1000px){
	
.footnav .inner {
	flex-direction: column;
	}
	.footnav .inner .right ul a {
		width: auto;
	}
	.footnav .inner .right {
		flex-direction: column;
		gap: 0;
		width: 100%;
	}
	.footnav_center,
	.footnav_right,
	.footnav_left{
		width: 100%;
	}
	
.footnav .inner .right ul.footnav_center li:first-child a,
.footnav .inner .right ul.footnav_right li:first-child a {
    border-top: none;
}
footer .inner {
	flex-direction: column;
	}
.footer_hr{
	width: 100%;
	height: 1px;
	background-color: #494949;
	display: block;
	border: none;
	padding: 0;
	margin: 0;
}
	footer .left{
		min-width: 0;
	}
}
.site-header{
	padding: 0 20px;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    box-sizing:border-box;
    background-color: #fff;
    z-index: 100;
}
.header_container{
	margin:auto;
	max-width:1200px;
	width:100%;
	position:relative;
	display:flex;
	justify-content:space-between;
	margin:auto;
	align-items:center;
}
.headermain{
	position:relative;
	width:100%;
	display:flex;
	justify-content:space-between;
	align-items: center;
}
.spnavibtn{
	display:flex;
	align-items:center;
	height: 90px;
}
@media screen and (min-width: 901px){
    .spnavibtn{
        display: none;
    }
}
.navibtn{
    display: block;
    position: relative;
    width: 38px;
    height: 48px;
	background: url("../images/spmenu_open.svg");
	cursor: pointer;
}
.headernavi{
	flex-shrink:0;
}
.headernavi ul{
	margin:auto;
	max-width: 1240px;
	display:flex;
}
.headernavi ul a{
	padding:25px 10px;
	color:#000;
	display:block;
	font-size:15px;
	position:relative;
	transition:0.3s 0.2s;
}
.headernavi ul a.current{
}
.headernavi ul a:after{
	content:"";
	display:block;
	left:0;
	right:0;
	bottom:0;
	height:1px;
	background-color:#999;
	width:0;
    transition: 0.3s 0.3s;
}
.headernavi ul a:hover{
	color:#999;
}
.headernavi ul a:hover:after{
	width:100%;
}
.headernavi ul a.current:after{
	background-color:#000;
	width:100%;
}
.header_right{
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
.headernavi{
	display: flex;
	align-items: center;
	margin-right: 20px;
}
.headernavi li{
	margin-right: 10px;
	padding-right: 10px;
	border-right: solid 1px #0067e6;
}
.headernavi a{
	color: #6d6d6d;
	transition: all 1s ease-out;
}
.headernavi a:hover{
}
.headernavi li:last-child{
	border-right: 0;
	padding-right: 0;
	margin-right: 0;
}
.search_bar{
    top: 0;
    transition: 0.3s;
    right: 0;
    z-index: 10;
    padding: 10px;
    background-color: #fff;
    box-shadow: 0px 0px 6px 0px rgba(0,0,0,0.6);
	font-size: 14px;
}
.search_bar form{
    width: 300px;
    display: flex;
    align-items: center;
}
.search_bar input[type='submit']{
	word-break: keep-all;
}
.search_bar p{
    margin: 0;
	word-break: keep-all;
	margin-right: 10px;
}
.search_bar button{
	word-break: keep-all;
	margin-left: 10px;
	
}
.search_btn{
	padding: 4px;
	background-color:#0067e6;
}
.search_btn img{
	width: 16px;
	height:auto;
}

.head_contact a{
background: #5f5f5f;
    color: #ffffff;
    /* padding: 20px 20px; */
    line-height: 0;
    /* height: 80px; */
    display: block;
    padding-top: 35px;
    padding-bottom: 35px;
    padding-left: 25px;
    padding-right: 25px;
	transition: all 1s ease-out;
}
.head_contact a:hover{
	background: #003976;
}

.spnavi{
	display:none;
}
.listitem_text{
	display:block;
	width:100%;
	color:#787878;
}
.listitem_text a{
	width:100%;
	display:flex;
	justify-content:flex-start;
	align-items:center;
	position:relative;
}
.listitem_text:last-child{
	margin-bottom:0;
}



.taglist{
	display:flex;
	justify-content:flex-start;
	align-items:flex-start;
	color:#bf1920;
	flex-wrap:wrap;
	margin-bottom:40px;
	gap:8px;
}
.tag{
    border: solid 1px #bf1920;
    border-radius: 5px;
    font-size: 12px;
    display: flex;
    justify-content: center;
    box-sizing: border-box;
    padding: 0px 6px;
    text-align: left;
    min-width: 80px;
    text-align: center;
}
.tag.current,
.tag:hover{
	background-color:#bf1920;
	color:#fff;
}



.two_column_left{
	display: flex;
	justify-content: center;
	align-items:flex-start;
	flex-direction: row-reverse;
}
.two_column_left > article{
	max-width: 745px;
	width: 100%;
	flex-shrink: 1;
}
.two_column_left > aside{
	width: 216px;
	margin-right: 20px;
	flex-shrink: 0;
}

.two_column,
.three_column{
		display: flex;
		flex-wrap: wrap;
	gap:35px;
	flex-direction:column;
	}
.two_column > div,
.two_column > li,
.three_column > div,
.three_column > li{
	width: 100%;
}

div.gbtn{
	margin-bottom: 0.5em;
}
.wp-block-buttons>.wp-block-button{
	margin-bottom: 0.5em;
}

div.gbtn a{
	background: #45b035;
    color: #FFFFFF;
    width: 280px;
    display: block;
    min-height: 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-left: 15px;
    padding-right: 15px;
	padding-top: 5px;
	padding-bottom: 5px;
    font-weight: 600;
    font-size: 16px;
	border-radius: 6px;
	transition: 0.5s;
	text-decoration: none;
	box-sizing: border-box;
	cursor: pointer;
	line-height: 1.3;
}
div.gbtn.long a{
	width: 330px;
}
div.gbtn a:hover{
	color: #FFFFFF;
	background: #7CC971;
}
div.gbtn.link a:after{
	content: "";
	background: url("../images/icon-link.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
}
div.gbtn.page a:after{
	content: "";
	background: url("../images/icon-page.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
}
div.gbtn.modal a:after{
	content: "";
	background: url("../images/icon-modal.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
}
div.gbtn.gaibu a:after{
	content: "";
	background: url("../images/icon-gaibu.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
}
div.gbtn.pdf a:after{
	content: "";
	background: url("../images/icon-pdf.svg");
	background-repeat: no-repeat;
	width: 20px;
	height: 17px;
	display: block;
}
div.gbtn.white a{
	background: #ffffff;
    color: #45b035;
	font-size:20px;
	width: 320px;
	height: 50px;
    padding-left: 20px;
    padding-right: 20px;
}
div.gbtn.white.link a:after{
	content: "";
	background: url("../images/icon-link2.svg");
	background-repeat: no-repeat;
	width: 17px;
	height: 17px;
	display: block;
}
#list div.gbtn.white{
	display: flex;
    justify-content: center;
}
div.gbtn.gray a{
	background: #cccccc;
	cursor: default;
}
.wp-block-buttons{
	margin-bottom: 20px;
}
.wp-block-buttons:last-child{
	margin-bottom: 0;
}
@media (min-width: 801px){
.two_column,
.three_column{
	flex-direction: row;
	}
.two_column > div,
	.two_column > li{
	width: calc(50% - 70px / 2);
	}
.three_column > div,
.three_column > li{
	width: calc(33.33% - 70px / 3);
}
}

.movie_list_item{
	background-color: #F2F2F2;
}
.movie_list_item h4{
    height: 3.2em;
    padding: 5px 10px;
    display: block;
    overflow: hidden;
		  overflow: hidden;
		  display: -webkit-box;
		  -webkit-box-orient: vertical;
		  -webkit-line-clamp: 2;
}

.movie_list_item .listitem_box_img{
	position: relative;
}
.movie_list_item .listitem_box_img:after {
    content: "";
    width: 25%;
    height: 0;
    padding-top: 25%;
    background-image: url(../images/icon_play.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    display: block;
    z-index: 10;
    transition: 0.3s;
	opacity: 0;
}
.movie_list_item a:hover .listitem_box_img:after {
    opacity: 0.6;
}
.movie_list_item .listitem_box_img:before {
    content: "";
    width: 100%;
    height: 100%;
    z-index: 5;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(0,0,0,0);
    transition: 0.3s;
}

.movie_list_item a:hover .listitem_box_img:before {
    background-color: rgba(0,0,0,0.60);
}
.listitem_box{
	background-color: #F2F2F2;
}
.listitem_box_img{
	width: 100%;
	display:block;
	padding-top: calc(56.25% - 2px);
	background-position: center;
	background-size: cover;
}

.listitem_box_text{
	padding: 10px;
}
.postdate{
	display: block;
	word-break: keep-all;
	margin: 0;
	font-size: 12px
}
	.listitem_box_text .text{
	   /* height: calc(3em * 1.6);*/
	    display: block;
	    overflow: hidden;
			  overflow: hidden;
			  display: -webkit-box;
			  -webkit-box-orient: vertical;
			  -webkit-line-clamp: 3;
}
.listitem_text h4,
.listitem_box h4{
	color: #5F5F5F;
	font-weight: 600;
	font-size: 18px;
	    height: 1.6em;
	    display: block;
	    overflow: hidden;
			  overflow: hidden;
			  display: -webkit-box;
			  -webkit-box-orient: vertical;
			  -webkit-line-clamp: 1;
}
.listitem_box a:hover h4{
	color: #eb6ea5;
}




@media (min-width: 701px){
}
@media (max-width: 700px){
}
.site-footer{
	background: #ababab;
}
.site-footer .copyright{
	color:#ffffff;
	text-align: center;
	padding: 20px;
}
.site-footer .icon{
	justify-content:flex-end;
	display:flex;
}
.site-footer .icon a{
	width:20px;
	margin-left:10px;
	display:block;
}
.footcontents{
	background: #FFFF00;
	padding: 20px;
} 
.footcontents .inner{
    max-width: 1040px;
	margin: auto;
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
	align-items:stretch;
	color: #000000;
}
@media (max-width: 600px){
	.headerlogo img{
	width: 75vw;
}
	.navibtn{
		width: 6vw;
        background-repeat: no-repeat;
        height: 7vw;
	}
	.spnavibtn{height: 60px;}
}
@media (max-width: 1060px){
.footcontents {
	padding: 40px 20px;
	}
	.footcontents .inner{
		flex-direction: column;
		align-items: center;
	}
	.footcontents .inner > img{
		max-width: 300px;
		width: 100%;
	}
	.footcontents .inner > p{
		display: block;
		margin-top: 20px;
	}
	.footcontents .inner > p.kouenkai_logo{
	
		margin-top: 0px;
	}
}
.footcontents p {
	margin: 0;
}
.footcontents p.mail {
	font-weight: 700;
	font-size: 20px;
    line-height: 1;
    margin-top: 4px;
	margin-bottom: 4px;
}
.footcontents .kigou{
	margin-left: -0.1em;
}

.page_container{
	padding:70px 20px;
	padding-bottom:0;
	margin:auto;
    min-height: 500px;
	position: relative;
}
.page_container > .inner{
    padding-bottom: 70px;
}
.page_title{
    font-size: 24px;
    margin: 0px;
    text-align: center;
    color: #ababab;
    line-height: 1.4;
    font-weight: 700;
}
.page_header{
	color: #fff;
	padding: 0 20px;
    height: 100px;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
	background-image: url("../images/pageheader_bg.jpg");
	position: relative;
}
.page_header .imgtitle {
	max-height: 40px;
    height: 7vw;
    margin: 0;
}
.page_header .page_header_kome{
	position: absolute;
	bottom: -30px;;
	padding: 0 20px;
	box-sizing: border-box;
	max-width: 1020px;
	margin: auto;
	left: 0;
	right: 0;
	color: #0067e6;
	text-align: right;
}
.title_illust{
	width: 160px;
}
.page_header .imgtitle img {
    width: auto;
    height: 130%;
	margin: auto;
}

@media (max-width: 800px){
.title_illust{
	width: 80px;
	}
.page_header {
	height: 130px;
}
}
#page{
	position: relative;
	z-index: 10;
}

.listitem_text{
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	gap:15px;
}
.postcat{
    /*width: 100px;*/
	 width: 30px;
    display: block;
    flex-shrink: 0;
    padding-top: 5px;
}
.postcat span{
	width: 100%;
	word-break: keep-all;
	background-color: #e3ebf5;
	text-align: center;
	display: block;
    font-size: 12px;
	line-height: 28px;
	color: #5f5f5f;
	line-height: 1.4;
	margin-top: 15px;
}
.postcat span:first-child{
	margin-top: 0px;
}
.listitem_text h4{
	flex-shrink: 1;
	width: 100%;
	color: #45b035;
}
.listitem_text p{
	margin-bottom: 0;
}


.archive_content .information_list {
}
.archive_content .listitem_text{
	border-bottom:solid 1px #cccccc;
}
.archive_content .listitem_text:first-child{
	border-top:solid 1px #cccccc;
}
.archive_content .listitem_text a{
	padding:15px 0;
}
.navigation .screen-reader-text{
	display:none;
}
.pagenavi{
	margin-top:50px;
	display:flex;
	justify-content:center;
	align-items:center;
}
.contact{
	border:none;
	margin-left:110px;
	max-width:740px;
	width:100%;
}
.contact th,
.contact td{
	border:none;
}
.contact th{
	width:190px;
}
.contact span{
	width:100%;
}
input, textarea{
	padding:5px;
	width:100%;
	box-sizing:border-box;
}
input[type="submit"]{
    border: solid 3px #5f5f5f;
    color: #ffffff;
	font-size: 20px;
	font-weight: 600;
    background-color: #5f5f5f;
    width: 300px;margin: auto;
    padding: 15px 30px;
	cursor:pointer;
    transition: 0.3s;
	text-align: center;
	display: block;
}
input[type="submit"]:hover{
    color: #5f5f5f;
    background-color: #ffffff;
	border: solid 3px #5f5f5f;
}
	.spnavi_bg{
		display: none;
		position: fixed;
		width: 100%;
		top: 0;
		height: 100vh;
		left: 0;
		background-color: rgba(0,0,0,0.50);
		z-index: 90;
		cursor: pointer;
	}

.spnavi{
    position: fixed;
    justify-content: center;
    align-items: center;
    left: 0px;;
    top: 70px;
    width: 100%;
    margin: auto;
	max-height:calc((var(--vh) * 100) - 70px);
    box-sizing: border-box;
	overflow:auto;
    font-size: 20px;
    background-color: #fff;
	display: none;
	z-index: 301;
	background: #ffffff;
}
	.spnavi_bg{
	}
	.search_btn{
		display: none;
	}
.spnavi{
	color: #5f5f5f;
}
.spnavi li{
}
.spnavi li a{
    margin: auto;
	padding: 15px 20px;
	display: block;
	box-sizing: border-box;
	border-bottom: solid 3px #ffffff;
    font-size: 18px;
    width: 100%;
    flex-shrink: 1;
	font-weight: 400;
	color: #494949;
}
.spnavi li.finish{
	padding: 20px;
}
	.spnavi li.head_contact_sp a{
		background-color: #5f5f5f ;
		color: #fff;
}
.navi_child{
	background: #e5f4e3;
}
.spnavi.active{
	display:flex;
}
.spnavi > div{
    margin: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: auto;
    position: relative;
	height:calc(100vh - 140px);
}
.spnavi > div > ul{
	overflow:auto;
}
.spnavi .navi_child{
	display:none;
}
.navi_parent{
	display:flex;
    align-items: center;
	border-top: solid 3px #e5f4e3;
	cursor: pointer;
}
.navi_parent.last{
	border-bottom: solid 3px #e5f4e3;
}
.navi_parent:after{
	content: "";
	background: url("../images/icon-plus.svg");
	width: 20px;
	height: 20px;
	display: block;
	position: absolute;
    right: 20px;
    background-repeat: no-repeat;
}
.navi_parent.active:after{
	content: "";
	background: url("../images/icon-mainasu.svg");
	width: 20px;
	height: 20px;
	display: block;
	position: absolute;
    right: 20px;
    background-repeat: no-repeat;
}
.spnavi li .navi_parent > a{
	border-bottom: 0;
}
.navi_parent ul{
	width:100%;
}
.navi_parent ul li{
	margin-bottom:0;
	margin-top:0.5em;
	margin-left:1em;
}
.navi_child li a:after{
	/*content: "";
	background: url("../images/icon-link2.svg");
	width: 20px;
	height: 20px;
	display: block;
	position: absolute;
    right: 20px;
    background-repeat: no-repeat;*/
}
.navi_child li a.page:after{
	/*background: url("../images/icon-page2.svg");
	height: 16px;
	background-repeat: no-repeat;*/
}
.navi_child{
	font-size:16px;
	
}
.navi_child li a{
	display: flex;
	align-items: center;
}


    
.navi_child li a{
	position: relative;
}
.childopen{
    width: 30px;
    height: 40px;
    display: block;
    position: relative;
    cursor: pointer;
    margin-left: 0;
    margin-top: 0px;
    flex-shrink: 0;
}
.childopen:after,
.childopen:before{
    content: "";
    width: 20px;
    height: 2px;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    background-color: #000;
}
.childopen:before{
    transform:rotateZ(90deg);
}
.navi_parent.active .childopen:before{
    width: 0;
}

@media (max-width: 1000px){
	.pcnavi{display: none;}
.spnavibtn{
	display:flex;
}
.headernavi,
.en_link{
	display:none;
}
	.head_contact{
		display: none;
	}
.site-header{
	transition:0.5s;
    min-height: 70px;
	overflow:hidden;
}
	
.site-header.active{
}
	.head_navi{
		display: none;
	}

.site-header {
    min-height: 60px;
}
}

@media (max-width: 800px){
	.box1 .pc{display: none;}.box1 .sp{display: block;}
}
@media (max-width: 700px){

.contact{
	margin:auto;
}
.contact table,
.contact tbody,
.contact td,
.contact th{
	display:block;
	width:100%;
    box-sizing: border-box;
}




.twocolumn li,
.threecolumn li{
	margin-bottom:20px;
}
.twocolumn li:last-child,
.threecolumn li:last-child{
	margin-bottom:0;
}


.page_container {
    padding: 40px 20px;
	padding-bottom:0;

}
.post_detail{
	display:block;
}
.post_detail .left{
    margin-bottom: 10px;
}
}
@media (max-width: 480px){
}

.maincontents{
background: #ffffff;
width: 100%;
	padding: 40px 0px;
	box-sizing: border-box;
}

@media (min-width: 801px){
.side_on{
	display: flex;
	justify-content: space-between;
}
	.side_on > main{
		width: 100%;
		flex-shrink: 1;
	}
	.side_on > aside{
		width: 300px;
		margin: 0;
		margin-left: 50px;
		flex-shrink: 0;
	}
	.side_on.left{
		flex-direction: row-reverse;
	}
	.side_on.left > aside{
		margin: 0;
		margin-right: 30px;
}
}
@media (max-width: 800px){
	.side_on > main{
		margin-bottom: 60px;
	}
	.side_on > aside{
	}
}
.navigation.pagination{
	margin-top: 60px;
}
.navigation .screen-reader-text{
	display:none;
}
.pagenavi{
	margin-top:50px;
	display:flex;
	justify-content:center;
	align-items:center;
	color:#004097;
}
.page_num{
	margin-bottom:0;
	margin-right:20px;
	color:#004097;
}
.nav-links{
	display:flex;
    justify-content: center;
	color: #ababab;
}


.page-numbers{
	border:solid 1px #ababab;
	background-color:#fff;
	display:flex;
	justify-content:center;
	align-items:center;
	line-height:1;
	width:30px;
	height:30px;
	margin-right:10px;
	transition:0.3s;
	color: #ababab;
}
.page-numbers:hover{
	color:#fff;
	background-color:#ababab;
}
.page-numbers.current{
	color:#fff;
	background-color:#ababab;
}
.page-numbers:last-child{
	margin-right:0;
}
.page-numbers.prev,
.page-numbers.next{
	display:none;
}
.sidebar{
}
.search_word{
    padding-bottom: 5px;
    margin-bottom: 20px;
    color: #004097;
    border-bottom: solid 1px #004097;
    font-size: 1.2rem;
}

.wpcf7-form-control-wrap{
	width: 100%;
}


@media screen and (max-width: 640px){
.contact_table,
.contact_table tr,
.contact_table td,
.contact_table th{
    display: block;
    width: 100%;
    text-align: left;
    padding: 0;
}
    .contact_table td{
    padding-bottom: 10px;}
    .contact_table th{
        padding-bottom: 0;
}

}
.contact_table .requied{
    font-size: 12px;
    background-color: #FF0004;
    color: #fff;
    display: inline-block;
    padding: 0 5px;
    margin-left: 10px;
}
.contact_table form, 
.contact_table input,
.contact_table textarea{
    border: solid 1px #ccc; 
}
.contact_table input[type="submit"] {
    margin: auto;
    display: block;
    background-color: #ababab;
    color: #fff;
    border: solid 2px #ababab;
}
.contact_table input[type="submit"]:hover{
    background-color: #fff;
    color: #ababab;
}
.contact_table input[type="date"]{
    font-size: 16px;
    padding: 3px 3px;
    border: solid 1px #ccc;
}
.contact_table select {
    font-size: 16px;
    padding: 5px;
    border: solid 1px #ccc; 
}

.popupmoviebox{
	position:fixed;
	width:90%;
	z-index:100001;
	display:none;
	left:5%;
	top:50%;
	margin-top:-25.3125%;	
}
.popupmoviebox iframe{
	width:100%;
}
.popupmoviebg{
	position:fixed;
	height:100vh;
	width:100vw;
	z-index:100000;
	display:none;
     top: 0;
    left: 0;
	background-color:rgba(0,0,0,0.70);
}
.moviethumb{
	cursor:pointer;
}

.youtubearea{
	padding:0 !important;
	width:100%;
	height:0;
	position:relative;
  padding-top: 56.25% !important;
  overflow:hidden;
  margin-bottom:20px;
}
.youtubearea iframe{
	width:100%;
	height:100%;
	position:absolute;
	top:-20%;
	right:-20%;
	left:-20%;
	bottom:-20%;
	margin:auto;
}
.greenbox .coursetitle{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.greenbox .coursetitle h3{
	width: calc(100% - 260px);
}
.greenbox .coursetitle gbtn{
	width: 200px;
	margin-right: 20px;
}
.greenbox .coursetitle .gbtn a{
	width: 200px;
}
.greenbox .coursetitle .plus{
	
}

.coursetitle + .aco_contents{
	margin-top: 1em;
}
.greenbox .coursetitle div.gbtn{
	margin: 0;
}
.sitecontents .greenbox .coursetitle h3{
	border:none;
	font-size:24px;
	font-weight: 600;
	color:#45b035;
	margin: 0;
	padding: 0;
}
.greenbox .plus{
	 flex-wrap: nowrap;
  position: relative;
  display: block;
  flex-shrink: 0;
	background-image: url("../images/faq-plus.svg");
	background-size: 40px;
	background-repeat: no-repeat;
	background-position: center;
	width: 40px;
	height: 40px;
	border-radius: 6px;
}
.greenbox .plus.open{
	background-image: url("../images/faq-mainasu.svg");
}

.faq_q {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  background-color: #e5f5fe;
  box-sizing: border-box;
	align-items: center;
	background-color: #e5f4e3;
	cursor: pointer;
		margin-bottom: 15px;
	}
.faq_q > p {
  padding: 10px 20px;
  box-sizing: border-box;
  flex-shrink: 1;
  display: flex;
  align-items: center;
  text-align: left;
  width: 100%;
  font-size: 18px;
  font-weight: 700;
	margin-bottom: 0;
}
.faq_q .plus {
  flex-shrink: 0;
}
.faq_q_icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.faq_a_icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.faq_q_icon,
.faq_a_icon,
.faq_q .plus  {
    height: 74px;
    width: 74px;
}
.faq_q_icon img, .faq_a_icon img {
  height: 32px;
  width: auto;
}
.aco_contents {
  display: none;
}
	.faq_a_outer {
		padding-left: 34px;
}
.faq_q,
.faq_a_outer{
		margin-bottom: 15px;
}
.faq_a {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  background-color: #f2f2f2;
}
.faq_a_text {
  padding: 10px 0;
  padding-right: 20px;
  flex-shrink: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  text-align: left;
}
.faq_a_text a {
  color: #45b035;
  text-decoration: underline;
  display: block;
}
.faq_a_text a:hover {
  text-decoration: none;
}
.faq_q h4{
	font-size: 18px !important;
	text-align: left !important;
	padding: 22px 0 !important;
	margin: 0 !important;
	border: 0 !important;
	font-weight: 500 !important;
    display: block;
    width: 100%;
}
.faq_q .plus {
  flex-wrap: nowrap;
  position: relative;
  display: block;
  flex-shrink: 0;
	background-image: url("../images/faq-plus.svg");
	background-size: 40px;
	background-repeat: no-repeat;
	background-position: center;
}
.faq_q.open .plus {
	background-image: url("../images/faq-mainasu.svg");
}

@media screen and (max-width: 500px) {
  .faq_q_icon {
    min-height: 46px;
    width: 46px;
  }
  .faq_a_icon {
    min-height: 46px;
    width: 46px;
    padding-left: 10px;
  }
  .faq_q {
    padding-right: 10px;
  }
  .faq_q > p {
    padding: 10px 10px;
    font-size: 16px;
  }
  .faq_a p {
    font-size: 16px;
  }
		}

.hover_menu_child{
	padding: 20px;
	display: none;
	position: fixed;
	width: 100%;
	box-sizing: border-box;
	background-color: #e5f4e3;
	background: #C6E9C2;
	z-index: 100;
	 box-shadow: 0px 4px 3px 0px rgba(0, 0, 0, 0.2);
}
.head_navi a{
    letter-spacing: 0.15em;
	font-size:18px;
	font-weight: 700;
	display: block;
	padding: 10px 0 ;
}
.head_navi a:hover{
	color: #eb6ea5;
}
.head_navi ul{
	max-width: 1200px;
	margin: auto;
	display: flex;
	align-items:center;
	justify-content:flex-start;
    column-gap: 40px;
	flex-wrap: wrap;
}

.subheader{
	background: #f1f1f1;
	height: 200px;
	display: flex;
	justify-content: center;
	align-items: center;
	background-image: url("../images/subheader.jpg");
	background-size: cover;
	background-position: center;
}
.subheader.nintei{
	background-image: url("../images/nintei-top.jpg");
}
.subheader .title{
	background-color: #fff;
	margin: 0;
	color: #45b035;
	font-size: 26px;
    font-weight: 700;
    padding: 8px 22px;
	letter-spacing: 7px;
}
.hovflex{
	display: flex;
	justify-content: space-between;
}

.hovflex ul{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	
}
.hovflex ul li{
	
    width: 24%;
   
    margin: 0.5%;
	
}
.hovflex ul li a{
	font-weight: 700;
	color:#45b035;
	font-size:16px;
	box-sizing: border-box;
    padding: 10px 15px;
	 background: #ffffff;
	display: block;
	position: relative;
}
.hovflex ul li a:before{
	content: "";
	background: url("../images/subheader_arrow.svg");
	width: 10px;
	height: 13px;
	background-repeat: no-repeat;
	position: absolute;
	right:10px;
	top: 18px;
    opacity: 0.3;
}
.hovflex ul li a:hover{
	color:#227B14;
}
.stepcolumn{
	margin-top: 6em;
}
.stepcolumn .wp-block-column{
	border-radius: 20px;
  box-shadow: 0px 0px 15px 0px rgba(69, 176, 53, 0.69);
	padding: 20px;
	position: relative;
	padding-top: 125px;
	margin-bottom: 2em;
}
.stepcolumn .wp-block-column h4{
	color: #45b035;font-weight: 600;
}
.stepcolumn .wp-block-column h3.flownum1{
background: url(../images/flownum1.svg);
    width: 89px;
    height: 89px;
    overflow: hidden;
    text-indent: -100px;
    position: absolute;
    top: 20px;
    left: -100%;
    right: -100%;
    margin: auto;
}
.stepcolumn .wp-block-column h3.flownum2{
background: url(../images/flownum2.svg);
    width: 89px;
    height: 89px;
    overflow: hidden;
    text-indent: -100px;
    position: absolute;
    top: 20px;
    left: -100%;
    right: -100%;
    margin: auto;
}
.stepcolumn .wp-block-column h3.flownum3{
background: url(../images/flownum3.svg);
    width: 89px;
    height: 89px;
    overflow: hidden;
    text-indent: -100px;
    position: absolute;
    top: 20px;
    left: -100%;
    right: -100%;
    margin: auto;
}
.stepcolumn .wp-block-column h3.flownum4{
background: url(../images/flownum4.svg);
    width: 89px;
    height: 89px;
    overflow: hidden;
    text-indent: -100px;
    position: absolute;
    top: 20px;
    left: -100%;
    right: -100%;
    margin: auto;
}
.stepcolumn .wp-block-column h3.flownum5{
background: url(../images/flownum5.svg);
    width: 89px;
    height: 89px;
    overflow: hidden;
    text-indent: -100px;
    position: absolute;
    top: 20px;
    left: -100%;
    right: -100%;
    margin: auto;
}

.borderdouble{
	border:4px double #45b035;
	padding: 20px;
	max-width: 900px;
	margin: auto;
}
.borderdouble .wp-block-table{
	margin: 0;
}
.borderdouble .wp-block-table table{
	border:none;
	margin: 0;
}
.borderdouble .wp-block-table table td{
	border:none;
	padding-top: 0;
	padding-left: 0;
}
.borderdouble .wp-block-table table td:nth-child(odd){
width: 7em;	
}
.borderdouble .wp-block-table table td strong{
	font-weight: 600;
	color: #45b035;
}
#list h3{
	position: relative;
	text-align: center;
	font-size:20px;
	font-weight: 600;
	width: 100%;
	color: #ffffff;
	 display: flex;
    align-items: center;
	z-index: 10;
}
#list h3:after,#list h3:before{
	  content: "";
    height: 2px;
    flex-grow: 1;
    background-color: #fff;
	border-radius: 5px;
}
#list h3:after{
	margin-left: 1rem;
}
#list h3:before{
	margin-right: 1rem;
}
#list h3 span{

}
#kakolist h3{
	position: relative;
	text-align: center;
	font-size:20px;
	font-weight: 600;
	width: 100%;
	color: #45b035;
	 display: flex;
    align-items: center;
	z-index: 10;
	border: none;
}
#kakolist h3:after,#kakolist h3:before{
	  content: "";
    height: 2px;
    flex-grow: 1;
    background-color: #45b035;
	border-radius: 5px;
}
#kakolist h3:after{
	margin-left: 1rem;
}
#kakolist h3:before{
	margin-right: 1rem;
}


.ninteibox{border-radius: 20px;
    box-shadow: 0px 0px 15px 0px rgba(69, 176, 53, 0.69);
    padding: 30px;
	margin-top: 20px;
	margin-bottom: 40px;
}
.ninteibox .grn{
	padding: 20px;
	border:1px solid #45b035;
	
}
.page_content .borderdouble table{
	margin-bottom: 0;
}
.page_content .ninteibox h2{
	color: #45b035;
    font-size: 30px;
    font-weight: 600;
    line-height: 1.2;
    position: relative;
    margin-bottom: 60px;
	background: none;
	padding: 0;
	margin: 0;
	margin-bottom: 30px;
}
.page_content .ninteibox h2:after{
	content: none;
}
.topfle{
	display: flex;
	justify-content: space-between;
    flex-wrap: wrap;
    column-gap: 15px;
	margin-bottom:30px;
}
.topfle div.gbtn:last-child{
	margin-bottom: 0;
}
.ninteibox .grn h3{
	border: none;
	text-align: center;
	font-size:18px;
	font-weight: 600;
	
}
.page_content h2.nintei{
	color: #45b035;
    font-size: 30px;
    font-weight: 600;
    line-height: 1.2;
    position: relative;
    margin-bottom: 60px;
	background: none;
	padding: 0;
	margin: 0;
	margin-bottom: 60px;
}
.faq_list section{
	margin-top: 60px;
}
.faq_list h3{
	display: flex;
	padding: 5px 0; 
	gap:20px;
	margin-top: 0px;
	margin-bottom: 20px;
	font-size: 22px;
	font-weight: 700;
	color: #45b035;
}
.faq_list section:first-child{
	margin-top: 0px;
}

.faq_list h3:before{
	content: "";
	width: 40px;
	height: 40px;
	background-image:url("../images/pmrjh3");
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	display: block;
    margin-top: -2px;
}

.modal a{
	display: block;
	
}
.batu{
	background: url("../images/batu.svg");
    width: 50px;
    height: 50px;
    display: block;
    background-size: cover;
    position: absolute;
    top: -25px;
    right: -25px;
}
.modalouter {
	position: fixed;
	width: 100%;
	z-index: 100001;
	display: none;
	left: 0;
	bottom: 0;
	margin: auto;
	top: 0;
	bottom: 0;
	box-sizing: border-box;
	align-items: center;
	height: 100vh;
	padding: 30px;
	background-color: rgba(0,0,0,0.40);
	flex-direction: column;
	justify-content: center;
}
.modalbox {
	display: none;
	max-width: 800px;
	width: 100%;
	background-color:#FFFFFF;
	border-radius: 15px;
	padding: 30px;
	padding-right: 0;
	max-height: calc(100vh - 100px);
	box-sizing: border-box;
	flex-direction: column;
	position: relative;
}
.modalbox a{
	color: #45b035;
    text-decoration: underline;
    font-weight: 600;
}
.modalinner{
	overflow: auto;
	width: 100%;
	padding-right: 30px;
	box-sizing: border-box;
}
.modal_close {
	width: 100%;
	background-position: right center;
	height: 40px;
	display: block;
	background-size: contain;
	background-repeat: no-repeat;
	background-image: url(../images/close-btn.png);
	margin-top: -60px;
	margin-bottom: 20px;
	max-width: 600px;
}
.flowbox.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column{
	flex-basis: auto;
}
.flowbox{
	border-radius: 20px;
    box-shadow: 0px 0px 15px 0px rgba(69, 176, 53, 0.69);
    padding: 20px;
	box-sizing: border-box;
	margin: 15px;
	margin-bottom: 40px;
	margin-top: 40px;
	position: relative;
	gap:0;
}
.flowbox + p{
	margin-bottom: 40px;
}
.flowbox .wp-block-column{
	width: 41%;
    padding-right: 20px;
    box-sizing: border-box;
	align-items: center;
    display: flex;
   justify-content: flex-start;
	
}
.flowbox h3{
	border:none;color: #45b035;
	font-size:20px;
	font-weight: 600;
	padding: 0;
	margin: 0;
	text-align:left;
}
.flowbox .wp-block-column:last-child{
	border-left:1px solid #45b035;
	width:  67%;
	padding-left: 20px;
	box-sizing: border-box;
	display: block;
	
}
.flowbox h4{
	color:#45b035;
	font-size:18px;
	font-weight: 600;
	line-height: 1.2;
	margin-bottom: 0.5em;margin-top: 1em;
}
.modalbox h4.flowlast{
	color:#494949;
	font-size:28px;
	text-align: center;
	font-weight: 600;
	line-height: 1.2;
	margin-top: 1em;
    margin-bottom: 1em;
}
.modalbox h4.flowcomplete{
	color: #494949;
    font-size: 32px;
    text-align: center;
    font-weight: 600;
    line-height: 1.2;
    margin-top: 1em;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}
.modalbox h4.flowcomplete:before{
	content: "";
    background: url(../images/complete.svg);
    background-size: cover;
    width: 50px;
    height: 63px;
    margin-right: 10px;
}
.flowbox h6{
background: url(../images/flownum1.svg);
    width: 70px;
    height: 70px;
    overflow: hidden;
    text-indent: -100px;
	margin-right: 15px;
	background-repeat: no-repeat;
}
.flowbox h6.flownum2{
	background: url(../images/flownum2.svg);
}
.flowbox h6.flownum3{
	background: url(../images/flownum3.svg);
}
.flowbox h6.flownum4{
	background: url(../images/flownum4.svg);
}
.flowbox h6.flownum5{
	background: url(../images/flownum5.svg);
}
.sitasankaku{
	width: 30px;
	display: block;
	margin: auto;
}
.wp-block-table.genti table td:nth-child(odd){
	width: 5em;
}
#list .inner{
	z-index: 10;
	position: relative;
}
#list h5{
	text-align: center;
	color: #ffffff;
	font-size:16px;
	font-weight: 600;
}
.courselist{
	padding-top: 40px;
	padding-bottom: 40px;
	display: flex;
	flex-wrap: wrap;
	gap:20px;
	justify-content: space-between;
	position: relative;
	z-index: 10;
	max-width: 900px;
    margin: auto;
}
.coursecard{
	background: #ffffff;
	width: calc( 50% - 10px);
	box-sizing: border-box;
	border-radius: 10px;
}
.nocourse{
	padding: 60px 0;
	text-align: center;
	color: #ffffff;
	font-size:16px;
	font-weight: 600;
	margin: auto;
}
.mt70{margin-top: 70px;}

@media (max-width: 1000px){
	.newsinner{display: block;}
	.newsinner .center{width: 100%;padding:0;padding-top: 10px;}
	.newsinner .right {width: 100%;justify-content: flex-start;border-left: none;margin-top: 1em;}
	.newsinner .left {width: 100%;border-right: none;border-left: none;justify-content: flex-start;border-bottom: 2px solid #45b035;}
	.newsinner .left h2{font-size:30px;}
	.sitecontents .newsinner h2 br{display: none;}
	.sitecontents .newsinner .left h2 em{display: inline-block;margin-left: 0.5em;font-size:12px;}
}
@media (max-width: 900px){
	.sitecontents .whitebox p{	margin-bottom: 1em;}
	.wp-block-column{margin-bottom: 1em;}
	/*.footnav .inner{display: block;}
	.footnav .inner .left,.footnav .inner .center{border-left: none;width: 100%;border-right: none;padding: 0;margin-bottom: 1em;}
	.footnav .inner .right{width: 100%;}*/
	footer .fle{display: block;}
	footer .fle img {margin: auto;}
	footer .fle p {margin:1em auto;text-align: center;}
	.page_content .ninteibox h2{font-size:24px;}
	
	.flowbox .wp-block-column:last-child {border-left: none;width: 100%;padding-left: 0;display: block;border-top: 1px solid #45b035;padding-top: 10px;margin-top: 20px;}
	.flowbox .wp-block-column {width: 100%;padding-right: 0;}
	.flowbox h3 br{display: none;}
	.sitecontents h2 br{display: none;}
	.sitecontents .left h2 em{display: inline-block;margin-left: 0.5em;font-size:12px;}
	#sanjonews{padding: 2em 0;}
}
@media (max-width: 600px){
	.greenbox{padding: 20px;}
	.ninteibox{padding: 20px;}
	.greenbox .coursetitle .gbtn a {width: 140px;}
	.greenbox .coursetitle h3 {width: calc(100% - 140px);}
	.modalouter{padding: 15px;}
	.modalbox{padding: 15px;padding-right: 0;}
	.modalinner{padding-right: 15px;}
	.flowbox {border-radius: 10px;box-shadow: 0px 0px 5px 0px rgba(69, 176, 53, 0.50);padding: 15px;margin: 5px;margin-bottom: 20px;margin-top: 20px;}
	.modalbox h4.flowlast{margin-bottom: 20px;margin-top: 20px;}
	.batu {width: 40px;height: 40px; top: -10px;right: -10px;}
	.page_content h2.nintei{font-size:24px;}
	.ninteibox .grn{margin-bottom: 20px;}
	.ninteibox .grn:last-child{margin-bottom: 0px;}

	
}
@media (max-width: 400px){
	.newsinner .center li a{display: block;}
}

.courserhead{
	display: flex;
	justify-content: space-between;
}
.coursecate{
	width: 70%;
	display: flex;
	justify-content: flex-start;
	padding: 10px;
}
.coursecate div{
	font-size: 12px;
    font-weight: 600;
    color: #ffffff;
    background: #082982;
    padding: 2px 6px;
    margin-right: 5px;
    height: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
    border-radius: 4px;
}
.coursecate div.cat_ma{background: #2229B0;}
.coursecate div.cat_de{background: #f7931e;}
.coursecate div.cat_pv{background: #3FC156;}
.coursecate div.cat_qu{background: #0B5E11;}
.coursecate div.cat_me{background: #44B5E4;}
.coursecate div.cat_other{background: #ed1e79;}






.coursecard{
	background: #ffffff;
	width: calc( 50% - 10px);
	box-sizing: border-box;
	border-radius: 10px;
	position: relative;
    padding-bottom: 60px;
	box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.2);
}
#kakolist .coursefoot{
	display: flex;
	justify-content: center;
	
}

@media (max-width: 800px){
	.coursecard{width: 100%;}
}

.coursecardtitle{
	padding:10px;
	font-size:18px;
	font-weight: 700;
	color: #494949;
	padding-bottom: 0;
	margin: 0;
}
.page_content h4.coursecardtitle{margin: 0;}
.coursedate{
	font-size:12px;
	color: #777777;
	font-weight: 600;
	padding:10px;
}
.coursefoot{
	background: #f1f1f1;
	border-radius: 0 0 10px 10px;
	padding: 10px;
	padding-right: 0;
	position: absolute;
	bottom: 0;
	width: 100%;
	box-sizing: border-box;
	
}
.coursefoot .flex{
	display: flex;
}
.coursefoot .flex .left{
	width: 25%;
	border-right: 2px solid #45b035;
	display: flex;
	align-items: center;
	justify-content: center;
	
}
.coursefoot .flex .left p{
	font-weight: 600;
    font-size: 14px;
    color: #37ac4a;
}
.coursefoot .flex .right{
	width: 75%;
    display: flex;
    justify-content: center;
    gap: 10px;
}
.coursefoot div.gbtn{
	margin-bottom: 0;
}
.coursefoot div.gbtn a{
	width: 120px;
	box-sizing: border-box;
}






.format{
	background: #f1f1f1;
    padding: 4px 10px 6px 20px;
    border-radius: 0 10px 0 20px;
	position: relative;
	font-size: 12px;
	width: 25%;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 30px;
	font-weight: 600;
    color: #37ac4a;
}
.format .webiner{
	position: absolute;
	padding-left: 34px;
	font-weight: 600;
}
.format .webiner:before{
	content: "";
	background: url("../images/icon/format-webnar.svg");
	background-repeat: no-repeat;
    width: 28px;
	height: 23px;
	position: absolute;
	display: block;
	top: 0;
	left: 0px;
}
.format .offline{
	position: absolute;
	padding-left: 34px;
	font-weight: 600;
}
.format .offline:before{
	content: "";
	background: url("../images/icon/format-offline.svg");
	background-repeat: no-repeat;
    width: 28px;
	height: 28px;
	position: absolute;
	display: block;
	top: -2px;
	left: 0px;
}
.format .hybrid{
	position: absolute;
	padding-left: 34px;
	font-weight: 600;
}
.format .hybrid:before{
	content: "";
	background: url("../images/icon/format-hybrid.svg");
	background-repeat: no-repeat;
    width: 28px;
	height: 28px;
	position: absolute;
	display: block;
	top: 0;
	left: 0px;
}

.formatsp .webiner{
	position: absolute;
	padding-left: 34px;
	font-weight: 600;
}
.formatsp .webiner:before{
	content: "";
	background: url("../images/icon/format-webnar.svg");
	background-repeat: no-repeat;
    width: 28px;
	height: 23px;
	position: absolute;
	display: block;
	top: 0;
	left: 0px;
}
.formatsp .offline{
	position: absolute;
	padding-left: 34px;
	font-weight: 600;
}
.formatsp .offline:before{
	content: "";
	background: url("../images/icon/format-offline.svg");
	background-repeat: no-repeat;
    width: 28px;
	height: 28px;
	position: absolute;
	display: block;
	top: -2px;
	left: 0px;
}
.formatsp .hybrid{
	position: absolute;
	padding-left: 34px;
	font-weight: 600;
}
.formatsp .hybrid:before{
	content: "";
	background: url("../images/icon/format-hybrid.svg");
	background-repeat: no-repeat;
    width: 28px;
	height: 28px;
	position: absolute;
	display: block;
	top: 0;
	left: 0px;
}


.formatsp{
	display: none;
	font-weight: 600;
    font-size: 14px;
    color: #37ac4a;
}
.status p{
	margin: 0;
}

#categories{
	display: block;
	width: 100%;
	max-width: 1000px;
	margin: auto;
	justify-content: space-between;
}
#categories .category{
	width: 100%;
	background: #e5f4e3;
	box-sizing: border-box;
	border-radius: 10px;
	padding: 10px;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	color: #45b035;
}
#categories .category.active{
	background: #45b035;
	color: #ffffff;
}

@media (max-width: 600px){
	.coursecate{
		width: 100%;
		flex-wrap: wrap;
	}
	.coursecard{
		padding: 0;
	}
	.coursefoot .flex{
		display: block;
	}
	.formatsp{
		display: block;
	}
	.format{
		display: none;
	}
	.coursefoot .flex .left{
		width: 100%;
        background: #f1f1f1;
        padding: 10px;
        box-sizing: border-box;
        border: none;
        margin-bottom: 15px;
		display: flex;
        justify-content: center;
        align-items: center;
	}
	.coursefoot .flex .left p{
		width: calc(50% - 1px);
		display: flex;
        align-items: center;
        justify-content: center;
		border-right: 1px solid #45b035;
	}
	.coursefoot .flex .left .formatsp{
		width: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
	}
	
	.coursecardtitle{
		padding-top: 0;
	}
	.coursefoot .flex{
		
	}
	.coursefoot .flex .right{
		width: 100%;
		padding-left: 10px;
		padding-right: 10px;
		box-sizing: border-box;
	}
	.coursefoot .flex .right .gbtn{
		width: 50%;
	}
	.coursefoot .flex .right .gbtn a{
		width: 100%;
	}
	.coursefoot{
		background: #ffffff;
		padding: 0px;
		padding-bottom: 15px;
		position: relative;
	}
	
}