/*base.css*/
a{
	color:#741E14;
	text-decoration: underline;
}
a:hover{
	color:#741E14;
	text-decoration: none;
}
a:visited{
	color:#333;
}
#gnav a:hover,#gnav-sub a:hover{
		text-decoration: underline;
}
#main-content img{
	max-width: 100%;
}
/*ヘッダー
----------------------------------------*/
header{
    width: 100%;
    z-index: 200;
    background: #fff;
	}
#gnav-cont{
}

#header-container {
	padding-top: 20px;
}
#head_top{
    height: 77px;
}
@media screen and (max-width:992px){
#head_top{
    height: auto;
}
}
/*ロゴ*/
#logo {
	float: left;
	width: 444px;
	padding: 15px;
}
#headerbox {
	float: right!important;
	width: 57%;
	padding: 15px;
	margin-top: 10px;
}
@media screen and (max-width:568px){
#header-container {
	background-image: url(/graduate/imgs/common/bg_head.gif);
	background-repeat: repeat-x;
	background-position: center top;
	padding-right: 10px;
	padding-left: 10px;
	width: 300px;
	margin-right: auto;
	margin-left: auto;
}
	
#logo {
	width: 300px;
	padding-left: 0px!important;
}
#headerbox {
	float: none!important;
	width: 300px!important;
	margin-right: auto!important;
	margin-left: auto!important;
}
}

/*----- ヘッダーリンク -----*/
#headerlink {
}
/*----- ヘッダーボックス -----*/

/*文字サイズ*/
#fontsize {
	float: left;
	position: relative;
	font-size:1px;
	line-height:1px;
	width: 170px;
	margin-bottom: 0;
}
@media screen and (max-width:568px)
{
#fontsize {
	display: none;
}
}

#fontsize dt {
	float: left;
	text-indent: -9999px;
	background-image: url(/graduate/imgs/common/img_moji.gif);
	background-repeat: no-repeat;
	height: 21px;
	width: 81px;
	background-position: left center;
	padding-left: 8px;
}
#fontsize dd {
	display: inline;
	font-size:1px;
	line-height:1px;
	width: 80px;
}
/*文字サイズアイコン*/
#fontsize ul {
	display: inline;
	padding: 0;
}
#fontsize li {
	float: left;
	padding-right: 5px;
	list-style: none;
}
#fontsize li a {
	text-indent: -9999px;
	display: block;
	background-repeat: no-repeat;
	background-position: top;
	width: 21px;
	height: 21px;
	text-decoration: none;
	overflow: hidden;
}
#fontsize li a:hover {
	background-position:bottom!important;
}
#fontsize #fs1 {
	background-image: url(/graduate/imgs/common/moji_b.gif);
}
#fontsize #fs2 {
	background-image: url(/graduate/imgs/common/moji_m.gif);
}
#fontsize #fs3 {
	background-image: url(/graduate/imgs/common/moji_s.gif);
}
.noscript {
	position: absolute;
	top:0px;
	left:0px;
	color: #000000;
	font-size: 10px;
	line-height: 1.1em;
	font-weight:bold;
	overflow: hidden;
	background: url(/graduate/imgs/base/bg_koshi.gif);

}
.font-active{
	background-position: center bottom !important;
}
/*文字サイズ調整*/
.font-superlarge {
	font-size: 110%;
}
.font-large {
	font-size: 100%;
}
.font-normal {
	font-size: 90%;
}


/*----- 検索 -----*/
.sitesearch {
	line-height:1px;
	list-style: none;
	float: left;
	width: 175px;
	margin: 0 10px;
}
.sitesearch dt {
	float: left;
	text-indent: -9999px;
	width: 0px;
}
.sitesearch dd {
	float: left;
	display: inline;
	font-size:1px;
	line-height:1px;
}
.sitesearch input.words {
	overflow: hidden;
	border: 1px solid #C8C8C8;/*都度変更*/
	color: #495142;/*都度変更*/
	font-size:11px;
	width: 152px;
	margin-top: 0;
	margin-right: 5px;
	margin-bottom: 0;
	height: 21px;
}
.sitesearch input.text {
	color:#333333!important;
}
.sitesearch input#go {
	display: block;
}
#access_but {
	margin: 0 10px 0 5px;
	padding: 0px;
}
#contact_but {
	margin: 0px;
	padding: 0px;
}

