@charset "utf-8";
@import "reset.css";

/* Base Style
================================================== */
body {
	background-color: #fff;
	color: #575757;
	font-size: 100%;
	font-family: -apple-system, blinkMacSystemFont, /* Macの欧文はSan Francisco (OS X 10.11以降) */ 'Helvetica Neue', /* Macの欧文 (OS X 10.10以前) */ 'Segoe UI', /* Windowsの欧文 */ YuGothicM, /* Windows8.1以上は游ゴシック */ YuGothic, /* Macの游ゴシック */ Meiryo, /* 游ゴシックが入っていないWindows */ sans-serif;
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
}

::selection {
	background: #63CEC8;
	color: white;
}

a {}

a:link {
	color: #575757;
}

a:visited {
	color: #575757;
}

a:hover,
a:focus {
	color: #63CEC8;
	transition: 0.6s;
	text-decoration: underline;
}

/*
a[href*="http"]::after {
	content: url(../img/face.png);
	display: inline-block;
	width: 15px;
	height: 15px;
	background-image: url(../images/link.png);
	margin-left: 5px;
	vertical-align: middle;
}
*/
.clr {
	clear: both;
	min-height: 1em;
}

*html .clr {
	height: 1px;
}

.clr:after {
	display: block;
	height: 1px;
	content: "";
	clear: both;
}

input,
select,
textarea {
	color: #000;
	font-family: inherit;
	font-size: 100%;
}

.new {
	margin-left: 0;
	padding-top: 3px;
	padding-right: 10px;
	padding-left: 10px;
	padding-bottom: 2px;
	border-radius: 2px;
	color: #ffffff;
	font-size: 80%;
	font-weight: bold;
	text-transform: uppercase;
	background-color: #63CEC8;
}

/**/
#page-top {
	position: fixed;
	bottom: 30px;
	right: 10px;
}

#page-top img {
	width: 50px;
}

#page-top a {
	text-decoration: none;
	width: 50px;
	display: block;
	opacity: 1;
}

#page-top a:hover {
	text-decoration: none;
}

img {
	max-width: 100%;
}

.clr {
	clear: both;
	min-height: 1em;
}

*html .clr {
	height: 1px;
}

.clr:after {
	display: block;
	height: 1px;
	content: "";
	clear: both;
}

.tbl-cnt {
	width: 600px;
	margin-right: auto;
	margin-left: auto;
}

.tbl-cnt th {
	font-size: 160%;
	color: #96682E;
	text-align: center;
	margin-bottom: 30px;
	font-weight: lighter;
	padding-bottom: 30px;
}

.tbl-cnt td {}

/* Clearfix
================================================== */
.inner:after,
header:after,
footer:after,
nav ul:after,
section:after,
article:after,
aside:after,
.clearfix:after {
	visibility: hidden;
	display: block;
	content: " ";
	clear: both;
	height: 0;
}

.inner,
header,
footer,
nav ul,
section,
article,
aside,
.clearfix {
	*zoom: 1;
}


.none_text {
	display: none;
}

/* Sitemap
================================================== */

.sitemap {
	font-size: 1em;
	line-height: 1.6em;
	padding: 15px;
}

.sitemap li {
	padding-bottom: 0px;
}

.sitemap ul li ul {
	margin-top: .5em;
	margin-bottom: .75em;
	list-style-type: none;
}

.sitemap ul li ul li {
	margin-bottom: .25em;
	position: relative;
	padding-left: 45px;
}

.sitemap ul li ul li::before {
	content: "";
	position: absolute;
	top: -0.5em;
	left: 11px;
	width: 10px;
	height: calc(100% + .75em);
	border-left: 2px solid #171717;
}

.sitemap ul li ul li:last-child::before {
	height: calc(1em + .25em);
}

.sitemap ul li ul li::after {
	content: "";
	position: absolute;
	top: .75em;
	left: 11px;
	width: 30px;
	border-bottom: 2px solid #171717;
}

.sm-depth1-label {
	padding-left: 5px;
	padding-right: 5px;
	font-size: 130%;
	font-weight: bold;
}

.sm-depth1-item:before {
	content: url(../images/folder.png);
	position: relative;
	top: 5px;
	margin: 0 5px 0 0;
}

.sm-depth1-label a {}

.sm-depth2-label {
	padding-left: 5px;
	padding-right: 5px;
}

/* PCサイト
==================================================
==================================================
==================================================
================================================== */

@media (min-width: 1024px) {
	.sp {
		display: none;
	}

	.content-top1-inner {
		width: 100%;
		max-width: 900px !important;
		margin: 0 auto;
		padding: 0 5px;
	}

}

