@charset "utf-8";

@import "base_layout.css";
@import "common_parts.css";

.bn-special{
	text-align: center;
	padding: 20px 0;
}
.bn-special img{
	max-width: 100%;
	height: auto;
	margin: 0 0 0 0;
	padding: 0 0 0 0;
}

@media screen and (max-width: 768px) {
	.bn-special img{
		width: 100%;
		height: auto;
		display: block;
	}
}


/*#top_eyecatch
************************************************************************************/
#top_eyecatch:before {
	content:"";
	display: block;
	padding-top: 50%;
}

#slideshow{
	position: relative;
	width: 100%;
	z-index: 10;
	overflow: hidden;
	text-align: center;
}
#slideshow:before {
	content:"";
	display: block;
	padding-top: 51%;
}

#slideshow img{
	height: 100%;
	width: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
	margin: auto;
	z-index:8;
}
#slideshow img.active { z-index:10; }
#slideshow img.last-active { z-index:9; }
@media screen and (max-width: 979px) {
#top_eyecatch .mainphoto img{
	opacity: inherit;
}
}
@media screen and (max-width: 979px) {
#top_eyecatch{
	background: #cfeef0;
	padding: 80px 0;
}
#slideshow{
	margin-top: 70px;
}
}
@media screen and (max-width: 768px){
#top_eyecatch{
	position: relative;
}
#top_eyecatch:before {
	content:"";
	display: block;
	padding-top: 50%;
}
#top_eyecatch .mainphoto{
	display: block;
}
#header{
	height: 130px;
	position: absolute;
}
}

/*#news
************************************************************************************/
#news{
	background: #f5f5f5;
	padding: 0 0 10px 0;
	margin-top: 0;
	position: relative;
	z-index: 10;
}
#news:before{
	content: "";
	display: block;
	width: 100%;
	height: 100px;
	background: url("../../img/toppage/photo_mask.svg") no-repeat;
	-moz-background-size: 100% auto;
	-webkit-background-size: 100% auto;
	background-size: 100% auto;
	position: absolute;
	top: -100px;
	left: 0;
	z-index: 20;
}
#news .title_box{
	text-align: center;
}
#news .title_box .eng{
	font-size: 16px;
	color: #008dd8;
	font-weight: 500;
	display: inline-block;
	padding: 10px 1em 0 1em;
	border-top: 3px solid #008dd8;
}
#news .title_box h1{
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	margin: 5px 0 1.5em 0;
}

#news ul.list{
	border-top: 1px solid #e8e8e8;
}

#news ul.list li{
	display: table;
	width: 100%;
	border-bottom: 1px solid #e8e8e8;
	padding: 15px 0;
}
#news ul.list li .date{
	font-weight: 400;
	color: #3071b8;
	display: table-cell;
	vertical-align: top;
	width: 8em;
	padding-right: 1em;
}
#news ul.list li .cate{
	font-weight: 400;
	display: table-cell;
	vertical-align: top;
	width: 8em;
	padding-right: 1em;
}
#news ul.list li .cate span{
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	padding: 3px 10px;
	display: inline-block;
	font-size: 12px;
	width: 6em;
	color: #FFF;
	text-align: center;
}
#news ul.list li .cate span.topics{
	background: #0f89c1;
}
#news ul.list li .cate span.column{
	background: #0fc191;
}
#news ul.list li .ttl{
	display: table-cell;
	vertical-align: middle;
}
#news .btn_moreview{
	margin: 50px auto;
	width: 190px;
}
#news .btn_moreview a{
	padding: 0 60px 0 20px;
	display: block;
	text-decoration: none;
	color: #000;
	text-align: center;
	line-height: .9em;
}
#news .btn_moreview a{
  display: block;
	background: url(../../img/common/ar_more_long.png) no-repeat right 15px bottom;
}
@media screen and (min-width: 980px) {
#news .btn_moreview a{
  -webkit-transition: 0.3s ease-in-out;
     -moz-transition: 0.3s ease-in-out;
       -o-transition: 0.3s ease-in-out;
          transition: 0.3s ease-in-out;
}
#news .btn_moreview a:hover {
  background-position: right 0 bottom;
}
}

@media screen and (max-width: 979px) {
#news ul.list li{
	padding: 15px 10px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
}
@media screen and (max-width: 620px) {
#news ul.list li{
	display: block;
}
#news ul.list li .date{
	display: block;
	width: auto;
	padding: 0 0 5px 0;
}
#news ul.list li .cate{
	display: block;
	width: auto;
	padding: 0 0 5px 0;
}
#news ul.list li .ttl{
	display: block;
}
}


#news ul#tab li{
	border: 3px solid #0085cc;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
	display:  inline-block;
	margin: 0 0 0 15px;
	background: #0085cc;
	color: #FFF;
}
#news ul#tab li span{
	padding: 15px 3em;
	cursor: pointer;
	display:  block;
}
#news ul#tab li.select{
	background: #FFF;
	color: #000;
}
#news .disnon{
  display: none;
}
#news .content_wrap{
	border-top: 3px solid #0085cc;
	margin-top: -3px;
}

