@charset "utf-8";
/* # =================================================================
   # ページ共通設定
   # ================================================================= */
/* フォードイン設定 */
.scroll-fade{opacity: 0; transition: all 2s/*処理にかかる時間*/; }
.scroll-up{opacity: 0; transform: translateY(100px)/*スクロールアップする距離*/; transition: all 2s/*処理にかかる時間*/; }
.scroll-up.done, .scroll-fade.done{opacity : 1; transform : translate(0, 0);}
.scroll-up1{opacity: 0; transform: translateY(100px)/*スクロールアップする距離*/; transition: all 1s/*処理にかかる時間*/; }
.scroll-up1.done, .scroll-fade.done{opacity : 1; transform : translate(0, 0);}
.scroll-up2{opacity: 0; transform: translateY(100px)/*スクロールアップする距離*/; transition: all 2s/*処理にかかる時間*/; }
.scroll-up2.done, .scroll-fade.done{opacity : 1; transform : translate(0, 0);}
.scroll-up3{opacity: 0; transform: translateY(100px)/*スクロールアップする距離*/; transition: all 3s/*処理にかかる時間*/; }
.scroll-up3.done, .scroll-fade.done{opacity : 1; transform : translate(0, 0);}
.load-fade {opacity : 0; transition : all 2s/*処理にかかる時間*/;}
.load-up{opacity: 0; transform: translateY(100px)/*スクロールアップする距離*/; transition: all 2s/*処理にかかる時間*/;}
.load-up.done, .load-fade.done{opacity : 1; transform : translate(0, 0);}

/*--------------------------------------------------------
  .news
--------------------------------------------------------*/
header {
	border-bottom: 1px solid var(--blue1);
}
#contents {
	padding-bottom: 50px;
}
#contents h2 {
	font-size: 28px;
	font-weight: bold;
	font-family: "M PLUS 1", sans-serif;
	color: var(--blue1);
	border-bottom: 3px solid var(--blue1);
	width: 90%;
	margin: 50px auto;
	padding-bottom: 30px;
}
section {
	padding: 50px 0 50px 0;
	font-family: "M PLUS 1", sans-serif;
	letter-spacing: 0.01em;
	background-color: var(--yellow1);
	margin-top: 70px;
}


.news {
	
}
.newsBlock h2 {
	font-family: "M PLUS 1", sans-serif;
	font-weight: bold;
	font-size: clamp(4.375rem, 2.941rem + 5.88vw, 6.25rem); /*900-100->390-70*/
	display: block;
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	color: var(--blue4);
}
.newsBlock h2 strong {
	display: block;
	width: 90%;
	max-width: 900px;
	margin: -50px auto 50px auto;
	font-size: clamp(2.25rem, 1.676rem + 2.35vw, 3rem);/*900-48->390-36*/
	color: #000;
	font-weight: bold;
	border-bottom: 1px solid #000;
}

.newsBlock section > h3 {
	background-color: var(--blue1);
	color: #FFF;
	font-weight: bold;
	font-size: clamp(1.25rem, 0.963rem + 1.18vw, 1.625rem);/*900-26->390-20*/
	line-height: 1;
	padding: 8px 30px 10px 30px;
	text-align: center;
	display: inline-block;
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	margin: 30px auto 30px auto;
}
@media screen and (max-width:750px) {
	.news h2 strong {
	width: 94%;
	}
	.company section > h3 {
	margin: 0px auto 30px auto;
	}
}

.newsBlock {
	width: 100%;
	font-family: "M PLUS 1", sans-serif;
	padding-bottom: 50px;
	position: relative;
	z-index: 0;
}
.newsBlock > a {
	color:  var(--yellow1) !important;
	margin: 0 !important;
}
.newsBox {
	width: 100%;
	background: var(--yellow1);
	max-width: 100%;
	margin: 0 auto 0 auto;
	display: block;
	padding: 50px 0 50px 0;
}

.newsBlock ul.news {
	width: 100%;
	max-width: 900px;
	margin: 0 auto;
	padding: 0px 10px 0 10px;
	display: block;
	overflow: hidden;
}