@media print,
screen and (min-width: 768px) {
	.sp {
		display: none;
	}


	a:hover img,
	a:focus img {
	}

	:-ms-input-placeholder {
		color: #999999;
	}


	body,
	html {
		height: 100%;
	}

	body {
		margin: 0px;
		padding: 0px;
		font-size: 100%;
		line-height: 145%;
	}



	ol,
	ul {
		list-style: none;
	}

	form {
		margin: 0px;
		padding: 0px;
	}

	* {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
	}


	.pc-disp {}

	.sp-disp {
		display: none;
	}

	#container {
		position: relative;
		width: 100%;
		height: auto !important;
		margin: 0;

	}


	#scrollTop {
		text-align: right;
		position: fixed;
		right: 0;
		z-index: 20;
		padding: 0;
		/* margin-bottom: 25px; */

	}

	@media print {
		#scrollTop {
			display: none;
		}
	}


	#scrollTop a {
		text-decoration: none;
	}

	#scrollTop img {
		opacity: 0.8;
		filter: alpha(opacity=80);
		max-width: 52px;
	}


	.skip a {
		display: block;
		background-color: #007b44;
		color: #fff;
		text-decoration: none;
		text-align: center;
		position: absolute;
		height: 0;
		overflow: hidden;
	}

	#logo {
		position: absolute;
		max-width: 300px;
		top: 20px;
		left: 20px;
		z-index: 99999;
	}


	#header {
		background-color: #fff;
		z-index: 9999;
		width: 100%;
		padding: 20px;
	}

	#header-inner {
		width: 100%;
		margin: 0 auto;
		padding: 0px 5px 10px 30px;
	}

	#header-inner:after {
		content: "";
		display: block;
		clear: both;
	}

	#header-inner-l {
		float: left;
		width: 20%;
	}

	#header-inner-l img {
		width: 100%;
	}

	#header-inner-c {
		float: left;
		width: 0%;
	}

	#header-inner-r {
		float: right;
		width: 80%;
		text-align: right;
		padding-top: 0px;
	}

	#keyword {
		width: 200px;
		height: 30px;
		border: 1px solid #63CEC8;
		border-radius: 30px;
		font-size: 100%;
		padding: 3px;
	}

	#searchsubmit {
		padding-left: 5px;
		width: 35px;
	}

	.tool-area {
		padding-right: 15px;
	}

	.sp-header {
		display: none;
	}

	#globalNav {
		width: 100%;
		text-align: right;
		padding-top: 18px;
		font-weight: bold;
		font-size: 116%;
	}

	#globalNav ul {
		display: -webkit-inline-box;
		display: -ms-inline-flexbox;
		display: inline-flex;
		-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	}

	#globalNav ul li {
		text-align: center;
		border-left: 1px solid #ccc;
	}

	#globalNav ul li:first-child {
		border-left: none;
	}

	#globalNav ul li a {
		display: block;
		text-decoration: none;
		padding: 2px 18px;
	}

	#globalNav ul li a {}

	#globalNav ul li a {
		background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #63CEC8 50%);
		background-position: 0 0;
		background-size: 200% auto;
		transition: .3s;
	}

	#globalNav ul li a:hover {
		background-position: -100% 0;
		color: #fff;
	}

	/* プルダウン Nav
================================================== */

	#globalNav>ul .child {
		width: 250px;
		display: none;
		position: absolute;
		z-index: 800;
		padding: 0px;
		background-color: #fff;
		border: solid 1px #63CEC8;
	}

	#globalNav>ul .child li {
		border-left: none;
		border-right: none;
		font-size: 100%;
		min-width: 100%;
		font-weight: normal;
		border-bottom: 1px solid #63CEC8;
	}

	#globalNav>ul .child li:last-child {
		border-bottom: none;
	}

	#globalNav>ul .child li a {
		display: block;
		text-decoration: none;
		padding: 15px 5px 15px 15px;
		text-align: left;
	}

	.fbicon {
		width: 28px;
		vertical-align: middle;
	}

	#content {
		width: 100%;
	}

	/* pageTop */

	/*パソコン・スマホ共通のCSS*/
	#PageTopBtn {
		position: fixed;
		/*ボタンの配置場所を固定*/
		bottom: -10px;
		/*下からのボタンの配置場所を指定*/
		right: 10px;
		/*右からのボタンの配置場所を指定*/
	}

	#PageTopBtn a {
		display: block;
		/*配置の調整*/
		text-decoration: none;
		/*文字の下線を消す*/
		color: #fff;
		/*文字の色*/
		background: #63CEC8;
		/*ボタンの背景色*/
		text-align: center;
		/*文字を中央に配置*/
		border-radius: 50%;
		/*ボタンの角を少し丸くする*/
		outline: none;
		/*クリックしたときの黒い枠を消す*/
	}

	#PageTopBtn a:hover {
		text-decoration: none;
		background: #63CEC8;
		/*マウスオーバー時の背景色*/
	}


	/*パソコンで表示する場合のCSS*/
	@media (min-width: 768px) {
		#PageTopBtn {
			font-size: 25px;
			/*文字のサイズ*/
		}

		#PageTopBtn a {
			width: 50px;
			/*ボタンの幅*/
			height: 50px;
			/*ボタンの高さ*/
			padding: 5px 0;
			/*文字の配置場所の調整*/
		}
	}

	/*
================================================== */


	#sitemap_main {
		width: 100%;
		height: 200px;
		margin: 0 auto;
		background-color: #ffffff;
		background-image: url("../images/sitemap_main.jpg");
		background-repeat: no-repeat;
		background-position: center top
	}

	#search_main {
		width: 100%;
		height: 200px;
		margin: 0 auto;
		background-color: #ffffff;
		background-image: url("../images/sitemap_main.jpg");
		background-repeat: no-repeat;
		background-position: center top
	}

	#breadCrumb {
		font-size: 85%;
		padding: 30px 0 20px 0px;
		width: 1080px;
		margin: 0 auto 0 auto;
	}

	#breadCrumb a {
		color: #63CEC8;
	}

	#breadCrumb a:hover {}


	#breadCrumb p {
		margin-left: 0px;
		font-size: 70%;

	}

	.scrText {
		position: absolute;
		width: 0;
		height: 0;
		overflow: hidden;
	}

	.print_wrp {
		display: none;
		text-align: right;
		padding-top: 8px;
		margin-bottom: -32px;
	}

	#content-inner {
		width: 100%;
		margin: 0 auto;

	}

	#content-inner:after {
		content: "";
		display: block;
		clear: both;
	}

	.page-image {
		margin-top: 15px;
		text-align: center;
	}


	#main {
		width: 100%;
		clear: both;
		max-width: 1180px;
		min-height: 300px;
		margin: 0 auto;
		padding: 30px 30px 40px 30px;
	}

	#main2 {
		width: 100%;
		clear: both;
		max-width: 1180px;
		margin: 0 auto;
		padding: 30px 30px 50px 30px;
		border-bottom: 1px solid #d9d9d9;
	}
	
	#search .thumb{
		display: none;
	}

	.contentBody {
		width: 100%;
		margin-right: auto;
		margin-left: auto;
		clear: both;
		min-height: 1em;
		line-height: 190%;
	}

	.contentBody img {
		max-width: 100%;
	}

	.contentHeader p.date {
		float: right;
	}

	.contentBody .pagination {
		text-align: center;
		font-size: 80%;
	}

	.contentBody .pagination a {
		background-color: #534741;
		color: #fff;
		text-decoration: none;
		text-align: center;
		border-radius: 100px;
		/* CSS3???ﾄ */
		-webkit-border-radius: 100px;
		/* Safari,Google Chrome?p */
		-moz-border-radius: 100px;
		/* Firefox?p */
		padding: 2px 7px 2px 7px;
	}

	#sidemenu {
		margin-top: 0px;
	}

	.sideHeader {
		width: 100%;

	}

	.sideHeader h2 {

		font-size: 120%;
		text-align: center;
		background-image: url(../images/bg-sidemenu-h2.png);
		background-repeat: no-repeat;
		background-position: center 80%;
		background-size: 24px;
		line-height: 2em;
	}

	.sideBody {
		width: 1150px;
		margin-left: auto;
		margin-right: auto;
		padding: 30px 0px 30px 0px;
	}

	.sideBody ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
	}

	.sideBody li {
		background-color: #63CEC8;
		margin: 6px;
		width: 32%;
		font-size: 70%;
	}

	.sideBody .current_page {
		background-color: #eeefef;
	}

	.sideBody li .active {
		padding: 10px;
		display: block;
		font-size: 130%;
		color: #B4B4B4;
		background-color: #3A8480;
	}

	.sideBody li a {
		padding: 10px;
		display: block;
		font-size: 130%;
	}

	.sideBody li a:link {
		color: #ffffff;
	}

	.sideBody li a:visited {
		color: #ffffff;
	}

	.sideBody li a:hover,
	a:focus {}

	.top-category_news .sideBody ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
	}

	.top-category_news .sideBody li {
		margin: 6px;
		width: 32%;
		font-size: 70%;
		padding: 2%;
		background-color: #f3f3f3;
	}

	.top-category_news .sideBody li a {
		color: #575757;
		padding: 0px;
	}

	.top-category_news .sideBody li .active {
		padding: 0px;
		display: block;
		font-size: 130%;
		color: #64c8c8;
		background-color: transparent;
	}

	.sidebanner {
		margin-top: 15px;
		text-align: center;
	}

	.sidebanner li {
		margin-bottom: 0px;
	}

	.sidebanner li img {
		border: solid 1px #ccc;
	}

	/*
================================================== */

	/*
================================================== */

	.sitemap {
		margin-left: 0px;
	}

	.depth1 li {
		padding-top: 0px;
	}

	.depth2 li {
		padding-top: 0px;
	}

}

