@charset "UTF-8";
/*
Theme Name: 韓国語の奈良はんぐる教室
Author: あそびラボ
*/


/*=======================================================
reset
=======================================================*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
/*=======================================================
layout
=======================================================*/
html {
    -webkit-text-size-adjust: 100%;
}
body {
	font-family: "メイリオ", Meiryo, "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 18px;
	background: #fff;
	color: #3f2f25;
}

/*=======================================================
common
=======================================================*/
main {
	display: block;
}
.inner {
	width: 1020px;
	margin: 0 auto;
}
img {
	vertical-align: bottom; 
	max-width: 100%;
	height: auto;
}
a {
	text-decoration: none;
	color: #000;
}
a:hover {
	color: #666;
	cursor: pointer;
	transition: .4s;
}
a img:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
}
.sp {
	display: none;
}
/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
	border-radius: 0;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	appearance: button;
	border: none;
	box-sizing: border-box;
	cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
	display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
	outline-offset: -2px;
}
strong {
	font-weight: bold;
}

/*=======================================================
header
=======================================================*/
.g-nav {
	display: none;
}
header {
	position: -webkit-sticky;
    position: -moz-sticky;
    position: -ms-sticky;
    position: -o-sticky;
    position: sticky;
    top: 0;
    z-index: 999;
	background: #fff;
}
header.pc {
	padding: 18px 0 0;
}
header.pc .inner {
	display: flex;
	margin: 0 auto 10px;
	align-items: center;
}
header.pc .inner h1 {
	margin-right: 50px;
}
header.pc .inner .bl_snsIcons {
	margin-right: 16px;
}
header.pc .inner .bl_snsIcons ul {
	display: flex;
}
header.pc .inner .bl_snsIcons img {
	width: 34px;
	height: 34px;
}
header.pc .inner .bl_info {
	display: flex;
	align-items: center;
}
header.pc .inner .bl_info dl {
	margin: 0 20px 0 0;
}
header.pc .inner .bl_info dl dt {
	margin: 0 0 10px;
}
header.pc nav {
	background: #3f2f25;
	background: url(images/nav_bg.png) top center;
	padding: 11px 0 13px;
}
header.pc nav ul {
	width: 1020px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
header.pc nav ul li a {
	color: #3f2f25;
	font-weight: bold;
	background: #fff;
	border-radius: 20px;
	padding: 8px 21px 6px;
	display: block;
}
header.pc nav ul li:first-of-type a {
	padding: 6px 14px 5px;
	font-size: 20px;
}
header.pc nav ul li a:hover {
	background: #dc7023;
	color: #fff;
}

/*=======================================================
footer
=======================================================*/
footer {
	background-color: #493625;
	color: #fff;
}
footer .inner nav {
	padding: 34px 0 20px;
	border-bottom: 1px solid #a59585;
	margin: 0 0 30px;
}
footer .inner nav ul {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
footer .inner nav ul li::after {
	content: "|";
	padding: 0 17px
}
footer .inner nav ul li:last-of-type::after {
	content: none;
}
footer .inner nav ul li a {
	color: #fff;
	font-size: 15px;
}
footer .inner nav ul li a:hover {
	color: #a59585;
}
footer .inner div {
	display: flex;
	justify-content: space-between;
	padding: 0 0 23px;
}
footer .inner div p {
	margin: 0 80px 0 0;
}
footer .inner div dl {
	font-size: 15px;
	line-height: 1.6;
}
footer .inner div dl a {
	color: #fff;
}
footer .inner div dl:first-of-type {
	margin: 0 82px 0 0;
}
footer .copyright {
	font-size: 13px;
	color: #fff;
	text-align: center;
	background: #271506;
	padding: 10px 0 7px;
}
footer .page_top {
    position: fixed;
    bottom: 40px;
    right: 20px;
	transition: 0s;
	z-index:10000;
}
@media only screen and (min-device-width:768px) and (max-device-width:1024px) and (orientation:portrait) {
	footer .inner div p {
		margin: 0 50px 0 0;
	}
	footer .inner div dl:first-of-type {
		margin: 0 50px 0 0;
	}
	footer .inner nav ul {
		margin: 0;
	}
	footer .inner nav ul li::after {
		padding: 0 10px;
	}
}
/*====================================================
スライダー
====================================================*/
.slider {
	max-width: 2000px;
	margin: 0 auto;
	display: none;
}
.slider_sp {
	display: none!important;
}
.slider.slick-initialized{
	display: block; /*slick-initializedが付与されたら表示*/
}
.slider img { width: 100%; height: auto;}
.slider .slick-slide { margin: 0 30px; }
.slick-prev, .slick-next {
    top: 50%;
    display: block;
    width: 43px;
    height: 43px;
    cursor: pointer;
    color: transparent;
    border: none;
    outline: none;
    background: transparent;
}
.slider .slick-next {
	background: url(images/slider_next.png) no-repeat;
	background-size: contain;
	position: absolute;
	right: calc((100vw - 1070px) / 2);
    z-index: 99;
}
.slider .slick-prev {
	background: url(images/slider_prev.png) no-repeat;
	background-size: contain;
	position: absolute;
	left: calc((100vw - 1070px) / 2);
	z-index: 100;
}

/*====================================================
トップページ
====================================================*/
.home main {
	padding: 0 0 200px;
}
.home main .slider_area {
	background: url(images/slider_bg.png) top center no-repeat;
	background-size: 2000px;
	padding: 50px 0;
	height: 643px;
}
.home main .lesson {
	padding: 220px 0 43px;
	margin-top: -160px;
}
.home main .lesson .inner {
	position: relative;
}
.home main .lesson h2 {
	font-size: 48px;
	font-weight: bold;
	color: #304183;
	text-align: center;
	margin: 0 0 35px;
}
.home main .lesson h2 span {
	display: block;
	font-size: 34px;
	color: #3f2f25;
	margin: 0 0 20px;
}
.home main .lesson h2 span em {
	color: #dc7023;
}
.home main .lesson p {
	text-align: center;
	line-height: 1.7;
	margin: 0 0 30px;
}
.home main .lesson .btn {
	margin: 0;
}
.home main .lesson .img2 {
	position: absolute;
	top: 40px;
	left: 13px;
	margin: 0;
}
.home main .lesson .img1 {
	position: absolute;
	bottom: 80px;
	right: 30px;
	margin: 0;
}
.home main .lesson ul.sp {
	display: none;
}
.home main .reason {
	background: #fff8a3;
	padding: 65px 0 50px;
}
.home main .reason .inner {
	position: relative;
}
.home main .reason .heart1 {
	position: absolute;
	top: -20px;
	left: 0;
}
.home main .reason .heart2 {
	position: absolute;
	top: -20px;
	right: 0;
}
.home main .reason h2 {
	font-size: 48px;
	color: #304183;
	font-weight: bold;
	text-align: center;
	margin: 0 18px 20px 0;
	letter-spacing: 0.02em;
}
.home main .reason h2 em {
	font-size: 60px;
}
.home main .reason h2 span {
	display: block;
	color: #3f2f25;
	font-size: 34px;
	margin: 0 0 10px;
}
.home main .reason h2 span em {
	color: #dc7023;
	font-size: 44px;
}
.home main .reason ul {
	display: flex;
	justify-content: space-between;
}
.home main .reason ul li {
	width: 313px;
	background: url(images/reason_bg1.png) no-repeat;
	background-size: 313px;
	text-align: center;
	padding: 29px 0 0;
}
.home main .reason ul li:nth-of-type(2) {
	background: url(images/reason_bg2.png) no-repeat;
	background-size: 313px;
}
.home main .reason ul li:last-of-type {
	background: url(images/reason_bg3.png) no-repeat;
	background-size: 313px;
}
.home main .reason ul li dl dt {
	margin: 0 0 114px;
	position: relative;
}
.home main .reason ul li dl dt span {
	display: block;
   	position: absolute;
   	top: -38px;
   	left: 11px;
   	right: 0;
}
.home main .reason ul li dl dd:first-of-type {
	background: rgba(73,88,143,.9);
	font-size: 24px;
	font-weight: bold;
	color: #fff;
	width: 190px;
	border-radius: 20px;
	padding: 10px 0 6px;
	margin: 0 auto 43px;
}
.home main .reason ul li dl dd:last-of-type {
	text-align: left;
	padding: 0 20px;
	line-height: 1.6;
}
.home main .class {
	padding: 25px 0 65px;
	background: #493625;
	position:relative;
}
.home main .class::after{
	content:"";
	display:block;
	width:100%;
	height:2px;
	background: #493625;
	position:absolute;
	bottom:-1px;
	left:0;
}
.home main .class h2 {
    height: 113px;
    margin: 0 0 20px;
    background: url(https://1guru.jp/wp/wp-content/themes/nh/images/class_h2_bg_test.png) top right 50px / 127px 113px no-repeat;
    color: #fff8a3;
    font-size: 40px;
    font-weight: bold;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}
/**教室名**/
.home main .class h3 {
    color: #fff;
    font-size: 28px;
    font-weight: bold;
    height:62px;
    line-height:65px;
    background: #374784;
    border: 1px solid #fff;
    padding: 0 25px;
    margin: 0 0 12px;
    letter-spacing: 0.02em;
    position:relative;
}
/**地図 + 住所**/
.home main .class .info{
    display:block;
    min-height:390px;
    padding:0 0 0 520px;
    color:#fff;
    position:relative;
}
/**地図**/
.home main .class .map{
    position:absolute;
    top:0;
    left:0;
}
.home main .class .map iframe{
    width:490px;
    height:390px;
}
/**住所**/
.home main .class .info dl{
    margin:0 0 20px;
}
.home main .class .info dt,
.home main .class .info dd{
    height:30px;
    line-height:32px;
}
.home main .class .info dt{
    width:70px;
    margin:0 0 10px;
    background:#fff;
    color:#493625;
    font-weight:bold;
    text-align:center;
}
.home main .class .info dd{
    margin:0 0 15px;
}
.home main .class .info dd a{
    color:#fff;
    font-weight:normal;
    pointer-events:none;
    display:inline-block;
}
/**交通手段**/
.home main .class .info h4{
    margin:0 0 5px;
    font-weight:normal;
}
.home main .class .info p + h4{
    margin-top:15px;
}
.home main .class .info h4 ~ p{
    line-height:1.5;
}
/*グーグルマップで見るボタン*/
.home main .class .info .btn a{
    width:200px;
    height:40px;
    margin:35px 0 0;
    text-align:center;
    line-height:42px;
    color: #fff;
    font-size: 16px;
    font-weight:bold;
    background: #dc7023;
    border-radius: 20px;
    display:block;
}
.home main .join {
	background: url(images/join_bg.png) top center no-repeat;
	background-size: 2000px;
	padding: 42px 0 43px;
}
.home main .join h2 {
	margin: 0 0 48px;
}
.home main .join h2 + div {
	display: flex;
	justify-content: space-between;
	margin: 0 0 45px;
}
.home main .join h2 + div h3 {
	font-size: 28px;
	font-weight: bold;
	margin: 0 0 15px 5px;
	letter-spacing: 0.01em;
}
.home main .join h2 + div ul {
	border-radius: 20px;
	border: 1px solid #304183;
	background: #fff;
	padding: 20px 38px 17px;
	font-size: 20px;
	line-height: 1.6;
	margin: 0 0 25px;
}
.home main .join h2 + div h4 {
	font-weight: bold;
	font-size: 20px;
	color: #dc7023;
	margin: 0 0 15px;
}
.home main .join h2 + div p {
	line-height: 1.6;
}
.home main .introduce {
	background: url(images/introduce_bg.png) top center no-repeat;
	background-size: 2000px;
	padding: 45px 0 0;
    height: 614px;
	position:relative;
	z-index:5;
}
.home main .introduce h2 {
	text-align: center; 
	font-size: 48px;
	font-weight: bold;
	color: #304183;
	margin: 0 0 15px;
	text-shadow: #fff 1px 1px 3px;
}
.home main .introduce h2 + p {
	font-size: 36px;
	color: #3f2f25;
	font-weight: bold;
	margin: 0 0 30px;
	text-align: center;
	text-shadow: #fff 1px 1px 3px;
}
.home main .introduce .box {
	position: relative;
	height: 437px;
}
.home main .introduce .box div {
	background: #fff;
	padding: 50px 65px;
	border: 1px solid #404f8c;
	width: 641px;
	height: 387px;
	line-height: 1.7;
	position: absolute;
	top: 0;
	right: 0;
}
.home main .introduce .box div p:last-of-type {
	text-align: right;
}
.home main .introduce .box > p {
	position: absolute;
	bottom: 1px;
	left: 0;
	z-index: 2;
}
.home main .news {
	padding: 100px 0 0;
	background: linear-gradient(#ecf5fb,#fff,#fff,#fff);
}
.home main .news h2 {
	font-size: 40px;
	color: #304183;
	font-weight: bold;
	margin: 0 0 27px;
	text-align: center;
}
.home main .news ul {
	margin: 0 0 36px;
}
.home main .news ul li {
	background: #eef1f3;
	border-radius: 20px;
	margin: 0 0 13px;
	height: 50px;
	padding: 3px 20px 0;
	display: flex;
	align-items: center;
}
.home main .news ul li span {
	background: #493625;
	width: 134px;
	color: #fff;
	font-size: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 28px;
	border-radius: 20px;
	margin: 0 30px 0 0;
}
.home main .news ul li a {
	overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
	line-height: 1.5;
}
.home main .news p a {
	display: flex;
	align-items: center;
	width: 235px;
	height: 45px;
	color: #fff;
	background: #304183;
	border-radius: 20px;
	margin: 0 auto;
	justify-content: center;
	font-weight: bold;
	position: relative;
	padding: 5px 0 0;
}
.home main .news p a::after {
	position: absolute;
	content: "▶";
	right: 20px;
	top: 39%;
	font-size: 12px;
}
.home main .news p a:hover {
	opacity: .7;
}
/***20190905追加***/
.home main .voice{
	padding:65px 0 60px;
	background:#493625;
	position:relative;
}
.home main .voice::after{
	content:"";
	display:block;
	width:100%;
	height:3px;
	background:#304183;
	position:absolute;
	left:0;
	bottom:-2px;
}
.home main .voice h2{
    font-size: 34px;
    color: #fff;
    font-weight: bold;
    text-align: center;
    margin: 0 0 40px;
	background: url(images/class-underline_dot.png) bottom center no-repeat;
    background-size: 1018px;
    padding: 0 0 15px;
}
.home main .voice ul{
	width: 1020px;
    max-height: 350px;
    margin: 0 auto;
    background: #fff;
	overflow-y: scroll;
    padding: 35px 25px;
}
.home main .voice ul::-webkit-scrollbar{
    height:10px;
}
.home main .voice ul::-webkit-scrollbar-track{
    background: #eef1f3;
}
.home main .voice ul::-webkit-scrollbar-thumb {
    background: #dc7023;
}
.home main .voice ul li{
	margin:0 0 20px;
	padding:0 10px 20px;
	border-bottom:1px dashed #304183;
	line-height:1.5;
}
.home main .voice ul li:last-of-type{
	margin:0;
	padding:0 10px;
	border:none;
}
.home main .voice ul li p{
	margin:0 0 1rem;
}
.home main .voice ul li .info{
	margin:0;
	font-size:16px;
	font-weight:bold;
	color:#304183;
}

.home main .apply{
	margin:-160px 0 0;
	padding:195px 0 60px;
	position:relative;
	z-index:1;
}
.home main .apply .trial{
	width:800px;
	margin:0 auto 20px;
	padding:25px 30px;
	background: #fff8a3;
	position: relative;
	z-index: 2;
}
.home main .apply .trial h2{
	font-size:28px;
	font-weight:bold;
	text-align:center;
	margin:0 0 15px;
}
.home main .apply .trial h3 a {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 20px 7px;
    background: #dc7023;
    border-radius: 5px;
    color: #fff;
    width: 260px;
    margin: 30px auto 0;
	border: 1px solid #dc7023;
}
.home main .apply .trial h3 a:hover {
	background: #fff;
	color: #dc7023;
}
.home main .apply .trial p:first-of-type{
	margin:0 0 20px;
	text-align:center;
	line-height:1.5;
}
.home main .apply .trial .day{
	/*min-height:72px;*/
	padding:0 0 0 105px;
	font-weight:bold;
	color:#dc7023;
	line-height:1.7;
	position:relative;
	display:flex;
	align-items:center;
}
.home main .apply .trial .day::before {
    content: "";
    background: url(images/entry-beginner.png) no-repeat;
    background-size: contain;
    display: block;
    width: 67px;
    height: 92px;
    position: absolute;
    top: 0;
    left: 20px;
    bottom: 30px;
    margin: auto 0;
}
.home main .apply .trial .day.no{
	margin:0;
	padding:0;
	justify-content:center;
}
.home main .apply .trial .day.no::before {
	left:100px;
}
.home main .apply .box{
	width:1020px;
	margin:0 auto;
}
.home main .apply > h2{
	background:#304183;
	font-size:30px;
	font-weight:bold;
    color: #fff;
	text-align:center;
	margin:0 auto 30px;
	padding:15px 0 10px;
	width: 1020px;
}
.home main .apply .box > p{
	text-align:center;
	line-height:1.6;
	margin:0 0 20px;
}
.home main .apply .box > p,
.home main .apply .box address{
	position:relative;
	z-index:5;
}
.home main .apply .box address{
	margin:0 0 50px;
	text-align:center;
}
.home main .apply .box address ul{
	display:flex;
	justify-content:center;
}
.home main .apply .box address ul li:first-of-type{
	margin:0 10px 0 0;
}
.home main .apply .box address li:first-of-type a{
    text-decoration: underline;
    color: #1360c6;
}
.home main .apply .box address li:last-of-type a{
    pointer-events:none;
}
#top_form{
	width:1020px;
	margin:0 auto;
	padding: 50px 163px 35px;
	background: #ebebeb;
	border-radius: 10px;
}
#top_form form{
	margin:-210px 0 0;
	padding: 210px 0 0;
	position:relative;
	z-index:1;
}
#contact #top_form form{
	margin: 0;
	padding: 0;
}
#top_form form table{
	margin: 0 0 46px;
}
#top_form tr {
	display: flex;
	align-items: center;
	margin: 0 0 22px;
}
#top_form tr:last-of-type {
	align-items: flex-start;
	margin: 0;
}
#top_form th {
	width: 278px;
	text-align: left;
	flex-shrink: 0;
}
#top_form th span {
	height: 23px;
	width: 50px;
	color: #fff;
	background: #da3a59;
	font-size: 16px;
	margin: 0 0 0 15px;
	display: inline-block;
    text-align: center;
    padding: 4px 0 0;
	font-weight: bold;
}
#top_form td input,
#top_form td textarea,
#top_form td select {
	background: #fff;
	border: 1px solid #9e9e9e;
	border-radius: 10px;
	padding: 10px;
	width: 416px;
	font-size: 18px;
}
#top_form td input:focus,
#top_form td textarea:focus,
#top_form td select:focus{
	outline: none;
}
#top_form tr.day td input {
	width: 92px;
	width: 162px;
}
#top_form td textarea {
	height: 220px;
}
#top_form input[type="submit"] {
	border: none;
	background: #dc7023;
	color: #fff;
	cursor: pointer;
	font-size: 28px;
	width: 245px;
	height: 60px;
	padding: 3px 0 0;
	border-radius: 7px;
	font-weight: bold;
}
#top_form input[type="submit"]:hover{
	opacity:0.7;
}
#top_form .mw_wp_form .error {
    text-align: left;
    margin: 10px 0 0;
}
#top_form form table + p{
    line-height: 1.5;
    margin: 0 0 30px;
	text-align:center;
}
#top_form input[type="submit"] {
    border: none;
    background: #dc7023;
    color: #fff;
    cursor: pointer;
    font-size: 28px;
    width: 245px;
    height: 60px;
    padding: 3px 0 0;
    border-radius: 7px;
    font-weight: bold;
}
#top_form section.thanks {
	margin: 65px 0 0;
	padding: 0 0 250px;
}
#top_form section.thanks .inner {
	background: url(images/thanks_bg.png) top center no-repeat;
	background-size: contain;
	width: 1020px;
	height: 335px;
	position: relative;
	text-align: left;
}
#top_form section.thanks .inner h2 {
	color: #304183;
	font-weight: bold;
	font-size: 36px;
	margin: 0 0 25px;
	position: absolute;
	top: 55px;
	left: 360px;
}
#top_form section.thanks .inner h2 + p {
	margin: 0 0 20px;
	position: absolute;
	top: 115px;
    left: 360px;
	letter-spacing: 0.05em;
}
#top_form section.thanks .inner .back {
	background: url(images/thanks_back_bg.png) top center no-repeat;
    background-size: contain;
    width: 399px;
    height: 111px;
    position: absolute;
    bottom: 9px;
    right: 62px;
}
#top_form section.thanks .inner .back a {
	background: #d62b4c;
	color: #fff;
	font-size: 20px;
	border-radius: 20px;
	font-weight: bold;
    display: block;
    width: 290px;
    margin: 45px 0 0 60px;
    text-align: center;
    border-radius: 30px;
    height: 47px;
	padding: 10px 15px 0 0;
	position: relative;
}
#top_form section.thanks .inner .back a::after {
	content: "";
	background: url(images/thanks_back.png) no-repeat;
	background-size: contain;
	width: 30px;
	height: 26px;
	display: block;
	position: absolute;
	right: 20px;
	top: 9px;
}
#top_form section.thanks .inner .back a:hover {
	opacity: .7;
}
.confirm_trial main{
	padding:0 0 120px;
}
.confirm_trial .entry_form > section,
.confirm_trial .title_wrap,
.confirm_trial .breadcrumbs,
.thanks_trial .title_wrap,
.thanks_trial .breadcrumbs{
	position:relative;
	z-index:5;
}
.confirm_trial #top_form form{
	margin:-850px 0 0;
	padding: 850px 0 0;
}
.thanks_trial .mw_wp_form{
	margin:-610px 0 0;
	padding: 610px 0 0;
}
#top_form .mw_wp_form_preview table {
	width: 100%;
}
#top_form .mw_wp_form_preview table tr {
    width: 100%;
    border-bottom: 1px solid #000;
    padding: 0 0 22px;
}
#top_form .mw_wp_form_preview table th {
    font-weight: bold;
}
/*フリースペース*/
.home main #free_space {
	max-width: 1020px;
	margin: 0 auto 50px;
}
.home main #free_space h2 {background: #f7e59d;
    font-size: 26px;
    padding: 15px 30px 13px;
    border-radius: 10px;
    letter-spacing: 0.05em;
    font-weight: bold;
    margin: 25px 0;
    line-height: 1.3;
    color: #3f2f25;
}
.home main #free_space h3 {
	font-size: 22px;
	font-weight: bold;
	margin: 23px 0;
    text-indent: -31px;
    padding: 0 0 0 31px;
    line-height: 1.3;
    color: #3f2f25;
}
.home main #free_space h3:before {
    content: "";
    background: url(https://1guru.jp/wp/wp-content/themes/nh/images/single_circle.png) no-repeat;
    width: 16px;
    height: 16px;
    display: inline-block;
    background-size: contain;
    margin: 0 12px 0 4px;
}
.home main #free_space p {
	margin: 0 0 20px;
	line-height: 1.5;
}
.home main #free_space .mb_20 {
	margin: 0 0 20px;
}
.home main #free_space .mb_30 {
	margin: 0 0 30px;
}
.home main #free_space .mb_40 {
	margin: 0 0 40px;
}
.home main #free_space .f_12 {
	font-size: 12px;
}
.home main #free_space .f_14 {
	font-size: 14px;
}
.home main #free_space .f_16 {
	font-size: 16px;
}
.home main #free_space .f_20 {
	font-size: 20px;
}
.home main #free_space .f_22 {
	font-size: 22px;
}
.home main #free_space .f_24 {
	font-size: 24px;
}
.home main #free_space .f_26 {
	font-size: 26px;
}
.home main #free_space .f_28 {
	font-size: 28px;
}
@media screen and (max-width : 750px){
	.home main #free_space {
		padding: 0 30px;
	}
}
/*=======================================================
下層ページ共通
=======================================================*/
main {
	background: url(images/pass_footer.png) bottom center no-repeat;
	background-size: 2000px;
}
.title_wrap {
	background: url(images/page_header.png) top center no-repeat;
	background-size: 2000px;
	height: 164px;
}
.title_wrap .inner {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 35px;
	font-weight: bold;
	color: #3f2f25;
	letter-spacing: 0.05em;
}
.breadcrumbs {
	background: #765b4a;
	height: 30px;
}
.breadcrumbs .inner {
	height: 100%;
	color: #fff;
	display: flex;
	align-items: center;
	font-size: 16px;
}
.breadcrumbs .inner a {
	color: #fff;
	text-decoration: underline;
	letter-spacing: 0.05em;
}
.breadcrumbs .inner span {
	margin: 0 10px 0 0;
	line-height: 1.4;
}
.breadcrumbs .inner span.title {
	flex-shrink: 0;
}
.breadcrumbs .inner span.current {
	white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
/*記事内無料体験ボタン*/
.single .trial_btn{
	display:flex;
	justify-content:center;
}
.single .trial_btn:hover{
	opacity: .7;
}
.single .trial_btn img{
	margin:0!important;
}

/*====================================================
ページナビ
====================================================*/
.wp-pagenavi {
	display: flex;
	align-items: center;
	justify-content: center;
}
.wp-pagenavi .pages,
.wp-pagenavi .extend,
.wp-pagenavi .last,
.wp-pagenavi .first {
	display: none;
}
.wp-pagenavi .page,
.wp-pagenavi .nextpostslink,
.wp-pagenavi .previouspostslink {
	border: 1px solid #222;
	padding: 7px 10px;
    margin: 0 3px;
	font-weight: bold;
}
.wp-pagenavi .current {
	border: 1px solid #222;
	padding: 7px 10px;
    margin: 0 3px;
	background: #222;
	color: #fff;
	font-weight: bold;
}



/*====================================================
無料体験を予約するエリア
====================================================*/
main .contact_box {
	margin: 40px auto;
	width: 1020px;
}
main .common_contact_area {
	background: #fff;
	border: 2px solid #afd3e2;
	border-radius: 20px;
	padding: 26px  27px 25px 48px;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
 }
main .common_contact_area dl {
	text-align: center;
}
main .common_contact_area dl dt {
	font-size: 26px;
	font-weight: bold;
	margin: 0 0 15px;
	color: #3f2f25;
}
main .common_contact_area dl dd:first-of-type,
main .common_contact_area dl dd:nth-of-type(2) {
	margin: 0 0 12px;
}

/*====================================================
教室案内
====================================================*/
.class main {
	padding: 0 0 200px;
}
.class main section {
	padding: 55px 0;
}
.class main section h3 {
	font-size: 34px;
	letter-spacing: 0.05em;
	font-weight: bold;
	text-align: center;
	margin: 0 0 30px;
}
.class main section h3 em {
	color: #dc7023;
}
.class main section.classroom ul {
	display: flex;
	justify-content: space-between;
}
.class main section.classroom ul li {
	background: #fff8a3;
	width: 495px;
	padding: 16px 10px;
}
.class main section.classroom ul li h4 {
	background: url(images/class-tomio.png) top center no-repeat;
	background-size: contain;
	width: 474px;
	height: 138px;
	font-size: 32px;
	font-weight: bold;
	color: #fff;
	display: flex;
    align-items: center;
    padding: 0 0 0 25px;
    letter-spacing: 0.05em;
    line-height: 1.3;
	margin: 0 0 15px;
}
.class main section.classroom ul li:last-of-type h4 {
	background: url(images/class-saidaiji.png) top center no-repeat;
	background-size: contain;
}
.class main section.classroom ul li dl {
	margin: 0 0 14px;
	padding: 0 0 5px;
	border-bottom: 1px dashed #413126;
}
.class main section.classroom ul li dl dt {
	background: #765b4a;
	color: #fff;
	width: 125px;
	height: 47px;
	display: flex;
	align-items: center;
	padding: 2px 0 0 40px;
	font-size: 18px;
	float: left;
	clear: left;
	margin: 0 0 10px;
	position: relative;
}
.class main section.classroom ul li dl dt::before {
	content: "";
	background: url(images/class-icon_address.png) top center no-repeat;
	background-size: contain;
	display: block;
	width: 16px;
	height: 23px;
	position: absolute;
	top: 12px;
	left: 10px;
}
.class main section.classroom ul li dl dt.station::before {
	content: "";
	background: url(images/class-icon_station.png) top center no-repeat;
	background-size: contain;
	width: 19px;
	height: 24px;
}
.class main section.classroom ul li dl dt.parking::before {
	content: "";
	background: url(images/class-icon_parking.svg) top center no-repeat;
	background-size: contain;
	fill: #fff;
	width: 19px;
	height: 24px;
}
.class main section.classroom ul li dl dd {
	padding: 0 0 0 28px;
	height: 47px;
	margin: 0 0 10px;
	display: flex;
	align-items: center;
	line-height: 1.2; 
}
.class main section.classroom ul li p a {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #dc7023;
	color: #fff;
	font-size: 18px;
	font-weight: bold;
	border-radius: 20px;
	width: 236px;
	height: 44px;
	margin: 0 auto;
	position: relative;
}
.class main section.classroom ul li p a::after {
	content: "▶";
	position: absolute;
	top: 16px;
    right: 20px;
    font-size: 13px;
}
.class main section.classroom ul li p a:hover {
	opacity: .7;
}
.class main section.level {
	background: #493625;
	color: #fff;
	padding: 55px 0 20px;
}
.class main section.level h3 {
	background: url(images/class-underline_dot.png) bottom center no-repeat;
	background-size: 1018px;
	padding: 0 0 15px;
}
.class main section.level h3 + p {
	text-align: center;
	line-height: 1.5;
	margin: 0 0 45px;
}
.class main section.level ol {
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 35px;
}
.class main section.level ol li {
	width: 325px;
	height: 127px;
	background: linear-gradient(#fffbc9, #ffe082);
	margin: 0 19px 13px 0;
	box-shadow: 2px 2px 4px #302318;
	color: #493625;
	padding: 16px 15px;
	display: flex;
	position: relative;
}
.class main section.level ol li:nth-of-type(3),
.class main section.level ol li:nth-of-type(6) {
	margin: 0 0 13px;
}
.class main section.level ol li h4 {
	font-size: 28px;
	font-weight: bold;
	color: #fff;
	background: #f19d31;
	width: 90px;
    height: 95px;
	border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
	margin: 0 14px 0 0;
	flex-shrink: 0;
}
.class main section.level ol li h4.color-beginner {
	background: #4fb538;
}
.class main section.level ol li h4.color-intermediate {
	background: #f88be7;
}
.class main section.level ol li h4.color-advanced {
	background: #1465b0;
}
.class main section.level ol li h5 {
	font-size: 20px;
	color: #493625;
	font-weight: bold;
	margin: 3px 0 0;
}
.class main section.level ol li p {
	font-size: 15px;
	line-height: 1.3;
}
.class main section.level ol li p.star {
	margin: 3px 0 5px;
	color: #dc7023;
	font-size: 16px;
	letter-spacing: 0.05em;
}
.class main section.level ol li a {
	display: block;
	width: 100%;
	height: 127px;
	position: absolute;
	top: 0;
	left: 0;
}
.class main section.level ol li a:hover {
	background: #fff;
	opacity: .5;
}
.class main section.level ol li a::after {
	background: #dc7023;
    content: "▶";
    color: #fff;
    position: absolute;
    right: 0;
    height: 100%;
    top: 0;
    padding: 60px 2px 0;
}
.class main section.teachers {
	background: #fffaab;
	padding: 55px 0 25px;
}
.class main section.teachers h3 {
	background: url(images/class-underline_dot2.png) bottom center no-repeat;
	background-size: 1018px;
	padding: 0 0 15px;
}
.class main section.teachers h3 + p {
	text-align: center;
	line-height: 1.5;
	margin: 0 0 45px;
}
.class main section.teachers ol li {
	display: flex;
	justify-content: space-between;
	margin: 0 0 40px;
}
.class main section.teachers ol li figure {
	flex-shrink: 0;
}
.class main section.teachers ol li figure img {
	width: 272px;
}
.class main section.teachers ol li > div {
	width: 700px;
}
.class main section.teachers ol li > div h4 {
	background: #e47121;
	color: #fff;
	font-size: 24px;
	font-weight: bold;
	display: flex;
	align-items: center;
	height: 48px;
	border-radius: 7px;
	padding: 2px 25px 0 25px;
	margin: 0 0 20px;
}
.class main section.teachers ol li > div h4 span {
	background: #fff;
	color: #493625;
	border-radius: 5px;
	font-size: 18px;
	height: 30px;
	width: 136px;
	display: flex;
    align-items: center;
    justify-content: center;
	font-weight: normal;
	margin: 0 20px 0 0;
	line-height: 1.3;
	padding: 1px 0 0;
}
.class main section.teachers ol li > div p {
	line-height: 1.5;
	margin: 0 0 20px;
}
.class main section.teachers ol li > div p strong {
	color: #cf2525;
}
.class main section.teachers ol li > div p.comment {
	background: #fff;
	border-radius: 10px;
	border: 2px solid #e47121;
	padding: 20px 35px;
}
.class main .common_contact_area {
	margin: 55px 0;
}
.single.single-class_level main article h1 + p {
	display: none;
}

/*====================================================
アクセス
====================================================*/
.access main {
	padding: 0 0 200px;
}
.access main section {
	padding: 55px 0;
}
.access main section.map h2 {
	text-align: center;
	font-size: 34px;
	font-weight: bold;
	color: #493625;
	padding: 170px 0 20px;
	margin: -170px 0 50px;
	background: url(images/access_dot.png) bottom center no-repeat;
	background-size: 1018px;
}
.access main section.map h2 + div {
	display: flex;
	margin: 0 0 75px;
}
.access main section.map h2:last-of-type + div {
	margin: 0 0 60px;
}
.access main section.map h2 + div figure {
	flex-shrink: 0;
	margin: 0 26px 0 0;
}
.access main section.map dl:first-of-type {
	margin: 0 0 24px;
}
.access main section.map h2:last-of-type + div dl {
	margin: 0 0 20px;
}
.access main section.map dl:first-of-type dt {
	background: #765b4a;
	color: #fff;
	width: 127px;
	height: 42px;
	display: flex;
	align-items: center;
	padding: 0 0 0 40px;
	line-height: 1.5;
	position: relative;
	margin: 0 0 10px;
	float: left;
	clear: left;
}
.access main section.map dl:first-of-type dt::before {
	content: "";
	background: url(images/class-icon_address.png) top center no-repeat;
	background-size: contain;
	display: block;
	width: 18px;
	height: 26px;
	position: absolute;
	top: 9px;
	left: 10px;
}
.access main section.map dl:first-of-type dt.station::before {
	content: "";
	background: url(images/class-icon_station.png) top center no-repeat;
	background-size: contain;
	display: block;
	width: 19px;
	height: 25px;
	position: absolute;
	top: 9px;
	left: 10px;
}
.access main section.map dl:first-of-type dd {
	height: 42px;
	margin: 0 0 10px;
	display: flex;
    align-items: center;
    padding: 0 0 0 28px;
	line-height: 1.3;
}
.access main section.map dl:last-of-type {
	margin: 0 0 40px;
}
.access main section.map dl:last-of-type dt {
	font-weight: bold;
	font-size: 19px;
	margin: 0 0 5px -0.5em;
}
.access main section.map dl:last-of-type dd {
	line-height: 1.5;
}
.access main section.map dl:last-of-type dt:not(first-of-type) {
	margin: 18px 0 5px -0.5em;
}
.access main section.map dl:last-of-type dd span {
	color: #455cb3;
}
.access main section.map dl:last-of-type dd strong {
	font-weight: bold;
}
.access main section.map dl:last-of-type dd em {
	font-weight: bold;
	color: #c60c30;
}
.access main section.map dl:last-of-type dd:last-of-type {
	margin: 0 0 5px -0.5em;
}
.access main section.map dl:last-of-type dd.tel {
    margin: 0 0 5px;
}
.access main section.map div p a {
	color: #fff;
	background: #dc7023;
	border-radius: 20px;
	height: 44px;
	width: 244px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	position: relative;
}
.access main section.map div p a:hover {
	opacity: .7;
}
.access main section.map div p a::after {
	content: "▶";
	position: absolute;
	right: 10px;
	top: 15px;
    font-size: 14px;
}
.access main section.map ul {
	display: flex;
	justify-content: space-between;
}
.access main section.map ul li {
}
.access main section.comic {
	background: #fff8a3;
	text-align: center;
	position: relative;
}
.access main section.comic::after {
	content: "";
	background: url(images/access_arrow.png) no-repeat;
	position: absolute;
	display: block;
	width: 269px;
	height: 85px;
	background-size: contain;
	left: 0;
	right: 0;
	margin: 0 auto;
	bottom: -40px;
}
.access main section.comic figure {
	margin: 0 0 45px;
}
.access main section.comic h2 {
	background: none;
	padding: 0;
	margin: 0;
}

/*====================================================
レッスン内容・料金
====================================================*/
.lesson-price main {
	padding: 0 0 200px;
}
.lesson-price main section {
	padding: 55px 0;
}
.lesson-price main section h2 {
	font-size: 34px;
	font-weight: bold;
	text-align: center;
	margin: 0 0 35px;
	line-height: 1.5;
}
.lesson-price main section h2 em {
	color: #dc7023;
}
.lesson-price main section.about h2 + div {
	background: #fff8a3;
	padding: 12px 32px 24px;
	margin: 0 auto 40px;
	text-align: center;
	width: 714px;
}
.lesson-price main section.about h2 + div h3 {
	margin: 0 0 17px;
}
.lesson-price main section.about h2 + div ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.lesson-price main section.about h2 + div ul li {
	background: #fff;
	border: 2px solid #dc7023;
	border-radius: 15px;
	width: 305px;
	height: 75px;
	display: flex;
	align-items: center;
	margin: 0 10px 14px;
	position: relative;
	padding: 0 0 0 125px;
}
.lesson-price main section.about h2 + div ul li::before {
	content: "";
	background: url(images/lesson-price/read-img.png) top center no-repeat;
	background-size: contain;
	display: block;
	width: 40px;
	height: 55px;
	position: absolute;
	left: 29px;
	top: 8px;
}
.lesson-price main section.about h2 + div ul li:nth-of-type(2)::before {
	background: url(images/lesson-price/listen-img.png) top center no-repeat;
	background-size: contain;
	width: 47px;
	height: 49px;
	left: 29px;
	top: 11px;
}
.lesson-price main section.about h2 + div ul li:nth-of-type(3)::before {
	background: url(images/lesson-price/write-img.png) top center no-repeat;
	background-size: contain;
	width: 56px;
	height: 40px;
	left: 18px;
	top: 18px;
}
.lesson-price main section.about h2 + div ul li:last-of-type::before {
	background: url(images/lesson-price/talk-img.png) top center no-repeat;
	background-size: contain;
	width: 66px;
	height: 49px;
	left: 15px;
	top: 10px;
}
.lesson-price main section.about h4 {
	font-size: 28px;
	text-align: center;
	font-weight: bold;
	line-height: 1.3;
	margin: 0 0 30px;
}
.lesson-price main section.about h4 em {
	color: #dc7023;
}
.lesson-price main section.about h4 + ul {
	display: flex;
	justify-content: space-between;
}
.lesson-price main section.about h4 + ul li {
	background: #d4e7ff;
	border-radius: 10px;
	width: 243px;
	height: 117px;
	font-size: 22px;
	font-weight: bold;
	padding: 0 0 10px;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	text-align: center;
	line-height: 1.3;
	position: relative;
}
.lesson-price main section.about h4 + ul li::before {
	content: "";
	background: url(images/lesson-price/heart1.png) top center no-repeat;
	background-size: contain;
	display: block;
	width: 48px;
	height: 20px;
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	top: 16px;
}
.lesson-price main section.about h4 + ul li:nth-of-type(even) {
	background: #ffd9e0;
}
.lesson-price main section.about h4 + ul li:nth-of-type(even)::before {
	content: "";
	background: url(images/lesson-price/heart2.png) top center no-repeat;
	background-size: contain;
	width: 65px;
	height: 48px;
	top: -12px;
}
.lesson-price main section.price {
	background: #493625;
}
.lesson-price main section.price h2 {
	color: #fff;
	background: url(images/class-underline_dot.png) bottom center no-repeat;
	background-size: 1018px;
	padding: 0 0 15px;
	margin: 0 0 30px;
}
.lesson-price main section.price h2 + div {
	background: #fff;
	border-radius: 10px;
	width: 100%;
	padding: 42px 43px 32px 44px;
	overflow: hidden;
}
.lesson-price main section.price dl {
	overflow: hidden;
}
.lesson-price main section.price dl dt {
	font-size: 22px;
	float: left;
	clear: left;
	width: 206px;
	margin: 0 0 25px;
	line-height: 1.2;
	padding: 0 0 0 12px;
}
.lesson-price main section.price dl dt span {
	font-size: 18px;
}
.lesson-price main section.price dl dd {
	float: left;
	font-size: 24px;
	font-weight: bold;
	margin: 0 0 25px;
}
.lesson-price main section.price dl dd span {
	font-size: 18px;
	font-weight: normal;
	margin: 0 0 0 20px;
}
.lesson-price main section.price dl dd span em {
	color: #c60c30;
}
.lesson-price main section.price dl:first-of-type {
	border-bottom: 1px solid #493625;
	margin: 0 0 25px;
}
.lesson-price main section.price dl:first-of-type dt:last-of-type,
.lesson-price main section.price dl:first-of-type dd:last-of-type {
	margin: 0 0 15px;
}
.lesson-price main section.price dl:last-of-type dt {
	width: 172px;
}
.lesson-price main section.price dl:last-of-type dd {
	font-size: 28px;
	color: #c60c30;
}
.lesson-price main section.price dl:last-of-type dd span {
	font-size: 18px;
	margin: 0;
}
.lesson-price main section.contents {
	background: #ecf5fb;
	padding: 55px 0 25px;
}
.lesson-price main section.contents h2 {
	background: url(images/class-underline_dot2.png) bottom center no-repeat;
	background-size: 1018px;
	padding: 0 0 15px;
	margin: 0 0 30px;
}
.lesson-price main section.contents h2 + p {
	text-align: center;
	margin: 0 0 48px;
}
.lesson-price main section.contents ol > li {
	display: flex;
	margin: 0 0 19px;
	padding: 0 0 19px;
	border-bottom: 1px solid #c8c8c8;
	flex-direction: row-reverse;
    justify-content: flex-end;
}
.lesson-price main section.contents ol li figure {
	margin: 0 40px 0 0;
}
.lesson-price main section.contents ol li > div p.txt {
	margin: 0 0 20px;
	display: flex;
	align-items: center;
}
.lesson-price main section.contents ol li > div p.txt span:first-of-type {
	font-weight: bold;
	background: #dadada;
	border-radius: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 150px;
	height: 32px;
	line-height: 1.3;
	margin: 0 20px 0 0;
}
.lesson-price main section.contents ol li > div h3 {
	font-size: 24px;
	font-weight: bold;
	margin: 0 0 35px;
}
.lesson-price main section.contents ol li > div ul {
	display: flex;
}
.lesson-price main section.contents ol li > div ul li {
	width: 325px;
    height: 127px;
    background: linear-gradient(#fffbc9, #ffe082);
    box-shadow: 2px 2px 4px #9a9fa3;
    color: #493625;
    padding: 16px 15px;
    display: flex;
    position: relative;
	margin: 0 19px 0 0;
}
.lesson-price main section.contents ol li > div ul li a::after {
    background: #dc7023;
    content: "▶";
    color: #fff;
    position: absolute;
    right: 0;
    height: 100%;
    top: 0;
    padding: 60px 2px 0;
}
.lesson-price main section.contents ol li > div ul li a:hover {
	opacity: .7;
}
.lesson-price main section.contents ol li > div ul li h4 {
    font-size: 28px;
    font-weight: bold;
    color: #fff;
    background: #f19d31;
    width: 90px;
    height: 95px;
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 14px 0 0;
    flex-shrink: 0;
}
.lesson-price main section.contents ol li > div ul li h4.color-beginner {
    background: #4fb538;
}
.lesson-price main section.contents ol li > div ul li h4.color-intermediate {
    background: #f88be7;
}
.lesson-price main section.contents ol li > div ul li h4.color-advanced {
    background: #1465b0;
}
.lesson-price main section.contents ol li > div ul li h5 {
    font-size: 20px;
    color: #493625;
    font-weight: bold;
    margin: 3px 0 0;
}
.lesson-price main section.contents ol li > div ul li p.star {
    margin: 3px 0 5px;
    color: #dc7023;
    font-size: 16px;
    letter-spacing: 0.05em;
}
.lesson-price main section.contents ol li > div ul li p {
    font-size: 17px;
    line-height: 1.3;
}
.lesson-price main section.contents ol li:last-of-type {
	border: none;
}
.lesson-price main section.contents ol li:last-of-type > p {
	width: 174px;
	height: 132px;
	background: #125797;
	color: #fff;
	font-size: 22px;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1.4;
	margin: 0 40px 0 0;
}
.lesson-price main section.contents ol li a {
    display: block;
    width: 100%;
    height: 127px;
    position: absolute;
    top: 0;
    left: 0;
}
.lesson-price main section.contents ol li a:hover {
	background: #fff;
	opacity: .5;
}
.lesson-price main section.timetable {
	padding: 55px 0 0;
}
.lesson-price main section.timetable h2 {
	background: url(images/class-underline_dot2.png) bottom center no-repeat;
    background-size: 1018px;
    padding: 0 0 15px;
    margin: 0 0 30px;
}
.lesson-price main section.timetable h3 {
	background: #fff8a3;
	font-size: 24px;
	font-weight: bold;
	border-radius: 20px;
	width: 376px;
	height: 42px;
	padding: 12px 0 0;
	text-align: center;
	margin: 0 0 20px;
}
.lesson-price main section table {
	border: 1px solid #9d9d9d;
	width: 100%;
	font-weight: bold;
	margin: 0 0 20px;
}
.lesson-price main section.timetable .scroll > p {
	text-align: right;
	margin-bottom: 56px;
}
.lesson-price main section table th {
	border: 1px solid #9d9d9d;
	padding: 10px 10px 8px;
	text-align: center;
	font-size: 20px;
	vertical-align: middle;
	letter-spacing: 0.07em;
}
.lesson-price main section table td {
	border: 1px solid #9d9d9d;
	padding: 10px 10px 8px;
	text-align: center;
	font-size: 24px;
	vertical-align: middle;
	letter-spacing: 0.07em;
	line-height: 1.5em;
}
.lesson-price main section table tr:first-of-type th {
	background: #f5f5f5;
	font-size: 24px;
	width: 132px;
}
.lesson-price main section table th span {
	display: block;
	font-size: 24px;
	margin: 0 0 5px;
}
.lesson-price main section table td {
	font-size: 20px;
	margin: 0 0 10px;
}
.lesson-price main section table td .el_level {
	color: #c60c30;
	padding-right: 10px;
}
.lesson-price main section table.tomio td .el_level {
	padding-right: 0;
}
.lesson-price main section table td .el_time {
	font-size: 16px;
}
.lesson-price main section table td.pink {
	background: #faadee;
}
.lesson-price main section table td.green {
	background: #8ddd7b;
}
.lesson-price main section table td.blue {
	background: #74b3ed;
}
.lesson-price main section table td.orange {
	background: #ffc261;
}
.lesson-price main section table td.purple {
	background: #beabf5;
}
.lesson-price main section table td.saidaiji {
	background: #f2e4bf;
}
.lesson-price main section .att {
	margin: 0 0 40px;
    font-size: 23px;
}
.lesson-price main section .att + p {
	margin: 0 0 50px;
	display: flex;
	align-items: center;
}
.lesson-price main section .att + p span {
	background: #f2e4bf;
	height: 37px;
	width: 102px;
	margin: 0 15px 0 0;
}
.lesson-price main section ul {
	line-height: 1.5;
}
.lesson-price main section ul li em {
	font-weight: bold;
	color: #c60c30;
}

/*====================================================
無料体験お申し込み
====================================================*/
.entry-form main,
#contact{
	padding: 0 0 200px;
}
.entry_form section:first-of-type,
#contact section {
	margin: 65px 0 35px;
	text-align: center;
}
.entry_form section:first-of-type h3,
#contact section h3 {
	background: #fff8a3;
	width: 706px;
	height: 109px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: relative;
	line-height: 1.5;
	font-size: 20px;
	margin: 0 auto 35px;
}
.entry_form section:first-of-type h3::before,
#contact section h3::before {
	content: "";
	background: url(images/entry-beginner.png) no-repeat;
	background-size: contain;
	display: block;
	width: 67px;
	height: 92px;
	position: absolute;
	top: 9px;
	left: 58px;
}
.entry_form section:first-of-type p,
#contact section p {
	line-height: 1.5;
	margin: 0 0 30px;
}
.entry_form section:first-of-type ul,
#contact section ul {
	display: flex;
	justify-content: center;
}
.entry_form section:first-of-type ul li a,
#contact section ul li a {
	text-decoration: underline;
	color: #1360c6;
}
#contact .confirm section.form{
    margin: 65px 0 0;
	padding:0 0 200px;
}
.entry_form section.form .inner,
#contact section.form .inner {
	background: #ebebeb;
	border-radius: 10px;
	padding: 50px 163px 35px;
}
.entry_form section.form table,
#contact section.form table {
	margin: 0 0 46px;
}
.entry_form section.form table tr,
#contact section.form table tr {
	display: flex;
	align-items: center;
	margin: 0 0 22px;
}
.entry_form section.form table tr:last-of-type,
#contact section.form table tr:last-of-type {
	align-items: flex-start;
	margin: 0;
}
.entry_form section.form table th,
#contact section.form table th {
	width: 278px;
	text-align: left;
	flex-shrink: 0;
}
.entry_form section.form table th span,
#contact section.form table th span {
	height: 23px;
	width: 50px;
	color: #fff;
	background: #da3a59;
	font-size: 16px;
	margin: 0 0 0 15px;
	display: inline-block;
    text-align: center;
    padding: 4px 0 0;
	font-weight: bold;
}
.entry_form section.form table td input,
.entry_form section.form table td textarea,
.entry_form section.form table td select,
#contact section.form table td input,
#contact section.form table td textarea,
#contact section.form table td select {
	background: #fff;
	border: 1px solid #9e9e9e;
	border-radius: 10px;
	padding: 10px;
	width: 416px;
	font-size: 18px;
}
.entry_form section.form table tr.day td input,
#contact section.form table tr.day td input {
	width: 92px;
	width: 162px;
}
.entry_form section.form table td textarea,
#contact section.form table td textarea {
	height: 220px;
}
.entry_form section.form input[type="submit"],
#contact section.form input[type="submit"] {
	border: none;
	background: #dc7023;
	color: #fff;
	cursor: pointer;
	font-size: 28px;
	width: 245px;
	height: 60px;
	padding: 3px 0 0;
	border-radius: 7px;
	font-weight: bold;
}
.entry_form .mw_wp_form .error,
#contact .mw_wp_form .error {
    text-align: left;
    margin: 10px 0 0;
}
.entry_form section.thanks,
#contact section.thanks {
	margin: 65px 0 0;
	padding: 0 0 250px;
}
.entry_form section.thanks .inner,
#contact section.thanks .inner {
	background: url(images/thanks_bg.png) bottom center no-repeat;
	background-size: contain;
	background-color: #CFF9FF;
	width: 1020px;
	/*height: 335px;*/
	height: 400px;
	position: relative;
	text-align: left;
}
.entry_form section.thanks .inner h2,
#contact section.thanks .inner h2 {
	color: #304183;
	font-weight: bold;
	font-size: 36px;
	margin: 0 0 25px;
	position: absolute;
	top: 55px;
	left: 360px;
}
.entry_form section.thanks .inner h2 + p,
#contact section.thanks .inner h2 + p {
	margin: 0 0 20px;
	position: absolute;
	top: 115px;
    left: 360px;
	letter-spacing: 0.05em;
	font-size: 20px;
}
.entry_form section.thanks .inner address,
#contact section.thanks .inner address {
	position: absolute;
	left: 362px;
	top: 230px;
	font-size: 20px;
}
#contact section.thanks .inner address {
	top: 210px;
}
.entry_form section.thanks .inner address ul {
	display: block;
}
.entry_form section.thanks .inner address ul li,
#contact section.thanks .inner address ul li {
	margin: 0 0 10px;
}
.entry_form section.thanks .inner .back,
#contact section.thanks .inner .back {
	background: url(images/thanks_back_bg.png) top center no-repeat;
    background-size: contain;
    width: 399px;
    height: 111px;
    position: absolute;
    bottom: 9px;
    right: 62px;
	margin: 0;
}
.entry_form section.thanks .inner .back a,
#contact section.thanks .inner .back a {
	background: #d62b4c;
	color: #fff;
	font-size: 20px;
	border-radius: 20px;
	font-weight: bold;
    display: block;
    width: 290px;
    margin: 45px 0 0 60px;
    text-align: center;
    border-radius: 30px;
    height: 47px;
	padding: 10px 15px 0 0;
	position: relative;
}
.entry_form section.thanks .inner .back a::after,
#contact section.thanks .inner .back a::after {
	content: "";
	background: url(images/thanks_back.png) no-repeat;
	background-size: contain;
	width: 30px;
	height: 26px;
	display: block;
	position: absolute;
	right: 20px;
	top: 9px;
}
.entry_form section.thanks .inner .back a:hover,
#contact section.thanks .inner .back a:hover {
	opacity: .7;
}
.entry_form .mw_wp_form_preview section.form table,
#contact .mw_wp_form_preview section.form table {
	width: 100%;
}
.entry_form .mw_wp_form_preview section.form table tr,
#contact .mw_wp_form_preview section.form table tr {
    width: 100%;
    border-bottom: 1px solid #000;
    padding: 0 0 22px;
}
.entry_form .mw_wp_form_preview section.form table th,
#contact .mw_wp_form_preview section.form table th {
    font-weight: bold;
}
#contact section.thanks p:first-of-type a:first-of-type{
    text-decoration: underline;
    color: #1360c6;
}
#contact section.thanks {
	padding: 0;
}
#contact section.thanks {
	padding: 0;
}
#contact #top_form input[type="submit"]{
    display: flex;
	margin: 0 auto;
	justify-content: center;
	align-items: center;
}

