@charset "utf-8";

/*
Theme Name: THETA
Author: minoru kubota
Version: 1.11
*/

/*
----------------------------------------
reset
----------------------------------------
*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

body {
	line-height: 1;
}

p,div,dt,dd,li{
	font-size:1.6rem;
	/*letter-spacing:1px;*/
	line-height:2.1;
	font-weight: 300;

	word-wrap: break-word;
	overflow-wrap: break-word;
}
/*
.vi .contents section p,
.pt .contents section p,
.en .contents section p,
.zh .contents section p,
.ko .contents section p{
	font-size:1.5rem;
	line-height:1.8;
}
*/
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
	display: block;
}

nav ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote: before, blockquote:after,
q: before, q:after {
	content: '';
	content: none;
}

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
a:active img,
a:hover img{
	opacity:.7;
}
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor:help;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}

input, select {
	vertical-align: middle;
}

figure img{
	vertical-align: middle;
}


	.pc-none {
		display: none;
	}

	.sp-none {
		display: block;
	}
	img.sp-none {
		display: inline-block;
	}


/*
----------------------------------------
common
----------------------------------------
*/

.left {
	text-align: left;
}

.center {
	text-align: center;
}

.right {
	text-align: right;
}

.video {
	max-width: 800px;
	margin: 30px auto;
}

.youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

.pc-none {
	display: none;
}

/* clearfix */

.clearfix: before,
.clearfix:after {
	display: table;
	content: ' ';
}

.clearfix:after {
	clear: both;
}

/* scrollbar */

::-webkit-scrollbar {
	width: 5px;
	background: transparent;
}

::-webkit-scrollbar-track {
	box-shadow: none;
}

::-webkit-scrollbar-thumb {
	background-color: #ccc;
	box-shadow: none;
}

/*
----------------------------------------
default
----------------------------------------
*/

html {
	font-size: 62.5%;
}

body {
	font-size: 1.4rem;
	line-height: 2;
	font-family: Hiragino Sans, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', '游ゴシック', YuGothic, sans-serif;
	text-align: center;
	position: relative;
	min-width: 300px;
	-webkit-text-size-adjust: 100%;
	overflow-scrolling: touch;
}

body.vi{
	font-family:Times New Roman,Hiragino Sans, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo',  '游ゴシック', YuGothic, sans-serif;
}
body.pt{
	font-family: sans-serif, Hiragino Sans, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', '游ゴシック', YuGothic, sans-serif;
}
body.ko{
	font-family: "Gulim", Hiragino Sans, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', '游ゴシック', YuGothic, sans-serif;
}
body.zh{
	font-family: "SF Pro SC","SF Pro Text","SF Pro Icons","PingFang SC",'Segoe UI',SegoeUI,'Microsoft YaHei',微软雅黑,"Helvetica Neue",Helvetica,Arial,sans-serif;
}
body.th{
	font-family: 'Sarabun', "Arial", "Tahoma", "Trebuchet MS", sans-serif;
}

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

ul, ol {
	list-style: none;
	margin: 0;
}

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

.ofi img {
	object-fit: cover;
	font-family: 'object-fit: cover;' /* ie */
}

div.wpcf7 .ajax-loader {
	display: none !important;
}

.lightboxOverlay {
	z-index: 999999 !important;
}

.lightbox {
	z-index: 1000000 !important;
}

/*
----------------------------------------
form
----------------------------------------
*/

input[type=text],
input[type=search],
input[type=tel],
input[type=number],
input[type=url],
input[type=email],
input[type=password],
input[type=date],
textarea, select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-size: 1.6rem;
	border: solid 1px #ccc;
	padding: 10px 15px !important;
	box-sizing: border-box;
	margin-right: 10px;
	text-align: left !important;
}

input[type=email],
input[type=tel],
input.l {
	width: 100%;
	margin: 0 !important;
}


textarea {
	margin: 0 !important;
	width: 100% !important;
	height: 20rem !important;
}

select {
	padding: 7px 35px 7px 15px !important;
	background: url( img/common/arrow-select.svg ) right 10px center / 10px no-repeat !important;
}


/*
----------------------------------------
flex
----------------------------------------
*/

.flex {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
}

.flex.nowrap {
	flex-wrap: nowrap;
}

.flex.reverce,
.flex.reverse {
	flex-direction: row-reverse;
}

.flex.item-center {
	align-items: center;
}


#contents .flex-box-02{
}

#contents .flex-box-02 > div {
	width: 50%;
	/*overflow: hidden;*/
	padding:20px 50px 20px 0;
}

#contents .flex-box-02.reverse > div {
	padding:20px 0 20px 50px;
}

#contents .flex-box-02 > .figure figure{
	margin:0;
}

	#contents .flex-box-02 > .figure {
		overflow: visible;
		padding:0;
		overflow: hidden;
		width: 54%;
		margin-right: -4%;
	}
	#contents .flex-box-02.reverse > .figure {
		margin-right: 0;
		padding: 0;
		margin-left: -4%;
	}

#contents .flex-box-02 > .figure figure img{
	width: 120%;
	max-width: 120%;
}

#contents .flex-box-02{
	max-width:1180px;
	margin:0 auto;
	padding-bottom:0;
	flex-wrap: wrap;
	justify-content: space-between;
	align-content: space-between;
	box-sizing: border-box;
}

/* column */

.contents .flex > * {
	box-sizing: border-box;
	padding: 10px;
	box-sizing: border-box;
}

.flex.col-02 > * {
	width: 50%;
}

.flex.col-03 > * {
	width: 33.3333%;
}

.flex.col-04 > * {
	width: 25%;
}

.flex.col-05 > * {
	width: 20%;
}

.flex.col-06 > * {
	width: 16.6666%;
	font-size: 1.3rem;
}

.flex figure {
	margin-bottom: 5px;
}
/* column */

.flex .box.pic {
	width: 44%;
	padding: 0 20px 0 0;
	box-sizing: border-box;
	text-align: center;
}

.flex.reverce .box.pic {
	padding: 0 0 0 20px;
}

.flex .box.txt {
	width: 56%;
	box-sizing: border-box;
	padding: 0;
	margin-bottom: 5px;
}

#contents .flex .box.txt h1,
#contents .flex .box.txt h2,
#contents .flex .box.txt h3 {
	font-size: 2rem;
}


/*
----------------------------------------
font
----------------------------------------
*/
/*
.en {
	font-family: 'Roboto', sans-serif;
}
*/
.gothic {
	font-family:'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo',  '游ゴシック', YuGothic, sans-serif;
}

.mincho {
	font-family: ’ヒラギノ明朝 ProN W3’, ’Hiragino Mincho ProN’, ’游明朝’, YuMincho, ’ＭＳ Ｐ明朝’, ’ＭＳ 明朝’, serif;
}

strong {
	font-weight: normal;
}

.Montsterrat,
.Montserrat{
	font-style:normal;
	font-family: 'Montserrat', sans-serif;
}

.Caveat{
	font-weight:700;
	font-style:italic;
	font-family: 'Caveat', cursive;
}

.Helvetica{
	font-style:normal;
	font-family: 'Helvetica', sans-serif;
}

.Nunito{
	font-weight:600;
	font-style:normal;
	font-family: 'Nunito', sans-serif;
}

/*
----------------------------------------
h1-h6
----------------------------------------
*/

h1, h2, h3, h4, h5, h6 {
	font-weight: normal;
	line-height: 1.6;
}

.contents h1,
.contents h2,
.contents h3,
.contents h4,
.contents h5,
.contents h6 {
	margin-bottom: 15px;
}

.contents h1 {
	font-size: 2.4rem;
}

.contents h2 {
	font-size: 2.2rem;
}

.contents h3 {
	font-size: 2rem;
}

.contents h4,
.contents h5,
.contents h6 {
	font-size: 1.8rem;
}

/* heading-01 */

.contents .heading-01 i{
	font-size:1.8rem;
	color:#a50021;
	letter-spacing:2px;
	display:block;
	margin-bottom:5px;
	font-style:normal;
	font-weight:500;
	z-index:1;
}

.contents .heading-01 {
	text-align:center;
	font-size:3.6rem;
	font-weight:500;
	z-index:1;
	position:relative;
	min-height: 178px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	overflow:hidden;
	line-height: 1.6;
	margin-bottom:20px;
}

.contents .heading-01 span{
	display: inline-block;
	z-index:2;
	position:relative;
	min-width: 178px;
	max-width: 770px;
}

.contents .heading-01 span::before,
.contents .heading-01 span::after {
	content: "";
	width: 42%;
	height: 100%;
	background: #fff;
	position: absolute;
	z-index: -1;
	top:0;
}

.contents .heading-01 span::before {
	left: 50%;
	margin-left: 79px;
}

.contents .heading-01 span::after {
	right: 50%;
	margin-right: 79px;
}

.contents .heading-01::before{
	width: 100%;
	height: 21px;
	content: "";
	position: absolute;
	top: 50%;
	left:0;
	background: url(img/common/bg-02.png) repeat-x center;
	z-index: -1;
	margin-top:-10px;
}

.contents .heading-01::after {
	width: 172px;
	height: 138px;
	margin: -69px 0 0 -86px;
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	background: #fff url(img/svg/book-open.svg) no-repeat 50% 50% / contain;
	z-index: -1;
}

/* heading-02 */

.contents .heading-02 i{
	font-size:1.8rem;
	color:#a50021;
	letter-spacing:2px;
	display:block;
	margin-bottom:5px;
	font-style:normal;
	font-weight:500;
}

.contents .heading-02 {
	font-size:3.6rem;
	font-weight:500;
	line-height:1.5;
	margin-bottom:20px;
}

/* heading-03 */

.contents .heading-03 span{
	display:block;
	margin-bottom:20px;
}

.contents .heading-03 em {
	display: inline-block;
	background: #fff8f5;

	vertical-align: middle;
	padding: 5px 1em;
	font-style: normal;
	line-height: 1.5;
}

.contents .heading-03 i{
	font-size:1.8rem;
	color:#a50021;
	letter-spacing:2px;
	display:inline-block;
	margin-bottom:5px;
	font-style:normal;
	font-weight:500;
	z-index:1;
	position:relative;
	border-bottom: 2px solid #a50021;
	line-height: 1.2;
	padding: 0 9px;
}

.contents .heading-03 i::after {
	content: "";
	position: absolute;
	bottom: -6px;
	left:5%;
	width:90%;
	height:2px;
	background:#a50021;
	box-sizing: border-box;
}

.contents .heading-03 {
	text-align:center;
	font-size: 3.6rem;
	font-weight:500;
	margin-bottom:20px;
}


/* heading-04 */


.contents .heading-04{
	font-size:3.6rem;
	font-weight:500;
	margin-bottom:20px;
}

.contents .heading-04 span{
	display:block;
	margin-bottom:12px;
}

.contents .heading-04 i{
	font-size:2.4rem;
	color:#a50021;
	letter-spacing:2px;
	display:inline-block;
	margin-bottom:5px;
	font-style:normal;
	font-weight:500;
	z-index:1;
	position:relative;
	border-bottom: 2px solid #a50021;
	line-height: 1.5;
	padding: 0 .5em;
}

.contents .heading-04 i::after {
	content: "";
	position: absolute;
	bottom: -6px;
	left:0;
	width:100%;
	height:2px;
	background:#a50021;
	border-right: .5em solid #fff;
	border-left: .5em solid #fff;
	box-sizing: border-box;
}


/* heading-05 */

.contents .heading-05 i{
	font-size:4.2rem;
	color:#a50021;
	letter-spacing:2px;
	display:block;
	margin-bottom:5px;
	font-style:normal;
	font-weight:500;
}

.contents .heading-05 span {
	display: block;
	position: relative;
	top: -.6em;
	width: 100%;
	height: 1em;
	line-height: 1;
	font-size: 4.8rem;
	color: #a50021;
	z-index: 1;
	transform: rotate(-8deg);
	letter-spacing: 0;
	left: -.75em;
	margin-bottom: 20px;
}

