@charset "UTF-8";

/* ! CSSの構成 独自共通要素 ================================================== 
  
独自共通コンテンツA
独自共通コンテンツB
独自共通コンテンツC
  
-------------------------------------------------- */

/* ! 404エラー ================================================== */
.erro_404 .white_wrap{
	padding: 0px 30px 50px;
}
.erro_404 h2{
	text-align: center;
  font-size: 110px !important;
  line-height: 1.4 !important;
  color: #dce1ea;
}
.erro_404 p{
	text-align: center;
	margin: 0 0 0px;
	font-size: 15px;
  font-weight: 500;
  letter-spacing: 1px;
}
.erro_404 .btnarea{
	margin: 30px auto 0;
}

.no_archive{
	padding: 30px;
	font-size: 15px;
	text-align: center;
	font-weight: bold;
	color: #555;
	letter-spacing: 1px;
}

/* ! 背景白 ================================================== */

.white_wrap{
  background: white;
  -webkit-box-shadow: 0px 3px 6px rgba(0,0,0,.08);
  	  box-shadow: 0px 3px 6px rgba(0,0,0,.08);
  border-radius: 2px;
}


/* ! アイコンあり ================================================== */

[class^="icon_"]{
/*
	position: relative;
	padding:  0 0 0 40px;
*/
}
[class^="icon_"]:before{
	content: '';
	display: block;
	width: 20px; height: 20px; 
	display: inline-block;
	margin: 0 10px 0 0;
	vertical-align: middle;
	background: #aaa;
}

.icon_word:before{
	background: url(../img/icon_word.svg)no-repeat center;
	background-size: cover;
}
.icon_word_white:before{
	background: url(../img/icon_word_white.svg)no-repeat center;
	background-size: cover;
}
.icon_calender:before{
	background: url(../img/icon_calender_2.svg)no-repeat center;
	background-size: 95%;
}
.icon_map:before{
	background: url(../img/icon_map.svg)no-repeat center;
	background-size: auto 100%;
  height: 23px;
}
.icon_tmap:before{
	background: url(../img/icon_travel.svg)no-repeat center;
	background-size: auto 100%;
  height: 23px;
}
.icon_contact:before{
	background: url(../img/icon_contact.svg)no-repeat center;
	background-size: 95%;
}
.icon_contact_white:before{
	background: url(../img/icon_contact_white.svg)no-repeat center;
	background-size: 95%;
}
.icon_japan:before{
	background: url(../img/icon_japan.svg)no-repeat center;
	background-size: 95%;
}
.icon_oversea:before{
	background: url(../img/icon_oversea.svg)no-repeat center;
	background-size: 95%;
}
.icon_press:before{
	background: url(../img/icon_press.svg)no-repeat center;
	background-size: 95%;
}
.active .icon_japan:before{
	background: url(../img/icon_japan_white.svg)no-repeat center;
	background-size: 95%;
}
.active .icon_oversea:before{
	background: url(../img/icon_oversea_white.svg)no-repeat center;
	background-size: 95%;
}
.active .icon_press:before{
	background: url(../img/icon_press_white.svg)no-repeat center;
	background-size: 95%;
}
.icon_archive:before{
	background: url(../img/icon_calendar.svg)no-repeat center;
	background-size: 95%;
}
.icon_famous:before{
	background: url(../img/icon_famous.svg)no-repeat center;
	background-size: 95%;
}
.icon_famous_black:before{
	background: url(../img/icon_famous_black.svg)no-repeat center;
	background-size: 95%;
}
.icon_list:before{
	background: url(../img/icon_list.svg)no-repeat center top 1px;
	background-size: 85%;
}
.icon_list_white:before{
	background: url(../img/icon_list_white.svg)no-repeat center top 1px;
	background-size: 85%;
}
.icon_category:before{
	background: url(../img/icon_category.svg)no-repeat center;
	background-size: 90%;
}
.icon_grass:before{
	background: url(../img/icon_grass.png)no-repeat center;
	background-size: 90%;
}
.icon_company:before{
	background: url(../img/icon_company.svg)no-repeat center;
	background-size: 100%;
}

