@charset "utf-8";


/*resetCSS*/
html{
font-size: 62.5%;
-webkit-text-size-adjust: 100%;
color:#333333;
background:#FFF;
}
body,div,
dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
form,fieldset,input,textarea,
p,
th,td{
margin:0;
padding:0;
}
table{
border-collapse:collapse;
border-spacing:0;
}
fieldset,
img{ border:0; }
address,
caption,
em{
font-style:normal;
font-weight:normal;
}
ol,ul{ list-style:none; }
caption, th{ text-align:left; }
h1,h2,h3,h4,h5,h6{
font-size:100%;
font-weight:normal;
}
q:before,q:after{ content:''; }
abbr,acronym{
border:0;
font-variant:normal;
}
sup{ vertical-align:text-top; }
sub{ vertical-align:text-bottom; }
input,textarea,select{
font-family:inherit;
font-size:inherit;
font-weight:inherit;
*font-size:100%;
}
*{
margin:0;
padding:0;
}
strong,
th{ font-weight:bold;}

#content{ }
.section{
clear:both;
margin-bottom:30px;
}

body{
font-size:1.6rem;
font-family: 'Noto Serif JP','游明朝体', 'Yu Mincho', serif;
}

*, *:before, *:after{
-webkit-box-sizing:border-box;
-moz-box-sizing:border-box;
-o-box-sizing:border-box;
-ms-box-sizing:border-box;
box-sizing:border-box;
}

h1{
font-size:4.8rem;
font-weight:bold;
margin-bottom:30px;
}
h2{
font-size:3.8rem;
font-weight:bold;
margin-bottom:1.5em;
}
h2 span{ }
h3{
font-size:24px;
font-weight:bold;
margin-bottom:15px;
}
h3 span{ }
h4{
font-size:95%;
font-weight:bold;
margin-bottom:15px;
}
h5{
font-size:90%;
font-weight:bold;
margin-bottom:10px;
}
p,ul,ol,dl{
font-size:16px;
margin-bottom:1.5em;
line-height:160%; }
.anchor a{ }

a{
text-decoration: none;
color: #D8B558;
}
a:hover{
text-decoration:underline;
}
a:hover img{
opacity: 0.7;
transition: all .3s;
}

/*clear Fix*/
.clearFix:after{
content:".";
display:block;
height:0;
clear:both;
visibility:hidden;
}
.clearFix{
display:inline-table;
min-height:1%;
}
* html .clearFix{
height:1%;
}
.clearFix{
display:
block;
}
/* フォント指定
=========================================================================================== */
@font-face {
    font-family: 'Noto Serif JP', serif;
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/NotoSerifJP-Medium.woff2') format('woff2'),
	     url('../fonts/NotoSerifJP-Medium.woff') format('woff'),
	     url('../fonts/NotoSerifJP-Medium.otf')  format('truetype'),
}
@font-face {
    font-family: 'Noto Serif JP', serif;
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/NotoSerifJP-SemiBold.woff2') format('woff2'),
	     url('../fonts/NotoSerifJP-SemiBold.woff') format('woff'),
	     url('../fonts/NotoSerifJP-SemiBold.otf')  format('truetype'),
}
@font-face {
    font-family: 'Noto Serif JP', serif;
    font-style: normal;
    font-weight: 900;
    src: url('../fonts/NotoSerifJP-Bold.woff2') format('woff2'),
	     url('../fonts/NotoSerifJP-Bold.woff') format('woff'),
	     url('../fonts/NotoSerifJP-Bold.otf')  format('truetype'),
}
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: bold;
    src: url('../fonts/Montserrat-SemiBold.woff2') format('woff2'),
	     url('../fonts/Montserrat-SemiBold.woff') format('woff'),
	     url('../fonts/Montserrat-SemiBold.ttf')  format('truetype'),
         url('../fonts/Montserrat-SemiBold.eot') format('embedded-opentype');
}
/*--------------------ここまで-----------------------------------*/
/* Header Setting
=========================================================================================== */
#headerSet{
	position:fixed;
	top:0;
	left:0;
	width: 100%;
	z-index:999;
    padding-left: 4%;
	display: flex;
    justify-content: flex-end;
	transition: all .3s;
}
#headerSet #headerLogoSet{
	margin-right:auto;
    display: flex;
    z-index: 9999;
}
#headerSet #headerLogoSet #headerLogo{
    margin-bottom: 0;
    display: flex;
    align-items: center;
    padding: 5px 0;
}
#headerSet #headerLogoSet a{
    font-size: 0;
	transition: all .3s;
}
/*#headerSet #headerLogoSet a:hover{
	background: #d5ba06;
}*/
#headerSet #headerLogoSet a span{
    font-size: 14px;
    margin-right: 0.5em;
}
#headerSet #headerLogoSet a strong{
    font-weight: 900;
    font-size: 24px;
}

