@charset "UTF-8";

/*
	Theme Name: lilys2026
	Theme URI: lilys-english.com
	Author: c-designoffice
*/


/*HEADER*/

header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 999;
	/* headerに余白を作るß */
	padding: 0 24px 16px ;
	/* アニメーションの変化時間 */
	transition: 0.5s;
	background-color: #fff;
	border-radius: 0px 0px 30px 30px;
}
header h1 {
	font-size: x-small; 
	transition: 0.5s;
}
.hed-top {
	display: flex;
    align-items:center;
	padding: 0;
}

.logo {
    width: 180px;
	margin-right:auto;
    margin-left:0;
	/* アニメーションの変化時間 */
	transition: 0.5s;
}
.global_menu {
}
.con-list {
	margin-left:auto;
	margin-right:0;
	text-align: center;
}
.con-list img {
	height: 24px;
	transition: 0.5s;
	padding-bottom: 8px;
}
.con-list span {
	display: block;
	color: #0282AB;
	font-size: 14px;
	font-weight: 900;
	transition: 0.5s;
}

.global_menu ul {
	display:flex;
    align-items:center;
}
.global_menu li {
	transition: 0.5s;
	text-align: center;
	padding: 0 16px;
	font-weight: 900;
	font-size: 0.9rem;
}
.global_menu img {
	height: 40px;
	transition: 0.5s;
	padding-bottom: 4px;
}
.global_menu span {
	display: block;
}

/* スクロールして「scroll-navクラス」がついたときのヘッダーデザイン */
header.scroll-nav {
	/* 余白を狭くする */
	padding: 8px 32px 16px;
}
header.scroll-nav h1 {
	display: none;
}

/* 「scroll-navクラス」がヘッダーについたときに、ロゴとナビゲーションの文字を黒にする */
header.scroll-nav .logo,
header.scroll-nav li {
}

header.scroll-nav .logo {
}

header.scroll-nav .global_menu {
}
header.scroll-nav .global_menu li {
	padding: 0 16px;
	font-size: 14px;
}
header.scroll-nav .global_menu img {
	height: 24px;
}
header.scroll-nav .con-list img {
	height: 20px;
}
header.scroll-nav .con-list span {
	font-size: 14px;
}


/*モーダルメニュー*/


/* ボタンのデザイン */
.menu-btn {

}

.menu-btn:hover {
  opacity: .8;
}

/* オーバーレイ */
.overlay {
  /* 位置を固定 */
  position: fixed;
  top: 0;
  left: 0;
  /* 画面いっぱいに広がるようにする */
  width: 100%;
  height: 100vh;
  /* rgbaを使って60%の黒いオーバーレイにする */
  background: #E5F6FF;  
  /* デフォルトでは見えないようにする */
  opacity: 0;
  visibility: hidden;
  /* 表示する際の変化の所要時間 */
  transition: .3s;
}

/* activeクラスのついたオーバーレイ */
.overlay.active {
  /* activeクラスがついたときにオーバーレイを表示する */
  opacity: 1;
  visibility: visible;
}

/* モーダルウィンドウ */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-y: auto;
    width: 100%;
    height: 100%;
    -webkit-transition: all .5s;
    transition: all .5s;
    visibility: hidden;
    opacity: 0;
	z-index: 1000;
}

/* activeクラスのついたモーダルウィンドウ */
.modal.active {
  opacity: 1;
  visibility: visible;
}

/* モーダルウィンドウ内の閉じるボタン */
.modal .close {
	position: absolute;
	top: 18px;
	right: 40px;
	cursor: pointer;
	display: block;
	font-weight: 900;
	text-align: center;
}
.modal .close img {
	height: 16px;
}
.modal .close span {
	display: block;
	color: #0282AB;
	font-size: 14px;
}
.modal-logo {
	padding-top: 32px;
	padding-left: 40px;
	display: flex;
}
.modal-logo h2 {
	font-size: 32px;
	color: #0282AB;
	font-weight: 900;
}
.modal-area {
	margin: 0 auto;
	max-width: 980px;
	display: flex;
	justify-content: center;
	padding-top: 16px;
}
.modal-area div {
	padding: 0 24px;
}

.modal-menu {
    padding: 0;
}

.modal-menu li {
    list-style-type: none;
    position: relative;
    padding: 4px 0;
	font-weight: 900;
	font-size: 16px;
}
.modal-menu li a {
	color: #0282AB;
}
.modal-menu li ul li {
    list-style-type: none;
    position: relative;
    padding: 0 0 0 16px;
	font-size: 14px;
	line-height: 24px;
	font-weight: normal;
}

.modal-menu span a {
  display: inline-block;
  max-width: 100%;
  display: flex;
  align-items: center;
  padding-left: 16px;
  text-decoration: none;
  background-image: url("images/link-blue02.svg");
  background-repeat: no-repeat;
  background-size: 8px 8px;
  background-position: left 0 top 50%;
}
.modal-sns {
}
.modal-sns a {
	padding: 4px 0;
	display: flex;
	align-items: center;
	font-weight: 900;
	color: #0282AB;
}
.modal-sns img {
	width: 24px;
	margin-right: 8px;
}



/*MAIN*/
main {
	padding-bottom: 64px;
}


/*TOP*/
	
/* スライダー全体のスタイル */
.slider-container {
    position: relative;
    width: 100%;
    overflow: hidden;
}
/* 各スライド画像のスタイル */
.slideimg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    animation: fadeInOut 25s infinite;
}
/* 最初の画像だけ親要素の高さを確保させる */
.slideimg:nth-child(1) {
    position: relative;
    animation-delay: 0s;
}
/* 2枚目の画像のアニメーション遅延 */
.slideimg:nth-child(2) {
    animation-delay: 5s;
}
/* 3枚目の画像のアニメーション遅延 */
.slideimg:nth-child(3) {
    animation-delay: 10s;
}
/* 4枚目の画像のアニメーション遅延 */
.slideimg:nth-child(4) {
    animation-delay: 15s;
}
/* 5枚目の画像のアニメーション遅延 */
.slideimg:nth-child(5) {
    animation-delay: 20s;
}
/* フェードイン・アウトのアニメーション */
@keyframes fadeInOut {
  0% { opacity: 0; } /* 開始（透明） */
  10% { opacity: 1; } /* 1.25秒で表示 */
  20% { opacity: 1; } /* 2.5秒まで表示 */
  25% { opacity: 0; } /* 3.125秒で消える（0%に戻る） */
  100% { opacity: 0; } /* 5秒間（25秒サイクル）待機してループ */
}
/* 画像の表示調整 */
.slideimg img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
}



.top-main {
	width: 100%;
	position: relative;
    display: inline-block;
	background: url("images/bg-topmain.png");
	background-position: bottom;
	background-size: 100% auto;
}
.top-main-image {
	width: 90%;
	margin: 0 auto;
	padding-top: 56px;
}
.top-main-image img{
    display: block;
    width: 100%;
}
.top-main img.topmain-wave{
    position: absolute;
    right: 0%;
    bottom: 0%;
    width: 100%;
    height: auto;
}
.top-main img.gem-birdy{
    position: absolute;
    right: 2%;
    bottom: 120px;
    width: 144px;
    height: auto;
}
.top-snsarea {
	position: absolute;
	right: 5%;
    bottom: 0%;
	background-image: url("images/bg-sns.png");
	background-repeat: no-repeat;
	background-size: 100%;
	width: 240px;
    height: 160px;
	text-align: center;
}
.top-snsarea h2 {
	font-size: 16px;
	padding-top: 64px;
}
.top-snsarea ul {
	display: flex;
	justify-content: center;
	margin: 8px 0;
}
.top-snsarea li {
	padding: 0 3px;
	width: 48px;
}
.top-snsarea img {
	width: 100%;
}
.top-gem3 {
	position: absolute;
	left: 5%;
    bottom: 0;
	width: 640px;
    height: auto;
}

