@charset "utf-8";
@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../font/ZenMaruGothic-Medium.woff2") format("woff2");
}

@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../font/ZenMaruGothic-Bold.woff2") format("woff2");
}

@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../font/ZenMaruGothic-Black.woff2") format("woff2");
}

@font-face {
  font-family: 'Quicksand';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../font/Quicksand-Medium.woff2") format("woff2");
}

@font-face {
  font-family: 'Quicksand';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../font/Quicksand-Bold.woff2") format("woff2");
}


/*------------------------
	initialization
------------------------*/
body {
	margin: 0;
	padding: 0;
	background-color: #FFFFFF;
}

h1,h2,h3,h4,h5 {
	margin: 0;
	padding: 0;
	font-weight:bold;
}

div {
	margin: 0;
	padding: 0;
}

p {
	margin: 0;
	padding: 0;
}

a {
	text-decoration:none;
	color: #000000;
}

table,th,td {
	margin: 0;
	padding: 0;
	font-size: inherit;
	font-size: 1em;
}

ul,ol,li,dl,dt,dd {
	margin: 0;
	padding: 0;
	list-style: none;
	list-style-position: outside;
	font-size: 12px;
}

img {
	margin: 0;
	padding: 0;
	border: none;
	line-height: 0;
}

form {
	margin: 0;
	padding: 0;
}

input,select,textarea {
	margin: 0;
	padding: 0;
}

textarea:focus,
input:focus {
  outline: none;
}

pre,address,citi {
	margin: 0;
	padding: 0;
}

object,embed {
	margin: 0;
	padding: 0;
}

html,body {
	background: #fff none;
    color: #313538;
	font-family: 'Zen Maru Gothic', serif;
	font-weight: 900;
    font-style: normal;
    letter-spacing: 0.5;
}

html{
	font-size: 62.5%;
	 scroll-padding-top: 100px;
}

.grecaptcha-badge{
	display: none !important;
}

#line{
	position: fixed;
	bottom: 125px;
	right: 25px;
	z-index: 999;
}

#zoom{
	position: fixed;
	bottom: 25px;
	right: 25px;
	z-index: 999;
}

/*** スマホ 320px ~ 767px***/
@media screen and (min-width: 768px) and (max-width: 1200px) {
	html {
	    font-size: 0.833vw;
	}
}

/*** スマホ 320px ~ 767px***/
@media screen and (max-width: 767px) {
	html {
	    font-size: 62.5%;
	}
}

body {
	-webkit-font-smoothing: antialiased;
}

* { box-sizing: border-box; }
a:hover img{
	opacity:0.8;
	filter: alpha(opacity=80);
}

a,
a:hover {
	transition: all .3s;
}

a:hover {opacity: .5;}


a[href^="tel:"] {
	pointer-events: none;
}

.sp_only {
	display: none;
}

img{
	max-width:100%;
	vertical-align: bottom;
	height: auto;
}

.cl-over {
	clear: both;
	overflow: hidden;
}

.fl-left {float: left;}
.fl-right {float: right;}

.di-fl {
	display: flex;
}

.ju-sb {justify-content: space-between;}
.ju-cn {justify-content: center;}
.ju-fe {justify-content: flex-end;}

.inner {
	box-sizing: border-box;
    max-width: 1100px;
	width: 90%;
    margin: 0 auto;
}

.inner_page {
	box-sizing: border-box;
    max-width: 1100px;
	width: 90%;
    margin: 0 auto;
}

.inner_page_01 {
	box-sizing: border-box;
    max-width: 1292px;
	width: 90%;
    margin: 0 auto;
}

.inner_page_02 {
	box-sizing: border-box;
    max-width: 1440px;
	width: 90%;
    margin: 0 auto;
}


.font-mi {font-family: 'Yu Mincho Light','YuMincho','Yu Mincho','游明朝体','ヒラギノ明朝 ProN','Hiragino Mincho ProN',sans-serif;}
.italic {font-style: italic;}
.font-w8 {
	font-family: "Hiragino Sans";
	font-weight: 800;
} 


.pop {font-family: 'Poppins', sans-serif;}
.lato {font-family: 'Lato', sans-serif;}
.rob {font-family: "Roboto Condensed";}
.nun {font-family: "Nunito", sans-serif;}
.qui{font-family: "Quicksand", sans-serif;}

.mb0 {margin-bottom: 0px !important;}
.mb10 {margin-bottom: 10px !important;}
.mb20 {margin-bottom: 20px !important;}
.mb30 {margin-bottom: 30px !important;}
.mb40 {margin-bottom: 40px !important;}
.mb50 {margin-bottom: 50px !important;}
.mb60 {margin-bottom: 60px !important;}
.mb70 {margin-bottom: 70px !important;}
.mb80 {margin-bottom: 80px !important;}
.mb90 {margin-bottom: 90px !important;}
.mb100 {margin-bottom: 100px !important;}

#sns{
	margin-top: 20px;
}

#sns a{
	display: inline-block;
	margin-right: 10px;
}

#sns a#x{
	color:#1DA1F2;
}

#sns a#instagram{
	
}

/*-----------------------------

sp-nav

------------------------------*/

#nav-toggle {
	position: fixed;
	top: 33px;
	right: 35px;
	height: 24px;
	cursor: pointer;
}
#nav-toggle > div {
	position: relative;
	width: 36px;
}
#nav-toggle span {
	width: 100%;
	height: 2px;
	left: 0;
	display: block;
	background: #EF90B0;
	position: absolute;
	transition: transform .6s ease-in-out, top .5s ease;
}
#nav-toggle span:nth-child(1) {
	top: 0;
}
#nav-toggle span:nth-child(2) {
	top: 12px;
}
#nav-toggle span:nth-child(3) {
	top: 24px;
}
.open #nav-toggle span {
	background: #fff;
}
.open #nav-toggle span:nth-child(1) {
	top: 15px;
	transform: rotate(45deg);
}
.open #nav-toggle span:nth-child(2) {
	top: 15px;
	width: 0;
	left: 50%;
}
.open #nav-toggle span:nth-child(3) {
	top: 15px;
	transform: rotate(-45deg);
}
#nav-toggle {
	z-index: 1000;
}
#container {
	z-index: 900;
}
#gloval-nav {
	background: #6CB3D5;
	color: #fff;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 2;
	text-align: center;
	/*display: flex;
	visibility: hidden;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	*/
	display: none;
	transition: opacity .6s ease, visibility .6s ease;
}


#gloval-nav ul.main {
	width: 80%;
	margin: 8rem auto 2rem;
}
#gloval-nav ul.main li a {
	font-size: 1.6rem;
	border-bottom: .5px solid #fff;
	display: block;
	color: #fff;
	text-decoration: none;
	padding: 1.5rem 0;
	transition: color .6s ease;
}

#gloval-nav ul.child {
	display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}

#gloval-nav ul.child li {
	text-align: center;
	font-size: 1.3rem;
	border-right: .5px solid #fff;
}

#gloval-nav ul.child li:last-child {
	border-right: none;
}

#gloval-nav a:hover {
	color: #666;
}
#gloval-nav ul {
	list-style: none;
}
/*
#gloval-nav ul li {
	opacity: 0;
	transform: translateX(200px);
	transition: transform .6s ease, opacity .2s ease;
}
*/
.open {
	overflow: hidden;
}
.open #gloval-nav {
	visibility: visible;
	opacity: 1;
	z-index: 10;
	overflow-y: scroll;
	height: 100vh;
	display: block;
}
.open #gloval-nav li {
	opacity: 1;
	transform: translateX(0);
	transition: transform 1s ease, opacity .9s ease;
}

.contact_nav h2 {
	font-size: 2rem;
	margin-bottom: 1rem;
}

