﻿/* CSS Document */

#right_box h2{
	font-size:2.6rem;
	text-align:center;
	background-color:#f1eee9;
	padding:0.3em;
	line-height:1.2;
}

#right_box h2 span{
	font-size:1.8rem;
}

#vision{
	text-align:center;
	margin-bottom:5rem;
}
#vision .logo{
	width:67.348%;
	margin:0 auto;
	text-align:center;
	font-size:0px;
	margin-bottom:2rem;
}
#vision .logo img{
	width:100%;
}
#vision .ttl{
	color:#008442;
	font-size:1.8rem;
	border:solid 1px #008442;
	display:inline-block;
	padding:0.4em 0.8em;
	margin-top:1.5em;
	margin-bottom:1em;
}
#vision .ttl + p{
	font-size:3rem;
}
#vision li{
	justify-content:center;
	align-items:center;
	margin-bottom:-1em;
}
#vision li p:nth-of-type(1){
	font-size:1.8rem;
	margin-right:0.5em;
	text-align:left;
}
#vision li p:nth-of-type(1) span{
	width:11.5em;
	display:inline-block;
}
#vision li p:nth-of-type(2){
	color:#008442;
	font-size:4rem;
}
#vision li p:nth-of-type(2) span{
	font-size:2.8rem;
}

#plan h3{
	display:inline-block;
	font-size:1.8rem;
	border:solid 1px;
	padding:0.2em 0.8em;
	margin-bottom:1em;
}
#plan h3 + .ttl{
	font-size:3rem;
	margin-bottom:0.6em;
}
#plan h3 + .ttl + p{
	margin-bottom:2em;
	font-size:1.8rem;
}
#plan h4{
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "メイリオ", sans-serif;
	font-size:1.8rem;
	line-height:1;
	border-left:0.3em solid #539f24;
	padding-left:0.2em;
	margin-bottom:1em;
}
#plan .target{
	margin-bottom:5rem;
}
#plan .target .table{
	align-items:stretch;
	margin-bottom:4.5rem;
}
#plan .target .table .left{
	border:solid 1px #539f24;
	width:80%;
}
#plan .target .table .box{
	padding:0.2rem;
	text-align:center;
}
#plan .target .table .box div{
	display:inline-block;
	text-align:left;
	padding:0.5rem 0 1rem 0;
}
#plan .target .table .box div p span.icon{
	color:#539f24;
}
#plan .target .table .box div p .large{
	font-size:2.4rem;
	font-weight:bold;
}
#plan .target .table .box div p .large span{
	font-size:1.6rem;
}
#plan .target .table .right{
	border:solid 1px #539f24;
	border-left:none;
	width:20%;
}
#plan .target .table .ttl{
	color:#FFF;
	background-color:#539f24;
	padding:0.5em 0;
	text-align:center;
}
#plan .target .table .box div p{
	margin-bottom:-0.5em;
}
#plan .target .table .box div p .small{
	font-size:1.3rem;
}
#plan .target .table .left .flex{
	border-top:solid 1px #539f24;
	align-items:stretch;
}
#plan .target .table .left .flex .box{
	width:50%;
	border-right:solid 1px #539f24;
}
#plan .target .table .left .flex .box_02 div p{
	padding-top:0.7em;
}
#plan .target .table .left .flex .box_03{
	border-right:none;
}
#plan .target .table .box_04 div p{
	padding-top:3.3em;
	font-size:1.8rem;
	font-weight:bold;
	text-align:center;
}
#plan .target dt{
	font-size:1.8rem;
	color:#d59400;
	background-color:#f4f5f5;
	padding:0.4em 0.8em;
}
#plan .target dt:nth-of-type(2){
	color:#cd6785;
}
#plan .target dt:nth-of-type(3){
	color:#91aa0b;
}
#plan .target dd{
	padding:0.9em;
}
#plan .target dd li{
	padding-left:1em;
	text-indent:-1em;
	margin-bottom:0.3em;
}
#plan .target dd li span{
	color:#d59400;
}
#plan .target dd:nth-of-type(2) li span{
	color:#cd6785;
}
#plan .target dd:nth-of-type(3) li span{
	color:#91aa0b;
}

#plan .target table.non_financial{width:100%;margin-bottom:1em;}

#plan .target table.non_financial td{padding:0.4em}
#plan .target table.non_financial td span{
	color:#d59400;

}
#plan .target table.non_financial tr:nth-child(odd){

	background:#f4f5f5;

}

#plan .target table.non_financial small {
  
  font-size:1.3rem;
}

