@charset "UTF-8";

/*-- Anchor -------------------------------------------------------------*/
a         { resize: none; }
a:link    { color:#333333; text-decoration: none; }
a:visited { color:#333333; text-decoration: none; }
a:hover   { color:#007440; text-decoration: underline; }
a:active  { color:#333333; text-decoration: none; }

.u_link a         { resize: none; }
.u_link a:link    { color:#333; text-decoration: underline; }
.u_link a:visited { color:#333; text-decoration: underline; }
.u_link a:hover   { color:#007440; text-decoration: underline; }
.u_link a:active  { color:#333; text-decoration: underline; }

footer a         { resize: none; }
footer a:link    { color:#fff; text-decoration: none; }
footer a:visited { color:#fff; text-decoration: none; }
footer a:hover   { color:#ccc; text-decoration: none; }
footer a:active  { color:#fff; text-decoration: none; }

em { color: #C00;}

sub { font-size: 0.6em;}
.far.fa-window-restore { color: #ccc; }
/*-- リスト全体をリンク　hover透過　グループリンク
-------------------------------------------------------------*/
.g_box { position:relative; }
.g_box:hover { cursor:pointer; opacity:0.7; }
.g_link { margin-bottom:0px; }
.g_link a {position:absolute; text-indent:-9999px; top:0px; left:0px; width:100%; height:100%; z-index: 2; }

@media screen and (max-width: 599px) {
	.pc { display: none; }
}
@media screen and (min-width: 600px) {
	.sp { display: none; }
	.alC_pc { text-align: center; }
}
@media screen and (max-width: 1079px) {
	.pc_tab { display: none; }
}
@media screen and (min-width: 1080px) {
	.sp_tab { display: none; }
}
@media screen and (max-width: 899px) {
	.pc_tab_mini { display: none; }
}
@media screen and (min-width: 900px) {
	.sp_tab_mini { display: none; }
}
/*-- imaga -------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	.img_t_R { float:right; margin:0 0 2% 4%; width:45%;}
	.img_t_L { float:left; margin:0 4% 2% 0; width:45%;}
	.img_y_R { margin:0 10% 4%; width:80%;}
	.img_y_L { margin:0 10% 4%; width:80%;}
}
@media screen and (min-width: 768px) {
	.img_t_R { float:right; margin:0 0 40px 40px; width:25%;}
	.img_t_L { float:left; margin:0 20px 20px 0; width:240px;}
	.img_y_R { float:right; margin:0 0 40px 40px; width:30%;}
	.img_y_L { float:left; margin:0 20px 20px 0; width:150px;}
}

/*-- base -------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.in { width: 96%; margin: 0 2%; }
	#keyVisual .in { width: 100%; margin: 0 auto; }
	#content .in { width: 100%; margin: 0 auto; }
}
@media screen and (min-width: 600px) {
	header .in { width: 96%; margin: 0 2%; }
}
@media screen and (min-width: 600px) and (max-width: 1260px) {
	header .in { width: 98%; margin: 0 1%; }
	#content .in { width: 96%; margin: 0 2%; }
	#keyVisual .in { width: 100%; margin: 0 auto; }
}

/*-- header -------------------------------------------------------------*/
header { position: fixed; left: 0; top: 0; width: 100%; z-index: 9999; background: rgb(0,0,0); background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.4) 100%);}
@media screen and (max-width: 1079px) {
	h1 { font-size:10px; color:#fff; margin-bottom: 5px; }
	header .in-head-flex .hL { margin-left: 1%; }
	header .in-head-flex .hL .logo { margin-bottom: 5px; width: 100px;}
}
@media screen and (min-width: 900px) and (max-width: 1079px) {
	header .in-head-flex .hL .logo { width: 130px; }
}
@media screen and (min-width: 1080px) {
	h1 { font-size: 10px; color: #fff; margin-bottom: 0px; }
	header .in-head-flex { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px;}
	header .in-head-flex .hL .logo { width: 150px; }
	header .in-head-flex .hR { width: 80%;}
	header .in-head-flex .hR ul { display: flex; justify-content: flex-end; align-items: center; }
	header .in-head-flex .hR ul li { margin-left: 2%; font-size: 0.95rem; }
	header .in-head-flex .hR ul li.telHead p { color: #fff; line-height: 1.0; background: url("../img/common/icon-tel-wh.png") left top no-repeat; background-size: 40px; padding-left: 45px; margin-bottom: 0px; }
	header .in-head-flex .hR ul li.telHead p .xlarge { font-size: 2.3rem; }
	header .in-head-flex .hR ul li.telHead p .xsmall { display: block; font-size: 0.7rem; font-weight: normal; }
	header .in-head-flex .hR ul li.telHead p .xsmall .roboto { font-size: 0.9rem; margin-right: 5px; }
	header .in-head-flex .hR ul li.telHead p .fa-phone { display: none; }

	header .in-head-flex .hR ul li { color: #fff;}
	header .in-head-flex .hR ul li a         { resize: none; }
	header .in-head-flex .hR ul li a:link    { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li a:visited { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li a:hover   { color:#dedede; text-decoration: none; }
	header .in-head-flex .hR ul li a:active  { color:#fff; text-decoration: none; }
	
	header .in-head-flex .hR ul li.contactHead { margin-left: 1%;}
	header .in-head-flex .hR ul li.contactHead p { margin-bottom: 0px;}
	header .in-head-flex .hR ul li.contactHead p a { margin-bottom: 0px; background: #007440; height: 30px; line-height: 30px; min-width: 180px; text-align: center; border-radius: 20px; font-size: 0.9rem; border: 1px solid #007440; resize: none; display: block; font-size: 0.9rem;}
	header .in-head-flex .hR ul li.contactHead p a:link    { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li.contactHead p a:visited { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li.contactHead p a:hover   { color:#007440; text-decoration: none; background: #fff; }
	header .in-head-flex .hR ul li.contactHead p a:active  { color:#fff; text-decoration: none; }
	
	header .in-head-flex .hR ul li .fas { margin-right: 5px; opacity: 0.5; }
	header .in-head-flex .hR ul li .far { margin-right: 5px; opacity: 0.5; }
	header .in-head-flex .hR ul li.contactHead .fas { margin-right: 0px; opacity: 1.0; }
} 
@media screen and (min-width: 1080px) and (max-width: 1179px) {
	header .in-head-flex .hL { width: 15%; }
	header .in-head-flex .hL h1 { font-size: 0.6em; }
	header .in-head-flex .hL h1 span { display: none; }
	header .in-head-flex .hL .logo { width: 130px; }
	header .in-head-flex .hR { width: 85%;}
	header .in-head-flex .hR ul li { font-size: 0.75rem; }
	header .in-head-flex .hR ul li.telHead p .xlarge { font-size: 1.6rem; }
	header .in-head-flex .hR ul li.telHead p .xsmall { font-size: 0.60em;}
	header .in-head-flex .hR ul li.telHead p .xsmall .roboto { font-size: 0.7rem; }
	header .in-head-flex .hR ul li.telHead p { background-size: 30px; padding-left: 35px;}
	header .in-head-flex .hR ul li.contactHead p a {  min-width: 140px; font-size: 0.8rem; }
}
@media screen and (min-width: 1180px) and (max-width: 1279px) {
	header .in-head-flex .hL { width: 15%; }
	header .in-head-flex .hL h1 { font-size: 0.6em; }
	header .in-head-flex .hL h1 span { display: none; }
	header .in-head-flex .hL .logo { width: 130px; }
	header .in-head-flex .hR { width: 85%;}
	header .in-head-flex .hR ul li { font-size: 0.80rem; }
	header .in-head-flex .hR ul li.telHead p .xlarge { font-size: 1.7rem; }
	header .in-head-flex .hR ul li.telHead p .xsmall { font-size: 0.60em;}
	header .in-head-flex .hR ul li.telHead p .xsmall .roboto { font-size: 0.7rem; }
	header .in-head-flex .hR ul li.telHead p { background-size: 30px; padding-left: 35px;}
	header .in-head-flex .hR ul li.contactHead p a {  min-width: 140px; font-size: 0.8rem; }
}
@media screen and (min-width: 1280px) and (max-width: 1479px) {
	header .in-head-flex .hL .logo { width: 140px; }
	header .in-head-flex .hR ul li { font-size: 0.85rem; }
	header .in-head-flex .hR ul li.telHead p .xlarge { font-size: 2.0rem; }
	header .in-head-flex .hR ul li.telHead p .xsmall { font-size: 0.6rem;}
	header .in-head-flex .hR ul li.telHead p { background-size: 35px; padding-left: 40px;}
	header .in-head-flex .hR ul li.contactHead p a { min-width: 150px; font-size: 0.85rem; }
}
/*-- nav -------------------------------------------------------------*/
@media screen and (max-width: 1079px) {
}
@media screen and (min-width: 1080px) {
	nav ul { display: flex; justify-content: flex-start; align-items: center; margin-bottom: 10px; }
	nav ul li { width: 16%; text-align: center; border-right: 1px solid #fff; font-size: 0.9rem; min-height: 40px; line-height: 1.5; display: flex; justify-content: center; align-items: center; position: relative; }
	nav ul li:nth-child(1) { width: 4%; border-left: 1px solid #fff; }
	nav ul li span { display: block; }
	nav ul li span.sp_tab { display: none; }
	
	nav ul li a         { resize: none; display: block; }
	nav ul li a:link    { color:#fff; text-decoration: none; }
	nav ul li a:visited { color:#fff; text-decoration: none; }
	nav ul li a:hover   { color:#005557; text-decoration: none; }
	nav ul li a:active  { color:#fff; text-decoration: none; }
	
	nav ul li a::after {
	  position: absolute;
	  bottom: -2px;
	  left: 5%;
	  content: '';
	  width: 90%;
	  height: 2px;
	  background: #005557;
	  transform: scale(0, 1);
	  transform-origin: left top;
	  transition: transform .3s;
	}
	nav ul li a:hover::after {
	  transform: scale(1, 1);
	}
}
@media screen and (min-width: 1080px) and (max-width: 1379px) {
	nav ul li { font-size: 0.85rem; min-height: 35px; }
}

/*-- is-fix  -------------------------------------------------------------*/
@media screen and (max-width: 899px) {
	header.is-fix h1 { display: none; }
	header.is-fix .in-head-flex .hL { display: none; }
}
@media screen and (min-width: 900px) {
	header.is-fix { background: rgba(255,255,255,0.9);}
	header.is-fix .in { max-width: 99.5%; margin: 0px 0 0px 0.5%; width: 100%; }
	header.is-fix .in-head-flex { margin-bottom: 0px; display: flex; justify-content: flex-end; }
	header.is-fix h1 { display: none; }
	header.is-fix .in-head-flex .hL { display: flex; justify-content: flex-start; width: 100%; padding: 5px 0; }
	header.is-fix .in-head-flex .hL .logo { display: block; width: 80px; }
	header.is-fix nav { display: none; }
	
	header.is-fix .in-head-flex .hR ul { display: flex; justify-content: flex-end; }
	header.is-fix .in-head-flex .hR ul li { font-size: 0.85rem; padding: 0 20px; word-break: keep-all; border-right: 1px solid #318e64; margin-left: 0px; color: #000; }
	header.is-fix .in-head-flex .hR ul li:nth-child(1) { border-left: 1px solid #318e64; }
	
	header.is-fix .in-head-flex .hR ul li a         { resize: none; display: block; }
	header.is-fix .in-head-flex .hR ul li a:link    { color:#000; text-decoration: none; }
	header.is-fix .in-head-flex .hR ul li a:visited { color:#000; text-decoration: none; }
	header.is-fix .in-head-flex .hR ul li a:hover   { color:#007440; text-decoration: none; }
	header.is-fix .in-head-flex .hR ul li a:active  { color:#000; text-decoration: none; }
	header.is-fix .in-head-flex .hR ul li.telHead { margin-left: 1%; padding: 0; border-right: none; text-align: center;}
	header.is-fix .in-head-flex .hR ul li.telHead p { background: none; padding-left: 0px; line-height: 50px; }
	header.is-fix .in-head-flex .hR ul li.telHead p span.xsmall { display: none; }
	header.is-fix .in-head-flex .hR ul li.telHead { background: #12a73b url("../img/common/fd-wh.png") 15px center no-repeat; background-size: 30px; width: 150px; min-width: 150px; }
	header.is-fix .in-head-flex .hR ul li.telHead p .xlarge { font-size: 1.1rem; padding: 0px; }
	header.is-fix .in-head-flex .hR ul li.telHead p .fa-phone { display: inline-block; margin-right: 5px; }
	header.is-fix .in-head-flex .hR ul li.contactHead { min-height: 51px; margin-left: 0px; padding: 0; border-right: none;  }
	header.is-fix .in-head-flex .hR ul li.contactHead p a { width: 50px; min-width: 50px; border-radius: 0px; min-height: 51px; border: none; display: flex; justify-content: center; align-items: center; font-size: 1.4rem; }
	header.is-fix .in-head-flex .hR ul li.contactHead p a span { display: none; }
	
	header.is-fix .in-head-flex .hR ul li .fas { display: none; }
	header.is-fix .in-head-flex .hR ul li .far { display: none; }
	header.is-fix .in-head-flex .hR ul li.contactHead .fas { display: block; }
}

/*--　megamenu  -------------------------------------------------------------*/
@media screen and (min-width: 1080px) {
	.h_menu li.h-menu { height: 40px; line-height: 40px;}
	.megaMenu { display: none; }
	.h_menu li.selected .megaMenu { display: flex !important; justify-content: center; padding: 20px 2%; background: #f4f4f4; position: absolute; top:50px; left: 2%; width: 96%; z-index: 10; }
	header.is-fix .h_menu li.selected .megaMenu { top:40px; }
	
	.h_menu li.selected .megaMenu .home { margin-right: 1%; }
	.h_menu li.selected .megaMenu .home-indus { margin-right: 1%; }
	.h_menu li.selected .megaMenu .indus { }
	.h_menu li.selected .megaMenu h6 { background: #000; color: #fff; margin-bottom: 10px; text-align: center; font-size: 0.8rem; padding: 0px 0; line-height: 25px; }
	.h_menu li.selected .megaMenu .home h6 { background: #FF6C00; }
	.h_menu li.selected .megaMenu .indus h6 { background: #2A83E8; }
	.h_menu li.selected .megaMenu .home-indus h6 { background: #66b793; color: #fff; }
	.h_menu li.selected .megaMenu .in-mega-flex { display: flex; justify-content: center; }
	.h_menu li.selected .megaMenu div.g_box { max-width: 100px; width: 100%;  padding: 0 10px; border-right: 1px solid #dedede; text-align: center;}
	.h_menu li.selected .megaMenu div.g_box.home-indus { border-right: none; }
	.h_menu li.selected .megaMenu div.g_box img { margin-bottom: 10px; }
	.h_menu li.selected .megaMenu div.brl { border-left: 1px solid #dedede; }
	.h_menu li.selected .megaMenu div.g_box p { color: #333; font-size: 0.7rem; text-align: center; margin-bottom: 0px; padding: 0px; line-height: 1.5; }
}
/*-- SP menu-trgger -------------------------------------------------------------*/
@media screen and (max-width: 1079px) {
	.menu-trigger,.menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box; }
	.menu-trigger { position: fixed; top: 1%; right: 4%; width: 35px; height: 33px; z-index: 9999; border-radius: 2px; }
	.menu-trigger:hover{ /*background: rgba(255, 255, 255,0.6);*/ cursor:pointer; }
	.menu-trigger span { position: absolute; z-index: 9999; left: 4.2px; width: 100%; height: 1px; background-color: #fff; border-radius: 2px; }
	.h_menu .active span { background-color: #fff !important; } /* 色を変える */
	.menu-trigger span:nth-of-type(1) { top: 7px; }
	.menu-trigger span:nth-of-type(2) { top: 16.5px; width: 75%; }
	.menu-trigger span:nth-of-type(3) { bottom: 6px; }
	.h_menu .active span:nth-of-type(3) { bottom: 8px; }
	.menu-trigger.active span:nth-of-type(1) {
	 -webkit-transform: translateY(20px) rotate(-45deg);
	 transform: translateY(8px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) { opacity: 0; }
	.menu-trigger.active span:nth-of-type(3) {
	 -webkit-transform: translateY(-20px) rotate(45deg);
	 transform: translateY(-8px) rotate(45deg);
	}
	#overlay{ display: none; width: 82%; margin: 0 0 0 10%; padding: 15% 4% 4%; height: calc(100% - 0px); text-align: center;
		position: fixed; top: 0px; right: 0px; z-index: 999; background: rgba(25,95,59,0.95); box-sizing: border-box;
		box-shadow: -4px 0px 16px -6px rgba(0,0,0,0.6);
	}
	#overlay .in { overflow: auto; height: 100%;
		-webkit-overflow-scrolling: touch;
	}	
	#overlay li { text-align: left; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px dotted #fff; font-size: 0.9rem; color: #fff; }
	#overlay li.intend:before { margin-left: 1em; content:"-"; display: inline-block; color: #fff; margin-right: 1em; }
	#overlay li.intend a { display: inline-block; }
	#overlay li a         { resize: none; display: block; /*font-family:'Roboto Condensed', sans-serif; font-weight:bold;*/ }
	#overlay li a:link    { color:#fff; text-decoration: none; }
	#overlay li a:visited { color:#fff; text-decoration: none; }
	#overlay li a:hover   { color:#fff; text-decoration: none; }
	#overlay li a:active  { color:#fff; text-decoration: none; }
	#overlay li:nth-child(3) span,#overlay li:nth-child(5) span { margin-right: 10px;}
	
	#overlay .subContact { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
	#overlay .subContact li { width: 33%; }
	#overlay .subContact li a:before { display: none; }
	#overlay li .fas { margin-right: 10px; opacity: 0.5; }
	#overlay li .far { margin-right: 10px; opacity: 0.5; }
	
	#overlay li .toggle { color: #fff; position: relative; margin-bottom: 0px; }
	#overlay li .toggle:after { content: "\f067"; font-family: "Font Awesome 5 Free"; font-weight: 900; position: absolute; right: 1%; top: 50%; transform:translateY(-50%); opacity: 0.7;}
	#overlay li .toggle.active:after { content: "\f068"; font-family: "Font Awesome 5 Free"; font-weight: 900; position: absolute; right: 1%; top: 50%; transform:translateY(-50%); opacity: 0.7;}
	#overlay li .toggleContent { padding: 4%; }
	#overlay li .toggleContent h6 { background: #1d4a35; text-align: center; margin-bottom: 10px; padding: 5px 0; color: #fff; }
	#overlay li .toggleContent ul li:before { content: "\f0da"; font-family: "Font Awesome 5 Free"; font-weight: 900; margin-right: 10px; color: #1d4a35; } 
	#overlay li .toggleContent ul li a { display: inline-block; }
	#overlay li .toggle.toggleTtl { border-left: 3px solid #fff; padding-left: 10px; }
}
@media screen and (min-width: 600px) and (max-width: 1079px) {
	.menu-trigger { position: fixed; top: 1%; right: 3%; }
	#overlay{ display: none; width: 40%; padding: 8% 4% 4%; }
}

.fa-phone { transform: rotate(90deg);}
/*-- コンテンツ -------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.secFlex { padding: 6% 0% 0; display: flex; flex-direction: column; }
	.flexImg { width: 100%; order: 1; margin-bottom: 20px; }
	.flexTxt { order: 2; }
	.flexTxt img { width: 100%; margin: 0 auto 20px; }
	
	.secFlex h2 { font-size: 1.5rem; font-weight: bold; margin-bottom: 10px; line-height: 1.5; }
	.secFlex h3 { font-size: 1.0rem; font-weight: bold; margin-bottom: 20px; }
	.secFlex ul.check li { padding-bottom: 10px; margin-bottom: 10px; border-bottom: 1px dashed #000; font-size: 0.9rem; color: #000; font-weight: bold; text-indent: -0.75em; padding-left: 1.5em; }
	.secFlex ul.check li:nth-child(1) { border-top: 1px dashed #000; padding-top: 10px; }
	.secFlex ul.check li .marker { color: #ed0000;}
	ul.check li .fa-check-circle { margin-right: 10px; color: #ccc;}
	
	.contactSec { background: #f4f4f4; padding: 6%; border-top: 1px solid #dedede; border-bottom: 1px solid #dedede; }
	.contactBox { background: #fff; padding: 20px; border: 1px solid #dedede; }
	.contactBox h2 { text-align: center; font-size: 1.0rem; margin-bottom: 10px; }
	.contactFlex { }
		
	.contactFlex li:nth-child(1) p { color: #000; line-height: 1.0; background: url("../img/common/fd-gr.png") 0 5px no-repeat; background-size: 40px; padding-left: 50px; margin-bottom: 20px; }
	.contactFlex li:nth-child(1) p .xlarge { font-size: 2.0rem; }
	.contactFlex li:nth-child(1) p .xsmall { display: block; font-size: 0.7rem; font-weight: normal; word-break: keep-all; }
	.contactFlex li:nth-child(1) p .xsmall .roboto { font-size: 0.9rem; margin-right: 5px; }
	
	.contactFlex li:nth-child(2) p { margin-bottom: 0px;}
	.contactFlex li:nth-child(2) p a { margin-bottom: 0px; background: #ff7e00; height: 35px; line-height: 35px; width: 80%; margin: 0 auto 10px; text-align: center; border-radius: 20px; font-size:0.9rem; border: 1px solid #ff7e00; resize: none; display: block;}
	.contactFlex li:nth-child(2) p a:link    { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:visited { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:hover   { color:#ff7e00; text-decoration: none; background: #fff; }
	.contactFlex li:nth-child(2) p a:active  { color:#fff; text-decoration: none; }
	
	.contactFlex li:nth-child(3) p { margin-bottom: 0px;}
	.contactFlex li:nth-child(3) p a { margin-bottom: 0px; background: #056238; height: 35px; line-height: 35px; width: 80%; margin: 0 auto; text-align: center; border-radius: 20px; font-size:1.0rem; border: 1px solid #056238; resize: none; display: block;}
	.contactFlex li:nth-child(3) p a:link    { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(3) p a:visited { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(3) p a:hover   { color:#056238; text-decoration: none; background: #fff; }
	.contactFlex li:nth-child(3) p a:active  { color:#fff; text-decoration: none; }
	
	.ttl01 { text-align: center; font-size: 1.5rem; font-weight: bold; margin-bottom: 20px; }
	.subTtl01 { text-align: center; font-size: 1.0rem; font-weight: bold; margin-bottom: 10px; }
	.mark { width: 30px; margin: 0 auto 10px; }
	.lead { text-align: center; margin-bottom: 20px;}
	
	.flexThird { }
	.flexThird li { margin-bottom: 20px; }
	.flexThird li h3 { text-align: center; font-size: 1.3rem; font-weight: bold; line-height: 1.0; margin-bottom: 10px; }
	.flexThird li h3 .roboto { font-size: 1.3em;}
	.flexThird li h4 { text-align: center; font-size: 1.3rem; font-weight: bold; line-height: 1.0; margin-bottom: 30px; }
	
	.flex-ul-li { display: flex; justify-content: center; flex-wrap: wrap; }
	.flex-ul-li li { width: 24%; margin: 0 1% 10px 0;}
	.flex-ul-li li:last-child { margin-right: 0px; }
	.flex-ul-li li div { margin-bottom: 10px; }
	.flex-ul-li li p { text-align: center; font-size: 0.7rem; }
	
	.fa-file-pdf { color: #b30c00; font-size: 1.0rem;}
	.fa-file-word { color: #1f5dbd; font-size: 1.0rem;}
	.fa-file-archive { color: #888888; font-size: 1.0rem;}
	.fa-file-excel { color: #0f7d3f; font-size: 1.0rem;}
	.fa-file-image { color: #0b3e8d; font-size: 1.0rem;}
	
	.flowList li { margin-bottom: 10px; }
	h4.toggle { background: #fff; height: 40px; line-height: 40px; position: relative; padding-left: 80px; font-size: 1.0rem; font-weight: bold; cursor: pointer; }
	h4.toggle span.roboto { background: #217440; color: #fff; min-width: 70px; position: absolute; left: 0; top: 0; text-align: center; font-size: 0.7rem; }
	h4.toggle:after { position: absolute; top: 50%; transform: translateY(-50%); right: 2%; content: "\f078"; font-family: "Font Awesome 5 Free"; font-weight: 900; opacity: 0.5; }
	h4.toggle.active:after { position: absolute; top: 50%; transform: translateY(-50%); right: 2%; content: "\f077"; font-family: "Font Awesome 5 Free"; font-weight: 900; opacity: 0.5; }
	h4.toggle .free { position: absolute; top: -20px; left: -20px; background:#ed0000; color: #fff; width: 40px; height: 40px; border-radius: 30px; text-align: center; line-height: 40px; font-size: 0.8rem;}
	.flowContent { background: #fff; padding: 2% 4%; }
	.tcFlex { border-top: 1px solid #000; padding-top: 2%; }
	.tcFlexL {  }
	.tcFlexR { width: 60%; margin: 0 auto; }
	.tcFlexL .contactFlex { display: flex; flex-direction: column; }
	.tcFlexL .contactFlex li:nth-child(2) { margin-bottom: 10px; }
	.tcFlexL .contactFlex li:nth-child(3) { margin-bottom: 20px; }
	
	.newsDl { display: flex; justify-content: flex-start; align-items: center; margin-bottom: 20px; }
	.newsDl dt { background: #217440; color: #fff; font-size: 10px; height: 20px; line-height: 20px; padding: 0 10px; border: 1px solid #217440; font-family:'Roboto Condensed', sans-serif; font-weight:bold; }
	.newsDl dd { background: #fff; color: #217440; font-size: 10px; height: 20px; line-height: 20px; padding: 0 10px; border: 1px solid #217440; font-family:'Roboto Condensed', sans-serif; font-weight:bold; }
	
	.newsList li { margin-bottom: 40px;}
}
@media screen and (min-width: 600px) {
	section .in { margin: 0 2%; padding: 40px 0; }
	section.contactSec .in { margin: 0; padding: 0;}
	section.one-column .in { max-width: 1200px; margin: 0 auto; width: 96%; }
	
	.secFlex { display: flex; justify-content: center; align-items: center; margin: 4% 4%; }
	.flexImg { width: 40%; }
	.flexTxt { width: 52%; padding: 4%; }
	
	.secFlex h2 { font-size: 2.4rem; margin-bottom: 10px; line-height: 1.5; color: #1aafa8; }
	.secFlex h3 { font-size: 1.2rem; margin-bottom: 20px; }
	.secFlex h6 { color: #dedede;}
	.secFlex ul.check li { padding-bottom: 10px; margin-bottom: 10px; border-bottom: 1px dashed #000; font-size: 1.2rem; width: 80%; color: #000; font-weight: bold; text-indent: -0.75em; padding-left: 1.5em; }
	.secFlex ul.check li:nth-child(1) { border-top: 1px dashed #000; padding-top: 10px; }
	.secFlex ul.check li .marker { color: #ed0000;}
	ul.check li .fa-check-circle { margin-right: 10px; color: #ccc;}
	
	.secFlex .flexTxt.flexL h2 { text-align: right;}
	.secFlex .flexTxt.flexL h3 { text-align: right;}
	.secFlex .flexTxt.flexL h6 { text-align: right;}
	
	.arrowR { float: right; }
	
	.contactSec { background: #f4f4f4; padding: 20px; border-top: 1px solid #dedede; border-bottom: 1px solid #dedede; }
	.contactBox { background: #fff; padding: 20px; max-width: 1000px; width: 100%; border: 1px solid #dedede; margin: 0 auto; }
	.contactBox h2 { text-align: center; font-size: 1.1rem; margin-bottom: 10px; }
	.contactFlex { display: flex; justify-content: center; align-items: center; }
	
	.contactFlex li:nth-child(1) p { color: #000; line-height: 1.0; background: url("../img/common/icon-tel.png") 0 0px no-repeat; background-size: 50px; padding-left: 55px; margin-bottom: 0px; margin-right: 20px; }
	.contactFlex li:nth-child(1) p .xlarge { font-size: 2.3rem; }
	.contactFlex li:nth-child(1) p .xsmall { display: block; font-size: 0.7rem; font-weight: normal; }
	.contactFlex li:nth-child(1) p .xsmall .roboto { font-size: 0.9rem; margin-right: 5px; }
	
	.contactFlex li:nth-child(2) p { margin-bottom: 0px;}
	.contactFlex li:nth-child(2) p a { margin-bottom: 0px; background: #ff7e00; height: 40px; line-height: 40px; min-width: 240px; text-align: center; border-radius: 20px; font-size:1.0rem; border: 1px solid #ff7e00; resize: none; display: block; margin-right: 20px;}
	.contactFlex li:nth-child(2) p a:link    { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:visited { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:hover   { color:#ff7e00; text-decoration: none; background: #fff; }
	.contactFlex li:nth-child(2) p a:active  { color:#fff; text-decoration: none; }
	
	.contactFlex li:nth-child(3) p { margin-bottom: 0px;}
	.contactFlex li:nth-child(3) p a { margin-bottom: 0px; background: #056238; height: 40px; line-height: 40px; min-width: 240px; text-align: center; border-radius: 20px; font-size:1.0rem; border: 1px solid #056238; resize: none; display: block;}
	.contactFlex li:nth-child(3) p a:link    { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(3) p a:visited { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(3) p a:hover   { color:#056238; text-decoration: none; background: #fff; }
	.contactFlex li:nth-child(3) p a:active  { color:#fff; text-decoration: none; }
	
	.ttl01 { text-align: center; font-size: 2.7rem; font-weight: bold; margin-bottom: 10px; }
	.subTtl01 { text-align: center; font-size: 1.8rem; font-weight: bold; margin-bottom: 0px; }
	.mark { width: 50px; margin: 0 auto 10px; }
	.lead { text-align: center; margin-bottom: 20px;}
	
	.flexThird { display: flex; justify-content: space-between; }
	.flexThird li { width: 31%; }
	.flexThird li h3 { text-align: center; font-size: 2.0rem; font-weight: bold; line-height: 1.0; margin-bottom: 10px; }
	.flexThird li h3 .roboto { font-size: 1.5em;}
	.flexThird li h4 { text-align: center; font-size: 2.0rem; font-weight: bold; line-height: 1.0; margin-bottom: 30px; }
	.flexThird li div { margin-bottom: 20px;}
	
	.flex-ul-li { display: flex; justify-content: center; flex-wrap: wrap; }
	.flex-ul-li li { width: 24%; margin: 0 1% 10px 0;}
	.flex-ul-li li:last-child { margin-right: 0px; }
	.flex-ul-li li div { margin-bottom: 10px; }
	.flex-ul-li li p { text-align: center; font-size: 0.7rem; }
	
	.fa-file-pdf { color: #b30c00; font-size: 1.1rem;}
	.fa-file-word { color: #1f5dbd; font-size: 1.1rem;}
	.fa-file-archive { color: #888888; font-size: 1.1rem;}
	.fa-file-excel { color: #0f7d3f; font-size: 1.1rem;}
	.fa-file-image { color: #0b3e8d; font-size: 1.1rem;}
	
	.flowList li { margin-bottom: 20px; }
	h4.toggle { background: #fff; height: 60px; line-height: 60px; position: relative; padding-left: 140px; font-size: 1.2rem; font-weight: bold; cursor: pointer; }
	h4.toggle span.roboto { background: #217440; color: #fff; min-width: 120px; position: absolute; left: 0; top: 0; text-align: center; }
	h4.toggle:after { position: absolute; top: 50%; transform: translateY(-50%); right: 2%; content: "\f078"; font-family: "Font Awesome 5 Free"; font-weight: 900; opacity: 0.5; }
	h4.toggle.active:after { position: absolute; top: 50%; transform: translateY(-50%); right: 2%; content: "\f077"; font-family: "Font Awesome 5 Free"; font-weight: 900; opacity: 0.5; }
	h4.toggle .free { position: absolute; top: -20px; left: -30px; background:#ed0000; color: #fff; width: 60px; height: 60px; border-radius: 30px; text-align: center; line-height: 60px;}
	.flowContent { background: #fff; padding: 2% 4%; }
	.tcFlex { display: flex; justify-content: space-between; border-top: 1px solid #000; padding-top: 2%; }
	.tcFlexL { width: 70%; }
	.tcFlexR { width: 24%; }
	.tcFlexL .contactFlex { display: flex; justify-content: flex-start; align-items: center; }
	
	.newsDl { display: flex; justify-content: flex-start; align-items: center; }
	.newsDl dt { background: #217440; color: #fff; font-size: 12px; height: 20px; line-height: 20px; padding: 0 10px; border: 1px solid #217440; font-family:'Roboto Condensed', sans-serif; font-weight:bold; }
	.newsDl dd { background: #fff; color: #217440; font-size: 12px; height: 20px; line-height: 20px; padding: 0 10px; border: 1px solid #217440; font-family:'Roboto Condensed', sans-serif; font-weight:bold; }
	.newsList { margin-bottom: 40px; }
	.newsList li { margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid #dedede; }
	.newsList li p { margin-bottom: 0px;}
}
@media screen and (min-width: 600px) and (max-width: 899px)  {
	.ttl01 { font-size: 2.3rem; }
	.subTtl01 { font-size: 1.4rem; }
	
	.secFlex { padding: 6% 6% 0; display: flex; flex-direction: column; }
	.flexImg { width: 100%; order: 1; margin-bottom: 20px; padding: 0; }
	.flexTxt { order: 2; width: 100%; padding: 0; }
	.flexTxt img { width: 80%; margin: 0 auto 20px; }
	
	.secFlex h2 { font-size: 1.6rem; }
	.secFlex h3 { font-size: 1.00rem; }
	.secFlex ul.check li {font-size: 1.00rem; width: 96%; }
	
	.contactBox { max-width: 660px; width: 100%; margin: 0 auto; }
	
	.flexThird li { width: 32%; }
	.flexThird li h3 { font-size: 1.5rem; }
	.flexThird li h4 { font-size: 1.5rem; }
	
	.flowList { margin: 0 2%; }
	.tcFlexL .contactFlex { display: flex; flex-direction: column; }
	.tcFlexL .contactFlex li:nth-child(1) { display: none; }
	
	.contactFlex li:nth-child(1) p { background-size: 30px; padding-left: 35px; margin-right: 10px; }
	.contactFlex li:nth-child(1) p .xlarge { font-size: 2.0rem; }
	.contactFlex li:nth-child(1) p .xsmall { display: block; font-size: 0.6rem; font-weight: normal; }
	.contactFlex li:nth-child(1) p .xsmall .roboto { font-size: 0.8rem; margin-right: 5px; }
	.contactFlex li:nth-child(2) p a { height: 30px; line-height: 30px; min-width: 180px; font-size:0.9rem; margin-right: 10px;}
	.contactFlex li:nth-child(3) p a { height: 30px; line-height: 30px; min-width: 180px; font-size:0.9rem;}
}
@media screen and (min-width: 900px) and (max-width: 1079px)  {
	.ttl01 { font-size: 2.4rem; }
	.subTtl01 { font-size: 1.5rem; }
	.secFlex { align-items: flex-start; }
	.secFlex h2 { font-size: 2.0rem; }
	.secFlex h3 { font-size: 1.05rem; }
	.secFlex ul.check li {font-size: 1.05rem; width: 100%; }
	
	.contactBox { max-width: 820px; width: 100%; margin: 0 auto; }
	
	.flexThird li h3 { font-size: 1.6rem; }
	.flexThird li h4 { font-size: 1.6rem; }
}
@media screen and (min-width: 1080px) and (max-width: 1179px)  {
	.ttl01 { font-size: 2.5rem; }
	.subTtl01 { font-size: 1.6rem; }
	.secFlex h2 { font-size: 2.4rem; }
	.secFlex h3 { font-size: 1.05rem; }
	.secFlex ul.check li {font-size: 1.05rem;  width: 100%;}

	.flexThird li h3 { font-size: 1.7rem; }
	.flexThird li h4 { font-size: 1.7rem; }
}
@media screen and (min-width: 1180px) and (max-width: 1279px)  {
	.ttl01 { font-size: 2.5rem; }
	.subTtl01 { font-size: 1.6rem; }
	.secFlex h2 { font-size: 2.5rem; }
	.secFlex h3 { font-size: 1.1rem; }
	.secFlex ul.check li {font-size: 1.1rem; width: 100%; }
	
	.flexThird li h3 { font-size: 1.8rem; }
	.flexThird li h4 { font-size: 1.8rem; }
}
@media screen and (min-width: 1280px) and (max-width: 1379px)  {
	.ttl01 { font-size: 2.6rem; }
	.subTtl01 { font-size: 1.7rem; }
	.secFlex h2 { font-size: 2.6rem; }
	.secFlex h3 { font-size: 1.15rem; }
	.secFlex ul.check li {font-size: 1.15rem; width: 100%; }
	
	.flexThird li h3 { font-size: 1.9rem; }
	.flexThird li h4 { font-size: 1.9rem; }
}
@media screen and (min-width: 1380px) {
	
}

/*-- FAQ DOWNLOAD SEC  -------------------------------------------------------------*/
@media screen and (max-width: 1079px) {	
	.facSec ul { display: flex; justify-content: center; align-items: center; }
	.facSec ul li { width: 34%; position: relative; height: 250px;  }
	.facSec ul li:nth-child(1) { background: url("../img/common/faqsec01.jpg") center center no-repeat; background-size: cover; }
	.facSec ul li:nth-child(2) { background: url("../img/common/faqsec02.jpg") center center no-repeat; background-size: cover; }
	.facSec ul li:nth-child(3) { background: url("../img/common/faqsec03.jpg") center center no-repeat; background-size: cover; }
	.facSec ul li .in-faqsec { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 2; width: 80%; text-align: center; }
	.facSec ul li .ovry { 
		position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0.8; z-index: 1;
		background-image: linear-gradient(45deg, rgba(0, 0, 0, .8) 50%, rgba(0, 0, 0, .9) 50%);
		background-size: 3px 3px;
	}
	.facSec ul li h3 { color: #fff; text-align: center; font-size: 1.1rem;  }
	.facSec ul li h6 { color: #fff; text-align: center; font-size: 0.7rem; line-height: 1.0; opacity: 0.5; margin-bottom: 10px;  }
	.facSec ul li p { font-size: 0.9rem; color: #fff; }
}
@media screen and (max-width: 599px) {
	.facSec ul { display: block; }
	.facSec ul li { width: 100%; position: relative; height: 200px;  }
	.facSec ul li .in-faqsec { width: 80%; }
	.facSec ul li p { text-align: center; font-size: 0.8rem; }
}
@media screen and (min-width: 1080px) {
	.facSec ul { display: flex; justify-content: center; align-items: center; }
	.facSec ul li { width: 34%; position: relative; height: 250px;  }
	.facSec ul li:nth-child(1) { background: url("../img/common/faqsec01.jpg") center center no-repeat; background-size: cover; }
	.facSec ul li:nth-child(2) { background: url("../img/common/faqsec02.jpg") center center no-repeat; background-size: cover; }
	.facSec ul li:nth-child(3) { background: url("../img/common/faqsec03.jpg") center center no-repeat; background-size: cover; }
	.facSec ul li .in-faqsec { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 2; width: 80%; text-align: center; }
	.facSec ul li .ovry { 
		position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0.8; z-index: 1;
		background-image: linear-gradient(45deg, rgba(0, 0, 0, .8) 50%, rgba(0, 0, 0, .9) 50%);
		background-size: 3px 3px;
	}
	.facSec ul li h3 { color: #fff; text-align: center; font-size: 1.1rem;  }
	.facSec ul li h6 { color: #fff; text-align: center; font-size: 0.7rem; line-height: 1.0; opacity: 0.5; margin-bottom: 10px;  }
	.facSec ul li p { font-size: 0.9rem; color: #fff; }
}
/*-- footer fix bnr  -------------------------------------------------------------*/
@media screen and (max-width: 1079px) {
	#contact-fixed ul { position: fixed; z-index: 888; bottom: 0; left: 0.5%; right: 0.5%; margin: 0 auto; width: 99%; display: flex; justify-content: center;}
	#contact-fixed ul li { width: 33%; }
}
@media screen and (min-width: 900px) and (max-width: 1079px) {
	#contact-fixed { display: none; }
}
/*-- pc
@media screen and (min-width: 768px) {
	#contact-fixed { position: fixed; z-index: 888; bottom: 0; left: 0; background: rgba(148,75,67,0.7); padding: 1%; width: 100%; }
	#contact-fixed ul { display: flex; justify-content: center;}
	#contact-fixed ul li { margin-right: 1%; }
	#contact-fixed ul li:last-child { margin-right: 0px;}
}
@media screen and (min-width: 768px) and (max-width: 960px)  {
	#contact-fixed .in { margin:0 1%; }
}
@media screen and (min-width: 961px) and (max-width: 1259px)  {
	#contact-fixed .in { margin:0 1%; }
}
@media screen and (min-width: 1260px) and (max-width: 1319px)  {
	#contact-fixed .in { margin:0 2%; }
}
@media screen and (min-width: 1320px) {
	#contact-fixed .in { width: 1260px; margin: 0 auto;}
}
-- */
/*-- footer ------------------------------------------------------------*/
footer { position: relative; z-index: 10;}
footer a         { resize: none; }
footer a:link    { color:#000; text-decoration: none; }
footer a:visited { color:#000; text-decoration: none; }
footer a:hover   { color:#007440; text-decoration: none; }
footer a:active  { color:#000; text-decoration: none; }

footer .in-f-R h5 a         { resize: none; }
footer .in-f-R h5 a:link    { color:#007440; text-decoration: none; }
footer .in-f-R h5 a:visited { color:#007440; text-decoration: none; }
footer .in-f-R h5 a:hover   { color:#000; text-decoration: none; }
footer .in-f-R h5 a:active  { color:#007440; text-decoration: none; }
@media screen and (max-width: 599px) {
	footer { background:#F5F4EF;}
	footer .in { color:#000; padding: 6% 6%; width: 88%; margin: 0 auto; }
	footer .in .fLogo { width: 60%; margin:0 auto 10px; }
	footer .in .grLogo { width: 40%; margin:0 auto 20px; }
	footer .in p { text-align: center; font-size: 0.8rem; line-height: 1.5; }
	
	.in-f-L-in { margin-bottom: 20px; }
	.in-f-R ul { margin-bottom: 20px; }
	.in-f-R ul li { margin-bottom: 10px; font-size: 0.8rem; }
	.in-f-R ul li.intend:before { content:"-"; font-family:'Noto Sans Japanese','Hiragino Kaku Gothic ProN','メイリオ', serif;; font-weight: bold; margin-right:5px; color:#056238;}
	.in-f-R h5 { color: #056238; border-bottom: 1px solid #056238; padding-bottom: 10px; margin-bottom: 10px; font-size: 0.9rem; font-weight: bold;}
	.in-f-R h6 { color: #056238; margin-bottom: 10px; font-size: 0.8rem; font-weight: bold; border-left: 3px solid #056238; padding-left: 10px; }
	
	.nice-g-logo { text-align: center; width: 60%; margin: 0 auto; }
}
@media screen and (min-width: 600px) {	
	footer { background:#F5F4EF; }
	footer .in { color:#000; padding:30px 2%; }
	footer .in .fLogo { width: 240px; margin:0 0 20px; }
	footer .in .grLogo { width: 180px; margin:0 0 20px; }
	footer .in p { text-align: left; font-size: 0.9rem; word-break: keep-all; }
	
	.in-f-R ul { margin-bottom: 20px; }
	.in-f-R ul li { margin-bottom: 10px; font-size: 0.8rem; padding-left: 1em; text-indent: -1em; }
	.in-f-R ul li:before { content:"\f0da"; font-family:"Font Awesome 5 Free"; font-weight: bold; margin-right:5px; color:#056238;}
	.in-f-R ul li.intend:before { content:"-"; font-family:'Noto Sans Japanese','Hiragino Kaku Gothic ProN','メイリオ', serif;; font-weight: bold; margin-right:5px; color:#056238;}
	.in-f-R h5 { color: #056238; border-bottom: 1px solid #056238; padding-bottom: 10px; margin-bottom: 10px; font-size: 0.9rem; font-weight: bold;}
	.in-f-R h6 { color: #056238; margin-bottom: 10px; font-size: 0.8rem; font-weight: bold; border-left: 3px solid #056238; padding-left: 10px; }
	
	.nice-g-logo { max-width: 200px; }
}
@media screen and (min-width: 600px) and (max-width: 899px) {	
	.in-f-L { display: flex; justify-content: flex-start; margin-bottom: 40px; }
	.in-f-R { display: flex; justify-content: flex-start; }
	.in-f-L-in { margin-right: 4%;}
	.in-f-R-in { margin-right: 4%; min-width: 200px; }
}
@media screen and (min-width: 900px) and (max-width: 1079px) {	
	footer .in .fLogo { width: 200px; margin:0 0 20px; }
	footer .in .grLogo { width: 140px; margin:0 0 20px; }
	
	.in-f-Flex { display: flex; justify-content: space-between;}
	.in-f-L { display: flex; justify-content: flex-start; margin-bottom: 40px; }
	.in-f-L-in { margin-right: 4%; width: 48%; }
	.in-f-L-in:last-child { margin-right: 0px;}
	.in-f-R { display: flex; justify-content: flex-end; }
	.in-f-R-in { margin-left: 4%; min-width: 30%; }
	.in-f-R-in:nth-child(1) { margin-left: 0%; min-width: 30%; }
}
@media screen and (min-width: 900px) {	
	.in-f-Flex { display: flex; justify-content: space-between;}
	.in-f-L { display: flex; justify-content: flex-start; width: 33%; }
	.in-f-L-in { margin-right: 6%; }
	.in-f-L-in:last-child { margin-right: 0px;}
	.in-f-R { display: flex; justify-content: flex-end; width: 66%; }
	.in-f-R-in { margin-left: 4%;  }
	.in-f-R-in:nth-child(1) { margin-left: 0%; }
}
@media screen and (min-width: 1080px) {	
	.f_menu_flex { display: flex; justify-content: flex-end; }
	/*.f_menu_flex div { margin-left: 6%; }*/
	.f_menu_flex div:nth-child(1) { margin-left: 0px; }
	
	.in-f-menu-flex { display: flex; justify-content: flex-end; }
	.in-f-menu-flex ul { margin-right: 4%; width: 180px; }
	.f_menu_flex ul:last-child { margin-right: 0px; }
}

/*-- copyright ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	#copyright { background:#dedede; text-align:center; margin-bottom:0px; padding:1px 0; color:#000; font-size:12px; }
}
@media screen and (min-width: 600px) {
	#copyright { background:#dedede;  text-align:center; margin-bottom:0px; padding:1px 0; color:#000; font-size:12px; }
}
/*-- pagetop ------------------------------------------------------------*/
#pagetop { background: #007440; }
#pagetop a         { color:#fff; display: block; resize: none; }
#pagetop a:link    { color:#fff; text-decoration: none; }
#pagetop a:visited { color:#fff; text-decoration: none; }
#pagetop a:hover   { color:#999; text-decoration: none; }
#pagetop a:active  { color:#fff; text-decoration: none; }
@media screen and (max-width: 599px) {
	#pagetop { width: 40px; height: 40px; line-height: 40px; position:fixed; right:5px; bottom:60px; opacity:0.8; z-index: 999; border-radius: 20px; text-align: center; }
}
@media screen and (min-width: 600px) and (max-width: 1079px) {
	#pagetop { width: 50px; height: 50px; line-height: 50px; position:fixed; right:20px; bottom:20px; opacity:0.8; z-index: 999; border-radius: 25px; text-align: center; }
}
@media screen and (min-width: 1080px) {
	#pagetop { width: 50px; height: 50px; line-height: 50px; position:fixed; right:20px; bottom:20px; opacity:0.8; z-index: 999; border-radius: 25px; text-align: center; }
}

/*-- box LINK ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.box_link_btn a { color:#000; width:80%; height:30px; line-height:30px; border:#000 1px solid; border-radius: 15px; display:block; text-align:center; margin:0 10%; background:#fff; font-size: 12px;}
	.box_link_btn a:link    { color:#000; text-decoration: none; }
	.box_link_btn a:visited { color:#000; text-decoration: none; }
	.box_link_btn a:hover   { color:#fff; text-decoration: none; background:#000; }
	.box_link_btn a:active  { color:#000; text-decoration: none; } 
}
@media screen and (min-width: 600px) {
	.box_link_btn a { color:#000; width:40%; height:40px; line-height:40px; border:#000 1px solid; border-radius: 20px; display:block; text-align:center; margin:0 30%; background:#fff; font-size: 15px;}
	.box_link_btn a:link    { color:#000; text-decoration: none; }
	.box_link_btn a:visited { color:#000; text-decoration: none; }
	.box_link_btn a:hover   { color:#fff; text-decoration: none; background:#000; }
	.box_link_btn a:active  { color:#000; text-decoration: none; }
	
	.box_link_btn_L a { margin: 0 0;}
	
	.box_link_btn_300 a { width: 300px; margin: 0 auto;}
	.box_link_btn_80 a { width: 80%; margin: 0 auto;}
	.box_link_btn_200 a { width: 200px; margin: 0 auto; height:30px; line-height: 30px; font-size: 0.8rem; }
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.box_link_btn a { width: 60%;}
}

@media screen and (min-width: 600px) {
	.flatbtn a {
		width: 200px;
		height: 35px;
		line-height: 35px;
		color: #fff;
		border: #ffa23e 1px solid;
		display: block;
		text-align: center;
		background: #ffa23e;
		border-bottom: #e68822 3px solid;
		border-radius: 4px;
	}
	.flatbtn a:hover {
		color:#ffa23e;
		background:#fff;
		text-decoration:none;
	}
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.flatbtn a {
		width: 160px;
		height: 30px;
		line-height: 30px;
	}
}

@media screen and (max-width: 599px) {
	.grd-btn a {
		position: relative;
		display: inline-block;
		margin: 0 15%;
		width: 70%;
		font-size: 0.7rem;
		/* font-weight: bold; */
		line-height: 35px;
		text-align: center;
		text-decoration: none;
		letter-spacing: 2px;
		color: #007440;
		background: #fff;
		border: 1px solid #007440;
		transition: 0.3s;
	}
	.grd-btn a:after{
		content: "";
		background: #007440;
		width: 12px;
		height: 1px;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		margin: auto;
	}

	.grd-btn a:hover{
		/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffd65e+0,febf04+100;Yellow+3D+%232 */
		background: #007440;
		color: #fff;
	}
	.grd-btn a:hover{ letter-spacing: 3px } 
	.grd-btn a:hover:after{ width: 20px; background: #fff; } 
}
@media screen and (min-width: 600px) {	
	.grd-btn a {
		position: relative;
		display: inline-block;
		margin: 0 auto 0;
		width: 250px;
		font-size: 0.8rem;
		/* font-weight: bold; */
		line-height: 40px;
		text-align: center;
		text-decoration: none;
		letter-spacing: 2px;
		color: #007440;
		background: #fff;
		border: 1px solid #007440;
		transition: 0.3s;
	}
	.grd-btn a:after{
		content: "";
		background: #007440;
		width: 12px;
		height: 1px;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		margin: auto;
	}

	.grd-btn a:hover{
		/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffd65e+0,febf04+100;Yellow+3D+%232 */
		background: #007440;
		color: #fff;
	}
	.grd-btn a:hover{ letter-spacing: 3px } 
	.grd-btn a:hover:after{ width: 20px; background: #fff; } 
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.grd-btn a { width: 240px; line-height: 40px; }
}
/*-- text-shadow ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.tShadow {
		text-shadow: 2px 2px 2px rgba(0,0,0,0.7), -2px -2px 2px rgba(0,0,0,0.7), -2px 2px 2px rgba(0,0,0,0.7), 2px -2px 2px rgba(0,0,0,0.7), 2px 0px 2px rgba(0,0,0,0.7), -2px -0px 2px rgba(0,0,0,0.7), 0px 2px 2px rgba(0,0,0,0.7), 0px -2px 2px rgba(0,0,0,0.7);
	}
	.tShadow-wh {
		text-shadow: 2px 2px 2px #fff, -2px -2px 2px #fff, -2px 2px 2px #fff, 2px -2px 2px #fff, 2px 0px 2px #fff, -2px -0px 2px #fff, 0px 2px 2px #fff, 0px -2px 2px #fff;
	}
}
@media screen and (min-width: 600px) {
	.tShadow {
		text-shadow: 3px 3px 3px rgba(0,0,0,0.7), -3px -3px 3px rgba(0,0,0,0.7), -3px 3px 3px rgba(0,0,0,0.7), 3px -3px 3px rgba(0,0,0,0.7), 3px 0px 3px rgba(0,0,0,0.7), -3px -0px 3px rgba(0,0,0,0.7), 0px 3px 3px rgba(0,0,0,0.7), 0px -3px 3px rgba(0,0,0,0.7);
	}
	.tShadow-wh {
		text-shadow: 3px 3px 3px #fff, -3px -3px 3px #fff, -3px 3px 3px #fff, 3px -3px 3px #fff, 3px 0px 3px #fff, -3px -0px 3px #fff, 0px 3px 3px #fff, 0px -3px 3px #fff;
	}	
}
/*-- sp tbl overscroll ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.scroll { overflow-y: scroll; padding: 0 4% 4%; margin-bottom: 60px; max-height: 300px; }
	.scroll::-webkit-scrollbar { width: 6px; }
	.scroll::-webkit-scrollbar-track { margin: 0 2px; background: #ccc; border-radius: 5px; }
	.scroll::-webkit-scrollbar-thumb { border-radius: 5px; background: #666; }
}
@media screen and (min-width: 600px) {
	.scroll { overflow-y: scroll; padding: 0 4% 4%; margin-bottom: 60px; max-height: 500px; }
	.scroll::-webkit-scrollbar { width: 10px; }
	.scroll::-webkit-scrollbar-track { margin: 0 2px; background: #ccc; border-radius: 5px; }
	.scroll::-webkit-scrollbar-thumb { border-radius: 5px; background: #666; }
}
/*-- list indent ------------------------------------------------------------*/
ol.indent { list-style-position: inside;}
ol.indent li { padding-left: 1em; text-indent: -1em;}
ul.indent { list-style-position: inside;}
ul.indent li { padding-left: 1em; text-indent: -1em;}

/*-- ol number list ------------------------------------------------------------*/
ol.type01 { margin-bottom: 40px; }
ol.type01 li { list-style-type: none; counter-increment: cnt; margin-bottom:10px; text-indent:-2.0em; padding-left:2.0em; border-bottom:#DEDEDE 1px dotted; padding-bottom:10px; }
ol.type01 li:before { content: counter(cnt)'）'; margin-right: 5px; /*font-family:'Roboto Condensed', sans-serif; font-weight:bold; font-size: 1.1rem;*/ }

ol.type01 li ol.type02 { margin-bottom: 40px; }
ol.type01 li ol.type02 li { list-style-type: none; counter-increment: cnt02; margin-bottom:10px; text-indent:-2.0em; padding-left:2.0em; border-bottom:none; padding-bottom:0px; }
ol.type01 li ol.type02 li:before { content: counter(cnt02)'.'; margin-right: 5px; /*font-family:'Roboto Condensed', sans-serif; font-weight:normal;*/ }

/*-- arrow list ------------------------------------------------------------*/
.arrow_list_w { margin-bottom:20px; }
.arrow_list_w li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; }
.arrow_list_w li:before { content:"\f101"; font-family: "Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:#217440; }

.arrow_list_s { margin-bottom:20px; }
.arrow_list_s li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; }
.arrow_list_s li:before { content:"\f105"; font-family: "Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:#217440; }

.arrow_list_t { margin-bottom:20px; }
.arrow_list_t li { padding:5px 0; text-indent:-1.5em; padding-left:2.0em; border-bottom:1px dotted #DEDEDE; font-size: 1.0rem; }
.arrow_list_t li:before { content:"\f0da"; font-family: "Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:#217440; }

.circle_list { margin:0 2% 0px; }
.circle_list li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list li:before { content:"\f111"; font-family: "Font Awesome 5 Free"; margin-right:10px; color:#f4f4f4; font-weight:900; font-size:1.0em; }

.circle_list02 { margin:0 2% 0px; }
.circle_list02 li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list02 li:before { content:"\f10c"; font-family: "Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:#217440; }

.circle_list03 { margin:0 2% 0px; }
.circle_list03 li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list03 li:before { content:"\f10c"; font-family: "Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:#217440; }

.circle_list04 { margin:0 2% 0px; }
.circle_list04 li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list04 li:before { content:"\f10c"; font-family: "Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:#217440; }

.arrow-button a {
	display:inline-block;
	cursor:pointer;
	position: relative;
	text-decoration: none;
	background: #92baa0;
	padding: 2px 40px 2px 10px;
	font-size: 0.8rem;
	color: #fff;
}
.arrow-button a::after {
	content: "";
	display: block;
	position: absolute;
	top: calc(50%);
	left: 95%;
	width: 40px;
	height: 5px;
	border: none;
	border-right: 2px solid #000;
	border-bottom: 1px solid #000;
	transform: skew(45deg);
	transition: .3s;
}
.arrow-button a:hover::after {
	position: absolute;
	top: calc(50%);
	left: 95%;
	width: 60px;
	height: 5px;
}

@media screen and (max-width: 599px) {
	.arrow-button a { font-size: 0.8rem; }
}
/*-- スマホメニュー開閉背景の色 ------------------------------------------------------------*/
.mm-menu { background:#54A583 !important; color:rgba(0, 0, 0, 0.7)  !important; }

/*--wordpress投稿　段落 ------------------------------------------------------------*/
.single_section h1 { font-size:2.4em; color:#333; font-weight:bold; margin-bottom:20px; }
.single_section h2 { font-size:2.1em; color:#333; font-weight:bold; border-left:6px solid #50A8ED; padding-left:2%; margin-bottom:20px; }
.single_section h3 { font-size:1.8em; color:#50A8ED; font-weight:bold; padding:2% 0; border-bottom:#333333 1px solid; margin-bottom:20px; }
.single_section h4 { font-size:1.5em; color:#333; font-weight:bold; margin-bottom:10px; }
.single_section h5 { font-size:1.2em; color:#333; font-weight:bold; margin-bottom:10px; }
.single_section p { line-height:1.7 !important; font-size:15px !important; margin-bottom:40px !important; }
.single_section img { margin-bottom:40px !important; }
.single_section strong { font-size: 1.2rem; }

/*-- wordpress 画像 ------------------------------------------------------------*/
.aligncenter { display: block; margin: 0 auto;}
.alignright { float: right; }
.alignleft { float: left; }

/*-- wordpress ページャーカラー ------------------------------------------------------------*/
#pager a:hover { background: #ccc !important; }
#pager .pages, #pager .current, #pager .extend, #pager a { color: #333 !important; background: #fff !important; }
#pager a { color: #333 !important;  }
#pager .pages, #pager .current { background: #dedede !important;}
#pager a.page { border: 1px solid #dedede; }

/*-- animation ------------------------------------------------------------*/
/* 点滅 */
.flash1{ animation: Flash1 1.0s infinite; }
@keyframes Flash1{ 50%{ opacity: 0.5; }}
/* 揺れる */
.fluffy { width: 100%; height: auto; animation: fluffy1 3s ease infinite; }
@keyframes fluffy1 {
  0% { transform:translateY(0) }
  5% { transform:translateY(0) }
  10% { transform:translateY(0) }
  20% { transform:translateY(-15px) }
  25% { transform:translateY(0) }
  30% { transform:translateY(-15px) }
  50% { transform:translateY(0) }
  100% { transform:translateY(0) }
}
	
/*-- Adjustment ------------------------------------------------------------*/
.mt5  { margin-top:  5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt40 { margin-top: 40px !important; }

.mr5  { margin-right:  5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
.mr40 { margin-right: 40px !important; }

.mb5  { margin-bottom:  5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb40 { margin-bottom: 40px !important; }

.ml5  { margin-left:  5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml40 { margin-left: 40px !important; }

.pg5  { padding:  5px !important; }
.pg10 { padding: 10px !important; }
.pg15 { padding: 15px !important; }
.pg20 { padding: 20px !important; }
.pg25 { padding: 25px !important; }
.pg30 { padding: 30px !important; }
.pg35 { padding: 35px !important; }
.pg40 { padding: 40px !important; }

.mg0  { margin: 0  !important; }
.pg0  { padding: 0 !important; }

.ofh  { overflow: hidden; }
.fltR { float: right; }
.fltL { float: left; }
.clr  { clear: both; }

.posRe { position: relative; }
.posAb { position: absolute; }

.alJ { text-align: justify; }
.alC { text-align: center; }
.alR { text-align: right; }
.alL { text-align: left; }

.xlarge { font-size: 1.2em; }
.large  { font-size: 1.1em; }

.xsmall { font-size: 0.8em; }
.small  { font-size: 0.9em; }

.bold { font-weight: bold; }
.red  { color: #C00; }
.blk {color:#000;}

.under {text-decoration:underline; border-color:#666;}

.marker { background:linear-gradient(transparent 60%, #ff6 60%); }

.border-dotted { display: block; clear: both; height: 1px; border: none; border-bottom: dotted 1px #ddd !important; }
.border-solid  { display: block; clear: both; height: 1px; border: none; border-bottom: solid 1px #ddd  !important; }

.trans-ease { -webkit-transition: all 0.6s ease; -moz-transition: all 0.6s ease; -ms-transition: all 0.6s ease; -o-transition: all 0.6s ease; transition: all 0.6s ease; }

.link-hover { -webkit-transition: all 0.6s ease; -moz-transition: all 0.6s ease; -ms-transition: all 0.6s ease; -o-transition: all 0.6s ease; transition: all 0.6s ease; }
.link-hover:hover { opacity: 0.7; filter: alpha(opacity=70); }

.roboto { font-family:'Roboto Condensed', sans-serif; font-weight:bold; }
.g_font { font-family: "Rounded Mplus 1c"; font-weight:300; }
.gothic { font-family: 'Noto Sans Japanese','Hiragino Kaku Gothic ProN','メイリオ', serif; }
.min { font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; }
.youtube { position: relative; width: 100%; padding-top: 56.25%; }
.youtube iframe { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important;}

/*-- clearfix ------------------------------------------------------------*/
.cf:after { visibility: hidden; display: block; font-size: 0; content: " "; clear: both; height: 0; }
/* *html .cf { zoom: 1; } */
*:first-child+html .cf { zoom: 1; } /* IE7 */

/*-- loading ------------------------------------------------------------*/
#loading{ position: absolute; left: 45%; top: 40%; }
#loader-bg { position: fixed; width: 100%; height: 100%; top: 0px; left: 0px; background: #fff; z-index: 8888; }
body{ background-color: #fff; }
@media screen and (max-width: 767px) { 
	#loading{ position: absolute; left: 45%; top: 40%; }
	#loading img { width:40px; }
}
@media screen and (min-width: 768px) and (max-width: 960px) {
	#loading{ position: absolute; left: 45%; top: 40%;}
	#loading img { width:50px; }
}
@media screen and (min-width: 961px) {
	#loading{ position: absolute; left: 48%; top: 40%;}
	#loading img { width:60px; }
}



