@charset "utf-8";
/* =======================================

	Customize Style

======================================= */
/* 本文中のリンク */
main a:link, main a:visited, main a:active, main a:hover {
  color: #003FB5;
  font-weight: bold;
}
/* 見出し */
h1, h2 {
  color: #004BA0;
}
.cont_header p.txt_catch {
  color: #FFF;
  background: linear-gradient(to right, #8CD8F0, #004BA0 25%);
  display: table;
  padding: 5px 54px;
  width: auto;
  font-size: 15px;
}
.unit {
  color: #333333;
  font-size: 1.6rem;
}
.h_bg {
  background-color: #004BA0;
}
.h_tri::before {
  border-color: transparent transparent transparent #004BA0;
}
.h_qa {
  color: #004BA0;
}
.h_qa02 {
  color: #333;
}
/* リストの● */
.ul_round li::before {
  background-color: #004BA0;
}
/*2025追加　リストの●*/
.ex-ul li::before {
  content: '';
  position: absolute;
  top: 11px;
  left: 0;
  display: block;
  width: 5px;
  height: 5px;
  background: #333;
  border-radius: 100%;}
  ul.ex-ul li{
    padding: 0 0 0 20px;
    position: relative;
    margin-left: 20px;
  }

/* グローバルヘッダー右上のボタン */
#global_header .sub_menu > ul li a {
  background-color: #004BA0;
}
body.pc_view #global_header.nav_02 .sub_menu > ul li a {
  background-color: #3887EF;
}
body.pc_view #global_header.nav_03 .sub_menu > ul li a {
  color: #004BA0;
  background-color: #D3EEF9;
  border: 1px solid #004BA0;
}
body.pc_view #global_header .sub_menu > ul li a:hover {
  background-color: #003FB5;
}
body.pc_view #global_header.nav_02 .sub_menu > ul li a:hover {
  background-color: #5F9FF2;
}
body.pc_view #global_header.nav_03 .sub_menu > ul li a:hover {
  background-color: #B6E4F8;
}
/* グローバルナビの区切り点の色 */
#global_nav ul li::before {
  background: #8C9BA5;
}
/* コンテンツヘッダー */
.cont_header {
  background: #e7f3fc;
}
.cont_header.visual .catch {
  color: #004BA0;
}
#pg_index .cont_header.visual::before {
  background: radial-gradient(ellipse at left top, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 70%);
  width: 100%;
  height: 100%;
  z-index: -1;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
}
#pg_index .cont_header.visual::after {
  z-index: -2;
}
.content-1 .cont_header.visual::before, .content-2 .cont_header.visual::before, .content-3 .cont_header.visual::before {
  /*background: linear-gradient(to right, rgba(232, 241, 246, .9) 0%, rgba(232, 241, 246, .75) 50%, rgba(255, 255, 255, 0) 100%);*/
  width: 100%;
  height: 100%;
  z-index: -1;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
}
.cont_header.visual::after {
  z-index: -1;
  background-position: top;
}
.content-1 .cont_header.visual::after, .content-2 .cont_header.visual::after, .content-3 .cont_header.visual::after {
  z-index: -2;
  background-position-y: bottom;
}
.cont_header.visual h1 {
  font-size: 30px;
}
.content-1 .cont_header.visual h1, .content-2 .cont_header.visual h1, .content-3 .cont_header.visual h1 {
  color: #FFF;
  font-size: 50px;
}
.cont_header h1 span {
  font-size: 166%;
}
.cont_header h1 span:nth-child(2) {
  margin-left: 22px;
}
/* コンテンツ中のボタン */
.btn_area a:link, .btn_area a:visited, .btn_area a:active, .btn_area a:hover {

border:none;
  color: #004BA0;
}
main a[target='_blank']::after{
background: transparent url(../img/ico_blank_f2.png) center center no-repeat !important;
}
body.pc_view .btn_area a{
    	-webkit-transition: opacity 0.65s ease-out;
	-moz-transition: opacity 0.65s ease-out;
	transition: opacity 0.65s ease-out;
}
body.pc_view .btn_area a:hover {
background-color:transparent;
opacity: 0.65;
}
.btn_area a.btn_blue {
  color: #fff;
  border-radius: 5px;
  background-color: #004BA0;
}
.btn_area a.btn_blue::after, .btn_area a.btn_grad::after {
  background: transparent url(../img/ico_blank_f.png) center center no-repeat;
  background-size: 100%;
}
body.pc_view .btn_area a.btn_blue:hover {
  background-color: #0049D2;
  border: solid 2px #0049D2;
}
.btn_area a.btn_grad {
  color: #fff;
  border-radius: 0;
  border: none;
  background: linear-gradient(90deg, rgba(0, 63, 181, 1) 0%, rgba(0, 45, 120, 1) 100%);
}
body.pc_view .btn_area a.btn_grad:hover {
  background: linear-gradient(90deg, rgba(0, 63, 181, 0.8) 0%, rgba(0, 45, 120, 0.8) 100%);
}
.btn_area a.btn_light_blue {
  color: #333;
  border-radius: 0;
  border: none;
  background: #E8F0F5;
}
body.pc_view .btn_area a.btn_light_blue:hover {
  background-color: #004BA0;
  color: #fff;
}
.btn_area a.btn_light_blue:hover::after {
  background: transparent url(../img/ico_blank_f.png) center center no-repeat;
  background-size: 100%;
}
/* グローバルフッター */
#cont_menu .issue {
  text-align: center;
}

