/* Common Styles ------------------------------------------ */
html { font-size: 100%; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; text-rendering: optimizelegibility; }
body {
	font-family:"Lucida Grande", "segoe UI", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Meiryo, Verdana, Arial, sans-serif;
	line-height: 1.5;
	color: #333;
	background-color: #fff;
	-webkit-font-smoothing: antialiased;
}

/*===============
#page_top
=================*/

#page_top{
  width: 50px;
  height: 50px;
  position: fixed;
  right: 10px;
  bottom: 50px;
  background: #3f98ef;
  opacity: 0.6;
  border-radius: 5px;
}
#page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f102';
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -10px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}


/*=============================================
common class
===============================================*/
.w100 { width: 100%!important; }


/*=============================================
main
===============================================*/
main#contents {
	width: 100%;
	margin: 0 auto;
} 
main#contents .inner {
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	padding: 3em 0;
} 
@media screen and (max-width: 640px){
		main#contents { 
	}
}

/*---------------
sld
---------------*/
#sld {
    position: relative;
	display: flex;
	justify-content: center;
	flex-direction:column;
    z-index: 3;
    height: 270px;
    padding-top: 130px;
    background:#fff;
	color: #333;
}
#sld h1.inner {
	color: #1C9671;
    position: relative;
    z-index: 5;
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
	font-size: 2.4rem;
	letter-spacing: 0.2rem;
	line-height: 1.2;
	text-align: left;
	font-weight: 600;
	font-style: normal;
	text-align: center;
}
#sld h1.inner .eng {
	color: #666;
	font-size: .4em;
	letter-spacing: normal;
	display: block;
}

@media screen and (max-width: 640px){
	#sld {
		height: 130px;
		padding-top: 40px;
	}
	#sld h2.inner {
		font-size: 1.6rem !important;
		text-align: center;
	}
	.sld_en {
		font-size: 0.5em;
	}	
}








main#contents .inner {
	width: 95%;
	max-width: 1000px;
	margin: 0 auto;
}
main#contents　section {
	margin-bottom: 60px;
}
.bg_yellow {
	background: #fbfce8;
	padding-top: 3em; padding-bottom: 3em;
}

@media screen and (max-width: 640px){
	main#contents .inner { width: 90%; }
}







/*=============================================
#投稿 single.php /  category.php
===============================================*/
section#news,
section#information { margin-bottom: 4em; }

section#news p, section#news ul,
section#information p, section#information ul { line-height: 1.8; padding: 0 1em; margin-bottom: 1em; }


section#information .post li::before,
section#news .post li::before {
	content: "●";
	color:#b2eafa;
	margin-right: 5px;
}

section#news .aligncenter,
section#information .aligncenter, aligncenter {
	margin-left: auto; margin-right: auto; margin-bottom: 1em;
	border: solid 1px #d9d9d9;
	display: block;
	width: 90%; max-width: 400px; height: auto;
}


section#news .no_border,
section#information .no_border, .no_border {
	border: none !important;
}



h1.title {
	position: relative;
	color: #1a1a1a;
	font-size: 24px;
	margin: 3em 0 10px;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	font-weight: 500;
	font-style: normal;	
	background:#b2eafa;
	padding: 10px 15px;
}


h2.sub_title {
	color: #1a1a1a;
	font-size: 20px;
	margin: 3em 0 20px;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	font-weight: 500;
	font-style: normal;	
	padding: 10px 15px;
	border-bottom: solid 2px #00A7D9;
}

.img_box#ZCE {
	width: 90%; max-width: 500px;
	margin: 0 auto 10px;
}
.img_box img {
	width: 100%; height: auto;
}