/*-- アクセスとお問い合せボタン --*/
#access_but,#contact_but{
	float: left;
}
#access_but a {
	float: left;
	margin: 0px;
	display:block;
	text-indent: -9999px;
	text-decoration: none;
	overflow: hidden;
	margin:0;
	height:27px;
	background-image: url(/graduate/imgs/common/but_access_pc.gif)!important;
	width: 80px;
	clear: both;
	padding:0px 10px 0px 0px;
	background-repeat: no-repeat;
	background-position: 0px 0px;
}
#contact_but a {
	/* float: left; */
	margin: 0px;
	padding: 0px;
	display: block;
	text-indent: -9999px;
	text-decoration: none;
	overflow: hidden;
	margin:0;
	height:27px;
	background-image: url(/graduate/imgs/common/but_contact.png)!important;
	width: 122px;
}
#access_but a:hover,#contact_but a:hover{
	opacity: 0.8;
	
}
@media screen and (max-width:568px){
#access_but a {
	height:27px;
	background-image: url(/graduate/imgs/common/but_access_sp.gif)!important;
	background-size:80px 54px;

	-webkit-background-size:80px 54px;
	-moz-background-size:80px 54px;
}
#contact_but a {
	height:27px;
	background-image: url(/graduate/imgs/common/but_contact_sp.gif)!important;
	background-size:110px 54px;
	-webkit-background-size:110px 54px;
	-moz-background-size:110px 54px;
}
}
/*メニュー*/
#gnav{
	background: #FFD9D9;
	display: table;
	width: 100%;
}
.gnav-bar {
	display: -webkit-box;
    display:flex;
    width:100%;
    -webkit-box-pack: center;
    justify-content:flex-end; 
	    margin: 0 auto;
}
.nav-item{
	list-style: none;
	text-align:center;
    position:relative;
}
.nav-link{
	color:#000;
	height: 50px;
	font-size: 1em;
	padding: 10px 45px;
	text-decoration: none;
    min-width: 175px;
}
.active .nav-link{
	background:#fff;
	border-top:1px solid #A7A7A7;
	border-left:1px solid #A7A7A7;
	border-right:1px solid #A7A7A7;
}
#gnav-sub{
	position: absolute;
	width: 100%;
	background: rgba(255,255,255,0.9);
	border-bottom:2px solid #000;
	z-index: 200;
}
.gnav-sub{
	width:100%;
	display: flex;
	display:flex;
	-webkit-box-pack: justify;
	justify-content:space-between;
	align-items: center;
	height: 40px;
	box-sizing: border-box;
	margin: 0 auto;
	text-align: center;
}
.gnav-sub li{
		list-style:none;
		width: calc(100% / 4);
}
.gnav-sub li a{
    position: relative;
    display: inline-block;
    padding: 10px 20px 10px 40px;
    color: #000;
    vertical-align: middle;
    text-decoration: none;
    font-size: 0.9em;
}
.gnav-sub li a:before,
.gnav-sub li a:after{
    position: absolute;
    top: 0;
    bottom: 0;
    left: 20px;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.gnav-sub li a:before{
	content:"";
    box-sizing: border-box;
    width: 15px;
    height: 15px;
    border: 1px solid #444444;
    -webkit-border-radius: 50%;
    border-radius: 50%;
}
.gnav-sub li a:after{
		content:"";
		left: 26px;
		box-sizing: border-box;
		width: 5px;
		height: 8px;
		border: 5px solid transparent;
		border-left: 5px solid #444444;
}
/*メインビジュアル*/
#mainvisual{
	width: 100%;
	background: url("/graduate/imgs/top/top-mv.png") no-repeat;
	height: 400px;
	/* margin-top: 20px; */
	/* padding-top: 70px; */
	border-bottom: #5884AD thin solid;
	box-sizing: border-box;
	position: relative;
	background-size: cover;
	}
@media screen and (min-width:1200px){
#mainvisual{
		background-size: auto;
		background-position: center;
}
}
	
