/*--------------------------------------------------------------
# LP03変更用（オリジナルのstyle.cssは変更しない）
# 22/03
# 23/03更新
--------------------------------------------------------------*/

body {
    font-family: "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
    line-height: 1.7;
    font-size: 1.5rem;
    font-weight: 500;
}

/*--------------------------- general ----------------------------*/
h1, h2, h3, h4, h5, h6 {
    font-feature-settings: "palt";
}
h2 {
    font-size: 3.6rem;
}
figure {
    margin: 0;
}
figure img {
    width: 100%;
    max-width: 100%;
    display: block;
}
figcaption {
    margin: .5em 1em;
    font-weight: bold;
}
/*--------------------------- general classes ----------------------------*/


/*-------- margins & paddings */

.mt-0 {
    margin-top: 0!important;
}
.mt-05 {
    margin-top: .5em!important;
}
.mt-1 {
    margin-top: 1em!important;
}
.mt-2 {
    margin-top: 2em!important;
}
.mt-3 {
    margin-top: 3em!important;
}

.mb-0 {
    margin-bottom: 0!important;
}
.mb-05 {
     margin-bottom: .5em!important;
}
.mb-1 {
    margin-bottom: 1em!important;
}
.mb-2 {
    margin-bottom: 2em!important;
}
.mb-3 {
    margin-bottom: 3em!important;
}

.ml-0 {
    margin-left: 0!important;
}
.ml-05 {
     margin-left: .5em!important;
}
.ml-1 {
    margin-left: 1em!important;
}
.ml-2 {
    margin-left: 2em!important;
}
.ml-3 {
    margin-left: 3em!important;
}

.mr-0 {
    margin-right: 0!important;
}
.mr-05 {
     margin-right: .5em!important;
}
.mr-1 {
    margin-right: 1em!important;
}
.mr-2 {
    margin-right: 2em!important;
}
.mr-3 {
    margin-right: 3em!important;
}

.pt-0 {
    padding-top: 0!important;
}
.pt-05 {
     padding-top: .5em!important;
}
.pt-1 {
    padding-top: 1em!important;
}
.pt-2 {
    padding-top: 2em!important;
}
.pt-3 {
    padding-top: 3em!important;
}

.pb-0 {
    padding-top: 0!important;
}
.pb-05 {
     padding-bottom: .5em!important;
}
.pb-1 {
    padding-bottom: 1em!important;
}
.pb-2 {
    padding-bottom: 2em!important;
}
.pb-3 {
    padding-bottom: 3em!important;
}

/*-------- typography */

.no-break {
    white-space: nowrap;
}

.midtitle {
    font-size: 2.8rem;
    padding: 0;
    margin: 0;
    font-weight: bold;
    text-align: center;
    margin-bottom: 0.5em;
    color: #f97408;
    display: inline-block;
    position: relative;
}
.midtitle::before,
.midtitle::after {
    content: "";
    height: .7em;
    width: .7em;
    background: #F39800;
    opacity: .6;
    display: block;
    position: absolute;
    
    top: 12px;
    border-radius: 50%;
}
.midtitle::before {
    left: -.9em;
}
.midtitle::after {
    right: -1em;
}
.midtitle small {
    position: absolute;
    bottom: 90%;
}
.midtitle__wrapper {
    text-align: center;
}

.subtitle {
    font-size: 2rem;
    padding: 0;
    margin: 0;
    margin-bottom: .2em;
    font-weight: bold;
    position: relative;
    padding-left: 1.3em;
    color: #0088ba!important;
    text-align: left;
}
.subtitle::before {
    content: "";
    height: 1em;
    width: 1em;
    background: pink;
    display: block;
    position: absolute;
    left: 0;
    top: 5px;
    border-radius: 50%;
}

.reason .contents__disc {
    margin: 24px 0px;
    font-size: 2rem;
}
.contents__lead {
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 2em;
}

@media screen and (max-width: 768px) {
    .reason .contents__disc {
        font-size: 1.7rem;
        margin: 16px 0px;
    }
	
} /* end media query */

