@charset "utf-8";
/* CSS Document */

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



/*
=========================================
	layout
=========================================
*/ 

html {
 overflow-y: scroll;
}

body{
	font-family: "ヒラギノ角ゴ Pro","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"ＭＳ Ｐゴシック",sans-serif;
	color: #333;
	text-align: center;
  word-break: break-all;
  overflow-wrap : break-word;
}

li{
	list-style: none;
}

a{
	text-decoration: none;
	color: inherit;
	display: block;
}

a:hover{
	opacity: 0.8;
}

/*a[href$=".pdf"]:after {
    content:" ";
    display: inline-block;
    width: 12px;
    height: 16px;
		background: url(/undergraduate/science/challengelabo/common/images/icon_pdf.gif) no-repeat;
		margin-left: 8px;
		vertical-align: text-top;
}*/

p{
	text-align: left;
	font-size: 16px;
	color: #3F3F3F;
	line-height: 180%;
}


/*
=========================================
	header
=========================================
*/ 

header{
	width: 1140px;
	margin: 25px auto;
	display: table;
}

.header_sp{
	display: none;
}

.header__logo{
	display: table-cell;
	vertical-align: middle;
}

.header__title{
	display: table-cell;
	vertical-align: middle;
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 0.09em;
	text-align: left;
	padding-left: 28px;
	font-feature-settings : "palt";
	color: #1E2626;
}

.header__sns{
	display: table;
}

.header__sns li{
	display: table-cell;
	vertical-align: middle;
}

.fb{
	padding: 0 30px;
}

/*
=========================================
	mainVisual,outline
=========================================
*/ 

.mainVisual{
	line-height: 0;
}

.mainVisual img{
	width: 100%;
	margin: 0 auto;
}

.outline{
	width: 1080px;
	margin: 0 auto;
	padding: 52px 0;
}

.outline p{
	text-align: center;
	font-size: 15px;
	line-height: 200%;
	letter-spacing: 0.02em;
	color: #1E2626;
}

.outlineBox{
	margin: 15px 0 0;
	border: 1px solid #ccc;
	padding: 15px;
	font-size: 15px;
line-height: 200%;
letter-spacing: 0.02em;
}

.outlineBox a {
    text-decoration: underline;
		display: inline;
}

/*
=========================================
	news
=========================================
*/ 

.news{
	background: #F0F4F5;
	padding: 60px 0 80px;
}

.h2area{
	text-align: center;
}

.h2area h2 {
	color: #999;
	font-size: 24px;
	letter-spacing: 2px;
	position: relative;
	display: inline-block;
	padding-bottom: 18px;
 }

.news .h2area h2::before {
 content: "";
 position: absolute;
 left: 0;
 right: 0;
 bottom: 0;
 border-bottom: 4px solid #CCC;
 width : 100% ;
 width : -webkit-calc(100% - 40px) ;
 width : calc(100% - 40px) ;
 margin: 0 auto;
 }
 
.news__lineBox{
	width: 1080px;
	margin: 55px auto 0;
	background: #fff;
	padding: 20px 45px;
	box-sizing: border-box;
	font-size: 15px;
line-height: 200%;
letter-spacing: 0.02em;
}

.news__lineBox strong{
		color: #ff0000;
		text-align: center;
        display: block;
}

