/*
Theme Name: doitsumura
Author: MoON 
Author URI: https://moongraphica.com

/* =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%;
	vertical-align: baseline;
}
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;
}
caption,
th,
td {
	font-weight: normal;
	text-align: left;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
}
html {
	overflow-y: scroll;
	font-size: 100%;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
}
a:focus {
	outline: thin dotted;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
	display: block;
}
audio,
canvas,
video {
	display: inline-block;
}
audio:not([controls]) {
	display: none;
}
del {
	color: #333;
}
ins {
	background: #fff9c0;
	text-decoration: none;
}
hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin: 24px;
	margin-bottom: 1.714285714rem;
}
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}
sup {
	top: -0.5em;
}
sub {
	bottom: -0.25em;
}
small {
	font-size: smaller;
}
img {
	border: 0;
	-ms-interpolation-mode: bicubic;
}

/* Clearing floats */
.clear:after,
.wrapper:after,
.format-status .entry-header:after {
	clear: both;
}
.clear:before,
.clear:after,
.wrapper:before,
.wrapper:after,
.format-status .entry-header:before,
.format-status .entry-header:after {
	display: table;
	content: "";
}


/* =Repeatable patterns
-------------------------------------------------------------- */

/* Form fields, general styles first */
button,
input,
select,
textarea {
	border: 1px solid #ccc;
	border-radius: 3px;
	/* font-family: inherit; */
	/* padding: 6px;
	padding: 0.428571429rem; */
}
button,
input {
	line-height: normal;
}
textarea {
	font-size: 100%;
	overflow: auto;
	vertical-align: top;
}

/* Reset non-text input types */
input[type="checkbox"],
input[type="radio"],
input[type="file"],
input[type="hidden"],
input[type="image"],
input[type="color"] {
	border: 0;
	border-radius: 0;
	padding: 0;
}

/* Buttons */
.menu-toggle,
input[type="submit"],
input[type="button"],
input[type="reset"],
article.post-password-required input[type=submit],
.bypostauthor cite span {
	padding: 6px 10px;
	padding: 0.428571429rem 0.714285714rem;
	font-size: 11px;
	font-size: 0.785714286rem;
	line-height: 1.428571429;
	font-weight: normal;
	color: #7c7c7c;
	background-color: #e6e6e6;
	background-repeat: repeat-x;
	background-image: -moz-linear-gradient(top, #f4f4f4, #e6e6e6);
	background-image: -ms-linear-gradient(top, #f4f4f4, #e6e6e6);
	background-image: -webkit-linear-gradient(top, #f4f4f4, #e6e6e6);
	background-image: -o-linear-gradient(top, #f4f4f4, #e6e6e6);
	background-image: linear-gradient(top, #f4f4f4, #e6e6e6);
	border: 1px solid #d2d2d2;
	border-radius: 3px;
	box-shadow: 0 1px 2px rgba(64, 64, 64, 0.1);
}
.menu-toggle,
button,
input[type="submit"],
input[type="button"],
input[type="reset"] {
	cursor: pointer;
}
button[disabled],
input[disabled] {
	cursor: default;
}
.bypostauthor cite span {
	color: #fff;
	background-color: #21759b;
	background-image: none;
	border: 1px solid #1f6f93;
	border-radius: 2px;
	box-shadow: none;
	padding: 0;
}

/* Responsive images */
.entry-content img,
.comment-content img,
.widget img {
	max-width: 100%; /* Fluid images for posts, comments, and widgets */
}
img[class*="align"],
img[class*="wp-image-"],
img[class*="attachment-"] {
	height: auto; /* Make sure images with WordPress-added height and width attributes are scaled correctly */
}
img.size-full,
img.size-large,
img.header-image,
img.wp-post-image {
	max-width: 100%;
	height: auto; /* Make sure images with WordPress-added height and width attributes are scaled correctly */
}

/* Navigation */
.site-content nav {
	clear: both;
	line-height: 2;
	overflow: hidden;
}
#nav-above {
	padding: 24px 0;
	padding: 1.714285714rem 0;
}
#nav-above {
	display: none;
}
.paged #nav-above {
	display: block;
}
table.navwrap {
    width: 100%;
    margin-bottom: 2rem;
}
.nav-previous,
.previous-image {
	width: 33%;
}
.nav-next,
.next-image {
	text-align: right;
	width: 33%;
}
.nav-center {
    text-align: center;
    width: 34%;
    line-height: 1.7;
}
.nav-single + .comments-area,
#comment-nav-above {
	margin: 48px 0;
	margin: 3.428571429rem 0;
}


/* =Basic structure
-------------------------------------------------------------- */

/* Body, links, basics */
body {
	font-size: 15px;
	font-size: 1rem;
	font-family: Helvetica, Arial, sans-serif;
	text-rendering: optimizeLegibility;
	color: #444;
}

/* Assistive text */
.assistive-text,
.site .screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	overflow: hidden;
	height: 1px;
	width: 1px;
}
.main-navigation .assistive-text:focus,
.site .screen-reader-text:hover,
.site .screen-reader-text:active,
.site .screen-reader-text:focus {
	background: #fff;
	border: 2px solid #333;
	border-radius: 3px;
	clip: auto !important;
	color: #000;
	display: block;
	font-size: 12px;
	height: auto;
	padding: 12px;
	position: absolute;
	top: 5px;
	left: 5px;
	width: auto;
	z-index: 100000; /* Above WP toolbar */
}
/* Navigation Menu */
/* .main-navigation {
	margin-top: 30px;
	text-align: center;
}
.main-navigation li {
	margin-top: 24px;
	margin-top: 1.714285714rem;
	font-size: 12px;
	font-size: 0.857142857rem;
	line-height: 1.42857143;
}
.main-navigation a:hover,
.main-navigation a:focus {
	color: #21759b;
}
.main-navigation ul.nav-menu.toggled-on,
.menu-toggle {
	display: inline-block;
} */


/* //////////////////////////////////////// taichi /////////////////////////////////////// */
.cf:after {
	content: "";
	display: block;
	clear: both;
}
/* body {
	font-family: 'M PLUS Rounded 1c',"Noto Sans JP", Helvetica, "Helvetica Neue", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Osaka, sans-serif;
} */

a {
	text-decoration: none;
	transition: 1s;
	color: unset;
}
a:hover {
	opacity: 0.7;
	transition: 1s;
}

input:hover {
    opacity: 0.7;
    transition: 1s;
}
h1 {
	font-size: 1.6rem;
	font-weight: normal;
}
h2 {
	font-size: 1.4rem;
	font-weight: normal;
}
h3 {
	font-size: 1.2rem;
	font-weight: normal;
}
h4 {
	font-size: 1.1rem;
	font-weight: normal;
}
h5 {
	font-size: 1rem;
	font-weight: normal;
}
h6 {
	font-size: 0.8rem;
	font-weight: normal;
}
p {
    line-height: 1.4;
}
.os {
	font-family: 'Oswald', sans-serif;
}
.amar {
	font-family: 'Amaranth', sans-serif;
}
.viga {
	font-family: 'Viga', sans-serif;	
}
.yugo {
	font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}
.yumin{
  font-family: "Yu Mincho", "YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}
.helb {
	font-family: "Helvetica Neue", "Segoe UI", Helvetica,sans-serif;
}
.dam {
	font-family: 'Damion', cursive;
}
.italic {
	font-style: italic;
}
section.bggray {
    background-color: rgba(212, 212, 216, 0.2);
}
.wid1060 {
	width: 100%;
    max-width: 1060px;
    box-sizing: border-box;
    padding: 0 50px;
    margin: auto;
}
.wid1160 {
	width: 100%;
    max-width: 1160px;
    box-sizing: border-box;
    padding: 0 50px;
    margin: auto;
}
.wid1280 {
	width: 100%;	
    max-width: 1280px;
    box-sizing: border-box;
    margin: auto;	
}
.wid70 {
    width: 70%;
    float: left;
}
.wid50 {
    width: 50%;
    float: left;
}
.wid30 {
    width: 30%;
    float: left;
}
.center {
	text-align: center;
}
.hide-pc {
	display: none;
}
.show600 {
	display: none;
}
.anchor {
	padding-top: 250px;
	margin-top: -250px;
}
/* ヘッダー */
header#masthead {
    /* background: #fff;
    padding-bottom: 14px; */
    position: fixed;
    width: 100%;
    z-index: 1000;
    box-sizing: border-box;
}
.hdarea.cf{
    display: flex;
    justify-content: space-between;
    align-items: flex-end
}
.hdbtnarea.cf {
    padding-top: 8px;
    margin-bottom: 5px;
}
.descwr {
    width: 40%;
    float: left;
    font-size: 0.8rem;
}


/* .hdbtmr {
    width: 78%;
    box-sizing: border-box;
    padding-left: 1rem;
} */
.hdbtmr ul {
    /* display: flex;
    justify-content: flex-end;
    align-items: flex-start;
    width: 100%;
    text-align: center; */
    /* position: relative; */
}
.hdbtmr ul li {
    /* float: left;
    margin-top: 0;
    border-left: solid 2px #bfbfbf; */
    /* position: relative; */
}
/* .hdbtmr ul li:before {
    position: absolute;
    content: "";
    display: block;
    width: 2px;
    height: 8px;
    top: 0;
    right: -2px;
    background: #fff;
    z-index: 1;
}
.hdbtmr ul li:after {
    position: absolute;
    content: "";
    display: block;
    width: 2px;
    height: 8px;
    bottom: 0;
    right: -2px;
    background: #fff;
    z-index: 1;
}
.hdbtmr ul:before {
    position: absolute;
    content: "";
    display: block;
    width: 2px;
    height: 8px;
    top: 0;
    left: 0;
    background: #fff;
    z-index: 1;
}
.hdbtmr ul:after {
    position: absolute;
    content: "";
    display: block;
    width: 2px;
    height: 8px;
    bottom: 0;
    left: 0;
    background: #fff;
    z-index: 1;
}
.hdbtmr ul.sub-menu:before,
.hdbtmr ul.sub-menu li:before,
.hdbtmr ul.sub-menu:after,
.hdbtmr ul.sub-menu li:after {
    display: none;
}
.hdbtmr ul li:last-child {
    border-right: solid 2px #bfbfbf;
}

.hdbtmr ul li a {
    line-height: 40px;
    padding: 24px;
    font-size: 15px;
    color: #383838;
	cursor: pointer;
}
@media screen and (max-width: 1100px) {
.hdbtmr ul li a {
    padding: 14px;
}
.descwr {
    width: 30%;
}	
}
@media screen and (max-width: 950px) {
.hdbtmr ul li a {
    padding: 9px;
    font-size: 14px;
}

}
@media screen and (max-width: 840px) {
.hdbtmr ul li a {
    padding: 7px;
}
} */
/* めにゅ＾ー_ */
/* .hdbtmr ul.sub-menu {
    display: none;
} */
.menu-item-has-children {
  /* position: relative; */
}
/* 子を持つ親メニューにマウスオーバーしたとき、サブメニューを表示する */
/* .menu-item-has-children:hover .sub-menu {
  display: flex;
  height: 3.5rem;
}
.hdbtmr ul.sub-menu {
    display: flex;
    position: absolute;
    top: 100%;
    width: 100vw;
    background: #f2f2f2;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    height: 0;
    overflow: hidden;
    transition: height 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    align-items: center;
    justify-content: center;
    z-index: 10;
}
.hdbtmr ul.sub-menu li {
    border: none;
    text-align: center;
    display: inline-block;
}
.hdbtmr ul.sub-menu li:first-child {
    position: relative;
}
.hdbtmr ul.sub-menu li a {
    display: inline-block;
    line-height: 0px;
    padding: 20px;
}
.hdbtmr ul.sub-menu li.current-menu-item a{
    position: relative;
}
.hdbtmr ul.sub-menu li.current-menu-item:after{
    content: none;
}
.hdbtmr ul.sub-menu li.current-menu-item a:before {
    position: absolute;
    content: "\f0da";
    font-family: FontAwesome;
    left: 0;
    color: #1aa1e6;
    border-bottom: none;
}
.hdbtmr ul li.current-menu-item {
position: relative;
}
.hdbtmr ul li.current-menu-item:after {
  content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    display: inline-block;
    width: 50%;
    height: 3px;
    -moz-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #506aa5;
    border-radius: 2px;
} */
/* footer */
.pagetop {
    width: 95%;
    position: sticky;
    text-align: right;
    bottom: 132px;
    right: 120px;
    z-index: 99;
    display: none;
    font-size: 0.8rem;
    color: #01654D;
    display: inline-block;
}
.topTri{
    display: inline-block;
    position: relative;
}
.topTri::before{
    position: absolute;
    bottom: 45%;
    transform: translateY(50%);
    left: -1.25rem;
    content: url(../doitsumura-child/img/pagetop.svg);
}

.ftl {
    width: 25%;
    float: left;
    box-sizing: border-box;
    padding-right: 3%;
}
p.ftlogo  {
    margin-bottom: 2.4rem;
}
p.ftlogo img {
    width: 100%;
}
.ftla a {
    background: #00a0e9;
    display: block;
    color: #fff;
    font-size: 1.1rem;
    border-radius: 7px;
    position: relative;
    text-align: center;
    margin-bottom: 0.9rem;
    width: 100%;
    padding: 14px 0;
}
.ftla li:last-child a {
    background: #f45a5b;
}
.ftla a:after { 
	position: absolute;
	content: "\f054";
	font-family: FontAwesome;
	right: 10px;
	top: 15px;
}
.center.fttoi {
    width: 100%;
    display: block;
    font-size: 0.9rem;
    border: solid 2px #86a4b3;
    border-radius: 1px;
    padding: 9px;
    box-sizing: border-box;
    margin-top: 1.7rem;
    margin-bottom: 1.4rem;
}
.fttel {
    margin-bottom: 1.3rem;
    text-align: center;
}
.fttel h2 {
    font-size: 1.6rem;
    box-sizing: border-box;
    padding-left: 24px;
    position: relative;
}
.fttel h2:before {
	content: url(./img/telb.png);
	position: absolute;
	left: 0;
}
.ftll {
        position: relative;
}
.ftll p {
    padding-right: 90px;
    box-sizing: border-box;
    line-height: 44px;
}
.ftll a.one {
    position: absolute;
    right: 47px;
    top: 0;
}
.ftll a.two {
    position: absolute;
    right: 0px;
    top: 0;
}
.ftr {
    float: left;
    width: 75%;
}
.ftrt ul {
    display: flex;
}
.ftrt ul li {
    border-right: solid 2px #bfbfbf;
    position: relative;
}
.ftrt ul li:before {
    position: absolute;
    content: "";
    display: block;
    width: 2px;
    height: 8px;
    top: 0;
    right: -2px;
    background: #0f2c71;
    z-index: 1;
}
.ftrt ul li:after {
    position: absolute;
    content: "";
    display: block;
    width: 2px;
    height: 8px;
    bottom: 0;
    right: -2px;
    background: #0f2c71;
    z-index: 1;
}
.ftrt ul li:last-child {
    border-right: none;
}
.ftrt ul li a {
	line-height: 40px;
    padding: 15px;
    font-size: 15px;
    font-weight: 300;
}
.ftrt {
    margin-bottom: 1.8rem;
}
#colophon h5 {
	font-size: 0.9rem;
}
.ftrm.cf,.ftrb.cf {
    border: solid 2px #828dad;
    padding: 15px;
    box-sizing: border-box;
    margin-bottom: 1.3rem;
}
footer .ftrm.cf,.ftrb.cf {
    padding: 0;
}
.ftrml {
    width: 15%;
    float: left;
    text-align: center;
}
.ftrml p {
    padding-top: 10px;
}
.ftrmr.cf h5 {
    padding-top: 14px;
}
.ftrmr.cf {
    width: 85%;
    float: left;
    box-sizing: border-box;
    padding: 0 1rem;
    border-left: solid 1px #818cae;
}
.ftrmr.cf .one {
    width: 75%;
    float: left;
}
.ftrmr.cf .two,
.ftrmr.cf .three {
    width: 20%;
    float: left;
}
.ftrmr.cf .four {
    width: 25%;
    float: left;
}
.ftrmr.cf .one ul {
    display: flex;
    flex-wrap: wrap;
}
.ftrmr.cf ul li {
    font-size: 0.8rem;
    margin-top: 1rem;
    box-sizing: border-box;
    padding-left: 8px;
    position: relative;
    line-height: 1.3
}
.ftrmr.cf .one ul li {
    width: 33.3%;
}
.ftrmr.cf ul li:before { 
	position: absolute;
	content: "\f0da";
	font-family: FontAwesome;
	left: 0;
	color: #009dec;
}
.ftrm.cf {
    position: relative;
}
footer .ftrmr.cf {
    padding-bottom: 0.8rem;
}
.ftrm.cf a.sagasufl {
/*     position: absolute; */
    bottom: 15px;
    right: 40px;
    font-size: 0.8rem;
}
.ftrb.cf div {
    float: left;
    width: 33.3%;
    border-left: solid 4px #ddd;
    box-sizing: border-box;
    padding: 10px;
    padding-bottom: 10px;
}
.ftrb.cf div:nth-child(1) {
    border-left: solid 4px #94c127;
}
.ftrb.cf div:nth-child(2) {
    border-left: solid 4px #22caff;
}
.ftrb.cf div:nth-child(3) {
    border-left: solid 4px #ea86b9;
}
.ftrb.cf {
    display: flex;
}
.ftrb.cf ul li {
    margin-top: 0.9rem;
    font-size: 0.8rem;
    box-sizing: border-box;
    padding-left: 5px;
}
p.btm1 {
    font-size: 0.8rem;
    text-align: right;
    margin-bottom: 1rem;
}
.btm2.cf {
    width: 45%;
    float: left;
}
.btm2.cf ul {
    display: flex;
    width: 100%;
    justify-content: space-between;
}
.btm2.cf ul li {
    padding-right: 10px;
    font-size: 0.8rem;
    color: #a3c9dc;
}
.btm2r {
    width: 55%;
    float: left;
    text-align: right;
}
.btm2r p {
    line-height: 0.7;
    padding-left: 10px;
}
.ftrt.hide600 {
    position: relative;
    padding-right: 85px;
}
.ftrt.hide600 a.torec {
    font-size: 0.9rem;
    position: absolute;
    right: 0;
    display: inline-block;
    padding: 6px;
    background: #fff;
    color: #102c71;
    top: 6px;
    border-radius: 4px;
}
.ftrt.hide600 a.torec i {
	padding-left: 4px;
}

