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

.h2 > p {
	font-size: 36px;
	margin: 20px 0;
	color: #000;
	display: inline-block;
	position: relative;
	line-height: 54px;
}

.h2 > p:before {
	content: "";
	display: block;
	/*background-color: #1A76D1;*/
	background-color: var(--o_main_color);
	width: 32px;
	height: 3px;
}

.h3 {
	padding: 10px 0;
	color: #000;
	font-size: 18px;
}

.h3::before {
	content: "";
	display: inline-block;
	width: 3px;
	height: 15px;
	/*background-color: #1A76D1;*/
	background-color: var(--o_main_color);
	margin-right: 4px;
}

.h3 > span {
	font-size: 14px;
	color: #999 !important;
}

.contents {
	padding: 20px 0 90px;
	background: #fdfdfd;
}

@media only screen and (max-width: 768px) {
	.contents {
		position: relative;
		max-width: 100%;
		min-height: 450px;
		padding: 10px;
	}
}

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

caption, legend {
	visibility: hidden;
	width: 0;
	height: 0;
	line-height: 0;
	font-size: 0;
	overflow: hidden;
	display:none;
}

th, td, tbody, thead, tfoot {
	border-collapse: collapse;
}

.table-layout {
	width: 100%;
	margin: 20px 0;
	border-right: solid 1px #ddd;
	border-left: solid 1px #ddd;
	overflow-x: auto;
}

.table-layout table {
	width: 100%;
	border-top: solid 2px #767676;
}

.table-layout th {
	font-size: 15px;
	background: #f5f5f5;
	border-bottom: solid 1px #ddd;
	border-right: solid 1px #ddd;
	color: #555;
	height: 40px;
	padding: 10px;
	text-align:center;
}

.table-layout th, .table-layout td {
	white-space: nowrap;
}

.table-layout td {
	font-size: 15px;
	border-bottom: solid 1px #ddd;
	border-right: solid 1px #eee;
	color: #999;
	padding: 10px;
	text-align: center;
}

.hd_writer {
	display: none;
}

.table-layout a {
	text-decoration: none;
	outline: none;
	color: #000 !important;
}

.search_box {
	width: 100%;
	text-align: center;
	margin-bottom: 30px;
}

.search_box span {
	display: inline-block;
}

.search_box span:first-of-type {
	/*float: right;
	margin-bottom: 16px;*/
}

.search_box span input {
	height: 35px;
	width: 250px;
}

@media only screen and (max-width: 768px) {
	.search_box span {
		display: block;
		margin-bottom: 5px;
	}
	.search_box span select {
		width: 100%;
		float: none;
	}
	.search_box span input {
		width: calc(100% - 85px);
	}
}

.search_button {
	display: inline-block;
	/*border: solid 1px #1A76D1;*/
	border: solid 1px var(--o_main_color);
	border-radius: 2px;
	line-height: 35px;
	min-width: 80px;
	height: 35px;
	vertical-align: middle;
	color: #fff !important;
	/*background: #1A76D1;*/
	background: var(--o_main_color);
	font-size: 14px;
}

.search_button:hover {
	background: var(--o_main_color);
	color: #fff;
	opacity: 0.8;
}

@media only screen and (max-width: 768px) {
	.search_button {
		min-width: 70px;
	}
}

.paging {
	clear: both;
	font-size: 12px;
	text-align: center;
	line-height: 28px;
}

.paging a.pre_end {
	content: "";
	background: url(../images/common/icon_back_first.gif) center center no-repeat;
}

.paging a.prev {
	content: "";
	background: url(../images/common/icon_back.gif) center center no-repeat;
}

.paging a.next {
	content: "";
	background: url(../images/common/icon_next.gif) center center no-repeat;
}

.paging a.next_end {
	content: "";
	background: url(../images/common/icon_next_last.gif) center center no-repeat;
}

.paging a {
	display: inline-block;
	vertical-align: middle;
	border: #dfdfdf 1px solid;
	width: 30px;
	height: 30px;
	color: #999999;
	font-size: 12px;
	text-align: center;
	padding: 0 !important;
	background: #fff;
	margin-left: 2px;
}