.contact_nav .tel-link {
	font-size: 3rem;
	margin-bottom: 1rem;
}
.contact_nav .tel-link a {color: #FFE600;}

.contact_nav p {
	font-size: 1.4rem;
}


/*-----------------------------

header

------------------------------*/

header {
	width: 98%;
	max-width: 98%;
	margin: 0 auto;
	padding: 1rem 2rem;
	background: #fff;
	border-radius: 50px;
	position: fixed;
	top: 15px;
	left: 0;
	right: 0;
	z-index: 9990;
}

header .hd-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

header .hd-inner h1 {
	width: 18.4rem;
}

header .hd-inner .hd-info {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}

header .hd-inner nav {
	display: flex;
	justify-content: space-between;
}
header .hd-inner nav ul li {padding-right: 2.5rem;}
header .hd-inner nav ul li:last-child {padding-right: 0;}
header .hd-inner nav ul li a {
	font-weight: bold;
}

header .hd-inner .hd-info .hd-contact {
	padding: 1rem 2rem;
	background: #EF90B0;
	border-radius: 50px;
	margin-left: 3rem;
} 

header .hd-inner .hd-info .hd-contact dl {align-items: center;}
header .hd-inner .hd-info .hd-contact dl dt {
	color: #fff;
	font-size: 1.3rem;
	margin-right: 1rem;
}

header .hd-inner .hd-info .hd-contact a {
	color: #fff;
	font-weight: 500;
} 

header .hd-inner .hd-info .hd-contact .tel {padding-right: 3.5rem; position: relative;}
header .hd-inner .hd-info .hd-contact .tel::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 1.8em;
  margin-right: 2rem;
  position: absolute;
  top: 0.5%;
  right: -3%;
  background-color: #fff;
}

header .hd-inner .hd-info .hd-contact .tel dd {padding-top: .2rem;}


@media screen and (min-width: 768px) {
	header .hd-inner .hd-info .hd-contact a,
	header .hd-inner nav ul li a{
		font-size: 1.2rem;
	}
}

@media screen and (min-width: 1024px) {
	header .hd-inner .hd-info .hd-contact a {
		font-size: 1.6rem;
		color: #fff;
	}
	
	header .hd-inner nav ul li a {
		font-size: 1.6rem;
		color: #333;
	}
}

@media screen and (max-width: 1350px) {
	header .hd-inner .hd-info .hd-contact a,
	header .hd-inner nav ul li a{
		font-size: 1.45rem;
	}
	header .hd-inner nav ul li {padding-right: 1.75rem;}
}

/*-----------------------------

page-ttl

------------------------------*/
#page-ttl {
	background: url("../img/common/page-ttl.jpg") no-repeat center;
	background-size: cover;
	width: 100%;
	padding: 0 24rem 20rem;
}

body#news #page-ttl,
body.category #page-ttl {
	padding: 0 24rem 5.5rem;
}

#page-ttl .page-inner {}
#page-ttl .page-inner h2 {
	font-size: 4.8rem;
	font-weight: bold;
	padding-top: 24.5rem;
}

/*-----------------------------

pan

------------------------------*/

#pan {
	padding: 1rem 24rem;
}

#pan ul li,
#pan ul li a{
	font-size: 1.3rem;
	font-weight: bold;
} 

#pan ul li a {
	color: #747474;
	font-weight: normal;
}

#pan ul li span {
	color: #747474;
	margin: 0 .5rem;
}

.bg-blue {background: #F3F8FB;}


/*-----------------------------

main-contents

------------------------------*/
.page-top {
	padding: 0 0 10em;
	margin-bottom: 5rem;
	text-align: center;
}

.page-top h2 {
	font-size: 3.2rem;
	color: #EF90B0;
	padding-top: 10rem;
	margin-bottom: 2rem;
}

.page-top p {
	font-size: 1.8rem;
	color: #313538;
	font-weight: bold;
	line-height: 2.4;
}


h2.ttl {
	font-size: 3.2rem;
	font-weight: bold;
	margin-bottom: 5rem;
	text-align: center;
}


.line_ttl {
	background: linear-gradient(transparent 60%, #FFF6A4 0%);
	padding: 0 .5rem;
}


/*-----------------------------

top

------------------------------*/

#main-fv {
	background: url("../img/page/top/main-bg.jpg") no-repeat;
	background-size: cover;
	padding: 20rem 0 6.5rem;
	position: relative;
}
#main-fv .inner {align-items: center;}
#main-fv .main-ttl {
	font-size: 6rem;
	font-weight: bold;
	line-height: 1.8;
}
#main-fv .main-ttl{
	width: 57%;
	max-width: 57%;
	padding-right: 1rem;
}

#main-fv .main-img{
	width: 42%;
	max-width: 42%;
}

#main-fv #bird1{
	position: absolute;
	top: 25%;
	left: 30%;
	margin: 0 auto;
	width: 162px;
}

#main-fv #bird2{
	position: absolute;
	bottom: 0px;
	right: 3%;
	margin: 0 auto;
	width: 150px;
}


#bird1 {
	animation: floating-y1 1.4s ease-in-out infinite alternate-reverse;
}
@keyframes floating-y1 {
	0% {
		transform: translateY(-4%);
	}
	100% {
		transform: translateY(4%);
	}
}

#bird2 {
	animation: floating-y2 1.8s ease-in-out infinite alternate-reverse;
}
@keyframes floating-y2 {
	0% {
		transform: translateY(-8%);
	}
	100% {
		transform: translateY(8%);
	}
}

.top-strengths {
	background: #FEFCEA;
	padding: 0 0 10rem;
	position: relative;
}

.top-strengths::before {
    position: absolute;
    bottom: -215px;
    left: 0;
    content: "";
    background: url("../img/page/top/strengths-bg.png") no-repeat top;
    background-size: cover;
    width: 100%;
    height: 220px;
    display: inline-block;
}

.top-strengths h2 {
	font-size: 4rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 4rem;
	text-align: center;
}

.top-strengths ul {margin-bottom: 5rem;}
.top-strengths ul li {
	width: 340px;
	max-width: 32%;
	min-height: 422px;
	background: url("../img/page/top/strengths-bg01.png") no-repeat top;
	background-size: 100% auto;
	padding: 5rem 2rem;
	position: relative;
}

.top-strengths ul li .icon {
	 position: absolute;
	 top: 0;
	 left: 0;
	 right: 0;
	 margin: 0 auto;
	 border-radius: 50%;
	 text-align: center;
	 padding-top: 2rem;
}

.top-strengths ul li h3 {
	font-size: 2.2rem;
	padding-top: 8rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 2rem;
}

.top-strengths ul li p {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.8;
}

.btn_top {
	width: 300px;
	margin: 0 auto;
	position: relative;
}

.btn_top span {
	position: absolute;
	top: 0;
	right: 4rem;
}

.btn_top a {
	display: block;
	height: 66px;
	line-height: 66px;
	border: 1.5px solid #CECECE;
	border-radius: 40px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: bold;
	background: #fff;
}

.btn_top a:hover{
	border: 1.5px solid #999;
}

.top-qualification {
	padding: 0 0 10rem;
	background: #FEFCEA;
}

.top-qualification h2 {
	font-size: 4rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 4rem;
	text-align: center;
}

.top-qualification ul {
	border: 10px solid #F3F8FB;
	background: #fff;
	padding: 3rem;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
	/*
	display: flex;
	flex-wrap: wrap;
	*/
    gap: 2rem 1rem;
    margin-bottom: 0.5rem;
}

.top-qualification ul li {
	font-size: 1.5rem;
	font-weight: 500;
	text-indent: -1.5rem;
	padding-left: 1.5rem;
}

.top-qualification p {
	font-size: 1.4rem;
	text-align: right;
	font-weight: 500;
}