.post_data { font-size: 100%; margin: 0 0 2em; text-align: right; color: #666; }

@media screen and (max-width: 768px){
	h1.title {
		font-size: 20px;
	}
	h2.sub_title { font-size: 18px; }
	.post_data { font-size: 90%; margin: 0 0 2em; text-align: right; color: #666; }
}
@media screen and (max-width: 640px){

}


.wrap_post_menu {

    display: flex;
    justify-content: space-between;
    padding: 15px 0 0;
    margin-top: 60px;
    margin-bottom: 10px;
	border-top: dotted 1px #ccc;

}
.wrap_post_menu li {

    list-style: none;
    cursor: pointer;
    display: block;
    width: 30%;

}
.wrap_post_menu li.next { text-align: right; }
.wrap_post_menu a.btn_box {

    padding: 0.5em;
    margin: 10px 1em;
    display: block;
    color:#fff !important;
	background: rgba(180,180,180,0.9);
    text-decoration: none;
    font-weight: bold;
    font-size: 16px;
    border-radius: 30px;
    text-align: center;
    text-decoration: none !important;
    transition: all 0.6s ease 0s;

}
.wrap_post_menu a.btn_box:hover {
	background: #b2eafa;
}
.wrap_post_menu a.btn_box::before {

    content: "";
    display: inline-block;
    width: 18px;
    height: 18px;
    margin: -3px 5px 0 0;
    background: url(..images/btn_arrow_w.png) no-repeat;
        background-size: auto;
    background-size: contain;
    vertical-align: middle;

}

/*=============================================

index.php

===============================================*/
.mainvisual {
	width: 100%;
	background: #cae9f7;
	padding-top: 106px;
}
.mainvisual .inner {
	width: 100%; max-width: 1200px;
	height: 540px;
	background: url("../images/mainvisual_img.png") no-repeat;
	background-size: auto 100%;	
	background-position: right center;
	margin: 0 auto;
	display: flex;
	align-items: center;
}
.mainvisual .inner .img_box {
	width: 38%;
	min-width: 400px;
	margin-left: 20px;
	margin-right: 20px;
}
.mainvisual .inner .img_box a {
	transition: .3s;
}
.mainvisual .inner .img_box a:hover {
	opacity: .6;
}
@media screen and (max-width: 768px) {
	.mainvisual {
		padding-top: 70px;
	}	
	.mainvisual .inner {
		width: 100%; max-width: 1200px;
		height: 100vh;
		background: url("../images/mainvisual_img.png") no-repeat;
		background-size: 100% auto;	
		background-position: center top;
		justify-content: center;
		padding-top: 30vh;
	}	
	.mainvisual .inner .img_box {
		width: 90%;
		min-width: auto;
		margin-left: auto;
		margin-right: auto;
	}	
}

/*=========================
.index_intro
===========================*/
.index_intro .heading_box {
	background: url("../images/intro_bar_bg.png") repeat-x;
	background-size: auto 100%;
	position: relative;
	padding: 1.0em 0;
	text-align: center;
}
.index_intro .heading_box::after {
	content: "";
	background: url("../images/intro_bar_arrow.png") no-repeat;
	background-size: cover;
	width: 117px; height: 35px;
	position: absolute; left: 50%; bottom: 0;
	transform: translate(-50%, 100%);
	display: block;
}
.index_intro .heading_box h2 {
	font-size: 2.0em;
}
.txt_red,
.index_intro .heading_box h2 .txt_red {
	color:#fd0130;
}
.marker_yellow,
.index_intro .heading_box h2 .marker_yellow {
	background:-webkit-linear-gradient(transparent 60%, #ff6 60%);
	background:-o-linear-gradient(transparent 60%, #ff6 60%);
	background:linear-gradient(transparent 60%, #ff6 60%);
}

.index_intro h3 {
	font-size: 2.25em;
	position: relative;
	padding-left: 80px;
	margin: 50px auto;
	display: table;
}
.index_intro h3::before {
	content: "";
	background: url("../images/checkmark.png") no-repeat;
	background-size: cover;
	width: 72px; height: 72px;
	position: absolute; left: 0; top: 50%;
	transform: translateY(-50%);
	display: block;
}

.index_intro .onayami {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
}
.index_intro .onayami .box {
	width: 25%;
	padding: 20px 20px;
	text-align: center;
}
.index_intro .onayami .box.onayami_1 {
	background:url("../images/onayami_img_1.jpg");
}
.index_intro .onayami .box.onayami_2 {
	background-color: #cb970a;
}
.index_intro .onayami .box.onayami_3 {
	background-color: #29b58e;
}
.index_intro .onayami .box.onayami_4 {
	background:url("../images/onayami_img_4.jpg");
}
.index_intro .onayami .box h4 {
	font-size: 1.125em;
	color: #fff;
}
.index_intro .onayami .box h4 .num {
	display: inline-block;
	width: 25px; height: 25px;
	padding: 5px 5px 0 0;
}
.index_intro .onayami .box h4 .num img {
	width: 100%; height: auto;
}
.index_intro .onayami .box p {
	font-size: .8em;
	color: #fff;
}
.index_intro .onayami .box .img_box {
	width: 100%;
	height: 100px;
	text-align: center;
}
.index_intro .onayami .box .img_box img {
	width: 104px; height: auto;
}
@media screen and (max-width: 768px) {
	.index_intro .heading_box h2 {
		font-size: 1.5em;
		padding-left: .5em; padding-right: .5em;
	}	
	.index_intro h3 {
		font-size: 1.75em;
		padding-left: 50px;
		margin: 50px auto;
	}
	.index_intro h3::before {
		width: 40px; height: 40px;
	}	
	.index_intro .onayami .box {
		width: 50%;
	}	
}

/*=========================
.wrap_section
===========================*/
.wrap_section.bg_green {
	background:url("../images/bg_green.jpg");
	background-attachment: fixed;
	background-size: 100% auto;
}
.wrap_section.bg_kikagaku {
	background:url("../images/bg_kikagaku.jpg");
	background-attachment: fixed;
	background-size: 100% auto;
}

@media screen and (max-width: 768px) {
	.wrap_section.bg_green,
	.wrap_section.bg_kikagaku {
		background-size: cover;
	}	
}
	

/*=========================
.index_section_1
===========================*/
.index_section_1 {
	padding: 0 0 5em;
}
.index_section_1 h2 {
	font-size: 2.0em;
	text-align: center;
	padding: 3em 1em;
	position: relative;
}
.index_section_1 h2::after {
	content: "";
	width: 200px; height: 48px;
	background-image: url("../images/arrow3.png");
	background-size: cover;
	position: absolute; left: 50%; bottom: 0; transform: translate(-50%, -50%);
}

.index_section_1 .wrap_strong {
	background-color: #29b58e;
	width: 90%; max-width: 900px;
	margin: 0 auto;
	padding: 3em 2em;
	position: relative;
}
.index_section_1 .wrap_strong::before {
	content: "";
	background: url("../images/chumoku.png") no-repeat;
	background-size: cover;
	width: 221px; height: 157px;
	position: absolute; left: 0; top: 0;
	transform: translate(-10%,-50%);	
}
.index_section_1 .wrap_strong h3 {
	color: #fff;
	font-size: 3.0em;
	text-align: center;
	padding: 0 1em 1em;
	text-shadow: 3px 3px 3px rgba(0,0,0,.3);
}
.index_section_1 .wrap_strong p {
	color: #fff;
	font-size: 2.0em;
	text-align: center;
	padding: 0 1em;
	text-shadow: 3px 3px 3px rgba(0,0,0,.3);
}

@media screen and (max-width: 768px) {
	.index_section_1 h2 {
		font-size: 1.25em;
		text-align: center;
		padding: 2em 1em;
	}	
	.index_section_1 h2::after {
		width: 100px; height: 24px;
	}	
	.index_section_1 .wrap_strong {
		padding: 3em 1em;
		position: relative;
	}	
	.index_section_1 .wrap_strong::before {
		width: 110px; height: 77px;
		transform: translate(-10%,-50%);	
	}
	.index_section_1 .wrap_strong h3 {
		font-size: 1.5em;
	}
	.index_section_1 .wrap_strong p {
		font-size: 1.0em;
	}	
}


/*=========================
.index_section_contact
===========================*/

.index_section_contact .inner {
	width: 90%; max-width: 900px !important;
	margin: 0 auto;
	padding: 4em 0;
	position: relative;
}
.index_section_contact .wrap_contact {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.index_section_contact .wrap_contact .txt_box {
	width: auto;
	text-align: center;
	padding: 0 1em;
}
.index_section_contact .wrap_contact .img_box {
	width: 150px;
	padding: 0 1em;
}
.index_section_contact .wrap_contact .txt_box h3 {
	font-size: 2.0em;
	margin: 0 0 .5em;
}
.index_section_contact .wrap_contact .txt_box p {
	font-size: 1.0em;
}
.index_section_contact ul {
	display: flex;
	position: relative;
	background-color: #29b58e;
	margin: 0 auto 0;
}
.index_section_contact ul::after {
	content: "";
	background-color: #fff;
	width: 1px; height: 80%;
	position: absolute; left: 50%; top: 10%;
}
.index_section_contact li {
	width: 50%;
}
.index_section_contact li a {
	display: block;
	padding: 1em 1em;
	width: 100%;
	color: #fff;
	text-decoration: none;
	font-size: 1.5em;
	text-align: center;
}

.index_section_contact .btn_box a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    margin:0 auto;
    padding: .9em 2em;
    border: none;
    border-radius: 50vh;
    box-shadow: 0 2px 3px rgb(0 0 0 / 25%), 0 2px 3px -2px rgb(0 0 0 / 15%);
    background-color: #1aa96f;
    color: #fff;
    font-weight: 600;
    font-size: 1em;
	text-decoration: none;
	transition: .3s;
}
.index_section_contact .btn_box a::after {
  border-bottom: 3px solid #fff;
  border-right: 3px solid #fff;
  content: "";
  height: .3rem;
  transform: rotate(-45deg);
  width: .3rem;
}
.index_section_contact .btn_box a:hover {
    background-color: #11905c;
}

@media screen and (max-width: 768px) {
	.index_section_contact li a {
		font-size: 1.0em;
	}	
}



/*=========================
.index_section_　共通
===========================*/
.index_section_2,
.index_section_3,
.index_section_5,
.index_section_6,
.index_section_7 {
	padding: 0 0 5em;
	overflow-x: hidden;
}
.index_section_2 .inner,
.index_section_3 .inner,
.index_section_5 .inner,
.index_section_6 .inner,
.index_section_7 .inner {
	width: 90%; max-width: 1000px;
	margin: 0 auto;
}
.index_section_2 h3,
.index_section_3 h3,
.index_section_5 h3,
.index_section_7 h3 {
	color: #000;
	font-size: 2.0em;
	text-align: center;
	padding: 1em 1em;
	text-align: center;
	width: auto;
}
.index_section_2 h3 .eng,
.index_section_3 h3 .eng,
.index_section_5 h3 .eng,
.index_section_7 h3 .eng {
	font-size: 1.75em;
	text-align: center;
	padding: 3em 1em;
}
@media screen and (max-width: 768px) {
.index_section_2 h3,
.index_section_3 h3,
.index_section_5 h3,
.index_section_7 h3 {
	color: #000;
	font-size: 1.25em;
	text-align: center;
	padding: 1em 1em;
	text-align: center;
	width: auto;
}
.index_section_2 h3 .eng,
.index_section_3 h3 .eng,
.index_section_5 h3 .eng,
.index_section_7 h3 .eng {
	font-size: 1.5em;
	text-align: center;
	padding: 3em 1em;
}	
}
/*=========================
.index_section_2
===========================*/

.character {
	width: 100%;
}

.character .character_bg_right {
	margin-right: calc(50% - 50vw);
	padding: 40px calc(50vw - 50%) 40px 40px;
}
.character .character_bg_left {
	margin-left: calc(50% - 50vw);
	padding: 40px 40px 40px calc(50vw - 50%);
	display: flex;
	justify-content: flex-end;
}
.character .character_1 {
	background: url("../images/chara_bg_1.jpg") no-repeat;
	background-size: cover;
}
.character .character_2 {
	background: url("../images/chara_bg_2_1.jpg") no-repeat;
	background-size: cover;
}
.character .character_3 {
	background: url("../images/chara_bg_3_1.jpg") no-repeat;
	background-size: cover;
}
.character .character_4 {
	background: url("../images/chara_bg_4.jpg") no-repeat;
	background-size: cover;
}

.character .box_point {
	background-color: rgba(255,255,255,.6);
	position: relative;
	width: 90%;
	max-width: 500px;
	padding: 3em 2em 2em;
	min-height: 15em;
}
.character .box_point::after {
	content: "";
	width: 200px; height: 75px;
	position: absolute; left: 0; top: 0;
	transform: translate(-20px, -20px);
	background-size: cover;
}
.character .character_1 .box_point::after {
	background: url("../images/point_3.png") no-repeat;
}
.character .character_2 .box_point::after {
	background: url("../images/point_1.png") no-repeat;
}
.character .character_3 .box_point::after {
	background: url("../images/point_2.png") no-repeat;
}
.character .character_4 .box_point::after {
	background: url("../images/point_4.png") no-repeat;
}

.character .box_point h4 {
	color: #04815e;
	font-size: 2.25em;
	line-height: 1.2;
	margin: 0 0 .5em;
}
.character .box_point p {
	color: #000;
	font-size: 1.25em;
}

@media screen and (max-width: 768px) {
	.character .character_bg_right {
		margin-right: 0;
		padding: 30px 30px;
		display: flex;
		justify-content: center;
	}
	.character .character_bg_left {
		margin-left: 0;
		padding: 30px 30px;
		display: flex;
		justify-content: center;
	}	
	.character .box_point h4 {
		font-size: 1.5em;
	}	
}

/*=========================
.index_section_3
===========================*/
.index_section_3 {
	padding-bottom: 0;
}
.index_section_3 .message {
	background: url("../images/bg_tell.png") no-repeat;
	width: 90%; max-width: 1000px;
	margin: 0 auto;
	padding: 0;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
.index_section_3 .message .img_box {
	width: 50%;
}
.index_section_3 .message .txt_box {
	width: 50%;
}
.index_section_3 .message h4 {
	font-size: 2.0em;
	line-height: 1.2;
	text-align: center;
	margin-bottom: .5em;
}
.index_section_3 .message p {
	font-size: 1.25em;
	line-height: 1.5;
	text-align: center;
}
.index_section_3 .message h4 span {
	color: #047672;
	background-color: rgba(8,92,66,.3);
}

@media screen and (max-width: 768px) {
	.index_section_3 .message {
		background-size: auto 100%;
	}	
	.index_section_3 .message .img_box {
		width: 100%;
	}
	.index_section_3 .message .txt_box {
		width: 100%;
		padding: 1em 1em;
	}	
	.index_section_3 .message h4 {
		font-size: 1.5em;
	}
	.index_section_3 .message p {
		font-size: 1.0em;
	}	
}


/*=========================
.index_section_4
===========================*/
.index_section_4 {
	background: url("../images/genjou_bg.jpg") no-repeat;
	background-size: 100% auto;
	margin: 0 auto;
	padding: 90px 0;	
}
.index_section_4 .box_genjou {
	width: 90%; max-width: 900px;
	background: url("../images/genjou_bg_01.png") no-repeat;
	background-size: 100% auto;
	margin: 0 auto;
	padding: 50px 5%;
}
.index_section_4 .box_genjou_btm {
	width: 90%; max-width: 900px;
	margin: 0 auto;
	padding: 0;
}
.index_section_4 .box_genjou_btm img {
	width: 100%; height: auto;
	margin: 0 auto;
	padding: 0;
}

.index_section_4 .box_genjou h3 {
	color: #000;
  font-size: 2.0em;
  text-align: center;
  padding: 0 0 1em;
}
.index_section_4 .box_genjou h3 strong {
  color: #035e27;
}
.index_section_4 .box_genjou h3 .marker_yellow {
	background:-webkit-linear-gradient(transparent 60%, #ff6 100%);
	background:-o-linear-gradient(transparent 60%, #ff6 100%);
	background:linear-gradient(transparent 60%, #ff6 100%);
}
.index_section_4 .box_genjou p {
  font-size: 1.25em;
}
.index_section_4 .box_kaiketsu {
	background-color: #1b8f6c;
	width: 90%; max-width: 900px;
	margin: 0 auto;
	padding: 1em 1em;
	position: relative;
}
.index_section_4 .box_kaiketsu p {
	color: #fff;
	font-size: 3.0em;
	font-weight: 600;
	text-align: center;
	padding: 0;
	text-shadow: 3px 3px 3px rgba(0,0,0,.3);
}

@media screen and (max-width: 768px) {
	.index_section_4 {
		background-size: auto 100%;
	}	
	.index_section_4 .box_genjou {
		padding: 30px 5%;
	}	
	.index_section_4 .box_genjou h3 {
	  font-size: 1.25em;
	}	
	.index_section_4 .box_genjou p {
	  font-size: 1.0em;
	}
	.index_section_4 .box_kaiketsu p {
		font-size: 1.5em;
	}	
}


/*=========================
.index_section_5
===========================*/
.index_section_5 {
	background-color: #efefef;
}
.index_section_5 h4 {
	color: #f90404;
	font-size: 1.5em;
	text-align: center;
}
.index_section_5 .button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    margin:0 auto;
    padding: .9em 2em;
    border: none;
    border-radius: 5px;
    box-shadow: 0 2px 3px rgb(0 0 0 / 25%), 0 2px 3px -2px rgb(0 0 0 / 15%);
    background-color: #1aa96f;
    color: #fff;
    font-weight: 600;
    font-size: 1em;
	transition: .3s;
}
.index_section_5 .button::after {
  border-bottom: 3px solid #fff;
  border-right: 3px solid #fff;
  content: "";
  height: .3rem;
  transform: rotate(-45deg);
  width: .3rem;
}
.index_section_5 .button:hover {
    background-color: #11905c;
}
.index_section_5 .slider {
  margin: 30px auto 0;
  max-width: 900px;
  width: 95%;
}
.index_section_5 .slider .slick-slide img {
  height: auto;
  width: 100%;
}


@media screen and (max-width: 768px) {
	.index_section_5 h4 {
		font-size: 1.125em;
	}	
}


/*=========================
.index_section_6
===========================*/
.index_section_6 {
	
}
.index_section_6 h3 {
	color: #11905c;
	font-size: 2.0em;
	text-align: center;
	padding: 3em 0 2em;
	position: relative;
}
.index_section_6 h3:before {
	content: "ここからが特に重要な付加価値です！";
	background-color: #e4352b;
	color: #fff;
	font-size: .8em;
	padding: 5px 10px;
	position: absolute; left: 50%; top: 1em; transform: translateX(-50%);
	display: inline-block;
}

.index_section_6 dt {
	font-size: 2.0em;
}
.index_section_6 dd {
	font-size: 1.5em;
	margin-bottom: 1em;
}
.index_section_6 .matome {
	background-color: rgba(255,255,255,.5);
	box-shadow: 3px 3px 5px rgba(0,0,0,.5);
	padding: 0 2em 2em;
}
.index_section_6 .matome .arrow {
	text-align: center;
}
.index_section_6 .matome p {
	color: #ff0000;
	font-size: 2.0em;
	text-align: right;
}
.index_section_6 .matome p.references {
	color: #000;
	font-size: 1.0em;
	text-align: right;
}

@media screen and (max-width: 768px) {
	.index_section_6 h3 {
		font-size: 1.25em;
	}
	.index_section_6 h3:before {
		width: 90%;
	}	
	.index_section_6 dt {
		font-size: 1.25em;
	}
	.index_section_6 dd {
		font-size: 1.0em;
	}
	.index_section_6 .matome p {
		font-size: 1.25em;
		text-align: center;
	}	
}


/*=========================
.index_firststep
===========================*/
.index_firststep {
	padding: 0 0 5em;
}
.index_firststep .heading_box {
	background: url("../images/intro_bar_bg.png") repeat-x;
	background-size: auto 100%;
	position: relative;
	padding: 1.0em 0;
	text-align: center;
}
.index_firststep .heading_box::after {
	content: "";
	background: url("../images/intro_bar_arrow.png") no-repeat;
	background-size: cover;
	width: 117px; height: 35px;
	position: absolute; left: 50%; bottom: 0;
	transform: translate(-50%, 100%);
	display: block;
}
.index_firststep h2 {
	font-size: 2.0em;
}
.index_firststep .wrap_step {
	width: 90%; max-width: 900px; min-height: 260px;
	margin: 3em auto;	
	background-color: #fff;
	background-repeat: no-repeat;
	background-size: auto 100%;
	box-shadow: 3px 3px 5px rgba(0,0,0,.3);
	overflow: hidden;
	border-radius: 20px;
	padding: 3em 3em;
	
}
.index_firststep .wrap_step#step01 {
	background-image: url("../images/img_firststep_01.jpg");
	background-position: right top;
}
.index_firststep .wrap_step#step02 {
	background-image: url("../images/img_firststep_02.jpg");
	background-position: left top;
	padding: 3em 3em 3em 40%;
}
.index_firststep .wrap_step#step03 {
	background-image: url("../images/img_firststep_03.jpg");
	background-position: right top;
}
.index_firststep .wrap_step#mienai {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
}
.index_firststep .wrap_step#mienai .img_box {
	width: 48%;
}
.index_firststep .wrap_step#mienai .txt_box {
	width: 48%;
}
.index_firststep .wrap_step h3 {
	color: #449579;
	font-size: 1.75em;
	text-align: left;
	margin: 0 0 1em;
}

@media screen and (max-width: 768px) {
	.index_firststep h2 {
		font-size: 1.25em;
	}	
	.index_firststep .wrap_step {
		padding: 1em 2em;

	}
	.index_firststep .wrap_step#step01,
	.index_firststep .wrap_step#step02,
	.index_firststep .wrap_step#step03 {
		background-position: center top;
		padding: 12em 2em 2em;
	}
	.index_firststep .wrap_step .txt_box {
		background-color: rgba(255,255,255,.9);
		padding: 1em 1em;
	}
	.index_firststep .wrap_step h3 {
		font-size: 1.25em;
	}	
	
	.index_firststep .wrap_step#mienai .img_box {
		width: 100%;
	}
	.index_firststep .wrap_step#mienai .txt_box {
		width: 100%;
	}	
}