.contents .heading-05 span i {
	font-weight: 400;
	font-style: italic;
	background: linear-gradient(transparent 93%, #a50021 0%);
	display: inline-block;
	line-height: 1.2;
}

.contents .heading-05 {
	font-size:3.6rem;
	font-weight:500;
	margin-bottom:20px;
}

.vi .contents .heading-05 {
	font-size: 2.6rem;
	font-weight: 500;
	line-height: 1.3;
}

/* heading-06 */

.contents .heading-06{
	text-align:center;
	position:relative;
	margin:0 auto 20px;
	font-size:2.8rem;
}

.contents .heading-06 span{
	display: inline-block;
	z-index:2;
	position:relative;
	background:#fff;
	padding:0 1.2em;
	line-height: 1.5;
}

.contents .heading-06 span.bg{
	background:#fff8f5;
}

.contents .heading-06::before{
	width: 100%;
	height: 21px;
	content: "";
	position: absolute;
	top: 50%;
	left:0;
	background: url(img/common/bg-02.png) repeat-x center;
	z-index: 1;
	margin-top:-10px;
}



/*
----------------------------------------
button
----------------------------------------
*/

.btn-01 a,
.btn-02 a,
.btn-03 a {
	text-decoration: none;
	transition: all .2s;
}

.btn-01 a {
	display: inline-block;
	border: solid 1px #a50021;
	background: #a50021;
	color: #fff;
	border-radius: 3em;
	text-align: center;
	font-size: 1.8rem;
	letter-spacing: 1px;
	padding: 15px 1em 15px 2.5em;
	position: relative;
	width: 100%;
	box-sizing: border-box;
	max-width:390px;
	line-height:1.5
}

.btn-01.small a {
	font-size: 1.6rem;
	padding: 5px 1em 5px 2em;
	width: inherit;
	min-width: 320px;
}

.btn-01.shadow a {
	box-shadow:0px 3px 4px 1px rgba(0,0,0,.2);
}
/*
.btn-01 a:before {
	content:"";
	width:17px;
	height:17px;
	background:url(img/svg/caret-circle-right.svg) no-repeat 50% 50% / contain;
	display:inline-block;
	margin:-4px 12px 0 0;
	vertical-align:middle;
	position:relative;
	transition:all .4s;
}
*/
.btn-01 a::before {
	content: "";
	width: 1.7rem;
	height: 1.7rem;
	background: url(img/svg/caret-circle-right.svg) no-repeat 50% 50% / contain;
	display: inline-block;
	margin: -4px 12px 0 0;
	vertical-align: middle;
	position: absolute;
	transition: all .4s;
	top: 50%;
	margin-top: -.5em;
	left: 1em;
}

.btn-01.small a:before {
	width:1.5rem;
	height:1.5rem;
	margin:-3px 5px 0 0;
}

.btn-01 a:hover:before {
	left:1.2em;
}

.btn-01 a:hover:after {
	right: 10px;
}

.btn-02{
	position:relative;
	height: 54px;
	z-index:1;
}

.btn-02 a{
	font-size: 1.8rem;
	background:#fff;
	position:relative;
	border-radius:2em;
	transition: all .4s;
	height: 100%;
	width: 100%;
	align-items: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	box-shadow:0 1px 0 1px #e5dfdc;
}

.btn-02 a:hover{
	top: 4px;
	box-shadow:none;
}

.btn-03 a {
	display: inline-block;
	padding: 5px 30px 5px 10px;
	margin: 10px 0;
	background: url( img/common/arrow-right.svg ) right 10px center / 8px no-repeat;
	border-bottom: solid 2px #000;
	position: relative;
	transition: all .2s;
}

.btn-03 a:hover {
	background: url( img/common/arrow-right.svg ) right 5px center / 8px no-repeat;
}

.back-btn a {
	display: inline-block;
	letter-spacing: 3px;
	padding: 15px 30px 15px 40px;
	border: solid 1px #000;
	background: url( img/common/arrow-left.svg ) 15px center / 8px no-repeat;
	transition: all .2s;
}

.back-btn a:hover {
	color: #fff;
	background: #000 url( img/common/arrow-left-wh.svg ) 10px center / 8px no-repeat;
}

.back-btn a:hover:after {
	right: 10px;
}


/*
----------------------------------------
table
----------------------------------------
*/

table caption {
	caption-side: bottom;
	padding-top: 15px;
	font-size: 1.3rem;
}

/* table-01 */

.table-01 {
	width: 100%;
	text-align: left;
	border-top: solid 1px #ccc;
	border-left: solid 1px #ccc;
	margin: 0 0 30px;
}

.table-01 thead th,
.table-01 thead td {
	color: #fff;
	background: #000;
	text-align: center;
}

.table-01 th {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	background: #f9f9f9;
	font-weight: normal;
	vertical-align: top;
}

.table-01 td {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	vertical-align: top;
}

/* table-02 */

.table-02 {
	width: 100%;
	text-align: left;
	border-top: solid 1px #ccc;
	margin: 30px 0;
}

.table-02 caption {
	font-size: 1.8rem;
	caption-side: top;
	background: #faf9f2;
	border-top: 1px solid #ccc;
	line-height: 1.5;
	padding: 10px 12px;
}

.table-02 th {
	width:25%;
	padding: 15px 25px;
	border-bottom: solid 1px #ccc;
	font-weight: normal;
}

.table-02 td {
	width:75%;
	/*text-align:right;*/
	padding: 15px 10px;
	border-bottom: solid 1px #ccc;
}


/*
----------------------------------------
list
----------------------------------------
*/

ul.list {
	list-style: disc;
	margin-left: 20px;
}

ol.list {
	list-style: decimal;
	margin-left: 20px;
}


/*
----------------------------------------
dl
----------------------------------------
*/

.dl-01 {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 10px 0 0 0;
}

.dl-01 dt {
	width: 20%;
	font-size: 1.1rem;
	line-height: 2rem;
	text-align: center;
	background: #222;
	color: #fff;
	margin-bottom: 10px;
}

.dl-01 dd {
	width: 77%;
	margin-bottom: 10px;
	line-height: 2rem;
}

.faq-01 dt {
	font-size: 2rem;
	padding: 30px 0 15px 5rem;
	border-top: solid 1px #ccc;
	position: relative;
}

/* faq */

.faq-01 dd {
	font-size: 1.5rem;
	padding: 15px 0 30px 5rem;
	position: relative;
}

.faq-01 dt:before,
.faq-01 dd:before {
	display: inline-block;
	font-size: 1.4rem;
	font-family: 'Roboto', sans-serif;
	text-align: center;
	line-height: 3.5rem;
	width: 3.5rem;
	height: 3.5rem;
	position: absolute;
	left: 0;
}

.faq-01 dt:before {
	content: 'Q';
	color: #fff;
	background: #000;
	top: 28px;
}

.faq-01 dd:before {
	content: 'A';
	background: #ddd;
	top: 10px;
}


/*
----------------------------------------
map
----------------------------------------
*/

.map {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}

.map iframe,
.map object,
.map embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


/*
----------------------------------------
layout
----------------------------------------
*/

#wrapper {
	width: 100%;
	margin: 0 auto;
}

.wrap {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 15px;
	box-sizing: border-box;
}

#sp-btn {
	display: none;
}

#overlay {
	display: none;
}


/*
----------------------------------------
header
----------------------------------------
*/

#wrapper > header .h1-cont {
	background: #a50021;
}

#wrapper > header h1,
#wrapper > header .h1-cont a {
	color:#fff;
}

#wrapper > header .h1-cont ul li {
	margin:5px 0 5px 1em;
}

#wrapper > header .h1-cont ul li a{
	display:block;
	padding:0 1em;
	border-radius:2em;
	font-size: 1.4rem;
	line-height: 1.5;
	font-family: Arial,sans-serif;
}

#wrapper > header .h1-cont ul li.current-lang a,
#wrapper > header .h1-cont ul li a:hover {
	background: #730017;
}

#wrapper > header h1 {
	display: block;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	text-align: left;
	font-family: 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', '游ゴシック', YuGothic, sans-serif;
	padding: 0 15px;
	font-size: 1.3rem;
	 -webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
}

#wrapper > header .wrap {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#wrapper > header .wrap .flex {
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
}

#wrapper > header .identity {
	margin-right: 20px;
	max-width: 240px;
	line-height: .5;
}

#wrapper > header .h-cont {
	margin-right: auto;
	text-align: left;
}

#wrapper > header .h-tel {
	margin-left: 20px;
	max-width: 240px;
	line-height: .5;
}


/*
----------------------------------------
g-nav
----------------------------------------
*/

#g-nav {
	background: #fff;
	z-index: 999999;
	padding: 0 ;
	width:55%;
}

#g-nav.fixed {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width:100%;
}

#g-nav > ul.wrap {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-around;
	padding: 0;
}

#g-nav > ul > li {
	flex-grow: 1;
	position: relative;
	height:85px;
	width:25%;
}

#g-nav > ul > li > a i{
	display:none;
}

#g-nav > ul > li > a {
	display: block;
	padding: 15px 5px;
	box-sizing: border-box;
	transition: all .2s;
	font-size:1.6rem;
	position:relative;
	height:100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	line-height:1.2;
}

.en #g-nav > ul > li > a,
.vi #g-nav > ul > li > a,
.pt #g-nav > ul > li > a,
.ko #g-nav > ul > li > a{
	font-size:1.4rem;
}

#g-nav > ul > li.current a:after,
#g-nav > ul > li > a:hover:after {
	content:"";
	width:50%;
	height:3px;
	position:absolute;
	left:25%;
	bottom:0;
	background:#a50021;
}

#g-nav > ul > li:before{
	content:"";
	width:1px;
	height:50%;
	position:absolute;
	top:25%;
	left:0;
	background:#e0e0e0;
}

#g-nav > ul > li:first-child:before {
	display:none;
}

#g-nav > ul > li > a:before {
	content:"";
	width:17px;
	height:17px;
	display:block;
	margin:0 auto;
}

#g-nav > ul > li.introduce > a:before{
	background:url(img/svg/book.svg) no-repeat 50% 50% / contain;
}

#g-nav > ul > li.school > a:before{
	width:20px;
	height:20px;
	background:url(img/svg/school.svg) no-repeat 50% 50% / contain;
}

#g-nav > ul > li.teacher > a:before{
	width:22px;
	height:22px;
	background:url(img/svg/chalkboard-teacher.svg) no-repeat 50% 50% / contain;
}

#g-nav > ul > li.contact > a:before{
	background:url(img/svg/envelope-open-text.svg) no-repeat 50% 50% / contain;
}


#g-nav > ul > li.introduce.current > a:before{
	background:url(img/svg/book-red.svg) no-repeat 50% 50% / contain;
}

#g-nav > ul > li.school.current > a:before{
	background:url(img/svg/school-red.svg) no-repeat 50% 50% / contain;
}

#g-nav > ul > li.teacher.current > a:before{
	background:url(img/svg/chalkboard-teacher-red.svg) no-repeat 50% 50% / contain;
}

#g-nav > ul > li.contact.current > a:before{
	background:url(img/svg/envelope-open-text-red.svg) no-repeat 50% 50% / contain;
}


#g-nav > ul > li.current a {
	color: #a50021;
}



/* sub-menu */

#g-nav li ul {
	min-width: 100%;
	position: absolute;
	top: 90%;
	left: 0;
	background: #f7f7f7;
	visibility: hidden;
	opacity: 0;
	z-index: 999999;
	transition: all .2s;
}

#g-nav li:last-child ul {
	right: 0;
	left: auto;
}

#g-nav li:hover ul {
	top: 100%;
	visibility: visible;
	opacity: 1;
}

#g-nav li ul li {
	border-top: solid 1px #ccc;
}

#g-nav li ul a {
	display: block;
	padding: 15px 20px;
	text-align: left;
	white-space: nowrap;
	transition: all .2s;
}


/*
----------------------------------------
contents
----------------------------------------
*/

#contents {
	text-align: left;
	margin-top: 20px;
	/*padding-bottom: 60px; */
	overflow: hidden;
}

#main-contents {
	width: 75%;
	padding: 0 40px 0 0;
	box-sizing: border-box;
	margin-bottom: 30px;
}

#head-contents {
	margin: 20px 0;
	text-align: left;
}


/*
----------------------------------------
sidebar
----------------------------------------
*/

#sidebar {
	width: 25%;
}

#sidebar > .search-form {
	margin: 0 0 30px 0;
	position: relative;
}

.search-form form {
	background: #eee;
	position: relative;
}

.search-form input[type='text'] {
	display: block;
	width: 100%;
	padding: 0 3rem 0 0;
	box-sizing: border-box;
	font-size: 1.8rem;
	line-height: 2rem;
	border: none;
	background: transparent;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.search-form button {
	border: none;
	outline: none;
	cursor: pointer;
	padding: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: block;
	width: 40px;
	height: 100%;
	background: url( img/common/icon-search.svg ) center center / 16px no-repeat;
	text-indent: -999px;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 0;
}

#sidebar .back-link {
	margin-bottom: 30px;
}

#sidebar .back-link a {
	display: block;
	padding: 15px;
	font-size: 1.6rem;
	text-align: center;
	background: url( img/common/arrow-left.svg ) 15px center / 8px no-repeat;
	border: solid 1px #ccc;
	transition: all .2s;
}

#sidebar .back-link a:hover {
	background: #000 url( img/common/arrow-left-wh.svg ) 10px center / 8px no-repeat;
	color: #fff;
}

#sidebar .bnr {
	margin-bottom: 40px;
}

#sidebar .bnr figure {
	margin-bottom: 10px;
}

#sidebar .bnr figcaption {
	text-align: left;
}

#sidebar > div {
	margin-bottom: 15px;
}

#sidebar h2 {
	font-size: 1.6rem;
	border-bottom: solid 2px #000;
	padding-bottom: 5px;
	margin-bottom: 0;
	position: relative;
}

#sidebar h2 .en {
	font-size: 1.4rem;
	position: absolute;
	right: 0;
	bottom: 5px;
}

#sidebar .rank-list {
	margin: 5px 0 40px;
}

#sidebar .rank-list a {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	padding: 20px 0 10px 15px;
	border-bottom: solid 1px #ccc;
	position: relative;
	transition: all .2s;
}

#sidebar .rank-list a::before {
	display: inline-block;
	width: 3rem;
	height: 3rem;
	border-radius: 1.5rem;
	line-height: 3rem;
	color: #fff;
	text-align: center;
	content: '';
	position: absolute;
	left: 0;
	top: 5px;
}

#sidebar .rank-list a:first-child::before {
	content: '1';
	background: #D9B036;
}

#sidebar .rank-list a:nth-child(2)::before {
	content: '2';
	background: #B6B9BF;
}

#sidebar .rank-list a:nth-child(3)::before {
	content: '3';
	background: #CC8033;
}

#sidebar .rank-list figure {
	width: 25%;
	line-height: 1;
	margin-bottom: 0;
}

#sidebar .rank-list .txt {
	width: 75%;
	padding-left: 15px;
	box-sizing: border-box;
	font-size: 1.2rem;
}

#sidebar .rank-list time {
	color: #777;
}

.views-count {
	display: inline-block;
	padding: 0 1rem;
	box-sizing: border-box;
	margin-left: 5px;
	background: #eee;
	line-height: 2.4rem;
	border-radius: 1.2rem;
}

#sidebar .rank-list .ttl {
	font-size: 1.4rem;
	line-height: 1.6;
}

.menu-list > ul {
	margin-bottom: 40px;
}

.menu-list > ul > li {
	border-top: solid 1px #ccc;
}

.menu-list li li {
	border-top: solid 1px #ccc;
}

.menu-list a {
	display: block;
	padding: 10px 35px 10px 10px;
	line-height: 1.6;
	position: relative;
	transition: all .2s;
	background: url( img/common/arrow-right.svg ) right 15px center / 8px no-repeat;
	transition: all .2s;
}

.menu-list li li a:before {
	content: '-';
	margin-right: 10px;
}

.menu-list.box-menu {
	border: solid 1px #ccc;
	padding: 15px;
}

.menu-list.box-menu ul {
	margin-bottom: 0;
}


/*
----------------------------------------
footer
----------------------------------------
*/

.bottom-contents{
	border-top: solid 1px #ccc;
	padding: 30px 20px;
}

footer {
	background: #f5f5f5;
  padding: 0 0 160px;
}

footer .wrap {
	text-align: left;
	padding: 30px 20px;
}

footer .footer-contents{
	justify-content: space-between;
}

footer .store-info {
	width: 32%;
}