/*バナー*/
#banner{
	background:#EEEEEE;
	padding:45px 0;
}
.bnr-list{
}
.bnr-list li{
	list-style:none;
}
.bnr-list img{
	max-width: 100%;
}
/*フッター*/
footer{
	background: #FFD9D9;
}
.fo-link li{
	list-style:none;
}

.fo-link li{
  position: relative;
  display: inline-block;
  padding-left: 20px;
	margin-left: 10px;
}
.fo-link li a{
	color: #444;
}
.fo-link li a:before{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 1px #444;
  border-right: solid 1px #444;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -4px;
}
.fo-link li a:after{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 1px #444;
  border-right: solid 1px #444;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 4px;
  margin-top: -4px;
}
.fo-link li a:hover{
	text-decoration: underline;
}
.fo-link li a:hover:before{
	  left: 2px;
}
	.fo-link li a:hover:after{
			  left: 6px;
}
.menu-fixed{
	position: fixed;
	z-index: 400;
	top:0;
}
.menu-fixed #gnav-sub{
	background: #fff;
}
@media screen and (max-width:1200px){
	#logo {
	width: 50%;
}
		#logo a img{
	max-width: 100%;
}
	#headerbox {
    width: 45%;
}
	#access_but{
		position: relative;
    right: -155px;
    top: 7px;
	}
	#contact_but,.sitesearch{
	float:right;
	}
}
@media screen and (max-width:992px){
	#headerbox{
		display:none;
	}
	#logo {
	width: 70%;
}
	.menu-fixed{
	position: static;
	}
	.gnav-bar{
		justify-content: space-between;
	}
	.nav-item {
    width: 24%;
}
	.nav-link {
		padding: 10px 3px;
		font-size: 1em;
		height: auto;
		min-width:auto;
	}
	#mainvisual{
		    height: 295px;
	} 
	.fo-link{
		font-size: 0.8em;
	}
	
}
@media screen and (max-width:768px){
	#banner{
		padding: 30px 0;
	}
	.bnr-list li{
		text-align: center;
	}
	.bnr-list li:nth-child(n+3){
		margin-top: 20px;
		
	}
	copy{
		font-size: 0.7em;
	}

}
@media screen and (max-width:576px){
	.nav-link {
		font-size: 0.8em;
	}
}
#mobile-menu {
    font-size: 0.5em;
    margin: 5px 5px 0;
    padding: 8px 10px 3px;
    text-align: center;
    position: fixed;
    right: 0;
    background: rgba(255,255,255,0.6);
    z-index: 300;
}
#sp-menu{
	    display: none;
    position: fixed;
    width: 100%;
    top: 65px;
    left: 0;
    z-index: 300;
    background: #fff;
	    border-bottom: 1px solid #333;
	border-top: 1px solid #333;
    padding: 10px;
}
#sp-menu .sitesearch{
    float: none;
    clear: both;
    display: table;
    margin: 10px auto;
	    width: 50%;
}
#sp-menu .searcharea{
	width: 80%;
}
#sp-menu .sitesearch input.words{
	    width: 100%;
}
#sp-gnav,#sp-gnav ul{
	padding: 0;
	margin: 0;
}
#sp-gnav li{
	list-style: none;
}
#sp-gnav  li  a{
		padding: 5px 20px 5px 25px;
		display: block;
	position: relative;
}
#sp-gnav > li > a{
	border-bottom: dotted 1px #333;

}
#sp-gnav > li a:before{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 1px #444;
  border-right: solid 1px #444;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 17px;
  left: 10px;
  margin-top: -4px;
}
#sp-gnav > li a:after{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 1px #444;
  border-right: solid 1px #444;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 17px;
  left: 4px;
  margin-top: -4px;
}
.sp-gnav-child li a{
	font-size: 0.8em;
}
.sp-gnav-child li a:before{
	top:15px !important;
}
.sp-gnav-child li a:after{
	display: none;
}
.bg-kyoushoku{
	    background: rgb(199 226 183 / 60%);
}
.bg-master{
	    background: rgb(194 232 255 / 60%);
}
@media screen and (max-width:992px){
#mobile-menu {
	top:10px;
	}
		.gnav-sub li {
		width: auto !important;
	}
}
@media screen and (max-width:768px){

		.gnav-sub li a{
		font-size: 0.7em;
	}
	.gnav-sub{

	}
	#sub-cont{
    border-top: 3px solid #741E14;
    border-bottom: 1px solid #741E14;
    margin-top:50px;
	}
}
@media screen and (max-width:576px){
	.gnav-sub li a{
		    padding:10px 5px 10px 15px;
		
	}
	.gnav-sub li a:before {
    width: 10px;
    height: 10px;
    left: 3px;
}
.gnav-sub li a:after {
	
    left: 7px;
    width: 3px;
    height: 7px;
    border: 3px solid transparent;
    border-left: 3px solid #444444;
}
	}