.top-video {}
.top-video h2 {
	font-size: 3.6rem;
	font-weight: bold;
	text-align: center;
	padding-top: 18rem !important;
	margin-bottom: 3rem;
}

.top-about {
	padding: 0 0 7rem;
    background: url(../img/page/curriculum/bg01.png), 
		url(../img/page/curriculum/bg-left01.png), 
		url(../img/page/curriculum/bg-right01.png),
		url(../img/page/rework/bg-line.png);
    background-repeat: no-repeat,no-repeat,no-repeat,repeat;
    background-position: top 70px left 73%, center left 3%, top 80% right 3%,center;
    background-size: 49px,66px 73px, 50px 49px,30px;
}

.top-about h2 {
	font-size: 4rem;
	font-weight: bold;
	text-align: center;
	padding-top: 10rem;
	margin-bottom: 3rem;
}

.top-about p.top-about-txt {
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.8;
	text-align: center;
	margin-bottom: 3rem;
}

.top-about ul li {
	background: #fff;
	border: 2px solid #C6C6C6;
	border-radius: 30px;
	padding: 2.5rem;
}

.top-about ul li + li {margin-top: 4rem;}

.top-about .about-info {
	width: 520px;
	max-width: 52%;
	order: 2;
	position: relative;
}

.top-about .about-info .btn_top {
	position: absolute;
	bottom: 0;
	right: 0;
}

.top-about .about-info .btn_top a {border: 1px solid #000;}

.top-about .about-img {
	width: 466px;
	max-width: 47%;
	order: 1;
}

.about-inner .about-info h3 {
	font-size: 3.2rem;
	font-weight: bold;
	border-left: 7px solid #EF90B0;
	padding-left: 1rem;
	margin-bottom: 2rem;
	margin-top: 5px;
}

.about-inner .about-info p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8;
	margin-bottom: 2rem;
}

.top-other {
	padding: 0 0 7rem;
	background: #FEFCEA;
	margin-bottom: 0;
}

.top-other h2 {
	font-size: 4rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 2rem;
	text-align: center;
}

.top-other p {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.8;
	margin-bottom: 4rem;
	text-align: center;
}


.top-other .other-list {
}

.top-other .other-list ul {
	display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
}

.top-other .other-list ul li{
	border: 3px dashed #FFF6A4;
	background-color: #fff;
	position: relative;
}

.top-other .other-list ul li i{
	font-size: 14px;
	position: absolute;
	top: 40%;
	right: 15px;
}

.top-other .other-list ul li a{
	display: block;
	padding: 15px 0px;
}

.top-other .other-list ul li .icon {
	margin-bottom: 1rem;
	text-align: center;
}

.top-other .other-list ul li .icon img{
	width: auto;
	display: block;
	height: 100px;
	margin: 0 auto;
}

.top-other .other-list ul li h3 {
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
}

.top-news {
	padding: 0 0 7rem;
	background: #F3F8FB;
}

.top-news h2,
.top-column h2{
	font-size: 4rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 4rem;
	text-align: center;
}

.top-news .news-article {margin-bottom: 5rem;}
.top-news .news-article li dl {align-items: flex-start;}
.top-news .news-article li a {
	font-size: 1.6rem !important;
}

.top-news .news-article li dl dd {padding-left: 4rem;}

.top-column {
	padding: 0 0 15rem;
} 

.top-column ul {
	display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4rem 2rem;
	margin-bottom: 5rem;
}

.top-column ul li .column-thumbnail {
	width: 100%;
	height: 17.3rem;
	margin-bottom: 1.5rem;
}


.top-column ul li .column-thumbnail img {
	border-radius: 30px;
	height: 100%;
	object-fit: cover;
}

.top-column ul li dl {margin-bottom: 1rem; align-items: center;}
.top-column ul li dl dt {
	font-size: 1.4rem;
	font-weight: bold;
	margin-right: 1rem;
}
.top-column ul li dl dd {
	font-size: 1.4rem;
	font-weight: bold;
	color: #fff;
	background: #9EC9DD;
	border-radius: 30px;
	padding: 0.2rem 0.8rem;
}

.top-column ul li h3 {
	font-size: 1.6rem;
	font-weight: bold;
}

.readmore {
    position: relative;
    margin: 15px auto 30px;
    display: block;
    color: #000;
    border: none;
    outline: 0;
    font-size: 1.6rem;
    font-weight: 500;
    cursor: pointer;
    background: none;
    letter-spacing: 0.1em;
}
.readmore:before {
  content: "";
  width: 50px;
  height: 50px;
  text-align: center;
  border-radius: 50%;
  display: block;
  margin: 0 auto .5em;
  background: url(../img/page/top/arrow.png) no-repeat center / 20px #fff;
  transition: .3s;
}
.readmore.on-click:before {
  transform: rotate(180deg);
}
.readmore .open {
  display: block;
}
.readmore.on-click .open {
  display: none;
}
.readmore .close {
  display: none;
}
.readmore.on-click .close {
  display: block;
}

.content{
	margin: 0 auto;
	padding: 40px;
}
.modal{
	display: none;
	height: 100vh;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 9995;
}
.modal__bg{
	background: rgba(240,248,226,0.8);
	height: 100vh;
	position: absolute;
	width: 100%;
}
.modal__content{
	background: #fff;
	left: 50%;
	padding: 40px;
	position: absolute;
	top: 50%;
	transform: translate(-50%,-50%);
	width: 60%;
	border-radius: 20px;
}

.modal__content p{
	font-size: 1.7rem;
	line-height: 2em;
	margin-bottom: 30px;
	font-weight: 500;
}

.modal__content a.js-modal-close{
	display: block;
	width: 75px;
	border-bottom: 2px double #000;
	margin: 50px auto 0px;
	font-size: 1.5rem;
	text-align: center;
	padding-bottom: 10px;
}


/*-----------------------------

curriculum

------------------------------*/

.curriculum-bg {
	background: url("../img/page/curriculum/bg-left.png"),
		url("../img/page/curriculum/bg-right.png");
	background-repeat: no-repeat;
	background-position: bottom left 7%, top 50px right;
	background-size: 304px 458px,335px 475px;
}

#curriculum-programs{
	margin: 10rem auto 0px;
}

#curriculum-programs th{
	text-align: left;
	font-size: 1.6rem;
	padding-bottom: 1rem;
	font-weight: bold;
	display: block;
}

#curriculum-programs td{
	text-align: left;
	font-weight: 500;
	font-size: 1.6rem;
	display: block;
	margin-bottom: 2rem;
	background-color: #fff;
	padding: 15px;
}

#sim-btn{
	width: 300px;
	line-height: 66px;
	display: block;
	margin: 3rem auto 0;
	background-color: #EFEAE5;
	text-align: center;
	height: 66px;
	font-size: 1.6rem;
	color:#000;
	border-radius: 33px;
}

@media screen and (min-width: 768px) {
	.curriculum-bg {
		background-size: 20% auto,20% auto;
	}
}


@media screen and (min-width: 1024px) {
	.curriculum-bg {
		background-size: 304px 458px,335px 475px;
	}
}

.curriculum-area {
	background: #E5F1D7;
	padding: 8rem 0;
	position: relative;
}

.curriculum-area::before {
    position: absolute;
    bottom: -215px;
    left: 0;
    content: "";
    background: url(../img/page/curriculum/curriculum-bg01.png) no-repeat top;
    background-size: cover;
    width: 100%;
    height: 220px;
    display: inline-block;
}

.curriculum-area ul li {
	background: #fff;
	border: 2px solid #C6C6C6;
	border-radius: 30px;
	padding: 5rem 3rem;
}

.curriculum-area ul li + li {margin-top: 4rem;}

.curriculum-inner {}
.curriculum-inner .curriculum-info {
	width: 520px;
	max-width: 52%;
}
.curriculum-inner .curriculum-img {
	width: 466px;
	max-width: 47%;
}