.tab_type01 > ul {
	font-size: 16px;
	width: 100%;
	height: 50px;
	border-bottom: 1px solid #999;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

.tab_type01 > ul > li.on {
	background-color: #fff;
	/*border-top: 4px solid #1A76D1;*/
	border-top: 4px solid var(--o_main_color);
	border-left: 1px solid #999;
	border-right: 1px solid #999;
	border-bottom: none;
}

.tab_type01 > ul > li:first-child {
	border-left: 1px solid #d5dae3;
}

.tab_type01 > ul > li {
	position: relative;
	display: inline-block;
	min-width: 98px;
	height: 100%;
	border: 1px solid #d5dae3;
	border-left: none;
	border-bottom: none;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

.tab_type01 > ul > li.on > a {
	background-color: #fff;
	/*color: #1A76D1;*/
	color: var(--o_main_color);
	font-weight: 600;
	height: 46px;
}

.tab_type01 > ul > li.on > a > span {
	/*color: #1A76D1 !important;*/
	color: var(--o_main_color) !important;
}

.tab_type01 > ul > li > a {
	display: block;
	height: 100%;
	padding: 16px 18px 9px;
	background-color: #f2f5f8;
	font-size: 16px;
	font-weight: normal;
	line-height: 16px;
	color: #333;
	text-align: center;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

@media only screen and (max-width: 768px) {
	.tab_type01 {
		width: 100%;
		margin-top: 0;
		padding: 15px;
		background-color: #f1f5f8;
	}

	.tab_type01 > ul {
		height: auto;
		border-bottom: none;
		border-bottom: 1px solid #e1e7ee;
		border-right: 1px solid #e1e7ee;
		background-color: #fff;
	}

	.tab_type01 > ul > li {
		width: 50% !important;
		height: auto;
		border: 1px solid #e1e7ee;
		border-right: none;
		border-bottom-color: #fff;
	}

	.tab_type01 > ul > li.on {
		height: auto;
		border: 1px solid #8777D9;
	}

	.tab_type01 > ul > li.on > a {
		background-color: #fff;
		color: #8777D9;
		font-weight: 600;
		height: auto;
	}
}

.item_6 > li {
	width: 16.666%;
}

ul li {
	vertical-align: middle;
	line-height: normal;
	list-style: none;
}

.tab_list {
	width: 100%;
	font-size: 14px;
	color: #666;
	line-height: 20px;
	margin-top: 15px;
}

.calenda_week {
	margin-top: 0 !important;
}

.calenda_week table {
	width: 100%;
	table-layout: fixed;
	background: #fff;
	border-top: 2px solid #b21e27;
}

.calenda_week th {
	background: #eee;
	color: #555;
	line-height: 30px;
}

.calenda_week th, .calenda_week td {
	border: solid 1px #ddd;
	font-size: 12px;
	text-align: center;
}

.tab_list .calenda_week td {
	width: 100%;
	text-align: center;
}

.calenda_week .div_schedule {
	background-color: #B2CCFF;
}

.calenda_week td {
	width: 100%;
	text-align: center;
	height: 50px;
	color: #333;
}

.calenda_week th.SAT {
	background: #e3eaff;
	color: #2c7bff;
}

.calenda_week th.SUN {
	background: #ffe3e3;
	color: red;
}

.search_box2 span select {
	height: 35px;
	background-position: right 7px top 13px;
}

.search_box2 span:first-of-type {
	float: right;
	margin-bottom:6px;
}

.arrow-icons {
	color: #999;
	vertical-align: middle;
	font-size: 32px;
	display: inline-block !important;
}

.join-terms_items {
	margin: 10px 0 20px 0;
}

.join-terms {
	border: 1px solid #e0e0e0;
	border-top: 1px solid #b8b8b8;
	width: 100%;
}

.join-terms_title {
	position: relative;
	width: 100%;
	font-size: 16px;
	color: #000;
	font-weight: 500;
	display: block;
	vertical-align: middle;
	text-align: center;
	border-bottom: 1px solid #e0e0e0;
	background: #fafafa;
	padding: 13px 0;
}

.join-terms_titleCheck {
	position: absolute;
	top: 16px;
	right: 20px;
	font-size: 14px;
}

.join-terms_description {
	font-size: 14px;
	color: #999;
	padding: 20px;
	height: 150px;
	line-height: 22px;
	overflow-y: scroll;
}

@media only screen and (max-width: 768px) {
	.join-terms_titleCheck {
		position: relative;
		top: 5px;
		font-size: 12px;
		text-align: right;
	}
}

.checkbox2 {
	display: inline-block;
	cursor: pointer;
	/*color: #8777D9;*/
	color: var(--o_main_color);
	vertical-align: middle;
}

.red {
	color: red !important;
}

.color_main {
	color: var(--o_main_color);
}

.findid {
	margin-left:10px;font-weight:500;cursor:pointer;
}

.left {
	text-align: left !important;
}

.right {
	text-align: right !important;
}

.center {
	text-align: center;
}

.hidden {
	display: none;
}

.required {
	display: inline-block;
}

.required:before {
	content: "*";
	display: inline-block;
	vertical-align: middle;
	color: red;
}

.divTable {
	width: 100%;
	margin-bottom: 20px;
	border-top: solid 2px #767676;
	border-bottom: solid 1px #ddd;
}

.divTableBody {
	display: table;
	table-layout: fixed;
	width: 100%;
	background-color: #fff;
}

.divTableRow {
	display: table-row;
}

.divTableHead {
	display: table-cell;
	width: 15%;
	border-top: 1px solid #eee;
	background-color: #fafafa;
	color: #333;
	padding-left: 20px;
	vertical-align: middle;
	font-size: 14px;
}

.divTableCell {
	display: table-cell;
	border-left: 1px solid #eee;
	border-top: 1px solid #eee;
	padding: 10px;
	vertical-align: middle;
	font-size: 14px;
	color: #666;
}

.divTableCell p {
	margin: 2px 0 3px 0;
	line-height: 28px;
}

.divTableCell p.pay {
	padding: 5px 0;
	border-bottom: dashed 1px #ddd;
}

.divTableCell p.pay span {
	display: inline-block;
	padding: 0 10px;
	border-right: solid 1px #ddd;
	line-height: 100%;
}

.divTableCell p.pay:last-child {
	border-bottom: 0;
}

@media only screen and (max-width: 768px) {
	.divTable {
		width: 100%;
		border-bottom: 0;
	}

	.divTableHead {
		display: block;
		background: #fff;
		font-size: 12px;
		padding: 10px 0 0 10px;
		width: 100%;
		height: auto;
		border: 0;
		color: #5971a3;
		font-weight: bold;
	}

	.divTableBody {
		display: block;
		border: 0;
	}

	.divTableRow {
		display: block;
	}

	.divTableCell {
		display: block;
		width: 100%;
		border: 0;
		padding: 10px;
		font-size: 12px;
		border-bottom: 1px solid #ddd;
	}
}

.btn_set {
	text-align: center;
	width: 100%;
	font-size: 0;
	margin: 10px 0;
}

.btn_set > span {
	display: inline-block;
	vertical-align: middle;
	font-size: 14px;
	padding: 0 0 0 5px;
	text-align: center;
}

.btn_set a {
	/*color: #1A76D1;*/
	color: var(--o_main_color);
	display: block;
	/*border: solid 1px #1A76D1;*/
	border: solid 1px var(--o_main_color);
	border-radius: 2px;
	line-height: 33px;
	padding: 0 15px;
	min-width: 80px;
	height: 35px;
}

.btn_set a:hover {
	background: var(--o_sub_color2);
}

.btn_set a.filled {
	/*background: #1A76D1;*/
	background: var(--o_main_color);
	color: #fff;
}

.btn_set a.filled:hover {
	background: var(--o_main_color);
	color: #fff;
	opacity: 0.8;
}

.btn_sml {
	display: inline-block;
	margin-left: 5px;
}

.btn_sml a {
	background: #fff;
	/*color: #1A76D1;
	border: 1px solid #1A76D1;*/
	color: var(--o_main_color) !important;
	border: 1px solid var(--o_main_color);
	border-radius: 2px;
	display: inline-block;
	vertical-align: middle;
	line-height: 24px;
	padding: 0 10px;
	font-size: 12px;
	margin-top: -3px;
}

.secret {
	display: inline-block;
	background: #aaa;
	color: #fff !important;
	padding: 3px;
	font-size: 11px;
	margin: 0 5px;
	line-height: 100%;
	border-radius: 2px;
}

.bannerBox_Img {
	display: none;
	text-align:center;
}

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

	.bannerBox_Img {
		width: 100%;
		display: block;
		margin-top: -20px;
		text-align:center;
		transform:translateY(-30%);
		z-index:999;
		position:relative;
	}

	.bannerBox_Img li {
		display: inline-block;
		margin: 0 3px;
	}

	.bannerBox_Img li img {
		width: 70px;
	}
}

#floatMenu {
	position: absolute;
	width: 50px;
	height: 50px;
	left: 88%;
	top: 8%;
	z-index: 100;
}

#floatMenu img {
	padding: 10px;
}