/* 幅が 1180px以下であれば */
@media (max-width:1150px) {
	#globalNav {
		font-size: 90%;
	}

	#main {}
}

/* 幅が 900px以上 999px以下であれば */
@media (min-width:900px) and (max-width:999px) {

	#keyword {
		width: 210px;
		height: 24px;
		border-radius: 24px;
	}

	#searchsubmit {
		width: 28px;
	}

	#globalNav ul li a {
		padding: 2px 15px;
	}

}

/*PCサイト終わり
==================================================
==================================================
==================================================
================================================== */
/**/
.cat-title-wrap {
	background-image: url(../images/btn_bg.png);
	background-position: center;
	background-size: cover;
	background-repeat: repeat;
	text-align: center;
	padding: 40px;
}

.cat-title {
	background-color: #fff;
    line-height: 120%;
    font-size: 180%;
    /* display: block; */
    padding: 8px 13px;
    color: #49b7b1;
    display: inline-block;
    letter-spacing: 2px;
}

/**/
.s-menu {
	background-image: url(../images/btn_bg.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
}

.s-menu ul {
	position: relative;
	top: -50px;
	text-align: center;
}

.s-menu li {
	display: inline-block;
	margin: 16px;
	    width: 100%;
    max-width: 230px;
}

.s-menu li img {
	width: 280px;
	border-radius: 10px;
	-moz-transition: -moz-transform 0.2s linear;
    -webkit-transition: -webkit-transform 0.2s linear;
    -o-transition: -o-transform 0.2s linear;
    -ms-transition: -ms-transform 0.2s linear;
    transition: transform 0.2s linear;
}

.s-menu li img:hover {
    -webkit-transform: scale(1.1);
    -moz-transform: scale(1.1);
    -o-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}


.s-menu ul.pc{
	display: flex;
    justify-content: center;
}


/*col1*/
.col1 {
	display: flex;
	justify-content: center;
	padding-top: 50px;
	padding-bottom: 50px;
	background-color: #F7F8F8;
}

/*news*/
.news {
	width: 480px;
	margin-right: 40px;
}

.news h2 {
	font-size: 150%;
    letter-spacing: 3px;
    border-bottom: 1px solid #63CEC8;
    padding-bottom: 10px;
}

.news h2 a,
.schedule h2 a {
	text-decoration: none;
}

.news h2 span,
.schedule h2 span {
	letter-spacing: normal;
	font-size: 0.6em;
	font-weight: normal;
	float: right;
	padding-left: 20px;
	background-image: url(../images/icon.png);
	background-repeat: no-repeat;
	background-size: 16px auto;
	background-position: left center;
}

.news .date {
	color: #63CEC8;
}

.news ul {
	margin-top: 5px;
}

.news li {
	border-bottom: 1px solid #C3C1C1;
	padding-top: 20px;
	padding-bottom: 20px;
}

.news li:last-child {
    border-bottom: none;
}

.news li .date {
	padding-left: 20px;
    background-image: url(../images/icon.png);
    display: block;
    background-repeat: no-repeat;
    background-size: 18px auto;
    background-position: left center;
    margin-bottom: 10px;
}

.news li .title {
    display: block;
}

.news li a {}

/*calendar*/
.schedule {
	width: 350px;
}

.cal {
	background-color: #fff;
	padding: 20px;
	margin-top: 20px;
}

.schedule h2 {
	font-size: 150%;
    letter-spacing: 3px;
    border-bottom: 1px solid #63CEC8;
    padding-bottom: 10px;
}

/*col2*/
.col2 {
	background-image: url(../images/kouenkai_bg.jpg);
	background-attachment: fixed;
	background-position: center;
	background-size: cover;

	position: relative;
	box-sizing: border-box;
	justify-content: center;
	align-items: center;
	padding-left: 10%;
	padding-right: 10%;
	padding-top: 50px;
	padding-bottom: 50px;
}

.infomation {
	padding: 20px;
	max-width: 900px;
	min-height: 300px;
	margin-left: auto;
	margin-right: auto;
	background-color: hsla(0, 0%, 100%, 0.78);
}

.infomation h2 {
	padding: 30px;
    text-align: center;
    font-size: 200%;
    letter-spacing: 3px;
    border-bottom: 2px solid;
    border-image: linear-gradient(to right, #63CEC8 0%, #FEFFEF 100%);
    border-image-slice: 1;
}

.infomation .date {
	color: #63CEC8;
}

.infomation ul {
	margin-top: 5px;
	padding: 15px;
}

.infomation li {
	border-bottom: 1px solid #C3C1C1;
	padding-top: 20px;
	padding-bottom: 20px;
}

.infomation li:last-child{
	border-bottom:none;
}

.infomation li .date {
	display: block;
    margin-bottom: 10px;
    padding-left: 20px;
    background-image: url(../images/icon.png);
    background-repeat: no-repeat;
    background-size: 18px auto;
    background-position: left center;
}

.infomation .title {
	display: block;
	padding-left: 20px;
}

.top-link {
	padding: 25px 20px;
	max-width: 900px;
	margin: 50px auto 0;
	background-color: hsla(0, 0%, 100%, 0.78);
	display: flex;
	justify-content: space-around;
}



.top-link ul {
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: flex-start;
    flex-wrap: wrap;
    width: 100%;
    margin: 0 auto;
}

.top-link ul li {
	text-align: center;
    margin: 1%;
    padding: 20px;
    vertical-align: middle;
    background-size: 10px;
    width: 31.3%;
    border-radius: 10px;
    background-color: #929e9e;
    font-weight: bold;
}

.top-link ul li a{
	color: #fff;
	text-decoration: none;
}

.col3 {
	background-attachment: fixed;
	background-position: center;
	background-image: url(../images/bnr_bg.png);
	background-size: 5%;
}

.banlist {
	display: flex;
	justify-content: center;
	padding-top: 50px;
	padding-bottom: 50px;
}

.banlist li {
	margin: 15px;
}

.banlist img {
	width: 200px;
	border-radius: 5px;
	border: 1px solid hsla(0, 0%, 76%, 1.00);
}

.banlist a:hover img,
.banlist a:focus img {
		opacity: 0.85;
		filter: alpha(opacity=85);
	}

/* footer */
#footer {
	width: 100%;
	bottom: 0;
	background-image: url(../images/f_bg.jpg);
	background-attachment: fixed;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	text-align: center;
}

#footer .inner {
	padding: 40px;
}

