@charset "UTF-8";

/* 
html5doctor.com Reset Stylesheet v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
*/

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
html, body {
	width: 100%;
	height: 100%;
}
body {
	line-height: 1;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}
ul, li {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}
a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	color: #949886;
	text-decoration: none;
}
a:hover {
	color: #FF9FA2;
}
/* change colours to suit your needs */

ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}
/* change colours to suit your needs */

mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}
del {
	text-decoration: line-through;
}
abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
th {
	font-weight: normal;
}
li img, dt img, dd img {
	vertical-align: bottom;
}
/* change border colour to suit your needs */

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}
input, select {
	vertical-align: middle;
}

em{
	font-style: normal;
}

/* module --------------------------------*/
#openBlock{
display:none;
}

p.tLink a {
    border-bottom: 1px solid #808080;
    padding-bottom: 3px;
}

.clearfix:after {
    content: "";
    display: block;
    clear: both;
}

.txtLink{
	text-align: right;
	margin-bottom: 20px;
	background: url(/assets/img/common/link-arrow.png) no-repeat center left;
	display: inline-block;
}

.align-r{
	text-align: right;
}
.align-c{
	text-align: center;
}
.margin-t10{
	margin-top: 10px;
}
.margin-t-20{
	margin-top: -20px;
}
.margin-b0{
	margin-bottom: 0px!important;
}
.margin-b10{
	margin-bottom: 10px;
}

.margin-b20{
	margin-bottom: 20px!important;
}
.margin-b30{
	margin-bottom: 30px;
}
.margin-b50{
	margin-bottom: 50px;
}
.margin-b1em{
	margin-bottom: 1em!important;
}

.padding-b0{
    padding-bottom: 0!important; 
}

.txtLink a{
	color:#FF3366;
	padding-bottom: 5px;
	margin-left: 20px;
	border-bottom: 2px solid #FF3366;
	
}

.f_left {
	float: left;
}
.f_right{
	float: right;
}

dd em.big{
font-size: 1.45rem;
}

.bgPink{
	background-color: #FFE7FF!important;
}

.c-red{
	color: #FF3366;
}

/* gnav setting --------------------------------*/

.slicknav_menu {
 display:none;/*PC時は非表示*/
}
@media screen and (max-width: 960px) {
 #gnav {
 display:none;/*モバイル時は非表示*/
}
 .slicknav_menu {
 display:block;/*モバイル時は表示*/}
}
/*ハンバーガーメニューのエフェクト*/
.slicknav_icon,
.slicknav_icon span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
}
.slicknav_icon {
    position: relative;
    width: 50px;
    height: 44px;
}
.slicknav_menu .slicknav_icon-bar{
    position: absolute;
    left: 0;
}
.slicknav_icon span:nth-of-type(1) {
    top: 0;
}
.slicknav_icon span:nth-of-type(2) {
    top: 3px;
}
.slicknav_icon span:nth-of-type(3) {
    bottom: 0;
}
.slicknav_menu .active.slicknav_btn{
	background-color: #1B30E6;
}
.active .slicknav_icon-bar:nth-of-type(1) {
    -webkit-transform: translateY(6px) rotate(-45deg);
    transform: translateY(6px) rotate(-45deg);
	background-color: #fff;
}
.active .slicknav_icon-bar:nth-of-type(2) {
    opacity: 0;
}
.active .slicknav_icon-bar:nth-of-type(3) {
    -webkit-transform: translateY(-6px) rotate(45deg);
    transform: translateY(-6px) rotate(45deg);
		background-color: #fff;
}
.menu4_prepend{
position: absolute;
	top:0;
	right: 0;
width: 100%;

}



/* layout setting --------------------------------*/
html{
		font-size:62.5%; 
}


body{
            font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	color: #505050;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
}
.pc-on{
		display: none;
	}

img
{max-width: 100%;
height: auto;}

.btn-detail{
display: none;
}


.snsIconList{
	display:flex;
	position: absolute;
	top:45px;
	right: 150px;
	width: 50px;
	height: 20px;
	justify-content: space-between;
}
.snsIcon img{
	width: 20px;
}

#footersitemap-bg{
	display: none;
}
footer{
	color: #fff;
	background-color: #727260;
	padding: 20px 10px 45px;
	text-align: center;
	font-size: 1.0rem;
	line-height: 1.8;
}
footer p{
	margin-bottom: 5px;
}
.footerLogo{
	width: 150px;
	margin: 0 auto 18px;
}
.footerCopy{
	font-size: 1.1rem;
margin-bottom: 25px;}


header{
		display: table;
	width: 100%;
	position: relative;
}