#headerSet #headerMenuSet{
    display: flex;
    align-items: center;
}
#headerSet #headerMenuSet .gnav ul{
	display: flex;
    align-items: center;
	justify-content: flex-end;
	font-size:16px;
    margin-bottom: 0;
}
#headerSet #headerMenuSet .gnav ul li{
	padding:0 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}
#headerSet #headerMenuSet .gnav ul li:last-child{
    padding-right: 2em;
}
#headerSet #headerMenuSet .gnav ul li a{
	color:#FFF;
	text-decoration:none;
	position: relative;
    text-shadow:2px 2px 2px rgba(0,0,0,0.8);
	transition: all .3s;
}
#headerSet #headerMenuSet .gnav ul li a:hover{
	color:#D8B558;
}

#headerSet #headerMenuSet .gnav ul li a:after {
	position: absolute;
	bottom: -0.5em;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #D8B558;
	transform: scale(0, 1);
	transform-origin: center top;
	transition: transform .3s;
}
#headerSet #headerMenuSet .gnav ul li a:hover:after {
	transform-origin: center top;
	transform: scale(1, 1);
}

#headerSet .headerSnsList {
    display: flex;
    align-items: center;
}
#headerSet .headerSnsList ul{
    display: flex;
    margin-bottom: 0;
}
#headerSet .headerSnsList ul li{
    margin-right: 1em;
    filter: drop-shadow(1px 1px 2px #000);
}
#headerSet .headerSnsList ul li:last-child{
    margin-right: 2em;
}
#headerSet .headerSnsList ul li a{
    display: block;
    line-height: 0;
}


#headerSet #headerContactSet ul{
    display: flex;
    margin-bottom: 0;
}
#headerSet #headerContactSet ul li a{
    text-decoration:none;
    transition: all .3s;
}
#headerSet #headerContactSet ul li a span{
    display: block;
    font-size: 14px;
}
#headerSet #headerContactSet li.headerLine{
    display: flex;
}
#headerSet #headerContactSet li.headerLine span{
    margin-bottom: 5px;
}
#headerSet #headerContactSet li.headerLine a{
    padding:0 1em;
    background:#EFE2A3;
    color:#0B4030;
    display: flex;
    align-items: center;
    text-align: center;
}
#headerSet #headerContactSet li.headerLine a:hover{
    background: #d3c16b;
}
#headerSet #headerContactSet li.headerTel a{
    padding: 1em 2em;
    background: #0B4030;
    color: #FFF;
    display: block;
    text-align: center;
    font-size: 20px;
	transition: all .3s;
}
#headerSet #headerContactSet li.headerTel a:hover{
    background: #1a5c48;
}
#headerSet #headerContactSet li.headerTel a strong:before {
    content: "";
    display: inline-block;
    width: 24px;
    height: 24px;
    background-image: url(../images/icon_tel.svg);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    margin-right: 10px;
}



.current #headerSet{
	background: rgb(0,0,0,0.4);
}
.current #headerSet #headerMenuSet .gnav ul li a:hover{
	color:#D8B558;
}
/* ALL Setting
=========================================================================================== */
#subContentsHead{
	background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
	margin-bottom:1em;
}
#subContentsHead.aboutHead{
	background-image:url(../images/about/mainvisual.jpg);
}
#subContentsHead.serviceHead{
	background-image:url(../images/service/mainvisual.jpg);
}
#subContentsHead.salonHead{
	background-image:url(../images/salon/mainvisual.jpg);
}
#subContentsHead.schoolHead{
	background-image:url(../images/school/mainvisual.jpg);
}

#subContentsHead .mainVisual{
	height: 54vh;
	position:relative;
	min-height: 380px;
}
#subContentsHead .mainVisual .mainTitle{
	font-size:3.2rem;
    text-align: center;
	white-space: nowrap;
    letter-spacing: 0.2em;
	font-weight: 700;
	margin-bottom:0;
	text-shadow:4px 4px 6px rgba(0,0,0,0.8);
	color:#FFF;
	position: absolute;
    left:50%;
    top: 50%;
    transform:translateY(-50%) translateX(-50%);
}
#subContentsHead .mainVisual .mainTitle span{
    font-family: 'Montserrat';
    display: block;
    font-size: 16px;
    color: #0B4030;
    text-shadow:0px 0px 6px rgba(255,255,255,0.8);
    letter-spacing: normal;
}
/**パンくず**/
#path{
	max-width:1100px;
	margin:0 auto;
	display: flex;
    align-items: center;
	justify-content: flex-start;
	font-size:14px;
	margin-bottom: 0;
}
#path li a{
	color:#0B4030;
}
#path li:after{
	content:"/";
	padding:0 1em;
}
#path li:last-child:after{
	content:none;
}

article section{
	padding:60px 0;
	width:1100px;
	margin:0 auto;
}
main article:last-child section{
    padding-bottom: 100px;
}