/*====================================================
検索
====================================================*/
.search {
	margin: 0 0 20px;
}
.search form {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
.search input.search-text {
	width: 250px;
    /*height: 30px;*/
    border-radius: 5px;
    border: solid 2px #4b4b4b;
    padding: 8px;
    font-size: 18px;
    margin: 0 10px 0 0;
	color: #222;
}
.search input[type="image"] {
	width: 22px;
}
.result {
	margin: 0 0 20px;
}
.result::before {
	content: "▶";
}
.result + ul li.no {
	margin: 0 0 0 17px;
    width: 100%;
}

/*====================================================
講師募集
====================================================*/
.recruit main {
	padding: 55px 0 200px;
}
.recruit main section h2 {
	font-size: 34px;
	font-weight: bold;
	background: url(images/recruit/who_h2_bg.png) top center no-repeat;
	background-size: 1018px;
	text-align: center;
	height: 120px;
	padding: 42px;
	margin: 0 0 22px;
	letter-spacing: 0.05em;
}
.recruit main section p {
	line-height: 1.7;
	margin: 0 0 30px;
}
.recruit main section p mark {
	background: linear-gradient(transparent 60%, #f8e565 60%);
}
.recruit main section p em {
	font-weight: bold;
	color: #333399;
}
.recruit main section:first-of-type h2 + div {
	display: flex;
}
.recruit main section:first-of-type figure {
	flex-shrink: 0;
	margin: 0 34px 0 0;
}
.recruit main section:first-of-type figure img {
	width: 402px;
}
.recruit main section:nth-of-type(2) {
	background: #493625;
	padding: 29px 0 54px;
	position: relative;
	margin: 0 0 52px;
}
.recruit main section:nth-of-type(2)::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 52px 107.5px 0 107.5px;
	border-color: #493625 transparent transparent transparent;
	position: absolute;
	bottom: -52px;
	left: 0;
	right: 0;
	margin: 0 auto;
}
.recruit main section:nth-of-type(2) h2 {
	color: #fff;
	background: url(images/recruit/fire_h2_bg.png) top center no-repeat;
	background-size: 1020px;
	height: 175px;
}
.recruit main section:nth-of-type(2) h2 em {
	font-size: 38px;
	color: #f8e565;
}
.recruit main section:nth-of-type(2) h2 + p {
	text-align: center;
	color: #fff;
	font-size: 24px;
	margin: -90px 0 61px;
}
.recruit main section:nth-of-type(2) .inner div {
	background: #fff8a3;
	border-radius: 20px;
	padding: 38px 42px;
}
.recruit main section:nth-of-type(2) .inner div h3 {
	font-size: 32px;
	text-align: center;
	margin: 0 0 25px;
	font-weight: bold;
}
.recruit main section:nth-of-type(2) .inner div ul {
	display: flex;
	justify-content: space-between;
}
.recruit main section:nth-of-type(2) .inner div ul li p {
	font-size: 20px;
	line-height: 1.4;
	text-align: center;
	margin: 15px 0 0;
}
.recruit main section:nth-of-type(2) .inner div ul li figure img {
	width: 289px;
}
.recruit main p.contact a {
	color: #fff;
	font-size: 40px;
	font-weight: bold;
	background: url(images/recruit/contact.png) top center no-repeat;
	background-size: 910px;
	height: 166px;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 22px 0 0;
}
.recruit main p.contact a:hover {
	opacity: .7;
}



/*====================================================
レスポンシブ
====================================================*/
@media screen and (max-width: 1073px) {
	body {
		min-width: 1073px;
	}
	.slider .slick-next {
		right: 5px;
	}
	.slider .slick-prev {
		left: 5px;
	}
}

/*====================================================
スマホ
====================================================*/
@media screen and (max-width: 750px) {
	html #wpadminbar {
		min-width: 750px!important;
	}
	body {
		min-width: 750px;
		font-size: 28px;
	}
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}
	.inner {
		width: initial;
	}
	a img:hover {
		opacity: initial;
		filter: initial;
		-ms-filter: initial;
	}