@media screen and (max-width: 979px) {
#news ul#tab li{
	font-size: 16px;
}
#news ul#tab li span{
	padding: 15px 1em;
}
#news .content_wrap ul.list{
	width: 95%;
	margin: auto;
}
}
@media screen and (max-width: 620px) {
#news ul#tab li{
	font-size: 14px;
	margin: 0 0 0 5px;
}
#news ul#tab li span{
	padding: 15px .5em;
}
}



/*patient
************************************************************************************/
#patient{
	background: url("../../img/toppage/patient_bg.jpg") no-repeat right;
	-moz-background-size: auto 100%;
	-webkit-background-size: auto 100%;
	background-size: auto 100%;
	padding: 100px 0;
}
#patient .title-wrap{
	display: table;
	margin: 0 0 1.5em 0;
}
#patient h1{
	display: table-cell;
	vertical-align: top;
	font-size: 38px;
	font-weight: 500;
	padding-right: 50px;
}
#patient h1 a{
color: #000;
text-decoration: none;
}

#patient .title-wrap .btn_more{
	display: table-cell;
	vertical-align: middle;
	font-weight: 400;
}

ul.box_btn{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-justify-content: left;
	justify-content: left;
	width: 800px;
}

ul.box_btn li{
	margin: 0.5%;
	width: 49%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	background: #FFF;
}


ul.box_btn li a{
	flex: 1 1 auto;
	padding: 20px 30px 20px 20px;
	border: 2px solid #000000;
	text-transform: uppercase;
	position: relative;
	overflow:hidden;
	transition: .3s;
	z-index: 100;
	font-size: 18px;
	font-weight: 500;
	color: #000;
	display:  block;
	text-decoration: none;
}
ul.box_btn li a:before{
	content: "";
	background: url("../../img/common/ar_menu_bk.svg") no-repeat right center;
	display: block;
	position: absolute;
	right: 15px;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 10;
	width: 30px;
	height: 30px;
}

@media screen and (min-width: 980px) {
ul.box_btn li a:after{
	position: absolute;
	transition: .3s;
	content: '';
	width: 0;
	left: 50%;
	bottom: 0;
	height: 3px;
	background: #f2f9f9;
}
ul.box_btn li a:after{
	height: 120%;
	left: -10%;
	transform: skewX(15deg);
	z-index: -1;
}
ul.box_btn li a:hover{
	cursor: pointer;
}
ul.box_btn li a:hover:after{
	width: 100%;
	left: 0;
	color: #5bcaff;
}
ul.box_btn li a:hover:after{
	left: -10%;
	width: 120%;
}
}


@media screen and (max-width: 979px) {
#patient .title-wrap{
	display: table;
	margin: 0 0 1.5em 0;
}
#patient h1{
	display: table-cell;
	vertical-align: top;
	font-size: 38px;
	font-weight: 500;
	padding-right: 50px;
}
#patient h1 a{
color: #000;
text-decoration: none;
}

#patient .title-wrap .btn_more{
	display: table-cell;
	vertical-align: middle;
	font-weight: 400;
}

ul.box_btn{
	width: 95%;
	margin: auto;
}
}
@media screen and (max-width: 768px){
#patient{
	background: url("../../img/toppage/patient_bg.jpg") no-repeat right;
	-moz-background-size: auto 100%;
	-webkit-background-size: auto 100%;
	background-size: auto 100%;
	background-color: rgba(255,255,255,0.5);
	background-blend-mode: lighten;
}

#patient h1{
	font-size: 28px;
	padding-left: 0.5em;
}
ul.box_btn li a{
	font-size: 14px;
}
}
@media screen and (max-width: 620px) {
#patient h1{
	font-size: 21px;
}
ul.box_btn li{
	margin: 0.5% 1%;
	width: 98%;
}
}

/*
************************************************************************************/
#class{
	background: #f2f9f9;
	padding: 70px 0;
}

#class ul{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-justify-content: left;
	justify-content: left;
	width: 100%;
}
#class ul li{
	display: block;
	width: 13%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	background: #FFF;
}
#class ul li.title{
	width: 22%;
	padding: 0 1em;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	background: none;
}
#class ul li.title:before{
	color: #d9eaea;
	font-size: 52px;
	font-weight: 500;
	content: "About Our Class";
	line-height: 1.0;
}
#class ul li.title h1{
	font-size: 33px;
	font-weight: 500;
	margin: -1.0em 0 .5em 0;
}
#class ul li.title .btn a{
	color: #FFF;
	display: block;
	border-radius: 2em;
	-webkit-border-radius: 2em;
	-moz-border-radius: 2em;
	background: url("../../img/common/ar_menu_yellow.svg") no-repeat right 30px center #0085cc;
	padding: 15px 30px;
	text-decoration: none;
}