.curriculum-area ul li:nth-child(odd) .curriculum-inner{
	flex-direction: row-reverse;
}

.curriculum-inner .curriculum-info h2 {
	font-size: 3.2rem;
	font-weight: bold;
	border-left: 7px solid #EF90B0;
	padding-left: 1rem;
	margin-bottom: 2rem;
}

.curriculum-inner .curriculum-info h3 {
	font-size: 2.2rem;
	font-weight: bold;
	color: #EF90B0;
	margin-bottom: 1rem;
}

.curriculum-inner .curriculum-info p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 2;
	margin-bottom: 2rem;
}

.curriculum-inner .curriculum-info p.top_txt {margin-bottom: 4rem;}
.curriculum-features {padding-top: 25rem !important;}

.curriculum-programs02 {
    background-position: top 20% left 3%, top 70% right 3% !important;
	margin-bottom: 0 !important;
}


.curriculum-schedule {
	padding: 0 0 7rem;
	background: url("../img/page/curriculum/bg01.png"),
		url("../img/page/rework/bg-line.png");
	background-repeat: no-repeat, repeat;
	background-position: top 70px left 63%, center;
    background-size: 49px, 30px;
}

.curriculum-schedule h2 {
	font-size: 3.2rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 4rem;
	text-align: center;
}

table.schedule-table {
	width: 100%;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
	table-layout: fixed;
}

table.schedule-table , 
table.schedule-table td, 
table.schedule-table th {
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid #EFEAE5;
}

th.left:first-child,
th.right:first-child{
	border-top-left-radius: 10px; /* 左上の角を丸くする */
}

th.left:last-child,
th.right:last-child{
	border-top-right-radius: 10px; /* 右上の角を丸くする */
}

table.schedule-table td, 
table.schedule-table th {
	padding: 1.5rem 1rem;
}

table.schedule-table th {
	font-size: 2rem;
	font-weight: bold;
	color: #fff;
	text-align: center;
	background: #75AD10;
}

table.schedule-table td {
	font-size: 1.5rem;
	font-weight: bold;
	text-align: center;
	background: #fff;
}

table.schedule-table td.time {
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
}

.yellow-bg {background: #FAF7DD !important;}
.bg-none {background: none !important;}



/*-----------------------------

company

------------------------------*/
.content {display: none;}
.content.show {display: block;}

.tab-container {
	background: #F3F8FB;
	border-radius: 50px;
	height: 50px;
	line-height: 50px;
	text-align: center;
	display: flex;
	justify-content: space-between;
	margin: 5rem auto 8rem;
	font-size: 1.6rem;
	font-weight: bold;
	cursor: pointer;
} 

.tab-container .tab {
	width: 20%;
	max-width: 20%;
}

.tab-container .tab.active {
	background: #6CB3D5;
	color: #fff;
	border-radius: 50px;
}

.content-container {
	margin-bottom: 10rem;
}

.company01 .inner {
	width: 760px;
	max-width: 90%;
}

.company02 .inner {
	width: 920px;
	max-width: 90%;
}

.inner-company {margin-bottom: 15rem !important;}

.company01 .inner h2,
.company02 .inner h2,
.thoughts-area h2{
	font-size: 4rem;
	font-weight: bold;
	margin-bottom: 3rem;
	text-align: center;
}

.company01 .inner h3.company_ttl,
.thoughts-area h3{
	font-size: 3.2rem;
	font-weight: bold;
	margin-bottom: 4rem;
	line-height: 1.8;
	text-align: center;
	color: #EF90B0;
}


dl.company01-info {
	border-bottom: 1px dashed #CECECE;
}
dl.company01-info dt,
dl.company01-info dd{
	font-size: 1.6rem;
	font-weight: 500;
	padding: 3rem 0;
	line-height: 1.8;
}

dl.company01-info dt {
	width: 150px;
	max-width: 20%;
}

dl.company01-info dd {
	width: 610px;
	max-width: 80%;
}

.company01-map {margin-top: 4rem;}
.company01-map .map-area {margin-bottom: 2rem;}
.company01-map iframe {
	width: 100%;
	height: 280px;
}

.company01-map h3 {
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 1rem;
	
}

.company01-map p {
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 2;
}

ul.company02_list {margin-bottom: 6rem;}
ul.company02_list li {
	font-size: 2rem;
	font-weight: bold;
}

ul.company02_list li span {
	color: #EF90B0;
	padding-right: 2rem;
}

ul.company02_list li + li {margin-top: 3rem;}

.company-greeting {
	padding: 8rem 0;
	background: #F3F8FB;
}

.wpcf7 form .wpcf7-response-output{
	text-align: center;
	font-size: 16px;
}

.inner-greeting {
	width: 1100px;
	max-width: 90%;
	margin: 0 auto;
	padding: 5rem 17rem;
	background: #fff;
	border-radius: 30px;
}

.inner-greeting .greeting-img {
	text-align: center;
	margin-bottom: 0.5rem;
}

.inner-greeting .greeting-img img {border-radius: 30px;} 

.inner-greeting p.greeting-name {
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 4rem;
}

.inner-greeting h3 {
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 4rem;
	line-height: 1.8;
	text-align: center;
	color: #EF90B0;
}

.inner-greeting p.greeting-txt {
	font-size: 1.6rem;
	line-height: 2;
	font-weight: 500;
}

.inner-greeting p.greeting-txt + p.greeting-txt {
	margin-top: 3rem;
}

.logo-area {}
.logo-area .logo-img {
	width: 255px;
	max-width: 25%;
}

.logo-area .logo-info {
	width: 695px;
	max-width: 75%;
	padding-left: 6rem;
}

.logo-area .logo-info p {
	font-size: 1.8rem;
	line-height: 2;
}

.logo-area .logo-info p + p {
	margin-top: 4rem;
}


.thoughts-area{
	padding: 5rem 0 20rem;
	background: url("../img/page/company/thoughts-left.png"),
		url("../img/page/company/thoughts-right.png"),
		url("../img/page/company/thoughts-bg.jpg");
	background-repeat: no-repeat;
	background-position: center left 5%, top 100px right 5%, center;
	background-size: 384px 300px,316px 771px, cover;
	text-align: center;
} 


@media screen and (min-width: 768px) {
	.thoughts-area {
		background-size: 20% auto,20% auto,cover;
	}
}


@media screen and (min-width: 1024px) {
	.thoughts-area {
		background-size: 384px 300px,316px 771px, cover;
	}
}


.thoughts-area h3 {padding-top: 5rem;}
.thoughts-area p {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2.4;
}

.thoughts-area p + p {margin-top: 4rem;} 




/*-----------------------------

about

------------------------------*/
.about-bg {
	background: url("../img/page/about/bg-left.png"),
		url("../img/page/about/bg-right.png");
	background-repeat: no-repeat;
	background-position: bottom left, top right;
	background-size: 360px 436px,340px 487px;
}

.top-step {
	padding-top: 10rem;
	text-align: center;
	margin-bottom: 8rem;
}


@media screen and (min-width: 768px) {
	.about-bg {
		background-size: 24% auto,24% auto;
	}
}


@media screen and (min-width: 1024px) {
	.about-bg {
		background-size: 360px 436px,340px 487px;
	}
}

.reason-area {
	background: #FEFBE9;
	padding: 0 0 5rem;
}

.reason-area h2 {padding-top: 10rem;}

ol.reason-list {
	background: #fff;
	padding: 6rem 5rem;
	border-radius: 30px;
}

ol.reason-list li .reason-inner {
	align-items: center;
}
ol.reason-list li + li {margin-top: 3rem;}
ol.reason-list li:nth-child(odd) .reason-inner{
	flex-direction: row-reverse;
}

ol.reason-list li:nth-child(odd) .reason-inner .reason-info {
	padding-left: 2rem;
}

ol.reason-list li .reason-inner .reason-img {
	width: 313px;
	max-width: 32%;
}

ol.reason-list li .reason-inner .reason-img img {
	border: 2px solid #B7B7B7;
	border-radius: 30px;
}

ol.reason-list li .reason-inner .reason-info {
	width: 665px;
	max-width: 67%;
}

ol.reason-list li dl {
	align-items: center;
	margin-bottom: 1rem;
}

ol.reason-list li dl dt {
	font-size: 4rem;
	color: #EF90B0;
	font-weight: bold;
	margin-right: 1rem;
}

ol.reason-list li dl dd h3 {
	font-size: 2.4rem;
	line-height: 2em;
}

ol.reason-list li p {
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 2;
	padding-top: 5px;
}

.video-area {
	background: url("../img/page/top/video-bg.jpg") no-repeat;
	background-size: cover;
	padding: 9.5rem 0;
}

.video-area .video {
	width: 920px;
	max-width: 90%;
	margin: 0 auto;
	background: #BABABA;
}

.access-area {
	background: #fff;
	padding: 0 0 10rem;
}

.access-area h2.ttl {padding-top: 10rem;}

.access-info {margin-bottom: 4rem;}
.access-info .access-company{
	max-width: 60%;
	width: 60%;
}
.access-info .access-address {
	max-width: 30%;
	width: 30%;
}

.access-info .access-address .logo {
	margin-bottom: 5rem;
}

.access-info .access-address h2 {
	font-size: 2.8rem;
	font-weight: bold;
	margin-bottom: .5rem;
}

.access-info .access-address p {
	font-size: 1.6rem;
	font-weight: bold;
}


.access-info .access-company {}
.access-info .access-company dl {
	padding: 1.5rem 0;
	border-top: 1px solid #E6E6E6;
}

.access-info .access-company dl.last {
	border-bottom: 1px solid #E6E6E6;
}

.access-info .access-company dl dt {
	width: 25%;
	max-width: 25%;
}

.access-info .access-company dl dd {
	width: 75%;
	max-width: 75%;
}

.access-info .access-company dl dt,
.access-info .access-company dl dd {
	font-size: 1.6rem;
	font-weight: 500;
}

.access-map {
	max-width: 1100px;
	width: 90%;
	margin: 0 auto;
}
.access-map .map {
	width: 32%;
	max-width: 32%;
}

.access-map .map h3 {
	font-size: 1.8rem;
	margin-bottom: 1rem;
}

.access-map .map p {
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 2;
}

.access-map .map-area {margin-bottom: 2rem;}
.access-map iframe {
	width: 100%;
	height: 280px;
}

/*-----------------------------

contact

------------------------------*/

body#contact,
body#confirm,
body#thanks {
	background: #FEFCEA;
}