/* ハンバーガーメニュー*/
	.menu-trigger {
		transition: all .4s;
		box-sizing: border-box;
	}
	.g-nav {
		position: fixed;
		overflow-y: scroll;
		width: 100%;
		z-index: 999999;
		height: 100%;
		display: none;
		background: url(images/sp/nav_bg.png);
		padding: 70px 0;
	}
	.g-nav ul {
		margin: 0;
		padding: 0;
		width: 100%;
		height: 100%;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
	}
	.g-nav ul li a {
		background: #fff;
		border-radius: 40px;
		color: #3f2f25;
		font-weight: bold;
		font-size: 40px;
		width: 495px;
		display: flex;
		align-items: center;
		justify-content: center;
		height: 92px;
		margin: 0 auto 40px;
	}
	.g-nav ul li:last-of-type a {
		width: 290px;
		color: #fff;
		background: #d26214;
		margin: 0 auto 100px;
		border-radius: 30px;
	}
	.g-nav ul li.sns {
		display: flex;
		justify-content: center;
	}
	.g-nav ul li.sns a {
		background: none;
		width: initial;
		margin: 0 24px 40px;
		width: 88px;
		height: 88px;
	}

/* ヘッダー */
	header {
		padding: 20px 16px 14px;
	}
	header .inner {
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin: 0;
	}
	header .inner h1 {
		padding: 0 0 10px;
	}
	header .inner ul {
		display: flex;
	}
	header .inner ul li {
		margin: 0 4px;
	}