.flink {
	display: flex;
	justify-content: center;
}

.flink li:nth-child(1) {
	padding-right: 30px;
}

.flink li:nth-child(n+2) {
	background-image: url(../images/f_menu.png);
	background-repeat: no-repeat;
	background-position: left center;
	padding-left: 60px;
	padding-right: 30px;
}

.flogo {
	font-size: 160%;
	letter-spacing: 0.05em;
	margin: 20px;
}

.flogo span {
	display: block;
	font-size: 80%;
	margin-bottom: 20px;
}

.copy {
	margin-top: 30px;
	font-size: 70%;
}

.fadd {}

#sp-footer {
	display: none;
}

/*contentListWrapper*/
.contentListWrapper {
	margin-left: auto;
	margin-right: auto;
}

.pageList {
	display: flex;
	flex-wrap: wrap;
}

.pagelist-item {
	margin: 10px 7px 30px 7px;
	width: 32%;
	padding: 2%;
}

.pagelist-item a {
	display: block;
	font-size: 110%;
}

.pagelist-item span.title{
	display: block;
    text-align: center;
    padding: 5%;
    font-size: 120%;
    font-weight: bold;
	border-bottom: solid 2px #63cec8;
}

.pagelist-item span.title a{
	text-decoration: none;
}

.pagelist-item a:link {}