/*=========================
.index_section_7
===========================*/
.index_section_7 .inner {
	width: 90%; max-width: 900px !important;
	margin: 0 auto;
	padding: 2em 2em !important;
	position: relative;
}
.index_section_7 ul.menu_tab {
	display: flex;
	position: relative;
	background-color: #29b58e;
	margin: 1em auto 0;
}
.index_section_7 ul.menu_tab::before {
	content: "";
	background-color: #fff;
	width: 1px; height: 80%;
	position: absolute; left: 33%; top: 10%;
}
.index_section_7 ul.menu_tab::after {
	content: "";
	background-color: #fff;
	width: 1px; height: 80%;
	position: absolute; left: 66%; top: 10%;
}
.index_section_7 ul.menu_tab li {
	width: calc(100% / 3);

	display: block;
	padding: 1em 1em;
	color: #fff;
	text-decoration: none;
	font-size: 1.5em;
	text-align: center;
}
.index_section_7 .menu_plan {
	background-color: #ebeeea;
	padding: 2em 10%;
}
.index_section_7 .menu_plan h4 {
	font-size: 2.0em;
	color: #29b58e;
}
.index_section_7 .menu_plan li {
	font-size: 1.25em;
	position: relative;
	padding-left: 60px;
	margin: 30px auto;
	display: block;
	text-align: left;
}
.index_section_7 .menu_plan li::before {
	content: "";
	background: url("../images/checkmark.png") no-repeat;
	background-size: cover;
	width: 48px; height: 48px;
	position: absolute; left: 0; top: 50%;
	transform: translateY(-50%);
	display: block;
}


