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

/**
#footer {
	margin-top: 0 !important;
}
**/
#banner_wrap {
	margin-top: 0 !important;
}
#contents{
	margin-top: 40px !important;
}
.contents_wrap{
	padding: 30px 0;
}
/*-------------------------------------
★#loading
--------------------------------------*/
#wrap{
  /**display: none;**/
}
#loader-bg {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: #000;
	z-index: 9999999;
}
#loader {
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	max-width: 700px;
	width: 85%;
	height: auto;
	text-align: center;
	color: #fff;
	z-index: 99999999;
	-webkit-transform: translate(-50%,-50%);
	-moz-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	-o-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
}
#loader path{
	stroke:#fff;
	fill: none;
	stroke-width: .5px;
	stroke-dasharray: 3000;
	stroke-dashoffset: 1000;
	animation: DASH 3s ease-in-out alternate forwards;
	-webkit-animation:DASH 3s ease-in-out .5s forwards;
	animation:DASH 3s ease-in-out .5s forwards;
}
@keyframes DASH{
	0%  {stroke-dashoffset:3000;fill:transparent;}
	50% {stroke-dashoffset:1000;fill:transparent;}
	80%{stroke-dashoffset:0;fill:#fff;}
	100%{stroke-dashoffset:0;fill:#fff;}
}
@-moz-keyframes DASH{
	0%  {stroke-dashoffset:3000;fill:transparent;}
	50% {stroke-dashoffset:1000;fill:transparent;}
	80%{stroke-dashoffset:0;fill:#fff;}
	100%{stroke-dashoffset:0;fill:#fff;}
}
@-webkit-keyframes DASH{
	0%  {stroke-dashoffset:3000;fill:transparent;}
	50% {stroke-dashoffset:1000;fill:transparent;}
	80%{stroke-dashoffset:0;fill:#fff;}
	100%{stroke-dashoffset:0;fill:#fff;}
}




/*-------------------------------------
★#mv
--------------------------------------*/
#mv {
	height: 70vh;
}
#mv #loopSlider{
	background: url(/Kokusai/IIGE/images/mv.jpg) left top repeat-x;
	background-size: cover;
	height: 70vh;
	width: 100%;
	display: table;
}
#mv h2 {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 1;
	max-width: 800px;
	width: 90%;
	height: auto;
	-webkit-transform: translate(-50%,-50%);
	-moz-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	-o-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
	padding-left: 80px;
}
#mv h2 img {
	width: 100%;
	height: auto;
}
#mv #particles-js {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	right: 0;
}



/*-------------------------------------
★#news
--------------------------------------*/
#news h2 {
	border-bottom: #ddd 1px solid;
}
#news .bscBtn01 a {
	padding: 10px 30px 6px;
}
#news .newsList {
	border-bottom: #ddd 1px solid;
	padding-bottom: 5px;
}



/*-------------------------------------
★#about
--------------------------------------*/
.about {
	padding:100px 0;
	background: url(../lib/cmn_img/bg_sq.jpg) center center no-repeat;
	background-size: cover;
	position: relative;
	z-index: 1;
}
.about::before {
	content: "";
	background: url(../lib/cmn_img/about_parts01.png);
	width: 462px;
	height: 127px;
	position: absolute;
	left: 10%;
	top: -50px;
}
.about::after {
	content: "";
	background: url(../lib/cmn_img/about_parts02.png);
	width: 343px;
	height: 120px;
	position: absolute;
	right: 10%;
	bottom: -50px;
}

/*-------------------------------------
★#category_news
--------------------------------------*/
#category_news{
	background: url(../images/bg_category_news.jpg) ;
}
#category_news .flbox{
	display: flex;
	justify-content: center;
	padding: 0px;
}
#category_news .flbox li{
	list-style: none;
	width: 33.33%;
	background-color: #fff;
	margin: 10px;
	padding: 0px;
}
#category_news .flbox li.ListBox{
	
}
#category_news .flbox .inner{
	padding: 5px 15px;
	height: 100%;
	display: flex;
	flex-direction: column;
}

#category_news .category_news_img_wrap {
	position: relative;
	padding-bottom: 56.25%;
	overflow: hidden;
}

#category_news .category_news_img_wrap img{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translateY(-50%) translateX(-50%);
	max-width: 100%;
	height: auto;
}