.pagelist-item a:visited {}

.pagelist-item li a:hover,
a:focus {}

.pagelist-item .description {
	margin: 5px 20px 10px 20px;
	padding: 5px;
	color: #fff;
	font-size: 80%;
	display: block;
	border-top: 1px solid #FFFFFF;
}


.current-category_news .pageList {}

ul.current-category_news {}

ul.current-category_news li{width: 100%;
    min-height: inherit;
    font-size: 100%;
    margin: 3px;
    background-color: #fff;
    border-bottom: 1px solid #63CEC8;
    background-size: 20px;
	background-image: none;
    padding-left: 14px;
}

ul.current-category_news .pagelist-item span.title {
    display: block;
    text-align: left;
    padding: 0;
    font-size: 120%;
    font-weight: bold;
    border-bottom: none;
}

ul.current-category_news .pagelist-item span.date {
	float: right;
}

/**/
.current-category_news ul {
	display: block;
}

.current-category_lecture ul {
	display: block;
}

.current-category_about_research ul {
	display: block;
}

.current-category_about_research2 ul {
	display: block;
}

.pagelist-item,
.current-category_lecture .pagelist-item,
.current-category_about_research .pagelist-item,
.current-category_about_research2 .pagelist-item {

}

.current-category_news .pagelist-item a {
	padding: 10px 10px 10px 25px;
    color: #63CEC8;
    background-image: url(../images/icon.png);
    background-repeat: no-repeat;
    background-position: 0px 11px;
    background-size: 20px;
	line-height: 150%;
}

.current-category_news .pagelist-item a {
	text-decoration: underline!important;
}

.current-category_lecture .pagelist-item a {
	padding: 10px;
	color: #63CEC8;
}

.current-category_about_research .pagelist-item a {
	padding: 10px;
	color: #63CEC8;
}

.current-category_about_research2 .pagelist-item a {
	padding: 10px;
	color: #63CEC8;
}



/**/
.contentHeader {}

.contentTitle {
	border-bottom: 2px solid #63CEC8;
	padding: 10px 10px 15px 8px;
	margin-bottom: 30px;
}

.contentTitle h1 {
    font-size: 190%;
    line-height: 170%;
}

.contentDescription {
	padding: 10px;
}

/*スタッフ*/
.stafflist {}

.staff-dr {}

.staff {
	display: inline-table;
    margin-bottom: 80px;
    padding: 3%;
    /* border: 1px solid #64c8c8; */
    width: 100%;
    background-color: #f7f7f7;
}

.staff-t {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 30px;
}

.prof-col-wrap {
	width: 70%;
    margin-left: 3%;
	font-size: 80%;
}

.photo {
	width: 25%;
}

.photo img {
	width: 250px;
	border: 1px solid #ccc;
}

.prof-col-a {
	margin-bottom: 20px;
}

.prof-col-wrap .cap {
	color: #64C8C8;
    font-weight: bold;
    font-size: 130%;
    padding-bottom: 3px;
}

.stafdivision {
	background-color: #64C8C8;
	color: #FFFFFF;
	width: 150px;
	font-size: 120%;
	font-weight: bold;
	text-align: center;
	line-height: 1.8em;
	letter-spacing: 0.15em;
}

.staffname {
	font-size: 185%;
    font-weight: bold;
    letter-spacing: 0.1em;
    padding-top: 10px;
}

.staffname span {
	font-size: 60%;
    margin-left: 2%;
    font-weight: normal;
    letter-spacing: 2px;
}

.history {
	margin-bottom: 30px;
}

.prof-col-b {
}

.prof-col-c {
	display: block;
	width: 100%;
}

.activity {
	padding: 40px;
    background-color: #fff;
    font-size: 85%;
}

.activity .cap {
    color: #64C8C8;
    font-weight: bold;
    font-size: 120%;
    padding-bottom: 3px;
    margin-bottom: 8px;
    border-bottom: 1px solid #64c8c8;
}

.activity h4{
	margin: 20px 0 5px 0;
}

.lentout {
	display: flex;
}

.lentout-com {
	background-color: #D9F1F1;
    padding: 20px;
    margin-bottom: 30px;
    margin-top: 40px;
    font-size: 140%;
    font-weight: bold;
}

.lentoutContainer {}

.lentout .staffname {
	font-size: 130%;
    padding: 0%;
    margin: 20px;
    text-align: center;
}

.lentout .staffname span {
	display: table;
	padding: 5px 0 0 5px;
	width: 100%;
}

.assistant-txt {
	color: #64C8C8;
	text-align: center;
	margin-top: 80px;
	margin-bottom: 30px;
	font-size: 150%;
	border-bottom: 1px solid #64C8C8;
	padding-bottom: 15px;
}

.assistant {
	display: flex;
	flex-wrap: wrap;
}

.assistantContainer {
	padding: 2%;
    background-color: #f7f7f7;
    /* margin-right: 30px; */
    /* margin-bottom: 20px; */
    width: 31.3%;
    text-align: center;
    margin: 1%;
}

.assistant .staffname {
	font-size: 130%;
}

.assistant .staffname span {
	display: block;
    margin: 0;
    padding: 2% 0;
}

.assdivision {
	display: block;
	color: #64C8C8;
	width: auto;
	padding: 0px;
	font-size: 100%;
	font-weight: normal;
}