.ttlStyle1{
    text-align:center;
	margin-bottom: 1.5em;
}
.ttlStyle1 span{
    color: #D8B558;
    font-size: 16px;
    display:block;
    font-family: 'Montserrat';
}
.ttlStyle1 span:before{
    content: "";
    background-image: url("../images/icon-h2.svg");
    display: block;
    width: 38px;
    height: 38px;
    background-repeat: no-repeat;
    background-position: center ;
    background-size: cover;
    margin: 0 auto;
}
.ttlStyle1 strong{
    font-size:3.2rem;
    color: #0B4030;
    font-weight: normal;
    display: block;
}

.ttlStyle2{
    font-size: 3.2rem;
    column-count: #0B4030;
    margin-bottom: 1.5em;
}
.ttlStyle3{
    font-size: 3.2rem;
    column-count: #0B4030;
    margin-bottom: 1.5em;
    border-bottom: 1px solid #0B4030;
    padding-bottom: 0.5em;
}
.ttlStyle3 span{
    color: #D8B558;
    font-size: 16px;
    display:block;
    font-family: 'Montserrat';
}
.ttlStyle4{
    background: #0B4030;
    color: #FFF;
    font-size: 3.2rem;
    text-align: center;
    padding: 0.5em 1em;
}




.bgPattern01{
    background-image: url(../images/mimoza_bg.jpg);
    background-size: cover;
    background-position: top;
    background-repeat: no-repeat;
}
.bgPattern02{
    background: #0B4030;
}
.bgPattern03{
    background: #FAF6E1;
}