/* フッター */
	footer .inner {
		background: #271506;
	}
	footer .inner nav {
		padding: 0;
		background: #493625;
		margin: 0;
	}
	footer .inner nav ul {
		flex-wrap: wrap;
		margin: 0;
	}
	footer .inner nav ul li {
		width: 50%;
		border-bottom: 2px solid #fff;
		padding: 0 0 0 36px;
	}
	footer .inner nav ul li.home {
		background: #271506;
		width: 100%;
		padding: 0;
	}
	footer .inner nav ul li.home a {
		font-weight: bold;
		justify-content: center;
	}
	footer .inner nav ul li.home a::before {
		content: url(images/sp/footer_home.png);
		margin: 0 10px 0 0;
	}
	footer .inner nav ul li:nth-of-type(even) {
		border-right: 2px solid #fff;
	}
	footer .inner nav ul li a {
		display: flex;
		height: 90px;
		align-items: center;
		font-size: 28px;
	}
	footer .inner nav ul li::after {
    	content: initial;
	}
	footer .inner nav ul li a::before {
		content: "▶";
		color: #eee095;
		margin: 0 10px 0 0;
		font-size: 20px;
	}
	footer .inner div {
		display: block;
		padding: 37px 0 65px;
		background: #493625;
	}
	footer .inner div p {
		margin: 0 auto 69px;
	}
	footer .inner div p img {
		margin: 0 auto;
	}
	footer .inner div dl {
    	font-size: 24px;
    	line-height: 1.5;
		margin: 0 0 0 30px;
	}
	footer .inner div dl:first-of-type {
    	margin: 0 0 40px 30px;
	}
	footer .page_top {
		bottom: 60px;
		right: 20px;
	}
	footer .page_top img {
		width: 130px;
	}
	footer .copyright {
    	font-size: 18px;
    	padding: 20px 0 12px;
	}