#global_footer .ft_menu_wrap {

  background-size: contain;
}
#global_footer .ft_menu {
  width: 100%;
  /*background: linear-gradient(to left, rgba(140, 216, 240, .7) 0px, rgba(140, 216, 240, 1) 338px);*/
  background: #333333;
}
#global_footer .copy {
  /* background: linear-gradient(to left, rgba(0, 75, 160, 0) 258px, rgba(0, 75, 160, 1) 398px); */
  background-color: rgba(0, 75, 160, 1);
}
#global_footer .ft_menu li a {
  color: #FFF;
}
#global_footer .ft_menu li a::after {
  border-left-color: #FFF;
}
#pg_index span.next {
  border-width: 7px 0 7px 12px;
}
span.next {
  display: inline-block;
  border-style: solid;
  border-width: 7px 0 7px 12px;
  border-color: transparent transparent transparent #fff;
  margin: 0 15px;
  transform: translateY(2px);
}
p.currency {
  text-align: right;
  margin-top: 20px;
}
/* ------------------------------------

	Overwrite IndexElements

------------------------------------ */
    
    
 .btn_area{
  padding-top: 131px;
}
.btn_area a{
  display: inline-block;
  color: #fff !important;
  text-decoration: none;
  padding: 13px 24px!important;
  border-radius: 0;      
  text-align: center;
  line-height: 1.5;
  background-color: transparent;
  background-image: url('../img/btn_back.png');
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover; 
  background-blend-mode: overlay;
  box-shadow: none!important;
  min-width: 350px;
} 
.btn_area a{
  margin: 0!important;
}  
    