/*TOP想い*/

.top-omoi {
	padding: 32px 0 96px 0;
	text-align: center;
	width: 100%;
	position: relative;
    display: inline-block;
}
.top-omoi h2,.top-omoi h3 {
	margin: 16px 0;
}
.top-omoi p {
	text-align: center;
	font-weight: 900;
	line-height: 2.2;
}
.top-omoi img{
    display: block;
    max-width: 100%;
    height: auto;
}
.top-omoi img:nth-of-type(1){
    position: absolute;
    right: 80px;
	bottom: 0;
    width: 380px;
    height: auto;
}


/*TOPお知らせ*/

.top-oshirase {
    background-image: linear-gradient(#ffffff, #7fcdf3);
    width: 100%;
	padding: 0;
}
.oshirase-list {
	padding: 24px 0;
}
.oshirase-list li {
	margin: 0 8px;
	padding: 24px;
	border: solid 3px #333333;
	background-color: #fff;
	border-radius: 20px;
}
.oshirase-list-image {
	position: relative;
	width: 100%;/*　トリミングしたい枠の幅（固定にしたい場合はサイズを入力）　*/
	padding-top: 75%;/*　トリミングしたい枠の高さを比率で指定。（固定にしたい場合はサイズを入力）　*/
	margin: 0 auto;
}
.oshirase-list img {
/* 画像を上下左右に中央配置する（絶対指定） */
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
.oshirase-list time {
	display: block;
	text-align: right;
	font-size: 13px;
	color: #0282AB;
}
.news-tag {
	margin-bottom: 8px;
}
.news-tag span {
	color: #fff;
	font-size: 13px;
	padding: 0 8px;
	line-height: 24px;
	border-radius: 50px;
	display:  inline-block;	
	background-color: #0282AB;
	margin-right: 3px;
}
.oshirase-list p {
	font-weight: 900;
}


/*スライダー
******************/

.slider { 
}

.slick-track {
  display: flex !important;
  align-items: stretch;
}
.slick-slide {
  height: auto !important;
}

/*TOP 英会話教室*/

.top-school {
	background-image: url("images/bg-wave-blue-alphabet.png"),
		url("images/bg-wave-orange-alphabet.png");
	background-position: top,
		bottom;
	background-repeat: no-repeat,
		no-repeat;
	background-size: 100% auto;
	padding: 15% 0;
}

.tab-1 {
    display: flex;
    flex-wrap: wrap;
    gap: 0 10px;
    max-width: 100%;
	margin: 40px 0;
}

.tab-1 > label {
    flex: 1 1;
    order: -1;
    min-width: 70px;
    padding: 24px;
    border-radius: 15px 15px 0 0;
    background-color: #f2f2f2;
    color: #333;
    font-size: 16px;
	font-weight: 900;
    text-align: center;
    cursor: pointer;
}

.tab-1 > label:hover {
    opacity: .8;
}

.tab-1 input {
    display: none;
}

.tab-1 > div {
    display: none;
    width: 100%;
    padding: 48px;
    background-color: #fff;
	border-radius: 0 0 15px 15px;
}

.tab-1 label:has(:checked) {
    background-color: #0282AB;
    color: #fff;
}

.tab-1 label:has(:checked) + div {
    display: block;
}

.school-box-kids {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.school-box-kids img {
	border-radius:10px;
}
.school-box-kids-img {
	width: 40%;
}
.school-box-kids-text {
	width: 55%;
}
.school-box-kids-title {
}

.school-box-other {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	padding: 40px 0;
}
.school-box-other img {
	border-radius:10px;
}

.school-box-other2 {
	width: 47%;
	display: flex;
	align-items: stretch;
}

.school-box-other3 {
	width: 32%;
	margin: 16px 0;
}
.school-box-other3 img {
	margin-bottom: 16px;
	width: 100%;
}

.school-box-title {
	margin: 8px 0;
}
.school-box-title a {
	display: inline-block;
	max-width: 100%;
	background-repeat: no-repeat;
	background-size: 28px 28px;
	background-position: left;
	font-size: 24px;
	line-height: 40px;
	padding-left: 35px;
}
.-blue a {
	background-image: url("images/link-blue01.svg");
	color: #0282AB;
}
.-green a {
	background-image: url("images/link-green01.svg");
	color: #52C362;
}
.-pink a {
	background-image: url("images/link-pink01.svg");
	color: #EB5E6F;
}
.-purple a {
	background-image: url("images/link-purple01.svg");
	color: #A964CE;
}
.-orange a {
	background-image: url("images/link-orange01.svg");
	color: #FF9502;
}
.-gray a {
	background-image: url("images/link-gray01.svg");
	color: #707070;
}

.page-menu {
	display: flex;
	justify-content: space-between;
	margin: 8px 0;
}
.page-menu li {
	width: 30%;
	border-bottom: dashed 2px #0282AB;
}
.page-menu a {
	display: inline-block;
	max-width: 100%;
	display: flex;
	align-items: center;
	padding: 8px 0;
	text-decoration: none;
	background-image: url("images/link-blue02.svg");
	background-repeat: no-repeat;
	background-size: 16px 16px;
	background-position: right 0 top 50%;
	font-weight: 900;
}

.bg-nyukaiannai {
	background-image: url("images/image-nyukaiannai.png");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	border-radius:20px 80px 20px 20px;
	padding-top: 160px;
}
.bg-seitohogosha {
	background-image: url("images/image-seitohogosha.png");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	border-radius:20px 80px 20px 20px;
	padding-top: 160px;
}
.school-box-annai {
	width: 72%;
	padding: 24px;
	background:rgba(255,255,255,0.9);
	border-radius:0 60px 0 0;
}
.school-box-annai h3 {
	color: #0282AB;
	margin: 0;
	padding: 0;
}
.school-box-annai ul {
	margin:0;
}
.school-box-annai li {
	border-bottom: dashed 2px #0282AB;
}
.school-box-annai a {
	display: inline-block;
	max-width: 100%;
	display: flex;
	align-items: center;
	padding: 8px 0;
	text-decoration: none;
	background-image: url("images/link-blue02.svg");
	background-repeat: no-repeat;
	background-size: 16px 16px;
	background-position: right 0 top 50%;
	font-weight: 900;
}

.contact-taiken {
	position: relative;
    display: inline-block;
	width: 100%;
	margin: 48px 0;
}
.contact-taiken img:nth-of-type(1){
    position: absolute;
    left: 30px;
    top: -70px;
    width: 150px;
    height: auto;
}
.contact-taiken-box {
	display: flex;
	align-items: center;
}
.contact-taiken-text {
	width: 60%;
	text-align: center;
}
.contact-taiken-btn {
	width: 38%;
}

/*TOP 英語の先生育成講座*/

.top-teacher {
	background-color: #FFF5E2;
	padding: 32px 0;
}
.top-teacher p {
	margin-bottom: 16px;
}
.top-teacher img {
	border-radius:10px;
}


/*TOP 法人・教育機関の方へ*/

.top-tocorporate {
	background-image: url("images/bg-lighthouse-alphabet.png");
	background-position: top;
	background-repeat: no-repeat;
	background-size: 100% auto;
	padding-top: 18%;
}
.top-tocorporate p {
	padding-bottom: 8px;
}
.top-tocorporate h3 {
	text-align: center;
	padding-bottom: 8px;
}
.top-tocorporate h4,.top-tocorporate h5 {
	text-align: center;
	padding-bottom: 8px;
}

/*BTN*/

.more-btn {
	margin:0 auto;
	width: 300px;
}


a.btn1{
	color: #fff !important;
	font-weight: 900;
	text-decoration: none;
	text-align:center;
	text-decoration:none !important;
	width: 100%;
	height: 72px;
	line-height: 72px;
	background: #0282AB;
	display:inline-block;
	border-radius: 50px;
	margin: 32px 0;
	font-size: 20px;
}
a.btn1:after {
	content: "";
	display: inline-block;
	width: 24px;
	height: 24px;
	background: url("images/link-white01.svg") no-repeat ;
	background-size: contain;
	vertical-align: middle;
	margin: -3px 0 0 16px ;
}

a.btn2{
	color: #fff !important;
	font-weight: 900;
	text-decoration: none;
	text-align:center;
	text-decoration:none !important;
	width: 100%;
	height: 72px;
	line-height: 72px;
	background: #FF9502;
	display:inline-block;
	border-radius: 50px;
	margin: 32px 0;
	font-size: 20px;
}
a.btn2:after {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	background: url("images/link-white01.svg") no-repeat ;
	background-size: contain;
	vertical-align: middle;
	margin: -3px 0 0 16px ;
}

a.btn3{
	color: #0282AB !important;
	font-weight: 900;
	text-decoration: none;
}
a.btn3:after {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	background: url("images/link-blue02.svg") no-repeat ;
	background-size: contain;
	vertical-align: middle;
	margin: -3px 0 0 16px ;
}

a.btn-line{
	color: #fff !important;
	font-weight: 900;
	text-decoration: none;
	text-align:center;
	text-decoration:none !important;
	width: 100%;
	height: 56px;
	line-height: 56px;
	background: #06BC24;
	display:inline-block;
	border-radius: 50px;
	margin: 0;
}
a.btn-line:before {
	content: "";
	display: inline-block;
	width: 24px;
	height: 24px;
	background: url("images/link-line.svg") no-repeat ;
	background-size: contain;
	vertical-align: middle;
	margin: -3px 8px 0 0;
}

a.btn-mail{
	color: #fff !important;
	font-weight: 900;
	text-decoration: none;
	text-align:center;
	text-decoration:none !important;
	width: 100%;
	height: 56px;
	line-height: 56px;
	background: #0282AB;
	display:inline-block;
	border-radius: 50px;
	margin: 0;
}
a.btn-mail:before {
	content: "";
	display: inline-block;
	width: 24px;
	height: 24px;
	background: url("images/link-mail.svg") no-repeat ;
	background-size: contain;
	vertical-align: middle;
	margin: -3px 8px 0 0;
}


/*TITLE*/

main h1 {
}
main h2,main h3,main h4,main h5,main h6 {
	font-weight: 900;
}

.tit01 {
	text-align: center;
	margin-bottom: 40px;
}

.tit02 {
	text-align: center;
}

.tit03 {
	text-align: center;
	font-size: 32px;
	margin-bottom: 32px;
}

.heading01 {
	text-align: center;
	margin-bottom: 40px;
}
.heading01 img {
	height: 56px;
	margin-bottom: 8px;
}
.heading01 span {
	display: block;
	color: #0282AB;
	font-weight: 900;
	font-size: 48px;
}
.heading01 h2 {
	padding-top: 16px;
}

.heading02 {
    position: relative;
    padding: 8px 8px 8px;
    border-bottom: 3px solid #fff;
    color: #fff;
	font-weight: 900;
	margin-bottom: 16px;
}

.heading02::before,
.heading02::after {
    position: absolute;
    left: 28px;
    bottom: -16px;
    width: 28px;
    height: 16px;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
}

.heading02::before {
    background-color: #fff;
}

.heading02::after {
    bottom: -11px;
    background-color: #0282AB;
}

.heading03 {
	margin: 16px 0;
	text-align: center;
	padding: 16px 0 8px;
	border-bottom: dashed 2px #0282AB;
}

.heading04 {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction : column;
	margin: 32px 0 56px 0;
	text-align: center;
}
.heading04::before{
	content: '';
	position: absolute;
	display: inline-block;
	width: 2px;
	height: 32px;
	bottom: -48px;
	left: 50%;
 -webkit-transform: translateX(-50%);
 transform: translateX(-50%);
 background-color:currentColor !important;
	color: #0282AB;
	top:unset;
	border: unset;
	margin-left: unset;
	margin-right:unset;
}
.heading04 span {
	font-size: 16px;
}

.heading05 {
	display: flex;
	justify-content: center;
}
.heading05 img {
	width: 88px;
	height: auto;
	padding-right: 8px;
	margin-left: -40px;
}
.heading05 h2 {
	color: #fff;
	font-size: 72px;
	margin: 0;
	padding: 0;
	line-height: 65px;
}

.heading06 {
	position: relative;
	text-align: center;
	margin: -72px 0 16px 0;
	padding: 8px 0;
	border-bottom: dashed 2px #0282AB;
}

.heading06::before {
	content: attr(data-number);
	display: block;
	margin-bottom: 30px;
	color: #fff;
	font-size: 14px;
	width: 90px;
	height: 90px;
	border-radius: 50%;
	background: #0282AB;/*背景色*/
	margin: 10px auto;
	line-height: 90px;
	text-align: center;
}

.heading07 {
	text-align: center;
	margin: 16px 0;
}
.heading07 img {
	height: 90px;
	padding-bottom: 8px;
}

.heading08 {
	padding: 16px 8px 16px 40px;
	position: relative;
	color: #FF9502;
	line-height: 48px;
	text-align: center;
	background-color: #ffe0bb;
	border-radius: 100px;
	margin: 24px 0;
	font-size: 24px;
	font-weight: 900;
}
.heading08:before{
	position: absolute;
	content: attr(data-number);
	display:inline-block;
	background: #FF9502;
	color: #fff;
	font-size: 32px;
	width: 48px;
	height: 48px;
	line-height: 48px;
	border-radius: 50%;
	text-align: center;
	margin-left: calc( -1em - 30px );
}

.heading09 {
	padding: 16px 8px 16px 40px;
	position: relative;
	color: #13c12c;
	line-height: 48px;
	text-align: center;
	background-color: #c7e1aa;
	border-radius: 100px;
	margin: 24px 0;
	font-size: 24px;
	font-weight: 900;
}
.heading09:before{
	position: absolute;
	content: attr(data-number);
	display:inline-block;
	background: #13c12c;
	color: #fff;
	font-size: 32px;
	width: 48px;
	height: 48px;
	line-height: 48px;
	border-radius: 50%;
	text-align: center;
	margin-left: calc( -1em - 30px );
}

.heading10 {
	padding: 16px 8px 16px 40px;
	position: relative;
	color: #fe475d;
	line-height: 48px;
	text-align: center;
	background-color: #f8cde0;
	border-radius: 100px;
	margin: 24px 0;
	font-size: 24px;
	font-weight: 900;
}
.heading10:before{
	position: absolute;
	content: attr(data-number);
	display:inline-block;
	background: #fe475d;
	color: #fff;
	font-size: 32px;
	width: 48px;
	height: 48px;
	line-height: 48px;
	border-radius: 50%;
	text-align: center;
	margin-left: calc( -1em - 30px );
}

.heading11 {
	margin: 16px 0;
	position: relative;
	text-align: center;
	padding: 8px 0;
	border-bottom: dashed 2px #0282AB;
}

.heading11::before {
	content: attr(data-number);
	display: block;
	margin-bottom: 30px;
	color: #fff;
	font-size: 14px;
	width: 90px;
	height: 90px;
	border-radius: 50%;
	background: #0282AB;/*背景色*/
	margin: 10px auto;
	line-height: 90px;
	text-align: center;
}

.heading12 {
	position: relative;
	text-align: center;
	padding: 8px 0;
	font-family: serif;
	font-size: 32px;
}

.heading12::before {
	content: attr(data-number);
	display: block;
	color: #0282AB;
	font-size: 24px;
	text-align: center;
	font-family: luxus-brut, cursive;
}

.heading13 {
	position: relative;
}

.heading13::before {
	position: absolute;
	content: attr(data-number);
	display:inline-block;
	color: #fff;
	font-size: 16px;
	font-family: luxus-brut, cursive;
	margin-left: calc( -1em - 5px );
}

/*TEXT*/

.text-emphasiz01 {
	font-weight: 900;
	text-align: center;
	margin-bottom: 16px;
}
.text-emphasiz02 {
	font-weight: 900;
	text-align: center;
	margin-bottom: 8px;
}

.accent1 {
	font-size: 32px;
	padding: 0 3px;
}
.accent2 {
	font-size: 56px;
	padding: 0 3px;
}
.accent3 {
	font-size: 24px;
	padding: 0 3px;
}

.tab {
	font-size: 13px;
	font-weight:900;
	padding: 4px 10px;
	border-radius: 50px;
	display:  inline-block;	
}
.-tab-blue {
	background-color: #C7F2FF;
	color: #24A0C7;
}
.-tab-green {
	background-color: #C7F2CD;
	color: #52C362;
}
.-tab-pink {
	background-color: #FFDDE0;
	color: #EB5E6F;
}
.-tab-purple {
	background-color: #F3DEFF;
	color: #A964CE;
}
.-tab-orange {
	background-color: #FFE4BF;
	color: #FF9502;
}
.-tab-gray {
	background-color: #D3D3D3;
}

/*list*/

ol.number01 {
  counter-reset:number; /*数字をリセット*/
  list-style-type: none!important; /*数字を一旦消す*/
  padding:8px;
}
ol.number01 li {
  position: relative;
  padding: 8px 8px 8px 40px;
	background: #FFF7F7;
	color: #FE5C68;
	font-weight: 900;
	margin-bottom: 8px;
	line-height: 24px;
}

ol.number01 li:before{
  /* 以下数字をつける */
  position: absolute;
  counter-increment: number;
  content: counter(number);
  /*以下数字のデザイン変える*/
  display:inline-block;
  background: #FE5C68;
  color: white;
  font-weight:900;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  line-height: 24px;
  text-align: center;
  margin-left: calc( -1em - 15px );
  margin-right: 4px;
}

ol.number02 {
  list-style: none;
  counter-reset: number;
	line-height: 32px;
	margin-left: 8px;
	margin-bottom: 8px;
}
ol.number02 li {
  position: relative;
  padding-left: 24px;
}

ol.number02 li:before{
  counter-increment: number;
  content: counter(number) '.';
  position: absolute;
  left: 0;
}


ol.number03 {
  list-style: none;
  counter-reset: number;
	line-height: 32px;
}
ol.number03 li {
  position: relative;
  padding-left: 40px;
}

ol.number03 li:before{
  counter-increment: number;
  content: '（' counter(number) '）';
  position: absolute;
  left: 0;
}

.reten-white li {
  position: relative;
  line-height: 1.8;
	padding: 0 8px 0 24px;
}
.reten-white li::after {
  content: '';
  display: block;
  position: absolute;
  top: .5em;
  left: 0;
  width: 10px;
  height: 5px;
  border-left: 3px solid #FFF;
  border-bottom: 3px solid #FFF;
  transform: rotate(-45deg);
}

.reten-or li {
  position: relative;
  line-height: 1.8;
	padding: 0 8px 0 24px;
}
.reten-or li::after {
  content: '';
  display: block;
  position: absolute;
  top: .5em;
  left: 0;
  width: 10px;
  height: 5px;
  border-left: 3px solid #FF9502;
  border-bottom: 3px solid #FF9502;
  transform: rotate(-45deg);
}

.reten-blue li {
  position: relative;
  line-height: 1.8;
	padding: 0 8px 0 24px;
}
.reten-blue li::after {
  content: '';
  display: block;
  position: absolute;
  top: .5em;
  left: 0;
  width: 10px;
  height: 5px;
  border-left: 3px solid #24A0C7;
  border-bottom: 3px solid #24A0C7;
  transform: rotate(-45deg);
}

ul.center-l-list li {
	font-weight: 900;
	text-align: center;
	padding-bottom: 8px;
}

ul.circle-list {
	list-style: none;
	padding-left: 0;
	display: table;
}
ul.circle-list li:after {
	content: "";
	display: block;
}
ul.circle-list li {
	display: table-row;
	line-height: 1.8;
}
ul.circle-list li:before {
	content: "⚫︎";
	display: table-cell;
	padding-right: 4px;
}

ul.kome-list {
	list-style: none;
	padding-left: 0;
	display: table;
}
ul.kome-list li:after {
	content: "";
	display: block;
}
ul.kome-list li {
	display: table-row;
	line-height: 1.8;
}
ul.kome-list li:before {
	content: "※";
	display: table-cell;
	padding-right: 4px;
}

.btn-list {
	display: flex;
	justify-content: center;
	margin: 16px 0;
}
.btn-list li {
	padding: 8px;
}
.btn-list img {
	width: 300px;
}

/*back-color*/

.bg-blue {
	background: #F0FBFF;
	padding: 48px 56px;
	height:auto !important;
	border-radius: 20px;
	margin: 80px 0;
}
.bg-blue100 {
	background: #F0FBFF;
	padding: 80px 0;
	margin: 80px 0;
}
.bg-pink100 {
	background: #FF7EA6;
	padding: 40px 0;
	margin: 40px 0;
}
.bg-purple100 {
	background: #E8E9FF;
	padding: 40px 0;
	margin: 40px 0;
}
.bg-blue-pink100 {
	background: linear-gradient(180deg, #7FCDF3 0%, #7FCDF3 50%, #FF9BBD 50%, #FF9BBD 100%);
	padding: 40px 0;
	margin: 56px 0;
}
.bg-yellow {
	background: #FFF100;
	padding: 32px;
	height:auto !important;
	border-radius: 20px;
}

.bg-rightyellow {
	background: #FFFBE5;
	padding: 48px 56px;
	height:auto !important;
	border-radius: 20px;
	margin: 80px 0;
}

.bg-white {
	background: #fff;
	padding: 32px;
	height:auto !important;
	border-radius: 20px;
	margin: 24px 0;
}

.bg-line {
	border: solid 5px;
	padding: 24px;
	height:auto !important;
	border-radius: 20px;
}
.bg-line-- {
	border: solid 5px;
	padding: 0;
	height:auto !important;
	border-radius: 20px;
}
.-line-blue {
	border-color:#96DCF2;
}
.-line-green {
	border-color:#A5E6AF;
}
.-line-pink {
	border-color:#FFBEC5;
}
.-line-purple {
	border-color:#E4BCFA;
}
.-line-orange {
	border-color:#FFCE8B;
}
.-line-gray {
	border-color:#BEBEBE;
}



/*layout*/

.column {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.column-f {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.column-s {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.column-w {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
}
.column-cw {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-wrap: wrap;
}
.column-sw {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
}
.column-ss {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.column2-1 {
	width: 48%;
}
.column3-1 {
	width: 32%;
}
.column3-2 {
	width: 32%;
}
.column2 {
	width: 48%;
}
.column4 {
	width: 24%;
}

.column-img {
	width: 32%;
}
.column-text {
	width: 64%
}

.column-img-m {
	width: 25%;
}
.column-text-l {
	width: 72%
}
.column4-2 {
	width: 23%;
	margin: 0 3px;
}



/*FOOTER*/

footer {
	margin-top: 40px;
}
footer h2,
footer h3,
footer h4,
footer h5 {
	font-weight: 900;
}

.foot-wrapper {
	margin: 0 auto;
	width: 1008px;
}

/*フッターコンタクト*/

.foot-contact {
	background-color: #F0FBFF;
	padding: 56px 0;
	text-align: center;
	align-items: flex-start;
}
.foot-contact-box {
	display: flex;
	justify-content: center;
	text-align: center;
}
.foot-contact-box--- {
	width: 33%;
}
.foot-contact-box h4 {
	font-size: 16px;
	margin-bottom: 8px;
}
.contact-tel {
	font-weight: 900;
	font-size: 32px;
}

/*サイトマップアコーディオン*/

.sitemap  {
	margin: 0 auto;
	background-color: #F0FBFF;
}

.footer-nav {
	padding: 40px 0;
	color: #fff;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	border-top: solid 1px #ACD6E3;
}
.footer-nav div {
	padding: 0 32px;
}

.footer-menu {
    padding: 0;
}

.footer-menu li {
    list-style-type: none;
    position: relative;
    padding: 4px 0;
	font-weight: 900;
	font-size: 16px;
}
.footer-menu li a {
	color: #0282AB;
}
.footer-menu li ul li {
    list-style-type: none;
    position: relative;
    padding: 0 0 0 16px;
	font-size: 14px;
	line-height: 2.0;
	font-weight: normal;
}
.footer-menu span a {
  display: inline-block;
  max-width: 100%;
  display: flex;
  align-items: center;
  padding-left: 16px;
  text-decoration: none;
  background-image: url("images/link-blue02.svg");
  background-repeat: no-repeat;
  background-size: 8px 8px;
  background-position: left 0 top 50%;
}
.footer-sns {
}
.footer-sns a {
	padding: 4px 0;
	display: flex;
	align-items: center;
	font-weight: 900;
	color: #0282AB;
}
.footer-sns img {
	width: 24px;
	margin-right: 5px;
}


.footer-area {
	text-align: center;
	color: #fff;
	background-color: #0282AB;
	padding: 56px 0;
}
.footer-logo {
	width: 230px;
	padding-bottom: 8px;
	margin: 0 auto;
}
.footer-area h2 {
	font-weight: 900;
	font-size: 16px;
}
.footer-area p {
}
.footer-map {
}
a.footer-map {
	color: #fff;
	font-weight: 400;
	border-bottom: 1px solid #fff;
}
a.footer-map:before {
	content: "";
	display: inline-block;
	width: 24px;
	height: 24px;
	background: url("images/link-googlemap.svg") no-repeat ;
	background-size: contain;
	vertical-align: middle;
	margin: -3px 0px 0 0;
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	background-color: #fff;
	padding: 8px 24px;
	font-size: 13px;
}
.footer-bottom ul {
	display: flex;
}
.footer-bottom li {
	margin-right: 8px;
}
.copyright {
	font-size: 13px;
}


/*contents*/

.contents p {
	margin-bottom: 8px;
}

.tit-en {
	display: block;
	font-size: 14px;
	color: #0282AB;
}

.contents-header01 {
	width: 100%;
	position: relative;
    display: inline-block;
	margin-bottom: 32px;
}
.contents-header01 img{
    display: block;
    width: 100%;
	height: 250px;
	object-fit: cover;
	object-position: bottom 0 right 0;
}

.contents-header02 {
	width: 100%;
	position: relative;
    display: inline-block;
	margin-bottom: 32px;
}
.contents-header02 img{
    display: block;
    width: 100%;
	height: 500px;
	object-fit: cover;
	object-position: bottom 0 right 0;
}

.contents-title {
	position: absolute;
	left: 10%;
    bottom: 0;
	background-color: #fff;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: left 32px top 50%;
	background-size: 56px auto; 
	padding: 16px 32px 16px 104px;
	border-radius: 50px;
}

.-con-about {
	background-image: url("images/nav-about.svg");
}
.-con-companies {
	background-image: url("images/nav-companies.svg");
}
.-con-dispatch {
	background-image: url("images/nav-dispatch.svg");
}
.-con-teacher {
	background-image: url("images/nav-teacher.svg");
}
.-con-school {
	background-image: url("images/nav-school.svg");
}
.-con-news {
	background-image: url("images/nav-news.svg");
}
.-con-lilys {
	background-image: url("images/nav-lilys.svg");
}
.-con-mail {
	background-image: url("images/nav-mail.svg");
}

.contents-image {
	margin: 16px 0 ;
}

/*リリーズについて*/

.aboutus-youtube {
	padding: 128px 96px 80px;
}

.column-method {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	padding: 8px 0;
}
.column-method-box {
	width: 48%;
	align-self: stretch;
}

.aboutus-column {
	background-image: url("images/bg-yakusoku.jpg");
	background-repeat: no-repeat;
	background-position: center;
	text-align: center;
	color: #fff;
	padding:  0;
}
.aboutus-column-box {
	background: linear-gradient(
      -45deg,
      rgba(0, 193, 209, 0.8),
      rgba(0, 118, 221, 0.8));
	padding: 13em 0 8em 0;
}
.aboutus-column h2,.aboutus-column h3 {
	margin: 16px 0;
}
.aboutus-column p {
	text-align: center;
	font-weight: 900;
	line-height: 2.2;
}
.aboutus-column li {
	text-align: center;
	font-weight: 900;
	line-height: 2.2;
}

.aboutus-method {
	width: 100%;
	position: relative;
    display: inline-block;
	padding-top: 56px;
}
.aboutus-method img.gem-ian-lamp{
    position: absolute;
    left: 80px;
    top: -48px;
    width: 200px;
    height: auto;
}
.aboutus-method img.gem-andy-haguruma{
    position: absolute;
    right: 32px;
    top: 960px;
    width: 200px;
    height: auto;
}
.aboutus-method img.gem-eve-flag{
    position: absolute;
    left: 32px;
    bottom: -160px;
    width: 200px;
    height: auto;
}

/*子ども英会話*/

.course-nav {
	display: flex;
	justify-content: center;
}
.course-nav-btn {
	width: 10%;
	margin: 0 8px;
	border-radius: 10px;
}
.course-nav-btn a {
	color: white;
	font-weight: 900;
	text-align: center;
	display:flex;
	flex-direction: column;
	width: 100%;
	height: 88px;
	padding: 12px 8px 0 8px;
	transition: .4s;
	background-image: url("images/link-down-white.svg");
	background-repeat: no-repeat;
	background-position: right 50% bottom 16%;
	background-size: 16px 16px;
}
.course-nav-btn a:hover {
	color: white;
	background-image: url("images/link-down-white.svg");
	background-repeat: no-repeat;
	background-position: right 50% bottom 10%;
	background-size: 16px 16px;
}

.course-nav-btn span {
	font-size: 13px;
}

.course-nav-btn-others {
	width: 10%;
	margin: 0 8px;
}
.course-nav-btn-others a {
	color: #0282AB;
	font-weight: 900;
	text-align: center;
	display:flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 88px;
	padding: 0 8px;
	transition: .4s;
	background: #fff;
	border: #0282AB solid 2px;
	border-radius: 10px;
}
.course-nav-btn-others a:hover {
	background-color: #BCEDFF;
}

.-down-blue {
	background-color: #24A0C7;
}
.-down-green {
	background-color: #52C362;
}
.-down-pink {
	background-color: #EB5E6F;
}
.-down-purple {
	background-color: #A964CE;
}
.-down-orange {
	background-color: #FF9502;
}
.-down-gray {
	background-color: #767676;
}
.-down-blue:hover {
	background-color:#96DCF2;
}
.-down-green:hover {
	background-color:#A5E6AF;
}
.-down-pink:hover {
	background-color:#FFBEC5;
}
.-down-purple:hover {
	background-color:#E4BCFA;
}
.-down-orange:hover {
	background-color:#FFCE8B;
}
.-down-gray:hover {
	background-color:#BEBEBE;
}


.course-wrapper {
	margin: 56px 0;
}
h3.course-title {
	margin: 0 0 8px;
	display: flex;
	align-items: center;
}
.course-title span {
	margin-right: 8px;
}
.course-box{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	margin: 0;
}

.course-box-img{
	width: 45%;
	height:auto;
}
.course-box-img img {
	border-radius: 15px 0 0 15px;
	object-fit: cover;
	width: 100%;
    height: 100%;
}
.course-box-text{
	width: 51%;
	padding: 32px 32px 32px 0;
}


/*講師派遣*/

.okan-list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 16px 0;
}
.okan-list li {
	text-align: center;
	width: 150px;
	height: 150px;
	background-image: url("images/bg-okan.png");
	background-size: 150px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 900;
	margin: 0 4px;
}

/*バルーン*/

.balloon {
    position: relative;
    padding: 24px;
    border-radius: 5px;
    border: 2px solid #333;
    color: #333;
    font-weight: bold;
    text-align: center;
	background-color: #FFE8EB;
	margin: 56px 0;
}

.balloon:before {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    height: 3px;
    width: 20px;
    background-color: #fff;
    content: "";
}

.balloon:after {
    position: absolute;
    top: 90%;
    left: 50%;
    transform: translateX(-50%);
    height: 32px;
    width: 2px;
    background-color: #333;
    content: "";
}


/*フロー*/

/***ステップバーデザイン***/
.step-wrap {
 counter-reset: count;
 margin: 4em 0;
 position: relative;
}
.step-content {
 padding: 1.3em 0 .3em 3em;
 margin: 0 0 1em 1em;
 position: relative;
 border-top: solid 2px #ddd;
}
.step-content::before {
 content: "";
 display: block;
 position: absolute;
 bottom: 0;
 left: 4px;
 border-style: solid;
 border-width: 14px 12px 0 12px;
 border-color: #B2ECFF transparent transparent transparent;
}
.step-content::after {
 content: "";
 display: block;
 height: calc(100% - 36px);
 border-left: dotted 12px #B2ECFF;
 position: absolute;
 top: 16px;
 left: 10px;
}
.step-label {
 padding: 3px 20px 3px 15px;
 color: #fff;
 font-weight: bold;
 position: absolute;
 top: -18px;
 left: -20px;
 background: #0282AB;
 border-radius: 20px;
 z-index: 1;
}
.step-label::after {
 counter-increment: count;
 content: counter(count);
 position: relative;
 left: .3em;
}
.step-title h3 {
	margin: 0;
	color: #0282AB;
}
.step-body {
 margin-top: .5em;
 padding: 0 0 1em;
}
.step-wrap > :last-child {
 box-shadow: 5px 7px 0 -5px #ddd;
}
.step-wrap > :last-child::before, .step-wrap > :last-of-type::after {
 display: none;
}
/***ステップバーデザイン***/


/*先生育成*/

.column-tokucho {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	padding: 8px 0;
}
.column-tokucho-box {
	width: 31%;
	align-self: stretch;
}


/*生徒・保護者様へ*/

.information-menu {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 16px 0 80px 0;
}
.information-menu li {
	width: 40%;
	margin: 4px;
}
.information-menu a {
	color:  #0282AB;
	font-weight: 900;
	text-decoration: none;
	text-align:center;
	width: 100%;
	height: 48px;
	line-height: 48px;
	background: #E5EBED;
	border: #C7C7C7 solid 1px;
	display:inline-block;
	border-radius: 48px;
}
.information-menu a:hover {
	background-color: #8ED1E6;
	color: #fff;
}
.information-menu a.active {
	background-image: linear-gradient(90deg, #149ecb, #0282ab);
	color: #fff;
}

/* *************  タブレット 以下 *************
*******************************************************************************/
@media only screen and (max-width:896px){
	
/*HEADER*/
	
/*HEADER*/

header {
	padding: 0 16px 16px ;
}

.logo {
    width: 110px;
}

.global_menu li {
	padding: 0 8px;
	font-size: 13px;
}
.global_menu img {
	height: 20px;
}
	
/* スクロールして「scroll-navクラス」がついたときのヘッダーデザイン */
header.scroll-nav {
	/* 余白を狭くする */
	padding: 8px 16px 16px ;
}
header.scroll-nav .global_menu li {
	padding: 0 8px;
	font-size: 13px;
}

	
/* モーダルウィンドウ内の閉じるボタン */
.modal .close {
	top: 10px;
	right: 20px;
}

.modal-logo {
	padding-top: 32px;
	padding-left: 24px;
}

.modal-area {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.modal-area div {
	padding: 0;
	width: 40%;
}
			
/*MAIN*/
	
/*TOP*/
	
.top-main-image {
}
.top-main-image img{
}

.top-main img.gem-birdy{
    right: 2%;
    bottom: 96px;
    width: 96px;
}
.top-snsarea {
	right: 5%;
    bottom: 0%;
	width: 200px;
    height: 124px;
}
.top-snsarea h2 {
}
.top-snsarea ul {
	margin: 4px 0;
}
.top-snsarea li {
	width: 40px;
}
.top-gem3 {
	width: 480px;
}
	
/*TOP想い*/
	
.top-omoi {
	padding: 24px 0 88px 0;
}

.top-omoi img:nth-of-type(1){
    width: 230px;
}

	
/*TOP 英会話教室*/
	
.tab-1 {
	margin: 24px 0;
}

.tab-1 > label {
    padding: 16px 8px;
    font-size: 14px;
}
.tab-1 > div {
    padding: 24px;
}

.school-box-kids {
	align-items: flex-start;
}
.school-box-kids-img {
	width: 28%;
}
.school-box-kids-text {
	width: 70%;
}
.school-box-title a {
	font-size: 20px;
}
.school-box-annai {
	width: 88%;
}
.contact-taiken {
	margin-top: 32px;
}
.contact-taiken img:nth-of-type(1){

}
.contact-taiken-box {
	display: flex;
	align-items: center;
}
.contact-taiken-text {
	width: 60%;
	text-align: center;
}
.contact-taiken-btn {
	width: 40%;
}

/*BTN*/

.more-btn {
	width: 240px;
}
	
a.btn1{ font-size: 16px; }
	
a.btn2{ font-size: 16px; }

/*TITLE*/



	
/*TEXT*/

.text-emphasiz01 {
}
.text-emphasiz02 {
}

.accent1 {
	font-size: 24px;
}
.accent2 {
	font-size: 32px;
}

/*list*/
	
.btn-list {
	display: block;
}
.btn-list li {
	padding: 8px 0;
	text-align: center;
}
	
/*CONTACT*/
	
.foot-wrapper {
	width: 90%;
}

.foot-contact-box {
	flex-flow: wrap;
}
.foot-contact-box--- {
	width: 40%;
}

/*FOOTER*/

.footer-nav {
	padding-bottom: 4em;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.footer-nav div {
	padding: 0;
	width: 40%;
}
	
/*contents*/

.contents {
}
.contents p {
	margin-bottom: 8px;
}

.contents-title {
	left: 5%;
    border: 0;
}

/*リリーズについて*/
	
.aboutus-youtube {
	padding: 88px 48px 48px;
}

.aboutus-column img.gem-kenny-niji{
	top: -104px;
    width: 130px;
}
.aboutus-column img.gem-jenny-heart{
    width: 130px;
}

.aboutus-method img.gem-ian-lamp{
    width: 130px;
}
.aboutus-method img.gem-andy-haguruma{
    width: 130px;
}
.aboutus-method img.gem-eve-flag{
    width: 130px;
}

/*先生育成*/

.column-tokucho-box {
	width: 48%;
}
	

}


/* *************  スマホ以下 *************
*******************************************************************************/

@media only screen and (max-width:640px){
	

/*HEADER*/
header {
		line-height: 16px;
}
.global_menu {
	display: none;
}

	
/*モーダルメニュー*/

/* モーダルウィンドウ内の閉じるボタン */
.modal .close {
	top: 16px;
	right: 16px;
}
.modal-logo {
	padding-top: 24px;
	padding-left: 16px;
}

.modal-area {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.modal-area div {
	padding: 0;
	width:  48%;
}

.modal-menu li {
    padding: 4px 0;
	font-size: 13px;
}
.modal-menu li ul li {
	font-size: 13px;
	line-height: 20px;
	padding: 0px 0 4px 16px;
}
	
.modal-sns a {
	line-height: 20px;
	font-size: 13px;
}

	
/*MAIN*/
main {
	padding-bottom: 32px;
}

/*TOP*/

.top-main {
	margin-bottom: 0;
	background-size: 140% auto;
}
.top-main-image {
	width: 85%;
	margin: 0 auto;
	padding: 80px 0 48px 0;
}
.top-main-image img{
}
.top-main img.gem-birdy{
    right: 1%;
    bottom: 80px;
    width: 72px;
}
.top-snsarea {
	right: 2%;
    bottom: 0%;
	width: 140px;
    height: 90px;
}
.top-snsarea h2 {
	font-size: 12px;
	padding-top: 32px;
}
.top-snsarea ul {
	margin: 2px 0;
}
.top-snsarea li {
	width: 38px;
}
.top-gem3 {
	left: 2%;
    bottom: -120px;
	width: 95%;
    height: auto;
}
	
/*TOP想い*/
.top-omoi {
	padding: 120px 0 56px;
}

.top-omoi img:nth-of-type(1){
	bottom: 0;
	right: 5px;
    width: 220px;
}
	
/*TOP 英会話教室*/

.top-school {
}

.school-box-kids {
	display: block;
}
.school-box-kids-img {
	width: 100%;
	margin-bottom: 16px;
}
.school-box-kids-text {
	width: 100%;
}
.school-box-other {
	display: block;
	padding: 16px 0;
}
.school-box-other3 {
	width: 100%;
}
	
.school-box-other2 {
	width: 100%;
	margin: 16px 0;
}
	
.bg-nyukaiannai {
	padding-top: 120px;
}
.bg-seitohogosha {
	padding-top: 120px;
}
.school-box-annai {
	width: 90%;
	padding: 16px;
}

	
.page-menu {
	display: block;
	margin: 8px 0;
}
.page-menu li {
	width: 100%;
}

.contact-taiken {
	margin-top: 32px;
}
.contact-taiken img:nth-of-type(1){
    left: 10px;
    top: -60px;
    width: 96px;
}
.contact-taiken-box {
	display: block;
	align-items: center;
}
.contact-taiken-text {
	width: 100%;
	text-align: center;
	margin-bottom: 16px;
}
.contact-taiken-btn {
	width: 100%;
}
	
/*TOP 英語の先生育成講座*/
	
/*TOP 法人・教育機関の方へ*/

.top-tocorporate h4,.top-tocorporate h5 {
	text-align: left;
}

	
/*TITLE*/

.tit01 {
	text-align: center;
}
.tit02 {
	text-align: left;
}
.tit03 {
	text-align: center;
	font-size: 20px;
}
.heading01 {
	margin-bottom: 24px;
}
.heading01 span {
	font-size: 32px;
}

.heading04 {
}
.heading05 {
	margin-bottom: 24px;
}
.heading05 img {
	width: 48px;
}
.heading06 {
	margin-top: -40px;
}
	
.heading08 {
	padding: 10px 8px 10px 40px;
	line-height: 32px;
	text-align: center;
	font-size: 18px;
}
.heading08:before{
	font-size: 24px;
	width: 32px;
	height: 32px;
	line-height: 32px;
	margin-left: calc( -1em - 20px );
}

.heading09 {
	padding: 10px 8px 10px 40px;
	line-height: 32px;
	text-align: center;
	font-size: 18px;
}
.heading09:before{
	font-size: 24px;
	width: 32px;
	height: 32px;
	line-height: 32px;
	margin-left: calc( -1em - 20px );
}

.heading10 {
	padding: 10px 8px 10px 40px;
	line-height: 32px;
	text-align: center;
	font-size: 18px;
}
.heading10:before{
	font-size: 24px;
	width: 32px;
	height: 32px;
	line-height: 32px;
	margin-left: calc( -1em - 20px );
}

	
.heading12 {
	font-size: 20px;
}
.heading12::before {
	font-size: 16px;
}


	
/*TEXT*/

.text-emphasiz02 {
	line-height: 24px;
}

.accent1 {
	padding: 0 3px;
}
.accent2 {
	font-size: 24px;
	padding: 0 3px;
}

	
/*layout*/

.column {
	display: block;
}
.column-s {
	display: block;
}
.column2-1 {
	width: 100%;
	margin-top: 1em;
}
.column3-1 {
	width: 100%;
	margin-top: 1em;
}
.column3-2 {
	width: 48%;
}
.column4-2 {
	width: 48%;
}
.column-text {
	width: 100%
}
	
.column-img {
	width: 60%;
	margin: 0 auto;
}
	
.column-img-m {
	width: 15%;
}
.column-text-l {
	width: 82%
}

/*back-color*/

.bg-blue {
	padding: 24px;
	margin: 40px 0;
}
.bg-yellow {
	padding: 16px;
}	
.bg-rightyellow {
	padding: 24px;
	margin: 40px 0;
}
	
.bg-white {
	padding: 16px;
}

.bg-line {
	padding: 16px;
}

/*CONTACT*/

.foot-contact {
	display: block;
}
.foot-contact-box--- {
	width: 100%;
	padding: 8px 0;
}
	
.contact-tel {
	font-size: 24px;
}
	
/*FOOTER*/
	
.footer-nav {
}
.footer-nav div {
	padding: 0;
	width: 50%;
}

.footer-menu li {
	padding: 4px 0;
	font-size: 13px;
	line-height: 24px;
}
.footer-menu li ul li {
	font-size: 13px;
	line-height: 20px;
	padding: 0 0 4px 16px;
}
.footer-sns a {
	font-size: 13px;
}
.footer-bottom {
	display: block;
}

.copyright {
	text-align:right;
}
	
/*contents*/

.contents-image {
	margin: 8px 0 ;
}
.tit-en {
	display: block;
	font-size: 12px;
	color: #0282AB;
}
	
.contents-header01 {
}
.contents-header01 img{
    height: 150px;
}

.contents-header02 {
}
.contents-header02 img{
	height: 180px;
}
	
.contents-title {
	left: 5%;
    bottom: 0;
	background-position: left 16px top 50%;
	background-size: 32px auto; 
	padding: 8px 16px 8px 56px;
	border-radius: 50px;
	font-size: 20px;
}
	
/*リリーズについて*/
	
.aboutus-youtube {
	padding: 80px 16px 32px;
}
.column-method {
	display: block;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	padding: 8px 0;
}
.column-method-box {
	width: 100%;
	align-self: stretch;
}
	
.aboutus-column {
	background-image: url("images/bg-yakusoku.jpg");
	background-size:auto 100%;
	padding: 0;
}
.aboutus-column-box {
	padding: 8em 32px ;
}
.aboutus-column p {
	text-align: left;
	line-height: 1.8;
}

	
.aboutus-column img.gem-kenny-niji{
    left: 0;
    top: -88px;
    width: 100px;
}
.aboutus-column img.gem-jenny-heart{
    position: absolute;
    right: 0;
    bottom: 280px;
    width: 100px;
}

.aboutus-method img.gem-ian-lamp{
    left: 24px;
    top: -56px;
    width: 100px;
}
.aboutus-method img.gem-andy-haguruma{
    right: 0;
    top: 480px;
    width: 100px;
}
.aboutus-method img.gem-eve-flag{
    left: 0;
    bottom: -60px;
    width: 100px;
}

	
/*子ども英会話*/

.course-nav {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.course-nav-btn {
	width: 30%;
	margin: 0 4px 4px;
}
.course-nav-btn a {
	height: 88px;
	padding: 12px 8px 0 8px;
	background-size: 16px 16px;
	font-size: 14px;
}
.course-nav-btn a:hover {
	background-size: 16px 16px;
}
.course-nav-btn-others {
	width: 30%;
	margin: 0 4px 4px;
}
.course-nav-btn-others a {
	height: 88px;
	padding: 0 8px;
	font-size: 14px;
}

.course-box{
	display: block;
}

.course-box-img{
	width: 100%;
}
.course-box-img img {
	border-radius: 15px 15px 0 0;
}
.course-box-text{
	width: 100%;
	padding: 16px;
}

h3.course-title {
	display:flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items:flex-start;;
}
	
	
/*講師派遣*/

.okan-list li {
	margin:4px;
	width: 130px;
	height: 130px;
	background-size: 130px;
}

.triangle{
	 width: 250px;
}
	
/*先生育成*/

.column-tokucho {
	display:block;
}
.column-tokucho-box {
	width: 100%;
}

	
/*フロー*/
/***ステップバーデザイン***/
.step-wrap {
 margin: 2em 0;
}
.step-content {
 padding: 1.3em 0 .3em 1.5em;
 margin: 0 0 1em 0em;
}
.step-content::before {
 bottom: 0;
 left: 0;
 border-width: 14px 6px 0 6px;
}
.step-content::after {
 height: calc(100% - 30px);
 border-left: dotted 3px #B2ECFF;
 top: 16px;
 left: 5px;
}
/***ステップバーデザイン***/
	
	
/*生徒・保護者様へ*/

.information-menu li {
	width: 48%;
	margin: 2px;
}
.information-menu a {
	font-size: 13px;
}

	
}



/*******************************************************************************/




/*テーブル*/

.table1 th,.table1 td {
    border: 1px solid#D0D0D0;
    padding: 8px 16px;
	font-size: 15px;
}

.table1 th {
	text-align: left;
	font-weight: 900;
}

.table1 td {
	width: 70%;
	vertical-align: middle;
}
.teble-green {
	background: #EAFCE2;
}
 
table.table1 {
    border-collapse:  collapse; /* セルの線を重ねる */
	width: 100%;
	margin: 16px 0;
}

@media only screen and (max-width:640px){
	.table1 th,.table1 td {
    padding: 5px 5px;      /* 余白指定 */
}
}



dl.table2{
	display:flex;
	flex-wrap: wrap;
	border-top: none;
	margin: 0;
	line-height: 1.8em;
}
dl.table2 dt{
	width: 18%;
	padding: 16px 0 16px 24px;
	box-sizing: border-box;
	text-align: left;
	color: #333333;
	font-weight: 900;
	border-bottom: 1px dashed #D0D0D0;
}
dl.table2 dd{
	padding: 16px 24px 16px 0;
	margin: 0;
	width: 82%;
	box-sizing: border-box;
	border-bottom: 1px dashed #D0D0D0;
}
@media only screen and (max-width:640px){
  dl.table2{
    flex-flow: column nowrap;
	line-height: 1.5em;
  }
  dl.table2 dt,
  dl.table2 dd{
    width: 100%;
  }
  dl.table2 dt {
	border-bottom: none;
	  padding: 16px 0 0;
  }
  dl.table2　dd{
    border-left: none;
	  padding: 16px 0;
  }
}


dl.table3{
	margin: 0;
}
dl.table3 dt{
	padding: 16px 0;
	box-sizing: border-box;
	text-align: left;
	font-weight: 900;
}
dl.table3 dd{
	padding: 0 0 0 8px;
	margin: 0;
}




/*************
blog コンテンツ
*************/

.blog-side{
	background: #E5EBED;
	width: 100%;
	padding: 16px 0;
	border: #C7C7C7 solid 1px;
	border-radius: 48px;
	margin-bottom: 1em;
}
.list-blog {
	padding: 24px 0;
	display: flex;
	flex-wrap: wrap;
	gap: 20px; /* カード間の余白 */
}
.list-blog li {
	flex: 0 0 calc((100% - 40px) / 3);
	padding: 24px;
	border: solid 3px #333333;
	background-color: #fff;
	border-radius: 20px;
}
.list-blog-image {
	position: relative;
	width: 100%;/*　トリミングしたい枠の幅（固定にしたい場合はサイズを入力）　*/
	padding-top: 75%;/*　トリミングしたい枠の高さを比率で指定。（固定にしたい場合はサイズを入力）　*/
	margin: 0 auto;
}
.list-blog-image img {
/* 画像を上下左右に中央配置する（絶対指定） */
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
.list-blog time {
	display: block;
	text-align: right;
	font-size: 13px;
	color: #0282AB;
}
.list-blog-tag {
	margin-bottom: 8px;
}
.list-blog-tag span {
	color: #fff;
	font-size: 13px;
	padding: 0 8px;
	line-height: 24px;
	border-radius: 50px;
	display:  inline-block;	
	background-color: #0282AB;
	margin-right: 3px;
}
.list-blog p {
	font-weight: 900;
}


@media screen and (max-width: 768px) {
.list-blog {
	display: block;
	padding-right:0;
	margin-bottom: 1em;
}
.list-blog li {
		margin: 24px 0;
}
	
}


.more {
	text-align: right;
	padding: 20px 0;
}

.side-category-list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.side-category-list li+li{
    position: relative;
}
.side-category-list li+li::before{
    content: "";
    display: block;
    height: 1em;
    border-left: 1px solid #C7C7C7;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}
.side-category-list a {
	padding: 0 24px;
}




/*********pageナビ*********/
.pagenavi{
    color: #331a08;
    margin: 1em auto 5em auto;
    line-height:2em;
    text-align:center;
    clear: both;
}
.pagenavi a{
    text-decoration:none;
}
.pagenavi a.page-numbers, .pagenavi .current{
    color: #331a08;
    padding: 6px 10px;
	background: #cccccc;
    text-decoration:none;
    font-size:12px;
}
.pagenavi a.page-numbers:hover{
    color:#fff;
    background: #1097C4;
}
.pagenavi .current{
    color: white;
    background: #1097C4;
    font-weight:bold;
}
.pagenavi .next, .pagenavi .prev{
    border:0 none;
    background:transparent;
    text-decoration:none;
    font-size:13px;
    font-weight:bold;
}


.blog__ time {
	display: block;
	text-align: right;
	font-size: 13px;
	color: #0282AB;
}
.blog__ a {
	color: #1097C4;
	text-decoration: underline;
}
.blog__ a:hover {
	color: #cccccc;
	-webkit-transition: all .5s;
  transition: all .5s;
}

.blog__ {
	margin: 2em auto;
	width: 72%;
}
@media only screen and (max-width:1024px){
.blog__ {
	margin: 0 auto;
    width: 100%;
}
}

.blog__ p{
	margin: 1.5em 0;
}
.blog__ img{
	margin: 1em 0;
}


/*postナビ*/
.pager {
	padding: 5em 0 ;
		}
.pager-btn {
}
.pager-btn a {
	background: #cccccc;
    padding: .5em 1em;
	color: #331a08;
	text-decoration: none;
	border-bottom: none;
}
.pager-btn a:hover {
	background: #1097C4;
    padding: .5em 1em;
	color: #fff;
}

.pager ul.pager-nav {
	display:flex;
    justify-content: center;
}
.pager ul.pager-nav li {
	margin: 0 2px;
}
.to-prev, .to-next {
	
}


@media only screen and (max-width:640px){
	
/*postナビ*/
.pager {
	padding: 5em 0 0 ;
		}

.pager ul.pager-nav {
	display: block;
}
.pager ul.pager-nav li {
	margin: 10px 0;
	text-align: center;
	
}
.pager-btn a {
	width: 100%;
	display: block;
}
	
.to-prev, .to-next {
	
}
	
}

