@charset "SJIS";
/* CSS Document */
/*@font-face {
  font-family: 'Rounded';
  font-style: normal;
  font-weight: 100;
  src: url(../fonts/rounded/EL.woff2) format('woff2'),
       url(../fonts/rounded/EL.woff) format('woff'),
       url(../fonts/rounded/EL.ttf) format('truetype');
}
@font-face {
  font-family: 'Rounded';
  font-style: normal;
  font-weight: 400;
  src: url(../fonts/rounded/R.woff2) format('woff2'),
       url(../fonts/rounded/R.woff) format('woff'),
       url(../fonts/rounded/R.ttf) format('truetype');
}
@font-face {
  font-family: 'Rounded';
  font-style: normal;
  font-weight: 900;
  src: url(../fonts/rounded/H.woff2) format('woff2'),
       url(../fonts/rounded/H.woff) format('woff'),
       url(../fonts/rounded/H.ttf) format('truetype');
}*/

@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300;500;700;800&display=swap');


@font-face {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-style: normal;
  font-weight: 100;
  src: url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300;500;700;800&display=swap');
}
@font-face {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-style: normal;
  font-weight: 400;
  src: url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300;500;700;800&display=swap');
}
@font-face {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-style: normal;
  font-weight: 900;
  src: url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300;500;700;800&display=swap');
}

#goTop {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 20px;
  height: 0;
  z-index: 99;
}

#goTop a {
  display: block;
  position: absolute;
  right: 0;
  bottom: 0;
  overflow: hidden;
  width: 60px;
  height: 60px;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 3px;
  text-indent: -999px;
}

#goTop a::after {
  content: '';
  position: absolute;
  left: calc(50% - 15px);
  top: calc(50% - 15px);
  width: 30px;
  height: 30px;
  background: url("../img/icon_arrow_01.png") no-repeat center center;
  background-size: 100% auto;
  transform: rotate(-90deg);
}

#cont{
        margin: 20px 10px 0 10px;
font-family: 'M PLUS Rounded 1c', sans-serif;
}

#cont a {
    transition: 0.5s ;
}

#cont a:hover{
   opacity: 0.7 ;
}

#cont section{
    max-width: 1120px;
    margin: auto;
}
#cont section img{
    width: 100%;
    max-width: 100%;
    height: auto;
}

#content_block a{
    color: #008ccf;
}

#content_block ul.menu_block{
    display: flex;
    flex-direction: row;
	flex-wrap:wrap;
	justify-content: space-between;
    max-width: 950px;
    margin: 40px auto 20px auto;
    padding: 0px;
    position: relative;    
}
#content_block ul.menu_block li{
    width: calc(100% / 3 - 20px);
    margin-bottom: 30px;
    padding: 0px;    
    text-align: left;
    flex-direction: column;
	border: #231815 1px solid;
	line-height: 60px;
	position: relative;
}
#content_block ul.menu_block li a{
	display: block;
	text-align: center;
	font-size: 1.6em;
	font-weight: 600;
	color: #231815;
	text-decoration: none;
}
#content_block ul.menu_block li::before{
	content: "";
	background: url("../img/yajirushi_icon.png") no-repeat;
	width: 40px;
	height: 40px;
	top: 0;
	left: 20px;
	bottom: 0;
	margin: auto;
	position: absolute;
}



#course_block article{
    margin-bottom: 90px;
}

#course_block article h2{
    margin-bottom: 10px;
    background:#4591b2;
    padding: 15px 30px 15px 30px;
    font-size: 1.6em;
    font-weight: 600;
	color: #fff;
	text-align: center;
}

#course_block article .note{
text-align: right;
font-size: 0.85em;
margin: 0 0 30px;
}/*20200221ǉ*/


#course_block article ul.details{
            display: flex;
    flex-direction: row;
	flex-wrap:wrap;
	justify-content:space-between;
    margin: 0 auto 0px auto;
    padding: 0px;
    position: relative;
    text-align: left;
    font-size: 1.1em;
}

#course_block article ul.details li{
    flex-direction: column;
	width: calc(100% / 2 - 65px);
	border: #231815 1px solid;
	border-radius: 3px;
	padding: 20px;
	margin-bottom: 30px;
}

#course_block article ul.details li.recommend{
	width: 100%;
	border: #6C0001 2px solid;
	border-radius: 3px;
	padding: 20px;
	margin-bottom: 30px;
	display: flex;
    flex-direction: row;
	flex-wrap:wrap;
	justify-content:space-between;