#pg_index .btn_area.blue_02 a[target='_blank']:hover::after {
  background: transparent url(../img/ico_blank_f.png) center center no-repeat;
  background-size: 100%;
}
#pg_index .btn_area.blue_02 a[href*='.pdf']:hover:after {
  background: transparent url(../img/ico_pdf_f.png) center center no-repeat;
  background-size: 100%;
}
/* ------------------------------------

	Overwrite ContentsElements

------------------------------------ */
/* ------------------------------------
	common
------------------------------------ */
.cont_header.visual {
  margin-bottom: 0;
}
#global_nav a.active {
  color: #004BA0;
}
#global_nav ul li::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 4px;
  left: 0;
  bottom: 0;
  background: #004BA0;
  transition: .3s;
  opacity: 0;
}
#global_nav ul li:hover::after {
  background-color: #004BA0;
}
#global_nav ul li:hover::after {
  opacity: 1;
}
.br-tablet, .br-xsp {
  display: none;
}
/* トップメッセージ */
.topmessage .contents_wrap section > h2 {
  font-weight: 600;
  color: #333333;
  border-bottom: 5px solid #85C5EE;
  margin-bottom: 1.33em;
  padding-bottom: 3px;
}
.topmessage h3 {
  margin: 0 0 5px 0;
  color: #004BA0;
}
.greeting h2 {
  font-size: 16px;
}
.greeting .twocolumn {
  margin-bottom: 0px;
}
.topmessage .cont_header.visual p.date, .topmessage .cont_header.visual p.sign {
  font-weight: bold;
  margin-bottom: 0px;
  line-height: 1.6;
  font-size: 2rem;
}
.topmessage .contents_wrap {
  max-width: 1100px;
}
/* トップページ */
.widebelt {
  padding-top: 180px;
  margin-bottom: 260px;
  background-size: contain;
  background-color: #004ba0;
}
.widebelt .base_wrap.wide{
  position: absolute;
  margin-top: -90px;
    right: 0;
    left: 0;
}
ul.cont_index li {
  background-position: top !important;
  background-size: auto !important;
  height: 217px;
}
.pattern_01 .cont_index li:first-child {
  background-position: center top !important;
}
.cont_index li a::after {
  content: none !important;
}
.cont_index li div {
  margin: 195px auto auto !important
}
.cont_index li div p {
  font-size: 16px;
  text-align: left;
}
.cont_index li div p::after {
  /*
    top: 43%;
        left: 3px;
        width: 10px;
        height: 10px;
        border-top: 2px solid #FFF;
        border-right: 2px solid #FFF;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    display: inline-block;*/
    content: "";
    height: 11px;
    width: 9px;
    background: url(../img/pattern_01/content_arrow.png) no-repeat center center;
  margin-left: 10px;
  display: inline-block;

  transition: transform 0.2s ease-out;
}
.cont_index li a:hover div p::after {
  transform: translateX(10px);
}
/* topmessage */
.topmessage .cont_header.visual.large.message {
  /*height: 486px;*/
  height: auto !important;
}
.topmessage .cont_header.visual.large.message::after {
  background: url(../img/topmessage/topmessage_pc.jpg) right no-repeat;
  background-color: #E8F1F6;
  background-size: contain;
}
.wrap_inner {
  max-width: 1010px;
  position: relative;
}
/* topmessage トップメッセージ */
.topmessage .cont_header.visual h1 {
  margin-bottom: 29px;
  line-height: 1.4em;
  font-size: 40px;
}
.topmessage .cont_header.visual h1 small {
  margin-bottom: 6px;
  line-height: 1.4em;
}
.pattern_01 .cont_index li a::before {
  content: none;
}
section .sq:first-child {
  margin-top: 49px;
}
section .sq {
  margin-top: 29px;
  font-size: 16px;
  margin-bottom: 30px;
  line-height: 1;
}
.sq:before {
  content: "■";
  color: #8CD8F0;
  margin-right: .5em;
}
.content-1 .topics_list article {
  border: none;
}
.content-1 table.five_column tr th, .content-1 table.five_column tr td {
  color: initial;
  background-color: initial;
}
.content-1 table.five_column tr td:nth-child(5n) {
  color: initial;
}
.content-1 table.number-target {
  border-collapse: collapse;
  width: 100%;
  border-bottom: none;
}
.content-1 table.number-target th, .content-1 table.number-target td {
  border: 1px solid #000;
  padding: 10px;
}
.content-1 table.number-target th:first-child, .content-1 table.number-target td:first-child {
  border-left: none !important;
}
.content-1 table.number-target th:nth-child(2), .content-1 table.number-target th:nth-child(3), .content-1 table.number-target td:nth-child(2), .content-1 table.number-target td:nth-child(3) {
  background-color: #e4f3f9;
}
.content-1 table.number-target tr:first-child th:nth-child(3), .content-1 table.number-target th:nth-child(4), .content-1 table.number-target td:nth-child(4) {
  background-color: #c7e5f2;
}
.content-1 table.number-target th:last-child, .content-1 table.number-target td:last-child {
  background-color: #b6deee;
}
.content-1 table.number-target td, .content-1 table.number-target th {
  border-left: none;
  border-right: none;
}
.content-1 table.number-target thead tr th:first-child, .content-1 table.number-target thead tr td:first-child, .content-1 table.number-target thead tr {
  border: none;
}
.content-1 table.number-target thead tr:not(:first-child) td:nth-child(2), .content-1 table.number-target tbody tr td:nth-child(2) {
  border-right: 1px dotted #000;
}
.content-1 table.number-target thead tr th, .content-1 table.number-target thead tr td {
  font-size: 16px;
  text-align: center;
  vertical-align: middle;
  font-weight: bold;
}
.content-1 table.number-target tr td {
  font-size: 2.6rem;
  text-align: center;
  vertical-align: middle;
  font-weight: bold;
}
.content-1 table.number-target tbody tr th {
  padding: 15px 10px;
  font-weight: bold;
  vertical-align: middle;
}
.content-1 .number-target tbody th:first-child, .content-1 .number-target tbody td:first-child {
  background-color: #FFF;
}
.content-1 .number-target tbody tr td {
  text-align: right;
}
.content-1 article {
  padding: 0;
}
.content-1 .exposition img, .content-1 .e3 img {
  margin-bottom: 25px;
}
.content-1 .strategic_plan img {
  margin-bottom: 15px;
}
.content-1 .exposition img:last-child,
.content-1 .e3 img:last-child,
.content-1 .strategic_plan img:last-child {
  margin-bottom: 0px;
}
.topmessage .greeting,
.topmessage .exposition{
  margin-top: 20px;
  background-color: #f1fcff;
  padding: 30px;
}
.topmessage .greeting{
    padding-bottom:70px;
}
.topmessage .exposition{
    
    margin-top:0;
}
.topmessage .exposition div{
    
    max-width: 800px;
    margin:auto;
}
.topmessage .greeting p:last-child {
  font-weight: bold;
  text-align: right;
}
.topmessage .contents_wrap section:last-child img {
  margin-top: 10px;
}
.topmessage .cont_header.visual p {
  line-height: 2;
}
/* content-1 */
.content-1 div.div_point.blue {
  background-color: #e8f7fc;
  padding: 38px 30px;
}
.content-1 div.div_point ul li::before {
  content: '';
  display: block;
  width: 10px;
  height: 10px;
  background: #004BA0;
  border-radius: 100%;
  position: absolute;
  top: 11px;
  left: 0;
}
.content-1 div.div_point ul li {
  margin-bottom: 35px;
  position: relative;
  padding-left: 20px;
}
.content-1 div.div_point ul span {
  display: flex;
  flex-wrap: wrap;
}
.content-1 div.div_point ul li span span {
  margin-left: 1em;
}
.content-1 div.div_point ul li:last-child {
  margin-bottom: 0px;
}
.content-1 div.div_point dl {
  flex-direction: row;
}
.content-1 .div_point dl dt {
  width: auto;
  flex-basis: 4em;
  color: #004BA0;
}
.content-1 h3 {
  margin-top: 50px;
  position: relative;
  padding-left: 20px;
  font-size: 16px;
}
.content-1 h3::before {
  content: "";
  display: block;
  height: 5px;
  width: 12px;
  background-color: #8CD8F0;
  margin-right: 8px;
  margin-left: 0px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin-top: auto;
  margin-bottom: auto;
}
.content-1 dl.construction {
  display: flex;
  margin-top: 24px;
  display: grid;
  grid-template-columns: auto 1fr;
}
.content-1 dl.construction dt {
  text-align: center;
  color: #004BA0;
  background-color: #E8F0F5;
  font-weight: bold;
  padding: 4px 13px;
  grid-column: 1 / 2;
}
.content-1 dl.construction dd {
  padding: 5px;
  margin-left: 20px;
  grid-column: 2 / 3;
}
.content-1 dl.construction dd a {
  color: #333333;
}
.content-1 dl.construction dd a::after {
  content: none;
}
.content-1 .segment_text {
  width: calc(75% - 5px);
  max-width: 595px;
}
.content-1 figure.segment_graph {
  width: 170px;
  margin: 0;
}
.content-1 figure.segment_graph figcaption {
  color: #004BA0;
  font-size: 1.5rem;
}
.content-1 table.four_column tbody tr td:nth-child(2), .content-1 table.four_column tbody tr td:nth-child(3) {
  text-align: right;
  color: #004BA0;
  padding-right: 29px;
}