.contact-inner {
	padding: 10rem;
	background: #fff;
	margin: 10rem 0;
	border-radius: 30px;
}

.contact-inner h2 {
	font-size: 3.2rem;
	font-weight: bold;
	margin-bottom: 3rem;
	text-align: center;
}

.contact-inner .tel-link {
	font-size: 5.6rem;
	font-weight: bold;
	text-align: center;
}

.contact-inner .tel-link a {color: #EF90B0;}

.contact-inner p.tel-time {
	font-size: 1.4rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 12.5rem;
}

h3.notes-ttl {
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	color: #EF90B0;
	margin-bottom: 2rem;
}

ul.notes-list {
	padding: 0 10rem;
}

ul.notes-list li {
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: bold;
	padding-left: 1em;
	text-indent: -1em;
}

.contact-form table {
	width: 100%;
}

.contact-form table th,
.contact-form table td{
	font-size: 1.6rem;
	font-weight: 500;
	text-align: left;
	padding: 3rem 0;
	background-image : linear-gradient(to right, #8E8E8E 4px, transparent 4px);
	background-size: 8px 2px;
	background-repeat: repeat-x; 
	background-position: left bottom;
}

.contact-form table th {
	width: 30%;
	max-width: 30%;
	position: relative;
}

.contact-form table th span {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 0;
	font-size: 1.4rem;
	background: #EF90B0;
	color: #fff;
	padding: .5rem 1rem;
	border-radius: 20px;
	
}

.contact-form table td {
	width: 70%;
	max-width: 70%;
	padding-left: 5rem;
}


.wpcf7-text,
.wpcf7-textarea {
	width: 100%;
	padding: 1.5rem 2rem;
	background: #fff;
	border: 1px solid #8E8E8E;
	border-radius: 10px;
}

.wpcf7-select {
	width: 50%;
	padding: 1.5rem 2rem;
	background: #fff;
	border: 1px solid #8E8E8E;
	border-radius: 10px;
}

.submit_btn {
	padding-top: 5rem;
	text-align: center;
}


.wpcf7-submit {
	width: 300px;
	height: 66px;
	line-height: 66px;
	background-color: #EF90B0;
	font-size: 1.6rem;
	font-weight: bold;
	color: #fff;
	border: none;
	border-radius: 40px;
	cursor: pointer;
}

.wpcf7-previous {
	width: 300px;
	height: 66px;
	line-height: 66px;
	background-color: #707070;
	font-size: 1.6rem;
	font-weight: bold;
	color: #fff;
	border: none;
	border-radius: 40px;
	cursor: pointer;
	margin-right: 3rem;
}

.wpcf7-submit:hover {
  background-color: #C3426D; 
}


.wpcf7-previous:hover {
  background-color: #333; 
}

.form-wrap__title {
	font-size: 1.8rem;
	text-align: center;
	margin-bottom: 2rem;
}

.form-wrap__text {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 2;
	text-align: center;
	margin-bottom: 4rem;
}


/*-----------------------------

news

------------------------------*/

body#news,
body.category {
	background: #F3F8FB;
}

.news-inner {
	padding: 10rem 0 15rem;
}

ul.news-cat {
	justify-content: center;
	margin-bottom: 7rem;
}

ul.news-cat li {
	width: 172px;
	height: 66px;
	text-align: center;
	margin: 0 1.5rem;
}

ul.news-cat li a {
	font-size: 1.6rem;
	font-weight: bold;
	background: #fff;
	display: block;
	line-height: 66px;
	border: 1px solid #CECECE;
	border-radius: 40px;
}


ul.news-cat li a.is_active {
	background: #6CB3D5;
	border: 1px solid #6CB3D5;
	color: #fff;
}


.news-article {
	background: #FFFFFF;
	border-radius: 30px;
	padding: 5rem 12.5rem;	
}
.news-article ul {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2.5rem 2rem;
}
.news-article ul li {}
.news-article ul li a {
	display: block;
	padding: 3rem 0;
	/*border-bottom: 1px dashed #8E8E8E;*/
}
.news-thumbnail {margin-bottom: 3rem;}
.news-thumbnail img {
	width: 100%;
	height: 140px;
	object-fit: cover;
	border-radius: 20px;
}

.news-article ul li dl {
	align-items: center;
}

.news-article ul li dl dt {
	width: 50%;
	max-width: 50%;
	font-size: 1.6rem;
	font-weight: bold;
	color: #1E98CC;
	padding-right: 2rem;
}

.news-article ul li dl dd .news-info {
	width: 50%;
	max-width: 50%;
	align-items: center;
}


.news-article ul li dl dd .news-info .news-cat {
	width: 125px;
	background: #1E98CC;
	color: #fff;
	padding: .5rem 1rem;
	border-radius: 30px;
	margin-right: 1rem;
	text-align: center;
}


.news-article ul li dl dd .news-info h3 {
	width: 800px;
	font-size: 1.6rem;
	font-weight: bold;
}

/*---top news---*/
.top-news-article ul {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 0;
}

.top-news-article ul li a {
	border-bottom: 1px dashed #8E8E8E;
}


/*-----------------------------

rework

------------------------------*/

.trouble-area {
	/*
	background: url("../img/page/top/trouble-bg.jpg") no-repeat top;
	background-size: cover;
	*/
	background: #F3F8FB;
	padding: 0 0 18rem;
	text-align: center;
	position: relative;
}

.trouble-area::before {
	position: absolute;
	bottom:0;
	left: 0;
	content: "";
	background: url("../img/page/top/trouble-bg-bottom.jpg") no-repeat top;
	background-size: cover;
	width: 100%;
	height: 100px;
	display: inline-block;
}


.trouble-area h2 {
	font-size: 3.2rem;
	line-height: 2;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 4rem;
}


.trouble-area h2 span {
	border-bottom: 2px dashed #1E98CC;
	padding-bottom: .5rem;
}

.trouble-area .trouble-img {
	
}


.trouble-area01 {
	padding: 0 0 10rem;
	background: url("../img/page/top/trouble-left.png"),
		url("../img/page/top/trouble-right.png");
	background-repeat: no-repeat;
	background-position: center left 50px, center right 50px;
	background-size: 304px 197px,345px 150px;
	text-align: center;
}

.trouble-area01 h2 {
	font-size: 3.6rem;
	padding-top: 5rem;
	margin-bottom: 2rem;
}

.trouble-area01 p {
	font-size: 2.4rem;
	font-weight: 500;
	margin-bottom: 2rem;
}

.features-area {
	padding: 0 0 10rem;
	background: url("../img/page/curriculum/dot-bg.png") repeat;
	background-size: 28px;
	text-align: center;
}


.features-area h2 {
	font-size: 3.2rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 4rem;
}

ul.features-list li {
	width: 340px;
	max-width: 34%;
}

ul.features-list li img {margin-bottom: 2rem;}

ul.features-list li h3 {
	font-size: 2.2rem;
	font-weight: bold;
	color: #EF90B0;
	margin-bottom: 1rem;
}

ul.features-list li p {
	font-size: 1.6rem;
	font-weight: 500;
	text-align: left;
	line-height: 2;
	padding: 0 3rem;
}

.comment-area {
	background: #F3F8FB;
	padding: 5rem 0;
	margin-bottom: 5rem;
}

.comment-area .inner_page {
	background: #fff;
	border-radius: 30px;
	padding: 5rem;
}

.comment-area h2 {
	font-size: 2.6rem;
	font-weight: bold;
	margin-bottom: 3rem;
	text-align: center;
}

.comment-area .comment-info {
	width: 550px;
	max-width: 55%;
	padding-right: 5rem;
}
.comment-area .comment-info p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8;
	margin-bottom: 1rem;
}

.comment-area .comment-img {
	width: 400px;
	max-width: 45%;
}
.comment-area .comment-img img {
	border-radius: 30px;
}

.comment-area .comment-name {
	font-size: 1.6rem;
	font-weight: 500;
	text-align: right;
}

.contact-area {
	padding: 0 0 10rem;
	background: #FEFCEA;
	text-align: center;
}

.contact-area h2 {
	font-size: 3.6rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 1rem;
}

.contact-area .contact-txt {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2;
	margin-bottom: 4rem;
} 


.contact-area ul.contact-list {}
.contact-area ul.contact-list li {
	width: 530px;
	max-width: 48%;
	background: #fff;
	border-radius: 30px;
	padding: 3rem;
}

.contact-area ul.contact-list li .icon {
	font-size: 3rem;
	color: #EF90B0;
}

.contact-area ul.contact-list li h3 {
	font-size: 1.8rem;
	font-weight: bold;
	padding-top: 1rem;
	mgin-bottom: 1rem;
}

.contact-area ul.contact-list li .tel {padding-top: .5rem;}
.contact-area ul.contact-list li .tel a {
	font-size: 5.2rem;
	font-weight: bold;
	color: #EF90B0;
}

.contact-area ul.contact-list li .mail{
	width: 300px;
	max-width: 100%;
	margin: 0 auto;
}
.contact-area ul.contact-list li .mail {padding-top: 1rem;}
.contact-area ul.contact-list li .mail a{
	display: block;
	background: #EF90B0;
	height: 66px;
	line-height: 66px;
	font-size: 1.6rem;
	font-weight: bold;
	color: #fff;
	border-radius: 40px;
}


.facility-area {
	margin-bottom: 10rem;
	text-align: center;
}

.facility-area h2 {
	padding-top: 10rem;
	font-size: 4rem;
	margin-bottom: 4rem;
}

.slide-items {
  width: 100%;
  display: flex;
  max-width: 96%;
  margin: auto;
}

.slide-items li {
  height: auto;
  margin-right: 10px;
  margin-left: 10px;
}

.slide-items img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 30px;
	border: 10px solid #F8F8ED;
}