/* 幅が 986px以下であれば */
@media (max-width:986px) {
	#footer .inner {
		padding: 0px;
		margin-top: 0px;
	}

	.flogo {
		font-size: 130%
	}

	.flink {
		display: block;
		background-image: url(../images/f_bg.jpg);
		background-attachment: fixed;
	}

	.flink li:nth-child(1) {
		background-image: url(../images/icon.png);
		background-repeat: no-repeat;
		background-size: 18px auto;
		background-position: left center;
		background-position-x: right;
		padding-right: 10px;
		text-align: left;
		border-bottom: 5px solid #FFFFFF;
	}

	.flink li:nth-child(n+2) {
		background-image: url(../images/icon.png);
		background-repeat: no-repeat;
		background-position: left center;
		padding-left: 0px;
		padding-right: 0px;
		background-size: 18px auto;
		background-position-x: right;
		text-align: left;
		border-bottom: 5px solid #FFFFFF;
	}

	.flink li a {
		text-decoration: none;
		display: block;
		padding: 20px;
		margin-bottom: 5px;
	}

	.copy {
		font-size: 60%;
		padding-bottom: 20px;
	}

	.s-menu .sp {
		display: none;
	}

	.s-menu ul {
		position: relative;
		top: -28px;
		text-align: center;
	}

	/*col1*/
	.col1 {
		display: block;
		padding-left: 20px;
		padding-right: 20px;
		padding-top: 50px;
		padding-bottom: 50px
	}

	.news {
		width: auto;
		margin-right: auto;
		padding-bottom: 100px;
	}

	.cal {
		width: auto;
		margin-left: auto;
		margin-right: auto;
	}

	.schedule {
		width: auto;
	}

	.schedule h2,
	.news h2 {
		text-align: center;
	}

	.schedule h2 span,
	.news h2 span {
		display: none;
	}

	.schedule .more,
	.news .more {
		margin-top: 30px;
		letter-spacing: normal;
		font-size: 1em;
		font-weight: normal;
		float: right;
		padding-left: 20px;
		background-image: url(../images/icon.png);
		background-repeat: no-repeat;
		background-size: 16px auto;
		background-position: left center;
	}

	.news li a {
		display: block;
	}

	.news li .title {
		margin-left: 20px;
		display: block;
	}

	.col3 {
		background-size: 15%;
	}

	.banlist {
		display: flex;
		flex-wrap: wrap;
	}

	.banlist li {
		margin: 5px;
		width: 40%;
	}

	.banlist img {}

	#header-inner {
		padding: 0px 5px 10px 0px;
	}

	#logo {
		max-width: 250px;
		left: 13px;
	}

	.pc-disp-con {
		display: none;
	}

	.tab-disp-con {
		display: block;
	}
	
	.s-menu li{
	width: 25%;
	}

}

/*　カレンダー
*********************************************/

.contentBody .calendar {}

.contentBody .sectionHeader {
	margin-bottom: 20px;
	text-align: center;
}

.contentBody .cal_month_select {
	text-align: center;
	display: inline-block;
	height: 30px;
	margin-top: 2em;
	padding: 0 25px;
	border-radius: 35px;
	background-color: #00BCD4;
}

.contentBody .cal_category_select {
	display: none;
}

.contentBody .cal_month_select a {
	color: #ffffff;
}

.contentBody .pre_month {}

.contentBody .now_month {
	color: #ffffff;
	background-color: #8ACCD5;
	font-size: 1.2em;
	line-height: 30px;
	display: block;
	float: left;
	padding: 0 25px;
	transition: 400ms ease;
	letter-spacing: 0.1em;
}

.contentBody .pre_month,
.next_month {
	font-size: 1.2em;
	line-height: 30px;
	display: block;
	float: left;
	padding: 0 25px;
	transition: 400ms ease;
	letter-spacing: 0.1em;
	color: #595959;
}

.contentBody .calendar table {
	width: 100%;
}

.contentBody .calendar table caption {
	font-size: 140%;
	color: #5f3919;
	font-weight: bold;
	padding-bottom: 5px;
}

.contentBody .calendar thead {
	background-color: #DFDFDF;
}

.contentBody .calendar table th,
.contentBody .calendar table td {
	border: 1px solid #ccc;
	height: 35px;

}

.contentBody .calendar .day,
.contentBody .calendar .week,
.contentBody .calendar .event {
	vertical-align: middle;
}

.calendar .sunday {
	background-color: #ffefed;

}

.calendar .saturday {
	background-color: #e3f5f9;
}

.contentBody .calendar table td a {}

.contentBody .calendar_item {
	padding: 2px 4px;
}

.contentBody .calendar_item .title {
	padding-right: 3px;
}

.calendar table .category {
	display: none;
}

.contentBody .calendar .cal_day_tbl th,
.calendar .cal_day_tbl td {
	padding: 5px 10px;
}

.contentBody .calendar .cal_day_tbl th {
	vertical-align: middle;
	background-color: #eee;
	width: 200px;
}


/* 幅が 1110px以下であれば */
@media screen and (max-width:1110px) {
	
.pagelist-item {
    margin: 2%;
    width: 29%;
}
	
}