/* 詳細系 */
.dvddl {
    width: 24%;
    float: left;
    margin-right: 5%;
}
.sidewr {
    background: #F8F8F4;  
    padding-bottom: 0.2rem;
    margin-bottom: 2rem;
}
.sidewr h3 {
    background: #0f2c70;
    color: #fff;
    text-align: center;
    padding: 12px;
    font-size: 0.9rem;
    margin-bottom: 1.5rem;
}
.sidein {
    box-sizing: border-box;
    padding: 15px 1.2rem;
    margin-bottom: 1.8rem;
}
.sidein img {
    width: 100%;
    margin-bottom: 0.8rem;
}
.sidein.sidein2 a {
    padding: 10px 35px 10px 25px;
    background: #00a0e9;
    display: block;
    margin: 0 10px;
    color: #fff;
    font-size: 1.1rem;
    border-radius: 7px;
    position: relative;
    text-align: center;
    margin-bottom: 0.8rem;
}
.sidein.sidein2 li:last-child a {
 background: #F45B5B;	
}
.sidein.sidein2 a:after {
    position: absolute;
    content: "\f054";
    font-family: FontAwesome;
    right: 10px;
    top: 11px;
}
.sidein.newswr p {
    font-size: 0.85rem;
    margin-bottom: 0.4rem;
}
.sidein.newswr p a {
    text-decoration: underline;
    color: #1aa1e6;
}
.sidein.newswr li {
    margin-bottom: 1.5rem;
}
.dvdr.cf.wid1160 {
    padding-top: 3rem;
}
.dvddr {
    width: 71%;
    float: left;
}



/* 教室 */
.dvddr h1 {
    margin-bottom: 2.3rem;
}
.topimg {
    margin-bottom: 2rem;
}
.topimg.single {
    margin-bottom: 0;
}
.topimg img {
    width: 100%;
    BORDER-RADIUS: 4px;
}
section.locbox {
    margin-bottom: 2rem;
}

section.locbox h2 {
    border-bottom: solid 2px #dadada;
    padding-bottom: 6px;
    margin-bottom: 1.3rem;
}
.locwr.cf {
    display: flex;
    flex-wrap: wrap;
}
.locwr.cf .chlbox {
    width: 31%;
    margin: 0 1.16%;
    float: left;
    position: relative;
    margin-bottom: 2rem;
}
.chlbox p.junbi {
    position: absolute;
    right: 0;
    color: #fff;
    font-size: 0.8rem;
    padding: 3px 10px;
    background: #f35151;
    letter-spacing: 1.2px;
    z-index: 100;
}
.chlbox p {
    font-size: 0.9rem;
    line-height: 1.5;
}
.chlbox h3 {
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
}
.chlbox p.tel {
    font-size: 1rem;
    margin-bottom: 0.1rem;
}
.chlimgwr {
    height: 150px;
    overflow: hidden;
    margin-bottom: 0.7rem;
    position: relative;
    border-radius: 6px;
}
.chlimgwr img {
 position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
}
a.tellink {
    color: #6bb9ce;
}
/* 教室single */

p.loc {
    display: inline-block;
    margin-bottom: 0.6rem;
    padding: 1px 16px;
    background: #fb9a3f;
    font-size: 0.8rem;
    color: #fff;
    border-radius: 13px;
}
.dvddr .schpicl h1 {
    margin-bottom: 2rem;
}
.schpicl {
    width: 55%;
    margin-right: 3%;
    float: left;
}
.schpicl img {
	width: 100%;
    border-radius: 8px;
}
.schpicr {
    width: 39%;
    float: right;
}
.schpicr img {
	border-radius: 8px;
}
section.schpics.cf {
    margin-bottom: 3rem;
}
section.schinmid {
    margin-bottom: 3rem;
}
section.schinmid h2 {
    font-size: 1.1rem;
    position: relative;
        border-bottom: solid 2px #888;
    padding-bottom: 6px;
    margin-bottom: 2rem;
}
section.schinmid h2 a {
    position: absolute;
    right: 0;
    font-size: 0.8rem;
}
.mindinl {
    width: 52%;
    float: left;
    margin-right: 3%;
}
.midinr {
    float: left;
    width: 45%;
}
.midinr iframe {
    width: 100%;
}
.mindinl th {
    width: 21%;
    font-size: 0.9rem;
    padding-right: 10px;
    box-sizing: border-box;
    padding-bottom: 1rem;
}
.mindinl td {
    padding-bottom: 0.6rem;
}
.mindinl td p {
    border-bottom: solid 2px #d8d8d8;
    font-size: 0.9rem;
    padding-bottom: 5px;
}
.mindinl td p.tel {
	font-size: 1.2rem;
}
.mindinl table {
    margin-bottom: 2.4rem;
}
.mindinl div.center a {
    background: #b6b6b6;
    color: #fff;
    font-size: 0.9rem;
    padding: 0.9rem 2rem;
    border-radius: 21px;
    display: inline-block;
}
section.schoolnews {
    margin-bottom: 3rem;
}
section.schoolnews h2 {
    font-size: 1.2rem;
    position: relative;
    padding-bottom: 6px;
}
section.schacv h2 {
    font-size: 1.1rem;
    position: relative;
    border-bottom: solid 2px #888;
    padding-bottom: 6px;
    margin-bottom: 2rem;
}
.schacv section.arcwrap {
    border-bottom: none;
    margin-bottom: 0;
}
section.schacv {
    margin-bottom: 3rem;
}
.center.schbtn input {
    display: inline-block;
    -webkit-appearance: none;
    background: #0f2c70;
    color: #fff;
    border: none;
    font-size: 1rem;
    padding: 0.5rem 2rem;
}
section.schinbtm {
    margin-bottom: 3rem;
}
.schbtmin.cf {
    margin-bottom: 2rem;
}
section.schinbtm h2 {
    font-size: 1.1rem;
    position: relative;
        border-bottom: solid 2px #888;
    padding-bottom: 6px;
    margin-bottom: 1.6rem;	
}
.scbtl {
    width: 35%;
    float: left;
    margin-right: 3%;
    font-size: 0.9rem;
}
.schacv .acvarbox.cf {
    width: 31.33%;
    margin: 0 1%;
    padding: 0.7rem 0.7rem 1rem;
    display: block;
    margin-bottom: 1.6rem;
}
.schacv p.argraade {
	padding-top: 12px;
}
.thumbwr a:after {
    display: block;
    clear: both;
    content: "";
}
.thumbwr a {
    display: block;
    width: 100%;
    height: 100%;
}
.schacv .acvarl {
    float: left;
    width: 100%;
    margin-right: 0;
    margin-bottom: 0.5rem;
}
.schacv .acvarr a {
    color: #1aa1e6;
}
.schacv .acvarl .thumbwr {
    margin: auto;
    margin-bottom: 0.7rem;
    width: 100%;
    height: 120px;
    border-radius: 4px;
    position: relative;
}
.schacv .acvarl .thumbwr img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    width:  100%;
}
.schacv .acvarr {
    float: left;
    width: 100%;
}
.scbtl img{
    width: 100%;
    border-radius: 15px;
    margin-bottom: 0.3rem;
}
.schbtr {
    width: 62%;
    float: left;
}
ul.slides li.slide img {
	width: 100%;
}
section.timetable h2, section.gokakuko h2 {
    font-size: 1.1rem;
    position: relative;
    border-bottom: solid 2px #888;
    padding-bottom: 6px;
    margin-bottom: 1.6rem;
}
section.timetable {
    margin-bottom: 3rem;
}
section.timetable iframe {
    width: 100%;
    height: 800px;
}
section.gokakuko {
    margin-bottom: 3rem;
}
section.gokakuko p {
    margin-bottom: 1rem;
}
/* 実績single */
article#acvsgl h1 {
    font-size: 2rem;
    font-weight: normal;
    margin-bottom: 0.6rem;
}
section.upbox {
    background: #fffff4;
    border-top: solid 5px #00A0DF;
    border-bottom: solid 5px #00A0DF;
    box-sizing: border-box;
    padding: 1.7rem;
    position: relative;
    padding-bottom: 0;
    margin-bottom: 3rem;
}
section.upbox p.time {
    position: absolute;
    right: 3rem;
    top: 0.6rem;
    font-size: 0.8rem;
    color: #a2a2a2;
}
section.upbox h2 {
    font-size: 1.2rem;
    position: relative;
    padding-left: 2rem;
    color: #e60011;
    margin-bottom: 2rem;
}
section.upbox h2:before {
    content: url(./img/up.png);
    position: absolute;
    left: 0;
    top: -2px;
}
.upbtl {
    width: 85%;
    float: left;
    box-sizing: border-box;
    min-height: 105px;
    margin-bottom: 1rem;
}
.upbtl .thumbwr {
    width: 40%;
    float: left;
}
.acvinfo {
    width: 60%;
    float: left;
    box-sizing: border-box;
    padding-left: 3%;
}
.upbtl .thumbwr img {
    width: 100%;
    border-radius: 7px;
}
.acvinfo h3 {
    line-height: 1.3;
    font-size: 1.1rem;
    margin-bottom: 0.7rem;
}
.acvinfo h3 span {
    font-size: 1.3rem;
}
.acvinfo table {
	font-size: 0.9rem;
}
.acvinfo table th {
    padding-right: 14px;
    padding-bottom: 0.5rem;
}
.upbtr p {
    font-size: 0.8rem;
    color: #fff;
    background: #00a0e9;
    display: inline-block;
    width: 100%;
    box-sizing: border-box;
    text-align: center;
    margin-bottom: 5px;
    margin-right: 2%;
    padding: 3px;
    border-radius: 4px;
    float: left;
}
.upbtr {
    width: 15%;
    float: left;
}
.upbt.cf {
    margin-bottom: 1rem;
}
.upbm {
    border-top: solid 2px #c1c1c1;
    position: relative;
}
.upbm h4 {
    font-size: 0.8rem;
    background: #fff;
    display: inline-block;
    position: absolute;
    top: -12px;
    padding: 4px 10px;
    border: solid 2px #c1c1c1;
    border-radius: 10px;
}
.upbm p {
    font-size: 0.9rem;
}
.upbm h4 {
    font-size: 0.8rem;
    background: #fff;
    display: inline-block;
    position: absolute;
    top: -12px;
    left: 0;
    padding: 4px 10px;
    border: solid 2px #c1c1c1;
    border-radius: 10px;
}
.upbm {
    border-top: solid 2px #c1c1c1;
    position: relative;
    padding: 2rem 2.5rem;
}
section.uptwo h2 {
    font-size: 1.2rem;
    margin-bottom: 1.3rem;
}
.btn3 {
    width: 31.3%;
    float: left;
    margin: 0 1%;
    text-align: center;
}
.btn3 a span {
    font-size: 1.5rem;
}
.btn3 a {
    padding: 13px 0.5rem;
    box-sizing: border-box;
    display: block;
    color: #fff;
    background: #0f2c70;
    border-radius: 10px;
    font-size: 0.9rem;
    line-height: 1.5;
    position: relative;
}
.btn3 a:after {
    position: absolute;
    content: "\f054";
    font-family: FontAwesome;
    right: 10px;
    bottom: 14px;
    font-size: 1.3rem;
}
.btn3wr.cf {
    display: flex;
    margin-bottom: 3rem;
}
section.uptwo h2 {
    text-align: center;
    border: solid 2px;
    color: #0f2c70;
    padding: 10px 0 8px;
    border-radius: 24px;
    margin-bottom: 2rem;
}
/* pardot */
#pardot h1 {
	margin-bottom: 2rem;
}
/* 実績arc */
section.arcwrap {
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: solid 2px;
    display: flex;
    flex-wrap: wrap;
}
article#acvsgl .acvarbox.cf p a {
    color: #55c6ff;
}
.nendpld {
    margin-bottom: 1.5rem;
    box-sizing: border-box;
    padding-left: 2%;
    text-align: right;
}
.nendpld p {
}
.nendpld p a {
    display: inline-block;
    padding: 2px 16px;
    background: #0f2e6f;
    color: #fff;
    font-size: 0.9rem;
    border-radius: 22px;
    margin-left: 15px;
}
.acvarbox.cf {
    width: 47%;
    float: left;
    margin: 0 1.5%;
    background: #fffff4;
    margin-bottom: 2.1rem;
    box-shadow: 3px 3px 8px #ddd;
    box-sizing: border-box;
    padding: 2rem 1.5rem;
    display: flex;
}
.acvarl {
    float: left;
    width: 26%;
    margin-right: 4%;
}
.acvarl a:hover {
    opacity: 1;
    filter: brightness(120%);
}
.acvarr {
    float: left;
    width: 70%;
}
.acvarr p {
    font-size: 0.9rem;
    line-height: 1.5;
}
.acvarl .thumbwr {
    border-radius: 50%;
    overflow: hidden;
    margin-bottom: 0.7rem;
    width: 84px;
    height: 84px;
    background-image: url(./img/jinbutu.png);
    background-size: cover;
}
.acvarl p.zaiseki {
    font-size: 0.9rem;
    margin-bottom: 0.2rem;
}
p.argraade {
    border-top: solid 3px;
    padding-top: 4px;
    font-size: 0.9rem;
}
p.argraade.s1,
p.argraade.s2,
p.argraade.s3,
p.argraade.s4,
p.argraade.s5,
p.argraade.s6 {
    border-top: solid 3px #95c036;
}
p.argraade.c1,
p.argraade.c2,
p.argraade.c3 {
    border-top: solid 3px #00a0df;
}
p.argraade.k1,
p.argraade.k2,
p.argraade.k3 {
    border-top: solid 3px #ef94ae;
}
.titarea {
    width: 100%;
    background-image: url(./img/acvtitbg.jpg);
    background-size: cover;
    background-position: center center;
    margin-bottom: 3rem;
    padding: 20% 1rem 1rem;
    box-sizing: border-box;
}
.titareain {
    background: rgba(255, 255, 255, 0.7);
    box-sizing: border-box;
    padding: 1rem;
}
.titareain tr th {
    width: 35%;
    vertical-align: middle;
    text-align: center;
}
.titareain tr td {
    padding-left: 1rem;
}
.titareain tr th h1 {
    margin-bottom: 0 !important;
    color: #0f2c71;
    text-shadow: 1px 2px #FFF;
}