footer .store-info dl *{
	display:inline-block;
}

footer .store-info dl dt:after {
	content:"：";
}

footer .store-info *{
	font-size:1.2rem;
}

footer #bottom-nav {
	width: 65%;
	box-sizing: border-box;
}

footer #bottom-nav h2 {
	font-size: 1.8rem;
	border-bottom: solid 1px #000;
	padding-bottom: 5px;
	margin-bottom: 15px;
}

footer #bottom-nav .bottom-menu {
	margin: 0 0 20px;
	justify-content: flex-start;
	clear:both;
}

footer #bottom-nav .bottom-menu > li.introduce {
	width: 75%;
}

footer #bottom-nav .bottom-menu > li {
	float:left;
	width:25%;
	margin-bottom: 1em;
	font-size: 1.7rem;
}
/*
footer #bottom-nav .bottom-menu > li > a {
	padding-left: 1rem;
	position: relative;
	background: url( img/common/arrow-right.svg ) left 5px / 6px no-repeat;
}
*/
footer #bottom-nav li li a {
	display: inline-block;
	font-size: 1.2rem;
	margin-left: 1rem;
	text-decoration: underline;
}

footer #bottom-nav .sub-menu {
	margin-bottom: 1.5rem;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: flex-start;
}
footer #bottom-nav .bottom-menu > li > a::before {
	content: "";
	width: .8em;
	height: .8em;
	background: url(img/svg/caret-circle-right-red.svg) no-repeat 50% 50% / contain;
	display: inline-block;
	margin: -.2em .5em 0 0;
	vertical-align: middle;
	position: relative;
	transition: all .4s;
}
footer #bottom-nav li li{
	margin-top: 1em;
	width: 50%;
}
footer #bottom-nav li li a:before{
	content:"";
	width:5px;
	height:5px;
	display:inline-block;
	background:#a50021;
	border-radius:100%;
	vertical-align:middle;
	margin: -.2em .5em 0 0;
}
footer #bottom-nav li li a{
	display: inline-block;
	font-size:1.6rem;
	margin-left: 0;
	padding-left:3px;
	text-decoration: none;
}

.copyright {
	background: #730017;
	color: #fff;
	padding: 15px 15px;
}

.copyright small {
	font-size: 1.1rem;
}

.copyright small span{
	display:block;
}

.copyright a {
	color: #fff;
}

#bottom-fix {
/*
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	align-items: center;
	justify-content: space-between;
*/
position: fixed;
right: 20px;
bottom: 164px;
z-index: 999999;
}

	#bottom-fix .contact-box{
		display:none;
	}

/*
#bottom-fix .tel,
#bottom-fix .mail {
	display: none;
}

#bottom-fix .mail a{
	display: block;
	width: 40px;
	height: 40px;
	padding: 12px;
	box-sizing: border-box;
	background: #000;
	color: #fff;
	text-align: center;
	line-height: 16px;
	transition: all .4s;
}

#bottom-fix .mail a {
	font-size: 2rem;
	background: #777;
}

#bottom-fix .mail a:hover {
	background: #999;
}
*/
#page-top a {
	display: block;
	transition: all .4s;
	position:relative;
	z-index:10000;
}

#page-top a:hover {
	transition: all .4s;
	top:-3px;
}

#contact #page-top {
	display: none;
}

div#bottom-contact {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	height: 160px;
	background: #fffaf8 url(img/common/btm-contact-bg_dot.png);
	z-index: 99999;
}

div#bottom-contact .wrap {
	position: relative;
	height: 160px;
}

div#bottom-contact .wrap .contact_fig {
	position: absolute;
	left: -35px;
	top: -109px;
}

.ja div#bottom-contact.pc .wrap .contact_fig img {
	width: 970px;
}
.en div#bottom-contact.pc .wrap .contact_fig img {
	width: 987px;
}
.ko div#bottom-contact.pc .wrap .contact_fig img {
	width: 970px;
}
.pt div#bottom-contact.pc .wrap .contact_fig img {
	width: 985px;
}
.th div#bottom-contact.pc .wrap .contact_fig img {
	width: 981px;
}
.vi div#bottom-contact.pc .wrap .contact_fig img {
	width: 991px;
}
.zh div#bottom-contact.pc .wrap .contact_fig img {
	width: 958px;
}

div#bottom-contact .wrap .mail {
	position: absolute;
	width: 220px !important;
	right: 15px;
	bottom: 45px;
	margin: auto;
	height: 78px;
}

div#bottom-contact .wrap .mail span {
	padding: 18px 32px;
	position: absolute;
	background: #FFF;
	color: #333;
	border-radius: 5px;
	top: -50px;
	border-bottom: 3px solid #004139;
	font-size: 18px;
	color: #007769;
	font-weight: 600;
	z-index: 3;
}

div#bottom-contact .wrap .mail span::before {
	content: "";
	position: absolute;
	background: #FFF;
	top: 40px;
	bottom: 0;
	right: 0;
	left: 0;
	z-index: 2;
		border-radius: 5px;
}

div#bottom-contact .wrap .mail span::after {
	content: "";
	position: absolute;
	bottom: -10px;
	left: 50%;
	margin-left: -15px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	background: #FFF;
	width: 16px;
	height: 16px;
	border: 3px solid #004139;
}

div#bottom-contact .wrap .tagline::after {
	content: "";
	background: #fffaf8 url(img/common/btm-contact-ttldec-r.png) 17px 32px / cover;
	width: 17px;
	height: 32px;
	position: absolute;
	right: -28px;
	top: 4px;
}

div#bottom-contact .wrap .tagline::before {
	content: "";
	background: #fffaf8 url(img/common/btm-contact-ttldec-l.png) 17px 32px / cover;
	width: 17px;
	height: 32px;
	position: absolute;
	left: -28px;
	top: 4px;
}

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

.new span {
	display: inline-block;
	padding: 2px 12px;
	background: #000;
	color: #fff;
	font-size: 1.2rem;
	margin: 0 10px 5px 0;
}

.cat-list {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
}

.cat-list li {
	margin: 0 5px 5px 0;
}

.cat-list a {
	display: inline-block;
	padding: 2px 12px;
	background: #bbb;
	color: #fff;
	font-size: 1.2rem;
	border-radius: 4px;
	transition: all .4s;
}

.cat-list a:hover {
	background: #000;
}

.post-header .views-count {
	margin-bottom: 5px;
}

.post .post-contents .more {
	text-align: right;
	margin-bottom: 0;
}

.post .more a {
	display: inline-block;
	padding: 5px 30px 5px 10px;
	background: url( img/common/arrow-right.svg ) right 10px center / 8px no-repeat;
	border-bottom: solid 2px #000;
	position: relative;
	transition: all .2s;
}

.post .more a:hover {
	background: url( img/common/arrow-right.svg ) right 5px center / 8px no-repeat;
}

/* post-header */

.post .post-header {
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	padding: 20px 0;
	margin-bottom: 30px;
}

.post .post-header > .flex {
	margin-bottom: 5px;
	align-items: center;
}

.post .post-header > .flex > * {
	padding: 0;
}

.post .post-header h1,
.post .post-header h2 {
	line-height: 1.4;
	margin-bottom: 5px;
}

/* post-contents */

.post .post-contents h1,
.post .post-contents h2,
.post .post-contents h3,
.post .post-contents h4,
.post .post-contents h5,
.post .post-contents h6 {
	border-bottom: solid 1px #ccc;
	padding: 0 0 10px 0;
	margin-bottom: 20px;
}

.post .post-contents p,
.post .post-contents a {
	font-size: 1.5rem;
}

.post .post-contents a {
	text-decoration: underline;
}

.post .post-contents strong {
	font-weight: bold;
}

.post .post-contents hr {
	margin: 40px 0;
}

.post .post-contents p {
	margin-bottom: 40px;
}

.post .post-contents ul,
.post .post-contents ol {
	font-size: 1.5rem;
	margin-bottom: 40px;
	margin-left: 20px;
}

.post .post-contents ul {
	list-style: disc;
}

.post .post-contents ol {
	list-style: decimal;
}

.post .post-contents blockquote {
	background: #eee url( img/common/icon-quote.svg ) 20px 20px / 40px no-repeat;
	padding: 30px 30px 10px 80px;
	margin-bottom: 40px;
	border-radius: 8px;
}

.post .post-contents blockquote p,
.post .post-contents blockquote ul,
.post .post-contents blockquote ol {
	margin-bottom: 20px;
}

.post .post-contents table {
	width: 100%;
	text-align: left;
	border-top: solid 1px #ccc;
	border-left: solid 1px #ccc;
	margin: 0 0 40px;
}

.post .post-contents table th {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	background: #f9f9f9;
	font-weight: normal;
	vertical-align: top;
}

.post .post-contents table td {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	vertical-align: top;
}

/* post-list */

.post-list .post {
	margin-bottom: 60px;
}

.post-list .post-contents figure {
	width: 40%;
	padding: 0;
}

.post-list .post-contents .txt {
	width: 60%;
	padding: 0 0 0 20px;
}

.search-msg {
	background: #fafafa;
	padding: 10px 20px;
	margin: 30px 0;
}

/* post-nav */

.post-nav {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 60px 0;
}

.post-nav .prev,
.post-nav .next {
	width: 40%;
}

.post-nav a {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	align-items: center;
	position: relative;
	transition: all .2s;
}

.post-nav .prev a {
	background: url( img/common/arrow-left.svg ) left 5px center / 14px no-repeat;
	padding: 0 0 0 3rem;
}

.post-nav .prev a:hover {
	background: url( img/common/arrow-left.svg ) left 0 center / 14px no-repeat;
}

.post-nav .next a {
	background: url( img/common/arrow-right.svg ) right 5px center / 14px no-repeat;
	padding: 0 15px 0 3rem;
}

.post-nav .next a:hover {
	background: url( img/common/arrow-right.svg ) right 0 center / 14px no-repeat;
}

.post-nav .next a {
	flex-direction: row-reverse;
	padding: 0 3rem 0 15px;
}

.post-nav img {
	width: 60px;
	line-height: 1;
}

.post-nav .prev img {
	margin: 0 15px 0 0;
}

.post-nav .next img {
	margin: 0 0 0 15px;
}

.post-nav .back-link {
	width: 20%;
}

.post-nav .back-link a {
	display: block;
	text-align: center;
	padding: 15px 5px;
	box-sizing: border-box;
	border: solid 1px #ccc;
	border-radius: 5px;
	transition: all .2s;
}

.post-nav .back-link a:hover {
	background: #000;
	color: #fff;
}

/* page-nav */

.page-nav .wp-pagenavi {
	clear: both;
	text-align: center;
	margin-top: 60px;
}

.page-nav .wp-pagenavi a,
.page-nav .wp-pagenavi span {
	display: inline-block;
	font-size: 1.5rem;
	padding: 5px 15px;
	margin: 0 5px;
	transition: all .4s;
}

.page-nav .wp-pagenavi a:hover,
.page-nav .wp-pagenavi span.current {
	background: #000;
	color: #fff;
}

/* author */

.author-box {
	border: solid 1px #ccc;
	margin: 60px 0;
}

.author-box h3 {
	font-size: 1.6rem;
	letter-spacing: 4px;
	text-align: center;
	padding: 5px;
	margin: 0;
	background: #eee;
	border-bottom: solid 1px #ccc;
}

.author-box .flex {
	margin-bottom: 0;
	padding: 20px 20px 10px;
}

.author-box .flex > figure {
	width: 30%;
	padding: 0;
	margin: 0;
}

.author-box figure + .txt {
	width: 70%;
	padding: 0 0 0 20px;
	box-sizing: border-box;
}

.author-box .name {
	font-size: 1.8rem;
}

.author-box .name span {
	font-size: 1.4rem;
	margin-right: 1rem;
}

/* relation-post */

.relation-post {
	padding: 0;
}

.relation-post h2 {
	text-align: center;
	background: #000;
	color: #fff;
	font-size: 1.6rem;
	letter-spacing: 4px;
	padding: 5px;
	margin-bottom: 20px;
}

.relation-post .flex {
	padding: 0;
	margin-bottom: 0;
	justify-content: space-between;
}

.relation-post .flex .post {
	padding: 0;
	width: calc( 33.3333% - 15px );
}

.relation-post .flex figure img {
	width: 100%;
	max-height: 160px;
}

.relation-post .flex h3 {
	font-size: 1.6rem;
	margin-bottom: 10px;
}

.relation-post ul.cat-list a {
	font-size: 1.1rem;
}

/*
----------------------------------------
teacher
----------------------------------------
*/

#teacher #page-ttl {
	background: #000 url( img/teacher/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

/*
----------------------------------------
voice
----------------------------------------
*/

#voice .user,
#voice .star {
	display: inline-block;
	margin-bottom: 10px;
}

#voice .user {
	font-size: 1.6rem;
	margin-right: 1rem;
}

.star {
	font-size: 2rem;
	color: #ccc;
	letter-spacing: 3px;
}

.star span {
	color: #D5B376;
}

#voice .post-contents .thumb {
	padding: 0;
	width: 40%;
}

#voice .post-contents .txt {
	width: 60%;
	padding: 0 0 0 30px;
}

#voice .faq-list {
	margin: 40px 0 20px;
}

/* staff-comment */

.staff-comment {
	padding: 20px 30px 30px;
	background: #fafafa;
}

.staff-comment h2 {
	text-align: center;
}

.staff-comment .flex {
	justify-content: space-between;
}

.staff-comment .flex {
	margin: 0;
	align-items: center;
}

.staff-comment .flex > figure {
	width: 30%;
	padding: 0;
	margin: 0;
}

.staff-comment .comment {
	border: solid 1px #ccc;
	background: #fff;
	padding: 20px;
	box-sizing: border-box;
}

.staff-comment figure + .comment {
	width: calc( 70% - 30px );
	min-height: 10rem;
	position: relative;
}

.staff-comment figure + .comment::before,
.staff-comment figure + .comment::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate( -100%, -50% );
}

.staff-comment figure + .comment::before {
	border: solid 15px transparent;
	border-right: solid 15px #ccc;
}

.staff-comment figure + .comment::after {
	border: solid 13px transparent;
	border-right: solid 13px #fff;
}

.staff-comment h3 {
	font-size: 1.6rem;
	margin-bottom: 10px;
}