header h1{
	background-color: #fff;
	width:100px;
	height: 86px;
	text-align: center;
vertical-align: middle;
display: table-cell;
	padding: 10px 10px 0px;
	margin-right: 15px;
}

header h1 img{
	width: 91px;
}
header nav{	
	display: none;
}

.btn-menu img{
	width: 25px;
}

.headerContents{
	position: relative;
	box-sizing: border-box;
	display: table-cell;
	height: 64px;
	float: right;
		z-index: 5;
}

.actionButtons{
	position: absolute;
	width: 64px;
	height: 64px;
	display: table;
	top:0;
	right: 64px;

}
 .actionButtons li{
	display: table-cell;
		text-align: center;
	 vertical-align: middle;
	 	width: 64px;
	height: 64px;
}
 .actionButtons li a{
	 text-decoration: none;
	 	color: #fff;
	 font-size: 1.2rem;
}
.actionButtons .btn-order{
	background-color: #006dff;
}
.actionButtons .btn-kengaku{
	background-color: #ff3366;
}
.actionButtons .btn-contact{
	background-color: #505050;
}

.actionButtons li.pc-on{
		display: none;
	}


.actionBox ul{
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	display: table;
		width:100%;
		margin: 0 auto;
	z-index: 5;
}
.actionBox li{
	display: table-cell;
    width: 50%;
}

.actionBox li.order a {
	border: none!important;
    background-color: #006dff;
    color: #FFF;
display: block;
    padding: 20px 5px;
    text-align: center;
}
.actionBox li.kengaku a {
	border: none!important;
    background-color:#ff3366;
    color: #FFF;
display: block;
    padding: 20px 5px;
    height: 100%;
        text-align: center;
}

.box{
	margin: 0 18px;
	position: relative;
}