/* コース */
.dvddr .course h1 {
    margin-bottom: 0.6rem;
    font-size: 1.8rem;
    position: relative;
}
.dvddr .course h1 span {
    position: absolute;
    right: 0;
    font-size: 0.9rem;
    font-style: italic;
    color: #b1b1b1;
    bottom: 0;
}
.course .bt {
    border-top: solid 4px #95c036;
    padding-top: 2rem;
    padding-bottom: 2rem;
}
.crs1l img {
    width: 100%;
    border-radius: 12px;
}
.crs1l {
    width: 38%;
    float: left;
    margin-right: 2%;
}
.crs1r {
    width: 60%;
    float: left;
}
.crs1r p {
    line-height: 1.6;
}
.sourses {
    margin-top: 2rem;
}
.sourses h2 {
    margin-bottom: 1rem;
    font-size: 2rem;
    position: relative;
    padding-left: 5px;
    display: inline-block;
    background: linear-gradient(transparent 57%, #fff03f 42%);
    background-position: left 40px bottom;
    line-height: 32px;
    margin-left: -2rem;
}
.sourses h2:before {
    position: absolute;
    content: url(./img/note.png);
    left: -34px;
    bottom: 0;
}
.sourses h2 small {
    font-size: 1rem;
}
.coursewr {
/*     background: url(./img/crsbg.png); */
	background: #DFEDED;
    padding: 1.3rem;
    display: flex;
    justify-content: space-between;
    border-radius: 15px;
}
.coursewr a {
    display: block;
    background: #fff;
    padding: 1.3rem 2.5rem 1.3rem 2rem;
    border-radius: 32px;
    color: #112e6e;
    position: relative;
    box-shadow: 2px 2px 4px #ddd;
}
.coursewr a:after {
    position: absolute;
    content: "\f054";
    font-family: FontAwesome;
    right: 10px;
    }
.crs2.bt h3 {
    border-left: solid 8px #96be41;
    padding: 2px;
    padding-left: 0.6rem;
    margin-bottom: 1.1rem;
}
.crs2.bt div.cf {
    padding-bottom: 2rem;
    border-bottom: solid 2px #ddd;
    margin-bottom: 2rem;
}
.crs2.bt div.cf .s3l {
    width: 35%;
    float: left;
    margin-right: 4%;
}
.crs2.bt div.cf .s3l img{
    width: 100%;
    border-radius: 12px;
}
.crs2.bt div.cf .s3r {
    width: 61%;
    float: left;
}
.s3r p {
    line-height: 1.6;
}
.crs2.bt div.cf:last-child {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 0;
}
.crs3 {
    border: 2px solid #8c8c8c;
    border-radius: 14px;
    box-sizing: border-box;
    padding: 1rem;
    padding-bottom: 2rem;
    margin-bottom: 1rem;
}
.bt.bb span {
    font-size: 0.8rem;
    width: 100%;
    text-align: right;
    display: block;
}
.bb.bt {
    border-top: 0;
    border-bottom: solid 4px #95c036;
    margin-bottom: 1rem;
}
.crs3 h2 {
    font-size: 1rem;
    margin-bottom: 2.5rem;
    position: relative;
    width: 100%;
    text-align: center;
    color: #fff;
    background: #95c036;
    padding: 10px;
    box-sizing: border-box;
    border-radius: 22px;
    margin-top: 0.5rem;
}
section.sched h2 {
    margin-bottom: 0.6rem;
    font-size: 1.8rem;
    position: relative;
}
section.sched.course img {
    width: 100%;
}
section.sched h2 span {
    position: absolute;
    right: 0;
    font-size: 0.9rem;
    font-style: italic;
    color: #b1b1b1;
    bottom: 0;
}
.crs3 h2 span {
    position: absolute;
    right: 1rem;
    font-size: 0.8rem;
    color: #a0a0a0;
}
.crs3in .qaBox {
    border-bottom: solid 2px #ddd;
	padding-bottom: 0.8rem;
    margin-bottom: 0.9rem;
}
.crs3in p.btnBelow {
    font-weight: bold;
    position: relative;
    cursor: pointer;
}
.crs3in .qaBox .answer {
    margin-bottom: 2rem;
    padding-top: 2rem;
    padding-left: 33px;
    position: relative;
}
.crs3in .qaBox .answer p {
    font-size: 0.9rem;
    color: #9a9a9a;
    margin-bottom: 0.5rem;
    line-height: 1.6;
}
.crs3in .qaBox .answer:before {
    content: "A.";
    position: absolute;
    left: 0;
}
section.course {
    margin-bottom: 2rem;
}
p.btnBelow i {
    color: #bbb;
    transition: 0.5s;
    margin-right: 0.5rem;
}
p.btnBelow.current i {
    transform: rotate(90deg);
    transition: 0.5s;
}
.dvddr {
    margin-bottom: 3rem;
}
#course2 .course .bt {
    border-top: solid 4px #1aa1e6;
}
#course2 .crs2.bt h3 {
    border-left: solid 8px #27a2e3;
}
#course3 .course .bt {
    border-top: solid 4px #ef94ae;
}
#course3 .crs2.bt h3 {
    border-left: solid 8px #ef94ae;
}
#course3 .coursewr {
    justify-content: flex-start;
}
#course3 .coursewr a {
    margin-right: 2rem;
}
#course2 .crs3 h2 {
    background: #1aa1e6;
}
#course2 .course .bt {
    border-top: 0;
    border-top: solid 4px #1aa1e6;
}
#course2 .bb.bt {
    border-bottom: solid 4px #00a0e9;
}
/* 高校生コース */
.hightit {
    width: 100%;
    background-image: url(./img/dummyimg1.jpg);
    background-size: cover;
    background-position: center center;
    border-radius: 15px;
    padding: 1rem;
    padding-top: 20%;
    margin-bottom: 2.5rem;
    text-align: right;
    box-sizing: border-box;
    margin-top: 2rem;
}
.hightopin {
    background: rgba(255, 255, 255, 0.8);
    display: inline-block;
    box-sizing: border-box;
    padding: 1.5rem 2rem;
    border-radius: 9px;
}
.hightopin img {
    max-width: 100%;
}
h2.yugo.hightitle img {
    width: 210px;
    vertical-align: bottom;
}
h2.yugo.hightitle {
	width: 94%;
    margin: auto;
    line-height: 1.3;
    margin-bottom: 3rem;
}
.highsub.cf {
    width: 94%;
    margin: auto;
    margin-bottom: 3rem;
}
.highsubl {
    width: 25%;
    float: left;
}
.highsubl img {
    width: 100%;
    border-radius: 10px;
}
.highsubr {
    width: 75%;
    float: left;
    box-sizing: border-box;
    padding-left: 3%;
}
.highsubr p {
    margin-bottom: 1.5rem;
    line-height: 1.8;
}
section.highbg {
	width: 100%;
    background-image: url(./img/highbg.png);
    background-size: cover;
    background-position: center center;
    padding: 3rem 0;
    margin-bottom: 3rem;
}
section.highbg .wid1160 {
    background: rgba(255, 255, 255, 0.8);
    box-sizing: border-box;
    border-radius: 30px;
    padding: 3rem 12% 2rem;
}
section.highbg h3 {
    margin-bottom: 3rem;
}
.cardh.wid1160 {
    width: 94%;
    margin: auto;
    margin-bottom: 3rem;
}
.cardh.wid1160 h3 {
    margin-bottom: 4rem;
    position: relative;
}
.cardh.wid1160 h3:after {
    position: absolute;
    width: 250px;
    height: 3px;
    display: block;
    background: #f193ae;
    left: 0;
    right: 0;
    margin: auto;
    bottom: -24px;
    content: "";
}
.cardl {
    width: 25%;
    float: left;
}
.cardl img {
    width: 100%;
    border-radius: 10px;
}
.cardr {
    width: 75%;
    float: left;
    box-sizing: border-box;
    padding-left: 2%;
}
.cardr p {
    line-height: 1.7;
}
section.bggray.high3 {
    background-color: #F8F8F4;
    padding: 4rem 0 1rem;
    margin-bottom: 4rem;
}
section.bggray.high3 h3 {
    font-size: 1.5rem;
    color: #24489e;
    line-height: 48px;
    display: inline-block;
    background-image: url(./img/enpitu.png);
    background-size: cover;
    background-position: center right;
    padding-right: 2rem;
    padding-top: 5px;
    padding-left: 1rem;
    border-left: solid 2px #0f2c71;
}
.h3wr {
    position: relative;
    margin-bottom: 3rem;
    z-index: 2;
}
section.bggray.high3 .h3wr:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 2px;
    top: 27px;
    left: 0;
    background: #7c8aaf;
    z-index: -1;
}
.high3l {
    width: 35%;
    float: left;
}
.high3l img {
    width: 100%;
    border-radius: 10px;
}
.high3r {
    width: 65%;
    float: left;
    box-sizing: border-box;
    padding-left: 3%;
}
.high3r p {
    line-height: 1.7;
    margin-bottom: 1rem;
}
section.bggray.high3 .cf {
    margin-bottom: 3rem;
}
section.bggray.high3 .cf.reve {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row-reverse;
}
.high3l2 {
    width: 35%;
    float: left;
}
.high3l2 img {
    width: 100%;
    border-radius: 10px;
}
.high3r2 {
    width: 65%;
    float: left;
    box-sizing: border-box;
    padding-right: 3%;
}
.high3r2 p {
    line-height: 1.7;
    margin-bottom: 1rem;
}
.high3db {
    display: flex;
    justify-content: space-evenly;
    margin-bottom: 4rem;
}
.high3db a {
    position: relative;
    padding: 1rem 2rem 1rem 1.2rem;
    background: #0f2c71;
    color: #fff;
    border-radius: 28px;
}
.high3db a:after {
    position: absolute;
    content: "\f054";
    font-family: FontAwesome;
    right: 10px;
    top: 17px;
}
.high3db a:before {
    content: "";
    position: absolute;
    bottom: -4px;
    width: 83%;
    height: 2px;
    background: #0e2a72;
    margin: auto;
    right: 0;
    left: 0;
}
.wid1160.highfaq {
    margin-bottom: 4rem;
}
.wid1160.highfaq h3 {
    margin-bottom: 3rem;
    font-size: 1.6rem;
    color: #0f2c71;
    letter-spacing: 1.6px;
}
.wid1160.highfaq h3 small {
    font-size: 0.9rem;
    color: #444;
    letter-spacing: 0.7px;
}
.highfaqwr {
    border-radius: 20px;
    border: solid 3px #DFEDED;
    box-sizing: border-box;
    padding: 4rem 3rem 0;
}
.wid1160.highfaq img {
    width: 100%;
    margin-bottom: 3rem;
    box-sizing: border-box;
    padding: 0 40px;
}
.highfaqwr h4 {
    position: relative;
    padding-left: 50px;
    border-bottom: solid 3px #dfeded;
    padding-bottom: 1rem;
    margin-bottom: 1.7rem;
    box-sizing: border-box;
    width: 100%;
    line-height: 1.2;
}
.highfaqwr h4:after {
	position: absolute;
	content: url(./img/q.png);
	left: 16px;
    top: -8px;
}

.highfaqwr div.highfaqt {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 2rem;
}
.highfaqwr div.highfaqt div {
    width: 47%;
    margin-bottom: 1.6rem;
}
.highfaqwr div.highfaqt div p {
    line-height: 1.8;
    font-size: 0.9rem;
}
.wid1160.narrow {
    width: 65%;
    margin-bottom: 3rem;
}