/* 幅が 925px以下であれば */
@media screen and (max-width:925px) {
	.pc {
		display: none;
	}

	.s-menu .sp {
    display: flex;
}
	
	.s-menu li {
    width: auto;
}

	.s-menu .sp li img {
		border-radius: 10px;
	}

	#header {
		display: none;
	}

	.sp-header {
		display: block;
	}
	
	.s-menu .sp {
    text-align: center;
    display: flex;
    justify-content: space-between;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    
}

	
	.s-menu ul {
    top: -90px;
}

	/**/
	.contentListWrapper {
		width: 100%;
	}

	.pageList {
	}

	.pagelist-item {
		text-align: center;
	}

	/*
================================================== */

	#title {
		position: absolute;
		width: 0;
		height: 0;
		overflow: hidden;
	}

	.sp-header {
		margin-top: 60px;
	}

	.header-top {
		position: fixed;
		left: 0px;
		top: 0px;
		background-color: #fff;
		width: 100%;
		height: 60px;
		padding: 0px 0px 0 0px;
		z-index: 30;
		border-bottom: 1px solid #e6e6e6;
	}

	.header-top .logo {
		float: left;
		padding-left: 10px;
		vertical-align: middle;

	}

	.header-top .logo img {
		float: left;
    	width: 200px;
		padding-top: 0px;
	}

	.header-top a {
		text-decoration: none;
	}

	/* accordion menu
================================================== */

	/*メニュー部分*/
	nav {
		display: none;
		position: absolute;
		top: 0;
		width: 100%;
		height: 100vh;
		background: #fff;
		left: 0;

	}

	header nav ul {
		display: block;
		width: 90%;
		height: 600px;
		position: absolute;
		top: 100px;
		right: 0px;
		bottom: 0px;
		left: 0px;
		margin: auto;
	}

	header nav ul li {
		margin: 0 auto;
		text-align: left;
		font-size: 140%;
		border-bottom: 1px solid #63CEC8;
		background-image: url(../images/icon.png);
		background-repeat: no-repeat;
		background-position: right center;
		background-size: 20px auto;
	}

	header nav ul li:last-child {
		border: none;
	}

	header nav ul li a {
		display: block;
		color: #63CEC8;
		padding: 15px 10px 15px 15px;
	}

	/*開閉ボタン*/
	#nav_toggle {
		display: block;
		width: 60px;
		height: 40px;
		position: relative;
		top: 6px;
		z-index: 100;
		padding: 10px;
	}

	#nav_toggle div {
		position: relative;
	}

	#nav_toggle span {
		display: block;
		height: 3px;
		background: #63CEC8;
		position: absolute;
		width: 100%;
		left: 0;
		-webkit-transition: 0.5s ease-in-out;
		-moz-transition: 0.5s ease-in-out;
		transition: 0.5s ease-in-out;
	}

	#nav_toggle span:nth-child(1) {
		top: 0px;
	}

	#nav_toggle span:nth-child(2) {
		top: 12px;
	}

	#nav_toggle span:nth-child(3) {
		top: 24px;
	}

	/*開閉ボタンopen時*/
	.open #nav_toggle span:nth-child(1) {
		top: 12px;
		-webkit-transform: rotate(135deg);
		-moz-transform: rotate(135deg);
		transform: rotate(135deg);
	}

	.open #nav_toggle span:nth-child(2) {
		width: 0;
		left: 50%;
	}

	.open #nav_toggle span:nth-child(3) {
		top: 12px;
		-webkit-transform: rotate(-135deg);
		-moz-transform: rotate(-135deg);
		transform: rotate(-135deg);
	}

	/*
================================================== */


	.sp_h_tool {
		float: right;
		display: flex;
	}

	.sp_h_tool img {
		width: 50px;
		padding-top: 3px;
	}



	/* Header Nav
================================================== */

	.header-navi {}

	.header-navi .nav-header {
		background: #999999;
	}

	.header-navi .nav-header h2 {
		float: left;
		padding: 15px 5px 5px 5px;
	}

	.header-navi .nav-header button {
		float: right;
		padding: 5px;
	}

	.header-navi .nav-header button img {
		width: 45px;
	}

	/*
---------------------------------------------------------------*/
	#pc-search {
		margin: 10px 10px;
	}

	#keyword {
		width: 170px;
		height: 28px;
		margin-top: 5px;
		border-radius: 28px;
		padding: 0 5px;
		border: 1px solid #63CEC8;
	}

	#searchsubmit {
		padding-left: 5px;
		width: 35px;
	}


	/*
---------------------------------------------------------------*/

	.content-top-inner {
		display: block;
		margin-top: 30px;
	}

	.news-title {
		width: 100%;
		text-align: center;
		padding-bottom: 10px;
		border-bottom: solid 1px #63CEC8;
		margin-bottom: 20px;
	}

	.r-area {
		text-align: center;
		padding-bottom: 35px;
	}

	.r-area img {
		width: 90%;
		border-radius: 10px;
	}

}


/* スマホサイト
==================================================
==================================================
==================================================
================================================== */