/* content-3 */
.content-3 .img_logo {
  width: auto;
}
.content-3 .main_contents_area {
  border-bottom: dotted;
  border-color: #B4B4B4;
}
.content-3 .main_contents_area h2 {
  margin-bottom: 0 0 34px;
}
.content-3 .twocolumn {
  margin: 0 0 100px;
}
.content-3 .text_company {
  width: 66.25% !important;
}
.content-3 .text_company p:first-child {
  margin-bottom: 29px;
}
.content-3 .text_company p:nth-child(2) {
  text-align: right;
  margin-bottom: 26px;
  font-weight: bold;
}
.content-3 .text_company p:nth-child(2) span {
  font-size: 125%;
}
.content-3 a.c-example {
  position: relative;
  padding-right: 45px;
}
.content-3 a.c-example::before {
  content: "";
  position: absolute;
  margin: auto;
  bottom: -4px;
  right: 3px;
  width: 30px;
  height: 30px;
  border-radius: 100%;
  background: #FFF;
  border: 2px solid #004BA0;
}
.content-3 a.c-example::after {
  content: "";
  position: absolute;
  margin: auto;
  bottom: 7px!important;
  bottom: 0;
  right: 15px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #004BA0;
  border-right: 2px solid #004BA0;
  transform: rotate(45deg);
  background: none;
}
.content-3 a.c-example:hover::before {
  background: #004BA0;
  border-color: #004BA0;
}
.content-3 a.c-example:hover {
  text-decoration: none;
  color: #004BA0;
}
.content-3 a.c-example:hover::after {
  border-top: 2px solid #FFF;
  border-right: 2px solid #FFF;
}
#page_top {
  background: #FFF;
  color: #004BA0;
  border: 2px solid #004BA0;
  border-radius: 100%;
}
#page_top:before {
  border-color: #004BA0;
}
p.asterisk::before {
  content: "※";
  display: inline-block;
  margin-left: -1em;
}
p.asterisk {
  padding-left: 1em;
}
p.rsc {
  margin-top: 60px !important;
}
@media (min-width: 769px) {
  #global_header {
    box-shadow: 0px 3px 6px rgba(0, 0, 0, .15);
  }
  #global_nav ul li {
    position: relative;
  }
  body.pc_view #global_nav a {
    min-height: 50px;
    display: inline-block;
  }
  body.pc_view #global_nav a:hover {
    color: #004BA0;
  }
  body.pc_view #global_nav ul li::after {
    z-index: -1;
  }
  #global_nav a {
    position: static;
  }
  .pattern_01 .cont_index li a {
    padding: 0px;
  }
  .pattern_01 .cont_index li a:hover::before {
    content: "";
    height: 180px;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    background: rgba(255,255,255, .3);
    border: none;
  }
  #global_nav ul li a.active:after {
    bottom: 0px;
    background-color: #004BA0;
  }
  #pg_index .btn_area {
    margin-top: 37px;
  }
  .contents_wrap {
    margin-top: 99px;
  }
  .content-1 .topics_list article {
    margin-bottom: 70px;
  }
  .topmessage .contents_wrap section > h2 {
    font-size: 24px;
  }
  .topmessage .exposition {
    margin-bottom: 30px;
  }
  .topmessage .cont_header.visual p {
    font-size: 1.8rem;
    text-align: justify;
    word-break: break-all;
    text-justify: inter-ideograph;
    text-justify: inter-character;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .greeting .twocolumn div:nth-child(1) {
    width: 40%;
    max-width: 400px;
  }
  .greeting .twocolumn div:nth-child(2) {
    width: calc(50% + 30px);
  }
  /*
	.greeting img {
		width: calc(40% + 25px);
		max-width: 400px;

	}*/
  .content-1 .topics_list article h2 {
    font-size: 28px;
    font-weight: 600;
    text-align: center;
    color: #004BA0;
    margin-bottom: 30px;
  }
  .content-1 .topics_list article h2 small {
    font-size: 20px;
  }
  .br-sp {
    display: none;
  }
    #global_footer nav.three_column ul li{
        margin:0 3.5% 0 0;
    }
  #global_footer nav.three_column ul li:last-child {
    width: 16em;
      white-space: nowrap;
  }
    #global_footer nav.three_column ul li:nth-child(3n){
        text-align: right;
    }
    #cont_menu ul li a::before{
    top:0.4em;
    background-color:#004BA0;
    height:10px;
    border:none;

}
  @media (max-width: 1120px) {
    .br-tablet {
      display: inline-block;
    }
  }
}
/* スマートフォン時の表示位置調整 */
@media (max-width: 768px) {
  #cont_menu {
    background: #F1FCFF;
  }
  #cont_menu .issue {
    text-align: left;
  }
    #cont_menu ul li a{
        padding-left:1em;
    }
    #cont_menu ul li a::before{