/*=========================
.index_section_7 .flow
===========================*/
.index_section_7 h3.title_flow {
	color: #29b58e;
}
.index_section_7 .flow {
	background-color: #ebeeea;
	padding: 2em 10%;
}
.index_section_7 .flow ol {
	list-style-type: none;
	counter-reset: number;/* カウンターを初期化 */
}
.index_section_7 .flow li {
	position: relative;
	font-size: 1.25em;
	padding: 0 0 0 2em;
	margin: 20px 0;
}
/*  afterでカウンターを作成 */
/* afterで○を作る */
.index_section_7 .flow li::after {
	content: counter(number);
	counter-increment: number;
	/* 配置を調整 */
	position: absolute;
	display: block;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	/* ○を作る */
	width: 1.5em;
	height: 1.5em;
	background-color: #29b58e;
	border-radius: 50%;
	color: #fff;
	text-align: center;
}

/*====================================================================================================
======================================================================================================*/



/*==========================================================================================
insurance
============================================================================================*/

main#contents .inner h2 {
	padding: 1rem 2rem;
	margin-bottom: .5em;
	color: #fff;
	background: #086788;
	-webkit-box-shadow: 3px 3px 0 #ccc;
	box-shadow: 3px 3px 0 #ccc;
	border-radius: 5px;
	font-size: 1.5em;
}
main#contents .inner p {
	margin: 1em 2em;
}
main#contents .inner h3 {
	padding: 1rem 2rem;
	margin-bottom: .5em;
	color: #493548;
	font-size: 1.25em;
	text-align: left;
}

