/* 
Theme Name: YASUI  2
Theme URI: 
Description:Yasui Labのテーマです
Version:1.1
 */


@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap');

body{
    background-color: #EFEFEF;
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
font-weight: 400;
font-style: normal;
	color: #000;
	font-size:14px;
	line-height:1.9;
	font-style: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%; 
		text-align: justify; 
}

.wrapper{
	width: 100%;	
	margin: 0 auto;
}
p{
	text-align: left;
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
	font-weight: 400;
	text-align: justify; 
}

h2{
	font-size:37px;
	font-family: "urw-din", sans-serif;
	font-weight: 100;
	text-align: center;
	text-transform: uppercase;
}
h3{
	font-size:37px;
	font-family: "urw-din", sans-serif;
	font-weight: 100;
	text-align: left;
	border-bottom:1px solid #c5c5c5;
	text-transform: uppercase;
	margin: 20px auto 20px;
}
h4{
	font-size:20px;
	line-height: 1.5;
	font-family: "urw-din", sans-serif;
	font-weight: 600;
	text-align: left;
	margin: 0 auto 10px;
}
a{
	color: rgba(0,0,0, 0.8);
	word-break :break-all;
	text-decoration: none;
}
.news-title a{
word-break: normal;
}

/* フッター */
footer{
	text-align: center;
	background:linear-gradient(135deg, #B1B5BC, #73767B);
	padding:84px 0 20px 0;
}
footer p,address{
	text-align: center;
}
footer h1 img{
	width:230px;
	height: auto;
	padding: 0 0 63px;
}
address{
	font-size:0.86rem;
	color:#fff;
	font-style:normal;
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
font-weight: 400;
	margin: 0 auto 15px;
}
.copyr{
	font-size:0.642rem;
	font-family: "urw-din", sans-serif;
	font-weight: 400;
	font-style: normal;
	color:#b5b7bc;
}

@media only screen and (max-width:796px) {
	h3{
		font-size:30px;
		margin: 10px auto;
	}
	footer h1 img{
		width:146px;
		height: auto;
		padding: 0 0 63px;
	}
	address{
		font-size:9px;
	}
}


/*===========================================================*/
/* トップページ */
/*===========================================================*/

.pickup_Wrap{
	width: 100%;	
	max-width:970px;
	margin: 0 auto;
	text-align: center;
	padding: 85px 0 60px;
}
#wrap {
	max-width: 100%;
	height:100vh;
	margin: 0 auto;
	background:linear-gradient(135deg, #B1B5BC, #73767B);
  }

.tmovie{
	width:47%;
	height: auto;
	margin:0 auto;
	padding:140px 0;
  }
  @media only screen and (max-width: 768px) {
.tmovie{
		width:100%;
		height: auto;
		margin:0 auto;
		padding:160px 0;
	  }
}

/* pick up news */
.pickup_Wrap h2{
	text-align: left;
	font-size:2.64rem;
	line-height: 2.4;
	font-family: "urw-din", sans-serif;
	font-weight: 100;
	font-style: normal;
	border-bottom: 1px solid #c5c5c5;
}
.news-link{
	border-bottom: 1px solid #c5c5c5;
	margin:26px auto;
	padding:0 0 26px 0;
}
.news-title{
	font-size:20px;
	line-height:1.5;
	font-weight: 500;
		margin-bottom:10px;
}
.news-data{
	font-size:17px;
	font-family: "urw-din", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height:1.5;
}
.news-honbun{
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
font-weight: 400;
	font-style: normal;
}
.news-doi{
	font-family: "urw-din", sans-serif;
	font-weight: 300;
	font-style: normal;
	margin: 6px auto 0;
}
.news-doi a{
	text-decoration: underline;
	color:#000;
}
.new-info{
	display: flex;
	justify-content: space-between;
	margin: 15px 0 0 0;
}
.news-category{
	font-family: "urw-din", sans-serif;
	font-weight: 400;
	font-style: normal;
	padding:2px 20px;
	border:1px solid #000;
	border-radius: 20px;
	text-transform: uppercase;
}
.buttan-rmore{
	font-family: "urw-din", sans-serif;
	font-weight: 300;
	font-style: normal;
	font-size:18px;
	color:#000;
}
.buttan-rmore a{
	color:#000;
	text-decoration: underline;
}

a:hover{
	opacity: 0.7;
}

@media only screen and (max-width:796px) {
	.pickup_Wrap{
		width: 90%;
		margin: 0 auto;
		text-align: center;
		padding: 40px 0 40px;
	}
	.pickup_Wrap h2{
		text-align: left;
		font-size:2rem;
		font-family: "urw-din", sans-serif;
		font-weight: 100;
		font-style: normal;
		border-bottom: 1px solid #c5c5c5;
	}
	.news-title{
		font-size:16px;
		font-weight: bold;
	}
	.news-link{
		border-bottom: 1px solid #c5c5c5;
		margin:20px auto;
		padding:0 0 20px 0;
	}
}


/*===========================================================*/
/* スクロール途中からリンクボタンの形状が変化 */
/*===========================================================*/

/*スクロールリンクの形状*/
.scroll-top {
	/*表示位置*/
	position: fixed;
	left: 50%;
	transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	
	bottom: 10px;
	z-index: 2;
	/*はじめは非表示*/
	opacity: 0;
	visibility: hidden; 
	transition: opacity .5s, visibility .5s; /*それぞれに0.5秒の変化のアニメーション*/
	/*縦書き*/
	/*-webkit-writing-mode: translateX(-50%);
    -ms-writing-mode: translateX(-50%);
    writing-mode: vertical-rl;*/
	/*改行禁止*/
    white-space: nowrap;
	/*矢印の動き*/
	animation: arrowmove 1s ease-in-out infinite;
}

@keyframes arrowmove{
      0%{bottom:75px;}
      50%{bottom:80px;}
     100%{bottom:75px;}
 }

/*.scroll-viewクラスがついたら出現*/
.scroll-top.scroll-view {
	opacity: 1;
	visibility: visible;
}

/*リンク全体の aタグの形状*/
.scroll-top a {
    position: relative;
	text-decoration: none;
	color: #fff;
	text-transform: uppercase;
	font-size:0.8rem;
    letter-spacing: 0.05em;
    display: block;
}

/*スクロールリンクの形状*/
.js-scroll.scroll-top a{
    color: #fff;
}
.js-scroll a::after{
	content:"";
	position: absolute;
	top:-20px;
	left:9px;
	width:1px;
	height: 16px;
	background:#fff;
	transform: skewX(62deg);
}
.js-scroll a::before {
    content: "";
    position: absolute;
    top:-20px;
    right: 9px;
    width: 1px;
    height: 16px;
    background: #fff;
    transform: skewX(-62deg);
}

/*Edge IE11 hack*/
_:-ms-lang(x), .js-scroll a::before{
	right:0px;
}

/*ページトップリンクの形状*/
.js-pagetop a::after{
	content:"";
	position: absolute;
	top:-20px;
	left:16px;
	width:1px;
	height: 16px;
	background:#fff;
	transform: skewX(-62deg);
}
.js-pagetop a::before {
    content: "";
    position: absolute;
    top:-20px;
    right: 16px;
    width: 1px;
    height: 16px;
    background: #fff;
    transform: skewX(62deg);
}

/*Edge IE11 hack*/
_:-ms-lang(x), .js-pagetop a::before{
	right:0;
}

/*===========================================================*/
/* VISION */
/*===========================================================*/
.vision-tp{
	max-width:767px;
	margin: 0 auto;
	padding:70px 0 70px;
}
.vision-img{
	text-align: center;
}
.vision-img img{
	padding: 20px 0;
}
.vision-tp a{
 text-decoration: underline;
}
@media only screen and (max-width:796px) {
	.vision-tp{
		width:90%;
		margin: 0 auto;
		padding:40px 0;
	}
	.vision-img img{
		width:100%;
		height: auto;
		padding: 20px 0;
	}
}

/*===========================================================*/
/* RESEARCH */
/*===========================================================*/
.research-tp{
	max-width:970px;
	margin: 0 auto;
	padding:70px 0 70px;
}
.read{
	margin:40px auto;
}
.motto{
	font-size:25px;
	font-family: "urw-din", sans-serif;
	font-weight:300;
	text-align:center;
	margin-top: 20px;
}
.anchor-link{
	width: 100%;
}
.anchor-label{
	font-size:17px;
	font-family: "urw-din", sans-serif;
	font-weight:400;
	text-transform: uppercase;
}
.alist {
	display: flex;
	margin: 0 auto 60px;
}
.alist li{
	margin: 10px 10px 0 0;
	list-style: none;
}
.research-tp h3{
	border-bottom:none;
	margin:40px auto 20px;
}
.research-img img{
	width: 167px;
	height: auto;
	margin: 0 0 0 35px;
}
.re-tbox{
	display: flex;
	border-top:1px solid #c5c5c5;
	padding:20px 0 0 0;
	margin: 10px auto 0;
}
.re-tbox a{
	text-decoration: underline;
}
.re-txt-box{
	margin:0 auto 20px	
}
a.button-alink{
	background-color:#fff;
	width:170px;
	border-radius: 30px;
	font-size:17px;
	line-height: 44px;
	font-family: "urw-din", sans-serif;
	font-weight:400;
	text-transform: uppercase;
	text-align: center;
	display: block;
	text-decoration: none;
	padding: 0;
	border: 1px solid #fff;
}

a.button-alink:hover{
	background-color: #000;
	color:#fff;
}

.current a.button-alink{
	background-color:#000;
	color:#fff;
}

a.button-alink2{
	background-color:#fff;
	border-radius: 30px;
	font-size:17px;
	line-height: 44px;
	font-family: "urw-din", sans-serif;
	font-weight:400;
	text-transform: uppercase;
	text-align: center;
	display: block;
	text-decoration: none;
	padding: 0;
	border: 1px solid #fff;
	padding:0 20px;
}

a.button-alink2:hover{
	background-color: #000;
	color:#fff;
}
.current a.button-alink2{
	background-color:#000;
	color:#fff;
}


@media only screen and (max-width:970px) {
	.research-tp{
		width:90%;
		margin: 0 auto;
		padding:35px 0;
	}
}
@media only screen and (max-width:796px) {
	.read{
		margin:20px auto;
	}
.motto{
	font-size:22px;
	font-family: "urw-din", sans-serif;
	font-weight:400;
	margin-top:0;
}
	.re-tbox{
		flex-wrap: wrap;
	}
	.research-img{
		width: 100%;
	}
	.research-img img{
		width: 100%;
		height: auto;
		margin: 20px 0 0 0;
	}
	.alist {
		display: flex;
		margin: 0 auto 30px;
	}
	.alist li{
		margin: 10px 10px 0 0;
		width: 33%;
	}
	a.button-alink{
		background-color:#fff;
		width:100%;
		border-radius: 20px;
		font-size:12px;
		line-height: 27px;
		font-family: "urw-din", sans-serif;
		font-weight:400;
		text-transform: uppercase;
		text-align: center;
		display: block;
		text-decoration: none;
		border: 1px solid #fff;
		padding:2px;
	}
	
	a.button-alink:hover{
		background-color: #000;
		color:#fff;
	}
	.alist li{
		margin: 10px 10px 0 0;
		width: 33%;
	}

	a.button-alink2{
		background-color:#fff;
		width:100%;
		border-radius: 20px;
		font-size:12px;
		line-height: 27px;
		font-family: "urw-din", sans-serif;
		font-weight:400;
		text-transform: uppercase;
		text-align: center;
		display: block;
		text-decoration: none;
		border: 1px solid #fff;
		padding:0 20px;
	}
	
	a.button-alink2:hover{
		background-color: #000;
		color:#fff;
	}
}
/*===========================================================*/
/* PUBLICATIONS */
/*===========================================================*/

.flist {
	display: flex;
	margin: 0 auto 60px;
}
.flist li{
	margin: 10px 10px 0 0;
	list-style: none;
}
.pub-flist{
	margin: 40px auto;
}
.pub-img {
	margin: 0 35px 0 0;
	aspect-ratio:1 / 1;
}
.pub-img img{
	width: 167px;
	height: auto;
	background-color:#fff;
	vertical-align:top;
}
.pub-f{
	margin: 0 auto 30px;
}

@media only screen and (max-width:796px) {
	.pub-img {
		width: 90px;
		height: 90px;
		margin: 0 0 10px;
	}
	.pub-img img{
		width: 100%;
		height: auto;
		object-fit: cover;
		object-position: 100% 100%;
		margin: 0;
	}
	.flist {
		display: flex;
		flex-wrap: wrap;
		margin: 0 auto 30px;
	}
	.flist li{
		margin: 10px 10px 0 0;
		width: 30%;
	}
}

/*===========================================================*/
/* NEWS */
/*===========================================================*/

.news-flist{
	margin: 40px 0 0 0;
	border-bottom: 1px solid #c5c5c5;
}

/* NEWS singleページ */
.news-single-tp{
	width: 790px;
	margin: 0 auto;
	padding:70px 0 70px;
}
.t-date{
	font-size:16px;
	font-family: "urw-din", sans-serif;
	font-weight: 500;
	margin:100px 0 10px 0;
}
.news-title-s{
	font-size:21px;
	font-weight: bold;
	line-height: 1.8;
	border-bottom: 1px solid #000;
	padding:0 0 20px 0;
	margin: 0 0 20px 0;
}

.article-field{
	padding: 10px 0 0 0;
}

.article-field h2{
	font-size:17px;
	font-weight: bold;
	border-bottom: 1px solid #A8A8A8;
	text-align: left;
	margin: 30px 0 10px 0;
	padding: 0 0 10px 0;
}
.article-field p{
	margin: 10px auto;
}
.article-field p b, strong{
 font-weight:bold;
}

.article-field img{
	max-width: 790px;
	height: auto;
}
.article-field .wp-block-image img{
	max-width: 790px;
	height: auto;
	margin: 10px auto;
}
@media only screen and (max-width:790px) {
	.article-field img{
		width: 100%;
		height: auto;
	}
	.article-field .wp-block-image img{
		width: 100%;
		height: auto;
	}

}
.news-link-a{
	display: flex;
	justify-content: center;
	margin: 60px auto 40px;
}
.news-link-a a{
	text-decoration: none;
	font-size:17px;
	font-family: "urw-din", sans-serif;
	font-weight: 400;
}
.article-field a{
	color:#1D60DD;
	text-decoration: underline;
	text-decoration-color: #1D60DD;
	font-weight: bold;
}

.article-field .wp-block-embed-youtube{
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	margin: 10px auto;
}

.article-field .wp-block-embed-youtube iframe{
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
	}
@media only screen and (max-width:796px) {
	.news-single-tp{
		width:90%;
		margin: 0 auto;
		padding:40px 0;
	}
	.t-date{
		font-size:16px;
		font-family: "urw-din", sans-serif;
		font-weight: 500;
		margin:40px 0 10px 0;
	}
}

/*===========================================================*/
/* MEMBERS */
/*===========================================================*/
h3.memb_pro{
	border-bottom:1px solid #c5c5c5;
}
.mem-all-img img{
	max-width: 970px;
	width: 100%;
	height: auto;
	margin: 50px auto;
}
.mem-boxes{
	display: flex;
	flex-wrap: wrap;
}
.memb-box{
	width: 31%;
	margin: 0 20px 20px 0;
}
.memb-box:nth-child(3n){
	width: 31%;
	margin: 0 0 20px;
}
.mem-img img{
	width: 100%;
	height:auto;
}
.mem-title span{
	font-size:16px;
	line-height: 1.5;
	font-family: "urw-din", sans-serif;
	font-weight: 300;
	color: rgba(0,0,0, 0.8);
}
.mem-name{
	font-size:16px;
	line-height: 1;
	line-height: 1.8;
}
.mem-name span{
	font-size:23px;
	line-height: 1.8;
	font-family: "urw-din", sans-serif;
	font-weight: 300;
	color: rgba(0,0,0, 0.8);
}
.mem-info{
	line-height: 1.5;
	color:#838383;
}
.mlist {
	display: flex;
	margin: 0 auto 60px;
}
.mlist li{
	margin: 10px 10px 0 0;
	list-style: none;
}

@media only screen and (max-width:796px) {
	.mem-boxes{
		justify-content: space-between;
	}
	.memb-box{
		width: 44%;
		margin: 0 20px 20px 0;
	}
	a p.mem-title{
		text-decoration: none;
	}
	.memb-box:nth-child(3n){
		width: 44%;
		margin: 0 20px 20px 0;
	}
	.mlist {
		display: flex;
		flex-wrap: wrap;
		margin: 0 auto 30px;
	}
	.mlist li{
		margin: 10px 10px 0 0;
	}
	.mem-title{
		font-size:8px;
	}
	.mem-title span{
		font-size:10px;
	}
	.mem-name{
		font-size:10px;
	}
	.mem-name span{
		font-size:13px;
	}
	.mem-info{
		font-size:8px;
		color:#838383;
	}
	.mem-all-img img{
	margin: 0 auto;
}
}
/* MEMBERS singleページ */
.mem-s-box{
	margin: 70px 0 30px;
	display: flex;
}
.mem-s-img{
	width: 314px;
	height: 210px;
	margin: 0 48px 0 0;
}
.mem-s-img img{
	width: 100%;
	height: auto;
	object-fit: cover;
}

@media only screen and (max-width:790px) {
	.mem-s-box{
		margin: 30px 0 20px;
		display: flex;
	flex-wrap: wrap;
	}
	.mem-s-img{
		width: 100%;
		height: auto;
		margin: 0;
	}
	.mem-s-txt .mem-title{
		font-size:14px;
	}
	.mem-s-txt .mem-title span{
		font-size:16px;
	}
	.mem-s-txt .mem-name{
		font-size:16px;
	}
	.mem-s-txt .mem-name span{
		font-size:23px;
	}
	.mem-s-txt .mem-info{
		font-size:14px;
}
}
/*===========================================================*/
/* CONTACT */
/*===========================================================*/
.contact-tp{
width: 720px;
margin: 70px auto 70px;	
}
.contact-form{
	margin: 85px 0 20px
}
.contact-form p{
	font-size:15px;
	font-weight: bold;
	margin: 0 0 10px 0;
}

.wpcf7-text, .wpcf7-textarea{
	background-color: #fff;
	width: 100%;
	padding:20px;
	margin: 0 0 30px 0;
	border-radius: 8px;
}

.button-viewall{
	font-family: "urw-din", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size:17px;
	width: 170px;
	background-color: #000;
	border-radius: 30px;
	color:#fff;
	display: block;
	margin: 0 auto;
	text-align: center;
	text-decoration: none;
	padding: 5px 0;
	border: 1px solid #000;
}

.button-viewall:hover{
	background-color: #fff;
	color:#000;
}

@media only screen and (max-width:720px) {
	.contact-tp{
		width: 90%;
		margin: 30px auto 60px;	
		}
		.contact-form{
			margin: 40px 0 0;
		}
	.wpcf7-text, .wpcf7-textarea{
	background-color: #fff;
	width: 100%;
	padding:10px;
	margin: 0 0 20px 0;
	border-radius: 8px;
}

	
}

.grecaptcha-badge { visibility: hidden; }