.slick-prev:before,
.slick-next:before {
  color: black;
}

.slick-dots {
  left: 50%;
  transform: translateX(-50%);
}

.service-area {
	padding: 7rem 0;
	background: #F0F8E2;
	/*margin-bottom: 7rem;*/
	text-align: center;
}

.service-area .inner_page_01 {
	padding: 0 10rem 7rem;
	background: #fff;
	border-radius: 30px;
}

.service-area h2 {
	font-size: 4rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 2rem;
}

.service-area p.service-txt {
	font-size: 1.8rem;
	line-height: 1.8;
	font-weight: 500;
	margin-bottom: 5rem;
}

ul.service-list li + li {margin-top: 5rem;}

ul.service-list li:nth-child(even) .service-inner{
	flex-direction: row-reverse;
}


ul.service-list .service-inner {align-items: center;}

ul.service-list .service-info {
	width: 600px;
	max-width: 60%;
}

ul.service-list .service-info dl {align-items: center; margin-bottom: 2rem;}

ul.service-list .service-info dl dt {
	font-size: 5.6rem;
	font-weight: 100;
	color:#EF90B0;
	margin-right: 2rem;
	border-bottom: 4px solid #EF90B0;
}

ul.service-list .service-info dl dd h3 {
	font-size: 3.2rem;
	font-weight: bold;
}

ul.service-list .service-info p {
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 2;
	text-align: left;
}


ul.service-list .service-img {
	width: 500px;
	max-width: 36%;
}

.flow-area {
	padding: 0 0 0;
	background: #F3F8FB;
	text-align: center;
}

.flow-area h2 {
	font-size: 4rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 2rem;
}

.flow-area p {
	font-size: 1.8rem;
	line-height: 1.8;
	font-weight: 500;
	margin-bottom: 2rem;
}

.flow-area .flow-step {
	background: #fff;
	border-radius: 30px;
	padding: 5rem 0;
}

.flow-area .flow-step-img {
	width: 74%;
	max-width: 74%;
	margin: 0 auto;
}

.faq-area {
	padding: 0 0 7rem;
	background: #F3F8FB;
	text-align: center;
}

.faq-area h2 {
	font-size: 4rem;
	font-weight: bold;
	padding-top: 10rem;
	margin-bottom: 4rem;
}

.faq-area .faq-main {
	background: #fff;
	border-radius: 30px;
	padding: 5rem 9rem;
}


.accordion-faq {
	border-radius: 20px;
	border: 1px solid #91BDD0;
	padding: 2.5rem 3rem;
}

.accordion-faq + .accordion-faq {margin-top: 2rem;}

.accordion-content {
  display: none;
}

.accordion-header {
	text-align: left;
	cursor: pointer;
	position: relative;
}

.accordion-header dl {align-items: center;}
.accordion-header dl dt {
	font-size: 2rem;
	font-weight: bold;
	color: #1E98CC;
	padding-right: 2rem;
}

.accordion-header dl dd {
	font-size: 1.8rem;
	font-weight: bold;
	color: #313538;
}