/* トップ */
section.top1 .slidewrap {
    max-width: 1700px;
    margin: auto;
}
.crs3in.topgrid.cf.show600 {
    display: none;
}
.slidewrap {
    position: relative;
}
.slidebox {
    position: absolute;
    top: 54%;
    right: 16%;
    width: 34%;
}
.slidebox img {
    width: 100%;
    filter: drop-shadow(2px 2px 4px #929292);
}
.metaslider .flexslider {
    margin: 0 !important;
}
.flex-direction-nav .flex-next {
    right: 3px !important;
}
.metaslider .flex-control-nav {
    bottom: 16% !important;
}
.flex-control-paging li a {
    background: rgb(255, 255, 255, 0.6) !important;
    box-shadow: 1px 1px 4px rgba(0,0,0,.4) !important;
}
.flex-control-paging li a.flex-active {
    background: #fff !important;
}
section.top2 {
    position: relative;
    background: #DFEDED;
    margin-top: -1.7rem;
    padding-top: 70px;
    padding-bottom: 2rem;
}
.twobtns a {
    background: #12306e;
    display: block;
    color: #fff;
    text-align: center;
    font-size: 1.7rem;
    padding: 0.1rem 90px 0.8rem 40px;
    border-radius: 10px;
    position: relative;
    line-height: 1.4;    
    box-shadow: 6px 5px 36px #424444;
}
.twobtns a:after {
    position: absolute;
    content: url(./img/maruya.png);
    right: 20px;
    top: 18px;
}
.twobtns a small {
	font-size: 0.9rem;
}
.twobtns {
    display: flex;
    width: 80%;
    margin: auto;
    justify-content: space-around;
    margin-top: -115px;
    margin-bottom: 2.5rem;
}
ul.top-slides li img {
    margin: auto;
    width: 93%;
}
section.top3 {
    padding-top: 3.5rem;
}
.tp3tt p {
    line-height: 1.6;
    font-size: 1.1rem;
}
.tp3tt h2 {
    font-size: 1.9rem;
    margin-bottom: 2.5rem;
    display: inline-block;
    color: #0f2e6f;
    position: relative;
}
.tp3tt {
	width: 50%;
    padding-left: 50%;
    background-image: url(./img/dummyimg1.jpg);
    background-repeat: no-repeat;
    background-size: 45%;
    padding-bottom: 11rem;
}
.tp3tt h2:after {
    content: "";
    width: 100%;
    height: 5px;
    background: #f65957;
    display: block;
    border-radius: 11px;
    position: absolute;
    bottom: -1.3rem;
}
.rinen {
    width: 60%;
    float: right;
    background: rgba(244, 243, 239, 0.8);
    padding: 2rem 2.5rem 1.5rem;
    box-sizing: border-box;
    font-size: 0.9rem;
    margin-top: -9rem;
    margin-bottom: 4rem;
    box-shadow: 3px 3px 4px #eae8e8;
/*     background-image: url(./img/dummyimg1.jpg); */
    background-repeat: no-repeat;
    background-position: center;
    background-size: 24%;
    border-radius: 23px;
}
.rinen p {
    line-height: 1.7;
    font-size: 1rem;
}
.rinen h3 {
    font-size: 1.6rem;
    text-align: center;
    border-bottom: solid 1px;
    padding-bottom: 0.8rem;
    margin-bottom: 1.3rem;
    color: #2147a2;
}
.topgrid.cf {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 2.5rem;
}
.grid {
    float: left;
    width: 33.3%;
    background: #c8e5ed;
    box-sizing: border-box;
    padding: 1rem 2.5rem 2rem;
}
.grid:nth-child(even) {
    background: #f2f2f2;
}
.grid:nth-child(2) {
    background: #fff;
}
.grid img {
	width: 100%;
}
.grid h3 {
    color: #1f4594;
    margin-bottom: 1rem;
}
.grid h2 {
    font-size: 2.1rem;
    color: #112e6f;
    font-weight: bold;
    margin-bottom: 7px;
}
section.top3 a {
    display: inline-block;
    border: solid 2px;
    padding: 1.3rem 2.5rem;
    position: relative;
    margin-bottom: 3.5rem;
    border-radius: 40px;
}
section.top3 a:after {
    position: absolute;
    content: "\f054";
    font-family: FontAwesome;
    right: 15px;
}
section.top4 {
    background: #fffac7;
    padding-top: 4rem;
}
section.top4 .wid1060 {
    max-width: 1200px;
}
section.top4 h2 {
    font-size: 1.5rem;
    margin-bottom: 4rem;
    color: #0e2a72;
    position: relative;
    z-index: 1;
    display: inline-block;
}
section.top4 h2:after {
    position: absolute;
    content: "";
    width: 112%;
    height: 17px;
    background: #e7fe69;
    border-radius: 15px;
    left: -6%;
    z-index: -1;
    bottom: -0.5rem;
}
.topacvbox {
    box-sizing: border-box;
    padding: 0 0.8rem;
    padding-bottom: 2rem;
}
.tpacvin {
    background: rgba(255, 255, 255, 0.8);
    box-sizing: border-box;
    padding: 1rem;
    font-size: 0.9rem;
    box-shadow: 5px 6px 14px #c7c297;
    border-radius: 10px;
}
.tpacvin a {
    color: #55c6ff;
}
.tpacvwr {
    margin-bottom: 2rem;
}
a.tp4a {
    display: inline-block;
    padding: 1.3rem 2.5rem;
    position: relative;
    margin-bottom: 3.5rem;
    border-radius: 40px;
    background: #0f2c71;
    color: #fff;
    font-size: 1.2rem;
    box-shadow: 3px 4px 11px #a7a4a4;
}
a.tp4a:after {
    position: absolute;
    content: "\f054";
    font-family: FontAwesome;
    right: 15px;
}
.tpacvl {
    width: 45%;
    float: left;
    margin-right: 3%;
}
.tpacvl img {
    width: 100%;
    border-radius: 8px;
}
.tpacvr {
    width: 52%;
    float: left;
    font-weight: bold;
}
.tpacvr .zaiseki {
    margin-bottom: 1rem;
}
.tpacvin .cf {
    margin-bottom: 1.5rem;
}
section.top5 {
    padding-top: 4rem;
    margin-bottom: 4rem;
}
section.top5 h2 {
    font-size: 1.6rem;
    margin-bottom: 3rem;
}
.cf.tpcrswr {
    display: flex;
    justify-content: space-between;
}
.cf.tpcrswr {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 3rem;
}
.tpcrsbox {
    width: 31%;
    float: left;
    border: solid 2px #7b7b7b;
    box-sizing: border-box;
    padding: 18px;
    position: relative;
    padding-bottom: 4.3rem;
    border-radius: 10px;
}
.tpcrsbox h3 {
    font-size: 1.5rem;
    border-bottom: solid 4px #96be41;
    padding-bottom: 5px;
    margin-bottom: 0.8rem;
}
section.tmt {
    background: #0f2c71;
    padding: 1rem 0;
    background-image: url(./img/tmtbg.png);
    background-repeat: no-repeat;
    background-position: right center;
    background-size: cover;
}
section.tmt h2 {
    font-size: 2.5rem;
    color: #f65957;
    margin-bottom: 1rem;
}
section.tmt p {
    font-size: 1.4rem;
    color: #fff;
    padding-bottom: 0.8rem;
}
section.toptok {
    background-image: url(./img/feamtbg.jpg);
    padding-top: 3rem;
}
.tptkl {
    float: right;
    width: 40%;
}
.tptkl img {
    width: 100%;
    border-radius: 10px;
}
.tptkr {
    width: 60%;
    float: right;
    box-sizing: border-box;
    padding-right: 5%;
}
.tptkr p {
    font-size: 1.1rem;
    line-height: 1.7;
}
.cf.tptkt {
    margin-bottom: 2rem;
}
.tptkbt {
    padding: 0 0 0 11%;
}
.tptkbt p {
    color: #f65957;
    font-size: 1.4rem;
}
.tptkb {
    border: solid 6px #fff;
    box-sizing: border-box;
    border-radius: 25px;
    background: rgba(255, 255, 255, 0.7);
    padding: 2rem 0;
    margin-bottom: 2rem;
}
.tptkbt h2:after {
        position: absolute;
    content: "";
    width: 112%;
    height: 31px;
    background: #e7fe69;
    border-radius: 15px;
    left: -6%;
    z-index: -1;
    bottom: -0.5rem;
}
.tptkbt h2 {
    font-size: 1.7rem;
    color: #0f2c71;
    margin-bottom: 3rem;
    position: relative;
    display: inline-block;
    z-index: 1;
}
.tptkbt h2 span {
    font-size: 3rem;
    display: inline-block;
    padding: 0 6px;
}


.tpcrsbox:nth-child(2) h3 {
    border-bottom: solid 4px #1aa1e6;
}
.tpcrsbox:nth-child(3) h3 {
    border-bottom: solid 4px #ef94ae;
}
.tpcrsbox img {
    margin-bottom: 1rem;
    width:100%;
    border-radius: 10px;
}
.tpcrsbox p {
    font-size: 0.9rem;
}
.tpcrsbox .awr {
    position: absolute;
    bottom: 1rem;
    left: 6%;
    width: 88%;
}
.tpcrsbox a {
    position: relative;
    background: #96be41;
    padding: 0.6rem;
    box-sizing: border-box;
    font-size: 0.9rem;
    border-radius: 5px;
    display: block;
        color: #fff;
}
.tpcrsbox:nth-child(2) a {
    background: #1aa1e6;
}
.tpcrsbox:nth-child(3) a {
    background: #ef94ae;
}
.tpcrsbox a:after {
    position: absolute;
    right: 10px;
    content: "\f0da";
    font-family: FontAwesome;
    color: #fff;
}
section.top5 ul {
    display: flex;
    text-align: center;
    width: 100%;
    justify-content: center;
}
section.top5 ul li {
    padding: 1rem 3rem;
    color: #fff;
    background: #112e6f;
    margin: 0 1rem;
    box-shadow: 0px 5px 0px #ddd;
}
.tpscbox {
    width: 18%;
    float: left;
    margin: 0 1% 1rem;
}
.tpscbox p {
    font-size: 0.9rem;
}
.tpscbox img {
    margin-bottom: 8px;
    border-radius: 10px;
}
section.top6 {
    padding-top: 2rem;
    margin-bottom: 1rem;
}
.tpscwr.cf {
    margin-bottom: 2rem;
    padding-top: 2rem;
}
section.top6 h2 {
    margin-bottom: 2rem;
}
section.top6 .rawr {
    text-align: right;
    margin-bottom: 1rem;
    box-sizing: border-box;
    padding-right: 1%;
}
.rawr a {
    color: #75cbf7;
}
section.top7 {
    padding: 2rem 0;
    background: #dfeded;
}
section.top7 .wid1060 {
    background: rgba(255, 255, 255, 0.8);
    border-radius: 12px;
    position: relative;
    padding-bottom: 3rem;
    padding-top: 2rem;
    border: solid 4px #0f2c71;
    box-sizing: border-box;
    width: 90%;
    max-width: 960px;
}
.tpblbox .postImg {
    height: 150px;
    overflow: hidden;
    position: relative;
    margin-bottom: 1.4rem;
}
.tpblbox .postImg img {
     position: absolute;
      top: 50%;
      left: 50%;
      transform: translateY(-50%) translateX(-50%);
      -webkit-transform: translateY(-50%) translateX(-50%);
}
section.top7 h3 {
    font-size: 1.4rem;
    margin-bottom: 2rem;
    background: #f3ebb1;
    padding: 0.5rem;
    border-radius: 20px;
}
.tpnswr {
    width: 96%;
    margin: auto;
    height: 200px;
    overflow: auto;
    overflow-y: scroll;
}
.tpnsrin {
    margin-bottom: 2.3rem;
}
.tpnswr h4 {
    font-size: 1.3rem;
    margin-bottom: 1.6rem;
    position: relative;
    width: 100%;
    box-sizing: border-box;
    padding-right: 100px;
    border-bottom: solid 1px;
    padding-bottom: 0.8rem;
        line-height: 1.2;
}
.tpnswr h4 span {
    position: absolute;
    right: 0;
    font-size: 0.9rem;
    color: #929292;
}
.tpnswr h4 a {
    color: #5b9fc1;
    text-decoration: underline;
}
.tpnswr p {
    width: 100%;
    margin-bottom: 1rem;
    font-size: 0.9rem;
}
.tpnswr p a {
    color: #79ccf5;
}
a.tooshi {
    font-size: 0.9rem;
    color: #7ccdf3;
    position: absolute;
    right: 3rem;
    bottom: 1.5rem;
}
section.top8 {
    padding-top: 4rem;
    margin-bottom: 3rem;
}
section.top8 h2 {
    font-size: 1.5rem;
    margin-bottom: 4rem;
}
.tpblwb {
    box-sizing: border-box;
    padding: 0 100px;
}
.tpblwr {
    margin-bottom: 3rem;
}
.tpblbox {
    border: solid 2px #0f2c71;
    box-sizing: border-box;
    border-radius: 11px;
    overflow: hidden;
    position: relative;
    margin: 0 0.7rem;
}
a.tpblm {
    position: absolute;
    bottom: 1rem;
    right: 1rem;
}
.tpblbox .tpbll {
    width: 27%;
    float: left;
    margin-right: 3%;
}
.tpblbox .tpblr {
    width: 70%;
    float: left;
}
.tpblbox h4 {
    margin-bottom: 1.1rem;
    box-sizing: border-box;
    font-size: 1rem;
    padding-bottom: 1rem;
    border-bottom: solid 2px #9da5b7;
    line-height: 1.4;
}
.top8 .slick-initialized .slick-slide {
    min-height: 450px;
}
.tpblbox h4 span {
    font-size: 0.8rem;
    position: absolute;
    right: 10px;
}
.cf.tpblin {
    padding: 0 1rem 1rem;
}
.tpblr p {
    font-size: 0.9rem;
}
p.honbun {
    margin-bottom: 1.4rem;
}
.cf.tpblin .honbun a {
    color: #55c6ff;
}
p.tpblct {
    font-size: 0.7rem;
    color: #949494;
}
.tpblr p.honbun {
    margin-bottom: 1.6rem;
}
.tpblr p.honbun a {
    color: #7ccdf3;
}
section.top8 .wid1060 {
    position: relative;
}
a.tooshi2 {
    position: absolute;
    right: 70px;
    top: 2rem;
    color: #82d2f3;
}
section.top9 {
    padding-top: 2rem;
    margin-bottom: 4rem;
}
section.top9 .bannarbox {
    width: 48%;
    margin: 0 1% 2rem;
}
section.top9 .bannarbox img{
    width: 100%;
}
 .slick-next:before {
    font-family: none;
    content: url(./img/slyaji.png) !important;
}
.slick-prev:before {
    font-family: none;
    content: url(./img/slyaji2.png) !important;
}
article#schsgl .slick-next:before {
    position: absolute;
    content: "\f138"!important;;
    font-family: FontAwesome; 
    color: #23282d;
}
article#schsgl .slick-prev:before {
    position: absolute;
    content: "\f137"!important;;
    font-family: FontAwesome; 
    color: #23282d;
}
.slick-prev, .slick-next {
    top: 48%;
    width: 26px;
    height: 60px;
}
.slick-next {
    right: -33px;
}
.slick-prev {
    left: -33px;
}
article#schsgl .slick-next {
    right: -23px;
}
article#schsgl .slick-prev {
    left: -39px;
}
h2.tph:after {
    position: absolute;
    content: "";
    width: 110%;
    left: -5%;
    bottom: -6px;
    height: 17px;
    border-radius: 11px;
    background: #dfeded;
    z-index: -1;
}
h2.tph {
    position: relative;
    display: inline-block;
    color: #0e2a72;
}
/* 会社概要 */
.abtop {
    position: relative;
    background-image: url(./img/dummyimg1.jpg);
    background-repeat: no-repeat;
    background-position: center;
    margin-bottom: 3rem;
    border-radius: 24px;
    padding: 0 7%;
    margin-top: 2rem;
    background-size: cover;
}
.abtopin {
    padding: 4.5rem 0;
    width: 56%;
}
.abtop h1 {
    color: #0f2c71;
    margin-bottom: 2rem;
    line-height: 1.8;
}
.abtop p {
    margin-bottom: 2rem;
    line-height: 1.8;
    color: #102e70;
}
table.yugo.abtab tr {
    border-bottom: solid 1px #ddd;
}
table.yugo.abtab th {
    width: 20%;
    line-height: 60px;
    vertical-align: middle;
    padding-left: 10px;
    padding-right: 1rem;
    color: #777;
    background: #F8F8F4;
}
table.yugo.abtab td {
    width: 80%;
    line-height: 30px;
    vertical-align: middle;
    padding: 1rem 0;
    padding-left: 1.5rem;
}
table.yugo.abtab {
    width: 100%;
    margin-bottom: 5rem;
}
h3.yugo.abh3 {
    margin-bottom: 2rem;
    text-align: center;
    display: inline-block;
    border-bottom: solid 4px #112e6f;
    padding: 0 1rem;
    padding-bottom: 1rem;
    font-size: 1.7rem;
    color: #102e70;
}
table.yugo.abtab iframe {
    padding-top: 1rem;
}
/* せいさくちう */
.comingsoon h1.yugo {
    text-align: center;
    padding-top: 2rem;
    margin-bottom: 3rem;
}
section.comingsoon p.soon {
    font-size: 4rem;
    font-family: "Yu Gothic";
    color: #ddd;
    margin-bottom: 2rem;
}
section.comingsoon p {
    color: #ddd;
    margin-bottom: 4rem;
}
section.comingsoon a {
    display: inline-block;
    padding: 1.3rem 2.7rem;
    background: #112e6e;
    color: #fff;
    border-radius: 6px;
    box-shadow: 4px 4px #ddd;
}
/* blog */
.dvddl.blg h3 {
    background: #0f2c71;
    color: #fff;
    font-size: 1rem;
    display: inline-block;
    padding: 10px 28px 4px;
    border-radius: 13px 13px 0 0;
    margin-left: 7px;
}
.dvddl.blg h2 a{
    width: 100%;
    background: #0f2c71;
    color: #fff;
    padding: 1.6rem;
    box-sizing: border-box;
    border-radius: 20px;
    margin-bottom: 2.1rem;
    display: block;
}
.bllin {
    border: solid 6px #0e2a72;
    border-radius: 4px;
    box-sizing: border-box;
    padding: 1.5rem 1rem 0.5rem;
    margin-bottom: 2rem;
}
.bllin ul li {
    margin-bottom: 1rem;
    border-bottom: dotted 1px #009dec;
    padding-bottom: 10px;
    font-size: 0.9rem;
    color: #797979;
    line-height: 1.2;
    position: relative;
}
.bllin.bllin2 ul li {
    border-bottom: dotted 1px #cee693;
}
.bllin.bllin3 ul li {
    border-bottom: dotted 1px #f185b7;
}
.bllin p.time {
    font-size: 0.8rem;
    margin-bottom: 5px;
}
section.blg h1 {
    font-size: 1.3rem;
    font-weight: normal;
    border-bottom: solid 4px #0f2c71;
    margin-bottom: 10px;
    padding-bottom: 6px;
    line-height: 1.4;
}
section.blg p.blginfo {
    font-size: 0.9rem;
    margin-bottom: 3rem;
    color: #b9b9b9;
}
section.blg p {
    line-height: 1.5;
}
section.blg {
    margin-bottom: 5rem;
}
section.blg img {
    margin-bottom: 2rem;
    padding-top: 1rem;
}
.blgcont {
    border-bottom: solid 4px #0e2a71;
    padding-bottom: 4rem;
    margin-bottom: 1rem;
}
.blgcont img {
    width: 100%;
    height: 100%;
}
.blg .loop p.blginfo {
    margin-bottom: 20px;
}
.blglpi img {
    border-radius: 9px;
    padding-top: 0 !important;
}
.blglpi {
    width: 35%;
    float: left;
    margin-right: 3%;
}
section.blg .loop h2 {
    font-size: 1.4rem;
    border-bottom: solid 2px #0f2c71;
    font-weight: normal;
    margin-bottom: 10px;
    padding-bottom: 6px;
    line-height: 1.2;
}
.blgcont.blglpr {
    width: 62%;
    float: left;
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 0;
}
.blgcont.blglpr p {
    line-height: 2;
}
section.blg .loop {
    margin-bottom: 3rem;
}
section.blg.acv {
    margin-bottom: 2rem;
    border-bottom: solid 4px #0b2874;
}
.postImg img {
    width: 100%;
}
.acvtit {
    margin-bottom: 2rem;
}
section.blg .acvtit h1 {
    border: none;
    color: #0f2c71;
    font-size: 1.7rem;
    position: relative;
    padding-left: 39px;
    margin-bottom: 0;
}
section.blg .acvtit h1:before {
	position: absolute;
	content: url(./img/notepen.png);
	left: 0;
	top: -5px;
}
p.blginfo span a {
    text-decoration: underline;
    color: #55c6ff;
}
a.acvtd {
    color: #55c6ff;
}
.acvtit p {
    color: #aed89a;
}


/* ニュースのとこ */
.demo_more {
    cursor: pointer;
    background-color: #dadac3;
    color: #fff;
    height: 20px;
    line-height: 20px;
    text-align: center;
    width: 100%;
    margin: 0 auto 10px;
    font-size: 0.8rem;
    margin-top: 0.6rem;
}
.hidetext {
	height:60px;
	line-height:20px;
	overflow-y:hidden;
}
/* 合格体験記 */
section.strwrap h2 {
    color: #f17272;
    margin-bottom: 1.4rem;
    border-bottom: solid 3px;
    padding-bottom: 0.6rem;
    padding-left: 7px;
    font-size: 1.1rem;
    line-height: 1.3;
}
.strwrapin {
	background-image: url(./img/rtsakura.png);
    background-repeat: no-repeat;
    background-position: top right;
        box-sizing: border-box;
    padding: 2.3rem;
    margin-top: 1rem;
}
section.strwrap {
    background: #FFFEFD;
    border-radius: 40px;
    box-shadow: 2px 2px 10px #ddd;
    margin-bottom: 2rem;
    position: relative;
    background-image: url(./img/lbsakura.png);
    background-repeat: no-repeat;
    background-position: bottom left;
}
.upbox.cf {
    position: relative;
    margin-bottom: 3rem;
    min-height: 150px;
}
.upbox.cf .upl {
    width: 40%;
    float: left;
    box-sizing: border-box;
    padding-right: 1rem;
}
.upbox.cf .upl p {
    text-align: right;
    font-size: 0.8rem;
}
.upbox.cf .upl .thumbwr {
    border-radius: 50%;
    overflow: hidden;
    border: solid 2px #ddd;
}
.upbox.cf .upl .thumbwr {
    border-radius: 50%;
    overflow: hidden;
    border: solid 2px #ddd;
    width: 104px;
    box-sizing: border-box;
    height: 104px;
    padding: 0px;
    position: relative;
    background: #fff;
    margin-bottom: 6px;
}
.upbox.cf .upl .thumbwr img {
    border-radius: 50%;
    width: 96px;
    height: 96px;
     position: absolute;
      top: 50%;
      left: 50%;
      transform: translateY(-50%) translateX(-50%);
      -webkit-transform: translateY(-50%) translateX(-50%);
}
.upr {
    padding-right: 150px;
    position: relative;
    background-image: url(./img/gokaku.png);
    background-repeat: no-repeat;
    background-position: right 20px center;
    box-sizing: border-box;
    width: 60%;
    float: left;
}
.upr p {
	margin-bottom: 10px;
}
.upr p span {
    font-size: 0.7rem;
    padding: 1px 3px;
    border: solid 1px;
    letter-spacing: 1.6px;
    margin-right: 4px;
}
.upr th p {
    font-size: 0.9rem;
    border-left: solid 4px #f3716f;
    padding-left: 5px;
    padding-right: 1rem;
    white-space: nowrap;
}
.upr td p {
    font-size: 0.9rem;
    margin-bottom: 0;
}
.midin {
    margin-bottom: 2.2rem;
}
.midin .contwrap {
    box-sizing: border-box;
    padding: 0 1.4rem;
    font-size: 0.9rem;
    line-height: 1.5;
}
.midin h3 {
    padding-left: 30px;
    font-size: 1rem;
    padding-bottom: 7px;
    border-bottom: solid 1px;
    margin-bottom: 1.4rem;
    color: #0f2c71;
    box-sizing: border-box;
    background-image: url(./img/pen2.png);
    background-repeat: no-repeat;
    background-position: left 5px top;
}
.ribbon1 {
      display: inline-block;
    position: relative;
    height: 39px;
    line-height: 39px;
    vertical-align: middle;
    text-align: center;
    padding: 0 30px;
    font-size: 14px;
    background: #ea5552;
    color: #FFF;
    box-sizing: border-box;
}

.ribbon1:before, .ribbon1:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.ribbon1:before {
  top: 0;
  left: -1px;
  border-width: 20px 0px 20px 10px;
  border-color: transparent transparent transparent #fff;
  border-style: solid;
}