.news__lineBox a {
    text-decoration: underline;
		display: inline;
}


 .newsList__inner{
	 	/*width: 960px;*/
		width: 1080px;
		margin: 55px auto 0;
		background: #fff;
		padding: 20px 45px;
		box-sizing: border-box;
 }
 
 .news__list ul li{
	padding: 20px 0;
	border-bottom: 2px solid #ccc;
 }
 
  .news__list ul li:last-child{
	border-bottom: none; 
 }
 
 .news__list dl{
	text-align: left;
	display: table;
	color: #1E2829;
 }
 
 .news__list dt{
	display: table-cell;
	font-size: 12px;
	font-weight: bold;
	letter-spacing: 0.01em;
 }
 
 .data{
	width: 125px;
 }
 
 .notice{
	width: 135px;
	color: #fff;

 }
 
 .notice span{
		font-size: 12px;
		border-radius: 5px;
		font-weight: normal;
 }
 
 .news__list dd{
	display: table-cell;
	width: 630px;
	font-size: 14px;
	line-height: 140%;
 }
 
 
 .pd_Brue{
	padding: 1px 20px;
 }
 
 .pd_Green{
	padding: 1px 20px;
 }
 
 .pd_Purple{
	padding: 1px 14px;
 }
 
 .news＿more{
	margin: 20px 0 15px;
 }
 
 .moreButton{
	width: 170px;
	margin: 0 auto;
	text-align: center;
	background: #ccc;
	color: #fff;
	border-radius: 30px;
	font-size:14px;
	font-weight: bold;
 }
 
 .open a{
 	 background: url(/undergraduate/science/challengelabo/common/images/downArrow.gif) no-repeat 20px 17px;
	 padding: 13px 0;
 }
 
 .close a{
 	 background: url(/undergraduate/science/challengelabo/common/images/upArrow.gif) no-repeat 20px 17px;
	 padding: 13px 0;
 }
 
 /*
=========================================
	event
=========================================
*/ 

 .event{
	 width: 960px;
	 margin: 0 auto;
	 padding: 0 0 20px;
 }
 
 .event .h2area h2::before {
 content: "";
 position: absolute;
 left: 0;
 right: 0;
 bottom: 0;
 border-bottom: 4px solid #CCC;
 width : 90% ;
 width : -webkit-calc(90% - 40px) ;
 width : calc(90% - 40px) ;
 margin: 0 auto;
 }
 
 .event h4{
	font-size: 16px; 
	font-feature-settings : "palt";
	margin-bottom: 5px;
 }
 
 .eventList{
	 margin-top: 60px;
 }
 
 .eventList__inner{
	 width: 460px;
 }
 
 .eventList dl{
	 display: table;
 }
 
 .eventList ul{
	margin-top: 30px; 
 }
 
 .eventList li{
	margin-bottom: 38px; 
 }
 
 .eventList dt{
	 display: table-cell;
	 vertical-align: top;
	 padding: 3px 15px 0 0;
 }
 
 .eventList dd{
	 display: table-cell;
	 vertical-align: top;
	 text-align: left;
	 font-size: 13px;
	 line-height: 140%;
	 overflow: hidden;
 }
 
 .eventList dt img{
	width: 80px;
	height: auto; 
 }
 
 .listLeft{
	float: left; 
 }
 
 .listRight{
	float: right; 
 }
 
 
 
  /*
=========================================
	eventReport
=========================================
*/ 
 
  .eventReport__inner {
    width: 1080px;
    margin: 0 auto 80px;
    border: 1px solid #cdcdcd;
    padding: 65px 59px 53px 59px;
    box-sizing: border-box;

    overflow:hidden;
    display: flex;
    flex-wrap: wrap;
  }
  .eventReport__inner .col {
    width: 50%;
  }
  .eventReport .h2area {
    width: 100%;
  }
  .eventReport h2{
    font-size: 25px;
  }
  .eventReport .h2area h2::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    border-bottom: 4px solid #CCC;
    width : 43% ;
    width : -webkit-calc(43% - 40px) ;
    width : calc(43% - 40px) ;
    margin: 0 auto;
  }
  /* .eventReport ul{
    display: table;
    margin: 34px auto 0;
  }
  .eventReport li{
    display: table-cell;
    width: 50%;
    vertical-align: top;
  }*/ 
  .eventReport ul{
    margin: 34px auto 0;
  }
  .eventReport li{
    width: 100%;
    padding: 0 0 3% 5%;
    box-sizing: border-box;
  }
  .eventReport li:last-child{
    padding: 0 0 0 5%;
  }
  .eventReport dl{
    display: table;
  }
  .eventReport dt{
    display: table-cell;
    vertical-align: top;
    padding-right: 15px;
  }
  .eventReport dd{
    display: table-cell;
    vertical-align: top;
    text-align: left;
    font-weight: bold;
    line-height: 150%;
  }
  .eventReport dd span{
    display: block;
    font-weight: normal;
    font-size: 80%;
    line-height: 1.5em;
  }
 
 
  
 
 /*
=========================================
	吹き出し
=========================================
*/  
 
 .ballBlue {
	font-size: 26px;
	position: relative;
	display: inline-block;
	padding: 12px 0;
	width: auto;
	min-width: 460px;
	border-radius: 5px;
	color: #FFF;
	line-height: 180%;
	text-align: center;
	background: #619DE5;
	z-index: 0;
	margin-bottom: 15px;
}
.ballBlue:after {
	content: "";
	position: absolute;
	bottom: -7px;
	left: 50%;
	margin-left: -15px;
	display: block;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 10px 15px 0 15px;
	border-color: #619DE5 transparent transparent transparent;
}

.ballGreen {
	font-size: 26px;
	position: relative;
	display: inline-block;
	padding: 12px 0;
	width: auto;
	min-width: 460px;
	border-radius: 5px;
	color: #FFF;
	line-height: 180%;
	text-align: center;
	background: #0EB191;
	z-index: 0;
	margin-bottom: 15px;
}