#plan .target .table .caption{
	font-size:1.4rem;
  margin:0.7rem 0;
} 


#plan .movie_box{
	text-align:center;
margin-top:4rem;
}
#plan .movie_box iframe{
	width:80%!important;
	height:380px!important;
}

#plan ul li{
margin-bottom: 1em;
}


main .caption li{
	font-size:1.4rem;
	padding-left:2.5em;
	text-indent:-2.5em;
}
main .caption p{
	font-size:1.4rem;
	margin-top:0.5em;
}
#plan .task{
	border-bottom:1px dashed #bcbcbc;
	padding-bottom:2rem;
	margin-bottom:5rem;
}

#plan .task p{
	margin-bottom:2rem;
}

#plan .task .anchor{
	margin-top:3rem;
	text-align:center;
	background:url(../img/theme_bg.png) center bottom/93.63% no-repeat;
	padding-bottom:2rem;
	margin-bottom:4.5rem;
}
#plan .task .anchor ul{
	justify-content:center;
}
#plan .task .anchor li:nth-of-type(2){
	margin:0 1.5%;
}
#plan .task .anchor li a{
	border-radius:50%;
	border:solid 0.5rem #a87d53;
	flex-direction: column;
	justify-content:center;
	text-align:center;
	align-items:center;
	width:20rem;
	height:20rem;
	background-color:#FFF;
}
#plan .task .anchor li a span:nth-of-type(1){
	display:inline-block;
	background-color:#a87d53;
	color:#FFF;
	font-size:1.8rem;
	padding:0.35em 0.6em 0.3em 0.6em;
	border-radius:0.2em;
	line-height:1;
}
#plan .task .anchor li a span:nth-of-type(2){
	width:80%;
	margin:0.8em auto 0.3em;
	display:block;
	background-color:#a87d53;
	color:#FFF;
	font-size:2rem;
	
}
#plan .task .anchor li a span:nth-of-type(3){
	color:#a87d53;
	font-size:1.5rem;
	font-weight:bold;
}
#plan .task .anchor ul + div{
	display:inline-block;
	text-align:left;
}
#plan .task .anchor p{
	margin-top:1rem;
}
#plan .task .anchor p span{
	font-size:1.8rem;
	color:#FFF;
	background-color:#a87d53;
	border-radius:0.3em;
	width:10em;
	display:inline-block;
	padding-left:0.5em;
	margin-right:0.5em;
}
#plan .task h5{
	font-size:1.6rem;
	margin-bottom:1.5em;
}
#plan .task h5 span{
	font-size:1.8rem;
	margin-right:1.5em;
}
#plan .task h5 span.number{
	display: inline-block;
    background-color: #a87d53;
    color: #FFF;
    padding: 0.35em 0.6em 0.3em 0.6em;
    border-radius: 0.2em;
    line-height: 1;
	margin-right:0.5em;
}
#plan .task dl{
	border-bottom:1px dashed #bcbcbc;
	margin-bottom:2rem;
	padding-bottom:2rem;
}
#plan .task dl div{
	padding:1em;
	justify-content:flex-start;
	flex-wrap:nowrap;
}
#plan .task dl div.caption {
    padding: 0em;
	padding-top:1em;
}

#plan .task dl div:nth-of-type(odd){
	background-color:#f4f5f5;
}
#plan .task dt{
	color:#a87d53;
	font-weight:bold;
	min-width:10em;
	white-space:nowrap;
}
#plan .task #task4 + dl dt{
	min-width:13em;
}
#plan .task #task5 + dl dt{
	min-width:13em;
}

#plan .task dl li{
  margin-bottom:1rem;
}

#plan .task dd li{
	padding-left:1em;
	text-indent:-1em;
}
#plan .strategy .graph{
	align-items:stretch;
}
#plan .strategy .graph .left{
	width:19%;
	flex-direction: column;
	align-items:center;
	position:relative;
}
#plan .strategy .graph .left:after{
	width:0.5625em;
	height:2.5625em;
	content:"";
	background:url(../img/arrow_01.png) 0 0 /contain no-repeat;
	right:-1.3em;
	top:50%;
	margin-top:-1.28em;
	position:absolute;
}