/* トップページ */
	.home main .slider_area {
    	background: url(images/sp/slider_bg.png) top center no-repeat;
    	background-size: contain;
    	padding: 43px 0;
    	height: 532px;
	}
	.slider_sp {
		display: none;
	}
	.slider_sp.slick-initialized{
		display: block!important; /*slick-initializedが付与されたら表示*/
	}
	.slider {
		display: none!important;
	}
	.slider_sp .slick-slide {
		margin: 0 30px;
	}
	.slick-prev, .slick-next {
    	top: 43%;
    	display: block;
    	width: 47px;
    	height: 47px;
	}
	.slider_sp .slick-prev {
    	background: url(images/sp/slider_prev.png) no-repeat;
    	background-size: contain;
    	position: absolute;
    	left: 10px;
    	z-index: 100;
	}
	.slider_sp .slick-next {
    	background: url(images/sp/slider_next.png) no-repeat;
    	background-size: contain;
    	position: absolute;
    	right: 10px;
    	z-index: 99;
	}
	.home main {
    	padding: 0 0 300px;
	}
	.home main .lesson {
    	padding: 196px 0 66px;
		margin-top: -136px;
	}
	.home main .lesson h2 {
    	font-size: 54px;
		margin: 0 0 20px;
	}
	.home main .lesson h2 span {
    	font-size: 38px;
	}
	.home main .lesson .img1,
	.home main .lesson .img2 {
		display: none;
	}
	.home main .lesson ul.sp {
    	display: flex;
		align-items: center;
		justify-content: center;
		margin: 0 0 25px;
	}
	.home main .lesson ul.sp li {
		margin: 0 20px;
	}
	.home main .lesson .btn img {
		margin: 0 auto;
	}
	.home main .reason {
		padding: 60px 0 20px;
	}
	.home main .reason h2 {
    	font-size: 54px;
		margin: 0 0 45px;
	}
	.home main .reason h2 span {
		font-size: 38px;
		line-height: 1.4;
		margin: 0 0 5px;
	}
	.home main .reason h2 span em {
		font-size: 44px;
	}
	.home main .reason h2 em {
    	font-size: 60px;
	}
	.home main .reason .heart1 {
    	top: 15px;
    	left: 20px;
	}
	.home main .reason .heart2 {
    	top: 15px;
    	right: 20px;
	}
	.home main .reason ul {
   		display: block;
	}
	.home main .reason ul li {
    	width: 692px;
    	background: url(images/sp/reason_bg1.png) no-repeat;
    	background-size: initial;
    	padding: 45px 0 0;
		margin: 0 auto 40px;
	}
	.home main .reason ul li:nth-of-type(2) {
    	background: url(images/sp/reason_bg2.png) no-repeat;
    	background-size: initial;
	}
	.home main .reason ul li:last-of-type {
	    background: url(images/sp/reason_bg3.png) no-repeat;
	    background-size: initial;
	}
	.home main .reason ul li dl dt {
    	margin: 0 0 219px;
	}
	.home main .reason ul li dl dt span {
		display: block;
    	position: absolute;
    	top: -54px;
    	left: 31px;
    	right: 0;
	}
	.home main .reason ul li dt img {
		margin: 0 auto;
	}
	.home main .reason ul li dl dd:first-of-type {
		font-size: 50px;
    	width: 440px;
    	border-radius: 40px;
    	padding: 20px 0 10px;
    	margin: 0 auto 55px;
	}
	.home main .reason ul li dl dd:last-of-type {
    	padding: 0 30px;
	}
  .home main .class{
      padding: 25px 0 50px;
  }
  .home main .class h2 {
      height: 140px;
      margin: 0 0 35px;
      padding:  10px 100px 0 0;
      background: url(https://1guru.jp/wp/wp-content/themes/nh/images/sp/class_h2_bg_test.png) top right / 132px 140px no-repeat;
      font-size: 40px;
      line-height: 1.3;
  }
  /**教室名**/
  .home main .class h3 {
      height: 88px;
      padding: 0 24px 0 34px;
      font-size: 48px;
      line-height:88px;
  }
/**地図 + 住所**/
  .home main .class .info{
      min-height:auto;
      padding:480px 0 0;
  }
/**地図**/
  .home main .class .map iframe{
      width:690px;
      height:450px;
  }
/**住所**/
  .home main .class .info dl{
      margin:0 0 25px;
  }
  .home main .class .info dt,
  .home main .class .info dd{
      height:40px;
      margin: 0 0 15px;
      line-height:40px;
  }
  .home main .class .info dt{
      width: 110px;
  }
  .home main .class .info dd a{
      pointer-events:auto;
  }
/*グーグルマップで見るボタン*/
  .home main .class .info .btn a{
      width: 305px;
      height: 55px;
      border-radius: 15px;
      line-height: 55px;
      font-size: 24px;
      position: absolute;
      top: -119px;
      right: 25px;
  }
	.home main .join {
    	background: url(images/sp/join_bg.png) top center no-repeat;
    	background-size: initial;
		padding: 40px 0 43px;
	}
	.home main .join h2 img {
		margin: 0 auto;
	}
	.home main .join h2 + div {
    	display: block;
    	margin: 0 0 26px;
	}
	.home main .join h2 + div figure {
		text-align: center;
		margin: 0 0 45px;
	}
	.home main .join h2 + div figure img {
		width: 582px;
	}
	.home main .join h2 + div h3 {
    	font-size: 36px;
    	margin: 0 0 20px;
    	text-align: center;
	}
	.home main .join h2 + div ul {
		margin: 0 0 50px;
		font-size: 28px;
		padding: 30px 50px 25px;
	}
	.home main .join h2 + div ul li {
		text-indent: -1.3em;
		padding: 0 0 0 1.3em;
	}
	.home main .join h2 + div h4 {
		font-size: 34px;
		text-align: center;
		line-height: 1.5;
	}
	.home main .join h2 + div p {
		text-align: center;
		position: relative;
		line-height: 1.5;
	}
	.home main .join h2 + div p .heart1 {
		position: absolute;
		top: 25px;
		left: 25px;
	}
	.home main .join h2 + div p .heart2 {
		position: absolute;
		top: 25px;
		right: 25px;
	}
	.home main .introduce {
    	background: url(images/sp/introduce_bg.png) top center no-repeat;
    	background-size: initial;
    	padding: 45px 0 76px;
		height:auto;
	}
	.home main .introduce h2 {
		font-size: 54px;
	}
	.home main .introduce h2 + p {
		font-size: 38px;
		line-height: 1.4;
		margin: 0 0 343px;
	}
	.home main .introduce .box {
		position: relative;
    	height: initial;
	}
	.home main .introduce .box > p {
    	position: initial;
	}
	.home main .introduce .box > p img {
		margin: 0 auto;
	}
	.home main .introduce .box div {
    	padding: 40px 45px 30px;
    	width: 100%;
    	height: auto;
    	line-height: 1.5;
    	position: initial;
	}
	.home main .introduce .box div p:last-of-type {
    	text-align: right;
    	font-size: 22px;
    	margin: 30px 0 0;
	}
	.home main .news {
    	padding: 58px 0 0px;
	}
	.home main .news h2 {
    	font-size: 54px;
		margin: 0 0 38px;
	}
	.home main .news ul {
		margin: 0 0 50px;
	}
	.home main .news ul li {
		height: auto;
		font-size: 26px;
		align-items: center;
		padding: 10px 14px 15px;
		line-height: 1.5;
		margin: 0 0 25px;
	}
	.home main .news ul li span {
		width: 190px;
		font-size: 22px;
		flex-shrink: 0;
		height: 40px;
		border-radius: 12px;
		margin: 8px 40px 0 0;
	}
	.home main .news ul li a {
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 1;
		overflow: hidden;
		white-space: initial;
	}
	.home main .news p a {
		font-size: 34px;
		width: 386px;
		height: 84px;
		border-radius: 40px;
	}
	.home main .news p a::after {
		font-size: 22px;
	}

/* 無料体験を予約するエリア */
	main .contact_box {
		width: initial;
	}
	main .common_contact_area {
		display: block;
		padding: 28px;
	}
	main .common_contact_area dl dt {
		font-size: 40px;
	}
	main .common_contact_area dl dd:last-of-type {
		margin: 0 0 30px;
	}
	main .common_contact_area dl dd:last-of-type img {
		margin: 0 auto;
	}
	
/* 20190905追加 */
	.home main .voice{
		padding:55px 30px 65px;
	}
	.home main .voice h2{
 	   font-size: 42px;
 	   padding: 0 0 30px;
 	   background-size: 1100px;
	}
	.home main .voice ul{
		width: 690px;
    	max-height: none;
    	background: none;
		overflow-y: visible;
   		padding: 0;
	}
	.home main .voice ul li{
		margin:30px 0 0!important;
		padding:25px!important;
		border-bottom:none;
		background: #f2e4bf;
		border-radius:20px;
	}
	.home main .voice ul li:nth-of-type(3){
		display:none;
	}
	.home main .voice ul li .info{
		font-size:24px;
	}

	.home main .apply{
		margin:-136px 0 0;
		padding:200px 0 60px;
	}
	.home main .apply .trial{
		width: 690px;
	    margin: 0 auto 30px;
	}
	.home main .apply .trial h2{
		font-size:38px;
	}
	.home main .apply .trial h2:nth-child(4) {
		margin: -36px 0 0 70px;
	}
	.home main .apply .trial h3 a {
    	padding: 20px 20px 17px;
    	width: 380px;
	}
	.home main .apply .trial .day::before {
    	width: 87px;
    	height: 112px;
    	left: -10px;
    	bottom: 0;
    	top: 42px;
    	 margin: 0;
	}
	.home main .apply .trial .day.no::before {
		left:0;
	}
	.home main .apply .box{
		width: 690px;
	}
	.home main .apply > h2{
		background:#304183;
		font-size:38px;
		padding:25px 0 20px;
		width: 690px;
	}
	.home main .apply .box > p {
    	margin: 0 0 30px;
	}
	.home main .apply .box address{
		margin:0 0 60px;
	}
	.home main .apply .box address ul{
		display:block;
		text-align:left;
		width:600px;
		margin:0 auto;
	}
	.home main .apply .box address ul li:first-of-type{
		margin:0 0 25px;
	}
	.home main .apply .box address ul li:last-of-type a{
		pointer-events:auto;
		text-decoration: underline;
		color: #1360c6;
	}
	#top_form{
		padding: 50px 30px;
	}
	#top_form form{
		margin:-186px 0 0;
		padding: 186px 0 0;
	}
	#top_form,
	#top_form table {
		width: 100%;
	}
	#top_form table tr {
		display: block;
		align-items: center;
		margin: 0 0 22px;
	}
	#top_form table th {
		width: 100%;
		display: flex;
		align-items: flex-end;
		margin: 0 0 20px;
	}
	#top_form table th span {
		height: 31px;
		width: 67px;
		font-size: 25px;
		margin: 0 0 0 15px;
		padding: 3px 0 0;
	}
	#top_form table td {
		display: block;
		text-align: left;
	}
	#top_form table td input,
	#top_form table td textarea,
	#top_form table td select {
		width: 100%;
		font-size: 32px;
	}
	#top_form table tr.day td input {
		width: 320px;
	}
	#top_form input[type="submit"] {
		font-size: 38px;
		width: 325px;
		height: 90px;
		padding: 4px 0 0;
	}
	.confirm_trial #top_form{
		width:690px;
	}
	.confirm_trial #top_form form {
    	margin: -930px 0 0;
    	padding: 930px 0 0;
}	
	#top_form .thanks {
    	margin: 60px 30px 0;
		padding: 0 0 300px;
	}
	#top_form .thanks .inner {
    	background: url(images/sp/thanks_bg.png) bottom center no-repeat;
    	background-size: contain;
    	width: initial;
    	height: 835px;
    	background-color: #cef9ff;
	}
	#top_form .thanks .inner h2 {
	    font-size: 42px;
	    top: 54px;
	    left: 0;
	    right: 0;
	    text-align: center;
		line-height: 1.5;
	}
	#top_form .thanks .inner h2 + p {
    	left: 0;
	    right: 0;
	    text-align: center;
		top: 195px;
	}
	#top_form .thanks .inner .back {
		width: 530px;
		height: 147px;
		bottom: 345px;
		right: 0;
		left: 0;
		margin: 0 auto;
	}
	#top_form .thanks .inner .back a {
		font-size: 30px;
		width: 400px;
		margin: 45px 0 0 70px;
		height: 70px;
		padding: 14px 15px 0 0;
	}
	#top_form .thanks .inner .back a::after {
		width: 38px;
		height: 33px;
		right: 20px;
		top: 17px;
	}