.tbl_course_insurance {
	border-collapse: collapse;
	min-width: 50%;
	margin: 1em auto 3em;
}
.tbl_course_insurance tr {
	border-bottom: solid 1px #ccc;
}
.tbl_course_insurance th,
.tbl_course_insurance td {
	padding: 1em 1em;
}
.tbl_course_insurance th span {
	color: #fff;
	background-color: #3d3a71;
	padding: .5em 1em;
	border-radius: 50vh;
	display: block;
}

.tbl_course_schedule {
	border-collapse: collapse;
	min-width: 50%;
	margin: 1em auto 3em;
}
.tbl_course_schedule tr {
	border-bottom: solid 1px #ccc;
}
.tbl_course_schedule th,
.tbl_course_schedule td {
	padding: 1em 1em;
}
.tbl_course_schedule th span {
	color: #fff;
	background-color: #F79256;
	padding: .5em 1em;
	border-radius: 50vh;
	display: block;
}
main#contents .button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    margin:0 auto;
    padding: .9em 2em;
    border: none;
    border-radius: 5px;
    box-shadow: 0 2px 3px rgb(0 0 0 / 25%), 0 2px 3px -2px rgb(0 0 0 / 15%);
    background-color: #1aa96f;
    color: #fff;
    font-weight: 600;
    font-size: 1em;
	transition: .3s;
}
main#contents .button::after {
  border-bottom: 3px solid #fff;
  border-right: 3px solid #fff;
  content: "";
  height: .3rem;
  transform: rotate(-45deg);
  width: .3rem;
}
main#contents .button:hover {
    background-color: #11905c;
}


