@charset "UTF-8";
/*---------------------------
IR共通
---------------------------*/
.page-template-page-ir .text + .text {
  margin-top: 1em;
}
.page-template-page-ir ul {
  list-style: none;
}
.page-template-page-ir.page .title {
  color: #45b035;
  text-align: center;
  font-size: 2rem;
  margin-top: 160px;
  font-weight: bold;
}
.page-template-page-ir .sec01 {
  margin-top: 80px;
}
.ir_title {
  color: #181878;
  font-size: 1.6em;
  margin-top: 80px;
  margin-bottom: 20px;
  font-weight: bold;
  line-height: 1.25;
}
.ir_title:first-child {
  margin-top: 0;
}
.ir_table {
  width: 100%;
  border-collapse: collapse;
}
.ir_table th, .ir_table td {
  border-bottom: 1px solid #c9caca;
  padding: 1em 0;
}
.ir_table th {
  padding-right: 1em;
  text-align: left;
  width: 200px;
}
.adobe_box {
  display: flex;
  align-items: center;
  margin: 80px 0 0;
  background: #e6e6e6;
  padding: 1em;
}
.adobe_box_link img {
  vertical-align: bottom;
}
.adobe_box_text {
  margin-left: 1em;
}
.ir_nav {
  width: 100%;
  max-width: 1000px;
  margin: 90px auto 0;
}
.ir_nav_container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(5, auto);
  gap: 30px;
}
.ir_nav_box:first-child {
  grid-column: 1/2;
  grid-row: 1/2;
}
.ir_nav_box:nth-child(2) {
  grid-column: 1/2;
  grid-row: 2/4;
}
.ir_nav_box:nth-child(3) {
  grid-column: 2/3;
  grid-row: 1/4;
}
.ir_nav_box:nth-child(4) {
  grid-column: 3/4;
  grid-row: 1/4;
}
.ir_nav_box:nth-child(5) {
  grid-column: 1/2;
  grid-row: 4/6;
}
.ir_nav_box:nth-child(6) {
  grid-column: 2/3;
  grid-row: 4/6;
}
.ir_nav_box:nth-child(7) {
  grid-column: 3/4;
  grid-row: 4/6;
}
.ir_nav_title {
  font-weight: bold;
  display: block;
  border-bottom: 1px solid #45b035;
  padding: .5em .5em .5em 1em;
}
.ir_nav_box ul {
  list-style: none;
}
.ir_nav_box li {
  padding: .5em 0 0;
  line-height: 1.5;
}
.ir_nav_box li a {
  padding-left: 1em;
}
.ir_nav_box a {
  display: block;
  position: relative;
}
.ir_nav_box a::before {
  content: "▶︎";
  display: block;
  position: absolute;
  top: .25em;
  left: 0;
  color: #45b035;
  font-size: .75em;
}
a.ir_nav_title::before {
  top: .75em;
}
@media (max-width: 768px) {
  .ir_table th, .ir_table td {
    display: block;
    width: 100%;
  }
  .ir_table th {
    border-bottom: none;
    padding-bottom: 0;
  }
  .ir_table td {
    padding-top: .5em;
  }
  .adobe_box {
    flex-direction: column;
    align-items: flex-start;
  }
  .adobe_box_link {
    margin-bottom: .5em;
  }
  .adobe_box_text {
    margin-left: 0;
  }
  .ir_nav {
    width: 95%;
    margin-bottom: 30px;
  }
  .ir_nav_container {
    grid-template-columns: 1fr;
    grid-template-rows: none !important;
  }
  .ir_nav_box {
    grid-column: auto !important;
    grid-row: auto !important;
  }
}
/*---------------------------
IR情報トップ
---------------------------*/
.irtop_title {
  text-align: center;
  color: #181878;
  font-size: 2.5rem;
  font-weight: bold;
  margin-bottom: 20px;
}
.irtop_btn {
  margin: 20px 0 0;
  text-align: right;
}
.irtop_btn .btn {
  padding: 0.5em 3em;
  margin: 0;
}
.page-parent .ir_nav_container {
  grid-template-rows: repeat(2, auto);
  gap: 30px;
}
.page-parent .ir_nav_box {
  grid-template-rows: none;
  grid-column: auto !important;
  grid-row: auto !important;
  border: 1px solid #181878;
  padding-bottom: 1em;
}
.page-parent .ir_nav_box:first-child {
  display: none;
}
.page-parent .ir_nav_title {
  text-align: center;
  padding: .5em;
  color: #fff;
  background: #181878;
  border-bottom: none;
}
.page-parent .ir_nav_box ul {
  padding: 0 1em;
}
/*---------------------------
IRニュース
---------------------------*/
.page-template-page-ir#news .cts {
  display: block !important;
}
/*---------------------------
トップメッセージ
---------------------------*/
.page-template-page-ir#message .sec01 {
  padding: 0;
  margin: 80px auto 0;
}
.page-template-page-ir#message .sec01 .cts {
  width: 100%;
  margin: 0;
  padding: 0;
}
.message_img {
  width: 250px;
  margin: 0 auto 1em 1em;
  text-align: center;
  float: right;
}
.message_img img {
  width: auto;
  max-width: 100%;
}
.message_img .text {
  line-height: 1.5 !important;
  margin-top: 1em !important;
}
.message_txt .text:first-child {
  margin-top: 0 !important;
}
.message_txt .ir_title {
  color: #231815;
  margin-top: 50px;
  font-size: 1.4em;
}
.message_note {
  text-align: right;
  font-size: .75em !important;
}
.message_img2 {
  margin-top: 50px;
  text-align: center;
}
.message_img2 img {
  width: auto;
  max-width: 100%;
}
.message_sign {
  text-align: right;
  margin-top: 3em;
}
.message_date {
  display: block;
}
.message_name {
  margin-top: 1em;
}
.message_name span {
  padding-top: .75em;
  font-size: 1.25em;
  font-weight: bold;
  display: block;
}
@media (max-width: 768px) {
  .message_img {
    margin-left: auto;
    float: none;
  }
}
/*---------------------------
会社概要
---------------------------*/
.overview_list {
  display: grid;
  grid-template-columns: 14em 1fr;
  row-gap: .25em;
}
/*---------------------------
コーポレート・ガバナンス
---------------------------*/
.governance_img {
  text-align: center;
}
/*---------------------------
IRライブラリ
---------------------------*/
.library_wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.library_item {
  flex: 0 1 45%;
  width: 45%;
  margin: 0 0 50px;
  position: relative;
  border: 1px solid #c9caca;
  padding: 20px 20px 88px;
}
.library_title {
  color: #181878;
  font-weight: bold;
  font-size: 1.6em;
  line-height: 1.25;
  margin-bottom: 1em;
}
.library_item .btn {
  padding: 0.5em 3em;
  position: absolute;
  bottom: 20px;
  right: 20px;
  margin-top: 0;
}
@media (max-width: 768px) {
  .library_item {
    flex: 0 1 100%;
    width: 100%;
  }
}
#securities .ir_title, #meeting .ir_title {
  margin-bottom: 0;
}
/*---------------------------
IRカレンダー
---------------------------*/
.calendar_img {
  margin-bottom: 50px;
  text-align: center;
}
.calendar_note {
  margin-top: 1em;
}
/*---------------------------
FAQ
---------------------------*/
.faq_list dt {
  position: relative;
  padding-left: 2em;
  color: #181878;
  font-weight: bold;
  font-size: 1.2em;
}
.faq_list dt::before {
  content: "Q";
  color: #fff;
  position: absolute;
  left: 0;
  font-size: 1.2em;
  width: 1.333em;
  height: 1.333em;
  background: #45b035;
  display: flex;
  justify-content: center;
  align-items: center;
}
.faq_list dd {
  border-bottom: 1px solid #c9caca;
  margin: .5em 0 2em;
  padding-left: 2.4em;
  padding-bottom: 2em;
}
.faq_list dd:last-child {
  margin-bottom: 0;
}