@media screen and (max-width: 480px) {
    .midtitle {
        font-size: 6vw;
    }
    .subtitle {
        font-size: 1.8rem;
    }
	
} /* end media query */

/*-------- components */
.badge {
    display: inline-block;
    padding: 0.25em 0.4em;
    font-size: 75%;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 5px;
    background: orange;
}

/*--------------------------- catch ----------------------------*/
.catch {
    width: 100%;
    max-width: 936px;
    margin: 2em auto;
    padding: 0 16px;
    text-align: center;
}
.catch figure {
    max-width: 600px;
    margin: 1.5em auto;
}
.catch__normal {
    font-size: 2rem;
    color: #333;
    font-weight: bold;
}

.catch__phrase {
    font-weight: bold;
    font-size: 2.4rem;
    color: #0088ba;
}
.catch__phrase em {
    font-style: normal;
    display: inline-block;
    padding: .5em 1em;
    border: 2px solid #f8ca7f;
    margin: .5em 0;
    color: #f97408;
}
.catch__symbol {
    font-size: 180%;
    line-height: .7;
    color: #f97408;
}

@media screen and (max-width: 768px) {
    .catch {
        padding: 0;
    }
	
} /* end media query */

@media screen and (max-width: 480px) {
    
    .catch__normal{
        font-size: 1.6rem;
    }
    .catch__phrase {
        font-size: 1.8rem;
    }
	
} /* end media query */

/*--------------------------- fv ----------------------------*/

#fv {
    border-top: 8px solid #b5ecf1;
    border-bottom: 8px solid #b5ecf1;
}
.fv__location h2 {
    color: #f97408;
}


/*--- location-table */
.location-table {
    display: block;
    border-collapse: collapse;
    border-top: 3px solid #b5ecf1;
    border-bottom: 3px solid #b5ecf1;
    margin-bottom: 3em;
    
}
.location-table tbody {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}
.location-table__item {
    display: block;
    width: 48%;
    clear: left;
}
.location-table__item.double {
    width: 97%;
}

.location-table__item th {
    width: 6em;
    text-align: center;
    display: block;
    float: left;
    border-top-color: #b5ecf1;
}
.location-table__item th span {
    background: #f97408;
    color: white;
    width: 100%;
    border-radius: 15px;
    padding: 3px;
}

.location-table__item td {
    width: calc(100% - 6em);
    text-align: center;
    display: block;
    float: left;
    padding-top: 12px;
    border-top-color: #b5ecf1;
    font-weight: bold;
}
.location-table__item.double td {
    font-size: 130%;
}
.location-table__item:first-child th,
.location-table__item:first-child td,
.location-table__item:nth-child(2) th,
.location-table__item:nth-child(2) td {
    border-top: none;
}

@media screen and (max-width: 768px) {
    
    #fv {
        border-top: none;
        /*border-bottom: none;*/
    }
    .fv__location {
        padding: 0 16px;
    }
	
} /* end media query */

@media screen and (max-width: 600px) {
    .location-table__item {
        display: block;
        width: 100%;
    }
    .location-table__item:nth-child(2) th,
    .location-table__item:nth-child(2) td {
        border-top: 1px solid #b5ecf1;;
    }
    
	
} /* end media query */