#class ul li .photo{
	width: 100%;
	overflow: hidden;
	position: relative;
}
#class ul li .photo:before {
	content:"";
	display: block;
	padding-top: 60%;
}
#class ul li .photo img{
	width: 100%;
	height: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
	margin: auto;
}
#class ul li .menutitle{
	margin: 8px 0;
	border-right: 1px solid #ededed;
	font-size: 16px;
	font-weight: 500;
}
#class ul li .menutitle a{
	color: #000;
	text-decoration: none;
	background: url("../../img/common/ar_menu_blue.svg") no-repeat right 15px center;
	display:  block;
	padding: 0.5em 1.5em;
}


@media screen and (min-width: 980px) {
#class ul li .photo img{
	transition-duration: 0.3s;
}
#class ul li:hover .photo img{
	-webkit-transform: scale(1.2);
	transform: scale(1.2);
	transition-duration: 0.3s;
}
}
@media screen and (max-width: 979px) {
#class ul li{
	width: 33%;
	margin-bottom: 15px;
}
#class ul li.title:before{
	display: none;
}
#class ul li.title{
	width: 100%;
	padding: 0 1em;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	background: none;
}
#class ul li.title h1{
	font-size: 28px;
	margin: 0 0 5px 0;
	display: inline-block;
	vertical-align: middle;
}
#class ul li.title .btn{
	display: inline-block;
	vertical-align: middle;
	margin-left: .5em;
}
#class ul li.title .btn a{
	padding: 10px 50px 10px 20px;
}
}
@media screen and (max-width: 768px){
#class ul li .menutitle{
	font-size: 14px;
}
}

@media screen and (max-width: 620px) {
#class{
	padding: 50px 0;
}

#class ul li.title h1{
	font-size: 21px;
}
}
@media screen and (max-width: 480px){
#class ul li{
	display: table;
	width: 98%;
	margin: auto;
	border-bottom: 1px solid #ededed;
}
#class ul li.title{
	padding-bottom: .7em;
}
#class ul li .photo{
	width: 30%;
	overflow: auto;
	position: static;
	display: table-cell;
	font-size: 0;
	margin: 0;
}
#class ul li .photo:before {
	display: none;
}
#class ul li .photo img{
	width: 100%;
	height: auto;
    position: static;
}
#class ul li .menutitle{
	display: table-cell;
	vertical-align: middle;
	margin: 0;
	border-right: 0;
}
#class ul li .menutitle a{
	color: #000;
	text-decoration: none;
	background: url("../../img/common/ar_menu_blue.svg") no-repeat right 15px center;
	display:  block;
	padding: 0.5em 1.5em;
}
#class ul li.title .btn{
	font-size: 14px;
}
}

/*info
************************************************************************************/
#info{
	background: url("../../img/toppage/info_bg.jpg") no-repeat right;
	-moz-background-size: auto 100%;
	-webkit-background-size: auto 100%;
	background-size: auto 100%;
	padding: 100px 0;
}
#info h1 a{
color: #000;
text-decoration: none;
}

#info .title-wrap{
	display: table;
	margin: 0 0 1.5em 0;
}
#info h1{
	display: table-cell;
	vertical-align: top;
	font-size: 38px;
	font-weight: 500;
	padding-right: 50px;
}
#info h1 span{
	font-size: 30px;
	display: block;
}
#info .title-wrap .btn_more{
	display: table-cell;
	vertical-align: middle;
	font-weight: 400;
}
#info .title-wrap .btn_more span{
	display: inline-block;
	padding: 5px 0 5px 20px;
	background-color: rgba( 255, 255, 255, 0.75 );
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
}

@media screen and (max-width: 979px) {
#info .title-wrap{
	display: table;
	margin: 0 0 1.5em 0;
}
#info h1{
	display: table-cell;
	vertical-align: top;
	font-size: 38px;
	font-weight: 500;
	padding-right: 50px;
}
#info h1 span{
	font-size: 25px;
	text-shadow: 1px 1px 3px #FFF;
}
#info h1 a{
color: #000;
text-decoration: none;
}

#info .title-wrap .btn_more{
	display: table-cell;
	vertical-align: middle;
	font-weight: 400;
}
}
@media screen and (max-width: 768px){
#info{
	background: url("../../img/toppage/info_bg.jpg") no-repeat right;
	-moz-background-size: auto 100%;
	-webkit-background-size: auto 100%;
	background-size: auto 100%;
	background-color: rgba(255,255,255,0.5);
	background-blend-mode: lighten;
}
#info h1{
	font-size: 28px;
	padding-left: 0.5em;
}
#info h1 span{
	font-size: 20px;
}
}
@media screen and (max-width: 620px) {
#info h1{
	font-size: 21px;
	display: block;
}
#info h1 span{
	font-size: 17px;
}
#info .title-wrap .btn_more{
	display: block;
}
}



/*column
************************************************************************************/
#column{
	background:#0085cc;
	padding: 50px 0;
    text-align:  center;
}
#column h1 a{
    color: #FFF;
    text-decoration: none;
    padding: 0 70px 0 0;
	background: url("../../img/common/ar_menu_yellow.svg") no-repeat right  center;
	font-size: 36px;
	font-weight: 400;
}