border-color: transparent transparent transparent #004BA0 !important;
        border-width: 5px 0 5px 5px !important;
        border: solid;
        position: absolute;
        content: "";
        transform: none;
    }
  .content-1 .cont_header.visual h1, .content-2 .cont_header.visual h1, .content-3 .cont_header.visual h1 {
    font-size: 2.8rem;
  }
  .cont_header .wrap {
    padding: 90px 0;
  }
  #global_footer .ft_menu_wrap {
    background-size: auto 119px;
  }
  #global_footer .copy {
    font-size: 10px;
  }
  #global_footer .ft_menu {
    background:#333;
  }
  #global_footer .copy {
    background: linear-gradient(to left, rgba(0, 75, 160, 0) 185px, rgba(0, 75, 160, 1) 225px);
    background-color: rgba(0, 75, 160, 1);
  }
  #pg_index .cont_header.visual::after {
    background-position: left -30px top;
  }
  #pg_index .cont_header.visual h1 {
    font-size: 26px;
  }
  #pg_index .cont_header.visual h1 span {
    font-size: 173%;
  }
  .cont_header p.txt_catch {
    margin: auto;
    padding: 10px 15px;
  }
  .cont_header.visual h1 {
    font-size: 35px;
  }
  .contents_wrap {
    margin-top: 30px;
  }
  .topmessage .cont_header.visual.large.message {
    height: auto;
  }
  .cont_header.visual.large .wrap {
    display: flex;
    flex-direction: column;
  }

  .topmessage .cont_header.visual::after {
    display: none;
  }
    .topmessage .cont_header.visual.large .wrap::after{
        background-color:#e8f1f6;
    }
  .cont_header.visual.large .wrap h1 {
    order: -2;
  }
  .cont_header.visual.message .wrap::after {
    content: none;
  }
  .wrap_inner {
    display: flex;
    flex-wrap: wrap;
  }
  .cont_header.visual.message .wrap_inner::after {
    content: '';
    background-image: url("../img/topmessage/topmessage_sp.jpg");
    background-position: top center;
    background-size: cover;
    display: block;
    width: 100%;
    height: 80vw;
    order: 1;
    z-index: 1;
    margin-left: 0;
  }
  p.date {
    order: 3;
  }
  p.sign {
    order: 4;
  }
  .topmessage .cont_header.visual.large.message::after {
    content: none;
  }
  .cont_header.visual h1 small {
    font-size: 20px;
  }
  .cont_header.visual.large .wrap h1 {
    background: #E8F1F6;
    margin: 20px 20px 0;
    line-height: 1em;
  }
  .cont_header.visual.large .wrap {
    padding-bottom: 0px;
    margin-bottom: 5px;
  }
  .cont_header.visual.large p {
    background-color: #E8F1F6;
    width: 92%;
    padding: 25px 0;
    margin: 0 auto;
  }
  .cont_header.visual.large p.date {
    margin-top: 30px;
    padding: 0;
  }
  .cont_header.visual.large p.sign {
    padding: 0;
    margin-bottom: 30px;
  }
  .pattern_01 .cont_index li {
    width: 80%;
    margin: 0px auto 22px;
  }
  .pattern_01 .cont_index li {
    background: none !important;
    display: table;
  }
  .widebelt {
    padding-top: 22px;
    padding-bottom: 22px;
    background-size: auto;
    background-color: #004BA0;

    background-position: top center;
    background-size: cover;
  }

  /*sp版ヘッダー背景画像*/
  .contents-2 .cont_header.visual .wrap, .contents-3 .cont_header.visual .wrap, .contents-4 .cont_header.visual .wrap {
    padding: 20px 10px 10px;
    background: #E8F1F6;
    width: 100%;
    margin-top: 20px;
  }
  .contents-2 .cont_header.visual.summary::after {
    background: url("../img/contents-2/header_bg_sp.png")center center no-repeat;
    background-size: cover;
  }
  .contents-3 .cont_header.visual.feature::after {
    background: url("../img/contents-3/header_bg_sp.png")center center no-repeat;
    background-size: cover;
  }
  .contents-4 .cont_header.visual.kabunushi::after {
    background: url("../img/contents-4/header_bg_sp.png")center center no-repeat;
    background-size: cover;
  }
  .topmessage .greeting {

    padding: 15px;
  }
  .greeting h2 {
    order: -2;
  }
  .greeting img {
    order: -1;
    margin-bottom: 20px;
  }
    
  /* contents-1 サステナビリティがトップページに統合されたことによって廃止予定 */
  .cont_header.visual.large .wrap {
    background: #E8F1F6;
    margin: 0;
    width: 100%;
  }
  .content-1xx table.number-target tbody tr th {
    padding: 0.8em 0.4em;
  }
  .content-1xx table.number-target tr, .content-1 table.number-target tr td {
    font-size: 1.4rem;
  }
  .content-1xx table.number-target tr td span {
    font-size: 1rem;
  }
  .content-1xx table.number-target thead tr th {
    font-size: 1.4rem;
    padding: 0.5em 0;
  }
  .content-1xx .number-target tbody tr td {
    text-align: right;
  }
  .content-1xx .segment_text {
    order: 0;
    width: 100%;
    max-width: initial;
  }
  .content-1 figure.segment_graph {
    order: 1;
    width: 100%;
    margin-bottom: 20px;
    margin-top: 20px;
  }
  .content-1 figure.segment_graph img {
    width: auto;
    margin: auto;
    display: block;
  }
  .content-1 table.four_column tbody tr td:nth-child(2), .content-1 table.four_column tbody tr td:nth-child(3) {
    padding-right: 14px;
  }
  .content-1 p.rsc {
    order: 3;
  }
  /* contents-3 */
  .contents-3 .flex figure figcaption {
    text-align: center;
  }
  .content-3 h2 {
    text-align: center;
  }
  .content-3 .text_company {
    width: 100% !important;
    order: 2;
  }
  .content-3 .img_face_area {
    order: 1;
  }
  /* reco */
  .reco .cont_header .wrap {
    height: 103px;
  }
  .reco .cont_header .wrap h1 {
    margin-top: 15px;
  }
}
@media (max-width: 1244px) and (min-width:961px) {
  .topmessage .wrap_inner {
    width: 75%;
  }
  .topmessage .cont_header.visual.large.message::after {
    background-position: right -120px top;
  }
}
@media (max-width: 960px) and (min-width:769px) {
  .topmessage .cont_header.visual.large.message::after {
    background-position: right -100px top;
  }
  .topmessage .wrap_inner {
    width: 90%;
  }
 .cont_header.visual.large .wrap::after {
    background: #E8F1F6;

  }
}
@media (max-width: 480px) {
  .content-1 table.number-target th, .content-1 table.number-target td {
    padding: 5px;
  }
  .br-xsp {
    display: block;
  }
  .content-1 .number-target tbody tr td {
    text-align: right;
    line-height: 1em;
  }
}
/* topmessage tablet overwrite*/
@media (min-width:1091px) and (max-width:1400px) {
  .topmessage .cont_header.visual.large.message::after {
    background-position: right -80px top;
  }
}
@media (min-width:959px) and (max-width:1090px) {
  .topmessage .cont_header.visual.large.message::after {
    background-size: cover;
    background-position: right -230px top;
  }
}
@media (max-width:959px) and (min-width:769px) {
  .topmessage .wrap_inner {
    display: flex;
    flex-wrap: wrap;
  }
  .cont_header.visual {
    /*background: #e7f3fc;*/
  }
  .cont_header .wrap {
    /*width: 100%;*/
  }
  .topmessage .wrap_inner {
    width: 100%;
  }
  .cont_header.visual.large .wrap h1 {
    background: #E8F1F6;
    margin: auto 0;
    line-height: 1em;
    width: 92%;
    order: -2;
    margin-bottom: 25px;
  }
  .cont_header.visual p {
    /*order: -1;
		width: 92%;
		padding: 25px 0;
		margin-right: auto;
		margin-left: auto;*/
  }
  .cont_header.visual.large p.date {
    margin-top: 30px;
    padding: 0;
    order: 1;
  }
  .cont_header.visual.large p.sign {
    padding: 0;
    margin-bottom: 30px;
    order: 2;
  }
  .topmessage .cont_header.visual.large.message::after {
    content: none;
  }
  .cont_header.visual.message .wrap_inner::after {
    content: '';
    background-image: url("../img/topmessage/topmessage_sp.jpg");
    background-position: top center;
    background-size: cover;
    display: block;
    width: 100%;
    height: 80vw;
    order: 0;
    z-index: 1;
    margin-left: 0;
  }
}
@media print {
  .cont_header.visual.large {
    background: none;
  }
  .cont_header.visual.large .wrap h1 {
    margin-bottom: 29px;
  }
  .cont_header.visual p {
    width: 73%;
    margin: 0 0 28px 0;
    padding: 0 !important;
  }
  .cont_header.visual.large .wrap::after {
    content: none;
  }
  .cont_header.visual.message .wrap_inner::after {
    /* print bug fixed*/
    content: "";
    background-color: #FFF;
    background-image: url("../img/topmessage/topmessage_sp.jpg") !important;
    z-index: 100;
    display: block;
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }
  .cont_header.visual {
    flex-wrap: wrap;
  }
  .topmessage .cont_header.visual p.date, .topmessage .cont_header.visual p.sign {
    margin-bottom: 0px;
    padding: 0 !important;
  }
  .cont_header.visual.large p.date {
    order: 2;
  }
  .cont_header.visual.large p.sign {
    order: 3;
  }
  @media (max-width: 959px) {
    .cont_header.visual.large .wrap h1 {
      margin-bottom: 0px;
    }
    .cont_header.visual.large {
      background: #e7f3fc;
    }
    .cont_header.visual p {
      width: 92%;
      padding: 25px 0 !important;
      margin-right: auto;
      margin-left: auto;
    }
    .cont_header.visual.large p.sign {
      margin-bottom: 30px;
    }
  }
}
@media (min-width: 1000px) {
  .greeting .twocolumn div:nth-child(2) {
    width: calc(50% + 80px);
  }
}
/*印刷時のバグ修正*/
.sp_load {
  display: none;
}
.text-indent {
  text-indent: 1em;
}
.small{
    font-size:small;
}