/* archive */

#voice .post-archive .user {
	font-size: 1.4rem;
}

#voice .post-archive .star {
	font-size: 1.8rem;
}

#voice .post-archive p {
	margin-bottom: 0;
}


/*
----------------------------------------
slider
----------------------------------------
*/

.slider-box {
	margin: 0 0 90px 0;
	margin: 0 0 45px 0;
	text-align: center;
}

.slider-box .slick-slide {
	text-align:center;
}

.slider-box .slick-slide.slide-1 {
	background:url(img/home/slide-01-bg.jpg) no-repeat 50% 50% / cover;
	height: 639px;
	align-content: center;
	justify-content: center;
	flex-wrap: wrap;
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
}

.slider-box .slick-slide.slide-1 img.pc-none{
	display:none;
}

.slider-box .slick-slide.slide-1 figure{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.slider-box .slick-slide.slide-1 figure img{
	border:none;
	background:none;
	box-shadow:none;
}

.slider-box .slick-slide img {
	display: inline-block;
	width:100%;
	border: 4px solid #fff;
	box-sizing: border-box;
	box-shadow: 0 2px 0px 0 rgba(0,0,0,.2);
}

.slider-box.thumb-slider {
	margin: 0;
}

.slider-box.thumb-slider + .thumb {
	margin-bottom: 40px;
}

.slider-box.thumb-slider + .thumb figure {
	padding: 0 5px;
	box-sizing: border-box;
}

.slider-box.slick-dotted.slick-slider {
	margin: 0 0 80px 0;
}

.slider-box .slick-dots {
	bottom: -40px;
}

.slider-box .slick-prev,
.slider-box .slick-next {
	width: 50px;
	height: 50px;
	padding: 0;
}

.slider-box .slick-prev {
	left: -20px;
	z-index: 999;
}

.slider-box .slick-next {
	right: -20px;
	z-index: 999;
}

.slider-box.slider .slick-prev {
	left: 75px;
}

.slider-box.slider .slick-next {
	right: 75px;
}

.slider-box .slick-prev:before,
.slider-box .slick-next:before {
	display: inline-block;
	content: '';
	width: 50px;
	height: 50px;
	opacity: 1;
	border-radius: 100%;
	box-shadow:0 0 3px 0 rgba(0,0,0,.1);
}

.slider-box .slick-prev:before {
	background: #a50021 url( img/common/arrow-left-wh.svg) center center / 37% no-repeat;
}

.slider-box .slick-next:before {
	background: #a50021 url( img/common/arrow-right-wh.svg) center center / 37% no-repeat;
}


/*
----------------------------------------
page-ttl
----------------------------------------
*/

#page-ttl {
	background: #000 url( img/information/bg-ttl.jpg) no-repeat 50% 50% / cover;
	padding: 0;
	height: 370px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

#page-ttl .box {
	display: inline-block;
	/*background: rgba( 255,255,255,.9 );*/
	padding: 0;
	line-height: 1.4;
	color:#fff;
}

#page-ttl .box h2 {
	font-size:  5rem;
	font-weight: normal;
}

#page-ttl .box h2.en {
	font-size: 2rem;
}

#page-ttl .box p {
	font-size: 1.5rem;
}

#page-ttl .box p.en {
	font-size: 2rem;
}

#page-ttl .box p.Montserrat {
	font-size: 2rem;
	letter-spacing: 4px;
	padding-left: 9px;
	line-height: 1.1;
	margin: -10px auto 7px;
}


/*
----------------------------------------
page-contents
----------------------------------------
*/

.page-contents section {
	margin-bottom: 30px;
}

.page-contents h2 {
	margin-bottom: 30px;
	border-left: solid 5px #000;
	padding-left: 15px;
}

.page-contents p,
.page-contents figure {
	margin-bottom: 30px;
}

.page-contents .flex.img-right {
	flex-direction: row-reverse;
}

.page-contents .flex figure {
	width: 40%;
	padding: 0;
}

.page-contents .flex figure + p {
	width: 60%;
	box-sizing: border-box;
}

.page-contents .img-left figure + p {
	padding: 0 0 0 25px;
}

.page-contents .img-right figure + p {
	padding: 0 25px 0 0;
}


/*
----------------------------------------
topic-path
----------------------------------------
*/

.topic-path {
	padding: 10px 0;
	margin-bottom: 20px;
	background: #fafafa;
	font-size: 1.2rem;
	display:none;
}

.topic-path .wrap {
	text-align: left;
}

.topic-path a {
	padding-right: 16px;
	background: url( img/common/arrow-right.svg ) right center / 6px no-repeat;
	margin-right: 8px;
}


/*
----------------------------------------
contact-box
----------------------------------------
*/

.contact_wrap{
	position:relative;
	background:#fff url(img/common/bg-03.png) repeat;
	padding: 10px;
	margin:60px auto;
}

.contact_wrap .inner{
	background:#fff;
	padding:15px;
}

.contact_wrap .contact-box{
	background:#ebebeb;
	padding:25px 30px;
	margin:25px auto;
	width: 90%;
	max-width: 930px;
}

.contact-box{
	margin:25px auto;
	align-items: center;
	justify-content: space-between;
}

.contact-box > div{
	padding:0 !important;
	width: 48.5% !important;
	position:relative;
	height: 84px;
	z-index:1;
}

.contact-box > div a{
	font-size: 1.6rem;
	background:#ccc;
	color:#fff;
	position:relative;
	border-radius:5px;
	transition: all .4s;
	height: 100%;
	width: 100%;
	align-items: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.contact-box > div a:hover{
	top: 4px;
}

.contact-box > div:after{
	content:"";
	width:100%;
	height:7px;
	position:absolute;
	bottom:-4px;
	left:0;
	border-bottom-right-radius:5px;
	border-bottom-left-radius:5px;
	z-index:-1;
}

.contact-box > .tel a{
	background:#a50021;
}

.contact-box > .tel .Helvetica{
	font-size: 3.4rem;
	font-style: normal;
	font-weight: 500;
	line-height: 1.1;
	position: relative;
	top: 5px;
}

@media screen and ( max-width: 1180px ) {
	.contact-box > .tel .Helvetica {
		font-size: 2.8rem;
	}
}

.contact-box > .tel .Helvetica:before{
	content:"";
	width:24px;
	height:28px;
	background:url(img/svg/icn_tel.png) no-repeat 50% 50% / contain;
	display:inline-block;
	vertical-align:middle;
	margin-right:10px;
}

.contact-box > .tel span{
	font-size: 1.3rem;
}

.contact-box > .tel:after{
	background:#84001a;
}

.contact-box > .mail a{
	background:#007769;
	flex-direction: row;
	flex-wrap: nowrap;
	box-sizing: border-box;
	line-height: 1.3;
}

.contact-box > .mail a:before{
	content:"";
	width: 1.2em;
	height: 1.2em;
	background:url(img/svg/envelope.svg) no-repeat 50% 50% / contain;
	display:inline-block;
	vertical-align:middle;
	margin-right:10px;
}*

.contact-box > .mail:after{
	background:#004139;
}


/*
----------------------------------------
attention-box
----------------------------------------
*/

.attention-box{
	align-items: center;
	height: 90px;
	margin: 35px auto;
}

.attention-box dt {
	width: 10%;
	text-align: center;
	position: relative;
	height: 90px;
	align-items: center;
	display: flex;
	justify-content: center;
	font-size: 1.7rem;
	font-weight: 600;
	background:#fff url(img/common/bg-04.png) repeat;
	letter-spacing: 3px;
}

.attention-box dt::before {
	content: "Attention!";
	position: absolute;
	top: -.8em;
	left: -.8em;
	width: 100%;
	height: 1em;
	font-size: 3.2rem;
	color: #a50021;
	z-index: 3;
	font-weight: 400;
	font-family: 'Caveat', cursive;
	letter-spacing: 0;
	transform: rotate(-18deg);
	font-style: italic;
	word-wrap: normal;
	overflow-wrap: normal;
}

.attention-box dd {
	width: 85%;
	padding:25px !important;
	background:#fff;
	line-height: 1.5;
}

.attention-box dd .red{
	font-style:normal;
	color:#a50021;
}

/*
----------------------------------------
access-box
----------------------------------------
*/

.access-box{
	position:relative;
	background:#fff8f5 url(img/common/bg-01.png) repeat;
	padding: 35px 0;
	margin:35px auto;
}

.access-box .flex{
	justify-content: space-between;
	align-items: center;
}

.access-box .info{
	width:42%;
	padding:0;
}

.access-box .info dd{
	line-height:1.8;
}

.access-box .info .small {
	font-size: 1.3rem;
	display: block;
	padding-left: 1em;
	line-height: 1.5;
	margin: 5px 0 10px;
}

.access-box .map{
	height: 450px;
	padding: 0;
	border: 10px solid #fff;
	width: 54%;
	box-shadow: 0 0 5px 2px rgba(0,0,0,.2);
}

.access-box .map iframe{
	display:block;
	width:100%;
	height:100%;
}

.access-box dt {
	margin: 15px 0 10px;
	display: inline-block;
	vertical-align: middle;
	background: #fff;
	padding: 0 1.2em;
	border-radius: 2em;
	color: #a50021;
	font-weight: 500;
	font-size: 1.7rem;
	line-height: 1.7;
}

.access-box .btn-01{
	margin: 25px auto 0;
}

.access-box .btn-01 a {
	display: inline-block;
	font-size: 1.6rem;
	padding: 10px 1em 10px 2.5em;
	width: inherit;
	box-sizing: border-box;
}


/*
----------------------------------------
home
----------------------------------------
*/

#home #contents {
	margin-top: 0;
}

#home .mainimg {
	width: 100%;
	max-width: 1800px;
	max-width: 100%;
	margin: 0 auto;
}

#home .mainimg .slick-slider,
#home .mainimg .slick-slider .slick-track,
#home .mainimg .slick-slider .slick-list,
#home .mainimg .slider-box .slick-slide.slide-1{
	width:100% !important;
}

/* news-box */

#home .news-box {
	padding: 0 10px 35px;
	position: relative;
	border-bottom: 1px dashed #ccc;
	margin-bottom: 25px;
}

#home .news-box .btn-01{
	position: absolute;
	top: 0;
	right: 0;
	margin: 0;
}

@media screen and ( min-width: 751px ) {
.sp {
	display: none !important;
}

.en .news-box .btn-01 a {
	font-size: 1.5rem;
}

.pt .contact-box > .mail a {
	font-size: 1.4rem;
}

.vi .contact-box > .mail a::before,
.pt .contact-box > .mail a::before {
	display: none;
}
}

@media screen and ( min-width: 1180px ) {
.en .news-box .heading-02 {
	padding-right: 330px;
}
}

@media screen and ( max-width: 1180px ) {
	#home .news-box .btn-01 {
		margin-top: 30px;
		width: auto;
		position: relative;
	}
}

#home .news-box .btn-01 a:hover{
	background:#fff;
	color:#a50021;
}

#home .news-box .btn-01 a:hover:before,
#home .news-box .btn-01 a:active:before {
	background:url(img/svg/caret-circle-right-red.svg) no-repeat 50% 50% / contain;
}

#home .news-list {
	border-bottom: solid 1px #ccc;
}

#home .news-list a.flex {
	margin-bottom: 0;
	border-top: solid 1px #ccc;
	padding: 20px 4rem 20px 0;
	background: url( img/common/arrow-right.svg ) right 15px center / 8px no-repeat;
	transition: all .2s;
}

#home .news-list a.flex:hover {
	background: #fafafa url( img/common/arrow-right.svg ) right 10px center / 8px no-repeat;
}

#home .news-list .flex .date {
	width: 20rem;
	padding: 0;
	text-align: center;
}

#home .news-list .flex .ttl {
	width: calc( 100% - 20rem );
	padding: 0;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

#home .btn-01 {
	margin-top: 40px;
}

#home .btn-02.en {
	margin-top: 30px;
}

#home #recruit {
	margin: 35px auto;
}

#home #recruit .flex > figure {
	width: 40%;
	position: absolute;
	top: 0;
	left: 0;
}

#home #recruit .flex > figure::before {
	content: "join us!";
	position: absolute;
	top: .2em;
	left: 1em;
	width: auto;
	height: 1em;
	font-size: 5.2rem;
	color: #a50021;
	z-index: 3;
	font-weight: 400;
	font-family: 'Caveat', cursive;
	transform: rotate(-20deg);
	letter-spacing: 0;
	line-height: 1;
}

#home #recruit > div{
	padding-left: 45%;
	position: relative;
	min-height: 410px;
	flex-direction: column;
	justify-content: center;
}

#home #recruit .contact-box{
	width: 100%;
}

@media screen and ( max-width: 1180px ) and ( min-width: 751px ) {
	#home #recruit .contact-box {
		flex-direction: column;
	}
	#home #recruit .contact-box > div {
		width: 100% !important;
		margin-bottom: 10px;
	}
}

#home #communication{
	position:relative;
	padding: 50px 0;
	margin:75px auto 60px;
}
#home #communication.lazyloaded {
	background:#fff8f5 url(img/home/bg-communication.jpg) no-repeat top center;
}

@media screen and ( min-width: 1698px ) {
	#home #communication.lazyloaded {
		background-size:cover;
	}
}

#home #communication p.center{
	margin-bottom: 70px;
}

#home #communication .flex{
	justify-content: space-between;
	margin:25px auto;
}

#home #communication .flex > *{
	background: #fff;
	padding: 0 10px 10px 10px;
	position:relative;
}

#home #communication .flex > * dt{
	text-align:center;
	font-size: 3rem;
	letter-spacing: 10px;
	line-height: 1.1;
	position: relative;
	top: -.7em;
}

#home #communication .flex > * dt i{
	display:inline-block;
}

#home #communication .flex > * dt i:before,
#home #communication .flex > * dt i:after{
	content:"";
	width:17px;
	height:32px;
	display:inline-block;
	vertical-align:middle;
	margin:0 10px;
}

#home #communication .flex > * dt i:before{
	margin-right:20px;
	background:url(img/home/bg-insta-l.png) no-repeat 50% 50% / contain;
}

#home #communication .flex > * dt i:after{
	background:url(img/home/bg-insta-r.png) no-repeat 50% 50% / contain;
}