.ribbon1:after {
  top: 0;
  right: -1px;
  border-width: 20px 10px 20px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
}
.center.mestin {
    display: inline-block;
    transform: rotate(-6deg);
}
.mestitle p {
    color: #eb534d;
}
.mestitle {
    margin-bottom: 1.6rem;
}
.mesbox {
    border: solid 2px #79b0cc;
    border-radius: 24px;
    padding: 10px 0.5rem 1.7rem;
    margin-bottom: 3rem;
}
.mecon {
    margin-left: 2rem;
    margin-right: 2rem;
    font-size: 0.95rem;
    line-height: 1.95;
    background-image: url(./img/noteline.png);
}
.titlearea {
    margin-bottom: 3rem;
}
article#acvsgl.str .titlearea {
	background-image: url(./img/strtop.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	padding: 2rem 1rem;
	    background-position: center center;
}
article#acvsgl.str .titlebox {
    width: 45%;
    margin-left: 55%;
    background: rgba(255, 255, 255, 0.7);
    box-sizing: border-box;
    padding: 3rem;
    box-shadow: 1px 1px 3px #d2cdcd;
}
article#acvsgl.str .titlebox h5 {
    font-size: 1.7rem;
    margin-bottom: 1.2rem;
    letter-spacing: 2.8px;
    color: #f96868;
}
article#acvsgl.str .titlebox h1 {
    color: #0f2c71;
    text-shadow: 1px 2px #FFF;
    margin-bottom: 1rem;
    font-size: 2.2rem;
}
article#acvsgl.str .titlebox p {
	font-size: 0.9rem;
}
article#acvsgl.str .acvarbox.cf {
    border-radius: 10px;
    background: #F5F5F5;
    padding: 0;
}
article#acvsgl.str .thumbwr {
/*
    border-radius: 50%;
    overflow: hidden;
    border: solid 2px #ddd;
    width: 96px;
    box-sizing: border-box;
    height: 96px;
    padding: 0px;
    position: relative;
    background: #fff;
    margin-bottom: 11px;
*/
    border-radius: 0;
    border: none;
    margin-bottom: 6px;
    width: 100%;
    height: 190px;
    border-radius: 8px;
}
article#acvsgl.str .thumbwr img {
/*
    border-radius: 50%;
    width: 90px;
    height: 90px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
*/
	width: 100%;
    height: unset;
    border-radius: 0;
}
article#acvsgl.str .acvarbox.str.cf .thumbwr {
    border-radius: 50%;
    overflow: hidden;
    border: solid 2px #ddd;
    width: 96px;
    box-sizing: border-box;
    height: 96px;
    padding: 0px;
    position: relative;
    background: #fff;
    margin-bottom: 11px;
}
article#acvsgl.str .acvarbox.str.cf .thumbwr img {
    border-radius: 50%;
    width: 90px;
    height: 90px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
}
article#acvsgl.str .acvarl {
    float: left;
    width: 26%;
    margin-right: 4%;
    background: #fff;
    padding: 1rem;
}
.strinfo p {
    font-size: 0.75rem;
    border: solid 1px;
    display: inline-block;
    padding: 1px 5px;
    margin-bottom: 10px;
}
.strinfo {
    padding-top: 2rem;
}
article#acvsgl.str .acvarr {
    padding: 1rem 1rem 1rem 0;
}
.acvarr p.strhb a {
    color: #55c6ff;
}
p.strgrade {
    display: inline-block;
    background: #ddd;
    padding: 2px 13px;
    color: #fff;
    font-size: 0.9rem;
    border-radius: 18px;
    margin-bottom: 0.6rem;
    float: right;
}
article#acvsgl .acvarbox.cf p.strgrade a {
    color: #fff;
}
article#acvsgl .acvarbox.cf .strinfo p a {
/*     color: #000; */
}
p.strgrade.college {
    background: #f292ae;
}
p.strgrade.high {
    background: #009ee2;
}
p.strgrade.junior {
    background: #95c125;
}
.accrtit {
    border-bottom: solid 1px #f17272;
    margin-bottom: 5px;
}
.accrtit h4 {
    color: #f17272;
    border-left: solid 4px;
    margin-bottom: 4px;
    font-size: 0.9rem;
    padding-left: 5px;
}
p.gokakuko {
    color: #f3716f;
    font-size: 0.9rem;
    margin-bottom: 1rem;
}
article#acvsgl.str .acvarr h2 {
    font-size: 1rem;
    margin-bottom: 1rem;
    font-size: 0.9rem;
    line-height: 1.3;
    color: #1f4090;
}
/* よくある質問 */
.faqnav {
    margin-bottom: 3rem;
}
.faqnav ul {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}
.faqnav ul li a {
    font-size: 0.9rem;
    color: #abaaa5;
}
.faqnav ul li.current a {
    color: #000;
    background: #f3eab4;
    padding: 4px 16px;
    border-radius: 23px;
}
.faqwrap {
    margin-bottom: 5rem;
}
h1.yugo.faqtit {
    border-bottom: solid 4px #102e6f;
    padding-bottom: 10px;
}
.faqbox {
    border-bottom: dashed 1px;
    margin-bottom: 2rem;
}
.faqbox h4 {
    font-size: 1.1rem;
    padding-left: 50px;
    position: relative;
    margin-bottom: 1.4rem;
    line-height: 1.4;
}
.faqbox h4:before {
	position: absolute;
	content: url(./img/q.png);
	left: 16px;
    top: -7px;
}
.faqanswer {
    padding: 0 2.4rem;
    margin-bottom: 1.5rem;
}
.faqanswer p {
    line-height: 1.6;
}
/* 授業料 */
.feebox.cf {
    margin-bottom: 3rem;
}
.feebox.cf h2 {
    font-size: 1rem;
    margin-bottom: 2rem;
    position: relative;
    display: inline-block;
}
.feebox.cf h2:after {
    position: absolute;
    content: "";
    width: 104%;
    height: 15px;
    background: #DFEDED;
    bottom: -5px;
    left: -1%;
    border-radius: 10px;
    z-index: -1;
}
.feebox.cf p {
    line-height: 1.8;
    font-size: 0.9rem;
    margin-bottom: 0.8rem;
}
.feebox.cf img {
    width: 100%;
    border-radius: 10px;
}
.feebox.cf .fel {
    width: 65%;
    float: right;
    box-sizing: border-box;
    padding-right: 5%;
}
.feebox.cf .fer {
    width: 35%;
    float: right;
}
.feebox.cf .fel2 {
    width: 35%;
    float: left;
}
.feebox.cf .fer2 {
    width: 65%;
    float: left;
    box-sizing: border-box;
    padding-left: 5%;
}
.yksfee {
    width: 60%;
    margin: auto;
    box-sizing: border-box;
    border: solid 2px #00a0e9;
    border-radius: 10px;
    padding: 10px 1.8rem;
    text-align: center;
    min-width: 270px;
    margin-bottom: 1rem;
}
.yksfee h5 {
    font-size: 0.9rem;
    letter-spacing: 1.2px;
    margin-bottom: 0.5rem;
}
.yksfee th p {
    margin-bottom: 0;
    line-height: 1.3;
}
.yksfee th {
    width: 45%;
}
.yksfee td {
    vertical-align: middle;
        width: 43%;
}
.s3l .yksfee {
	margin-top: 2rem;
	min-width: unset;
	width: 100%;
	padding: 10px 1.2rem;
}
/* 講習会 */
.lectmain {
    width: 100%;
    background-image: url(./img/dummyimg1.jpg);
    border-radius: 20px;
    background-size: cover;
    background-position: center center;
    margin-bottom: 4rem;
    box-sizing: border-box;
    padding: 2rem 3rem;
}
.flmin {
    width: 50%;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 10px;
    box-sizing: border-box;
    padding: 2rem 3rem;
    float: right;
}
.flmin p {
    color: #f65957;
    margin-bottom: 0.4rem;
}
.flmin h1 {
    font-size: 2.5rem;
    color: #0f2c71;
    margin-bottom: 1.3rem;
}
.flmin h3 {
    line-height: 1.5;
    margin-bottom: 1.3rem;
}
.flmin img {
    width: 100%;
}
.lectimg {
    margin-bottom: 2rem;
}
.lectimg img {
    width: 100%;
}
.lectwr h3 {
    border: solid 2px #ddd;
    padding: 10px;
    margin-bottom: 1.6rem;
    border-radius: 30px;
}
.lectwr h3.pink {
    border: solid 2px #ffcec8;    
}
.lectwr h3.green {
    border: solid 2px #dbed80;    
}
.lectwr h3.blue {
    border: solid 2px #b4d3ff;    
}
.lectin p {
    width: 94%;
    margin: auto;
    margin-bottom: 2.5rem;
    line-height: 2;
}
.lectin table {
    width: 96%;
    margin: auto;
    margin-bottom: 5rem;
}
.lectin table th {
    width: 2rem;
    vertical-align: middle;
    box-sizing: border-box;
    padding: 0 0.5rem;
    font-size: 1.1rem;
    color: #fff;
    background: #ddd;
    line-height: 1.4;
}
.lectin table td {
    padding: 0.6rem 0.8rem 0.4rem;
    font-size: 0.9rem;
    vertical-align: middle;
    line-height: 1.4;
}
.lectin table tr td:last-child {
    text-align: right;
}
.lectin table td span {
    font-size: 1.2rem;
    letter-spacing: 2px;
    font-weight: bold;
}
.lectin table tr.green {
    background: #EFF8C1;
    border-top: solid 1px #BBD446;
}
.lectin table tr.green th {
    background: #BBD446;
}
.lectin table tr.green td {
    border-left: solid 1px #BBD446; 
}
.lectin table tr.blue {
    background: #D6F4FF;
    border-top: solid 1px #00A0DF;
}
.lectin table tr.blue th {
    background: #00A0DF;
}
.lectin table tr.blue td {
    border-left: solid 1px #00A0DF;
}
.lectin table tr.pink {
    background: #FFF5F8;
    border-top: solid 1px #EF94AE;
}
.lectin table tr.pink th {
    background: #EF94AE;
}
.lectin table tr.pink td {
    border-left: solid 1px #EF94AE;
}
.lectin table tr.nob.blue,
.lectin table tr.nob.green,
.lectin table tr.nob.pink {
    border-top: none;
}
/* 流れ */
.stepbox {
    margin-bottom: 2rem;
    padding-bottom: 4rem;
    background-image: url(./img/flbelow.png);
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: center bottom;
}
.stepbox h2 {
    position: relative;
    font-size: 1.1rem;
    line-height: 1.4;
    padding-left: 42px;
    margin-bottom: 1.5rem;
}
.stepbox h2 img {
    position: absolute;
    left: 0;
    top: -10px;
}
.stepbox .cf .stel img {
    width: 100%;
    border-radius: 12px;
}
.stepbox .cf .ster {
    float: left;
    width: 60%;
}
.stepbox .cf .stel {
    float: left;
    width: 40%;
    box-sizing: border-box;
    padding-right: 3%;
}
.stepbox .cf .ster p {
    font-size: 1rem;
    line-height: 1.7;
}
.stepbox th {
    background-image: url(./img/flbg.png);
    background-repeat: no-repeat;
    background-position: right center;
    background-size: cover;
    width: 37%;
        border-bottom: solid 1.4rem #FFF;
    vertical-align: middle;
}
.stepbox th p {
    box-sizing: border-box;
    padding-left: 50px;
    background-image: url(./img/flsl.png);
    background-repeat: no-repeat;
    background-position: left 9px center;
    padding: 1rem 0 1rem 40px;
    font-size: 0.9rem;
}
.stepbox td {
    width: 63%;
    padding-left: 3%;
        border-bottom: solid 1.4rem #FFF;
}
.stepbox td p {
    font-size: 0.8rem;
}
.stepbox td h4 {
    font-size: 1.1rem;
    margin-bottom: 10px;
    color: #3057b9;
}
/* forms */
.formtitle.cf {
    margin-bottom: 1rem;
    border-bottom: solid 1px #4466b1;
    padding-bottom: 2rem;
}
.formtitle.cf .fmtl {
    float: left;
    width: 25%;
}
.formtitle.cf .fmtl img {
    width: 100%;
    border-radius: 10px;
}
.formtitle.cf .fmtr {
    width: 75%;
    float: left;
    box-sizing: border-box;
    padding-left: 3%;
}
.formtitle.cf .fmtr p {
	line-height: 1.6;
}
/* 特徴 */
section.featop {
	width: 100%;
    background-image: url(./img/dummyimg1.jpg);
    background-size: cover;
    background-position: center center;
    margin-bottom: 3rem;
}
.featopin {
    padding-top: 17%;
    text-align: right;
    padding-bottom: 2.5rem;
}
.featopin.wid1160 img {
    width: 190px;
    margin-bottom: 1rem;
}
.featopin.wid1160 h1 {
    color: #0e2a72;
    font-size: 1.9rem;
    letter-spacing: 1px;
}
.metit.center.wid1160 {
    margin-bottom: 2rem;
}
.metit.center.wid1160 p.os {
    color: #0e2a72;
    font-size: 1.2rem;
    letter-spacing: 1.6px;
    margin-bottom: 0.5rem;
}
.metit.center.wid1160 h2 {
    font-size: 2.5rem;
    margin-bottom: 1.5rem;
    color: #F45B5B;
}
.cf.metimgin {
    width: 84%;
    margin: auto;
    display: flex;
}
.wid1160.metimg {
	background-image: url(./img/feamtbg.jpg);
	background-position: center center;
	box-sizing: border-box;
	padding: 1.5rem;
	border-radius: 9px;
    margin-bottom: 2rem;
}
.metimgl {
    width: 55%;
    float: left;
}
.metimgl img {
    width: 100%;
}
.metimmgr {
    width: 45%;
    float: left;
    display: flex;
    align-items: center;
}
.metimmgr img:first-child {
    width: 45%;
}
.metimmgr img:last-child {
    width: 55%;
}
.wid1160.tokucho3 {
    margin-bottom: 3rem;
}
.wid1160.tokucho3 h2 {
    font-size: 1.7rem;
    color: #0f2c71;
    margin-bottom: 3rem;
    position: relative;
    display: inline-block;
}
.wid1160.tokucho3 h2 span {
    font-size: 3rem;
    display: inline-block;
    padding: 0 6px;
}
.wid1160.tokucho3 h2:after {
    position: absolute;
    content: "";
    width: 112%;
    height: 31px;
    background: #e7fe69;
    border-radius: 15px;
    left: -6%;
    z-index: -1;
    bottom: -0.5rem;
}
.wid1160.tokucho3.center ul {
    display: flex;
    justify-content: space-evenly;
}
.wid1160.tokucho3.center ul li {
    width: 30%;
}
.wid1160.tokucho3.center ul li img {
    width: 100%;
}
section.featitsec {
    background: #0f2c71;
    margin-bottom: 3rem;
}
section.featitsec div {
    background-image: url(./img/titleimg2.png);
    background-position: center right;
    background-repeat: no-repeat;
    background-size: 79%;
}
section.featitsec img {
    width: 18%;
    padding: 1.7rem 0;
}
section.featitsec.fti2 {
    background: #DFEDED;
}
section.featitsec.fti2 div {
    background-image: url(./img/titleimg2.png);
}
section.featitsec.fti3 {
    background: #F45B5B;
}
section.featitsec.fti3 div {
    background-image: url(./img/titleimg2.png);

}
section.mtwr div.mtbox {
    margin-bottom: 3rem;
}
.cf.mtbox {
    display: flex;
    justify-content: space-around;
}
.cf.mtbox .fea45 {
    width: 45%;
}
.cf.mtbox .fea45 img {
    width: 100%;
    border-radius: 12px;
    margin-bottom: 2rem;
}
.mhul {
    margin-bottom: 1rem;
}
.mhul ul {
    box-sizing: border-box;
    padding-left: 80px;
    background-image: url(./img/point.png);
    background-repeat: no-repeat;
    background-position: left 5px center;
}
.mhul ul li {
    box-sizing: border-box;
    padding-left: 20px;
    background-image: url(./img/tenten.png);
    background-repeat: no-repeat;
    background-position: left center;
    position: relative;
    color: #0e2a72;
    line-height: 2.1;
    display: inline-block;
    font-size: 0.9rem;
}
.mhul ul li:after {
    position: absolute;
    content: "";
    width: 100%;
    left: 18px;
    bottom: 3px;
    background-color: #e7ff5c;
    height: 13px;
    z-index: -1;
}
.mttit {
    margin-bottom: 1.5rem;
}
.mttit p {
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
    letter-spacing: 0.7px;
    color: #f0404b;
}
.mttit h3 {
    font-size: 1.4rem;
    color: #0f2c71;
    line-height: 1.4;
    margin-bottom: 0.2rem;
}
.mttit:after {
    width: 90%;
    max-width: 450px;
    height: 3px;
    content: "";
    background: #0f2c71;
    display: block;
}
p.feap {
    line-height: 1.8;
    margin-bottom: 1.6rem;
}
.feaig.center {
    width: 90%;
    margin: auto;
    margin-bottom: 3rem;
    border: solid 4px #DFEDED;
    border-radius: 25px;
    box-sizing: border-box;
    padding: 2rem;
}
.feaig.center h3 {
    color: #0f2c71;
    margin-bottom: 2rem;
    position: relative;
    font-size: 1.3rem;
    display: inline-block;
}
.feaig.center h3:after {
    position: absolute;
    content: "";
    width: 110%;
    height: 15px;
    background: #e7fe69;
    left: -5%;
    z-index: -1;
    bottom: -0.3rem;
}
.feaig.center ul {
    display: flex;
    justify-content: space-around;
}
.feaig.center li {
    width: 21%;
}
.feaig.center li img {
    width: 100%;
}
.fea70 {
    width: 65%;
    float: left;
    box-sizing: border-box;
    padding-right: 5%;
}
.fea70 img{
    width: 100%;
}
.fea70 h4 {
    font-size: 1rem;
    color: #0f2c71;
    margin-bottom: 0.5rem;
}
.fea30 {
    width: 35%;
    float: left;
}
.fea30 img {
    width: 100%;
    border-radius: 12px;
}
.otlayout.cf {
    display: flex;
    flex-wrap: wrap;
    width: 90%;
    margin: auto;
    margin-bottom: 3rem;
}
.otlayout.cf .wid30 {
    width: 35%;
    margin: 0 1%;
    margin-bottom: 1rem;
}
.otlayout.cf .wid30 img {
    width: 100%;
    border-radius: 13px;
}
.otlayout.cf .wid70 {
    width: 61%;
    margin: 0 1%;
    background: #dfeded;
    box-sizing: border-box;
    padding: 0.7rem;
    border-radius: 12px;
    margin-bottom: 1rem;
}
.otlayout.cf .wid70 .in {
    border: solid 2px #fff;
    border-radius: 12px;
    box-sizing: border-box;
    padding: 1rem 1.5rem 0;
    height: 100%;
}
.otlayout.cf .wid70 h4 {
    border-left: solid 5px #0f2c71;
    color: #0f2c71;
    padding-left: 5px;
    margin-bottom: 1.2rem;
    line-height: 1.4;
}
.otlayout.cf .wid70 p {
    font-size: 0.9rem;
}
.toolwr {
    background-image: url(./img/feamtbg.jpg);
    background-position: center center;
    box-sizing: border-box;
    padding: 1.5rem 0.5rem;
    margin-bottom: 3rem;
padding-bottom: 2.5rem;
}
.toolwr p.os {
    color: #0f2c71;
    letter-spacing: 1.6px;
    margin-bottom: 1.3rem;
    font-size: 1.1rem;
}
.toolwr h3 {
    color: #0f2c71;
    font-size: 1.3rem;
    position: relative;
    margin-bottom: 2rem;
    line-height: 1.4;
    display: inline-block;
    z-index: 2;
}
.toolwr h3:after {
    position: absolute;
    content: "";
    width: 104%;
    height: 15px;
    background: #e7fe69;
    left: -2%;
    bottom: -0.1rem;
    z-index: -1;
}
.tools.cf {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}
.tool {
    width: 31%;
    margin: 0px 1%;
    box-sizing: border-box;
    padding: 1.4rem 1rem;
    border: solid 3px #0f2c71;
    border-radius: 9px;
    background: #fff;
}
.tool .center p {
    margin-bottom: 4px;
    color: #0f2c71;
    line-height: 1.4;
    font-size: 1rem;
}
.tool .center h4 {
    background: #0f2c71;
    color: #fff;
    font-size: 1.3rem;
    padding: 0.9rem 0 0.5rem;
    border-radius: 20px;
    margin-bottom: 1.9rem;
}
.tool p {
    line-height: 1.6;
    font-size: 0.9rem;
}
.feainl {
    width: 25%;
    float: left;
    box-sizing: border-box;
    padding-right: 2%;
}
.feainl img {
    width: 100%;
}
.feainr {
    width: 75%;
    float: left;
}
.feainr h4 {
    text-align: left;
    margin-bottom: 1rem;
    color: #0f2c71;
    padding-top: 0.6rem;
}
.feainr p {
    line-height: 1.7;
    text-align: left;
}
.mtbox.ver2 .fea70 {
    padding-right: 0;
    padding-left: 5%;
}
.mtbox.ver2 {
	flex-direction: row-reverse;
}
ul.kyozai {
    padding-top: 2rem;
    padding-left: 140px;
    box-sizing: border-box;
    background-image: url(./img/hon.png);
    background-repeat: no-repeat;
    background-position: left bottom;
}
ul.kyozai li {
    background: #dfeded;
    display: inline-block;
    margin-bottom: 0.7rem;
    padding: 0.2rem 1rem;
    font-size: 0.8rem;
    color: #0e2a72;
    border-radius: 16px;
}
section.feamat {
    background-image: url(./img/aobg.png);
    box-sizing: border-box;
    padding-top: 3rem;
    padding-bottom: 1rem;
}
section.feamat .matin {
    background: #fff;
    border-radius: 25px;
    box-sizing: border-box;
    padding: 0.5rem;
    box-shadow: 2px 2px 3px #ababab;
}
section.feamat .matin .matin2 {
    border: solid 3px #eafdbb;
    border-radius: 25px;
    padding: 3rem 2rem 1rem;
}
section.feamat h2.dam.italic {
    color: #ff6e75;
    display: inline-block;
    margin-bottom: 2.5rem;
    padding-bottom: 1.7rem;
    border-bottom: solid 2px #0e2a72;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box;
    letter-spacing: 1.4px;
    font-size: 1.7rem;
}
section.feamat h3 {
    font-size: 1.2rem;
    line-height: 1.9;
    color: #0e2a72;
    margin-bottom: 3rem;
}
.matin2 p {
    width: 60%;
    margin: auto;
    margin-bottom: 1.6rem;
    font-size: 0.9rem;
}
section.feamat .wid1160.narrow {
    padding-top: 4rem;
}
/* フォーム */
article#pardot iframe {
    margin-bottom: 3rem;
}
p.prwrn {
    font-size: 0.9rem;
    box-sizing: border-box;
    text-align: center;
    margin-bottom: 1rem;
}
.privacy .prin {
    height: 150px;
    overflow: auto;
}
.privacy .prin h5 {
    margin-bottom: 1.3rem;
}
.privacy .prin p {
    margin-bottom: 1rem;
    font-size: 0.9rem;
}
.privacy {
    border-radius: 20px;
    border: solid 1px;
    box-sizing: border-box;
    padding: 2rem 3rem;
}
section.mtwr {
    margin-bottom: 6rem;
}
section.mtwr.env .wid1160 {
    border: solid 4px #0f2c70;
    border-radius: 20px;
    padding-top: 250px;
    padding-bottom: 2rem;
    position: relative;
}
.envtitle.center {
    position: absolute;
    width: 100%;
    top: 80px;
    background: #0f2c70;
    left: 0;
    padding: 20px 0;
}
.envtitle.center h4 {
    color: #fff;
    margin-bottom: 1rem;
    line-height: 1.4;
}
.envtitle.center h4 .dam {
    font-size: 1.3rem;
    letter-spacing: 1.2px;
    color: #ef4550;
}
.envtitle.center h2 {
    color: #fff;
    letter-spacing: 1.7px;
}