.textSmall{
    font-size: 14px;
}
.imgOnlyStyle img{
    max-width: 100%;
}
.centerAdjust{
    text-align: center;
}
.rightAdjust{
    text-align: right;
}
.anchor {
    display: block;
    padding-top: 100px;
    margin-top: -100px;
    pointer-events: none;
}
.boxPatternA{
    background: #0B4030;
    padding: 3em 4%;
    color: #FFF;
    margin-bottom: 3em;
}
.boxPatternA h2{
    font-size: 3.2rem;
}
.btnStyle1 a{
    background: #FFF;
    color: #0B4030;
    font-size: 16px;
    padding: 0.8em 2em;
    border: 1px solid #0B4030;
    border-radius: 10px;
    display: inline-block;
    text-decoration:none;
    min-width: 180px;
	transition: all .3s;
	position:relative;
}
.btnStyle1 a:before {
    content: "";
    display: inline-block;
    background-image: url(../images/icon_arrow_r.svg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 10px;
    height: 10px;
    position: absolute;
    top: 50%;
    right: 2em;
    transform: translateY(-50%);
    transition: all .3s;
}
.btnStyle1 a:hover{
    background: #0B4030;
    color: #FFF;
}
.btnStyle1 a:hover:before{
    background-image: url(../images/icon_arrow_r_w.svg);
}


.listStyle1 li{
    margin-bottom: 0.5em;
    text-indent: -1.5em;
    padding-left: 1.5em;
}
.listStyle1 li:before{
    content: "■";
    color: #0B4030;
    margin-right: 0.5em;
}



.columnList3{
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 2em;
}
.columnList3 li{
	width:30%;
    text-align: center;
	margin-left:5%;
}
.columnList3 li:nth-child(3n+1){
	margin-left:0;
}
.columnList3 li .imgOnlyStyle{
    margin-bottom: 1em;
}
.columnList3 li img{
	width:100%;
}
.columnList3 li .ttl{
    font-size: 18px;
}

/* about Setting
=========================================================================================== */
.aboutCatchText{
    text-align: center;
}
.aboutFeature{
    color: #FFF;
}
.aboutFeature .ttlStyle1 strong{
    color: #FFF;
}
.aboutColumnSet h3{
    font-size: 24px;
    color: #EFE2A3;
    margin-bottom: 1.5em;
}

.aboutColumnSet .columnText{
	width:48%;
}
.aboutColumnSet .columnImg {
    width: 48%;
}
.aboutColumnSet .columnImg .imgOnlyStyle{
    margin-bottom: 0;
}
.aboutColumnSet .columnImg img{
	width:100%;
}
.aboutColumnSet.typeA{
	display: flex;
    justify-content: center;
    align-items: center;
	margin-bottom: 2em;
}
.aboutColumnSet.typeB{
	display: flex;
    flex-direction: row-reverse;
    align-items: center;
    flex-wrap: wrap;
	margin-bottom: 2em;
}
.aboutColumnSet.typeA .columnText{
	margin-left:4%;
}
.aboutColumnSet.typeB .columnImg{
	margin-left:4%;
}


.profileColumnSet{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.profileColumnSet h3{
    font-size: 2.4rem;
    color: #06479D;
}
.profileColumnSet .profileColumnImg{
    width: 30%;
}
.profileColumnSet .profileColumnImg .imgOnlyStyle{
    margin-bottom: 0.5em;
}
.profileColumnSet .profileColumnImg img{
    width: 100%;
}
.profileColumnSet .profileColumnImg span{
    margin-bottom: 0.5em;
    display: block;
}
.profileColumnSet .profileColumnImg dl{
    display: flex;
    align-items: center;
    margin-bottom: 0;
}
.profileColumnSet .profileColumnImg dl dt{
    background: #0B4030;
    color: #FFF;
    font-size: 14px;
    padding: 0.2em 1em;
    display: inline-block;
    margin-right: 1em;
}
.profileColumnSet .profileColumnImg dl dd{
    font-size: 24px;
}
.profileColumnSet .profileColumnText{
    width: 50%;
    margin-left: 4%;
}
.profileColumnSet .profileColumnText p{
    line-height: 180%;
}

.profileColumnSet .profileColumnText .name{
    display: flex;
    align-items: center;
    margin-bottom: 1em;
}
.profileColumnSet .profileColumnText .name dt{
    background: #0B4030;
    color: #FFF;
    font-size: 14px;
    padding: 0.2em 1em;
    display: inline-block;
    margin-right: 1em;
}
.profileColumnSet .profileColumnText .name dd{
    font-size: 24px;
}
/* service Setting
=========================================================================================== */
.menuBtnList{
	display: flex;
    justify-content: flex-start;
	flex-wrap: wrap;
}
.menuBtnList li{
	width: 30%;
    margin-left: 5%;
    margin-bottom: 1.5em;
}
.menuBtnList li:nth-child(3n+1){
	margin-left:0;
}
.menuBtnList li a{
    background: #0B4030;
    display: block;
    color: #FFF;
    padding: 1.5em 1em;
    text-align: center;
    position: relative;
    transition: all .3s;
    text-decoration: none;
}
.menuBtnList li a:before{
    content: "";
    display: inline-block;
    background-image: url("../images/icon_arrow_r_w.svg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 10px;
    height: 10px;
    position: absolute;
    top: 50%;
    right: 2em;
    transform: translateY(-50%) rotate( 90deg );
    transition: all .3s;
}

.menuBtnList li a:hover{
    opacity: 0.7;
}



.menuList > li{
    background: #F7F9F9;
    padding: 2em 4%;
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 3em;
}
.menuList > li:last-child{
    margin-bottom: 0;
}
.menuList > li .menuImg{
    width: 40%;
    margin-bottom: 1em;
}
.menuList > li .menuImg img{
    width: 100%;
}
.menuList > li .menuText{
    width: 56%;
    margin-left: 4%;
    margin-bottom: 1em;
}
.menuList > li .menuText .tag{
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 1em;
}
.menuList > li .menuText .tag > li{
    background: #D8B558;
    margin-right: 1em;
    margin-bottom: 5px;
    font-size: 14px;
    border-radius: 4px;
    display: inline-block;
    padding: 0 1em;
    color: #FFF;
}
.menuList > li .menuText h3{
    font-size: 2.8rem;
}
.menuList > li .menuText h3 span{
    display: inline-block;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    border: 1px solid #0B4030;
    color: #0B4030;
    letter-spacing: -0.1em;
    text-align:center;
    line-height: 60px;
    font-size: 2.0rem;
    margin-right: 0.5em;
}
.menuList > li .menuText h3 + p{
    font-size: 14px;
}


.menuList > li .menuText .priceList > li{
    font-size: 24px;
    margin-bottom: 0.2em;
}
.menuList > li .menuText .priceList > li span{
    background: #0B4030;
    color: #FFF;
    border-radius: 4px;
    padding: 0 0.5em;
    font-size: 14px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 0.5em;
    width: 12em;
    text-align: center;
}



/*.menuList > li .menuText .price{
    display: flex;
    align-items: center;
}
.menuList > li .menuText .price dt{
    background: #0B4030;
    color: #FFF;
    border-radius: 4px;
    padding: 0 0.5em;
    font-size: 14px;
    display: inline-block;
    margin-right: 0.5em;
}
.menuList > li .menuText .price dd{
    font-size: 24px;
    margin-right: 1em;
}


.menuList > li .menuText .price2{
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 0.5em;
}
.menuList > li .menuText .price2 dt{
    background: #0B4030;
    color: #FFF;
    border-radius: 4px;
    padding: 0 0.5em;
    font-size: 14px;
    display: inline-block;
    margin-right: 0.5em;
    width: 12em;
    text-align: center;
    margin-bottom: 0.5em;
}
.menuList > li .menuText .price2 dd{
    font-size: 24px;
    width: calc(100% - 12em);
    margin-bottom: 0.5em;
}
*/



.menuList > li .menuText .yoyaku{
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}
.menuList > li .menuText .yoyaku li{
    width: 48%;
}
.menuList > li .menuText .yoyaku li:last-child{
    margin-left: 4%;
}
.menuList > li .menuText .yoyaku li a{
    background: #0B4030;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1em;
    text-align: center;
    color: #FFF;
    text-decoration: none;
    transition: all .3s;
}
.menuList > li .menuText .yoyaku li a:hover{
    opacity: 0.7;
}
.menuList > li .menuText .yoyaku li.tel a:before{
    content: "";
    background-image: url("../images/icon_tel_w.svg");
	background-size: cover;
	background-repeat: no-repeat;
	display: inline-block;
	width:24px;
	height:24px;
    margin-right: 1em;
}
.menuList > li .menuText .yoyaku li.line a:before{
    content: "";
    background-image: url("../images/icon_line.svg");
	background-size: cover;
	background-repeat: no-repeat;
	display: inline-block;
	width:24px;
	height:24px;
    margin-right: 1em;
}

.menuList > li .accordionArea{
    width: 100%;
}


.optionTable{
    width: 100%;
    margin-bottom: 2em;
}

.optionTable tr{
    border-bottom: 1px dashed #0B4030;
}
.optionTable th{
    font-weight: normal;
    padding: 1.5em 0;
}
.optionTable td{
    text-align: right;
    padding: 1.5em 0
}
.optionTable td span{
    border: 1px solid #0B4030;
    display: inline-block;
    padding: 0 1em;
    margin-right: 1em;
}



/* salon Setting
=========================================================================================== */
.salonTableSet{
    text-align: center;
}
.salonTable{
    display: inline-block;
	font-size: 16px;
    margin: 0 auto;
    text-align: left;
    margin-bottom: 2em;
}
.salonTable th{
	padding:1.5em;
}
.salonTable td{
	padding:1.5em;
}


.licenseList{
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 4em;
}
.licenseList li{
    background: #EFE2A3;
    padding: 10px;
    width: 30%;
    margin-left: 5%;
    font-size: 2.4rem;
    text-align: center;
}
.licenseList li:nth-child(3n+1){
	margin-left:0;
}
.licenseList li span{
    display: block;
    border:1px solid #D8B558;
    padding: 2em 4%;
}
.map iframe{
	width: 100%;
}


.routeList{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.routeList li{
    width: 30%;
    margin-left: 5%;
    position: relative;
    margin-bottom: 3em;
}
.routeList li:nth-child(3n+1){
    margin-left: 0;    
}
.routeList li img{
    width: 100%;
}
.routeList li span{
    position: absolute;
    top: 0;
    left: 0;
    transform: translateY(-20%) translateX(-20%);
    width: 50px;
    height: 50px;
    display: inline-block;
    background-color: #0B4030;
    color: #FFF;
    line-height:50px;
    border-radius: 50%;
    text-align: center;
    font-size: 24px;
    font-weight: 900;
}
.routeList li p{
    font-size: 18px;
    text-align: center;
}


.parkingList{
    display: flex;
    flex-wrap: wrap;
}
.parkingList li{
    width: 48%;
    text-align: center;
    margin-left: 4%;
}
.parkingList li:first-child{
    margin-left: 0
}
.parkingList li img{
    width: 100%;
    margin-bottom: 1em;
}
.parkingList li h3{
    margin-bottom: 1em;
}





/* school Setting
=========================================================================================== */
.fukidashiTtl{
    text-align: center;
    margin-bottom: 2em;
}
.fukidashiTtl span{
	color:#FFF;
	position:relative;
	padding:0.5em 2em;
	margin-bottom:1em;
    border-radius: 3em;
    text-align: center;
    font-size: 2.4rem;
    background: #0B4030;
    display: inline-block;
}
.fukidashiTtl span:before {
    content: "";
    position: absolute;
    right: 0;
    bottom: -16px;
    left: 0;
    width: 0px;
    height: 0px;
    margin: auto;
    border-style: solid;
    border-color: #0B4030 transparent transparent transparent;
    border-width: 16px 20px 0 20px;
}


.checkListSet{
    text-align: center;
}
.checkList{
    text-align: left;
    display: inline-block;
}
.checkList li{
    font-size: 18px;
    font-weight: bold;
    position: relative;
    padding-left: 2.2em;
	margin-bottom:1.5em;
}
.checkList li:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 30px;
    height: 30px;
    background: #FFF;
    border: 1px solid #0B4030;
}
.checkList li:after {
    content: "";
    position: absolute;
    top: .35em;
    left: 10px;
    -webkit-transform: rotate(50deg);
    -ms-transform: rotate(50deg);
    transform: rotate(50deg);
    width: 10px;
    height: 16px;
    border-right: 4px solid #0B4030;
    border-bottom: 4px solid #0B4030;
}



.courseList > li{
    background: #F7F9F9;
    padding: 2em 4%;
    margin-bottom: 3em;
}
.courseList > li .courseInner{
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: wrap;
    margin-bottom: 1em;
}
.courseList > li .courseImg{
    width: 34%;
    margin-left: 4%;
    margin-bottom: 1em;
}
.courseList > li .courseImg img{
    width: 100%;
}
.courseList > li .courseText{
    width: 62%;
    margin-bottom: 1em;
}
.courseList> li .courseText .tag{
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 1em;
}
.courseList > li .courseText .tag > li{
    background: #D8B558;
    margin-right: 1em;
    font-size: 14px;
    border-radius: 4px;
    display: inline-block;
    padding: 0 1em;
    color: #FFF;
}
.courseList > li .courseText h3{
    color: #0B4030;
    font-size: 2.8rem;
}

.courseList > li .courseText .recommendBox{
    background: #FFF;
    padding: 1em 4%;
}
.courseList > li .courseText .recommendBox h4{
    border-bottom: 1px dashed #0B4030;
    color: #0B4030;
    font-size: 18px;
    padding-bottom: 0.5em;
}



.accordionArea {
}
.accordionArea .accordionBtn{
    border: 1px solid #0B4030;
    border-radius: 6px;
    padding: 1em;
    color: #0B4030;
    max-width: 330px;
    text-align: center;
    display: block;
    margin: 0 auto;
    cursor: pointer;
    transition: all .3s;
    position: relative;
}
.accordionArea .accordionBtn:hover{
    background: #0B4030;
    color: #FFF;
}
.accordionArea .accordionBtn:before{
    content: "";
    position: absolute;
    width: 20px;
    height: 2px;
    background: #0B4030;
    top:50%;
    right: 1em;
    transform: translateY(-50%);
    transition: all .3s;
}
.accordionArea .accordionBtn:after{
    content: "";
    position: absolute;
    width: 20px;
    height: 2px;
    background: #0B4030;
    top:50%;
    right: 1em;
    transform: translateY(-50%) rotate(90deg);
    transition: all .3s;
}
.accordionArea .accordionBtn:hover:before,
.accordionArea .accordionBtn:hover:after{
    background: #FFF;
}
.accordionArea .accordionBtn.ac:after {
    content: none;
}
.accordionArea .accordionBtn.ac .open{
    display: none;
}
.accordionArea .accordionBtn.ac .close{
    display: block;
}
.accordionArea .accordionBtn .close{
    display: none;
}
.accordionArea .accordionBtn .open{
    display: block;
}


.accordionArea .accordionContents{
    
}
.accordionArea .accordionContents .courseTable{
	width:100%;
	font-size:16px;
	margin-bottom:1.5em;
}
.accordionArea .accordionContents .courseTable th,
.accordionArea .accordionContents .courseTable td{
	padding:1.5em;
	border:1px solid #CCC;
}
.accordionArea .accordionContents .courseTable th{
	background:#0B4030;
	font-weight:normal;
	color:#FFF;
}
.accordionArea .accordionContents .courseTable td{
	background:#FFF;
}


.schoolAccessSet{
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 2em;
}
.schoolAccessSet .schoolAccessText{
    width: 48%;
}
.schoolAccessMap{
    width: 48%;
    margin-left: 4%;
}
.schoolAccessMap iframe{
    width: 100%;
}

.entryBox{
    background: #FAF6E1;
    padding: 2em 4%;
    text-align: center;
}
.entryBox .entryBtn{
    display: flex;
    justify-content: center;
}
.entryBox .entryBtn li {
    width: 38%;
    margin: 0 2%;
    text-align: center;
}
.entryBox .entryBtn li a{
    background: #0B4030;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    padding: 1.5em 1em;
    color: #FFF;
    border-radius: 4px;
    text-decoration: none;
    transition: all .3s;
}
.entryBox .entryBtn li a:hover{
    opacity: 0.7;
}
.entryBox .entryBtn li.tel a:before{
    content: "";
    background-image: url("../images/icon_tel.svg");
	background-size: cover;
	background-repeat: no-repeat;
	display: inline-block;
	width:24px;
	height:24px;
    margin-right: 1em;
}
.entryBox .entryBtn li.line a:before{
    content: "";
    background-image: url("../images/icon_line.svg");
	background-size: cover;
	background-repeat: no-repeat;
	display: inline-block;
	width:24px;
	height:24px;
    margin-right: 1em;
}




.chinaList{
    display: flex;
}
.chinaList li{
    width: 48%;
    margin-left: 4%;
    text-align: center;
}
.chinaList li:first-child{
    margin-left: 0;
}
.chinaList li .imgOnlyStyle{
    margin-bottom: 0;
}
.chinaList li .btnStyle1{
    margin-bottom: 1em;
}
.chinaList li .btnStyle1 a:before{
    right: 1em;
}
/* =========================================================
	index Setting
========================================================= */
/***メインビジュアル***/
#indexContentsHead{
	position:relative;
}
#mainVisualImgSet div{
	background-repeat: no-repeat;
	background-size: cover;
    background-position: center;
	height: 86vh;
	margin: 0;
}
#mainVisualImgSet .mainVisual1{
	background-image: url(../images/index/mainvisual01.jpg);
}
#mainVisualImgSet .mainVisual2{
	background-image: url(../images/index/mainvisual02.jpg);
}
#indexContentsHead .mainCatch{
	width:1100px;
	margin-bottom:0;
	position:absolute;
	top:50%;
	left:50%;
    transform:translateY(-50%) translateX(-50%);
}
#indexContentsHead .mainCatch span{
    background: #0B4030;
    font-size: 16px;
    color: #FFF;
    display: inline-block;
    padding: 0.5em 1em;
    margin-bottom: 1em;
}
#indexContentsHead .mainCatch strong{
    font-size: 32px;
    display: block;
    letter-spacing: 0.1em;
    line-height: 180%;
    color: #FFF;
    text-shadow:2px 2px 2px rgba(0,0,0,0.8);
}