#category_news .ListBox .bscBtn01 {
	margin-top: auto;
}
#category_news .bscBtn01 a{
	width: 100%;
}

/*-------------------------------------
★#contents_box
--------------------------------------*/
#contents_box{
	
}
#contents_box .contents_list{
	display: flex;
	justify-content: center;
	padding: 0px;
}
#contents_box .contents_list li{
	list-style: none;
	width: 33.33%;
	background-color: #fff;
	margin: 10px;
	padding: 0px;
}
#contents_box .contents_list li img{
	width: 100%;
	max-width: 313px;
	height: auto;
	margin: 0 auto;
}
#contents_box .contents_list li.ListBox{
	padding: 5px 15px;
	display: flex;
	flex-direction: column;
}

/*-------------------------------------
★#top_implementing_box
--------------------------------------*/
#top_implementing_box{
	
}

/*-------------------------------------
★#top_promot_box
--------------------------------------*/
#top_promot_box{
	background: url(../images/bg_category_news.jpg) ;
}

/*-------------------------------------
★#top_banner_box
--------------------------------------*/
#top_banner_box{
	background: url(../images/bg_category_news.jpg) ;
}

#top_banner_box .banner_list{
	display: flex;
	justify-content: center;
	padding: 0px;
}
#top_banner_box .banner_list li{
	list-style: none;
	width: 480px;
	margin: 10px;
	padding: 0px;
}
#top_banner_box .banner_list li img{
	width: 100%;
	max-width: 480px;
	height: auto;
	margin: 0 auto;
}
#top_banner_box .banner_list li.ListBox{
	padding: 5px 15px;
	display: flex;
	flex-direction: column;
}


.img_list{
	display: flex;
	justify-content: center;
	padding: 0px;
}
.img_list li{
	list-style: none;
	width: 33.33%;
	margin: 10px;
	padding: 0px;
}
.img_list li img{
	width: 100%;
	max-width: 313px;
	height: auto;
	margin: 0 auto;
}
.img_list li.ListBox{
	padding: 5px 15px;
	display: flex;
	flex-direction: column;
}




.clearfix {
  display: inline-block;
  min-height: 1%;
}

.videoWrap {
  width: 98%;
  margin: auto;
  max-width: 800px;
}
.videoWrap .videoFrame {
  height: 400px;
}
.videoWrap img{
  width: 100%;
}

dl.lg_num_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
}
dl.lg_num_list dt {
  counter-increment: number;
  font-size: 22px;
  font-weight: 300;
  width: 3em;
  padding-top:6px;
  font-family: 'Josefin Sans', sans-serif;
}

dl.lg_num_list dt::after{
  content: counter(number, decimal-leading-zero) ".";
  color: #ec6515;
}

dl.lg_num_list dd {
  width: calc(100% - 8em);
  margin-bottom: 30px;
}
dl.lg_num_list .lg_title{
	font-size: 22px;
	font-weight: 300;
	font-family: 'Josefin Sans', sans-serif;
}




























/*SP*/
@media only screen and (max-width: 800px) {

/*-------------------------------------
★#mv
--------------------------------------*/
#mv {
	height: 40vh;
}
#mv #loopSlider{
	height: 40vh;
}

#mv h2 {
	padding-left: 30px;
}
	
/*-------------------------------------
★#news
--------------------------------------*/
#news .bscBtn01 a {
	padding: 15px 30px 13px;
}
#news .newsList {
	padding-bottom: 0;
	margin-bottom: 10px;
}

/*-------------------------------------
★#about
--------------------------------------*/
.about {
	padding:40px 0;
}
.about::before {
	width: 200px;
	height: 55px;
	background-size: 100% auto;
	left: 3%;
	top: -25px;
}
.about::after {
	background-size: 100% auto;
	width: 170px;
	height: 60px;
	right: 3%;
	bottom: -25px;
}
#category_news .flbox{
	flex-wrap: wrap;
}
#category_news .flbox li{
	width: 100%;
}

#contents_box .contents_list{
	flex-wrap: wrap;
}
#contents_box .contents_list li{
	width: 100%;
	max-width: 313px;
}


.img_list{
	flex-wrap: wrap;
}
.img_list li{
	width: 100%;
	max-width: 313px;
}


}


@media only screen and (max-width: 600px) {
.videoWrap .videoFrame {
  height: 200px;
}
}