@charset "utf-8";
/*==================================================
	【トップ】ページ固有のスタイル
==================================================*/
.top_contact_box a {
	display: inline-block;
	background: #fff;
	width: calc(50% - 200px);
	padding: 10px;
	box-sizing: border-box;
	line-height : 28.5px;
	color : #00401E;
	position: absolute;
	bottom: 10%;
	left: 13%;
	border-radius: 10px;
	font-size: 98%;
	font-weight: 500;
}
.fb_box {
	display: inline-block;
	width: 180px;
	box-sizing: border-box;
	line-height : 28.5px;
	color : #00401E;
	position: absolute;
	bottom: 10%;
	right: 8%;
}
.fb_box .waku {
	display: inline-block;
	width: 100%;
	background: #fff;
	border: 3px solid #0e4b69;
	border-radius: 30px;
	padding: 2px 10px 0;
	box-sizing: border-box;
	color : #0E4B69;
	font-weight: 500;
}
.fb_box .box_flex_sp {
	justify-content: center;
	align-items: center;
	column-gap: 20px;
}
.fb_box .logo img {
	width: 50px;
}
.fb_box .qr img {
	width: 60px;
}
.lft_box {
	width: 270px;
}
.rit_box {
	width: 780px;
}
.txt {
	font-weight: 500;
}
.top_ttl {
	align-items: center;
	margin-bottom: 50px;
}
.top_ttl h3.sub {
	width: 270px;
	margin-bottom: 0!important;
}
.top_ttl .txt_box {
	width: 780px;
}
#concept .lft_box {
	justify-content: space-between;
	flex-direction: column;
}
#concept .rit_box .txt {
	line-height : 32.5px;
	margin-bottom: 2em;
}
#concept .rit_box ul {
	display: grid;
	justify-content: space-between;
	grid-template-columns: repeat(3, 31%);
	gap: 20px 0;
}
#concept .rit_box li {
	background: #00401e;
	border-radius: 25px;
	min-height: 49px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
}
#lesson .rit_box .txt.pb02 {
	padding-bottom: 32px;
}
#lesson .rit_box .contents_box dl {
	border-bottom: 1px solid #ccc;
	padding: 15px 0;
	display: flex;
	justify-content: flex-start;
	font-weight: 500;
}
#lesson .rit_box .contents_box dl:last-of-type {
	margin-bottom: 20px;
}
#lesson .rit_box .contents_box dt {
	width: 10%;
	padding-left: 1em;
	position: relative;
}
#lesson .rit_box .contents_box dt::before {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	background: #0e4b69;
	border-radius: 50%;
	top: 9px;
	left: 0;
}
#price .ttl_box {
	justify-content: flex-start;
	align-items: center;
	margin-bottom: 50px;
}
#price .ttl_box h3.sub {
	margin-right: 50px;
	margin-bottom: 0;
}
#price .box_price {
	display: grid;
	justify-content: space-between;
	grid-template-columns: repeat(2, 48%);
	gap: 40px 0;
}