/* 下層ページ共通 */
	main {
	    background: url(images/sp/pass_footer.png) bottom center no-repeat;
	    background-size: initial;
	}
	.title_wrap {
    	background: url(images/sp/page_header.png) top center no-repeat;
    	background-size: initial;
    	height: 164px;
	}
	.title_wrap h2 {
		font-size: 44px;
	}
	.breadcrumbs {
		height: 40px;
		padding: 0 30px;
	}
	.breadcrumbs .inner {
		font-size: 20px;
	}
	section .inner {
		padding: 0 30px;
	}
/* 教室案内 */
	.class main {
    	padding: 0 0 300px;
	}
	.class main section.classroom ul {
		display: block;
	}
	.class main section h3 {
		font-size: 38px;
	}
	.class main section.classroom ul li {
		width: initial;
		padding: 20px 15px;
		margin: 0 0 33px;
	}
	.class main section.classroom ul li h4 {
		height: 193px;
		width: initial;
		font-size: 44px;
		padding: 9px 0 0 38px;
		margin: 0 0 23px;
	}
	.class main section.classroom ul li dl {
		font-size: 28px;
		border-bottom: 1px dashed #3f2f25;
		margin: 0 0 28px;
	}
	.class main section.classroom ul li dl dt {
		font-size: 28px;
		width: 188px;
		height: 68px;
		padding: 2px 0 0 57px;
	}
	.class main section.classroom ul li dl dt::before {
    	width: 23px;
    	height: 37px;
		top: 17px;
		left: 13px;
	}
	.class main section.classroom ul li dl dt.station::before {
		width: 30px;
    	height: 40px;
	}
	.class main section.classroom ul li dl dt.parking::before {
		width: 30px;
    	height: 40px;
	}
	.class main section.classroom ul li dl dd {
		height: 68px;
		line-height: 1.4;
	}
	.class main section.classroom ul li p a {
		font-size: 30px;
		height: 80px;
		width: 380px;
	}
	.class main section.classroom ul li p a::after {
    	top: 31px;
    	font-size: 22px;
	}
	.class main section.level {
    	padding: 55px 0 35px;
	}
	.class main section.level h3 {
		font-size: 42px;
		padding: 0 0 30px;
	    background-size: 1100px;
	}
	.class main section.level ol {
		display: block;
		margin: 0 0 55px;
	}
	.class main section.level ol li {
		width: initial;
		height: 100%;
		margin: 0 0 23px;
		padding: 16px 42px 16px 15px;
	}
	.class main section.level ol li a {
		height: 100%;
	}
	.class main section.level ol li h4 {
		width: 95px;
		height: 115px;
		font-size: 34px;
		margin: 0 18px 0 0;
	}
	.class main section.level ol li h5 {
		font-size: 28px;
	}
	.class main section.level ol li p.star {
		font-size: 22px;
	}
	.class main section.level ol li p {
		font-size: 26px;
	}
	.class main section.teachers h3 {
		font-size: 42px;
        background-size: 1100px;
		padding: 0 0 30px;
	}
	.class main section.teachers ol li > div h4 {
    	font-size: 32px;
    	height: 80px;
    	border-radius: 7px;
		padding: 2px 13px 0;
    	margin: 0 0 37px;
	}
	.class main section.teachers ol li > div h4 span {
    	font-size: 24px;
    	height: 49px;
    	width: 163px;
    	margin: 0 20px 0 0;
		padding: 4px 0 0;
	}
	.class main section.teachers ol li figure {
		text-align: center;
		margin: 0 0 35px;
	}
	.class main section.teachers ol li figure img {
    	width: initial;
	}
	.class main section:last-of-type {
		padding: 0;
	}

