@charset "utf-8";
/* メインヴィジュアル */
.mainvisual{
    overflow: hidden;
    width: 100%;
    max-height: 700px;
    object-fit: cover;
}

.mainvisual picture{
    position: relative;
}

.mainvisual img{
    display: block;
    width: 100%;
}
.mainvisual picture::after{
  content: '';
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(rgba(0,0,0,0.4) 0%,rgba(0,0,0,0.0) 100%);
}
.sp_br{
    display: none;
}

/* お知らせ */
.news{
	margin: 10px 0 50px 0;
}
.news a{
 text-decoration: none;
}
.news .container{
	display: block;
	background-color: #fff;
}


.news .news_sec1{
	text-align: center;
	margin: 50px 0 0 0;
}
.news .news_sec1 p{
	font-size: 1.0rem;
  font-weight: 700;
  font-style: normal;
	color: #7da0c8;
}
.news .news_sec1 h2{
	font-size: 1.8rem;
  font-weight: 700;
  font-style: normal;
	color: #0b4589;
}
.news_sec1_btn{
	text-align: center;
}
.news_sec1_btn a img{
	width: 220px;
}
.news .news_sec1 a img{
	width: 220px;
}

.news .news_area{
	width: 100%;
}

.news_container{
    height: auto;
    margin: auto;
    padding: 50px 10px 20px;
    position: relative;
}
.news_list{
    margin: auto;
}
.news_list li{
    margin: 0 0 20px 0;
		list-style: none;
}
.news_list a{
    display: flex;
		align-items: center;
}
.press{
    width: 18%;
		font-size: 0.9rem;
    color: #fff;
		background: var(--text-color);
    display: inline-block;
		border-radius: 6px;
		padding: 6px 0 8px 0;
		text-align: center;
		margin: 0 30px 0 0;
}
.news_time{
    width: 15%;
		font-size: 0.9rem;
    color: #999999;
    display: inline-block;
		padding: 10px;
		text-align: right;
		margin: 0 10px 0 0;
}

.news_ttl{
    width: 65%;
		font-size: 1.0rem;
}


/* 上廣海洋学講座について */
.about{
	background: url("/wp-content/themes/tpl-ulo.fish.hokudai.ac.jp-ver1.02/module/img/index/sec2_bg.png");
	background-size: cover;
	min-height: 600px;
	box-sizing: border-box;
	padding:  40px 0 0 0;
}
.about .container{
	display: flex;
	flex-wrap: wrap;
	padding:  0 0 80px 0;
}

.about .about_sec1_tit{
	text-align: center;
	margin: 50px 0 0 0;
}
.about .about_sec1_tit p{
	font-size: 1.0rem;
  font-weight: 700;
  font-style: normal;
	color: #FFFFFF;
}
.about .about_sec1_tit h2{
	font-size: 1.8rem;
  font-weight: 700;
  font-style: normal;
	color: #0b4589;
	margin-bottom: 20px;
}

.about .about_sec1{
	width: 30%;
}
.about .about_sec1 h2{
	font-size: 4vw;
  font-family: "Archivo Black", sans-serif;
  font-weight: 400;
  font-style: normal;
	color: #FFF;
}
.about .about_sec1_img{
	width: 100%;
}
.about .about_sec1_img img{
	width: 100%;
}

.about .about_sec2{
	padding: 0 0 0 3%;
  width: 70%;
}
.about .about_sec2 h2{
	font-size: 1.8rem;
  font-weight: 400;
  font-style: normal;
	color: #FFF;
	margin: 0 0 20px 0;
}
.about .about_sec2_txt{
	color: #FFF;
	margin: 0 0 20px 0;
	line-height: 2rem;
}
.about_sec2_btn{
	width: 100%;
	text-align: center;
}
.about_sec2_btn img{
	max-width: 220px;
}


/* メンバー */
.member{
	margin: 50px 0 0 0;
}
.member .member_sec1{
	text-align: center;
	margin: 0 0 50px 0;
}
.member .member_sec1 p{
	font-size: 1.0rem;
  font-weight: 700;
  font-style: normal;
	color: #7da0c8;
}
.member .member_sec1 h2{
	font-size: 1.8rem;
  font-weight: 700;
  font-style: normal;
	color: #0b4589;
}
.member .member_sec2 ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.member .member_sec2 ul li{
	display: block;
	width: 19%;
	margin: 0 2% 50px 2%;
	height: auto;
	text-align: center;
}
.member .member_sec2 ul li img{
	width: 100%;
	height: auto;
	border-radius: 1rem;
}