/*=============================================
contact
===============================================*/
.contact section { margin: 3em 0; }

/*=============================================
contact form7
===============================================*/

/* 必須マーク */
.must{
	color: #fff;
	margin-right: 10px;
	padding: 6px 10px;
	background: #F92931;
	border-radius: 20px;
}

/* 任意マーク */
.free {
	color: #fff;
	margin-right: 10px;
	padding: 6px 10px;
	background: #424242;
	border-radius: 20px;
}

/* 項目名を太字にする */
form p {
	margin-top: 1em; padding: 1em 1em 10px;
	border-top: dotted 1px #ccc;
	box-sizing: border-box;
}


/* 入力項目を見やすくする */
input.wpcf7-form-control.wpcf7-text,
textarea.wpcf7-form-control.wpcf7-textarea {
	width: 95%;
	padding: 8px 15px;
	margin-right: 10px;
	margin-top: 10px;
	border: 1px solid #d0d5d8;
	border-radius: 3px;
}
textarea.wpcf7-form-control.wpcf7-textarea {
	height: 200px;
}

/* 必須項目の入力欄を黄色にする */
input.wpcf7-form-control.wpcf7-text.wpcf7-validates-as-required {
	background: rgba(255, 255, 142, 0.46);
}

/* 送信ボタンを見やすくする */
input.wpcf7-submit {
	width: 50%; height: 50px; margin: 1em auto; display: block;
	background: rgba(0,167,217,1.0);
	color: #fff;
	font-size: 18px;
	font-weight: 600;
	border-radius: 25px;
	border: none;
	transition : all 1.0s;
}

input.wpcf7-submit:hover {
	 background: #2374ab;
         color: #ffffff;
	 cursor: pointer;
	 text-decoration: none;
}





/* エラーメッセージを見やすくする */
span.wpcf7-not-valid-tip,
.wpcf7-response-output.wpcf7-validation-errors {
	color: red;
	font-weight: 400;
	padding: 1em;
}
div.wpcf7-validation-errors, div.wpcf7-acceptance-missing {

    border: 2px solid #ffffcc;

}