.courseTitle {
	padding: 20px 0;
	text-align: center;
	background: linear-gradient(to right, #ff7760, #c86999);
	margin-top: 30px;
}
	.courseTitle p {
	margin: 0 auto;
	font-size:1.5rem;
	color: #fff;
	line-height: 1.7;
	letter-spacing: 0.1em;
	padding: 0 10px;

	}
	
.courseTitle p span{
color: #FFFFB6;
	font-weight: bold;
	}

.courseTitle img { width: 90%; }

.courseArrow {
	width: 30px;
	margin: 0 auto 30px;
}
.courseDetail { 
	background-color: #eeeeea; 
padding:0 18px 20px; }

.btn-pagetop{
	position: fixed;
	width: 33px;
	height: 33px;
	bottom: 60px;
	right: 2px;	
}
.courseDetail section h3,
.profile section h3,
.page section h3{
	border-bottom: 1px solid #505050;
	padding-bottom: 10px;
	color: #505050;
	font-size: 1.4rem;
	font-weight: 600;
	margin-bottom: 15px;
}

.schedule table {
	border-top: 1px solid #505050;
	border-bottom: 1px solid #505050;
	margin-bottom: 10px;
	width: 100%;
}
.schedule table th {
	border-bottom: 1px dashed #505050;
	border-right: 1px solid #505050;
	border-left: 1px solid #505050;
	padding: 5px 3px;
	font-size: 1.2rem;
	background: #eeeeea;
	vertical-align: middle;
}
.schedule table tr th.solidBd{
		border-bottom: 1px solid #505050;
	vertical-align: middle
	
}
.schedule table .va_m{
	vertical-align: middle
	
}
.schedule table .date{

	text-align: center;
}
.schedule table.dateC td:nth-child(2) {
text-align: center;
    }
.schedule table th span{
	font-weight: normal;
}
.schedule table td {
	border-bottom: 1px dashed #505050;
	border-right: 1px solid #505050;
	border-left: 1px solid #505050;
	background-color:#fff;
	padding: 5px;
	font-size: 1.1rem;
	vertical-align: middle;
	line-height: 1.6;
}
.schedule table.dateCenter td {
	text-align: center;
}
.tagawajuku .schedule table td {
text-align: center;
}

.schedule table tr:last-child td{
border-bottom:none;	
}
.schedule table th.courseName{
	border-bottom: 1px solid #505050;
	background-color:#DADAD1;
	padding: 5px;
	font-size:3.1vw;
	line-height: 1.4;
}
.page section p {
    line-height: 2.0;
    font-size: 1.2rem;
    letter-spacing: 0.07em;
    color: #505050;
	margin-bottom: 30px;
}

.page article h1{
	font-size: 1.8rem;
margin-bottom: 20px;
}



/*////////////////////////////////////////////////////////
PC setting 
//////////////////////////////////////////////////////// */

@media screen and (min-width: 960px){
.courseDetail { 
	background-color: #eeeeea; 
padding:0 18px 50px; }

.btn-detail{
	display: block;
	width: 70px;
	height: 196px;
	bottom: 90px;
	right: 0;
	position: fixed;
}

	
header h1{
	background-color: #fff;
	width:30%;
	text-align: center;
vertical-align: middle;
display: table-cell;
	padding: 10px 10px 0px;
	margin-right: 15px;
}
	
header h1 img{
	width: 150px;

}
	
.txtLink{
	text-align: right;
	margin-bottom: 20px;
	background: url(/assets/img/common/link-arrow.png) no-repeat center left;
	display: inline-block;
}
	
.sp-on{
		display:none;
	}
.pc-on{
		display: block;
	}
.left_pc{
	float: left;	
}
.right_pc{
	float: right;	
}
	

.box{
	width: 790px;
	margin: 0 auto;
}	

    .hover a{
        transition: 0.3s;
    }
    .hover a:hover{
        opacity: 0.8;     
    }
    
    
    
    
header{
	display: inherit;
	width: 1000px;
	margin: 0 auto;
}

	
header h1{
	width: 193px;
	text-align: center;
	padding: 48px 0 0;
	height: 85px;
	float: left;
	display: block;
}
 .actionButtons li a{
	 font-size: 1.3rem;
}	
header nav{	
	z-index: 30;
	display: block;
	position: absolute;
	bottom: 17px;
	right: 0;
	z-index: 10;
	}
	
header nav>ul{
	display: table;
	table-layout: fixed;
	width: 792px;
	height: 17px;
}
header nav>ul>li{
	display: table-cell;
		font-size: 1.1rem;
	text-align: center;
	position: relative;
}

header nav>ul>li:not(:last-child) {
	border-right: 1px solid #949886;
}
header nav li a{
	color: #000;
	letter-spacing: 0.2em;
	    display: inline-block;
	position: relative;
}


header nav>ul>li>a>i{
display: none!important;
}

		
	
  header nav li.menu01>a:hover::after,
	 .home header nav li.menu01 a::after {
    left: -45px;
	content: '';
    position: absolute;
    bottom: -23px;
    display: inline-block;
    background: url(../img/common/active.png);
    width: 132px;
    height: 8px;
    background-size: 132px 8px;
	z-index: 30;
  }

	
  header nav li.menu02>a:hover::after,
	.course header nav li.menu02>a::after{
    left: -45px;
	  	content: '';
    position: absolute;
    bottom: -23px;
    display: inline-block;
    background: url(../img/common/active.png);
    width: 132px;
    height: 8px;
    background-size: 132px 8px;
	  
  }
  header nav li.menu03>a:hover::after,
	.profile header nav li.menu03 a::after{
    left: -40px;
	  	content: '';
    position: absolute;
    bottom: -23px;
    display: inline-block;
    background: url(../img/common/active.png);
    width: 132px;
    height: 8px;
    background-size: 132px 8px;
	  
  }
	  header nav li.menu04 a:hover::after,
	.gallery header nav li.menu04 a::after{
    left: -33px;
		  	content: '';
    position: absolute;
    bottom: -23px;
    display: inline-block;
    background: url(../img/common/active.png);
    width: 132px;
    height: 8px;
    background-size: 132px 8px;
	  
  }
	
	  header nav li.menu05 a:hover::after,
	.category header nav li.menu05 a::after,
	.post-type-archive-blog header nav li.menu05 a::after,
		.single-blog header nav li.menu05 a::after{
    left: -45px;
		  	content: '';
    position: absolute;
    bottom: -23px;
    display: inline-block;
    background: url(../img/common/active.png);
    width: 132px;
    height: 8px;
    background-size: 132px 8px;
	  
  }
	  header nav li.menu06 a:hover::after,
	.access header nav li.menu06 a::after{
    left: -39px;
		  	content: '';
    position: absolute;
    bottom: -23px;
    display: inline-block;
    background: url(../img/common/active.png);
    width: 132px;
    height: 8px;
    background-size: 132px 8px;
	  
  }
		
	
nav li ul.sub_menu{
	width: 132px;
  display: none;
  position: absolute;
  top:10px;
  left:0;
	padding-top: 25px;
background-color: #fff;
}
nav li ul.sub_menu::before {
top:16px;
    left: 0px;
		  	content: '';
    position: absolute;
    display: inline-block;
    background: url(../img/common/active.png);
    width: 132px;
    height: 8px;
    background-size: 132px 8px;
}
	
	
	
nav>ul>li:hover ul.sub_menu,
	nav>ul>li ul:hover.sub_menu{
  display: block;

	}

ul.sub_menu li>a{
	text-align: left;
	font-size: 1.1rem;
box-sizing: border-box;
	color: #505050;
	width:132px;
	padding: 13px 10px 0;
		height: 39px;
	}
		
/*ul.sub_menu li a:before{
	font-family: "Font Awesome 5 Free";
	content: "\f105";
	padding-right: 5px;
		
}*/

ul.sub_menu li>a:hover{
		background-color: #006DFF;
	color: #fff;
	}
	
	ul.sub_menu li i{
		margin-right: 5px;
	}

	
.headerContents{
	background-color: #fff;
	width: 792px;
	float: right;
	padding:27px 0 16px;
	height: 133px;
	display:block;
box-sizing: border-box;
	
}
	
	.actionButtons{
	width: 192px;
	right: 0;

}
.btn-pagetop{
	position: fixed;
	width: 56px;
	height: 56px;
	bottom: 0px;
	right: 7px;	
}
	
	.actionBox ul{
	position:inherit;
	display: table;
	width:710px;;
	margin: 0 auto 40px;
}
.actionBox li{
	display: table-cell;
	padding: 15px;
}
	
.courseDetail section h3,
.profile section h3{
	font-size: 1.8rem;
}
	.schedule table {
	margin-left: 0px;
}
.schedule table th {
	padding:  14px;
	vertical-align:middle;

}
.schedule table td {
	padding: 14px;
	font-size: 1.26rem;
}
	
.schedule table th.courseName{
	padding: 20px 5px;
	line-height: 1.7;
	font-size: 1.2rem;
}
.schedule table th.year{
white-space: nowrap;
	min-width:inherit;
}
.schedule table .date{
	width: 80px;
	text-align: center;
}
	dd em.big{
font-size: 1.55rem;
}
		.courseTitle p {

	font-size:2.2rem;
	
	line-height: 1.7;

	}
#footerSitemap {
	width: 890px;
	color: #FFF;
	border-right: 5px solid #FFF;
	border-left: 5px solid #FFF;
	padding: 30px;
	overflow: hidden;
	margin: auto;
}
#footersitemap-bg {
	display: block;
	background: #969687;
	padding-top: 45px;
	padding-bottom: 45px;
}
#footerSitemap ul.first {
	padding-right: 15px;
	border-right: 1px dotted #FFF!important;
	color: #FFF;
	width: 125px;
	float: left;
}
#footerSitemap ul.second {
	padding-right: 30px;
	border-right: 1px dotted #FFF!important;
	color: #FFF;
	width: 500px;
	float: left;
	padding-left: 30px;
}
#footerSitemap a {
	color: #FFF;
	text-decoration: none;
}
#footerSitemap a:hover {
	color: #FF9FA2;
	text-decoration: underline;
}
#footerSitemap ul.first li a, #footerSitemap ul.second li a {
	line-height: 2.0em;
	background: url(/img/common/footer-ls1.png) no-repeat left center;
	padding-left: 20px;
	display: block;
}
#footerSitemap ul.second li li a {
	line-height: 2em;
	background: url(/img/common/footer-ls2.png) no-repeat left center;
	padding-left: 15px;
	font-size: 80%;
	margin-left: 5px;
}
#footerSitemap ul.second dd a {
	line-height: 2em;
	background: url(/img/common/footer-ls2.png) no-repeat left 4px;
	padding-left: 15px;
	font-size: 80%;
}
#footerSitemap .second dl {
	width: 180px;
	float: left;
}
#footerSitemap .second dl.last {
	width: 140px;
	float: left;
}
#footerSitemap .second dt {
	font-size: 80%;
	line-height: 2.0em;
}
#footerSitemap .third {
	width: 150px;
	float: left;
	padding-left: 30px;
}
#footerSitemap .third a {
	line-height: 2em;
	background: url(/img/common/footer-ls2.png) no-repeat left center;
	padding-left: 15px;
	font-size: 80%;
	display: block;
}
.page article h1{
	font-size: 2.2rem;
	width: 790px;
	margin: 50px auto 30px;
}
.actionButtons li.pc-on{
		display: table-cell;
	}


.snsIconList{
	top:45px;
	right: 205px;



}
	
/* PC end */	
	}
/* PC end */	


header p{
width: 460px;
	margin-left: 25px;
            font-size: 10px;
          	font-family: 'Oswald'; 
    line-height: 1.7;
}



.lineBox{
    border: 1px solid #333;
    padding: 2px 3px;
    margin-right: 5px;
}

.tableLine{
      background-image: linear-gradient(to top left,
  transparent, transparent 49%,
     #ccc 49%,
     #ccc 51%, 
    transparent 51%, transparent);
}

.bruby{
    font-size: 90%;
}