/*--------------------------- cta ----------------------------*/
.cta__catch {
    text-align: center;
    font-weight: bold;
    margin-top: -1.5em;
    margin-bottom: 2em;
	color: #0052a4;
}
.cta__catch strong {
	background: linear-gradient(transparent 50%,#ffea3c 0);
}


/*--------------------------- reason 特徴 ----------------------------*/


.reason .index__item {
    height: auto;
    border-radius: 10px;
    border: 2px solid #b5ecf1;
    flex: 0 0 350px;
}
.reason .index__numbering {
    width: 60%;
    margin-top: 0.6em;
}
.reason .index__title {
    font-size: 2.4rem;
    padding: 0 1em 1em;
    font-feature-settings: "palt";
}

.reason .contents {
    margin-bottom: 3em;
}

.reason img {
    max-width: 600px;
    margin: 0 auto;
    display: block;
}

.contents__disc-wrap > .contents__img {
    -webkit-flex: 0 1 calc(100% / 3 + 50px);
    -ms-flex: 0 1 calc(100% / 3 + 50px);
    flex: 0 1 calc(100% / 3 + 50px);
}
.contents__disc-wrap > .contents__disc {
    -webkit-flex: 0 1 calc(100% / 3 * 2 - 60px);
    -ms-flex: 0 1 calc(100% / 3 * 2 - 60px);
    flex: 0 1 calc(100% / 3 * 2 - 60px);
    font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
    .reason .index__item {
        -webkit-flex: 0 0 100%;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        height: auto;
        max-width: 400px;
    }
    .reason .index__title {
        font-size: 3.8vw;
    }
    .reason .index__item:nth-of-type(3) {
            margin: 24px 16px;
    }
	
} /* end media query */

@media screen and (max-width: 425px) {
	
    /*.reason .index__item {
        flex: 0 0 260px;
        height: 260px;
    }*/
    .reason .index__numbering {
        font-size: 2.2rem;
    }
    .reason .index__title {
        font-size: 2.1rem;
        font-size: 5.8vw;
    }
    .reason .index__item:nth-of-type(3) {
        margin: calc(100vw / 768 * 24) calc(100vw / 768 * 16);
    }
    .reason .contents h3 {
        font-size: calc(100vw / 425 * 21);
    }
	
} /* end media query */



/*--------------------------- courses コース案内 ----------------------------*/

.courses{
	display:-webkit-box;/*--- Android旧ブラウザ用 ---*/
	display:-ms-flexbox;/*--- IE10 ---*/
	display: -webkit-flex;/*--- safari（PC）用 ---*/
	display:flex;
	align-content: flex-start;
	-ms-flex-wrap:wrap;/*--- IE10用 ---*/
	-webkit-flex-wrap:wrap;/*--- safari（PC）用 ---*/
	flex-wrap:wrap;
	justify-content:space-between;
}

.course{
	padding:24px 24px 24px 24px;
	border:2px solid #E887A8;
	border-radius:8px;
	-webkit-flex:0 1 calc(50% - 16px);/*--- safari（PC）用 ---*/
	-ms-flex:0 1 calc(50% - 16px);/*--- IE10用 ---*/
	flex : 0 1 calc(50% - 16px);
	margin:16px 0px;
	position:relative;
}
.course__weak{
	font-size:1.6rem;
	background:#E887A8;
	display:inline-block;
	padding:0.2em;
	border-radius:2px;
	color:#ffffff;
	position:absolute;
	left:16px;
	top:0px;
	transform:translateY(-50%);	
}
.course__goal{
	margin:8px 0px;
	color:#E887A8;
	font-weight:bold;
}
.course__name{
	font-size:2.4rem;
	font-weight:bold;
}
@media screen and (max-width:768px){
	.courses{
		display:block;
	}
	.course{
		padding:16px 16px 16px 16px;
		margin:24px 0px;
	}
	.course__weak{
		font-size:1.6rem;
	}
	.course__goal{
		margin:4px 0px;
	}
	.course__name{
		font-size:2.0rem;
	}
}
@media screen and (max-width:425px){
    .course__weak{
		font-size:calc(100vw / 425 * 16);
	}
    .course__goal{
		font-size:calc(100vw / 425 * 16);
	}
}

/*--------------------------- locations 教室案内 ----------------------------*/

.locations dt.new {
    background: #16A700;
    background-image: repeating-linear-gradient(-45deg ,#2DB019, #2DB019 2px,rgba(0,0,0,0) 0, rgba(0,0,0,0) 7px);
}
.locations dt small {
    margin-left: .5em;
}

/*--------------------------- covid ----------------------------*/

.covid {
    padding-top: 3em;
    padding-bottom: 0;
}