.accordion-header::before,
.accordion-header::after{
  position:absolute;
  content:'';
  top:1px;
  right:20px;
  bottom:0;
  width:15px;
  height:2px;
  margin:auto;
  background:#1E98CC;
}
.accordion-header::after{
  transform:rotate(-90deg);
  transition:transform 0.3s;
}
.accordion-header.active::after{transform:rotate(0deg);}

.accordion-content {
	padding: 2rem 0 0;
	margin-top: 2rem;
	border-top: 1px dashed #8E8E8E;
}

.accordion-content p {
	font-size: 1.6rem;
	text-align: left;
	line-height: 2;
	font-weight: 500;
}


.accordion-header span,
.accordion-content span{
  padding-left: 25px;
  position: relative;
}

.accordion-header:hover {
	opacity: .5;
}

.page-link {
	background: url("../img/page/rework/bg-line.png") repeat;
	background-size: 30px;
	padding: 8rem 0 0;
}

.page-link ul {}

.page-link ul li {
	width: 540px;
	max-width: 48%;
	overflow:hidden;
	position: relative;
}

.page-link ul li h2 {
	position: absolute;
	text-align: center;
	top: 50%;
	left: 0;
	right: 0;
	margin: 0 auto;
	font-size: 2rem;
	font-weight: bold;
	color: #fff;
	transform: translateY(-50%);
}

.page-link ul li {
	border: 3px solid #C6C6C6;
	border-radius: 30px;
}

.page-link ul li a:hover {opacity: 1;}
.page-link ul li img{
	transition: .5s all;
	opacity: .8;
}

.page-link ul li img:hover{
  transform:scale(1.2,1.2);
  transition:1s all;
}

.page-link ul li a{
	display: block;
	position: relative;
	background-color: #EF90B0;
}

.page-link ul li a:hover{
	transition: inherit;
}

.page-link ul li a:hover img{
	opacity: .3;
}

/*-----------------------------

training

------------------------------*/

.training-area {
	padding: 7rem 0;
	background: #F7FFED;
	margin-bottom: 7rem;
}

.training-area ul li {
	width: 520px;
	max-width: 48%;
}

.training-area ul li .training-box {
	padding: 5rem 3rem;
	background: #fff;
	margin-top: -2rem;
	text-align: center;
}

.training-area ul li .training-box h2 {
	font-size: 2.2rem;
	font-weight: bold;
	margin-bottom: 2rem;
}

.training-area ul li .training-box p {
	font-size: 1.6rem;
	line-height: 2;
	text-align: left;
	font-weight: 500;
	margin-bottom: 2rem;
}

.training-area ul li .btn {
	width: 300px;
	margin: 0 auto;
	position: relative;
}

.training-area ul li .btn span {
	position: absolute;
	top: 0;
	right: 4rem;
}

.training-area ul li .btn a {
	display: block;
	height: 50px;
	line-height: 50px;
	border: 1px solid #CECECE;
	border-radius: 40px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: bold;
}

.use-area {
	margin-bottom: 10rem;
	text-align: center;
}

.use-area h2 {
	padding-top: 10rem;
	font-size: 3.2rem;
	font-weight: bold;
	margin-bottom: 5rem;
}

.use-inner {
	width: 98%;
	max-width: 98%;
	margin: 0 auto;
	align-items: flex-end;
}

.use-inner .use-img {
	width: 48%;
	max-width: 48%;
}

.use-inner .use-info {
	width: 48%;
	max-width: 48%;
	background: #F3F8FB;
	border-radius: 30px;
	padding: 5rem;
}

.use-inner .use-info ul li {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.8;
	text-align: left;
	padding-left: 0.8rem;
	padding-left: 27px;
	position: relative;
}

.use-inner .use-info ul li span {
	color: #1E98CC;
	position: absolute;
	top: 0px;
	left: 0px;
}

.use-inner .use-info ul li + li {margin-top: 1.5rem;}

.training-area01 {
	text-align: center;
	margin-bottom: 10rem;
}

.training-area01 h2,
.training-programs h2,
.training-programs02 h2{
	font-size: 3.2rem;
	font-weight: bold;
	margin-bottom: 2rem;
}

.training-programs02 h2 {margin-bottom: 4rem;}

.training-area01 p,
.training-programs p,
.training-programs02 h3.programs_ttl01{
	font-size: 2rem;
	font-weight: 500;
	margin-bottom: 3rem;
}

.training-programs02 p{
	font-size: 2rem;
	font-weight: bold;
	margin-bottom: 3rem;
}


.training-area01 ol {flex-wrap: wrap;}
.training-area01 ol li,
.training-programs02 ol li{
	width: 356px;
	max-width: 32.5%;
	border: 2px solid #CECECE;
	background: #fff;
	border-radius: 20px;
	padding: 1.5rem 1rem;
	margin-bottom: 2rem;
}

.training-programs02 ol {margin-bottom: 7.5rem;}
.training-programs02 ol li{padding: 1.5rem 2rem;}

 .training-programs02 ol li .img{
	text-align: center;
	padding-bottom: 2rem;
}

.training-area01 ol li {}

.training-area01 ol li dl {margin-bottom: 4rem;}
.training-programs02 ol li dl {align-items: center; margin-bottom: 2rem;}
.training-area01 ol li dl dt,
.training-programs02 ol li dl dt{
	font-size: 4.4rem;
	font-weight: bold;
	color: #EF90B0;
	margin-right: 1rem;
}