/* アクセス */
	.access main {
    	padding: 0 0 300px;
	}
	.access main section.map h2 {
		font-size: 42px;
		background-size: 1100px;
		padding: 146px 0 30px;
		margin: -146px 0 40px;
	}
	.access main section.map h2 + div {
    	display: block;
	}
	.access main section.map h2 + div figure {
    	margin: 0 0 39px;
	}
	.access main section.map h2 + div figure img {
		width: 100%;
	}
	.access main section.map div p a {
    	height: 80px;
    	width: 458px;
   		font-size: 30px;
    	margin: 0 auto 48px;
	}
	.access main section.map div p a::after {
    	right: 15px;
    	top: 29px;
    	font-size: 21px;
	}
	.access main section.map dl:first-of-type {
    	margin: 0 0 30px;
	}
	.access main section.map dl:first-of-type dt {
		width: 187px;
		height: 68px;
		padding: 0 0 0 56px;
		margin: 0 0 13px;
	}
	.access main section.map dl:first-of-type dd {
		margin: 0 0 13px;
		height: 68px;
	}
	.access main section.map dl:first-of-type dt::before {
    	width: 24px;
    	height: 33px;
    	top: 16px;
    	left: 13px;
	}
	.access main section.map dl:first-of-type dt.station::before {
    	width: 27px;
    	height: 34px;
    	top: 16px;
    	left: 12px;
	}
	.access main section.map dl:last-of-type dt {
    	font-size: 28px;
	}
	.access main section.map dl:last-of-type dt:not(first-of-type) {
    	margin: 25px 0 5px -0.5em;
	}
	.access main section.map dl:last-of-type dd a {
		color: #493625;
		text-decoration: underline;
	}
	.access main section.map dl:last-of-type dd:last-of-type {
    	margin: 0 0 5px -0.5em;
    	text-indent: -0.5em;
    	padding-left: 0.5em;
	}
	.access main section.map dl:last-of-type dd.tel a {
		color: #455cb3;
	}
	.access main section.map ul li img {
		width: 338px;
	}

/* レッスン内容・料金 */
	.lesson-price main {
    	padding: 0 0 300px;
	}
	.lesson-price main section h2 {
    	font-size: 38px;
	}
	.lesson-price main section.about h2 + div {
    	padding: 21px 26px 31px;
    	margin: 0 auto 40px;
    	width: initial;
	}
	.lesson-price main section.about h2 + div h3 {
    	margin: 0 0 22px;
	}
	.lesson-price main section.about h2 + div h3 img {
    	width: 620px;
	}
	.lesson-price main section.about h2 + div ul li {
    	width: 305px;
    	height: 90px;
    	margin: 0 0 20px;
    	padding: 0 0 0 121px;
	}
	.lesson-price main section.about h2 + div ul li img {
		width: 87px;
	}
	.lesson-price main section.about h2 + div ul li::before {
	    width: 43px;
	    height: 58px;
	    left: 21px;
	    top: 13px;
	}
	.lesson-price main section.about h2 + div ul li:nth-of-type(2)::before {
    	width: 52px;
    	height: 52px;
    	left: 24px;
    	top: 17px;
	}
	.lesson-price main section.about h2 + div ul li:nth-of-type(3)::before {
    	width: 60px;
    	height: 42px;
    	left: 12px;
    	top: 20px;
	}
	.lesson-price main section.about h2 + div ul li:last-of-type::before {
    	width: 71px;
    	height: 52px;
    	left: 15px;
    	top: 15px;
	}
	.lesson-price main section.about h4 {
    	font-size: 34px;
    	margin: 0 0 46px;
	}
	.lesson-price main section.about h4 + ul {
    	flex-wrap: wrap;
	}
	.lesson-price main section.about h4 + ul li {
    	width: 335px;
    	height: 162px;
    	font-size: 30px;
    	margin: 0 0 29px;
		padding: 0 0 15px;
	}
	.lesson-price main section.about h4 + ul li::before {
    	width: 66px;
    	height: 28px;
    	top: 20px;
	}
	.lesson-price main section.about h4 + ul li:nth-of-type(even)::before {
    	width: 89px;
    	height: 66px;
    	top: -15px;
	}
	.lesson-price main section.price {
    	padding: 55px 0 65px;
	}
	.lesson-price main section.price h2 {
		font-size: 42px;
    	background-size: 1100px;
		padding: 0 0 30px;
	}
	.lesson-price main section.price h2 + div {
    	padding: 41px 22px 17px 20px;
	}
	.lesson-price main section.price h2 + div span {
		font-size: 22px;
		margin: 5px 0 0;
		font-weight: normal;
	}
	.lesson-price main section.price h2 + div em {
		color: #c60c30;
	}
	.lesson-price main section.price dl dt {
		width: 510px;
		font-size: 28px;
		padding: 0;
		font-weight: bold;
	}
	.lesson-price main section.price dl dd {
		font-size: 28px;
	}
	.lesson-price main section.price dl:first-of-type dt:last-of-type {
    	margin: 0 0 30px;
	}
	.lesson-price main section.price dl:last-of-type dt {
    	width: 464px;
	}
	.lesson-price main section.price dl:last-of-type dd {
    	font-size: 34px;
	}
	.lesson-price main section.price dl:last-of-type dd span {
		font-size: 22px;
	}
	.lesson-price main section.contents h2 {
		font-size: 42px;
		background-size: 1100px;
		padding: 0 0 30px;
		margin: 0 0 40px;
	}
	.lesson-price main section.contents h2 + p {
    	margin: 0 0 65px;
	}
	.lesson-price main section.contents ol > li {
    	display: block;
    	margin: 0 0 35px;
    	padding: 0 0 25px;
	}
	.lesson-price main section.contents ol li > div ul {
		display: block;
	}
	.lesson-price main section.contents ol li > div p.txt.pc {
		display: none;
	}
	.lesson-price main section.contents ol li > div h3 {
    	font-size: 32px;
    	display: flex;
		align-items: center;
	}
	.lesson-price main section.contents ol li > div h3 span {
		font-size: 20px;
		background: #dadada;
		width: 155px;
	    border-radius: 20px;
	    text-align: center;
	    padding: 10px 0 7px;
		margin: 0 15px 0 0;
	}
	.lesson-price main section.contents ol li > div h3 + p {
		margin: -15px 0 30px;
		font-size: 20px;
	}
	.lesson-price main section.contents ol li figure {
    	margin: 0 0 27px;
    	text-align: center;
	}
	.lesson-price main section.contents ol li figure img {
		width: 196px;
	}
	.lesson-price main section.contents ol li > div ul li {
    	width: initial;
    	height: 142px;
    	padding: 14px 13px;
    	margin: 0 0 22px;
	}
	.lesson-price main section.contents ol li > div ul li h4 {
    	font-size: 34px;
	    width: 97px;
	    height: 115px;
	    margin: 0 17px 0 0;
	}
	.lesson-price main section.contents ol li > div ul li h5 {
    	font-size: 28px;
	}
	.lesson-price main section.contents ol li > div ul li p.star {
		font-size: 24px;
	}
	.lesson-price main section.contents ol li > div ul li p {
    	font-size: 26px;
	}
	.lesson-price main section.contents ol li a {
    	height: 142px;
	}
	.lesson-price main section.timetable h2 {
		font-size: 42px;
	    background-size: 1100px;
    	padding: 0 0 30px;
	    margin: 0 0 40px;
	}
	.lesson-price main section.timetable h3 {
	    font-size: 34px;
	    border-radius: 15px;
	    width: 557px;
	    height: 60px;
	    padding: 16px 0 0;
	    margin: 0 auto 37px;
	}
	.lesson-price main section table td {
		font-size: 24px;
	}
	.lesson-price main section table td .el_level {
		font-size: 24px;
	}
	.lesson-price main section table td .el_time {
		font-size: 18px;
	}
	.lesson-price main section.timetable .att:first-of-type {
		margin-bottom: 64px;
	}
	.lesson-price main section.timetable .scroll table {
		width: 1020px;
	}
	.lesson-price main section.timetable .scroll > p {
		text-align: left;
		font-size: 23px;
		margin-bottom: 30px;
	}
	.lesson-price main section.timetable .scroll {
		overflow: auto;
		white-space: nowrap;
		margin: 0 0 30px;
	}
	.lesson-price main section.timetable .scroll::-webkit-scrollbar{
		height: 5px;
	}
	.lesson-price main section.timetable .scroll::-webkit-scrollbar-track{
		background: #F6F6F6;
	}
	.lesson-price main section.timetable .scroll::-webkit-scrollbar-thumb {
		background: #C2C2C2;
	}

