@charset "utf-8";
/* CSS Document */



/* category index
--------------------------------------------*/

#category_index {
	background: url("/common2/img/title01_l.svg") no-repeat; /* img/title01_l.svg */
	background-size: 45%;
	position: relative;
	padding: 4rem 0 0;
}

#category_index h1 {
	color: var(--white-color);
	margin: 0 auto 3rem;
	padding-left: 3rem;
}

#category_index h1 span {
	display: inline-block;
	background-color:  var(--blue-color);
}

#category_index h1 span span {
	display: block;
	font-size: 1rem;
    letter-spacing: 0.2rem;
    font-weight: normal;
}

#category_index #category_content .outline {
	display: flow-root;
	position: relative;
}

#category_index #category_content .outline .content_in{
	background: linear-gradient(140deg, var(--white-color) 95%, rgba(255, 255, 255, 0));
	padding: 2rem 2rem;
    margin-bottom: 3rem;
/*    border-bottom-right-radius: 15rem;*/
}


@media screen and (max-width: 1366px){
	#category_index #category_content .outline {
		padding: 2rem 1rem 0;
/*		margin: 0 1rem;*/
		position: relative;
	}
}

@media screen and (max-width: 1024px){	
	#category_index {
		padding: 3rem 0 0;
	}
	
	#category_index h1 {
		margin: 0 auto 2rem;
		padding-left: 2rem;
	}
}

@media screen and (max-width: 767px){	
    #category_index #category_content .outline .content_in{
        padding: 1rem;
    }
}


#category_index #category_content img.about_img,
#category_index #category_content .content_in iframe{
	float: left;
	margin: 0 2rem 3rem 0;
	width: 50%;
}

/*
#category_index #category_content h2 {
	font-weight: bold;
    background: var(--blue-color2) ;
    font-size: 1.8rem;
    padding: 0.8rem 1.2rem 0.7rem;
    margin-bottom: 1.5rem;
    clear: both;
    letter-spacing: 0.1rem;
    line-height: 2.8rem;
}
*/

#category_index #category_content h2 {
	font-weight: bold;
/*	background: url("/common2/img/title03.svg") no-repeat center right;  img/title03.svg */
    background-color: var(--blue-color2) ;
    font-size: 1.8rem;
    padding: 0.8rem 1.2rem 0.7rem;
    margin: 2rem 0 1.5rem;
/*    margin: 5rem 0 1.5rem;	*/
    clear: both;
    letter-spacing: 0.1rem;
    line-height: 2.8rem;		
/*	background-size: 4.9rem;*/
    border-left: 8px solid var(--blue-color);}
    

/*
#category_index #category_content .lo_nav + section h2 {
	margin-top: 3rem;
}
*/

#category_index #category_content .lnk2 h2 {
	padding: 0;
	margin: 0 0 0.8rem;
}

#category_index #category_content .lnk2 a h2 {
	font-size: 1.6rem;
    background: none;
    clear: inherit;
    margin-bottom: 0.8rem;
    letter-spacing: inherit;
    line-height: inherit;
    border-left: none;
	display: inline;
}

#category_index #category_content .lnk2 a h3 {
    margin-bottom: 0.8rem;
}

/*-- h3 --*/

h3 {
  font-weight: bold;
  border-left: 3px solid var(--blue-color);
  font-size: 1.6rem;
  padding: 0.5rem 1.2rem;
  margin-top: 3rem;
  margin-bottom: 1.5rem;
}



#category_content {
	background: url("img/title01_r.svg") no-repeat bottom right;
	background-size: 20%;
	padding-bottom: 5rem;
}


@media screen and (max-width: 767px){
	#category_index {
		padding: 2rem 0 0;
		background-size: 70%;
	}
	
	#category_index h1 {margin-bottom: 2rem;}
	
/*
	#category_index #category_content img {
		float: none;
		margin: 0 0 2rem;
		width: 100%;
	}
*/
}

/* Components
--------------------------------------------*/

/*---- p ----*/

p {
    margin: 0 0 1rem 0;
}

img.icon {
	width: 20px;
	margin: 0 5px;
}