/* 第14回 */
.topmessage .flex figure {
  width: calc(25% - 30px);
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 65px;
  margin-right: 20px;
  margin-left: 20px;
}
.topmessage .flex figure:first-child {
  margin-left: 0;
}
.topmessage .flex figure:last-child {
  margin-right: 0;
}
.topmessage .flex {
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: stretch;
  display: flex;
}
.topmessage .greeting .twocolumn{
    margin-bottom:100px;
}
.topmessage .graph_wrap {
  max-width: 800px;
  margin: auto;
}
@media only screen and (max-width: 767px) {
  .topmessage .flex figure {
    width: 100%;
    margin-bottom: 65px;
    margin-right: 0;
    margin-left: 0;
  }
  .topmessage .flex {
    display: block;
  }
  .topmessage .topmessage_p {
    order: -1;
  }
  .topmessage .greeting .graph_title {
    margin-top: 40px;
    text-align: center;
  }
}
@media only screen and (min-width: 768px) {
  .topmessage .greeting .graph_title {
    margin-top: 25px;
    text-align: center;
    font-size: x-large;
  }
}
.topmessage .greeting .graph_title span {
  font-size: 83%;
}

.topmessage .table_co2 .table_wrap table th {
  background: #e5e5e5;
  font-weight: bold;
}
.topmessage .table_co2 .table_wrap table {
  width: 100%;
  border: 2px solid #000;
  border-collapse: collapse;
  border-spacing: 0;
}
.topmessage .table_co2 .table_wrap table th,
.topmessage .table_co2 .table_wrap table td {
  padding: 10px 15px;
  line-height: 1.5;
  border: solid 2px #000;
}
.topmessage .table_co2 .achievement {
  text-align: center;
}
.topmessage .table_co2 {
  width: 100%;
  margin: 0 auto 0;
}
.topmessage .scope2 {
  margin-left: 48px;
}
.topmessage .exposition dl {
  display: flex;
  flex-wrap: wrap;
}
.topmessage .exposition dl dt {
  width: 5em;
}
.topmessage .exposition dl dd {
  width: calc(100% - 5em);
}
.topmessage .annotation {
  margin-left: 5em;
}
.topmessage .table_co2 p:last-child {
  margin-left: 6.9em;
  padding-left: 0em;
  text-indent: -3.9em;
}
/* content-1 サステナビリティ統合により廃止予定　xx追加 */