#home #communication .flex > .facebook dt i:before{
	background:url(img/home/bg-fb-l.png) no-repeat 50% 50% / contain;
}

#home #communication .flex > * .facebook i:after{
	background:url(img/home/bg-fb-r.png) no-repeat 50% 50% / contain;
}

#home #communication .flex > .instagram dt:before,
#home #communication .flex > .instagram dt:after,
#home #communication .flex > .facebook:after{
	content:"";
	position:absolute;
}

#home #communication .flex > .instagram dt:before{
	width:66px;
	height:49px;
	left:10px;
	bottom:0;
	background:url(img/home/ico-sns-1.png) no-repeat 50% 50% / contain;
}

#home #communication .flex > .instagram dt:after{
	width:84px;
	height:79px;
	right:10px;
	bottom:0;
	background:url(img/home/ico-sns-2.png) no-repeat 50% 50% / contain;
}

#home #communication .flex > .facebook:after{
	width:84px;
	height:72px;
	right:-45px;
	bottom:-35px;
	background:url(img/home/ico-sns-3.png) no-repeat 50% 50% / contain;
}

#home #communication .flex > .instagram{
	width:58%;
}

#home #communication .flex > .facebook{
	width:38%;
}

#home #communication .flex > .facebook dd > *{
	display:block;
	margin:0 auto;
	text-align: center;
	height: 300px;
	overflow:hidden;
	max-width:100%;
}

#home #communication .flex > .facebook dt{
	color:#3b579d;
}

/*--access --*/

#home #access header {
	text-align: center;
	background-color: #6cf;
	height: 330px;
	display: flex;
	justify-content: center;
	align-content: center;
	align-items: center;
	overflow:hidden;
}
#home #access.lazyloaded header {
	background: #6cf url(img/home/bg-access.jpg) no-repeat 50% 50%;
}

@media screen and ( min-width: 1698px ) {

	#home #access.lazyloaded header{
		background-size:cover;
	}
}

#home #access header .heading-05::after,
#home #access header .heading-05::before {
	content: "";
	width: 50%;
	height: 2px;
	position: absolute;
	background: #0c2a48;
	top: 50%;
}

#home #access header .heading-05::before {
	left: 90%;
}

#home #access header .heading-05::after {
	right: 90%;
}

#home #access header .heading-05{
	width: 100%;
	max-width: 1700px;
	margin: 0 auto 15px;
	overflow:hidden;
	position:relative;
	padding: 0 10%;
	line-height: 1.3;
}

#home #access .inner{
	position:relative;
	padding:1px 0;
}

#home #access .inner > .read{
	color: #fff;
	margin: 45px auto;
	font-size: 1.4rem;
	line-height: 2.3;
}

#home #access .inner > * {
	position:relative;
	z-index:1;
}

#home #access .inner:before{
	content:"";
	width:100%;
	height:290px;
	background-color:#a50021;
	position:absolute;
	top:0;
	left:0;
}

#home #access.lazyloaded .inner:before{
	background:#a50021 url(img/home/bg-04.png) no-repeat bottom center / cover;
}

#home #access .heading-05{
	color:#0c2a48;
	font-size:3.4rem;
}

#home #access .heading-05 i {
	font-size: 6rem;
	color: inherit;
	letter-spacing: inherit;
	display: inline-block;
	margin: 0 2px;
	font-style: normal;
	font-weight: 700;
	vertical-align: baseline;
}

#home #access .flex.col-03 > *{
	padding: 0 20px;
}

#home #access .flex.col-03{
	margin-top: -20px;
}

#home #access .flex.col-03 figure{
	text-align:center;
	position:relative;
	max-width: 276px;
	margin: 0 auto;
}

#home #access .flex.col-03 figure figcaption {
	position: absolute;
	text-align: left;
	bottom: .3em;
	right: .5em;
	width: auto;
	font-size: 4.8rem;
	color: #a50021;
	z-index: 1;
	transform: rotate(-15deg);
	letter-spacing: 0;
	line-height: 1;
	height: 1em;
}

#home #access .flex.col-03 figure figcaption i {
	font-weight: 400;
	font-style: italic;
	background: linear-gradient(transparent 95%, #a50021 0%);
	display: inline-block;
	line-height: 1;
	height:1em;
}

#home #access .flex.col-03 .txt p{
	font-size:1.4rem;
}

#home #access .flex.col-03 .txt h3{
	text-align:center;
	font-size: 2.2rem;
	margin-bottom: 5px;
	min-height: 3.2em;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height:1.5;
}

/*--course --*/

#home #course{
	margin-bottom:25px;
}

#home #course header{
	position:relative;
	z-index:5;
}

.course-box{
	position:relative;
	background:#fff8f5 url(img/common/bg-01.png) repeat;
	padding: 154px 0 60px 0;
}

.course-box:after{
	content:"let's study together !";
	position:absolute;
	text-align:center;
	top:-30px;
	left:0;
	width:100%;
	height:2em;
	font-size:8.4rem;
	color:#a50021;
	z-index: 3;
	font-weight: 400;
	font-style: italic;
	font-family: 'Caveat', cursive;
}

.course-box::before {
	content: "";
	position: absolute;
	z-index: 0;
	top: -110px;
	left: 0;
	width: 100%;
	height: 233px;
	background: url(img/home/tri.png) no-repeat bottom center;
}

.course-box > *{
	position:relative;
	z-index:2;
	justify-content: space-between;
}

.course-box > .btn-01{
	margin:40px auto 60px auto!important;
}

.course-box > .flex > div{
	padding:0;
	width: 49%;
	margin: 0 0 25px;
	height: 300px;
	overflow: hidden;
	align-items:center;
	box-shadow:0 0 10px 0px rgba(0,0,0,.3)
}

.course-box > .flex > div:hover{
	opacity:.8;
	transition:all .4s;
	cursor: pointer;
}

.course-box > .flex > div .txt{
	width:48%;
}

.course-box > .flex > div .txt h3 {
	box-shadow: 0 1px 2px 0px rgba(0,0,0,.3);
	background: #fff;
	text-align: center;
	border-radius: 7px;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 93px;
	margin: 0px auto 20px;
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: .5px;
	padding: 10px 5px;
	box-sizing: border-box;
	line-height:1.3;
	width:100%;
}

.ja .course-box > .flex > div .txt h3{
	font-family: dnp-shuei-mgothic-std, sans-serif;
	font-weight: 600;
	font-style: normal;
}

.course-box > .flex > #course-01 .txt h3 {
	color: #b71c1c;
}

.course-box > .flex > #course-02 .txt h3 {
	color: #e65100;
}

.course-box > .flex > #course-03 .txt h3 {
	color: #2e7d32;
}

.course-box > .flex > #course-04 .txt h3 {
	color: #0d47a1;
}

.course-box > .flex > #course-05 .txt h3 {
	color: #ad1457;
}

.course-box > .flex > #course-06 .txt h3 {
	color: #00695c;
}

.course-box > .flex > #course-07 .txt h3 {
	color: #3a70ac;
}

.course-box > .flex > div .txt h3:before{
	content:"";
	background:url(img/home/ico-fuki.png) no-repeat 50% 50% ;
	width:26px;
	height:13px;
	position:absolute;
	bottom:-13px;
	left:50%;
	margin-left:-6.5px;
}

.course-box > .flex > div .txt dl{
	align-items:center;
}

.course-box > .flex > div .txt dl dt,
.course-box > .flex > div .txt dl dd{
	margin-bottom:3px;
	line-height: 1.5;
}

.course-box > .flex > div .txt dl dt{
	width: 28%;
	padding: 5px 0;
	text-align: center;
	border: 1px solid #fff;
	color: #fff;
	font-size: 1.5rem;
	line-height: 1.2;
}

.zh .course-box > .flex > div .txt dl{
	align-items: flex-start;
}

.en .course-box > .flex > div .txt dl{
	align-items: flex-start;
}

.en .course-box > .flex > div .txt dl dt {
	width: 42%;
}

.en .course-box > .flex > div .txt dl dd {
	width: 58%;
}

.vi .course-box > .flex > div .txt dl dt{
	width:35%;
}

.vi .course-box > .flex > div .txt dl dd {
	width: 65%;
}

.vi .course-box > .flex > div .txt h3 {
	min-height: 70px;
}

.pt .course-box > .flex > div .txt dl dt{
	width:100%;
	padding: 2px 0;
}

.pt .course-box > .flex > div .txt dl dd {
	width: 100%;
	padding: 2px 0 7px 0;
}

.ko .course-box > .flex > div .txt dl{
	align-items: flex-start;
}

.course-box > .flex > div .txt dl dd{
	width: 72%;
	padding:1px 10px;
	text-align:right;
	color: #fff;
	line-height: 1.3;
	font-size: 1.3rem;
	white-space: nowrap;
}

.course-box > .flex > div .txt dl dd i{
	font-style:normal;
}

.course-box > .flex > div .txt dl dd .Helvetica {
	font-weight: 500;
	font-size: 2.4rem;
	line-height: 1.1;
}

.course-box > .flex > div .txt dl dd.small{
	white-space: normal;
	text-align: left;
	font-size: 1.2rem;
	padding-right: 0;
}

.course-box > .flex > div .txt .btn-01{
	margin:15px auto 0 !important;
	text-align: center;
}

.pt .course-box > .flex > div .txt .btn-01 {
	margin: 0 auto 0 !important;
}

.course-box > .flex > div .txt .btn-01 a{
	font-size: 1.6rem;
	padding: 10px 1em 10px 2.2em;
	/*max-width: 230px;*/
}

.course-box .flex > div figure{
	padding:0;
	margin: 0;
	width: 52%;
}

/*--test--*/
.course-box > .flex > div {
	padding: 0 0 0 25%;
	width: 49%;
	margin: 0 0 25px;
	height: auto;
	min-height: 300px;
	overflow: hidden;
	align-items: center;
	box-shadow: 0 0 10px 0px rgba(0,0,0,.3);
	position: relative;
	box-sizing: border-box;
	display: flex;
}

.course-box > .flex > div .txt {
	width: 100% !important;
	display: flex;
	flex-direction: column;
}

.course-box .flex > div figure {
	padding: 0;
	margin: 0;
	width: 50%;
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	overflow: hidden;
}

.course-box .flex > div figure img {
	vertical-align: middle;
	width: auto;
	height: 110%;
	max-width: inherit;
	position: relative;
	left: -5%;
	top: -5%;
}

.course-box .flex #course-01{
	background:#d22e2e url(img/home/bg-course-01.png) repeat;
}

.course-box .flex #course-01 .btn-01 a{
	background:#661111;
	border-color:#661111;
}

.course-box .flex #course-02{
	background:#f57e00 url(img/home/bg-course-02.png) repeat;
}

.course-box .flex #course-02 .btn-01 a{
	background:#742d00;
	border-color:#742d00;
}

.course-box .flex #course-03{
	background:#398f3d url(img/home/bg-course-03.png) repeat;
}

.course-box .flex #course-03 .btn-01 a{
	background:#193d1a;
	border-color:#193d1a;
}

.course-box .flex #course-04{
	background:#3847a9 url(img/home/bg-course-04.png) repeat;
}

.course-box .flex #course-04 .btn-01 a{
	background:#0c2552;
	border-color:#0c2552;
}

.course-box .flex #course-05{
	background:#c31a5d url(img/home/bg-course-05.png) repeat;
}

.course-box .flex #course-05 .btn-01 a{
	background:#590c2d;
	border-color:#590c2d;
}

.course-box .flex #course-06{
	background:#008a7c url(img/home/bg-course-06.png) repeat;
}

.course-box .flex #course-06 .btn-01 a{
	background:#004039;
	border-color:#004039;
}

.course-box .flex #course-07{
	background:#3a70ac url(img/home/bg-course-07.png) repeat;
}

.course-box .flex #course-07 .btn-01 a{
	background:#203d5e;
	border-color:#2d5685;
}

/* voice-box / blog-box */

#home .voice-box .post,
#home .blog-box .post {
	padding: 10px;
	text-align: left;
}

#home .voice-box .user {
	font-size: 1.4rem;
}

#home .voice-box .star {
	font-size: 1.6rem;
}

#home .voice-box h3,
#home .blog-box h3 {
	font-size: 1.6rem;
	margin-bottom: 10px;
}

/* faq-box */

#home .faq-box .flex > * {
	padding: 0 10px;
}

/*
----------------------------------------
information
----------------------------------------
*/


#information #page-ttl{
	position: relative;
	background: #000 url( img/information/bg-ttl2.jpg) no-repeat 50% 65% / cover;
}

#information #page-ttl .box{
	position: absolute;
	width: 100%;
	height: 240px;
	padding-top: 130px;
	background: rgba(0, 0, 0, 0.5);
}
@media screen and ( max-width: 750px ) {
	#information #page-ttl .box{
		height: 120px;
		padding-top: 70px;
	}
}

#information #about_us {
	margin: 15px auto 65px;
}

#information #about_us .heading-01{
	margin-bottom: 0;
}

#information #feature{
	border-bottom:75px solid #fff8f5;
}

#information #feature header{
	margin-bottom: 0;
	background: #fff8f5;
	padding: 50px 0 40px;
}

#information #feature .heading-05 i {
	font-size: 3.6rem;
}

#information #event{
	padding:50px 0 0 0;
}

#information #event > .wrap > p{
	margin-top:30px;
}

#information .event-list{
	position:relative;
	padding:15px 0;
	margin:50px auto 0;
}
#information #event.lazyloaded .event-list {
	background:url(img/information/bg-event.jpg) no-repeat 50% 0% / cover;
}

#information .event-list hr{
	display:block;
	width:100%;
	height:5px;
	margin:22px auto 24px;
	border: none;
	background:url(img/common/line-02.png) repeat-x center;
}

#information .event-list dl {
	border: 1px solid #000;
	background: #fff;
	padding: 10px;
	border-radius: 7px;
	display: inline-block;
	width: 45%;
	margin: 35px 5% 35px 0;
	max-width: 500px;
	position:relative;
}

#information .event-list dl.spring:after,
#information .event-list dl.autumn:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	bottom: -71px;
}

#information .event-list dl.summer:after,
#information .event-list dl.winter:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	top: -72px;
}