.ballGreen:after {
	content: "";
	position: absolute;
	bottom: -7px;
	left: 50%;
	margin-left: -15px;
	display: block;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 10px 15px 0 15px;
	border-color: #0EB191 transparent transparent transparent;
}

 /*
=========================================
	eventDetail
=========================================
*/ 
 
.eventDetail{
	background: #F9F8F4;
	padding: 80px 0 55px;
 }
 
 .eventDetail__inner{
	width: 960px;
	margin: 0 auto;
 }
 
 .listBox{
	background: #fff; 
	border: 2px solid #000;
	border-radius: 5px;
	padding: 20px;
	box-sizing: border-box;
	text-align: left;
	margin-bottom: 20px;
 }
 
 .imgBox{
	float: left;
	width: 240px;
 }
 
 .imgBox img{
	width: 240px;
	height: auto;
 }
 
 .imgBox span{
	position: absolute;
 }
 
 .imgBox .pd_Brue{
	 padding: 3px 20px;
 }
 
 .imgBox .pd_Green{
	 padding: 3px 20px;
 }
 
 .textBox{
	float: right;
	width: 655px;
	line-height: 180%;
 }
 
 .textBox h4{
	 font-size: 24px;
	 min-width: 40%;
	 float: left;
	 font-feature-settings : "palt";
	 margin-bottom: 10px;
 }
 
 .systemNotice{
	font-size: 14px; 
	min-width: 60%;
	float: right;
	color: #666;
 }
 
 .textBox dl{
	clear: both;
	
 }
 
 .textBox dt{
	margin-bottom: 5px;
	font-weight: bold;
 }
 
 .textBox dd{
	color: #1E2627;
	margin-bottom: 20px;
 }
 
 .textBox dd a{
	text-decoration: underline;
 }
 
 .app{
	margin: 20px 0 15px;
 }
 
 .appButton{
	width: 170px;
	margin: 0 auto;
	text-align: center;
	background: #ccc;
	color: #fff;
	border-radius: 30px;
	font-size:14px;
	font-weight: bold;
 }
 
 .appButton_oc{
	width: 300px;
	margin: 0 auto;
	text-align: center;
	background: #ccc;
	color: #fff;
	border-radius: 30px;
	font-size:14px;
	font-weight: bold;
 }
 
 .appButton a{
 	 background: url(/undergraduate/science/challengelabo/common/images/rightArrow.gif) no-repeat 145px 14px;
	 padding: 5px 10px 5px 0;
 }
 
 .appButton_oc a{
 	 background: url(/undergraduate/science/challengelabo/common/images/rightArrow.gif) no-repeat 270px 14px;
	 padding: 5px 10px 5px 0;
 }

.app2{
	margin: 20px 0 15px;
}
.app2 ul{
	display: table;
	line-height: 1.5;
	margin: 0 auto;
}
.app2 li{
	display: table-cell;
}
.app2 li:first-child{
	padding-right: 30px;
}





 
  /*
=========================================
	access
=========================================
*/ 

.access{
	padding: 60px 0 120px;
}

.access .h2area h2::before {
 content: "";
 position: absolute;
 left: 0;
 right: 0;
 bottom: 0;
 border-bottom: 4px solid #CCC;
 width : 75% ;
 width : -webkit-calc(75% - 40px) ;
 width : calc(75% - 40px) ;
 margin: 0 auto;
 }

.access__inner{
	width: 960px;
	margin: 0 auto;
}

.map{
	margin-top: 60px;
}

   /*
=========================================
	contact
=========================================
*/ 


.contact__inner{
	width: 960px;
	margin: 0 auto 120px;
}

.contact .h2area h2 {
	color: #999;
	font-size: 24px;
	letter-spacing: 2px;
	position: relative;
	display: inline-block;
	padding-bottom: 25px;
 }
 
.contact .h2area h2::before {
 content: "";
 position: absolute;
 left: 0;
 right: 0;
 bottom: 0;
 border-bottom: none;
 width : 90% ;
 width : -webkit-calc(90% - 40px) ;
 width : calc(90% - 40px) ;
 margin: 0 auto;
 } 
 
 .mail{
	 text-align: center;
	 font-weight: normal;
	 color: #1E2627;
 }
 
 
 .mail span{
	display: block;
	font-size: 16px;
	font-style: normal;
	color: #666;
	font-weight: bold;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	letter-spacing: 0.09em;
	margin-bottom: 10px;
 }
 
   /*
=========================================
	footer pageTop
=========================================
*/  
 
 footer{
	 background: #D0D4D7;
	 padding: 48px 0 37px;
 }
 