/* 夏期講習 */
.summer .fullmain {
    background-color: #D3E767;
    background-image: url(./img/ssbg.jpg);
    background-position: center left;
    background-repeat: no-repeat;
    background-size: 33%;
    position: relative;
}
.summer .fullmain:after {
	position: absolute;
	content: "";
	background-image: url(./img/sslect.png);
	background-size: 100% 100%;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}
.fullmain .titlebox.center {
    margin-left: 20%;
}
.fullmain .titlebox.center img {
    width: 50%;
    min-width: 250px;
}
section.sstop {
    padding-top: 1rem;
    margin-bottom: 4rem;
}
.sstopl {
    width: 65%;
    float: left;
    padding-right: 3%;
    box-sizing: border-box;
}
.sstopl {
	color: #102E70;
}
.sstopr {
    width: 35%;
    float: left;
    margin-bottom: 2rem;
}
.sstopr img {
    width: 100%;
    border-radius: 10px;
}

.sstopl h3 {
    line-height: 1.8;
    margin-bottom: 2rem;
}
.sstopl p {
    position: relative;
    margin-bottom: 1.5rem;
    font-size: 1.1rem;
    box-sizing: border-box;
    padding-left: 50px;
}
.sstopl p:before {
	position: absolute;
	top: 0;
	left: 10px;
	content: url(./img/stchk.png);
}
.sstopb.center {
    color: #102E70;
    box-sizing: border-box;
    border: solid 4px #DFEDED;
    border-radius: 30px;
    padding: 1.5rem 5%;
    margin-bottom: 4rem;
}
.sstopb.center h3 {
    display: inline-block;
    position: relative;
    height: 44px;
    line-height: 44px;
    text-align: center;
    padding: 0 30px;
    font-size: 1.6rem;
    background: #dfeded;
    box-sizing: border-box;
    width: 94%;
    margin-bottom: 1.7rem;
}
.sstopb.center h3:before, .sstopb.center h3:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}

.sstopb.center h3:before {
  top: 0;
  left: 0;
  border-width: 22px 0px 22px 15px;
  border-color: transparent transparent transparent #fff;
  border-style: solid;
}

.sstopb.center h3:after {
  top: 0;
  right: 0;
  border-width: 22px 15px 22px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
}
.sstopb.center h4 {
    display: inline-block;
    margin-bottom: 1.7rem;
    position: relative;
    font-size: 1.2rem;
}
.sstopb.center h4:after {
    position: absolute;
    content: "";
    width: 110%;
    height: 15px;
    background: #FEED00;
    left: -5%;
    z-index: -1;
    bottom: -0.3rem;
}
.sstopb.center h4 span {
    font-size: 1.9rem;
    padding: 0 5px;
}
.sstopb.center h2 {
    font-size: 2.5rem;
    position: relative;
    margin-bottom: 3rem;
}
.sstopb.center h2:after {
    position: absolute;
    content: url(./img/ssch.png);
    left: 50px;
    top: -40px;
}
.sstopb.center img {
    width: 100%;
}
.mazu.center p {
    line-height: 1.7;
    display: inline-block;
    padding: 0 56px;
    position: relative;
    color: #102e70;
}
.mazu.center {
    margin-bottom: 3rem;
}
.mazu.center p:before {
    position: absolute;
    content: url(./img/mazu1.png;);
    bottom: -10px;
    left: 0;
}
.mazu.center p:after {
	position: absolute;
	content: url(./img/mazu2.png;);
	bottom: -10px;
    right: 0;
}
.sstopbtn {
    display: flex;
    justify-content: space-evenly;
}
.sstopbtn a {
    display: inline-block;
    font-size: 1.2rem;
    color: #112e70;
    border: solid 2px;
    box-sizing: border-box;
    width: 47%;
    text-align: center;
    padding: 1.1rem 0;
    position: relative;
    border-radius: 40px;
}
.sstopbtn a:after {
    position: absolute;
    content: "\f054";
    font-family: FontAwesome;
    right: 10px;
    font-size: 1.3rem;
}
.sstopbtn a.blue {
    background: #dfeded;
}
.sslechl {
    border-bottom: solid 4px #dfeded;
    margin-bottom: 2.5rem;
}
.sslechl h3 {
    font-size: 1.3rem;
    color: #0f2c71;
    margin-bottom: 10px;
    padding-left: 10px;
    border-left: solid 8px #BBD446;
    box-sizing: border-box;
    line-height: 1.4;
}
.nanasan.cf {
    margin-bottom: 1.4rem;
}
.nanasanl.center {
    width: 31%;
    float: left;
    box-sizing: border-box;
    border: solid 2px #0f2c71;
    color: #0f2c71;
    padding: 96px 6px 1rem;
    border-radius: 7px;
    margin-bottom: 2rem;
    background-image: url(./img/sspoint1.png);
    background-position: center top 15px;
    background-repeat: no-repeat;
}
.nanasanl.center.nsl2 {
    background-image: url(./img/sspoint2.png);	
}
.nanasanl.center h3 {
    line-height: 1.5;
}
.nanasanr {
    width: 69%;
    float: left;
    box-sizing: border-box;
    padding-left: 6%;
}
.nanasanr h4 {
    color: #102e70;
    font-size: 1rem;
    padding-left: 40px;
    padding-bottom: 10px;
    border-bottom: dashed 1px #000;
    margin-bottom: 1.3rem;
    position: relative;
    line-height: 1.4;
}
.nanasanr p {
    padding-left: 40px;
    line-height: 1.7;
    margin-bottom: 2rem;
    font-size: 0.95rem;
    position: relative;
}
.nanasanr h4:before {
	 position: absolute;
	 content: url(./img/ssq.png);
	 left: 0;
	 top: -10px;
}
.nanasanr p:before {
	 position: absolute;
	 content: url(./img/ssa.png);
	 left: 0;
	 top: -6px;
}
section.ssqa {
    margin-bottom: 2rem;
}
.pitain {
	width: 50%;
	float: left;
}
.pitain p {
	position: relative;
    margin-bottom: 1.5rem;
    font-size: 1.1rem;
    box-sizing: border-box;
    padding-left: 50px;
    color: #0f2c71;
}
.pitain p:before {
    position: absolute;
    top: 0;
    left: 10px;
    content: url(./img/stchk.png);
}
.pitab {
    background: #F8F8F4;
    border-radius: 8px;
    box-sizing: border-box;
    padding: 17px;
    display: flex;
    align-items: center;
}
.pitabl {
    width: 44%;
}
.pitabl img {
    width: 100%;
    border-radius: 8px;
}
.pitabr {
    width: 56%;
    padding-left: 3%;
    box-sizing: border-box;
}
.pitabr p {
    line-height: 2;
}
section.pittari {
    margin-bottom: 4rem;
}
.saraniin {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}
.saranibox {
    color: #fff;
    width: 48%;
    background: #0f2c71;
    min-height: 140px;
    display: flex;
    align-items: center;
    border-radius: 20px;
    margin-bottom: 1rem;
    box-sizing: border-box;
    padding-left: 100px;
    position: relative;
}
.saranibox p {
    font-size: 1.1rem;
    line-height: 1.6;
}
.saranibox:before {
	position: absolute;
	left: 37px;
}
.saranibox.one:before {
	content: url(./img/sarani1.png);
}
.saranibox.two:before {
	content: url(./img/sarani2.png);
}
.saranibox.three:before {
	content: url(./img/sarani3.png);
}
.saranibox.four:before {
	content: url(./img/sarani4.png);
}
section.sarani {
    margin-bottom: 4rem;
}
.ssflowbox {
    background: #dfeded;
    border-radius: 9px;
    margin-bottom: 3.4rem;
    display: flex;
    align-items: center;
}
.ssfll {
    width: 12%;
    min-width: 80px;
    text-align: center;
}
.ssflr {
    width: 90%;
    border-left: solid 4px #fff;
    padding: 30px 0;
    position: relative;
}
.ssflr:after {
	position: absolute;
	content: url(./img/ssyaji.png);
	bottom: -2.6rem;
	width: 100%;
	text-align: center;
}
.ssflowbox:last-child .ssflr:after {
	content: none
}
.ssflr h3 {
    color: #0f2c71;
}
.ssflrin {
    width: 75%;
    margin: auto;
    box-sizing: border-box;
    background: #fff;
    margin-top: 1.4rem;
    border-radius: 10px;
    padding: 20px 11px;
}
.ssflrin h4 {
    color: #9e9e9e;
    font-size: 1.1rem;
    border-bottom: solid 2px #bbd446;
    padding-bottom: 11px;
    margin-bottom: 0.9rem;
}
.ssflrin ul {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}

.ssflrin ul li {
    min-width: 33%;
    text-align: center;
    line-height: 2;
}
section.ssflow {
    margin-bottom: 6rem;
}
section.uptwo.sslst img {
    width: 100%;
    margin-bottom: 1rem;
}
.sslst {
    margin-bottom: 4rem;
}

 




/* IE11 */
@media all and (-ms-high-contrast:none) {
  *::-ms-backdrop a, 
	.selector a {
		color: inherit;
	}
    *::-ms-backdrop .acvarr,
	.selector .acvarr {
    width: 56%;
	}
    *::-ms-backdrop .high3db,
    .selector .high3db {
    justify-content: space-around;
	}
    *::-ms-backdrop article#acvsgl.str .thumbwr img,
	.selector article#acvsgl.str .thumbwr img {
    height: auto;
	}
    *::-ms-backdrop iframe#sdnw,
	.selector iframe#sdnw {
		height: 300px;
	}
}

/* IE10 */
@media all and (-ms-high-contrast:none) {
	a {
		color: inherit;
	}
	.acvarr {
    width: 56%;
	}
	.high3db {
    justify-content: space-around;
	}
	article#acvsgl.str .thumbwr img {
    height: auto;
	}
	iframe#sdnw {
		height: 300px;
	}
}

/* =Media queries
-------------------------------------------------------------- */

/* Does the same thing as <meta name="viewport" content="width=device-width">,
 * but in the future W3C standard way. -ms- prefix is required for IE10+ to
 * render responsive styling in Windows 8 "snapped" views; IE10+ does not honor
 * the meta tag. See https://core.trac.wordpress.org/ticket/25888.
 */
@-ms-viewport {
	width: device-width;
}
@viewport {
	width: device-width;
}

@media only screen and (min-device-width: 601px) and (max-device-width: 1024px) {
.flex-direction-nav .flex-next {
    right: 0 !important;
}
}

@media screen and (max-width: 768px) {
    .topTri::before{
        top: -0.9rem;
        bottom: auto;
        transform: translateX(-50%);
        left: 50%;
    }
.hide-pc {
	display: block;	
}	
.hide-sp {
	display: none;
}
div#main {
    padding-top: 0;
}
.wid1160 {
    padding: 0 20px;
}
.wid1060 {
    padding: 0px 25px;
}
.prdr {
    width: 76%;
    margin-left: 2%;
}
.pagetop {
    font-size: 11px;
}
.anchor {
    padding-top: 150px;
    margin-top: -150px;
}
.dvddl {
    margin-right: 2%;
}
.dvddr {
    width: 74%;
}
.ftrt ul li a {
    padding: 15px 10px;
}
/* メニュー */
body.js-hiraku-offcanvas-body.js-hiraku-offcanvas-body-right {
    overflow: unset !important;
}

div#navwrap {
    width: 100%;
    display: block;
    position: fixed;
    z-index: 1000;
    text-align: right;
    padding-top: 4px;
    padding-right: 3px;
    padding-bottom: 4px;
    box-sizing: border-box;
    top: 0;
    background: #fff;
    border-top: solid 10px #0f2e6f;
    box-shadow: 3px 2px 4px #ddd;
}
.spnavtit {
        width: 100px;
    float: left;
    padding-bottom: 5px;
    padding-top: 12px;
    padding-left: 12px;
}
.spbtnwrap {
    padding-top: 2px;
    zoom: 1.3;
}
.spbtnwrap ul {
    display: flex;
    position: absolute;
    right: 38px;
    top: 8px;
}
.spbtnwrap ul li a {
    display: block;
    font-size: 0.6rem;
    background: #0e2c70;
    color: #fff;
    padding: 6px 9px;
    border-radius: 4px;
    margin-right: 4px;
    margin-top: 3px;
}
.spbtnwrap ul li:nth-child(2) a {
	background: #F45B5B
}