.icon_research:before{
	background: url(../img/icon_data.png)no-repeat center;
	background-size: 100%;
}
.icon_newsletter:before{
	background: url(../img/icon_letter.png)no-repeat center;
	background-size: 100%;
}
.icon_seminar:before{
	background: url(../img/icon_seminer.png)no-repeat center;
	background-size: 100%;
}
/* ! 記事一覧 ================================================== */
ul[class^="article_"]{
	overflow: hidden;
}
ul[class^="article_"] li.google-auto-placed,
ul[class^="article_"] li.google-auto-placed ins,
ul[class^="article_"] li.google-auto-placed iframe,
ul[class^="article_"] li .google-auto-placed,
ul[class^="article_"] li .google-auto-placed ins,
ul[class^="article_"] li .google-auto-placed iframe{
	width: 100% !important;
	overflow: hidden;
	margin: auto !important;
	max-width: 800px;
}
.main_contents > .google-auto-placed,
.main_contents > section > .google-auto-placed{
	max-width: 1120px;
	padding: 0 20px;
	overflow: hidden;
	margin: auto !important;
	width: 100vw !important;
}
.main_contents > .google-auto-placed{
	margin: 20px auto 0;
}
.main_contents > .google-auto-placed ins,
.main_contents > section > .google-auto-placed ins{
	overflow: hidden;
}
ul[class^="article_"] li > div{
	position: relative;
	padding: 20px 40px;
}
ul[class^="article_"] li > div > a{
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%);
	width: 100%; height: 100%;
	z-index: 1;
}
ul[class^="article_"] li > div > a:hover{
	background: rgba(156, 175, 214, 0.09);
}
ul[class^="article_"] li + li > div{
	border-top: solid 1px #E0E0E0;
}
ul[class^="article_"] li div h1{
	font-size: 20px;
	margin: 0 0 10px;
}
ul[class^="article_"] li div h1 span{
  width: 37px;
  height: 20px;
  background: #ED6060;
  font-size: 10px;
  color: white;
  border-radius: 3px;
  line-height: 1;
  text-shadow: none;
  display: -webkit-inline-flex; display: inline-flex;
  -webkit-flex-wrap: wrap; flex-wrap: wrap;
  -webkit-align-items: center; align-items: center;
  -webkit-justify-content: center; justify-content: center;
  vertical-align: middle;
  margin: -3px 4px 0 0;
  padding: 0 0 2px;
}
p.prefectures,
p.category{
  display: inline-block;
  color: white;
  background: #58AEDD;
  font-weight: 500;
  letter-spacing: 1px;
  border: none;
  margin: 0 2px;
  line-height: 1.2;
  z-index: 2;
  position: relative;
}
p.prefectures a,
p.category a{
	display: block;
	padding: 5px 10px;
}
p.prefectures a{
	color: white;
}
p.prefectures:empty,p.category:empty,
p.prefectures a:empty,
p.category a:empty{
	display: none;
}
p.category{
  background: #e2e2e2;
  color: #333;
}
span.date {
  font-size: 13px;
  color: #A7A7A7;
  font-weight: 500;
  margin: 0 0 0 9px;
  display: inline-block;
}
ul[class^="article_"] li .detail {
  margin: 20px 0 0;
  display: -webkit-flex; display: flex;
  -webkit-flex-wrap: nowrap; flex-wrap: nowrap;
}
ul[class^="article_"] li .detail .img{
	width: 150px; height: 79px;
	border-radius: 5px;
	-webkit-box-shadow: 0px 0px 3px rgba(0,0,0,.16);
		  box-shadow: 0px 0px 3px rgba(0,0,0,.16);
		  background-size: cover !important;
}
ul[class^="article_"] li .detail p{
	width: calc((100% - 150px));
	width: -webkit-calc((100% - 150px));
	padding: 0 0 0 30px;
	line-height: 2;
}

@media screen and (max-width: 430px){
	ul[class^="article_"] li:nth-of-type(2n){
		background: #f4f6f9;
	}
	ul[class^="article_"] li > div{
		padding: 20px;

	}
	ul[class^="article_"] li .detail{
		 display: -webkit-flex; display: flex;
		  -webkit-flex-wrap: wrap; flex-wrap: wrap;
	}
	ul[class^="article_"] li .detail .img{
		width: 100%;
    height: auto;
    padding-top: 52.63%;
	}
	ul[class^="article_"] li div h1{
		font-size: 16px;
		line-height: 1.5;
	}
	ul[class^="article_"] li .detail p{
    width: 100%;
    padding: 10px 0 0;
	}

}

/* ! 下層タイトル ================================================== */

main .white_wrap > h2[class^="icon_"]{
	background: #58AEDD;
	text-align: center;
	padding: 17px 0;
	color: white;
}
main .white_wrap > h2:not([class^="icon_"]){
	padding: 30px 30px 30px;
	font-size: 27px;
	line-height: 1.5;
}

main  .white_wrap > h2[class^="icon_"] + div{
	padding: 30px 30px 0;
}
main .white_wrap > h2:not([class^="icon_"]) + div{
	padding: 0 30px 30px;
}
main  .white_wrap  h4{
  padding: 0 0 10px;
  border-bottom: solid thin #ccc;
}

@media screen and (max-width: 640px){
	main .white_wrap > h2:not([class^="icon_"]){
		border-radius: 0;
	}

}