/* 無料体験フォーム */
.entry-form main {
	padding: 0 0 200px;
}
.entry_form section.form,
#contact section.form{
	margin: 0 30px 100px;
}
.confirm .entry_form section.form{
	margin: 0 30px;
	padding:0 0 250px;
}
.entry_form section.form .inner {
	padding: 50px 30px 75px;
}
.entry_form section:first-of-type h3,
#contact section h3 {
	width: initial;
	height: 180px;
	text-align: left;
	font-size: 28px;
	padding: 0 0 0 60px;
}
.entry_form section:first-of-type h3::before,
#contact section h3::before {
	width: 87px;
	height: 112px;
	top: 32px;
	left: 28px;
}
.entry_form section:first-of-type ul,
#contact section ul {
	display: block;
}
.entry_form section.form table {
	width: 100%;
}
.entry_form section.form table tr {
	display: block;
	align-items: center;
	margin: 0 0 22px;
}
.entry_form section.form table th {
	width: 100%;
	display: flex;
	align-items: flex-end;
	margin: 0 0 20px;
}
.entry_form section.form table th span {
	height: 31px;
	width: 67px;
	font-size: 25px;
	margin: 0 0 0 15px;
	padding: 5px 0 0;
}
.entry_form section.form table td {
	display: block;
	text-align: left;
}
.entry_form section.form table td input,
.entry_form section.form table td textarea,
.entry_form section.form table td select {
	width: 100%;
	font-size: 38px;
}
.entry_form section.form table tr.day td input {
	width: 320px;
}
.entry_form section.form input[type="submit"] {
	font-size: 38px;
	width: 325px;
	height: 90px;
	padding: 4px 0 0;
}
.entry_form section.thanks,
#contact section.thanks {
	margin: 60px 30px 0;
	padding: 0 0 300px;
}
#contact section.thanks {
	padding: 0;
}
.entry_form section.thanks .inner,
#contact section.thanks .inner {
	background: url(images/sp/thanks_bg.png) bottom center no-repeat;
	background-size: contain;
	width: initial;
	height: 865px;
	background-color: #cef9ff;
}
.entry_form section.thanks .inner h2,
#contact section.thanks .inner h2 {
	font-size: 40px;
	top: 40px;
	left: 0;
	right: 0;
	text-align: center;
	line-height: 1.5;
}
.entry_form section.thanks .inner h2 + p,
#contact section.thanks .inner h2 + p {
	left: 0;
	right: 0;
	text-align: center;
	top: 175px;
	font-size: 24px;
}
.entry_form section.thanks .inner address,
#contact section.thanks .inner address {
	left: 162px;
	top: 300px;
	font-size: 26px;
	line-height: 1.4;
}
#contact section.thanks .inner address {
	left: 105px;
	top: 330px;
}
#contact section.thanks .inner address ul {
	display: flex;
	flex-flow: column;
	align-items: center;
}
.entry_form section.thanks .inner .back,
#contact section.thanks .inner .back {
	width: 530px;
	height: 147px;
	bottom: 325px;
	right: 0;
	left: 0;
	margin: 0 auto;
}
#contact section.thanks .inner .back {
	bottom: 300px;
}
.entry_form section.thanks .inner .back a,
#contact section.thanks .inner .back a {
	font-size: 30px;
	width: 400px;
	margin: 45px 0 0 70px;
	height: 70px;
	padding: 14px 15px 0 0;
}
.entry_form section.thanks .inner .back a::after,
#contact section.thanks .inner .back a::after {
	width: 38px;
	height: 33px;
	right: 20px;
	top: 17px;
}
#contact {
	width: 690px;
	display: flex;
	flex-flow: column;
	margin: auto;
}
#contact section .inner{
	padding: 50px 0 75px;
}
#contact section{
	margin: 0;
}
#contact section h3{
	padding: 0 30px 0 110px;
	text-align: center;
}

/* 講師募集 */
	.recruit main {
    	padding: 55px 0 300px;
	}
	.recruit main section h2 {
    	font-size: 42px;
    	background: url(images/sp/recruit/who_h2_bg.png) top center no-repeat;
    	background-size: initial;
    	height: 152px;
    	margin: 0 0 40px;
		line-height: 1.3;
		padding: 26px;
	}
	.recruit main section:first-of-type {
		padding: 0 0 30px;
	}
	.recruit main section:first-of-type h2 + div {
		display: block;
		padding: 0 19px;
	}
	.recruit main section:first-of-type figure {
		margin: 0 0 48px;
		text-align: center;
	}
	.recruit main section:first-of-type h2 + div figure img {
		width: initial;
	}
	.recruit main section:nth-of-type(2) {
		margin: 0 0 95px;
	}
	.recruit main section:nth-of-type(2) h2 {
    	background: url(images/sp/recruit/fire_h2_bg.png) top center no-repeat;
    	background-size: 715px;
    	height: 177px;
		margin: 0 -30px;
		font-size: 36px;
	}
	.recruit main section:nth-of-type(2) h2 em {
		font-size: 42px;
	}
	.recruit main section:nth-of-type(2) h2 + p {
    	font-size: 30px;
    	margin: -8px 0 50px;
	}
	.recruit main section:nth-of-type(2) .inner div {
		text-align: center;
	}
	.recruit main section:nth-of-type(2) .inner div h3 {
		font-size: 40px;
		line-height: 1.3;
	}
	.recruit main section:nth-of-type(2) .inner div ul {
		display: block;
	}
	.recruit main section:nth-of-type(2) .inner div ul li {
		margin: 0 0 40px;
	}
	.recruit main section:nth-of-type(2) .inner div ul li p {
    	font-size: 32px;
	}
	.recruit main p.contact a {
    	font-size: 50px;
    	background: url(images/sp/recruit/contact.png) top center no-repeat;
    	background-size: contain;
   		height: 206px;
		display: block;
		margin: 0 30px;
		padding: 62px 0 0;
		text-align: center;
	}
	.recruit main p.contact a span {
		font-size: 40px;
		display: block;
		margin: 15px 0 0;
	}
	.recruit main section:nth-of-type(2) .inner div ul li figure img {
		width: initial;
	}
}

/*=============================
　404テンプレート
==============================*/
.not_found {
	margin: 0 auto;
	padding: 100px 0 150px;
	max-width: 1020px;
	text-align: center;
}
.not_found h2 {
	margin: 0 0 40px;
	font-size: 30px;
}
.not_found h2 + p {
	margin: 0 0 40px;
	line-height: 1.8;
}
.not_found .btn {
	color: #000;
	font-size: 26px;
	display: flex;
 	align-items: center;
	justify-content: center;
}
.not_found .btn::before {
	content: "";
    display: block;
    width: 0;
    height: 0;
    margin: 0 9px 0 0;
    border-style: solid;
    border-width: 7px 0 7px 10px;
    border-color: transparent transparent transparent #da6e21;
}
@media screen and (max-width: 750px) {
	.not_found h2 {
 		font-size: 40px;
 		line-height: 1.5;
	}
	.not_found .btn {
		font-size: 35px;
	}
	.not_found .btn::before {
 		margin: 0 14px 0 0;
		border-width: 12px 0 12px 15px;
	}
}
/*=============================
　無料体験日カレンダー
==============================*/
#calendar {
	padding: 50px 0;
}
#calendar h2 {
	font-size: 24px;
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: #493625!important;
	color: #fff;
	border-radius: 7px;
	height: 50px;
	margin: 0 0 20px;
	padding: 0 11px 0 40px;
}
/*前月へ翌月へ*/
#calendar .nav a {
	background: #dc7023;
	border-radius: 5px;
	padding: 5px 30px 3px 20px;
    width: 105px;
	display: flex;
	justify-content: center;
	position: relative;
	font-size: 18px;
	color: #fff;
}
#calendar .nav a:hover {
	background: #fff;
	color: #dc7023;
}
#calendar .nav .prev{
    padding: 5px 20px 3px 30px;
}
#calendar .nav .prev::before{
	content: "◀";
	color: #fff;
	position: absolute;
	top: 7px;
    left: 6px;
    font-size: 14px;
}
#calendar .nav .next:hover::after{
	content: "▶";
	color: #dc7023;
	position: absolute;
	top: 7px;
    right: 6px;
    font-size: 14px;
}
#calendar .nav .prev:hover::before{
	content: "◀";
	color: #dc7023;
	position: absolute;
	top: 7px;
    left: 6px;
    font-size: 14px;
}
#calendar .nav .next::after{
	content: "▶";
	color: #fff;
	position: absolute;
	top: 7px;
    right: 6px;
    font-size: 14px;
}
#calendar ul {
	border: 1px solid #000;
	background: #fff;
	margin: 0 0 50px;
}
#calendar ul li {
	display: flex;
	align-items: flex-start;
	border-top: 1px solid #000;
}
#calendar ul li:first-of-type {
	border: none;
}
#calendar ul li div {
	padding: 15px;
	width: 10%;
}
#calendar .scheduleComment {
	line-height: 1.5;
	padding: 15px;
	width: 90%;
	border-left: 1px solid #000;
	min-height: 48px;
}
#calendar .scheduleComment:first-line {
	line-height: 1;
}
/*休業日*/
#calendar .small {
	margin: 0 0 20px;
}
#calendar .small .holidayCube {
	width: 14px;
    height: 14px;
    display: inline-block;
	margin: 0 10px 0 0;
}
/*本日*/
#calendar .small .todayCube {
	width: 14px;
    height: 14px;
    display: inline-block;
	margin: 0 10px 0 0;
	background: #cfeff6;
}
#calendar .small span:first-of-type {
	margin: 0 10px 0 0;
}
/*土曜日*/
#calendar ul li.youbi_6 div:first-of-type{
	color: blue;
}
/*日曜日*/
#calendar ul li.youbi_0 div:first-of-type {
	color: #c60c30;
}
/*本日*/
#calendar ul li.today {
	background: #cfeff6!important;
}
#calendar ul li.today div:first-of-type {
	font-weight: bold;
}
#calendar .btn {
	text-align: center;
	margin: 0 0 130px;
}
#calendar .att {
	margin: 0 0 50px;
	text-align: center;
}
#calendar .att p {
	font-size: 18px;
	margin: 0 0 20px;
	line-height: 1.5;
}
#calendar .att p a {
	pointer-events: none;
}
#calendar .att p img {
	width: 290px;
}
@media screen and (max-width : 750px){
	#calendar {
		padding: 50px 30px;
	}
	#calendar h2 {
    	font-size: 34px;
    	height: 70px;
    	padding: 0 15px 0 20px;
	}
	#calendar .nav a {
    	padding: 8px 30px 6px 20px;
    	width: 155px;
    	font-size: 28px;
	}
	#calendar .nav .prev {
    	padding: 8px 20px 6px 50px;
}
	#calendar .nav .next::after {
		top: 13px;
		right: 8px;
		font-size: 19px;
	}
	#calendar .nav .prev::before{
		top: 13px;
		left: 8px;
		font-size: 19px;
	}
	#calendar .small {
    	margin: 30px 0 30px;
	}
	#calendar ul {
    	margin: 0 0 60px;
	}
	#calendar ul li div {
    	padding: 25px;
    	width: 150px;
	}
	#calendar .scheduleComment {
    	padding: 25px;
    	width: 538px;
    	min-height: 78px;
	}
	#calendar .btn {
		margin: 0 0 180px;
	}
	#calendar .att p {
		font-size: 24px;
	}
	#calendar .att p a {
		pointer-events: initial;
	}
	#calendar .att p img {
		width: 360px;
	}
}