ul.lnk3 {
	display: grid;
	grid-template-columns: repeat(3,1fr);
	grid-gap: 2rem;
	padding-left: 0;
}

.lnk3 li img:not([class]) {width: 100%;}


.lnk4{
	display: grid;
	grid-template-columns: repeat(3,1fr);
	grid-gap: 2rem;
	margin: auto;
	padding: 0 1rem;
}

.lnk4 a{
	color: var(--black-color);
/*	display: flow-root;*/
	height: 100%;
	text-decoration: none;
	position: relative;
	padding: 2rem;
	background-size: 3rem!important;
	background-position: 2rem center!important;
	background-repeat: no-repeat!important;
/*    position: relative;*/
    background: var(--white-color);
    display: grid;
	grid-template-columns: 3.5rem 1fr;
    grid-gap: 2rem;

}

.lnk4 a:hover {
	box-shadow: 0px 8px 12px 2px rgba(10,10,10,0.1), 0px 0px 0px 1px rgba(10,10,10,0.02);
    transition: 0.3s;
}

.lnk4 a:after{
    content: "";
    position: absolute;
    width: 1.5rem;
    height: 1.5rem;
    background: url("/common2/img/circle_arrow.svg") no-repeat; /* /common2/img/circle_arrow.svg */
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
}

.lnk4 a img{
    max-width: 100%;
}


@media screen and (max-width: 1366px){
    .lnk4{
        grid-template-columns: repeat(2,1fr);
    }
}

@media screen and (max-width: 1024px){
    .lnk4{
        grid-gap: 1.5rem;
    }
}

@media screen and (max-width: 767px){	
    .lnk4 {
        grid-template-columns: 1fr;
        grid-gap: 1rem;
    }
}



/*ニュースリスト調整*/
.box_frame ul ul.topic_tag {
    display: block;
    margin: inherit;
    margin-top: 1rem;
    padding-left: 0;
}

.box_frame ul ul.topic_tag li {
    display: inline;
    border: none;
    padding: 0;
}


/* NEDOについて 
-------------------------------------*/

ul.main_menu {
	clear: both;
	display: grid;
	grid-template-columns: repeat(3,1fr);
	grid-gap: 2rem;
	margin: 1rem 0;
	padding: 0;
}

.main_menu a {
	background-repeat: no-repeat!important;
	text-align: center;
	padding: 2rem 2rem;
	background-size: 80px!important;
	background-position: center top 40px!important;
	font-size: 1.6rem;
	font-weight: bold;
}

.main_menu a:after {
	width: 30px;
	height: 20px;
	background-size: 30px;
	bottom: 10px;
	right: 15px;
}

.main_menu a span {
	display: block;
	color: var(--gray-color3);
	font-size: 1.2rem;
}

#category_index #category_content .main_menu a img {
	display: block;
	width: 70px;
	margin: 0 auto 2rem;
    float: inherit;
}

@media screen and (max-width: 1024px){
	
	ul.main_menu {
		grid-gap: 1.5rem;
		margin: 1.5rem 0;
	}
	.main_menu a {
		padding: 1.5rem 1.5rem;
		background-size: 70px!important;
		background-position: center top 30px!important;
		font-size: 1.4rem;
	}

	.main_menu a:after {
		width: 28px;
		height: 18px;
		background-size: 28px;
		bottom: 8px;
		right: 12px;
	}
}

@media screen and (max-width: 767px){
	ul.main_menu {grid-template-columns: 1fr;}
	
	.main_menu a {
		text-align: left;
		padding: 1rem;
		background-size: 50px!important;
		background-position: 15px center!important;
	}
	
	.main_menu h2 {
		font-size: 1.4rem;
		margin-bottom: 0.5rem;
	}

	.main_menu h2 span {
		font-size: 0.9rem;
	}
	
	.main_menu ul {
		grid-template-columns: 1fr;
		grid-gap: 1rem;
	}
    
    #category_index #category_content .main_menu a img {
        display: inline-block;
        width: 50px;
        margin: 0 1rem 0 0;
        float: left;
    }
}

/*-- number --*/

#number {
	background: var(--gray-color1);
	padding: 3rem 0;
}

#number dl {
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3,1fr);
}