.newsBlock ul.news li {
	width: 100%;
	padding: 10px;
	float: none;
	border-bottom: 1px dotted #999;
}
.newsBlock ul.news li:hover {
	background: var(--yellow2);
}
.newsBlock ul.news li:nth-child(1) {
}
.newsBlock ul.news li a {
	display: block;
    transition: 0.5s;
}
.newsBlock ul.news li a:hover {
     color: var(--blue1);
}
.newsBlock ul.news li.title strong {
	font-size: 24px;
}
.newsBlock ul.news li.title img.line {
	width: 80%;
	display: block;
	margin-bottom: 10px;
}
.newsBlock ul.news li.title > img.illust01 {
	width: 80px;
	display: block;
	margin-top: 15px;
	margin-left: 0px;
	margin-bottom: 30px;
}
.newsBlock ul.news li.title a {
	display: none;
}
.newsBlock ul.news li span.up_ymd {
	font-size: 12px;
	display: block;
	text-align: left;
	color: var(--blue1);
	font-weight: normal;
	padding-top: 10px;
	font-family: "Murecho", serif;
}
.newsBlock ul.news li span.thumbNailWrap {
	width: 80px;
	height: 80px;
	display: inline-block;
	float: left;
	padding: 5px 10px 10px 0;
}
.newsBlock ul.news li span.thumbNailWrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 100px;
}
.newsBlock ul.news li span.title {
	width: 100%;
	max-width: 100%;
	font-size: clamp(0.875rem, 0.684rem + 0.78vw, 1.125rem);/*900-18->390-14*/
	padding-top: 10px;
	padding-bottom: 5px;
	display: block;
	text-align: left;
	font-weight: bold;
	color: var(--green1);
}
.newsBlock ul.news li span.comment {
	width: 100%;
	font-size: 12px;
	display: none;
	text-align: left;
	margin-bottom: 20px;
}

/************************************************************************************************************************************************************************************
     ニュース詳細ページ
************************************************************************************************************************************************************************************/
.newsDetail {
	width: 100%;
	background: var(--yellow1);
	max-width: 100%;
	margin: 0 auto 0 auto;
	display: block;
	padding: 20px 0 50px 0;
}
.newsDetail .newsDetailBox {
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
	padding: 0px 10px 0 10px;
	display: block;
	overflow: hidden;
}
.newsDetail .newsDetailBox a {
	color: var(--yellow1) !important;
}
.newsDetail .newsDetailBox .pNav {
	color: #999;
}
.newsDetail .newsDetailBox .pNav a {
	color: var(--blue1) !important;
	text-decoration: underline;
}
.newsDetail .newsDetailBox .pNav a:hover {
	color: #000;
	background-color: var(--yellow2);
}

.newsDetail .newsDetailBox h3 {
	color: #000;
	font-weight: bold;
	font-family: "M PLUS 1", sans-serif;
	font-size: clamp(1.25rem, 0.963rem + 1.18vw, 1.625rem);/*900-26->390-20*/
	font-size: clamp(1.125rem, 0.838rem + 1.18vw, 1.5rem);/*900-24->390-18*/
	padding-top: 20px;
	text-align: left;
	letter-spacing: -0.01em !important;
}

.newsDetail .newsDetailBox #up_ymd {
	font-size: 14px;
	display: block;
	text-align: right;
	color: var(--blue1);
	font-weight: normal;
	padding-top: 10px;
}
.newsDetail .newsDetailBox .detailUpfile {
	padding: 15px 0 15px 0;
}
.newsDetail .newsDetailBox .detailUpfile img {
	width: 100%;
}
.newsDetail .newsDetailBox .detailText {
	font-size: clamp(1rem, 0.904rem + 0.39vw, 1.125rem);/*900-18->390-16*/
	line-height: 1.8;
	letter-spacing: 0;
}

.backORcloseBtn  {
	display: block;
	text-align: center;
}
.backORcloseBtn a {
	background: var(--blue1);
	color: #FFF;
	font-size: 18px;
	line-height: 1em;
	padding: 10px;
	border-radius: 30px;
	width: 150px;
	text-align: center;
	display: inline-block;
	margin: 50px auto 0px auto;
}
.backORcloseBtn a:hover {
	background: var(--blue2);
}
#detail {
	display: block;
}
#detail a {
	color: var(--blue1) !important;
	text-decoration: underline;
}
#detail a:hover {
	background: var(--blue2);
}



/************************************************************************************************************************************************************************************
************************************************************************************************************************************************************************************
     スマホ用の設定　ここから
************************************************************************************************************************************************************************************
************************************************************************************************************************************************************************************/
@media screen and (max-width:750px) {
.newsList {
	width: 96%;
	margin: 0 auto;
}
.newsList h2 {
	font-weight: bold;
	font-size: 18px;
	padding: 20px 0;
	text-align: center;
}
#newsList li {
	width: 45%;
}
#newsList li .title {
	display: block;
	width: 100%;
	font-size: 14px;
	font-weight: bold;
	color: var(--green1);
	padding: 10px 0 5px 0;
}
#newsList li .comment {
	display: block;
	width: 100%;
	font-size: 12px;
	text-align: justify;
	line-height: 1.5;
	padding-bottom: 30px;
}
.newsDetail .newsDetailBox .detailUpfile img {
	width: 90%;
	margin: 0 0 0 5%;
}


}