.content-1xx .topics_list article h2 {
  text-align: left;
}
.content-1xx h3 {
  margin: 0 0 5px 0;
  color: #004BA0;
}
.content-1xx .annotation {
  margin-left: 5em;
}
.content-1xx .table_co2 .table_wrap table th, .table_co2 .table_wrap table td:first-child {
  background: #e5e5e5;
  font-weight: bold;
}
.content-1xx .table_co2 .table_wrap table {
  width: 100%;
  border: 2px solid #000;
  border-collapse: collapse;
  border-spacing: 0;
}
.content-1xx .table_co2 .table_wrap table th,
.content-1xx .table_co2 .table_wrap table td {
  padding: 10px 15px;
  line-height: 1.5;
  border: solid 2px #000;
}
.content-1xx .table_co2 .achievement {
  text-align: center;
}
.content-1xx .table_co2 {
  width: 100%;
  margin: 0 auto 0;
}
.content-1 .scope2 {
  margin-left: 48px;
}
.content-1xx .exposition dl {
  display: flex;
  flex-wrap: wrap;
}
.content-1xx .exposition dl dt {
  width: 5em;
}
.content-1xx .exposition dl dd {
  width: calc(100% - 5em);
}
.content-1xx .astrisk {
  padding-left: 1em;
  text-indent: -1em;
}
.content-1xx .table_co2 p {
  padding-left: 6.9em;
  text-indent: -6.9em;
}

.content-1xx .table_co2 p:last-child {
  margin-left: 6.9em;
  padding-left: 0em;
  text-indent: -3.9em;
}
@media only screen and (max-width: 767px) {
  .content-1xx .annotation {
    margin-left: 0;
  }
  .scope2 {
    margin-left: 0;
  }
}
/* content-1 */
.content-1 .flex figure {
  width: calc(50% - 25px);
  display: flex;
  flex-wrap: wrap;
  margin-right: 0;
  margin-left: 0;
  margin-bottom: 40px;
}
@media only screen and (min-width: 768px) {
  .content-1 .flex figure:nth-child(odd) {
    margin-right: 25px;
  }
  .content-1 .flex figure:nth-child(even) {
    margin-left: 25px;
  }
}
.content-1 .flex {
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: stretch;
  display: flex;
}
.content-1 .segment_img {
  max-width: 90%;
}
.content-1 .segment_text {
  width: calc(50% - 5px);
  max-width: 595px;
}
.content-1 figure.segment_graph figcaption {
  color: #002D78;
  font-size: 1.4rem;
}
.content-1 ol {
  list-style-type: none;
  counter-reset: item;
}
.content-1 ol > li {
  counter-increment: item;
  margin-bottom: 5px;
}
.content-1 ol > li::before {
  content: counter(item);
  display: inline-block;
  width: 20px;
  height: 20px;
  text-align: center;
  line-height: 20px;
  background-color: #004BA0;
  color: #FFFFFF;
  border-radius: 50%;
  margin-right: 10px;
}
.content-1 ol > li ul li{
  list-style-type: disc;
    list-style-position: outside;
    margin-left:3em;
}
.content-1-ul{
  width: 40%;
}