.spnavtit img {
    width: 100%;
}
.hiraku-open-btn {
    z-index: 1000;
    border: none;
    border-radius: 0;
    zoom: 1.3;
}	
.hiraku-open-btn-line {
    background-color: #0e2a71;
}
.hiraku-open-btn-line:after, .hiraku-open-btn-line:before {
    background-color: #0e2a71;
}
/*
.js-hiraku-offcanvas-btn-active span.hiraku-open-btn-line:before, 
.js-hiraku-offcanvas-btn-active span.hiraku-open-btn-line:after {
    background-color: #fff !important;
    z-index: 100003;
}
*/
.js-hiraku-offcanvas-body-right {
    left: -80%;
}
.js-hiraku-offcanvas-active .js-hiraku-offcanvas-sidebar {
    width: 80%;
}
.js-hiraku-offcanvas-body-right .js-hiraku-header-fixed {
    margin-left: -80%;
}
.center.sptitle {
    background: #0e2a71;
    padding: 2rem 1rem;
}
.center.sptitle img {
    width: 250px;
}
.spinfo {
    padding: 0 1rem;
    box-sizing: border-box;
    background: #efefec;
    padding-top: 1rem;
    border-top: solid 1px #fff;
    padding-bottom: 2rem;
}
.spinfo a {
    margin-bottom: 0.6rem;
}
.spinfo .eigyo p span {
    padding: 3px 8px 1px;
    margin-right: 9px;
}
/* .menu-item-has-children:hover .sub-menu {
    display: none;
} */
.offcanvas-right ul.sub-menu {
    margin-bottom: 0;
    display: none;
}
.offcanvas-right ul li {
    border-top: solid 1px #fff;
    position: relative;
}

.offcanvas-right ul li a {
    padding: 0.8rem 1rem;
    display: inline-block;
    background: #EFEFEC;
    width: 100%;
    color: #0b2873;
    box-sizing: border-box;
}
.offcanvas-right .spinfo ul li {
    border: none;
}
.offcanvas-right .spinfo ul li a {
    padding: 0.8rem 1rem;
    display: inline-block;
    background: #00a0e9;
    width: 100%;
    color: #fff;
    box-sizing: border-box;
}
.offcanvas-right .spinfo ul li:last-child a {
    background: #f45a5b;
}
.offcanvas-right .spinfo ul{
    margin-bottom: 0;
}
.offcanvas-right .center.fttoi {
    width: 100%;
    display: block;
    font-size: 0.9rem;
    border: solid 2px #0b2873;
    color: #0b2873;
    background: #fff;
    border-radius: 1px;
    padding: 9px;
    box-sizing: border-box;
    margin-top: 0;
    margin-bottom: 0.7rem;
    border-radius: 10px;
}
.splast a {
    font-size: 0.9rem;
    display: block;
    width: 100%;
    float: left;
    text-align: center;
    color: #fff;
    padding: 10px;
    box-sizing: border-box;
    margin-bottom: 0.6rem;
    background: #0f2c71;
    border-radius: 5px;
}
.splast:after {
    display: block;
    clear: both;
    content: "";
}
.offcanvas-right ul.sub-menu li a {
    background: #DFEDED;
    padding-left: 12%;
}
.offcanvas-right ul li a.accordionbtn {
    position: absolute;
    right: 18px;
    top: 1px;
    height: 10px;
    width: 0px;
    background: none;
}
a.accordionbtn span i {
    transition: 0.5s;
}
a.accordionbtn span.open i {
    transform: rotate(180deg);
    transition: 0.5s;
}

/* トップ */
.metaslider .flex-control-nav {
    bottom: 14% !important;
}
.twobtns {
    width: 90%;
    margin-top: -43px;
    margin-bottom: 2rem;
}
.twobtns a {
    padding: 0rem 60px 0.6rem 30px;
    font-size: 1.4rem;    
}
.twobtns a:after {
    right: 20px;
    top: 24px;
    zoom: 0.7;
}

.tpbns {
    width: 90%;
    margin: auto;
}
section.top3 {
    padding-top: 1.5rem;
}
.tp3tt {
    width: 100%;
    padding-left: 0;
    background-size: 60%;
    padding-bottom: 11rem;
    padding-top: 31%;
    background-position: top center;
}
.rinen {
    width: 100%;
    padding: 4.5rem 1.5rem 0.7rem 1.5rem;
    margin-bottom: 2rem;
}
.tp3tt h2 {
    font-size: 1.5rem;
    padding-top: 2rem;
}
section.tmt {
    background-position: right -200px center;
}
.tptkl {
    width: 44%;
}
.tptkr {
    width: 56%;
    padding-right: 3%;
}
.grid {
    padding: 1rem 1rem 1.1rem;
}
.grid p {
    font-size: 14px;
}
section.top4 {
    padding-top: 3rem;
}
a.tp4a {
    font-size: 1.1rem;
}
.tpacvwr {
    width: 90%;
    margin: auto;
}
section.top5 {
    padding-top: 3rem;
    margin-bottom: 3rem;
}
.tpcrsbox h3 {
    font-size: 1.3rem;
}
section.top6 {
    padding-top: 1rem;
    margin-bottom: 3rem;
}
section.top7 h3 {
    margin-bottom: 1.5rem;
}
.tpnswr {
    width: 85%;
}
section.top7 .wid1060 {
    padding-bottom: 1rem;
}
section.top8 {
    padding-top: 3rem;
    margin-bottom: 0;
}
.tpblwb {
    padding: 0 50px;
}
/* 成績 */
.dvdr.cf.wid1160 {
    padding-top: 2rem;
}
.acvarbox.cf {
    width: 98%;
}
.acvarl .thumbwr {
    margin: auto;
    margin-bottom: 0.7rem;
}
.acvarl {
    text-align: center;
}
section.arcwrap {
    padding-top: 2rem;
}
.sidein.sidein2 a {
    padding: 10px 25px 10px 10px;
    margin: 0;
    margin-bottom: 1rem;
    font-size: 1rem;
}
.sidein {
    margin-bottom: 1.2rem;
    padding: 0 1rem;
}
.upbtl {
    width: 80%;
}
.upbtr {
    width: 20%;
}
.upbm {
    padding: 2rem 0.5rem;
}
.btn3 a {
    font-size: 0.6rem;
}
.btn3 a span {
    font-size: 1.2rem;
}
.btn3 a:after {
   display: none;
}
.ftrmr.cf .one ul li {
    width: 50%;
}
.ftrml p {
    padding-top: 53px;
}
/* コース */
.coursewr a {
    padding: 0.5rem 1.7rem 0.5rem 0.6rem;
}
.sourses {
    margin-top: 1rem;
}
/* 教室 */
.dvddr h1 {
    margin-bottom: 1.5rem;
}
.locwr.cf .chlbox {
    width: 48%;
    margin: 0 1%;
    margin-bottom: 1rem;
}
section.locbox {
    margin-bottom: 1rem;
}
.schpicl {
    width: 47%;
    margin-right: 8%;
}
.schpicr {
    width: 40%;
    float: left;
}
.dvddr .schpicl h1 {
    margin-bottom: 1rem;
}
.dvddr .schpicl h1 {
    margin-bottom: 1rem;
}
.mindinl th {
    white-space: nowrap;
}
.scbtl {
    width: 27%;
    margin-right: 3%;
}
section.blg {
    margin-bottom: 2rem;
}
.btn3wr.cf {
    display: flex;
    margin-bottom: 1rem;
}
iframe#pdt {
    height: 800px;
}
/* よくある */
.faqanswer {
    padding: 0 1.4rem;
}
.faqnav {
    margin-bottom: 2rem;
    background: #efefef;
    padding-top: 1.4rem;
    border-radius: 10px;
}
.faqnav ul {
    justify-content: flex-start;
}
.faqnav ul li {
    width: 50%;
    text-align: center;
    margin-bottom: 1.4rem;
}
/* 講習会 */
.flmin {
    width: 65%;
}
.lectmain {
    margin-bottom: 2rem;
}
.lectin table {
    width: 100%;
    margin-bottom: 4rem;
}
/* 流れ */
.stepbox th {
    width: 43%;
}
.stepbox {
    padding-bottom: 3rem;
}
/* 高校生 */
section.highbg .wid1160 {
    padding: 3rem 6% 2rem;
}
.wid1160.narrow {
    width: 100%;
    margin-bottom: 3rem;
}
.highfaqwr h4:after {
    left: -2px;
}
/* 特徴 */
.featopin.wid1160 {
    padding-top: 100px;
    padding-bottom: 40px;
}
section.featitsec img {
    width: 20%;
    padding: 0.8rem 0;
}
.mhul ul {
    padding-left: 0;
    padding-top: 45px;
    background-position: top left 0px;
}
.cf.mtbox .fea45 img {
    margin-bottom: 1rem;
}
section.mtwr div.mtbox {
    margin-bottom: 1rem;
}
.feaig.center {
    width: 100%;
    padding: 2rem 1rem;
}
.feaig.center li {
    width: 23%;
}
.otlayout.cf {
    width: 100%;
    padding-top: 2rem;
}
.tool {
    margin: 0;
    width: 100%;
    margin-bottom: 1.5rem;
}
.feainl {
    width: 44%;
}
.feainr {
    width: 56%;
}
.mhul ul li {
    line-height: 1.2;
    margin-bottom: 0.7rem;
}
.mhul ul li:after {
    display: none;
}
ul.kyozai {
    padding-left: 130px;
}
.matin2 p {
    width: 100%;
}
/* 概要 */
.abtop.wid1060 {
    width: 90%;
    padding: 0 7%;
}
.abtopin {
    width: 100%;
}
.abtop h1 {
    margin-bottom: 1rem;
}
/* 高校 */
.wid1160.highfaq img {
    padding: 0;
}

/* 夏期講習 */
.summer .fullmain {
    background-size: 35%;
}
.sstopb.center h2:after {
    left: -20px;
    top: -60px;
}
.nanasanl.center h3 {
    font-size: 1.1rem;
}
.nanasanr {
    padding-left: 2%;
}
.saranibox {
    padding-left: 70px;
}
.saranibox:before {
    left: 20px;
}
.schacv .acvarbox.cf {
    width: 48%;
}


}

/* Minimum width of 600 pixels. */
@media screen and (max-width: 600px) {
	
.wid1060 {
    padding: 0px 20px;
}	
.hide600 {
	display: none;
}
.show600 {
	display: block;
}
iframe#pdt {
    height: 400px;
}
/* メニュー */
.center.sptitle img {
    width: 130px;
}
.center.sptitle {
    padding: 1.2rem 1rem;
    text-align: right;
}
.ftl {
    display: none;
}
.ftr {
    float: left;
    width: 100%;
}
.ftrt ul {
    flex-wrap: wrap;
}
.ftrt ul li {
    margin-bottom: 3px;
}
.ftrt ul li a {
    line-height: 30px;
    padding: 7px 10px;
    font-size: 14px;
}
.ftrt {
    margin-bottom: 1rem;
}
.ftrml {
    width: 100%;
}
.ftrml p {
    padding-top: 0px;
    margin-bottom: 1rem;
}
.ftrmr.cf {
    width: 100%;
    padding: 0 1rem;
    border-left: none;
}
.ftrmr.cf .one {
    width: 100%;
    margin-bottom: 1rem;
}
.ftrmr.cf .one ul li {
    width: 33.3%;
}
.ftrmr.cf .two, .ftrmr.cf .three {
    width: 50%;
    float: left;
    margin-bottom: 2rem;
}
.ftrb.cf div {
	width: 50%;
	padding: 5px 10px;
    padding-bottom: 5px;
    margin-bottom: 1rem;
}
.ftrb.cf ul li {
    margin-top: 0.7rem;
}
p.btm1 {
    text-align: center;
    font-size: 0.6rem;
    margin-bottom: 4px;
}
.btm2r {
    width: 100%;
    float: none;
    text-align: center;
}
.ftrb.cf {
    display: none;
}
.hide-pc.ftbbb.center {
    background: #383838;
    color: #fff;
    font-size: 0.7rem;
}
.hide-pc.ftttt.center img {
    width: 130px;
    margin-bottom: 1rem;
}
/* トップ */
.crs3in.topgrid.cf.show600 {
    display: flex !important;
}
#home h2 {
	font-size: 1.3rem;
}
.metaslider .flex-control-nav {
    bottom: 4% !important;
}
.slidebox {
    top: unset;
    right: 5%;
    width: 80%;
    bottom: 5%;
}
.twobtns a {
    padding: 0rem 30px 0.6rem 10px;
    font-size: 0.9rem;
}
.twobtns a {
    padding: 0rem 30px 0.6rem 10px;
    font-size: 1.3rem;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 1rem;
    box-shadow: 1px 1px 12px #afafaf;
}
.twobtns a small {
    font-size: 14px;
}
.twobtns {
    width: 100%;
    margin-top: 0;
    flex-direction: column;
    padding: 0 20px;
    box-sizing: border-box;
    background: #fff;
    padding-top: 1.1rem;
}
section.top2 {
    position: relative;
    margin-top: 0;
    padding-top: 0;
    padding-bottom: 2rem;
}
.top2 .wid1060 {
    padding: 0;
}
.tpbns {
    width: 80%;
    margin: auto;
    padding-top: 0;
    padding-bottom: 0; 
}
.tp3tt {
    width: 100%;
    padding-left: 0;
    background-size: 110%;
    padding-bottom: 10rem;
	padding-top: 57%;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box;
}
.rinen {
    padding: 1.5rem 1.5rem 0.7rem 1.5rem;
}
.rinen {
    background-size: 54%;
    border-radius: 0;
}
.tp3tt p {
    font-size: 0.9rem;
}
.top3 .wid1160:last-child {
    padding: 0;
}
.grid {
    padding: 1rem 1rem 1.1rem;
    width: 100%
}
.grid:nth-child(2) {
    background: #f2f2f2;
}
.grid .center {
    text-align: left;
    position: relative;
}
.grid h3 {
    top: 7px;
    padding-left: 50px;
    position: absolute;
}
.topgrid.cf.hide600 {
	display: none;
}
.grid p.btnBelow {
    position: absolute;
    right: 9px;
    top: 13px;
    padding-left: 100%;
    padding-top: 10px;
    padding-bottom: 10px;
}
.grid {
    position: relative;
}
#home .grid h2 {
    margin-bottom: 0;
    font-size: 2.1rem;
}
.grid .answer {
    padding-top: 1rem;
}
section.top4 h2 {
    font-size: 1.3rem;
}
a.tp4a {
    margin-bottom: 1.5rem;
}
section.top5 {
    padding-top: 2rem;
    margin-bottom: 2rem;
}
section.top5 h2 {
    margin-bottom: 2rem;
}
.tpcrsbox {
    width: 101%;
    margin-bottom: 1.3rem;
}
.cf.tpcrswr {
    margin-bottom: 0rem;
}
section.top5 {
    margin-bottom: 0rem;
}
section.top6 h2 {
    margin-bottom: 1rem;
}
.top6 .wid1060 {
    padding: 0;
}
.tpscbox {
    width: 50%;
    box-sizing: border-box;
    margin: 0;
}
.tpscbox a {
    display: none;
}
.tpscbox p.center a {
    display: block;
    text-align: left;
    padding: 7px 10px 7px 10px;
    border: solid 1px #b3b2b2;
    border-top: none;
    border-left: none;
    font-size: 0.9rem;
    background: #f5f5f5;
    position: relative;
}
.tpscbox p.center a:after {
	position: absolute;
	content: "\f0da";
	font-family: FontAwesome;
	right: 10px;
}
.tpscwr.cf {
    border-top: solid 1px #b3b2b2;
    border-bottom: solid 1px #b3b2b2;
    background: #f5f5f5;
    padding-top: 0;
}
.tpnswr {
    width: 100%;
}
section.top7 h3 {
    font-size: 1.2rem;
}
section.top7 {
    padding: 1rem 1rem;
}
.tpnswr h4 span {
    top: 3px;
}
.tpnswr p {
    width: 100%;
    margin-bottom: 1rem;
}
section.top8 {
    padding-top: 2rem;
    margin-bottom: 1rem;
}
a.tooshi2 {
    display: none;
}
section.top8 h2 {
    margin-bottom: 2rem;
}
.tpblbox {
    width: 100%;
    margin: 0 0.5rem;
}
.tpblr p.honbun {
    margin-bottom: 0.6rem;
}
.tpnswr h4 {
    padding-right: 0;
}
.tpnswr h4 span {
    position: relative;
    display: block;
}