background: #fff;
    position: relative;	
}
#course_block article ul.details li.recommend div{
	width:calc(100% / 2 - 20px);

}
#course_block article ul.details li.recommend .area{
	background: #A33200;
	color: #fff;
	font-size: 1em;
	border-radius: 50px;
	padding: 5px 10px;
	margin-bottom: 10px;
	display: table-cell;
}
#course_block article ul.details li.recommend h3 {

    margin-top: 5px;
}
#course_block article ul.details li.recommend::before{
	content: "";
	background: url("../img/like_icon.png") no-repeat;
	left: -10px;
	top: -25px;
	position: absolute;
	width: 90px;
	height: 90px;
}


#course_block article ul.details li figure{
margin: 0 auto 10px auto;
width: 100%;
	height: 350px;
	display: inline-block;
}
#course_block article ul.details li figure img{
	width: 100%;
		max-width: 100%;
	height: 100%;
}
#course_block article ul.details li .area{
	background: #A33200;
	color: #fff;
	font-size: 1em;
display: inline-block;
	border-radius: 50px;
	padding: 5px 10px;
	margin-bottom: 5px;
min-width: 100px;
    /* display: block; */
    text-align: center;	
}
#course_block article ul.details li h3{
	font-size: 1.2em;
	color: #3e3a39;
	font-weight: 600;
	margin-bottom: 5px;
}
#course_block article .details li p{
    font-size: 0.9em;
	color: #3e3a39;
	line-height: 1.4;
	margin-bottom: 10px;
	margin: auto;
min-height: 55px;
}
#course_block article .details li ul.btns{
        display: flex;
    flex-direction: row;
	flex-wrap:wrap;
	justify-content: flex-start;
	margin: 5px auto 15px auto;
    padding: 0px;
    position: relative;
}
#course_block article .details li ul.btns li{
/*width: calc(100% / 3 - 12px); */
    text-align: left;
    flex-direction: column;
    display: flex;
    height: 48px;
    background:  #00447C;
    display: block;
    padding: 0;
    margin: 5px;
    width: auto;
	position: relative;
	border: none!important;
flex-grow: 1;
}

#course_block article .details li ul.btns li a{
	line-height: 48px;
		color: #fff;
text-align: center;
			display: block;
	text-decoration: none;
}

#course_block article .details li ul.btns li a:hover{
	background: #00213F;
}

#course_block article .details li ul.btns li::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 8px;
    right: 0;
    left: 0;
    width: 5px;
    height: 5px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform:rotate(135deg);
    margin: auto;
}






#course_block article .details li ul.btns + p{
	color: #AC0002;
	font-size: 1em;
}

#course_block article .others{
	font-size: 1.4em;
	color: #231815;
	text-align: right;
	font-weight: 600;
	margin-top: 15px;

}
#course_block article .oth_l{
text-align: left;
}
#course_block article .others a {
	color: #231815;
	position: relative;
	padding-right: 30px;
}
#course_block article .others a::after{
	content: "";
	position: absolute;
	right: 0;
}

ul.sub_menu_block{
    display: flex;
    flex-direction: row;
	flex-wrap:wrap;
	justify-content: space-between;
    max-width: 100%;
    margin: 40px auto 20px auto;
    padding: 0px;
    position: relative;    
}
 ul.sub_menu_block li{
    width: calc(100% / 6 - 10px);
    margin-bottom: 0px;
    padding: 0px;    
    text-align: left;
    flex-direction: column;
	border: #231815 1px solid;
	line-height: 40px;
	position: relative;
}
 ul.sub_menu_block li a{
	display: block;
	text-align: center;
	font-size: 1.2em;
	font-weight: 600;
	color: #231815;
	text-decoration: none;
}

ul.sub_menu_block li.over{
	background:  #64002F;
}
ul.sub_menu_block li.over a{
	display: block;
	text-align: center;
	font-size: 1.2em;
	font-weight: 600;
	color: #fff;
	text-decoration: none;
}
ul.sub_menu_block li.over::before{
	content: "";
	background: url("../img/sub_over_yajirushi_icon.png") no-repeat;
	width: 24px;
	height: 24px;
	top: 0;
	left: 10px;
	bottom: 0;
	margin: auto;
	position: absolute;
}