.briefing {
	text-align:left;
	min-height:177px;
}

.briefing a {
	font-size: 14px;
	color: #555;
	line-height: 28px;
	display: inline-block;
	width: 220px;
	text-overflow: ellipsis;
	white-space: nowrap;
	word-wrap: normal;
	overflow: hidden;
}

.briefing span {
	font-size: 13px;
	color: #ffffff;
	line-height: 20px;
	float: right;
	cursor: pointer;
	border-radius: 2px;
	display: block;
	padding: 3px;
	margin: 1px 0;
	background: #00B8D9;
}

.main_qna {
	width: 100%;
	border-top: solid 1px #ddd;
	padding-top:4px;
	margin-top: 18px;
}

.guide .notice {
	min-height: 177px;
	text-align:left;
}

.guide .notice a {
	font-size: 14px;
	color: #555;
	line-height: 24px;
	display: block;
	width: 280px;
	text-overflow: ellipsis;
	white-space: nowrap;
	word-wrap: normal;
	overflow: hidden;
}

.loginWrap {
	text-align: center;
	border: solid 1px #ddd;
	height: 380px;
}

.login_title {
	background: url(../images/common/icon_biglock.png) center 20px no-repeat;
	padding-top: 130px;
	font-size: 15px;
}

.login_input {
	width: 433px;
	margin: 20px auto;
	position: relative;
}