/* 数値目標表 */
.content-1 .policy {
  margin-bottom: 50px;
  overflow: auto
}
.content-1 .policy .table_wrap table th + td, .content-1 .policy .table_wrap table td + th {
  border-left: 2px solid #000;
  text-align: center;
}
.content-1 .policy .table_wrap table {
  width: 100%;
  border: 2px solid #000;
  border-collapse: collapse;
  border-spacing: 0;
}
.content-1 .policy .table_wrap table th:first-child {
  width: 272px;
}
.content-1 .policy .table_wrap table th, .content-1 .policy .table_wrap table td:first-child {
  background: #e5e5e5;
  font-weight: bold;
}
.content-1 .policy .table_wrap table th, .content-1 .policy .table_wrap table td {
  padding: 10px 15px;
  line-height: 1.5;
  text-align: center;
}
.content-1 .policy .table_wrap table td:nth-child(n+2) {
  text-align: right;
}
.content-1 .policy .dot-line {
  border-right: 2px dotted #000;
  border-left: 2px solid #000;
}
.content-1 .policy .table_wrap table .b-line-l {
  border-left: 4px solid #00b0f0;
  border-right: 2px dotted #000;
}
.content-1 .policy .table_wrap table .b-line2 {
  border-top: 4px solid #00b0f0;
  border-right: 4px solid #00b0f0;
  border-left: 4px solid #00b0f0;
  border-bottom: 2px solid #000;
}
.content-1 .policy .table_wrap table .b-line-r {
  border-right: 4px solid #00b0f0;
  border-left: 2px dotted #000;
}
.content-1 .policy .table_wrap table .b-line3 {
  border-left: 4px solid #00b0f0;
  border-right: 2px dotted #000;
  border-bottom: 4px solid #00b0f0;
}
.content-1 .policy .table_wrap table .b-line4 {
  border-right: 4px solid #00b0f0;
  border-left: 2px dotted #000;
  border-bottom: 4px solid #00b0f0;
}
.content-1 .policy .table_wrap table td {
  border-top: 2px solid #000;
}
.content-1 .line-1 {
  border: 2px solid #000;
}
/*2025追加*/
.exposition h3 {
  margin-top: 50px;
  position: relative;
  padding-left: 0px;
  font-size: 16px;
  color: #004BA0;
  margin-bottom: 0;
  line-height: 32px;
}
.exposition h3::before {
display: none;
}
@media only screen and (max-width: 767px) {
  .content-1 .flex figure {
    width: 100%;
    margin-bottom: 40px;
  }
  .content-1 .flex {
    display: block;
  }
  .content-1_p {
    order: -1;
  }
  .content-1 figure.segment_graph {
    order: -1;
    width: calc(50% - 5px);
    margin-bottom: 20px;
  }
  .content-1 .segment_text {
    order: 0;
    width: 100%;
    max-width: initial;
  }
  .content-1 dl.construction dd {
    font-size: 14px;
  }
  .content-1 .table_wrap table th, .content-1 .table_wrap table td {
    font-size: 12px;
  }
  .content-1-ul{
    width: 100%;
  }
}
/*インターライフグループの紹介の企業情報*/
.profile_area .inner{padding: 0 20px;}
.profile_area .inner table {
  width: 100%;
  border-top: 1px solid #cccccc;
}
.profile_area .inner table th {
  width: 198px;
  color: #004ba0;
  text-align: left;
  font-weight: normal;
}
.profile_area .inner table th,.profile_area .inner table td {
  border-bottom: 1px dotted #8e8e8e;
  padding: 28px 0 28px 17px;}

.profile_area .inner table td {
  width: calc(100% - 198px);
}
.profile_area .inner table th {
  width: 198px;
  color: #004ba0;
  text-align: left;
  font-weight: normal;
}
.profile_area h2 {
  font-size: 3rem;
  color: #004ba0;
  font-weight: bold;
  margin: 60px 0 25px;
}
.profile_area .overview{
  padding-left: 20px;
}

@media (max-width: 767px) {
 .profile_area .inner table,.profile_area .inner table tbody,.profile_area .inner table tr,.profile_area .inner table th,.profile_area .inner table td {
      display: block;
      width: 100%;}
  .profile_area .inner table th {
      width: 100%;
      border-bottom: none;
      padding: 15px 0 0 0;
  }
  .profile_area .inner table th{
    padding: 12px 0 0 0;}
    .profile_area .inner table td {
      padding: 0 0 12px 0;
    }
  .profile_area h2 {
    margin: 45px 0 10px;
    text-align: left;
}

}
/*アトラスボードについて*/
.content-2 .exposition dl{
  display: flex;
flex-wrap: wrap;}
.content-2 .exposition dl dt{
  width: 5em;
}
.content-2 .exposition dl dd {
  width: calc(100% - 5em);
}
.content-2 .astrisk {
  padding-left: 1em;
  text-indent: -1em;
}
.content-2 .annotation {
  margin-left: 5em;}
  @media only screen and (max-width: 767px) {
    .content-2 .annotation {
        margin-left: 0;
    }
}