#plan .strategy .graph .left p{
	font-size:1.8rem;
	text-align:center;
	color:#FFF;
	width:100%;
	line-height:1.3;
}
#plan .strategy .graph .left p span{
	width:100%;
}
#plan .strategy .graph .left p span span{
	font-size:1.2rem;
	width:auto;
}
#plan .strategy .graph .left p:nth-of-type(1){
	background-color:#a87c53;
	height:78%;
	display:flex;
	align-items:center;
}
#plan .strategy .graph .left p:nth-of-type(2){
	background-color:#8f8f8f;
	height:22%;
	display:flex;
	align-items:center;
  color:#FFF;
}

#plan .strategy .graph .right{
	width:77%;
}
#plan .strategy .graph .right div{
	border-top: 1px dashed #bcbcbc;
	padding:1px 0;
	justify-content:flex-start;
	align-items:center;
	flex-wrap:nowrap;
}
#plan .strategy .graph .right div:last-child{
	border-bottom: 1px dashed #bcbcbc;
}
#plan .strategy .graph .right dt{
    min-width: 8em;
    white-space: nowrap;
	font-size:1.8rem;
	background-color:#f5b090;
	text-align:center;
	padding:2em 0;
	line-height:1.3;
  color:#000000;
}
#plan .strategy .graph .right div:nth-of-type(2) dt{
	background-color:#fcd475;
  padding:3em 0;
}
#plan .strategy .graph .right div:nth-of-type(3) dt{
	background-color:#fae6ad;
  padding:1.5em 0;
}
#plan .strategy .graph .right dt p{
	font-size:1.8rem;
}
#plan .strategy .graph .right dt span{
	font-size:1.2rem;
}
#plan .strategy .graph .right dd{
	padding-left:2em;
	position:relative;
	font-size:1.8rem;
}
#plan .strategy .graph .right dd:before{
	width:0.5em;
	height:1.77em;
	content:"";
	background:url(../img/arrow_02.png) 0 0 /contain no-repeat;
	left:0.7em;
	top:50%;
	margin-top:-0.88em;
	position:absolute;
}
#plan .strategy .graph + p{
	padding:3em 0 1.5em 0;
}


#plan .strategy .graph .right dd ul li{
padding-left: 1em;
    text-indent: -1em;
}

.banner img{
	max-width:100%;
}

#policy { 
  margin:4em auto 0 auto;
}

#policy .lead{ 
  max-width:98%;
  font-size:18px;
  line-height:1.4;
  margin:0 auto;
}

#policy .figure{ 
  margin:1.5em auto;
  width:100%;
		text-align:center;
}

#policy .figure img{ 
  max-width:100%;
}


#policy ul{
margin:1em auto;  
display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    justify-content: space-between;
}

/*#policy ul li{
width:100%;
  margin:0.5em 0;
}

#policy li{
	padding-left:3em;
	text-indent:-3em;
}


#policy li span:nth-of-type(1){
	display:inline-block;
	background-color:#eb0100;
	color:#FFF;
	font-size:1.8rem;
	padding:0.35em 0.6em 0.4em 0.6em;
	border-radius:0.2em;
	line-height:1;
  margin-right:0.5em;
	text-indent:0em;
}
#policy li span:nth-of-type(2){
	width:80%;
	margin:0.8em auto 0.3em;
	display:block;
	background-color:#eb0100;
	color:#FFF;
	font-size:2rem;
	
}
#policy li span:nth-of-type(3){
	color:#eb0100;
	font-size:1.5rem;
	font-weight:bold;
}*/

#right_box ul.anchor {
    margin-bottom: 3rem;
    font-size: 0px;
    margin-top: 4rem;
}

#right_box ul.anchor li {
    display: inline-block;
    width: 30%;
    margin-right: 3%;
    font-size: 1.6rem;
}

#right_box ul.anchor li a {
    display: block;
    border-bottom: 1px solid #ccc9c9;
    padding: 0 1.5em 0.8em 0;
    position: relative;
    margin-bottom: 1em;
}

#right_box ul.anchor li a:after {
    content: "";
    vertical-align: middle;
    position: absolute;
    top: 50%;
    margin-top: -0.7em;
    right: 0.5em;
    width: 0.3em;
    height: 0.3em;
    border-top: 0.15em solid #ff0a0a;
    border-right: 0.15em solid #ff0a0a;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}


#dx {
    margin: 4em auto 0 auto;
}

#dx .lead {
    max-width: 98%;
    font-size: 18px;
    line-height: 1.4;
    margin: 0 auto;
}

#dx .figure {
    margin: 1.5em auto;
    width: 100%;
    text-align: center;
}

#dx .logo{
	margin:5rem auto 0 auto;
	text-align:center;
	font-size:0px;
}

#dx .logo img{
    height: 7rem;
    width: auto;
}