.slick-dots{
	position:absolute;
	bottom: 3em;
	left:50%;
	transform:translateX(-50%);
}
.slick-dots li{
	position: relative;
    display: inline-block;
    width: 10px;
	margin:10px;
    padding: 0;
    cursor: pointer;
}
.slick-dots li button{
    font-size: 0;
    line-height: 0;
    display: block;
    width: 10px;
    height: 10px;
    padding: 5px;
    cursor: pointer;
    outline: none;
	border:1px solid #FFF;
	background:none;
    border-radius: 50%;
}
.slick-dots .slick-active button{
	background: #0B4030;
}






/***contents01***/
.contents01 {
	position:relative;
}
.contents01:before{
	content:"";
	display:block;
	width:62%;
	height: 28vw;
	position:absolute;
	left:0;
	top:0;
	background-color: #FAF6E1;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
	z-index:-1;
}
.contents01 .aboutColumnSet{
	display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 4em;
}
.contents01 .aboutColumnSet .columnImg{
	width:40%;
}
.contents01 .aboutColumnSet .columnImg img{
	max-width:100%;
}
.contents01 .aboutColumnSet .columnText{
	width:48%;
	margin-left:12%;
}
.contents01 .aboutColumnSet .columnText p{
    line-height: 180%;
}
.contents01 .aboutColumnSet .columnText h2{
    font-size: 24px;
	text-align:left;
    letter-spacing: 0.2em;
    line-height: 180%;
	font-weight:bold;
    color: #0B4030;
    position: relative;
}
.contents01 .aboutColumnSet .columnText h2:before{
	content:"";
	display:inline-block;
	width:230px;
	height:230px;
	position:absolute;
	top:0;
    right: 0;
    background-image: url("../images/index/cont01_logo.svg");
    background-size: cover;
    background-repeat: no-repeat;
    transform: translateY(-50%);
	z-index:-1;
}