/*news event*/
.top-h {
  position: relative;
  padding: 20px 20px 10px;
  border-bottom: solid #DDDDDD 2px;
}
.top-h:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 2px;
  background-color: #741E14;
  display: block;
  width: 20%;
  z-index: 2;
}
.top-h:after {
  width: 100%;
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 2px;
  background: #DDDDDD;
}
#event-cont .top-h:before {
	background-color:#FFA8A8;
}
.top-h h2 {
  font-family: "Yu Mincho", "YuMincho", serif;
  font-size: 1.4em;
  font-weight: bold;
}
/*新着一覧のh2スタイルの重複をクリアします。*/
.h2-none{
	position: revert;
    padding: revert;
    border-bottom: none;
}
.top-tab {
  position: absolute;
  display: -webkit-box;
  display: flex;
  align-items: center;
  top: 15px;
  left: 25%;
  border: 1px solid #ccc;
  margin: 0;
  padding: 0;
}
.top-tab li {
  list-style: none;
}
.top-tab li a {
  color: #000;
  display: inline-block;
  padding: 5px 10px;
  border-right: 1px solid #ccc;
  text-align: center;
  font-size: 0.9em;
  width: 130px;
  height: 35px;
  position: relative;
  text-decoration:none;
}
.top-tab li:last-child a {
  border-right: none;
}
.top-tab li a.active, .top-tab li a:hover {
  background: #ccc;
  text-decoration: none;
}
.top-tab li a.active:after, .top-tab li a:hover:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #ccc;
}
.top-tab li .icon{
	display:none;
}
.top-box a{
	color: #000;
}
.top-box article{
	padding: 30px 20px 10px;
	border-bottom: dashed 1px #ccc;
}
.top-box article a:hover{
	text-decoration:none;
	color: #999;
}
.top-box time{
	font-size: 0.9em;
}
.top-cat{
	float: left;
	width: 115px;
	padding: 3px;
	text-align: center;
	margin-top: -3px;
	margin-right: 20px;
	border: solid 1px #ccc;
	font-size: 0.9rem;
}
.cat-kyoushoku{
	background-color: #c7e2b7;
}
.cat-master{
	background-color: #C2E8FF;
}
.cat-doctor{
	background-color: #E6D2FF;
}
.more-link{
	display: block;
	color: #000;
	border: solid 1px #000;
	padding: 10px 30px;
	margin-top: 20px;
	width: 200px;
	text-align: center;
	position:relative;
	margin-left:auto;
	margin-right:auto;
}
.more-link a{
	color: #000;
}
.more-link a:hover{
	opacity: 0.5 ;
	text-decoration: none;
}
.more-link a:before{
	left: 35px;
    box-sizing: border-box;
    width: 5px;
    height: 5px;
    border: 5px solid transparent;
    border-left: 4px solid #000;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.more-link a:hover:before{
	left: 40px;
}
#event-cont{
	margin: 40px 0;
}
@media screen and (max-width:992px){
	.top-cat{
		max-width: 100%;
		width: 88px;
		margin-right: 0px;
	}
	.top-box time{
		font-size: 0.8em;
		padding: 0;
	}
}
@media screen and (max-width:768px){
	.top-tab {
		     position: relative;
		    top: auto;
    left: auto;
		    margin-top: 15px;
	}
	.top-tab li{
		width: 25%;
	}
	.top-tab li a {
width: 100%;
    font-size: 0.8em;
    padding: 5px;
}
}
/*インデント*/
.indent-1{
	padding-left: 1rem;
	text-indent: -1rem;
}

.top-mainvisual{
	background-image:none !important;
	height:auto !important;
	min-height:auto !important;
}