/*---------------------------------------------------------------
横幅768px～1190pxまでのレイアウト
---------------------------------------------------------------*/
@media screen and (min-width:768px) and (max-width:1150px){
#plan .task .anchor li a{
	width: 17.5vw;
    height: 17.5vw;
}
#plan .task .anchor li a span:nth-of-type(1){
	font-size:1.53vw;
}
#plan .task .anchor li a span:nth-of-type(2){
	font-size:1.69vw;
}
#plan .task .anchor li a span:nth-of-type(3){
	font-size:1.3vw;
}
#plan .task .anchor p{
	font-size:1.35vw;
}
#plan .task .anchor p span{
	font-size:1.53vw;
}

#plan .strategy .graph .left p {
	font-size:1.53vw;
}
#plan .strategy .graph .left p span span {
    font-size: 1.05vw;
}
#plan .strategy .graph .right dt {
	font-size:1.53vw;
}
#plan .strategy .graph .right dt span {
    font-size: 1.05vw;
}
#plan .strategy .graph .right dd {
	font-size:1.53vw;
}

#policy .lead br{ 
display:none;
}

}

/*---------------------------------------------------------------
スマホレイアウト
---------------------------------------------------------------*/
@media screen and (max-width:767px){

#vision .logo{
	width:74%;
}	
	
	#vision .logo img {
    width: 100%;
}
#vision .ttl + p {
    font-size: 2.5rem;
}
#plan h3 + .ttl{
	font-size:2.3rem;
}

#plan .target .table{
	display:block;
}
#plan .target .table .left {
    width: 100%;
}
#plan .target .table .right{
    width: 100%;
	border: solid 1px #539f24;
    border-left: solid 1px #539f24;
	border-top:none;
}

#plan .target table.non_financial td{padding:0.4em 0;}
#plan .target table.non_financial td span{
	font-size:1rem;

}

#plan .target .table .box div p {
    font-size: 1.5rem;
}
#plan .target .table .box div p .large {
    font-size: 1.7rem;
}
#plan .target .table .box_04 div p {
    padding-top: 0em;
}
#plan .task h5 span.number{
	margin-bottom:0.5em;
}
#plan .task .anchor li a {
    width: 42vw;
    height: 42vw;
	border: solid 0.3rem #a87d53;
}
#plan .task .anchor li:nth-of-type(2) {
    margin: 0 0%;
	margin-left:4vw;
}
#plan .task .anchor li:nth-of-type(3) {
	margin-top:-3vw;
}
#plan .task .anchor p span {
    display: block;
	margin-bottom:0.5em;
}
#plan .task dl div {
	display:block;
}
#plan .task dt {
	margin-bottom:0.5em;
	white-space:normal;
}
#plan .task #task4 + dl dt {
    min-width: 0em;
}
#plan .task #task5 + dl dt {
    min-width: 0em;
}
#plan h4 {
    line-height: 1.6;
}
#plan .strategy .graph .left {
    width: 100%;
    flex-direction: row;
    align-items: stretch;
    position: relative;
	margin-bottom:7vw;
}
#plan .strategy .graph .left:after {
    right: 50%;
	transform: rotate(90deg);
    top: auto;
	bottom:-2em;
    margin-top: -1.28em;
}
#plan .strategy .graph .left p:nth-of-type(1) {
    height: auto;
	width:70%;
	padding:0.5em 0;
}
#plan .strategy .graph .left p:nth-of-type(2) {
    width: 30%;
    height: auto;
}
#plan .strategy .graph .right {
    width: 100%;
}
#plan .strategy .graph .right div {
    align-items: stretch;
}
#plan .strategy .graph .right dd {
	padding:0.5em 0 0.5em 2em;
}
#plan .strategy .graph .right dt {
	flex-direction: column;
    justify-content: center;
    text-align: center;
    align-items: center;
	display:flex;
}
  
  #plan .strategy .graph .right dt:nth-of-type(1)  {
padding: 4em 0;
}
  
#plan .movie_box iframe{
width: 100%!important;
    height: 54vw!important;
}  
  
  
#policy .lead{ 
  max-width:96%;
font-size: 1.8rem;
}  

/*#policy li{
	padding-left:3em;
	text-indent:-2.5em;
}*/
 
  
#right_box ul.anchor li {
        width: 100%;
        margin-right: 0%;
    }

#dx .lead{ 
  max-width:96%;
font-size: 1.8rem;
}   
  
#dx .logo img{
    height: 5rem;
    width: auto;
}

}