.training-programs02 ol li dl dt {color: #76AD11;}

.training-area01 ol li dl dd,
.training-programs02 ol li dl dd{
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.6;
	text-align: left;
}

.training-programs02 ol li p {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 2;
	margin-bottom: 0;
}

.training-programs {margin-bottom: 14rem;}
.training-programs .inner {
	border-radius: 30px;
	padding: 4rem 9rem;
	background: #F7FFED;
	text-align: center;
}

.training-programs .inner ul {
	margin-top: 10rem;
}

.training-programs .inner ul li.list {
	width: 440px;
	max-width: 48%;
	background: #fff;
	border: 2px solid #C6C6C6;
	padding: 3rem;
	border-radius: 20px;
}

.training-programs .inner ul li.list h3 {
	font-size: 2.2rem;
	color: #1E98CC;
	font-weight: bold;
	margin: -5rem 0 3rem;
}

.training-programs .inner ul li.list h3 span {
	background: #fff;
	border-radius: 30px;
	padding: 1rem 3rem;
}
.training-programs .inner ul li.list ol {padding: 0 1rem 0 3rem;}
.training-programs .inner ul li.list ol li {
	font-size: 2rem;
	font-weight: bold;
	text-align: left;
}

.training-programs .inner ul li.list ol li + li {margin-top: 2rem;}

.training-programs .inner ul li.list ol li span {
	color: #EF90B0;
	padding-right: 1rem;
}

.training-programs .inner ul li.list ol li b{
	color:#FF982A;
	font-size: 12px;
	vertical-align: top;
	margin: 0px 0px 0px 10px;
	position: relative;
}

.training-programs02 {
    padding: 7rem 0;
    margin-bottom: 10rem;
    background: url(../img/page/curriculum/bg-left01.png), url(../img/page/curriculum/bg-right01.png) #FEFCEA;
    background-repeat: no-repeat;
    background-position: top 20% left 5%, top 20% right 5%;
    background-size: 66px 73px, 50px 49px;
}

.training-programs02 p {line-height: 2;}
.training-programs02 .programs02-inner {
	background: #fff;
	padding: 7rem 3rem 10rem !important;
	border-radius: 30px;
	text-align: center;
	margin-bottom: 5rem;
}

.training-programs02-img {
	width: 80%;
	margin: 0 auto;
	padding-top: 3rem;
}

.training-programs02 h3.programs_ttl02 {
	font-size: 2.2rem;
	font-weight: bold;
	border-left: 10px solid #76AD11;
	padding-left: 2rem;
	margin-bottom: 2em;
}

.programs-voice {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 0 1rem;
	
}

.programs-voice .voice {
	background: #fff;
	border-radius: 30px;
	padding: 2rem;
}

.programs-voice .voice p {
	font-size: 1.6rem;
	font-weight: 500;
	margin-bottom: 1rem;
}

.programs-voice .voice .voice-icon {text-align: right;}

.voice_box01,
.voice_box03 {height: 233px;}

.voice_box04 {height: 293px;}
.voice_box05 {height: 203px;}
.voice_box06 {height: 353px;}





/*-----------------------------

footer

------------------------------*/

footer {
	padding: 10rem 0 3rem;
	background: #F7F7F7;
}

footer .footer-address,
footer .footer-nav{
	width: 550px;
	max-width: 50%;
}

footer .footer-address .logo {margin-bottom: 4rem;}
footer .footer-address p b {
	font-size: 2rem;
}

footer .footer-address p {
	font-size: 2.8rem;
	font-weight: bold;
	line-height: 1.4;
	margin-bottom: 30px;
}

footer .footer-address p + p {margin-top: 4rem;}
footer .footer-nav {}

footer .footer-nav ul {
	flex-wrap: wrap;
}
footer .footer-nav ul.nav li {
	width: 140px;
	max-width: 30%;
	margin: 0 0 2rem 3rem;
}

footer .footer-nav ul.nav li a {
	font-size: 1.6rem;
	font-weight: bold;
	padding-bottom: 1rem;
	background-image : linear-gradient(to right, #313538 4px, transparent 4px);
	background-size: 7px 2px;
	background-repeat: repeat-x; 
	background-position: left bottom;
	display: block;
}

footer .footer-nav ul.nav li ul.child {padding-top: 1rem;}
footer .footer-nav ul.nav li ul.child li {
	width: 100%;
	max-width: 100%;
	margin: 0;
}

footer .footer-nav ul.nav li ul.child li a {
	font-size: 1.4rem;
	font-weight: 500;
	background: none;
}

p.copyright {
	padding-top: 10rem;
	font-size: 1.4rem;
	font-weight: bold;
	text-align: center;
}




/*-----------404-----------------*/
p.error_txt {
	font-size: 1.4rem;
	line-height: 2;
}

/*----------------------------blog-single----------------------------*/

ul#blog-cate{
	max-width: 1000px;
	width: 90%;
	margin: 0 auto;
	padding-top: 100px;
}

ul#blog-cate li{
	display: inline-block;
	margin: 0px 10px 10px 0px;
	color:#06A79A;
	border: 1px solid #06A79A;
	padding: 10px 15px;
	border-radius: 30px;
	font-size: 14px;
}

h2#blog-ttl{
	padding-top: 10px;
	font-size: 36px;
	line-height: 1.6em;
	font-weight: 900;
	max-width: 1000px;
	width: 90%;
	margin: 0 auto;
}

p#blog-time{
	padding: 20px 0px 50px;
	max-width: 1000px;
	width: 90%;
	margin: 0 auto;
	letter-spacing: 0.1em;
	font-size: 16px;
}

#blog-contents{
	padding: 0 80px 15px;
	background-color: #fff;
	max-width: 1170px;
	width: 90%;
	margin: 0 auto;
	font-size: 16px;
}

#blog-contents h2{
	color:#EF90B0;
	border: 1px solid #EF90B0;
	padding: 15px;
	margin-top: 50px;
	margin-bottom: 10px;
}

#blog-contents h3{
	margin-top: 50px;
	border-bottom: 1px solid #EF90B0;
	padding-bottom: 5px;
	margin-bottom: 10px;
}

#blog-contents li,
#blog-contents p{
	line-height: 2em;
	font-weight: 500;
	font-size: 1.5rem;
}

.wp-caption img{
	width: 100%;
	height: auto;
	object-fit: cover;
	display: block;
	margin-bottom: 20px;
}

#blog-contents img{
	max-width: 100%;
	height: auto;
	display: block;
	margin-bottom: 20px;
}

#blog-contents h3{
	margin-top: 70px;
	margin-bottom: 30px;
	border-bottom: 1px solid #CECECE;
	position: relative;
	font-size: 26px;
	padding-bottom: 20px;
	line-height: 1.6em;
}

#blog-contents h3:after{
	position: absolute;
	content: " ";
	display: block;
	border-bottom: 1px solid #06A79A;
	bottom: -1px;
	width: 200px;
}

#blog-contents h4{
	color:#06A79A;
	font-size: 20px;
	border: 1px solid #06A79A;
	padding: 20px 30px;
	margin-top: 70px;
	margin-bottom: 30px;
	line-height: 1.6em;
}

#pagination{
	text-align: center;
	padding: 70px 0px 85px;
}

#pagination a#back{
	display: inline-block;
	text-decoration: none;
	color:#06A79A;
	width: 200px;
	line-height: 60px;
	border: 1px solid #EF90B0;
	color:#fff;
	margin: 0px 45px;
	font-weight: bold;
	border-radius: 5px;
	background-color: #EF90B0;
}

#pagination a#back:hover{
	background-color: #fff;
	color:#06A79A;
}

#pagination a{
	font-size: 1.4rem;
	display: inline-block;
	color:#333333;
	font-weight: bold;
	text-decoration: none;
}

#pagination a:hover{
	color:#06A79A;
}

#pagination a.arrow i{
	color:#06A79A;
	margin: 0px 10px;
}

.post_thumbnail {margin-bottom: 5rem;}

.tooltip{
 	position: relative;
 	cursor: pointer;
}
.tooltip p{
 	margin: 0;
	padding: 0;
}
.fukidashi {
	display: none;
	position: absolute;
	padding: 10px;
	font-size: 12px;
	line-height: 1.6em;
	color: #fff;
	border-radius: 5px;
	background: #000;
	width: auto;
}
.fukidashi1{
	top: -100px;
}
.fukidashi2{
	top: -75px;
}
.fukidashi3{
	top: -115px;
}
.fukidashi:before {
	content: "";
	position: absolute;
	top: 100%;
	left: 50px;
	border: 10px solid transparent;
	border-top: 15px solid #000;
}
.tooltip:hover .fukidashi{
    display: inline-block;
    top: -60px;
    left: 0px;
}

.tooltip:hover .fukidashi1{
	top: -100px;
}

.tooltip:hover .fukidashi2{
	top: -75px;
}

.tooltip:hover .fukidashi3{
	top: -115px;
}

.hide-text{
	margin-top: 2rem;
}


.page-about {
	margin: 5em 0 0;
}
.page-about .inner {align-items: center;}
.page-about-info {
	width: 58%;
	max-width: 58%;
}

.page-about-info h3 {
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 1rem;
}
.page-about-info p {
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: bold;
}

.page-about-img {
	width: 40%;
	max-width: 40%;
}

.pp{
	border: 1px solid #ddd;
	padding: 40px;
	border-radius: 20px;
	margin-top: 50px;
	height: 250px;
	overflow-y: scroll;
}

.pp p.ttl-pp{
	font-size: 17px;
	line-height: 1.2em;
	font-weight: bold;
}

.pp p.ttls-pp{
	font-size: 16px;
	line-height: 1.2em;
	font-weight: bold;
	padding-top: 25px;
	padding-bottom: 10px;
}

.pp p.txt-pp{
	font-size: 14px;
	line-height: 1.8em;
	font-weight: 500;
}

.pp p.txt-pp.txt-pp-spc{
	position: relative;
	padding-left: 15px;
}

.pp p.txt-pp.txt-pp-spc span{
	position: absolute;
	top: 3px;
	left: 0px;
	display: block;
}