#information .event-list dl.spring:after{
	left: 55px;
	background: url(img/information/ico-spring.png) no-repeat 50% 50%;
}

#information .event-list dl.autumn:after{
	left: 190px;
	background: url(img/information/ico-autumn.png) no-repeat 50% 50%;
}

#information .event-list dl.summer:after{
	right: 200px;
	background: url(img/information/ico-summer.png) no-repeat 50% 50%;
}

#information .event-list dl.winter:after{
	right: 50px;
	background: url(img/information/ico-winter.png) no-repeat 50% 50%;
}

#information .event-list dl.spring:before,
#information .event-list dl.autumn:before {
	content:"";
	position:absolute;
	width:44px;
	height:37px;
	bottom:-37px;
}

#information .event-list dl.summer:before,
#information .event-list dl.winter:before {
	content:"";
	position:absolute;
	width:38px;
	height:33px;
	top:-33px;
}

#information .event-list dl.spring:before{
	left:60px;
	background:url(img/information/img-fuki-01.png) no-repeat 50% 50%;
}

#information .event-list dl.summer:before{
	right:205px;
	background:url(img/information/img-fuki-03.png) no-repeat 50% 50%;
}

#information .event-list dl.autumn:before {
	left:190px;
	background:url(img/information/img-fuki-02.png) no-repeat 50% 50%;
}

#information .event-list dl.winter:before{
	right:55px;
	background:url(img/information/img-fuki-04.png) no-repeat 50% 50%;
}

#information .event-list dl.spring {
	border-color: #e91e63;
}

#information .event-list dl.autumn {
	border-color: #ff5722;
}

#information .event-list dl.summer {
	border-color: #2196f3;
}

#information .event-list dl.winter {
	border-color: #9c27b0;
}

#information .event-list dl ul.flex{
	justify-content: center;
}

#information .event-list dl .flex.col-02 > *{
	padding:5px 10px;
	width: 40%;
}

.autumn-winter{
	left: 120px;
	position: relative;
}

#information .event-list dl dt {
	position: absolute;
	top: -33px;
	left: -20px;
	background: #000;
	width:145px;
	height:71px;
	text-align: center;
}

#information .event-list .spring dt {
	background:url(img/information/tape-01.png) no-repeat 0 0 / contain;
}

#information .event-list .summer dt {
	background:url(img/information/tape-03.png) no-repeat 0 0 / contain;
}

#information .event-list .autumn dt {
	background:url(img/information/tape-02.png) no-repeat 0 0 / contain;
}

#information .event-list .winter dt {
	background:url(img/information/tape-04.png) no-repeat 0 0 / contain;
}

#information .event-list dl h3{
	font-size:2rem;
	margin: 0 0 5px;
}

.pt#information .event-list dl h3 {
	font-size: 1.8rem;
	line-height: 1.2;
}

.vi #information .event-list dl h3,
.pt #information .event-list dl h3{
	font-size:1.8rem;
	line-height:1.1 !important;
}

#information .event-list .spring h3 {
	color:#e91e63;
}

#information .event-list .summer h3 {
	color:#2196f3;
}

#information .event-list .autumn h3 {
	color:#ff5722;
}

#information .event-list .winter h3 {
	color:#9c27b0;
}

#information .event-list dl h3 .small{
	display: block;
	font-size: 1.3rem;
	line-height: 1.2;
}

#information .event-list dl dt i {
	font-size: 4.2rem;
	color: #fff;
	display: inline-block;
	line-height: 1;
	font-weight:400 !important;
	transform: rotate(-15deg);
	height: 1em;
	position: relative;
	top: 9px;
}

#information .event-list dl p{
	font-size: 1.3rem;
	line-height: 1.5;
	max-width: 180px;
	text-align: center;
	margin: 12px auto;
}

@media screen and ( max-width: 1180px ) {
	.spring-summer,
	.autumn-winter {
		left: 0;
		justify-content: center;
	}

	#information .event-list dl {
		margin: 35px 2.5%;
	}
}

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

	#information .event-list dl ul.flex {
		flex-direction: column;
	}
	#information .event-list dl .flex.col-02 > * {
		width: 100%;
	}
}

#information #our_policy{
	padding:60px 0 22px 0;
}

#information #our_policy .heading-01{
	margin:-5px 0 0 0;
	font-size: 2.8rem;
	display: block;
	height: inherit;
	min-width: inherit;
	max-width: inherit;
	min-height: inherit;
	margin-bottom: 25px;
}

#our_policy .heading-01:before,#our_policy .heading-01:after,
#our_policy .heading-01 span:before,#our_policy .heading-01 span:after {
	display:  none;
}

#our_policy .heading-01 span {
  text-align: left;
  display: block;
	height: inherit;
	min-width: inherit;
	max-width: inherit;
}

#information #greeting{
	background:#a50021;
	overflow:hidden;
	padding:0 0 40px;
	margin:70px auto 0;
}

#information #greeting *{
	color:#fff;
}

#information #greeting .heading-05 {
	font-size: 2.4rem;
}

#information #greeting .wrap {
	padding: 0;
}

#information #greeting .ttl{
	position:relative;
	text-align:center;
	line-height:1;
	top: -17px;
	margin-bottom: 25px;
}

#information #greeting .ttl span{
	font-size:12rem;
	color:rgba(0,0,0,.1);
	line-height:1;
	height:12rem;
	font-weight:bold;
}

#information #greeting .ttl i{
	position:absolute;
	bottom:.5em;
	left:0;
	width:100%;
	text-align:center;
	color:#fff;
	font-size:3.6rem;
	font-style:normal;
	line-height:1;
	height:1em;
	font-weight:300;
}

#information #greeting .info {
	width: 54%;
}

#information #greeting figure {
	width: 47%;
	margin: 0 -3% 0 0;
	padding: 0;
	position: relative;
	left: 3%;
}

#information #greeting .info .right{
	font-size: 1.8rem;
}

#information #about{
	margin:65px auto 0;
}

#information #about .table-02 caption {
	font-size: 2.4rem;
	padding: 13px 12px;

}

#information #access{
	background:#fff8f5;
	padding:50px 0 22px 0;
}

#information #access .heading-04{
	margin-bottom:25px;
}

#information #access .btn-02{
	margin:30px auto;
	line-height: 1.3;
}

#information #access .btn-02 a{
	flex-direction:row;
	max-width: 690px;
	margin: 0 auto;
}

#information #access .btn-02 a:before{
	content:"";
	width:18px;
	height:18px;
	background:url(img/svg/map-marker-alt-red.svg) no-repeat 50% 50% / contain;
	display:inline-block;
	margin:-4px 8px 0 0;
	vertical-align:middle;
	position:relative;
	transition:all .4s;
}

#information #access .map{
	height:590px;
	width:100%;
	margin:40px auto 55px;
	box-sizing: border-box;
	padding: 0;
}

#information #access .map iframe{
	height:100%;
	width:100%;
	display:block;
}


#information #access .access-flow .num{
	position:absolute;
	top:-35px;
	left:50%;
	margin:0 0 0 -40px;
	border: 3px solid #fff;
	background:#fff;
	border-radius: 100%;
	width: 80px;
	height: 80px;
	z-index:1;
	box-sizing:border-box;
	color:#a50021;
}

#information #access .access-flow ol{
	margin:50px auto 0;
}

#information #access .access-flow ol li p{
	padding:20px;
	font-size:1.5rem;
}

#information #access .access-flow ol li{
	position:relative;
	margin-bottom:55px;
	z-index:1;
	padding:0 15px;
}

#information #access .access-flow ol li:after{
	content:"";
	width:30px;
	height:30px;
	background:url(img/svg/chevron-right-brown.svg) no-repeat 50% 50% / contain;
	position:absolute;
	right:-15px;
	top:50%;
	margin-top:-15px;
}

#information #access .access-flow ol li:nth-child(3n):after{
	display:none;
}

#information #access .access-flow ol li > *{
	border:2px solid #a50021;
	border-radius:4px;
	background:#fff;
	height:100%;
}

#information #access .access-flow ol li figure,
#information #access .access-flow ol li figure img{
	border-top-left-radius:7px;
	border-top-right-radius:7px;
}

#information #access .access-flow .num > *{
	display:flex;
	width:100%;
	height:100%;
	font-size:1.3rem;
	text-align:center;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	overflow:hidden;
	border-radius: 100%;
	box-sizing:border-box;
	border: 1px dashed #a00001;
	font-style:normal;
	font-weight:500;
}

#information #access .access-flow .num i{
	font-size:3.2rem;
	line-height:1;
	font-weight:bold;
}



/*
---------------------------------------
tab-panel
---------------------------------------
*/

#tab-box,.tab-box{
	margin: 50px auto;
}

.tab-box {
	background: #fff;
	min-height: 394px;
}

.tab-menu{
	margin-bottom: 0;
	/*overflow: hidden;*/
	border-bottom: 2px solid #a50021;
	justify-content: space-around;
	position:relative;
	background: #fff8f5;
}

.tab-menu > li{
	padding: 0 10px !important;
}

.tab-menu > li > * {
	width: 100%;
	line-height:1.5;
	font-size: 2rem;
	position: relative;
	box-sizing: border-box;
	padding: 12px 10px;
	background:#a50021;
	color: #fff !important;
	text-align: center;
	text-decoration: none !important;
	overflow: hidden;
	cursor: pointer;
	transition: all .2s;
	display:block;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
	border:2px solid #a50021;
	border-bottom:none;
	top: 2px;
	height:100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.tab-menu > li .small {
	font-size:1.5rem;
}

.tab-menu > li .active{
	color: #a50021 !important;
	background: #fff;
}

.tab-menu > li *:hover,
.tab-menu > li *:active {
	border-bottom-width:2px;
	top:4px;
}

.tab-menu::after {
	content: "";
	width: 100%;
	height: 5px;
	background: #fff;
	position: absolute;
	bottom: -7px;
	left: 0;
	z-index: 10;
}

/* schedule-box */

.schedule-box {
	background: #fff;
	margin: -50px auto 50px;
	padding: 20px 35px 35px;
}

.schedule-box > p {
	font-size: 1.4rem;
	margin-top: 20px;
}

.schedule-box .slider-box {
	margin-bottom: 30px;
}

.schedule-box .slider-box figure {
	padding: 0 15px;
}

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

	.schedule-box {
		padding: 20px 10px 35px;
	}

	.schedule-box > h3 {
		margin: 0 10px 20px !important;
	}

	.schedule-box > p {
		margin-right: 10px;
		margin-left: 10px;
	}

}

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

	.schedule-box {
		margin: -40px 0 20px;
		padding: 10px 10px 30px;
	}

	.schedule-box > p {
		margin: 15px 10px 0;
		line-height: 1.8;
		font-size: 1.3rem;
	}

	/*
	.schedule-box .flex .box {
		width: calc( ( 100% - 10px ) / 2 ) !important;
		margin-right: 10px;
	}

	.schedule-box .flex .box:nth-child( even ) {
		margin-right: 0;
	}
	*/

}

.online-ttl {
	padding-bottom: 50px;
}

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

	#online .sec-01 {
		padding-top: 25px;
	}

}


/*
----------------------------------------
course-single
----------------------------------------
*/

#intensive #page-ttl {
	background: #000 url( img/course/intensive/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

#twice-weekly #page-ttl {
	background: #000 url( img/course/twice-weekly/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

#nighttime #page-ttl {
	background: #000 url( img/course/nighttime/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

#weekend #page-ttl {
	background: #000 url( img/course/weekend/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

#private #page-ttl {
	background: #000 url( img/course/private/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

#online #page-ttl {
	background: #000 url( img/course/online/online-ttl-bg.png ) no-repeat 50% 50% / cover;
}

#other #page-ttl {
	background: #000 url( img/course/other/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

.course-single .slick-slider{
	margin-top:25px;
}

.course-single .topic-path{
	margin-bottom:0;
}

.course-single #head-contents{
	margin:0 auto 25px;
	background:#fff8f5;
}

.course-single #bottom-nav-cf .flex{
	justify-content: center;
}

.course-single #top-nav .flex li,
.course-single #bottom-nav-cf .flex li{
	padding:20px 10px;
	box-sizing: border-box;
}

.course-single #top-nav .flex li a,
.course-single #bottom-nav-cf .flex li a {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
	color: #a50021;
	border: 1px solid #a50021;
	position: relative;
	font-size: 1.6rem;
	font-weight: 500;
	width:100%;
	height:60px;
	box-sizing:border-box;
	box-shadow: 0 2px 0 0 #ffd9e0;
	line-height: 1.3;
}

.course-single #top-nav .flex li a:before,
.course-single #bottom-nav-cf .flex li a:before {
	content:"";
	display:inline-block;
	margin:0 5px 0 0;
}

.course-single #top-nav .flex li a:before{
	width:20px;
	height:20px;
	background:url(img/svg/caret-down-red.svg) no-repeat 50% 50% / contain;
}

.course-single #bottom-nav-cf .flex li.access a:before{
	width:15px;
	height:15px;
	background:url(img/svg/map-marker-alt-red.svg) no-repeat 50% 50% / contain;
}

.course-single #bottom-nav-cf .flex li.back a:before{
	width:15px;
	height:15px;
	background:url(img/svg/bars-red.svg) no-repeat 50% 50% / contain;
}

.course-single #photos {
	padding: 0;
}

.course-single #photos h3{
	position:relative;
	z-index:1;
	overflow:hidden;
}

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

	.contents .heading-03 em {
		padding: 5px;
		background: transparent;
	}

	#photos h3::before {
		display: none;
	}

}

#photos h3::before {

	width: 100%;
	height: 21px;
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	background: url(img/common/bg-02.png) repeat-x center;
	z-index:-1;
	margin-bottom: 12px;

}

.course-single #photos .slick-initialized .slick-slide{
	padding:3px;
	opacity:.3;
}

.course-single #photos .slick-initialized .slick-active{
	opacity:1;
}

.course-single #feature .flex {
	align-items: center;
	justify-content: space-between;
	margin-bottom: 25px;
}

.course-single #feature .flex .box.txt {
	width: 51%;
}

.course-single #feature p {
	font-feature-settings: 'palt';
	letter-spacing: .5px;
}

.course-single #feature .heading-02{
	font-size:2.8rem !important;
}

.course-single #feature .heading-02 i{
	font-size: 1.6rem;
}