#number dl div:first-child {border-left: 2px solid var(--gray-color2);}

#number dl div {
	text-align: center;
	border-right: 2px solid var(--gray-color2);
	display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
/*    gap: 30px;*/
}

#number dl div.small {
	border-right: none;
}

#number dt {
	font-size: 1.6rem;	
}

#number dt img {
	display: block;
	width: 120px;
	margin: 2rem auto;
}

#number dd span {
	font-size: 4rem;
	color: var(--blue-color);
}

#number dd time {
	display: block;
    text-align: right;
    font-size: 0.9rem;
    padding: 1rem 1rem 0 0;
}

@media screen and (max-width: 1366px){
	#number {
		padding: 2.5rem 0 2rem;
	}
}
	
@media screen and (max-width: 1024px){
	#number dt {
		font-size: 1.4rem;	
	}
	#number dt img {
		width: 100px;
		margin: 1.5rem auto;
	}
	#number dd span {
		font-size: 3.5rem;
	}
}

@media screen and (max-width: 767px){
	#number dt {
		font-size: 1.2rem;	
	}
	#number dt img {
		width: 80px;
	}
	#number dd span {
		font-size: 3rem;
	}
}

/*-- region --*/

#region {
	padding: 3rem 0;
	background: url("/common2/img/region.svg") no-repeat top; /* img/region.svg */
	background-size: cover;
}

#region h2,
#region h2 span {color: var(--white-color);}

#region h2 {
	margin-bottom: 5rem;
	display: inline-block;
	background-color:  var(--blue-color);
}

#region section{
	background: var(--white-color);
	padding: 3rem 2rem 2rem;
}

#region h3 {
	text-align: center;
	margin-top: 0;
	padding: 160px 2rem 2rem;
	background-repeat: no-repeat;
	border-left: none;
}

#region #energy,
#region #industria{
	border-bottom: 2px solid var(--gray-color2);

}

#region #energy h3 {
	background-image: url("/common2/img/region01.svg");
	background-size: 120px;
	background-position: top 20px center;}
#region #industria h3 {
	background-image: url("/common2/img/region02.svg");
	background-size: 180px;
	background-position: top 20px center;}
#region #other h3 {
	background-image: url("/common2/img/region03.svg");
	background-size: 130px;
	background-position: top 20px center;}



@media screen and (max-width: 1024px){	
	#region h2 {
		margin-bottom: 3rem;
	}
}

@media screen and (max-width: 767px){
	#region section {
		padding: 1rem;
	}
	#region h3 {
		text-align: left;		
	}

	#region #energy h3 { background-size: 70px;background-position: center left 20px; padding: 2rem 1rem 2rem 100px;
	}
	#region #industria h3 { background-size: 90px;background-position: center left 10px; padding: 2rem 1rem 2rem 120px;
	}
	#region #other h3 { background-size: 70px;background-position: center left 10px; padding: 2rem 1rem 2rem 100px;
	}		
}



/*-- contents_list --*/

#contents_list {
	padding: 3rem 1rem;
	background: var(--gray-color1);
}


/*-- bg_gray --*/

/*
.bg_gray .outline {
	padding: 3rem;
}
*/




/* ニュースリリース :
--------------------------------------------*/

.box_frame ul {
	display: grid;
	grid-template-columns: repeat(3,1fr);
	grid-gap: 2rem;
	margin: 2rem 0 3rem;
}

.box_frame ul li {
	background-color: var(--white-color);
	padding: 2rem;
	height: 100%;
    border: solid 1px var(--gray-color2);
}


@media screen and (max-width: 1024px){
	.box_frame ul li {
		padding: 1.5rem;
	}
	
	.box_frame ul {
		grid-gap: 1.5rem;
		margin: 1.5rem 0 2rem;
	}
}

.box_frame ul time {
	color: var(--black-color);
/*	font-weight: 600;*/
	display: block;
	margin-bottom: 1rem;
}
.box_frame ul a{
    font-weight: bold;
    display: inline-block;
}

@media screen and (max-width: 767px){
	.box_frame {
		padding: 2rem 0 1rem;
	}
	.box_frame ul {
		grid-template-columns: 1fr;
	}
}