@media screen and (max-width: 767px) {
	.pc {
		display: none
	}

	.print_wrp {
		display: none;
	}

	body,
	html {
		height: 100%;
		-webkit-text-size-adjust: 100%;
	}

	body {
		margin: 0px;
		padding: 0px;
		font-size: 87.5%;
		line-height: 130%;
	}

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

	ol,
	ul {
		list-style: none;
	}

	form {
		margin: 0px;
		padding: 0px;
	}
	
	#nav_toggle {
		width: 40px;
	}
	
	
	.s-menu .sp {
    padding: 50px 40px 0px 40px;
}
	
	.s-menu {
    height: 190px;
}
	

	#main {
		margin: 30px 0px 30px 0px;
		padding: 0 4%;
	}

	.top-link {
		flex-direction: column;
		padding: 25px 10px;
	}

	.top-link a {
		width: 95%;
		margin: 0.75em auto;
		padding: 1em 0;
		flex-direction: row;
	}
	
	.news li .title {
    margin-left: 0px;
}
	
	
	.col2 {
		padding: 8% 5%;
	}
	
	.col3 {
    background-size: 8%;
}
	
	.banlist {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
	padding: 10%;
}
	
	.banlist li {
    margin: 3%;
    width: 40%;
}
	
	.banlist img {
    width: auto;
}
	
	#footer .inner {
    margin-top: 0px!important;
}
	
	.pagelist-item {
    width: 25%;
}
	
	.pagelist-item span.title {
    padding: 7% 0;
    font-size: 100%;
	}
	

	/*スタッフ*/
	
	.staff-t {
    display: block;
}
	
	.staff {
    display: block;
    width: auto;
}
	
	.prof-col-wrap {
		display: block;
		flex-wrap: nowrap;
		width: 100%;
		margin: 0;
		padding: 1%;
	}

	.photo {
		float: none;
		text-align: center;
		width: 100%;
	}

	.photo img {
		width: auto;
		margin-bottom: 20px;
		max-width: 250px;
	}
	
	.prof-col-a {
    	text-align: center;
	}
	
	.stafdivision {
		width: auto;
		display: inline;
		padding: 2px 10px;
	}

	.prof-col-b {
		padding-left: 0px;
		width: auto;
	}

	.assistant {
		display: flex;
		flex-wrap: wrap;
	}

	.assistantContainer {
		width: 44%;
	}
	

	.prof-col-c {
		display: block;
		margin: 0px;
		width: 100%;
	}
	
	.activity {
    padding: 15px;
}
	
.top-link ul li {
    width: 42%;
}
	
	.contentBody {
		line-height: 190%;
	}	

}

@media screen and (max-width: 480px) {
	
	
.col1 {
        padding-top: 40px;
    }
	
.s-menu .sp {
    padding: 65px 15px 0px 15px;
}
	
.s-menu {
    height: 112px;
}
	
.s-menu li {
    margin: 8px;
}
	
.infomation h2 {
    padding: 15px;
    font-size: 150%;
	}
	
.infomation ul {
    padding: 0px;
}
	
/*
.cat-title-wrap {
    height: 98px;
}
*/
	
ul.current-category_news li{
	padding: 0;
	}
	
ul.current-category_news .pagelist-item span.date {
	padding-bottom: 3%;
}
	
	
.banlist {
    padding: 10% 0%;
}
	
.pagelist-item {
   margin: 3%;
    width: 40%;
}
	
.staff {
    padding: 5%;
}
	
.photo {
    padding-top: 5%;
}
	
.photo img {
    max-width: 130px;
}
	
.activity h4 {
    font-size: 115%;
}
	
.assistantContainer {
    width: 100%;
    margin: 3%;
    padding: 8%;
}
	
.pagelist-item span.title {
    font-size: 70%;
}
	
.copy {
    font-size: 60%;
    padding: 5% 5% 10% 5%;
    margin: 0;
	}
	
.top-link ul li {
    width: 100%;
}
	
.contentTitle h1 {
    font-size: 170%;
}
	
.contentTitle .date{
	margin-top: 10%;
    text-align: center;
    color: #64c8c8;
	}
	
}


/*staff*/

.top-category_staff .pageList {
    margin-bottom: 60px;
}

.top-category_staff .pagelist-item span.title {
    display: block;
    text-align: center;
    padding: 40px 20px;
    font-size: 120%;
    font-weight: bold;
    border-bottom: none;
    border: 1px solid #bad3d2;
    background-color: #e2f3f0;
}

.top-category_staff .pagelist-item {
    margin: 1%;
    width: 31.3%;
    padding: 0%; 
}



@media screen and (max-width: 1110px) {
	
	
.top-category_staff .pagelist-item span.title {
    display: block;
    text-align: center;
    padding: 40px 20px;
    font-size: 120%;
    font-weight: bold;
    border-bottom: none;
    border: 1px solid #bad3d2;
    background-color: #e2f3f0;
}

.top-category_staff .pagelist-item {
    margin: 1%;
    width: 31.3%;
    padding: 0%; 
}

	
	
}



@media screen and (max-width: 600px) {
	
	
.top-category_staff .pagelist-item {
    margin: 1%;
    width: 48%;
    padding: 0%; 
}
	
}



.s-menu li {
    display: inline-block;
    margin: 1%;
    width: 100%;
    max-width: 230px;
}


@media screen and (max-width: 1100px) {
.s-menu ul.pc {
    display: flex;
    justify-content: center;
    max-width: 1000px;
    margin: 0 auto;
}
}


@media screen and (max-width: 1050px) {
	.s-menu ul.pc {
		padding: 0 20px;
	}
}
	
	
@media screen and (max-width: 900px) {
	
	
.s-menu {
    padding: 30px;
	height: auto;
}
	
	.s-menu ul.pc {
		padding: 0;
	}
	
	.s-menu ul {
        position: unset;
}
}
	
	
@media screen and (max-width: 630px) {
	
.s-menu ul.pc {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    }
	
	
.s-menu li {
    display: inline-block;
        margin: 2%;
        width: 46%;
    max-width: unset;
}
	
}
	
	
@media screen and (max-width: 500px) {
	
.slick-slide img {
    width: 100%;
    height: 250px;
    object-fit: cover;
}
}
	
	
	
	