#information #feature .heading-05 {
	font-size: 2.6rem;
}

.course-single #feature .box.pic {
	background: #f3f3f3;
	position: relative;
	padding: 0;
}

.course-single #feature .box.pic img{
	position: relative;
	top:10px;
	left:10px;
}

.course-single .gallery figure{
	padding:15px;
}

.course-single #calendar .wrap{
	padding:0;
}

.course-single #select {
	background: #fff8f5;
	padding:50px 0 1px;
}

.course-single #select .tab-box .course-info .table-02 td{
	text-align:right;
}

.course-single #select .tab-box .course-info .table-02 td div.ttl {
	border-bottom: solid 1px #ccc;
	padding-bottom: 5px;
	margin: 15px 0;
}

.course-single #select .tab-box .course-info .table-02 td div.ttl.first {
	margin-top: 0;
}

.course-single #select .tab-box .course-info .table-02 td div.ttl + br {
	display: none;
}

.course-single #select .tab-box > div{
	background:#fff;
	padding:35px 35px 1px;
}

.course-single #select .tab-box > div .acf_flex{
	width:100%;
	justify-content: space-between;
	margin-bottom: 25px;
}

.course-single #select .tab-box > div .acf_flex > *{
	width:49%;
}

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

	.course-single #select .tab-box > div {
		padding: 35px 10px 1px;
	}

}

.course-single #select .tab-box .course-icon {
	margin: 25px auto;
	justify-content: space-between;
}

.course-single #select .tab-box .course-icon > * {
	background: #faf9f2;
	width: 32.3333%;
	box-sizing: border-box;
	position: relative;
	padding:10px 10px 10px 98px;
	font-size:1.8rem;
	min-height:88px;
	line-height: 1.5;
	display: flex;
	align-items: center;
}

.pt.course-single #select .tab-box .course-icon > *{
	font-size:1.5rem;
}

.course-single #select .tab-box .course-icon > *:before {
	content:"";
	width:68px;
	height:68px;
	border-radius:100%;
	background:#a50021;
	display:inline-block;
	position:absolute;
	top:50%;
	left:15px;
	margin-top:-34px;
	background: #a50021 url(img/svg/check-wh.svg) no-repeat 50% 50% / 32px 32px;
}
/*
.course-single #select .tab-box .course-icon > *:nth-child(1):before {
	background: #a50021 url(img/svg/ear.svg) no-repeat 50% 50% / 32px 32px;
}

.course-single #select .tab-box .course-icon > *:nth-child(2):before {
	background: #a50021 url(img/svg/edit.svg) no-repeat 50% 50% / 32px 32px;
}

.course-single #select .tab-box .course-icon > *:nth-child(3):before {
	background: #a50021 url(img/svg/user.svg) no-repeat 50% 50% / 32px 32px;
}
*/
.course-single #contents .tab-box .table-02 caption {
	font-size: 1.6rem;
}

.course-single #photos .slider::before {
	background: #fff8f5;
	content: "";
	width: 150%;
	height: 200%;
	transform: rotate(20deg);
	transform-origin: 100% 100%;
	position: absolute;
	right: 0;
	top: 0;
	z-index: -1;
}

.course-single .tab-box .btn-course{
	width: 100%;
	height: 255px;
	background: #000;
	color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 0 12px;
	box-sizing: border-box;
	text-align: center;
	line-height: 1.5;
	z-index: 1;
	position:relative;
}

.course-single .tab-box .btn-course:before{
	content:"";
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	background:rgba(0,0,0,.2);
	z-index:-1;

}

.course-single .tab-box .btn-course > *{
	position:relative;
	z-index:1;
}

.course-single .tab-box #select-1 .btn-course.lazyloaded {
	background: #000 url( img/course/btn-course-select1.jpg ) no-repeat 50% 50% / cover;
}

.course-single .tab-box #select-2 .btn-course.lazyloaded {
	background: #000 url( img/course/btn-course-select2.jpg ) no-repeat 50% 50% / cover;
}

#private.course-single .tab-box #select-1 .btn-course.lazyloaded {
	background: #000 url( img/course/private/btn-course-select1.jpg ) no-repeat 50% 50% / cover;
}

#private.course-single .tab-box #select-2 .btn-course.lazyloaded {
	background: #000 url( img/course/private/btn-course-select2.jpg ) no-repeat 50% 0% / cover;
}

#other.course-single .tab-box #select-1 .btn-course.lazyloaded {
	background: #000 url( img/course/other/btn-course-select1.jpg ) no-repeat 50% 50% / cover;
}

#other.course-single .tab-box #select-2 .btn-course.lazyloaded {
	background: #000 url( img/course/other/btn-course-select2.jpg ) no-repeat 50% 50% / cover;
}

#other.course-single .tab-box #select-3 .btn-course.lazyloaded {
	background: #000 url( img/course/other/btn-course-select3.jpg ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box .btn-course {
	background: #faf9f2;
	color: #a50021;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}

#online.course-single .tab-box .btn-course:before {
	background: transparent;
}

#online.course-single .tab-box #class-01-01 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-01.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-01-02 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-02.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-02-01 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-03.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-02-02 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-04.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-03-01 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-05.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-03-02 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-06.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-05-01 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-07.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-05-02 .btn-course.lazyloaded {
	background: #000 url( img/course/online/online-bg-08.png ) no-repeat 50% 50% / cover;
}

#online.course-single .tab-box #class-01-01 .btn-course,
#online.course-single .tab-box #class-01-02 .btn-course,
#online.course-single .tab-box #class-02-01 .btn-course,
#online.course-single .tab-box #class-02-02 .btn-course,
#online.course-single .tab-box #class-03-01 .btn-course,
#online.course-single .tab-box #class-03-02 .btn-course,
#online.course-single .tab-box #class-05-01 .btn-course,
#online.course-single .tab-box #class-05-02 .btn-course {
	color: #fff;
}

#online.course-single .tab-box #class-01-01 .btn-course:before,
#online.course-single .tab-box #class-01-02 .btn-course:before,
#online.course-single .tab-box #class-02-01 .btn-course:before,
#online.course-single .tab-box #class-02-02 .btn-course:before,
#online.course-single .tab-box #class-03-01 .btn-course:before,
#online.course-single .tab-box #class-03-02 .btn-course:before,
#online.course-single .tab-box #class-05-01 .btn-course:before,
#online.course-single .tab-box #class-05-02 .btn-course:before {
	background: rgba(0,0,0,.2);
}

.course-single .tab-box .btn-course .Montserrat{
	font-size: 3.2rem;
	letter-spacing: 5px;
	font-weight: 600;
	line-height: 1.2;
}

.course-single .tab-box .course-info .table-02{
	margin-top: 0;
}

.course-single .tab-box .course-info .table-02 th,
.course-single .tab-box .course-info .table-02 td{
	padding:15px 20px;
}

.course-single #photos .slider-box {
	background: #fff8f5;
	position:relative;
	padding: 50px 0;
	margin-bottom: 0;
	opacity: 0;
	visibility: hidden;
}

.course-single #photos .slider-box.slick-slider {
	opacity: 1;
	visibility: visible;
}

.course-single #photos .slider-box > slick-list draggable{
	position:relative;
	z-index:10;
}

.course-single #recommend {
	background: #fff;
	position: relative;
	z-index: 1;
	padding: 25px 0;
}

.course-single #information {
	padding: 50px 0 50px;
}

.course-single #recommend .box{
	margin:50px 0 10px 0;
}

.course-single #recommend .box > *{
	border:3px solid #a50021;
	border-radius:7px;
	position:relative;
	height:100%;
}

.course-single #recommend .box > * p{
	padding: 0 30px 15px 30px;
	margin:0;
}

.course-single #recommend .box > * h3{
	padding: 10px 30px;
	margin:0;
	min-height: 3em;
	display: flex;
	justify-content: center;
	align-items: center;
}

.course-single #recommend h3 .num{
	position:absolute;
	top:-65px;
	left:50%;
	margin:0 0 0 -55px;
	border: 4px solid #fff;
	background:#fff;
	border-radius: 100%;
	width: 110px;
	height: 110px;
	z-index:1;
	box-sizing:border-box;
	color:#a50021;
}

.course-single #recommend h3 .num i{
	font-size:4.8rem;
	line-height:1;
	font-weight:bold;
}

.course-single #recommend h3 .num > *{
	display:flex;
	width:100%;
	height:100%;
	font-size:1.5rem;
	text-align:center;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	overflow:hidden;
	border-radius: 100%;
	box-sizing:border-box;
	border: 2px dashed #a00001;
	font-style:normal;
	font-weight:500;
}

.course-single #flow {
	background: #fff8f5;
	padding: 25px 0;
}

.course-single #flow .flex.col-04{
	margin:25px auto;
}

.course-single #flow .flex.col-04 > * {
	padding: 0 20px;
}

.course-single #flow .flex.col-04 .box figure{
	position:relative;
	background:#fff;
	width:250px;
	height:250px;
	border-radius:100%;
	display:block;
	margin:0 auto 25px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.course-single #flow .flex.col-04 .box figure::after {
	content: "";
	width: 40px;
	height: 40px;
	background: url(img/svg/chevron-right-brown.svg) no-repeat 50% 50% / contain;
	position: absolute;
	right: -40px;
	top: 50%;
	margin-top: -20px;
}

.course-single #flow .flex.col-04 .box:nth-child(4n) figure::after {
	display:none;

}

.course-single #flow .flex.col-04 h3{
	min-height: 3.2em;
	display: flex;
	align-items: center;
	justify-content: center;
}

.course-single #flow .flex.col-04 figure img{
	width:50%;
	max-width:100px;
}

.course-single #flow .flex.col-04 figure figcaption {
	position: absolute;
	text-align: left;
	top: -.5em;
	left: 0;
	width: 100%;
	height: 1.5em;
	font-size: 3.8rem;
	color: #a50021;
	z-index: 1;
	transform: rotate(-15deg);
	letter-spacing: 0;
	line-height: 1;
}

.course-single #flow .flex.col-04 figure figcaption i {
	font-weight: 400;
	font-style: italic;
	background: linear-gradient(transparent 95%, #a50021 0%);
	display: inline-block;
	line-height: 1.2;
	vertical-align: top;
}

@media screen and ( max-width: 1180px ) {
	.course-single #flow .flex.col-04 .box figure {
		width: 200px;
		height: 200px;
	}
}

@media screen and ( max-width: 960px ) {
	.course-single #flow .flex.col-04 .box figure {
		width: 150px;
		height: 150px;
	}
}


.course-single #calendar {
	background: #fcfcf5;
	padding: 50px 0 25px;
}

.course-single #calendar .gallery{
	margin:25px auto 0;
	max-width: 100%;
}

/*
----------------------------------------
course-list
----------------------------------------
*/


#course-list #page-ttl{
	background: #000 url( img/course/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

#course-list #contents{
	padding-bottom: 0;
}

#course-list .category-description {
	margin: 50px auto;
}

#course-list .post-list{
	padding:50px 0;
	background:url(img/common/bg-01.png) repeat;
}

/*
#course-list .post-contents {
	display: flex;
	flex-direction: column;
	height: 100%;
	justify-content: space-between;
	box-sizing: border-box;
}

#course-list .post-list .post-contents .box {

	padding: 20px 30px 0;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
	height: 100%;

}
*/
#course-list .post-course {
	background: #fff;
	width: 48%;
	margin: 0 1% 30px;
	padding:0;
}

#course-list .post-course .post-header {
	text-align:center;
}

#course-list .post-course .post-header h2{
	margin:0;
	font-size:2.4rem;
}

#course-list .post-course .post-header h2 a{
	padding:5px 0;
	background:#000;
	display: block;
	color: #fff;
}

#course-list #course-intensive .post-header h2 a {
	background: #d32f2f;
}

#course-list #course-twice-weekly .post-header h2 a {
	background: #f57c00;
}

#course-list #course-nighttime .post-header h2 a {
	background: #3949ab;
}

#course-list #course-private .post-header h2 a {
	background: #c2185b;
}

#course-list #course-weekend .post-header h2 a {
	background: #388e3c;
}

#course-list #course-other .post-header h2 a {
	background: #00897b;
}

#course-list #course-online .post-header h2 a {
	background: #3a70ac;
}

#course-list .post-list .post-contents figure {
	width: 100%;
	padding: 0;
}

#course-list .post-list .post-contents .btn-01{
	margin:15px auto 30px;
}

#course-list .access-box {
	margin: 25px auto;
	background: #fff;
}

#course-list .access-box dt{
	background:#fcf5f2;
}

#course-list #contents .contact{
	background:#faf9f2;
	padding:1px 0;
}

#course-list .post-list .post-contents .box {
	padding: 20px 30px 0;
}

#course-list .post-list .post-contents .box .table-02 caption {
	font-size: 1.5rem;
	caption-side: top;
	padding: 5px 0;
	font-weight:bold;
	background: #faf9f2;
	border-top: 1px solid #ccc;
}

#course-list .post-list .post-contents .box .table-02 {
	min-height: 160px;
}

#course-list .post-list .post-contents .box .table-02 th,
#course-list .post-list .post-contents .box .table-02 td{
	vertical-align: middle;
	padding:5px 20px;
	line-height: 1.7;
	font-size:1.5rem;
}

/*
----------------------------------------
faq
----------------------------------------
*/

#contents #faq-menu {
	padding: 30px 30px 10px;
	border: solid 1px #ccc;
	justify-content: space-between;
}

#contents #faq-menu > div {
	width: calc( 50% - 15px );
	padding: 0;
	margin-bottom: 20px;
}

#contents #faq-menu h2 {
	font-size: 1.6rem;
	background: #eee;
	padding: 10px 15px;
}

#faq-menu li {
	margin-bottom: 10px;
}

#faq-menu li a {
	display: block;
	padding: 5px 5px 5px 4rem;
	font-size: 1.5rem;
	position: relative;
}

#faq-menu li a:before {
	content: 'Q';
	display: inline-block;
	color: #fff;
	background: #000;
	font-size: 1.4rem;
	font-family: 'Roboto', sans-serif;
	text-align: center;
	line-height: 2.8rem;
	width: 2.8rem;
	height: 2.8rem;
	position: absolute;
	top: 3px;
	left: 0;
}

#faq-list {
	margin: 60px 0;
}