/***contents02***/
.contents02 .topMenuList{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 4em;
}
.contents02 .topMenuList > li{
    width: 30%;
    margin-left: 5%;
    margin-bottom: 2em;
    display: flex;
    flex-direction: column;
}
.contents02 .topMenuList > li:nth-child(3n+1){
    margin-left: 0;    
}
.contents02 .topMenuList > li h3{
    font-size: 2.0rem;
}
.contents02 .topMenuList > li h3 span{
    background: #EFE2A3;
    font-size: 16px;
    display: inline-block;
    padding: 0 0.5em;
    margin-left: 1em;
}
.contents02 .topMenuList > li .imgOnlyStyle{
    margin-bottom: 0.5em;
}
.contents02 .topMenuList > li p.detail{
    font-size: 13px;
    /*flex-grow: 1;*/
}


.contents02 .topMenuList .priceList  > li{
    margin-bottom: 0.5em;
}
.contents02 .topMenuList .priceList  > li span{
    background: #0B4030;
    color: #FFF;
    border-radius: 4px;
    padding: 0 0.5em;
    font-size: 14px;
    display: inline-block;
    margin-right: 0.5em;
    width: 12em;
    text-align: center;
}



/*.contents02 .topMenuList li .priceA{
    display: flex;
    align-items: center;
}
.contents02 .topMenuList li .priceB dt{
    display: flex;
    flex-wrap: wrap;
}
.contents02 .topMenuList li .priceA dt{
    background: #0B4030;
    color: #FFF;
    border-radius: 4px;
    padding: 0 0.5em;
    font-size: 14px;
    display: inline-block;
    margin-right: 0.5em;
}
.contents02 .topMenuList li .priceA dd{
    font-size: 16px;
    margin-right: 1em;
}
.contents02 .topMenuList li .priceB dt{
    background: #0B4030;
    color: #FFF;
    border-radius: 4px;
    padding: 0 0.5em;
    font-size: 14px;
    display: inline-block;
    margin-right: 0.5em;
    width: 12em;
    text-align: center;
}
.contents02 .topMenuList li .priceB dd{
    font-size: 16px;
    margin-right: 1em;
    display: inline-block;
    margin-bottom: 0.5em;
    width: calc(100% - 12.5em);
}*/