ul.sub_menu_block li::before{
	content: "";
	background: url("../img/sub_yajirushi_icon.png") no-repeat;
	width: 24px;
	height: 24px;
	top: 0;
	left: 10px;
	bottom: 0;
	margin: auto;
	position: absolute;
}

#hok h2,#hok li.over{
	background: #339999!important;
}
#hok .recommend{
	border: #339999 2px solid!important;
}
#hok li{
	border: #339999 1px solid!important;
}
#hok .others a{
	color: #339999!important;
}
.menu_block li:first-child a:hover{
	background:  #339999!important;
	color: #fff!important;
	opacity: 1!important;
}
#toh h2,#toh li.over{
	background: #669966!important;
}
#toh .recommend{
	border: #669966 2px solid!important;
}
#toh li{
	border: #669966 1px solid!important;
}
#toh .others a{
	color: #669966!important;
}
.menu_block li:nth-child(2) a:hover{
	background:  #669966!important;
	color: #fff!important;
	opacity: 1!important;
}
#kat h2,#kat li.over{
	background: #336666!important;
}
#kat .recommend{
	border: #336666 2px solid!important;
}
#kat li{
	border: #336666 1px solid!important;
}
#kat .others a{
	color: #336666!important;
}
.menu_block li:nth-child(3) a:hover{
	background:  #336666!important;
	color: #fff!important;
	opacity: 1!important;
}
#chu h2,#chu li.over{
	background: #996633!important;
}
#chu .recommend{
	border: #996633 2px solid!important;
}
#chu li{
	border: #996633 1px solid!important;
}
#chu .others a{
	color: #996633!important;
}
.menu_block li:nth-child(4) a:hover{
	background:  #996633!important;
	color: #fff!important;
	opacity: 1!important;
}

#west h2,#west li.over{
	background: #663333!important;
}
#west .recommend{
	border: #663333 2px solid!important;
}
#west li{
	border: #663333 1px solid!important;
}
#west .others a{
	color: #663333!important;
}
.menu_block li:nth-child(5) a:hover{
	background:  #663333!important;
	color: #fff!important;
	opacity: 1!important;
}

#kyu h2,#kyu li.over{
	background: #990033!important;
}
#kyu .recommend{
	border: #990033 2px solid!important;
}
#kyu li{
	border: #990033 1px solid!important;
}
#kyu .others a{
	color: #990033!important;
}
.menu_block li:nth-child(6) a:hover{
	background:  #990033!important;
	color: #fff!important;
	opacity: 1!important;
}





#course_block article .details > div h3{
   letter-spacing: 0.1em;
    font-weight: 600;
    text-align: center;
    font-size: 1.2em;
    position: relative;
    border-bottom:  #f1a767 2px solid;
    padding-bottom: 2px;
    margin-bottom: 20px;
}
#course_block article .details > div > div{
    max-width: 100%;
        border: #f1a767 2px solid;
    padding: 20px;
        margin-top: auto;
    background: #fff;
}
#course_block article .details > div > div dl{
margin-bottom: 15px;
}
#course_block article .details > div > div dt{
width: 10.5em;
    float: left;
    margin: 0 0 0.8px 0;
}
#course_block article .details > div > div dt::before{
    content: "";
}
#course_block article .details > div > div dd{
margin: 10px 0 10px 0;
    padding-left: 11em;
    line-height: 1.2em;
}
#course_block article .details > div > div p{
margin-bottom: 0;
    font-size: 0.9em;
    color: #000;
}


#course_block article .details > div + div{
    max-width: 35%;
}
#course_block article .details > div + div figure{
    width: 100%;
    margin: 0 0 30px 0;
}
#course_block article .details > div + div figure img{
    width: 100%;
    max-width: 100%;
    height: auto;
}
#course_block article .details > div + div a.btn_box {
    width:100%;
    font-size:1.4em;
    font-weight:bold;
    text-decoration:none;
    display:block;
    text-align:center;
    padding:8px 0 10px;
    color:#fff;

}
#course_block article .details > div + div a.btn_box span{
        position: relative;
}