footer p{
	text-align: center;
	color: #3E4852;
}

footer p span{
	font-family:'Times New Roman', 'Times';	
}

.pageTop {
	clear: both;
	text-align: right;
	position: fixed;
	bottom: 70px;
	right: 20%;
}

.pageTop a:hover{
	opacity: 1;
}


/*
=========================================
	color
=========================================
*/

.bgBrue{
	background: #619DE5; 
 }
 
.bgGreen{
	background: #0EB191; 
 }
 
.bgPurple{
	background: #AD94C5; 
 }
 
.cBrue{
	color: #619DE5; 
 }
 
.cGreen{
	color: #0EB191; 
 }
 
 .cRed{
	color: #FF0000; 
 }
 
.bdBrue{
	border-color: #619DE5; 
 }
 
.bdGreen{
	border-color: #0EB191; 
 }
 
 
 
 
  /*
=========================================
	table
=========================================
*/

table{
	width: 570px;
	margin: 20px auto;
	color: #666;
	font-size: 14px;
}

table, td, th{
	border: 1px solid #CCC;
}

th{
	text-align: center;
	background-color: #F0F0F0;
	font-weight: normal;
}

td{
	padding: 0 10px;
}

table p{
	color: #666;
	font-size: 14px;
	margin-bottom: 10px;
}


 
 
 /*
=========================================
	flexBox
=========================================
*/
 
.flexBox {
	display: flex;
	justify-content: space-around;
	margin:20px auto 20px;
}

.flexBox span {
	color: #666;
	font-size: 12px;
	text-align: center;
	line-height: 150%;
}

.flexBox_img_3{
	width: 570px;
}

.flexBox_img_2{
	width: 440px;
}

.report .flexBox_img_2{
	width: auto;
}


/*
=========================================
	text-indent
=========================================
*/

.t-int_1{
	text-indent: -1em;
	margin-left: 1em;
}

.t-int_2{
	text-indent: -2em;
	margin-left: 2em;
}


/*
=========================================
	margin
=========================================
*/ 

.mt0{
	margin-top: 0 !important;
}
.mt5{
	margin-top: 5px !important;
}
.mt10{
	margin-top: 10px !important;
}
.mt15{
	margin-top: 15px !important;
}
.mt20{
	margin-top: 20px !important;
}

.mr0{
	margin-right: 0 !important;
}
.mr5{
	margin-right: 5px !important;
}
.mr10{
	margin-right: 10px !important;
}
.mr15{
	margin-right: 15px !important;
}
.mr20{
	margin-right: 20px !important;
}

.mb0{
	margin-bottom: 0;
}
.mb5{
	margin-bottom: 5px !important;
}
.mb10{
	margin-bottom: 10px !important;
}
.mb15{
	margin-bottom: 15px !important;
}
.mb20{
	margin-bottom: 20px !important;
}

.mb30{
	margin-bottom: 30px !important;
}

.mb35{
	margin-bottom: 35px !important;
}

.mb40{
	margin-bottom: 40px !important;
}

.mb50{
	margin-bottom: 50px !important;
}

.ml0{
	margin-left: 0;
}
.ml5{
	margin-left: 5px !important;
}
.ml10{
	margin-left: 10px !important;
}
.ml15{
	margin-left: 15px !important;
}
.ml20{
	margin-left: 20px !important;
}

.f65 {
    font-size: 65%;
}

.f70 {
    font-size: 70%;
}

.f75 {
    font-size: 75%;
}

.f80 {
    font-size: 80%;
}

.f85 {
    font-size: 85%;
}

.f90 {
    font-size: 90%;
}

.f95 {
    font-size: 95%;
}

.f100 {
    font-size: 100%;
}

.f110 {
    font-size: 110%;
}

.f120 {
    font-size: 120%;
}

.f130 {
    font-size: 130%;
}

.f140 {
    font-size: 140%;
}

/*
=========================================
	text-align
=========================================
*/ 

.tLeft {
    text-align: left !important;
}

.tRight {
    text-align: right !important;
}

.tCenter {
    text-align: center !important;
}


/*
=========================================
	float
=========================================
*/ 

.floatL {
    display: inline;
    float: left;
}

.floatR {
    display: inline;
    float: right;
}

.floatL-Object {
    margin: 0 30px 15px 0 !important;
}

.floatR-Object {
    margin: 0 0 20px 20px !important;
}