@media only screen and (max-width: 768px) {
	.loginWrap {
		padding: 0 10px;
		font-size: 12px;
	}

	.login_title {
		font-size: 12px;
	}

	.login_input {
		width: 100%;
	}
}

.login_input p {
	margin: 5px 0;
}


element.style {
	ime-mode: disabled;
}

.login_input input[type="text"], .login_input input[type="password"] {
	width: 100%;
	height: 44px;
	font-size: 15px;
	text-align: center;
	line-height: 42px;
}

.loginWrap a.login {
	display: block;
	line-height: 44px;
	background: var(--o_main_color);
	border: solid 1px var(--o_main_color);
	color: #fff;
	font-size: 15px;
	cursor:pointer;
}

.loginWrap a.login:hover {
	color: #fff;
}

.map_cont .map_area {
	width: 100%;
	display: block;
}

.map_cont .map_info {
	font-size: 0;
	margin: 30px 0;
	display: flex;
	justify-content: space-between;
}

.map_cont .map_info li {
	position: relative;
	display: inline-block;
	width: calc(50% - 20px);
	font-size: 16px;
	/*margin-right: 30px;*/
	border: solid 1px #ccc;
	padding: 20px 0;
	text-align: center;
}

.map_cont .map_info li span {
	position: absolute;
	top: 8px;
	left: 10px;
}

.map_li_span {
	display: block;
}

@media only screen and (max-width: 768px) {
	.map_li_span {
		display: none;
	}
}

.login_input p {
	margin: 5px 0;
}

.bustime {
	font-size: 0;
	margin-bottom: 10px;
}

.bustime li {
	display: inline-block;
	width: 25%;
	padding: 5px;
}

.bustime li button {
	border: solid 1px #ddd;
	background: #fff;
	width: 100%;
	height: 50px;
	text-align: center;
	font-size: 15px;
}

.bustime li button:hover, .bustime li button.focus {
	border: solid 2px var(--o_main_color);
}

.month {
	text-align: center;
}

.month span {
	display: inline-block;
	vertical-align: middle;
	font-size: 24px;
	color: #333;
	padding: 0 10px;
}

.bg_gray {
	background: #fafafa;
	border: 1px solid #ddd;
	padding: 10px;
}

.teacher {
	margin-bottom: 20px;
}

.faq {
	margin-bottom: 20px;
}

.faq li {
	position: relative;
	border-bottom: 1px solid #ddd;
	padding: 10px 0;
}

.faq li > a {
	display: inline-block;
	font-size: 16px;
	color: #333;
	padding: 10px 20px 10px 20px;
}

.faq li div {
	display: block;
	background: #fafafa;
	padding: 20px 20px 20px 20px;
	font-size: 16px;
	line-height: 24px;
	border-top: 1px solid #eee;
	margin-top: 10px;
}

.passwrap {
	position: relative;
	width: 520px;
	margin: 20px auto;
	text-align: center;
}

.pass_box {
	margin: 20px 0;
	background: #f5f5f5;
	color: #000;
	padding: 20px;
	border: 1px solid #ddd;
	text-align: center;
}

.pass_box > span {
	display: inline-block;
	padding: 10px 0;
	font-size: 14px;
	line-height: 20px;
}

@media only screen and (max-width: 768px) {
	.passwrap {
		width: 100%;
	}

	.pass_box {
		padding: 15px;
	}

	.pass_box > span {
		font-size: 14px;
		text-align: left;
	}
}