#course_block article .details > div + div a.btn_box span::before{
    width: 16px;
    height: 2px;
    background: #A6A6A6;
    position: absolute;
    top: 0;
    bottom: 0;
    right: -25px;
    margin: auto;
    content: "";
    vertical-align: middle;    
}
#course_block article .details > div + div a.btn_box span::after{
    width: 8px;
    height: 8px;
    border-top: 2px solid #A6A6A6;
    border-right: 2px solid #A6A6A6;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 0;
    bottom: 0;
    right: -25px;
    margin: auto;
    content: "";
    vertical-align: middle;    
}


#course_block article .details > div + div a.btn_box {
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#fefefe+0,dbdbdb+50,d1d1d1+50,e2e2e2+100 */
background: #fefefe; /* Old browsers */
background: -moz-linear-gradient(top,  #fefefe 0%, #dbdbdb 50%, #d1d1d1 50%, #e2e2e2 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top,  #fefefe 0%,#dbdbdb 50%,#d1d1d1 50%,#e2e2e2 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom,  #fefefe 0%,#dbdbdb 50%,#d1d1d1 50%,#e2e2e2 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fefefe', endColorstr='#e2e2e2',GradientType=0 ); /* IE6-9 */
color:#A6A6A6;
    border: #A0A0A0 1px solid;
    cursor: default;
}

#course_block article .details > div + div a.on{
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#4b6338+0,4b6338+52,375122+52,375122+100 */
background: #4b6338; /* Old browsers */
background: -moz-linear-gradient(top,  #4b6338 0%, #4b6338 52%, #375122 52%, #375122 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top,  #4b6338 0%,#4b6338 52%,#375122 52%,#375122 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom,  #4b6338 0%,#4b6338 52%,#375122 52%,#375122 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4b6338', endColorstr='#375122',GradientType=0 ); /* IE6-9 */
    color: #fff;
    cursor: pointer;
    
}
#course_block article .details > div + div a.on span::before{
    width: 16px;
    height: 2px;
    background: #fff;
    position: absolute;
    top: 0;
    bottom: 0;
    right: -25px;
    margin: auto;
    content: "";
    vertical-align: middle;    
}
#course_block article .details > div + div a.on span::after{
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 0;
    bottom: 0;
    right: -25px;
    margin: auto;
    content: "";
    vertical-align: middle;    
}


.pc{
    display: block;
}
.sp{
    display: none;
}

@media screen and (max-width: 768px) {    
    .pc{
    display: none;
}
.sp{
    display: block;
}
    #course_block article {
    margin-bottom: 45px;
}

    #cont section{
    max-width: 100%;
}
	#content_block ul.menu_block {
		margin-top: 20px;
	}
#content_block ul.menu_block li{
margin-bottom: 5px;
	line-height: 30px;
	width: calc(100% / 3 - 5px);
}
#content_block ul.menu_block li a{

	font-size: 1em;

}	
#course_block article ul.details li.recommend div{
	width:100%;

}	
	
	#content_block ul.menu_block li::before{
    top: 23px;
    left: 5px;
    bottom: 0;
    background-size: 38%;
	}
	#course_block article ul.details li {
    width: 100%;
}
	#course_block article .others {
    font-size: 1em;

}
	
#course_block article h2 {
    font-size: 1.2em;
	}
	
	
ul.sub_menu_block li {
    width: calc(100% / 3 - 5px);
	margin-bottom: 5px;

}

ul.sub_menu_block li a {
    font-size: 1em;
	}
ul.sub_menu_block li::before,ul.sub_menu_block li.over::before{
    top: 11px;
    left: 5px;
    bottom: 0;
    background-size: 63%;
}
ul.sub_menu_block li.over a {
    font-size: 1em;
}
	#course_block article .details li ul.btns li a {
		font-size: 0.9em;
	}
	
#course_block article .details > div p {
    font-size: 0.9em;

}    
#course_block article .details > div > div {
margin-bottom: 20px;
    padding: 10px;

}    
#course_block article .details > div > div dd span{
    font-size: 0.7em;
    
    }
#course_block article .details > div + div a.btn_box {
    font-size: 1.1em;    
    }
#course_block article .details > div + div a.on {
    font-size: 1.1em;    
    }    
#course_block article .details > div + div figure {
    margin: 0 0 15px 0;
}    
    
    
}
@media screen and (max-width: 480px) {
    .jtb-nav-breadcrumb{
        display: none;
    }
    
    
    #course_block article .details > div {
    max-width: 100%;
    display: block;
}
    #course_block article .details > div + div {
    max-width: 100%;
}
    /*#page_header,#page_footer{display: none;}*/
}