/***contents03***/
.contents03 .ttlStyle1{
    text-align: left;
    margin-bottom: 0.5em;
}
.contents03 .ttlStyle1 span:before{
    content: none;
}
.contents03 .topAccessSet{
    display: flex;
    position: relative;
}
.contents03 .topAccessSet .text{
    width: 70%;
    background: #0B4030;
    padding: 4em 24% 4em 4%;
    color: #FFF;
    min-height: 440px;
}
.contents03 .topAccessSet .text p a{
    color: #FFF;
}
.contents03 .topAccessSet .text .btnStyle1 a{
    background: none;
    color: #FFF;
    border: 1px solid #FFF;
}
.contents03 .topAccessSet .text .btnStyle1 a:before{
    background-image: url("../images/icon_arrow_r_w.svg");
}
.contents03 .topAccessSet .text .btnStyle1 a:hover{
    background: rgb(255,255,255,0.2);
}
.contents03 .topAccessSet .map{
    width: 50%;
    position: absolute;
    top:-10%;
    right: 0;
}
.contents03 .topAccessSet .map iframe{
    width: 100%;
}
/***contents04***/
.contents04 .schoolBanner a{
    padding: 4em 8%;
    display: block;
    background-image: url(../images/index/school_bg.jpg);
	background-size: cover;
	background-position: top center;
    background-repeat: no-repeat;
    color: #333;
    position: relative;
    text-decoration: none;
    transition: all .3s;
}
.contents04 .schoolBanner a:after{
    content: "";
    background-image: url("../images/icon_arrow_circle.svg");
    background-repeat: no-repeat;
    background-size: contain;
    display: inline-block;
    width: 60px;
    height: 60px;
    position: absolute;
    top: 50%;
    right: 4%;
    transform: translateY(-50%);
}
.contents04 .schoolBanner a:hover{
    opacity: 0.7;
}
.contents04 .schoolBanner a h2{
    text-align: left;
}
.contents04 .schoolBanner a .ttlStyle1 span:before{
    margin: 0 0 0 1em;
}
/* footer Setting
=========================================================================================== */
footer{
    color: #FFF;
    text-align: center;
}
footer .ttlStyle1 strong{
    color: #FFF;
}
footer .inner{
    background-image: url(../images/footer_bg.jpg);
    background-size: cover;
    background-position: center right;
    background-attachment: fixed;
}
footer #footerContactArea{
    max-width:1100px;
	padding:6em 0 2em;
	margin:0 auto;
}