/* お問い合わせ */
.contact{
	margin: 100px 0 0 0;
	padding: 100px 0 100px 0;
	background: #f5f5f5;
}
.contact .contact_sec1{
	text-align: center;
	margin: 0 0 30px 0;
}
.contact .contact_sec1 p{
	font-size: 1.0rem;
  font-weight: 700;
  font-style: normal;
	color: #7da0c8;
}
.contact .contact_sec1 h2{
	font-size: 1.8rem;
  font-weight: 700;
  font-style: normal;
	color: #0b4589;
}
.contact .contact_sec2{
	text-align: center;
}
.contact .contact_sec2 p{
	font-size: 1.2rem;
  font-weight: 500;
  font-style: normal;
	color: #0b4589;
	margin: 0 0 20px 0;
}
.contact .contact_sec2 p{
	font-size: 1.2rem;
  font-weight: 500;
  font-style: normal;
	color: #0b4589;
	margin: 0 0 20px 0;
}
.contact .contact_sec2 .contact_sec2_btn{
	display: inline-block;
	width: 220px;
}
.contact .contact_sec2 .contact_sec2_btn img{
	width: 100%;
	height: auto;
}


.slogan{
    position: absolute;
    width: 100%;
    top: 100px;
    left: 65%;
    -ms-transform: translate(-50%,0);
    -webkit-transform: translate(-50%,0);
    transform: translate(-50%,0);
    z-index: 150;
    color: #ffffff;
    text-align: left;
}

.slogan p{
    font-size: clamp(1.2rem, 0.14rem + 2.84vw, 2.25rem);
    font-weight: 500;
    color: #ffffff;
    text-shadow: 1px 1px 5px #000;
    letter-spacing: 2px;
		line-height: 4rem;
}

.slogan p:last-child{
    font-size: clamp(1.5rem, 0.14rem + 2.84vw, 2.25rem);
}


/* フェードイン */
.fadein{
    transition: all 0.8s linear 0.1s;
    transform: translate3d(0, 0, 0);
}

/* SPレスポンシブ */

@media screen and (max-width:767px) {
/* SPメインヴィジュアル */

/* SPメインヴィジュアル */
.mainvisual{
    aspect-ratio: 75 / 56;
    object-fit: contain;
}
	
.section_ttl {
    width: 32%;
    max-width: 142px;
    margin: 0 auto;
}
	
/* SPお知らせ */

/* お知らせ */
.news{
	margin: 10px 0 50px 0;
}
.news .container{
	flex-wrap: wrap;
	flex-direction:column-reverse;
}
.news .news_sec1{
	width: 100%;
	display: block;
	text-align: center;
}

.news .news_sec1 h2{
	font-size: 1.4rem;
}
	
.news .news_sec1 a img{
	width: 220px;
	margin: auto;
}

.news .news_area{
	width: 100%;
}
.news_container {
	padding: 20px 10px 20px;
}
.news_list a{
    display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
}
.press{
    width: 50%;
    color: var(--text-color);
		background: #FFF;
    display: inline-block;
		text-align: left;
}
.news_time{
    width: 35%;
		font-size: 1rem;
    color: #999999;
    display: inline-block;
		padding: 10px 0;
		text-align: left;
		margin: 0 10px 0 0;
}

.news_ttl{
    width: 100%;
		font-size: 1rem;
}


/* 上廣海洋学講座について */
.about{
	min-height: 800px;
}
.about .container{
	display: block;
	flex-wrap: wrap;
	padding: 10px 10px 50px 10px;
	text-align: center;
}
.about .about_sec1{
	width: 100%;
}
.about .about_sec1_img img{
	width: 70%;
}
.about .about_sec1 h2{
	font-size: 8vw;
}
.about .about_sec2 h2{
	font-size: 1.4rem;
}
.about .about_sec2{
	width: 100%;
}
.about .about_sec1_tit h2{
	font-size: 1.4rem;
}
	
/* メンバー */
.member .member_sec2 ul li{
	width: 28%;
}

.member .member_sec1 h2{
	font-size: 1.4rem;
}

.contact .contact_sec1 h2{
	font-size: 1.4rem;
}

.slogan{
    top: 25%;
	left: 55%;
}

.slogan p{
	font-size:100%;
    /*font-size: clamp(1.563rem, 0.785rem + 3.32vw, 2.375rem);*/
    /*font-size: clamp(1.125rem, 0.587rem + 2.3vw, 1.688rem);
    letter-spacing: 2px;*/
    letter-spacing: 1px;
		line-height: 2rem;
}

.slogan p:last-child{
	font-size:100%;
  /*  font-size: clamp(1.125rem, 0.587rem + 2.3vw, 1.688rem);*/
    letter-spacing: 1px;
}

/* SPお知らせ */


}