#price .price_waku .col_box {
	font-size: 125%;
	background: #5d7100;
	line-height : 54px;
	color: #fff;
}
#price .price_waku.orange .col_box {
	background: #ff8f17;
}
#price .price_waku .beige_box {
	background: #f9e9da;
	padding: 15px 40px;
}
#price .price_waku .beige_box .in {
	width: 100%;
	margin: 0 auto;
}
#price .price_waku .beige_box .in.mb {
	margin-bottom: 15px;
}
#price .price_waku .beige_box .in .ttl,#price .price_waku .beige_box .in .lesson {
	padding: 0 20px;
}
#price .price_waku .beige_box .in .lesson  {
	padding: 0 20px;
}
#price .price_waku .beige_box .in .line {
	border-bottom: 2px dotted #0e4b69;
	width: 25%;
	position: relative;
	top: -13px;
}
#price .price_waku .beige_box .in .line.no {
	border-bottom: none;
}
#price .price_waku .beige_box .in .line.w40 {
	width: 40%;
}
#price .price_waku .beige_box .in .line.w27 {
	width: 27%;
}
#price .price_waku .beige_box .in .line.w19 {
	width: 19%;
}
#price .price_waku .beige_box .in .line.w15 {
	width: 15%;
}
/* 月謝枠の高さを揃える */
#price .price_waku.orange .beige_box {
  min-height: 115px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  text-align: center;
}
#about .about_contents .box {
	width: 48%;
	background: #f9e9da;
	border-radius: 30px;
	margin-bottom: 50px;
	overflow: hidden;
}
#about .about_contents .box:last-of-type {
	margin-bottom: 0;
}
#about .about_contents .box .ttl {
	background: #5d7100;
	font-size : 125%;
	color: #fff;
	min-height: 67px;
	display: flex;
	justify-content: center;
	align-items: center;
}
#about .about_contents .box .ttl .zyunbi {
	background: #fff;
	color : #E50011;
	display: inline-block;
	padding: 0 5px;
	margin-left: 1em;
	font-weight: 500;
}
#about .about_contents .box .txt_box {
	padding: 25px;
}
#about .about_contents .box .txt_box dl {
	font-weight: 500;
	border-top: 1px solid #ccc;
	display: flex;
	padding: 15px 0;
}
#about .about_contents .box .txt_box dl:last-of-type {
	border-bottom: 1px solid #ccc;
}
#about .about_contents .box .txt_box dt {
	width: 20%;
}
#about .about_contents .box .pin a {
	background: #e0e000;
	font-size : 110%;
	color: #e50011;
	min-height: 67px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 500;
}
#about .about_contents .box .pin a img {
	padding-left: 1em;
}
#profile .prof_box .rit_box .career_box {
	border-left: 1px solid #0e4b69;
	padding-left: 2em;
	margin-bottom: 50px;
}
#profile .prof_box .rit_box .career_box dl {
	display: flex;
	font-weight: 500;
	margin-bottom: 15px;
}
#profile .prof_box .rit_box .career_box dt {
	width: 10%;
}
#profile .prof_box .rit_box .career_box dd {
	width: 90%;
}
#profile .prof_box.tbs_img .lft_box {
	display: flex;
	justify-content: center;
}
#contact .contact_box .rit_box .txt {
	margin-bottom: 0;
}
#contact .contact_box .rit_box .tel a {
	color : #0E4B69;
	font-size: 32px;
}
#contact .box {
	background: #f2f2f2;
}
#contact .box .yellow_box {
	background: #e0e000;
	font-weight: 500;
	min-height: 54px;
	display: flex;
	justify-content: center;
	align-items: center;
}
#contact .box table,#contact .box tbody {
	width: 570px;
	margin: 0 auto;
	display: block;
}
#contact .box tr {
	margin: 25px 0;
	display: block;
}
#contact .box th,#contact .box td {
	display: block;
}
#contact .box td input {
	background: #fff;
	border: none;
	min-height: 54px;
	display: block;
	width: 100%;
	font-size: 110%;
}
#contact .box td textarea {
	background: #fff;
	border: none;
	min-height: 193px;
	display: block;
	width: 100%;
	font-size: 110%;
}
#contact .box .btn input {
	background: #5d7100;
	width: 218px;
	min-height: 67px;
	border-radius: 35px;
	font-size: 125%;
	margin: 15px 0 50px;
	color: #fff;
	border: none;
}
#contact .box .btn input:hover {
	opacity: 0.5;
	cursor: pointer;
}
#sns .rit_box {
	border: 1px solid #ccc;
}
/*slider02*/
#slider02 {
	max-width: 100%;
	margin: 0 auto;
}
#slider02 {
	margin: 0 5px;
}
#slider02 img {
	max-width: calc(100% - 35px);
	height: auto;
	margin: 0 auto;
}
.slick-prev, .slick-next {
	z-index: 1;
}
.slick-slide {
	transition: all ease-in-out .3s;
}
.slick-slide {
	opacity: 0.3;
	transition: 0.2s linear;
}
.slick-active {
	opacity: 1;
}
.slick-current {
	opacity: 1;
}
.thumb {
	margin: 20px 0 0;
}
.thumb .slick-slide {
	cursor: pointer;
}
.thumb .slick-slide:hover {
	opacity: .7;
}
.full-screen .slick-list {
	overflow: visible;
}
.full-screen.slider {
	margin: 0 auto;
}
@media print, screen and (min-width: 769px){ /* PCのみ */
	#contact .contact_box .rit_box .txt {
		margin-bottom: -5px;
		margin-top: 5px;
	}
	#lesson .rit_box .txt {
		margin-top: 13px;
	}
}
@media print, screen and (min-width: 641px){ /* PC・タブレット */
	/* お知らせ */
	#top_info dl {
		display: flex;
	}
	#top_info dt {
		width: 100px;
	}
	#top_info dd {
		width: calc(100% - 100px);
	}
}
@media only screen and (max-width: 768px) and (min-width: 641px){ /* タブレットのみ */
}
@media only screen and (max-width: 768px) {  /* タブレット以下 */
	.top_contact_box a {
		width: 50vw;
		line-height: 1.8em;
		bottom: 5%;
		left: 5%;
		padding: 5px;
	}
	.fb_box {
		bottom: 5%;
		right: 0;
		line-height: 1.8em;
	}
	.lft_box ,.rit_box {
		width: 100%;
	}
	.lft_box {
		margin-bottom: 20px;
	}
	.lft_box .img  {
		text-align: center;
	}
	.lft_box .img img {
		width: 250px;
	}
	.rit_box .txt {
		line-height: 1.8em;
		margin-bottom: 15px;
	}
	#concept .rit_box ul {
		grid-template-columns: repeat(3, 32%);
	}
	#lesson .rit_box .txt.pb02 {
		padding-bottom: 20px;
	}
	#lesson .rit_box .contents_box dt {
		width: 15%;
	}
	#lesson .rit_box .contents_box dd {
		width: 72%;
	}
	#price .box_price {
		grid-template-columns: repeat(1, 100%);
		gap: 30px 0;
	}
	#price .price_waku .beige_box .in {
		width: 100%;
	}
	.top_ttl h3.sub {
		margin-bottom: 30px!important;
		width: 100%;
	}
	#about .about_contents .box .ttl {
		font-size: 105%;
		line-height: 1.5em;
	}
	#about .about_contents .box .txt_box {
		padding: 15px;
	}
	#about .about_contents .box .txt_box dl {
		padding: 5px;
		flex-direction: column;
	}
	#about .about_contents .box .txt_box dt,#about .about_contents .box .txt_box dd {
		width: 100%;
	}
	#about .about_contents .box .pin a {
		font-size: 105%;
		min-height: 50px;
	}
	#profile .prof_box .rit_box .career_box {
		padding-left: 1em;
	}
	#contact .box table, #contact .box tbody {
		width: 90%;
	}
}
@media only screen and (max-width: 640px){ /* スマホ */
	#slider {
		margin-bottom: 80px;
	}
	.top_contact_box a {
		font-size: 80%;
		width: 90%;
		left: 50%;
		transform: translateX(-50%);
		border: 2px solid #00401E;
	}
	#page_title .fb_box {
		display: none;
	}
	#concept {
		padding-top: 20px;
	}
	.lft_box .img img {
		width: 180px;
	}
	#concept .rit_box .txt {
		line-height: 1.8em;
	}
	#concept .rit_box ul {
		grid-template-columns: 100%;
	}
	#lesson .rit_box .contents_box dl {
		flex-direction: column;
	}
	#lesson .rit_box .contents_box dt,#lesson .rit_box .contents_box dd {
		width: 100%;
	}
	#price .price_waku .beige_box {
		padding: 15px 10px;
	}
	#price .price_waku.nyukai .beige_box .in {
		width: 100%;
		flex-direction: column;
	}
	#price .price_waku.nyukai .beige_box .in p {
		text-align: center;
	}
	#price .price_waku.nyukai .beige_box .in .line {
		display: none;
	}
	#price .price_waku .beige_box .in .line.w40 {
		width: 27%;
	}
	#price .price_waku .beige_box .in .line.w27 {
		width: 13%;
	}
	#price .price_waku .beige_box .in .line.w19 {
		width: 6%;
	}
	#price .price_waku .beige_box .in .line.w15 {
		width: 3%;
	}
	#price .price_waku .beige_box .in .ttl,#price .price_waku .beige_box .in .lesson {
		padding: 0;
	}
	#price .price_waku.orange .col_box {
		line-height: 1.8em;
		padding: 0 15px;
	}
	#about .about_contents .box {
		width: 100%;
		margin: 0 auto 30px;
	}
	#about .about_contents .box .txt_box dl {
		flex-direction: row;
	}
	#about .about_contents .box .txt_box dt {
		width: 25%;
	}
	#about .about_contents .box .txt_box dd {
		width: 75%;
	}
	#profile .prof_box .rit_box .career_box dt {
		width: 23%;
	}
	#contact .contact_box .rit_box .tel a {
		font-size: 135%;
	}
	#contact .box .yellow_box {
		padding: 0 15px;
	}
	#contact .box .yellow_box .txt {
		text-align: left;
	}
	#contact .box table, #contact .box tbody {
		width: 95%;
	}
	#sns .sns_box iframe {
		width: 80%;
		height: 350px;
	}
}
	@media only screen and (max-width: 320px) {
		#about .about_contents .box .txt_box dt {
			width: 30%;
		}
		#about .about_contents .box .txt_box dd {
			width: 70%;
		}
		#price .price_waku .beige_box .in .line.w27 {
			width: 3%;
		}
		#price .price_waku .beige_box .in .line.w15 {
			width: 0%;
		}
	}