.footerContactBtnList{
    display: flex;
    justify-content: center;
}
.footerContactBtnList li{
    width: 38%;
    margin: 0 2%;
    text-align: center;
}

.footerContactBtnList li p{
    margin-bottom: 0.5em;
    font-size: 14px;
}
.footerContactBtnList li a{
    background: #0B4030;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    padding: 1.5em 1em;
    color: #FFF;
    border-radius: 4px;
    text-decoration: none;
    transition: all .3s;
}
.footerContactBtnList li a:hover{
    opacity: 0.7;
}
.footerContactBtnList li.footerTel a:before{
    content: "";
    background-image: url("../images/icon_tel.svg");
	background-size: cover;
	background-repeat: no-repeat;
	display: inline-block;
	width:24px;
	height:24px;
    margin-right: 1em;
}
.footerContactBtnList li.footerLine a:before{
    content: "";
    background-image: url("../images/icon_line.svg");
	background-size: cover;
	background-repeat: no-repeat;
	display: inline-block;
	width:24px;
	height:24px;
    margin-right: 1em;
}


footer #footerArea{
    background: #0B4030;
    padding: 4em 0 1em;
}
footer #footerArea h2{
    margin-bottom: 0;
}
footer #footerArea .footerSnsList{
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 4em;
}
footer #footerArea .footerSnsList li{
    margin: 0 0.5em;
}
footer #copy{
    font-size: 14px;
    margin-bottom: 0;
}

/* After Setting
=========================================================================================== */
.mt0{margin-top:0;}
.ml0{ margin-left:0;}
.mr2{ margin-right:2em;}
.mb0{margin-bottom:0;}
.mb20{margin-bottom:20px;}
.mb40{margin-bottom:40px;}
.mb50{margin-bottom:50px;}
.mb100{margin-bottom:100px;}
.mb3{margin-bottom:3em;}
.mb4{margin-bottom:4em;}
.mb6{margin-bottom:6em;}
.pb0{ padding-bottom:0;}
.pb20{ padding-bottom:20px;}
.pr20{ padding-right:20px;}
.vat{ vertical-align:top;}
.vam{ vertical-align:middle;}