#faq-list h2 {
	font-size: 2rem;
	border-left: solid 5px #777;
	padding: 5px 5px 5px 15px;
	margin-bottom: 20px;
}

#faq-list .faq-01 {
	margin-bottom: 40px;
}


/*
----------------------------------------
staff
----------------------------------------
*/

.staff-list .staff {
	border: solid 1px #ccc;
	padding: 30px;
	margin-bottom: 30px;
}

.staff-list .name {
	font-size: 2.4rem;
	border-left: solid 4px #000;
	padding-left: 15px;
	margin-bottom: 20px;
}

.staff-list .name .sub {
	font-size: 1.6rem;
	margin-left: 10px;
}

.staff-list .staff figure {
	width: 25%;
	padding: 0;
	margin-bottom: 0;
}

.staff-list .staff figure + .txt {
	width: 75%;
	padding: 0 0 0 20px;
	box-sizing: border-box;
}

.staff-list .staff .txt h3 {
	font-size: 1.8rem;
}

.staff-list .staff:nth-child(even) .flex {
	flex-direction: row-reverse;
}

.staff-list .staff:nth-child(even) .flex figure + .txt {
	padding: 0 20px 0 0;
}


/*
----------------------------------------
company
----------------------------------------
*/

#company .contents section {
	margin-bottom: 80px;
}

#company .philosophy-box .cont figure,
#company .philosophy-box .cont p {
	margin-bottom: 20px;
}

#company .greeting-box figure {
	width: 35%;
	padding-right: 30px;
	box-sizing: border-box;
	text-align: center;
}

#company .greeting-box figcaption {
	font-size: 1.4rem;
}

#company .greeting-box figcaption .name {
	font-family: '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
	font-size: 2rem;
	margin-left: 10px;
}

#company .greeting-box figure + .txt {
	width: 65%;
}

#company .greeting-box .txt p {
	margin-top: 15px;
}

#company .contents table th {
	width: 25%;
	text-align: center;
}


/*
----------------------------------------
contact
----------------------------------------
*/

#contact #g-nav {
	position: static !important;
}

#contact #page-ttl {
	background: #000 url( img/contact/bg-ttl.jpg) no-repeat 50% 50% / cover;
}

.contact-info {
	margin-bottom: 80px;
}

.contact-info .flex {
	justify-content: space-between;
}

.contact-info .cont {
	width: calc( 50% - 15px );
	border: solid 1px #ccc;
	padding: 30px;
}

.contact-info .tel,
.contact-info .line{
	text-align:center;
}

.contact-info .tel .label {
	display: inline-block;
	background: #000;
	color: #fff;
	padding: 0 10px;
}

.contact-info .tel a {
	display: inline-block;
	font-size: 3.6rem;
	white-space: nowrap;
	margin: 0 10px;
	vertical-align: middle;
}

.contact-info .line {
	margin-top: 15px;
}

.contact-info .line img {
	max-width: 160px;
}

.contact-info .thanks-img {
	text-align: center;
	margin-bottom: 30px;
}

.contact-info .read {
	text-align: center;
	margin-bottom: 40px;
}

.contact-info .read a {
	text-decoration: underline;
}

.contact-info .back-btn {
	text-align: center;
	margin-top: 40px;
}

.accbox.notice {
	width: 100%;
	margin: 40px 0;
	align-items: center;
	background: #fafafa;
}

.accbox.notice ul {
	padding-left: 1.4rem;
	text-indent: -1.4rem;
}

.accbox.notice li {
	margin: 5px 0;
}

.accbox label {
	display: block;
	margin: 1.5px 0;
	padding : 11px 12px;
	background :#fafafa;
	cursor :default;
	transition: all 0.5s;
	width: 25%;
	text-align: center;
}

.accbox label:hover {
	background: #fafafa;
}

.accbox input {
	display: none;
}

.accbox .accshow {
	background: #fafafa;
	padding: 15px 0;
	overflow: hidden;
	transition: 0.8s;
	width: 75%;
}

.form-step {
	width: 100%;
	margin-bottom: 30px;
	border-left: solid 1px #ddd;
	border-right: solid 1px #ddd;
}

.form-step > p {
	width: 33.3333%;
	height: 50px;
	line-height: 50px;
	padding: 0 30px !important;
	background: #fafafa;
	border-top: solid 1px #ddd;
	border-bottom: solid 1px #ddd;
	text-align: center;
	white-space: nowrap;
	position: relative;
}

.form-step > p::before {
	content: '';
	border: solid 25px transparent;
	position: absolute;
	top: -1px;
	left: 1px;
	border-left: solid 20px #ddd;
}

.form-step > p::after {
	content: '';
	border: solid 25px transparent;
	position: absolute;
	top: -1px;
	left: 0;
	border-left: solid 20px #fafafa;
}

#mailformpro .step-01,
#mfp_phase_confirm .step-02 {
	background: #555;
	color: #fff;
	border-top: solid 1px #555;
	border-bottom: solid 1px #555;
}

.form-step > p.step-01::before,
.form-step > p.step-01::after {
	display: none;
}

#mailformpro .step-01 + p::before,
#mfp_phase_confirm .step-02 + p::before {
	display: none;
}

#mailformpro .step-01 + p::after,
#mfp_phase_confirm .step-02 + p::after {
	border-left: solid 20px #555;
}

.form-box {
	padding: 0;
}

#contact form#mailformpro {
	padding: 0;
}

#contact form#mailformpro > dl {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
}

#contact form#mailformpro dl dt {
	width: 25%;
	padding: 20px 70px 20px 20px;
	box-sizing: border-box;
	border: none;
	background: #fafafa;
	text-align: left;
	font-size: 1.6rem;
	position: relative;
}

#contact .req-label {
	display: inline-block;
	background: #a00;
	color: #fff;
	font-size: 1.2rem;
	padding: 0 5px;
	position: absolute;
	right: 20px;
	top: 25px;
}

#contact form#mailformpro dl dd {
	width: 75%;
	padding: 15px 44px 15px 20px;
	box-sizing: border-box;
	border: none;
	font-size: 1.6rem;
	position: relative;
}

#contact form#mailformpro dl dd::after {
	content: '';
	width: 24px;
	height: 24px;
	background: url( img/common/icon-check.svg ) center center / 24px no-repeat;
	position: absolute;
	right: 0;
	top:24px;
	opacity: 0;
	visibility: hidden;
	transition: all .2s;
}

#contact form#mailformpro dl dd.ok::after {
	opacity: 1;
	visibility: visible;
}

#contact dd .flex > .ttl {
	width: 25%;
	padding: 13px 0;
}

#contact dd .flex > .input {
	width: 75%;
	padding: 5px 0;
}

#contact dd .flex.inline span {
	padding: 0 20px 0 0;
}

.pp-box {
	max-height: 140px;
	overflow: auto;
	border: solid 1px #ccc;
	padding: 30px;
	margin: 40px 0;
	-webkit-overflow-scrolling: touch;
}

.pp-box h2 {
	text-align: center;
	margin-bottom: 25px;
}

.pp-box h3 {
	margin-top: 30px;
	padding-bottom: 10px;
	border-bottom: solid 1px #ccc;
}

.pp-box .address-box p {
	display: inline-block;
	background: #fafafa;
	margin-top: 20px;
	padding: 20px 30px;
}

.submit-box {
	text-align: center;
	margin-bottom:85px;
}

#contact .agree label {
	border: solid 1px #ccc !important;
	margin: 0 !important;
	font-size: 1.6rem;
	width: 360px;
	max-width: 100%;
}

#contact button.mfp_element_submit,
#contact button#mfp_button_send {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: inline-block;
	width: 360px;
	max-width: 100%;
	font-size: 1.6rem;
	text-shadow: none;
	padding: 20px 0 15px;
	border-radius: 0;
	box-shadow: none !important;
	transition: all .2s;
}

#contact button.mfp_element_reset,
#contact button#mfp_button_cancel {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-size: 1.4rem;
	text-shadow: none;
	padding: 10px 20px;
	border-radius: 0;
	border: solid 1px #000;
	background: #fff;
	color: #000;
	box-shadow: none !important;
	transition: all .2s;
}

#contact button.mfp_element_submit,
#contact button#mfp_button_send {
	border: solid 1px #000;
	background: #000;
	color: #fff;
	display: block;
	margin: 30px auto;
}

#contact button.mfp_element_submit,
#contact button.mfp_element_submit:hover,
#contact button#mfp_button_send:hover {
	border: solid 1px #333;
	background: #333;
}

#contact button.mfp_element_submit.disable,
#contact button.mfp_element_submit.disable:hover {
	border: solid 1px #777;
	background: #777;
}

#contact button.mfp_element_reset:hover,
#contact button#mfp_button_cancel:hover {
	background: #ddd;
}

#contact .mfp_element_all {
	max-width: 100%;
}

.form-box input[type="text"] {
	min-width: 310px;
}

#contact .mfp_element_text,
#contact .mfp_element_number,
#contact .mfp_element_select-one,
#contact .mfp_element_email,
#contact .mfp_element_tel,
#contact .mfp_element_textarea,
#contact .mfp_element_date,
#contact .mfp_element_password {
	box-shadow: none;
	border: solid 1px #ccc;
	border-radius: 0;
	background: transparent;
	margin: 0;
}

#contact .mfp_element_text.req,
#contact .mfp_element_number.req,
#contact .mfp_element_select-one.req,
#contact .mfp_element_email.req,
#contact .mfp_element_tel.req,
#contact .mfp_element_textarea.req,
#contact .mfp_element_date.req,
#contact .mfp_element_password.req {
	background: #fffeee;
}

#contact form#mailformpro label.mfp_not_checked,
#contact form#mailformpro label.mfp_checked {
	background: transparent;
	padding: 15px;
	display: inline-block;
	text-align: center;
	box-sizing: border-box;
	margin-right: 10px;
	box-shadow: none;
	border: none;
	border-radius: 0;
	transition: all .2s;
}


#contact form#mailformpro label.mfp_not_checked .mfp_err,
#contact form#mailformpro label.mfp_checked .mfp_err {
	text-align: center;
}

#contact form#mailformpro label.mfp_not_checked:hover,
#contact form#mailformpro label.mfp_checked {
	background: #eee;
}

#contact .name.flex > span {
	padding: 0;
	margin-right: 15px;
}

#contact .problem {
	border: solid 1px #a00 !important;
}

#contact div.mfp_err {
	background: transparent;
	padding: 0;
	margin: 10px 0 0;
	font-size: 1.2rem;
	color: #a00;
}

#contact div#mfp_phase_confirm h4 {
	font-size: 3rem;
	padding: 0;
}

#contact .mfp_confirm_before {
	text-align: center;
}

#contact table#mfp_confirm_table {
	border-top: solid 1px #ccc;
	border-left: solid 1px #ccc;
	margin: 30px 0 45px;
}

#contact table#mfp_confirm_table tr th,
#contact table#mfp_confirm_table tr td {
	font-size: 1.6rem;
	font-weight: normal;
	padding: 15px;
	box-sizing: border-box;
	border: none;
	border-right: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
}

#contact table#mfp_confirm_table tr th {
	background: #fafafa;
}

#contact table#mfp_confirm_table tr.mfp_colored {
	background: transparent;
}

#contact div.mfp_buttons {
	padding: 0;
}

#contact .remaining {
	position: fixed;
	right: 20px;
	bottom: 110px;
	display: inline-block;
	background: #fff;
	border: solid 1px #a00;
	text-align: center;
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	transition: all .2s;
}

#contact .remaining.active {
	opacity: 1;
	visibility: visible;
	z-index: 999;
}

#contact .remaining .read {
	padding: 10px 20px;
}

#contact .remaining .num {
	background: #a00;
	color: #fff;
	padding: 5px 20px;
}


/*
----------------------------------------
sitemap
----------------------------------------
*/

.sitemap section {
	margin-bottom: 40px;
}

.sitemap .search-form {
	max-width: 1000px;
	margin: 20px auto 60px;
}

.sitemap .search-form input[type='text'] {
	padding: 15px !important;
}

.sitemap h2 {
	margin-bottom: 30px;
	border-left: solid 5px #000;
	padding-left: 15px;
}

.sitemap .flex {
	justify-content: space-between;
	margin-bottom: 0;
}

.sitemap .flex > * {
	width: calc( 50% - 15px );
}

.sitemap .menu-list > ul {
	border-bottom: solid 1px #ccc;
}


/*
----------------------------------------
404
----------------------------------------
*/

#not-found .info-box {
	text-align: center;
	margin-bottom: 40px;
}


/*
----------------------------------------
search
----------------------------------------
*/

#search .post-list {
	border-top: solid 1px #ccc;
}

#search .post {
	border-bottom: solid 1px #ccc;
	margin-bottom: 0;
}

#search .post a.flex {
	padding: 20px 50px 20px 20px;
	margin: 0;
	align-items: center;
	background: url( img/common/arrow-right.svg ) right 15px center / 16px no-repeat;
	transition: all .2s;
}

#search .post a.flex:hover {
	background: #fafafa url( img/common/arrow-right.svg ) right 10px center / 16px no-repeat;
}

#search .post figure {
	width: 170px;
	padding-right: 20px;
}

#search .post .flex > .thumb + .txt {
	width: calc( 100% - 170px );
}

#photos h3{
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 15px;
	box-sizing: border-box;
}

@media screen and (min-width: 751px) and (max-width: 920px) {
	#wrapper > header .h1-cont .wrap{
		flex-direction: column;
	}
	#wrapper > header .h1-cont ul li a{
		font-size:1.3rem;
	}
	#wrapper > header .h1-cont .wrap .flex{
		justify-content: flex-end;
		width: 100%;
	}
	#wrapper > header .h1-cont ul li {
		margin: 5px 0 5px 5px;
	}
	#wrapper > header h1{
		width: 100%;
	}
	#g-nav > ul > li > a{
		justify-content: center;
	}
	.en #g-nav > ul > li > a, .vi #g-nav > ul > li > a, .pt #g-nav > ul > li > a, .ko #g-nav > ul > li > a {
		font-size: 1.3rem;
	}
	#g-nav > ul > li > a::before,
	#g-nav > ul > li.current a::after,
	#g-nav > ul > li > a:hover::after{
		display:none;
	}
}