/* 実績 */
.dvddl {
    display: none;
}
.dvddr {
    width: 100%;
    float: left;
}
section.upbox {
    padding: 1.7rem 1rem;
}
.acvarbox.cf {
    padding: 1.5rem 1rem;
}
.acvarl {
    width: 30%;
    margin-right: 5%;
}
.acvarr {
    float: left;
    width: 65%;
}
.pagination {
    margin: 20px 0;
}
.dvddr {
    margin-bottom: 1rem;
}
section.upbox p.time {
    right: 1rem;
}
section.upbox h2 {
    line-height: 1.3;
    margin-bottom: 1.2rem;
}
.upbtl {
    width: 100%;
}
.upbtr {
    width: 100%;
}
.upbt.cf {
    margin-bottom: 2rem;
}
.btn3 {
    width: 100%;
    margin: 0;
    margin-bottom: 1rem;
}
.btn3wr.cf {
    flex-wrap: wrap;
}
.titarea {
    background-position: left center;
    margin-bottom: 0rem;
    padding: 50% 0 0;
}
.upbtr p {
    font-size: 0.8rem;
    color: #fff;
    background: #00a0e9;
    display: inline-block;
    width: 48%;
    box-sizing: border-box;
    text-align: center;
    margin-bottom: 5px;
    margin-right: 2%;
    padding: 3px;
    border-radius: 4px;
    float: left;
}
.upbtl .thumbwr {
    width: 100%;
    margin-bottom: 0.7rem;
}
.acvinfo {
    width: 100%;
    padding-left: 0;
}
/*
.titareain {
    position: absolute;
    padding: 0;
    width: 90%;
}
*/
.titareain tr th {
    width: 100%;
    text-align: left;
    display: block;
/*     padding-top: 1rem; */
}
.titareain tr td {
    padding-left: 0;
    width: 100%;
    display: block;
    padding-top: 1rem;
}
#home section.tmt h2 {
    font-size: 2rem;
}
section.tmt p {
    font-size: 1.1rem;
}
section.tmt {
    background-position: right -380px center;
}
section.toptok {
    padding-top: 1.4rem;
}
.tptkl {
    width: 100%;
    margin-bottom: 1rem;
}
.tptkr {
    width: 100%;
    padding-right: 0;
}
.tptkr p {
    font-size: 1rem;
}
.tptkbt {
    padding: 0;
    text-align: center;
}
.tptkb {
    padding: 1rem;
}
#home .tptkbt h2 {
    font-size: 1.2rem;
}
.tptkbt h2 span {
    font-size: 2.1rem;
}
section.top4 {
    padding-top: 2rem;
}
section.top4 h2 {
    margin-bottom: 2rem;
}
/* コース */
.dvddr .course h1,
section.sched h2 {
    padding-top: 1rem;
}
.dvddr .course h1 span,
section.sched h2 span {
    top: -6px;
    left: 0;
}
section.sched h2 {
	font-size: 1.6rem;
}
.crs1l {
    width: 100%;
    margin-right: 0%;
    margin-bottom: 1rem;
}
.crs1r {
    width: 100%;
}
.sourses h2 {
    margin-bottom: 1.3rem;
    margin-left: 0rem;
    line-height: 0.7;
    text-align: left;
    background: linear-gradient(transparent 21%, #fff03f 21%);
}
.coursewr {
    flex-direction: column;
    padding-bottom: 0.3rem;
}
.coursewr a {
    padding: 0.8rem 1.7rem 0.8rem 0.6rem;
    margin-bottom: 1rem;
    text-align: center;
}
.crs2.bt div.cf .s3l {
    width: 100%;
    margin-right: 0;
    margin-bottom: 1rem;
}
.crs2.bt div.cf .s3r {
    width: 100%;
}
.crs3 h2 {
    padding-top: 1rem;
    font-size: 1rem;
    margin-bottom: 1.5rem;
    position: relative;
    padding-bottom: 2rem;
}
.crs3 h2 span {
    right: 0;
    bottom: 0;
}
.crs3in .qaBox .answer {
    margin-bottom: 1rem;
    padding-top: 1rem;
}
.crs3 {
    padding-bottom: 1rem;
}
section.course {
    margin-bottom: 1rem;
}
 .top4 .slick-initialized .slick-slide {
    min-height: 350px;
}
/* 教室 */
.chlimgwr {
    height: 110px;
}
.schpicl {
    width: 100%;
    margin-right: 0;
    margin-bottom: 2rem;
}
.schpicr {
    width: 90%;
    margin: 0 5%;
}
section.schpics.cf {
    margin-bottom: 1rem;
}
.mindinl {
    width: 100%;
    margin-right: 0;
    margin-bottom: 1rem;
}
section.schinmid h2 {
    margin-bottom: 1.4rem;
}
.mindinl table {
    margin-bottom: 0.4rem;
}
.midinr {
    width: 100%;
}
.schbtr p {
    font-size: 0.9rem;
}
/* ブログ */
.blglpi {
    width: 100%;
    float: left;
    margin-right: 0;
}
section.blg img {
    margin-bottom: 1rem;
    padding-top: 0;
}
.blgcont.blglpr {
    width: 100%;
}
.blgcont.blglpr p {
    line-height: 1.6;
}
section.blg .loop {
    margin-bottom: 2rem;
}
section.blg p.blginfo {
    margin-bottom: 1rem;
}
.blgcont img {
    border-radius: 10px;
}
.blgcont {
    padding-bottom: 2rem;
}
/* 合格体験記 */
article#acvsgl.str .titlearea {
    background-size: 150%;
    background-position: top left;
    padding: 1px 0;
    box-shadow: 1px 1px 3px #d2cdcd;
}
article#acvsgl.str .titlebox {
    width: 100%;
    padding: 1rem;
    margin-top: 45%;
    margin-left: 0;
    margin-bottom: 1rem;
    box-shadow: none;
}
.strwrapin {
    padding: 1.5rem 1rem;
}
.upbox.cf .upl {
    width: 100%;
    position: unset;
    text-align: center;
    margin-bottom: 1rem;
    padding-right: 0;
}
.upbox.cf .upl p {
    font-size: 1rem;
}
article#acvsgl.str .acvarbox.str.cf .thumbwr {
    margin: auto;
    margin-bottom: 0.7rem;
    width: 100px;
    height: 100px;
}
article#acvsgl.str .thumbwr .acvarbox.str.cf img {
    width: 142px;
    height: 142px;
}
.upr {
        padding-left: 0;
    padding-right: 0;
    background-position: right top;
    width: 100%;
}
.upr th {
    white-space: nowrap;
}
.upr td {
    font-size: 0.9rem;
}
.upbox.cf {
    margin-bottom: 2rem;
}
.midin .contwrap {
    padding: 0 0.6rem;
}
.midin h3 {
    margin-bottom: 0.9rem;
}
.midin {
    margin-bottom: 1.2rem;
}
.center.mestin {
    transform: rotate(0deg);
}
.mestitle {
    text-align: center;
    margin-bottom: 1.1rem;
}
.mecon {
    margin-left: 1rem;
    margin-right: 1rem;
}
.mesbox {
    margin-bottom: 2rem;
}
section.strwrap {
    margin-bottom: 3rem;
}
/* よくある */
.faqanswer {
    padding: 0 0.4rem;
}
/* 授業料 */
.feebox.cf .fel {
    width: 100%;
    padding-right: 0;
}
.feebox.cf .fer {
    width: 100%;
    margin-bottom: 1rem;
}
.feebox.cf .fer2 {
    width: 100%;
    padding-left: 0;
}
.feebox.cf .fel2 {
    width: 100%;
    margin-bottom: 1rem;
}
.feebox.cf {
    margin-bottom: 1.4rem;
}
.feebox.cf h2 {
    font-size: 1rem;
    margin-bottom: 1.3rem;
    line-height: 1.4;
    padding-bottom: 5px;
}
.feebox.cf h2:after {
    bottom: 2px;
}
/* 講習会 */
.flmin {
    width: 100%;
    padding: 1rem 1rem;
    float: none;
    border-radius: 0;
}
.lectmain {
    border-radius: 0;
    background-position: top left -260px;
    padding: 0rem 0rem;
    padding-top: 80%;
}
.flmin h1 {
    font-size: 2rem;
    margin-bottom: 0.6rem;
}
.flmin h3 {
    line-height: 1.4;
    font-size: 1rem;
}
.lectin table td {
    min-width: 25px;
}
/* 流れ */
.stepbox th {
    display: block;
    width: 100%;
    border-bottom: solid 10px #fff;
}
.stepbox td {
    padding-left: 0;
    display: block;
    width: 100%;
}
.stepbox {
    padding-bottom: 2rem;
}
.stepbox .cf .stel {
    width: 100%;
    padding-right: 0;
    margin-bottom: 0.8rem;
}
.stepbox .cf .ster {
    width: 100%;
}
.stepbox h2 {
    margin-bottom: 0.8rem;
}
/* form */
.formtitle.cf .fmtl {
    width: 100%;
    margin-bottom: 1rem;
}
.formtitle.cf .fmtr {
    width: 100%;
    padding-left: 0%;
}
.formtitle.cf {
    padding-bottom: 1rem;
}
/* 高校生 */
.hightopin {
    padding: 0.8rem 1rem;
}
.hightit {
    padding: 0.5rem;
    padding-top: 37%;
    margin-bottom: 1.5rem;
}
h2.yugo.hightitle {
    line-height: 1.4;
    margin-bottom: 2rem;
    font-size: 1.2rem;
}
.highsubl {
    width: 70%;
    margin: auto;
    margin-bottom: 1rem;
    float: none;
}
.highsubr {
    padding-left: 0;
    width: 100%;
}
.highsub.cf {
    width: 100%;
    margin-bottom: 1rem;
}
section.highbg .wid1160 {
    padding: 2rem 6% 2rem;
}
section.highbg h3 {
    margin-bottom: 2rem;
    line-height: 1.4;
}
.cardh.wid1160 {
    width: 100%;
}
.cardh.wid1160 h3 {
	margin-bottom: 3.3rem;
    line-height: 1.4;
    font-size: 1.1rem;
}
.cardl {
    width: 100%;
    margin-bottom: 1rem;
}
.cardr {
    padding-left: 0%;
    width: 100%;
}
.high3l {
    width: 100%;
    margin-bottom: 0.7rem;
}
.high3r {
    padding-left: 0;
    width: 100%;
}
section.bggray.high3 .cf {
    margin-bottom: 1rem;
}
.h3wr {
    margin-bottom: 1.5rem;
}
section.bggray.high3 .cf.reve {
    flex-direction: column;
}
.high3l2 {
    width: 100%;
    margin-bottom: 0.7rem;
}
.high3r2 {
    padding-right: 0;
    width: 100%;
}
.high3db a {
    width: 100%;
    display: block;
    margin-bottom: 1.6rem;
    text-align: center;
}
.high3db {
    margin-bottom: 0.5rem;
    flex-wrap: wrap;
}
section.bggray.high3 {
    margin-bottom: 3rem;
}
.highfaqwr {
    padding: 2rem 1rem 0;
}
.highfaqwr h4 {
    padding-left: 30px;
    line-height: 1.4;
}
.highfaqwr div.highfaqt div {
    width: 100%;
}
.highfaqwr div.highfaqt {
    margin-bottom: 0rem;
}
.wid1160.highfaq {
    margin-bottom: 3rem;
}
.wid1160.highfaq img {
    margin-bottom: 1rem;
}
/* 特徴 */
.featopin.wid1160 {
    padding-top: 70px;
    padding-bottom: 20px;
}
section.featop {
    margin-bottom: 2rem;
    background-position: left -180px top;
}
.featopin.wid1160 h1 {
    font-size: 1.5rem;
}
.featopin.wid1160 img {
    width: 170px;
}
.metit.center.wid1160 h2 {
    font-size: 2.1rem;
    margin-bottom: 1.4rem;
}
.cf.metimgin {
    width: 100%;
    flex-direction: column;
}
.metimgl {
    width: 100%;
}
.metimmgr {
    align-items: center;
        width: 100%;
}
.wid1160.tokucho3 h2 {
    font-size: 1.3rem;
    margin-bottom: 2rem;
}
.wid1160.tokucho3 h2 span {
    font-size: 2.1rem;
    padding: 0 4px;
}
.wid1160.tokucho3 h2:after {
    height: 20px;
}
.wid1160.tokucho3.center ul {
    flex-wrap: wrap;
}
.wid1160.tokucho3.center ul li {
    width: 45%;
    margin-bottom: -1rem;
}
.wid1160.tokucho3 {
    margin-bottom: 2rem;
}
section.featitsec div {
    background-size: 150%;
    background-position: bottom center;
    height: 170px;
    position: relative;
    background-size: cover;
}
section.featitsec img {
    width: 150px;
    padding: 0;
    position: absolute;
    top: 10px;
    right: 10px;
}
.cf.mtbox {
    flex-wrap: wrap;
}
.cf.mtbox .fea45 {
    width: 100%;
}
.mtbox.revlayout {
    flex-direction: column-reverse;
}
.mttit:after {
    width: 100%;
}
.fea70 {
    width: 100%;
    padding-right: 0;
}
.fea30 {
    width: 100%;
    margin-bottom: 1rem;
}
.tool .center h4 {
    margin-bottom: 1.2rem;
}
.toolwr {
    padding-bottom: 0.5rem;
}
.mtbox.ver2 .fea70 {
    padding-left: 0;
}
.feaig.center ul {
    flex-wrap: wrap;
}
.feaig.center li {
    width: 47%;
    margin-bottom: 1rem;
}
.feaig.center {
    padding: 1.5rem 1rem 1rem;
    margin-bottom: 2rem;
}
.mttit {
    width: 100%;
}
.mttit h3 {
    font-size: 1.3rem;
}
p.feap {
    margin-bottom: 0.7rem;
}
ul.kyozai {
    padding-left: 165px;
}
ul.kyozai {
    background-position: left 20px bottom;
}
.otlayout.cf .wid30 {
    width: 98%;
}
.otlayout.cf .wid70 {
    width: 98%;
}
.otlayout.cf .wid70 .in {
    padding: 1rem;
}
.otlayout.cf .wid70 h4 {
    margin-bottom: 0.6rem;
}
.otlayout.cf {
    margin-bottom: 1rem;
}
.feainl {
    width: 100%;
    margin-bottom: 0.4rem;
}
.feainr {
    width: 100%;
}
section.featitsec {
    margin-bottom: 2rem;
}
section.feamat .matin .matin2 {
    padding: 1.5rem 1rem 1rem;
}
section.feamat h2.dam.italic {
    margin-bottom: 1.2rem;
    padding-bottom: 0.9rem;
}
section.feamat h3 {
    font-size: 1.1rem;
    line-height: 1.6;
    margin-bottom: 2rem;
}
.privacy {
    padding: 1.5rem 1.4rem;
}
/* 概要 */
.abtop.wid1060 {
    width: 100%;
    padding: 0 5%;
    border-radius: 0;
    margin-top: 0;
    margin-bottom: 2rem;
}
.abtopin {
    padding: 1.5rem 0 3.5rem;
}
table.yugo.abtab th {
    padding-left: 6px;
    padding-right: 6px;
    white-space: nowrap;
    font-size: 0.8rem;
    text-align: center;
}
/* 夏期講習 */
.summer .fullmain {
    background-size: 100%;
}
.summer .fullmain {
    background-size: 100%;
    padding-top: 67%;
    background-position: top left;
}
.fullmain .titlebox.center {
    margin-left: 18%;
}
.sstopr {
    width: 100%;
    margin-bottom: 1rem;
}
.sstopl {
    width: 100%;
    padding-right: 0;
    margin-bottom: 1rem;
}
section.sstop .cf {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column-reverse;
}
section.sstop {
    padding-top: 0rem;
    margin-bottom: 2rem;
}
.sstopl h3 {
    line-height: 1.4;
    margin-bottom: 1.2rem;
}
.sstopb.center {
    padding: 1rem 3%;
    margin-bottom: 2rem;
}
.sstopb.center h3 {
    font-size: 1rem;
    white-space: nowrap;
    margin-bottom: 1rem;
}
.sstopb.center h4 {
    margin-bottom: 3.5rem;
}
.sstopb.center h2 {
    font-size: 1.8rem;
    margin-bottom: 2rem;
    line-height: 1.4;
}
.sstopb.center h2:after {
    left: 0px;
    top: -40px;
}
.sstopbtn a {
    width: 90%;
    margin: auto;
    margin-bottom: 1rem;
}
.sstopbtn {
    flex-direction: column;
}
.mazu.center {
    margin-bottom: 2rem;
}
.nanasanl.center {
    width: 100%;
}
.nanasanr {
    width: 100%;
    padding-left: 0%;
}
.pitain {
    width: 100%;
}
.sslechl {
    margin-bottom: 1.5rem;
}
.nanasanr p {
    margin-bottom: 1.4rem;
}
.pitab {
    flex-direction: column;
}
.pitabl {
    width: 100%;
    margin-bottom: 1rem;
}
.pitabr {
    width: 100%;
    padding-left: 0;
}
section.pittari {
    margin-bottom: 2rem;
}
section.ssqa {
    margin-bottom: 1rem;
}
.saranibox {
    width: 100%;
    padding-left: 100px;
    min-height: 120px;
}
.saranibox:before {
    left: 37px;
}
section.sarani {
    margin-bottom: 2rem;
}
.ssflr h3 {
    line-height: 1.3;
}
.ssflrin {
    width: 90%;
}
.ssflrin ul li {
    min-width: 50%;
}
section.ssflow {
    margin-bottom: 3rem;
}
.ssflowbox {
    margin-bottom: 2.4rem;
}
.ssflr:after {
    bottom: -1.9rem;
}
.sslst {
    margin-bottom: 2rem;
}
section.schacv h2 {
    margin-bottom: 0;
}
.schacv .acvarbox.cf {
    width: 98%;
}
}

@media screen and (max-width: 350px) {
.spbtnwrap ul li a {
    font-size: 0.6rem;
    padding: 6px;
}
.spbtnwrap ul {
    right: 39px;
    top: 11px;
}
}




/* =Print
----------------------------------------------- */

@media print {
	body {
		background: none !important;
		color: #000;
		font-size: 10pt;
	}
	footer a[rel=bookmark]:link:after,
	footer a[rel=bookmark]:visited:after {
		content: " [" attr(href) "] "; /* Show URLs */
	}
	a {
		text-decoration: none;
	}
	.entry-content img,
	.comment-content img,
	.author-avatar img,
	img.wp-post-image {
		border-radius: 0;
		box-shadow: none;
	}
	.site {
		clear: both !important;
		display: block !important;
		float: none !important;
		max-width: 100%;
		position: relative !important;
	}
	.site-header {
		margin-bottom: 72px;
		margin-bottom: 5.142857143rem;
		text-align: left;
	}
	.site-header h1 {
		font-size: 21pt;
		line-height: 1;
		text-align: left;
	}
	.site-header h2 {
		color: #000;
		font-size: 10pt;
		text-align: left;
	}
	.site-header h1 a,
	.site-header h2 a {
		color: #000;
	}
	.author-avatar,
	#colophon,
	#respond,
	.commentlist .comment-edit-link,
	.commentlist .reply,
	.entry-header .comments-link,
	.entry-meta .edit-link a,
	.page-link,
	.site-content nav,
	.widget-area,
	img.header-image,
	.main-navigation {
		display: none;
	}
	.wrapper {
		border-top: none;
		box-shadow: none;
	}
	.site-content {
		margin: 0;
		width: auto;
	}

	.entry-header .entry-title,
	.entry-title {
		font-size: 21pt;
	}
	footer.entry-meta,
	footer.entry-meta a {
		color: #444;
		font-size: 10pt;
	}
	.author-description {
		float: none;
		width: auto;
	}
}
