@charset "UTF-8";
/* sec01 */
.container01 {
  width: 100%;
  height: 45vw;
  position: relative;
  background-image: url(../images/ir/ir_mv_sp.png);
  background-size: cover;
  background-position: top;
  background-repeat: no-repeat;
}

.text__main {
  & .txt__top1 {
      color: var(--color-black);
  }

  & .txt__top2 {
      color: var(--color-black);
  }
}

@media screen and (min-width: 999.8px) {
  /* sec01 */
  .container01 {
    width: 100%;
    height: 27vw;
    position: relative;
    background-image: url(../images/ir/ir_mv_pc.png);
    background-size: cover;
    background-position: top;
    background-repeat: no-repeat;
  }

}

/* sec02*/


#sec02 .contents {
  padding: min(10vw, 80px) min(10vw, 280px);
}

#sec02 h3{
  margin: 0 0 2vw;
}


#sec02 .table-wrap {
  overflow-x: auto;
  display: block;
  min-width: 600x;
  width: 100%;
  margin-bottom: 4rem;
}

.table {
  width: 100%;
  border-collapse: collapse;
  white-space: nowrap;
}

#sec02 .t_left{
  display: inline-block;
  width:50%;
  text-align: left;

}

#sec02 .t_right{
  display: inline-block;
  width:50%;
  text-align: right;

}


    thead {
      /* background-color: var(--color-main); */
      color: white;
    
    }

    th, td {
      padding: 10px 14px;
      border-right: 1px solid var(--color-main);
      text-align: center;
      white-space: nowrap;
      font-weight: normal;
    }

    th.firstcell{
      border: none;
    }
    th.anothercell{
      border: 1px solid var(--color-white);
      background-color: var(--color-main);
    }

    td.firstcell{
      background-color: var(--color-main); 
      color: white;
      /* font-weight: bold; */
      }

    td.firsttxt{
      color:var(--color-main);
      font-weight: bold;
      border-bottom: 1px solid var(--color-main);
    }

   .undermaker td{
   border-bottom: 1px solid var(--color-main);
  } 

    tbody tr:nth-child(odd) {
     background-color: #efefef;
    }



      th:first-child {
      text-align: left;
      font-weight: bold;
      /* background-color: white; */
    }


 /* Webkitブラウザ (Chrome, Safari) 用 */
    ::-webkit-scrollbar {
      width: 50%; /* スクロールバーの幅 */
    }
    ::-webkit-scrollbar-track {
      background: #f1f1f1; /* スクロールバーの背景 */
    }
    ::-webkit-scrollbar-thumb {
      background: #888; /* スクロールバーのバー */
      border-radius: 4px;
    }

.chart-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4rem;
  /* margin-bottom: 12vw; */
}

.chart-box {
  flex: 1 1 300px;
}

.chart-box img {
  width: 100%;
  height: auto;
}

.caption {
  margin-top: 8px;
  font-size: 14px;
  color: #333;
  font-weight: bold;
}



  #spTable th,
td {
  border-left: solid 1px var(--color-main);
  border-right: solid 1px var(--color-main);
  text-align: right;
}

#spTable th {
  font-size: 1.8rem;
  font-weight: 400;
  height: 20vw;

  vertical-align: middle;
  letter-spacing: 0.1em;
  padding-left: 7%;
}

#spTable th span {
  display: flex;
  font-size: 1.4rem;
  color: var(--color-main);
}

#spTable td {
  border-left: none;
  vertical-align: middle;
}

#spTable {
  width: 88%;
}

.spTable01 {
  height: 60vw;
  margin: 18vw auto 9vw;
}

.spTable02 {
  height: 100vw;
  margin: 9vw auto 18vw;
}

#spTable img {
  width: 31px;
  height: 31px;
}

#spTable td {
  margin-right: clamp(10px, 7vw, 60px);
}

@media screen and (min-width: 999.8px) {
  #sec02 h3{
    margin-bottom: 2vw;
  }

  #spTable {
    display: none;
  }

  #pcTable {
    display: block;
  }

  .pcTable01 th,
  td,
  .pcTable02 th,
  td {
    border-right:  1px var(--color-main);
  }

  #pcTable th {
    width: 44.5%;
    height: 8vw;
    font-size: 2.6rem;
    font-weight: 400;
    color: var(--color-black);
    vertical-align: middle;
    padding-left: 2.5vw;
    letter-spacing: 0.1em;
  }

  #pcTable th span {
    display: flex;
    font-size: 1.8rem;
    color: var(--color-main);
  }

  #pcTable td {
    height: 8vw;
    border-left: none;
    vertical-align: middle;
  }

  #pcTable img {
    text-align: center;
    width: 31px;
    height: 31px;
    margin-right: 2.5vw;
  }

  .pcTable01 {
    padding: 8vw 0 0;
  }

  .pcTable02 {
    padding: 0 0 8vw;
  }

  .pcTable02 tr:last-child th:last-of-type,
  .pcTable02 tr:last-child td:last-of-type {
    border-bottom: none;
    border-right: none;
  }

  .no-bottom {
    border-bottom: none;
  }

  .chart-row {
    margin-bottom: 0;
  }
}

.table tr td:last-child,
.table tr th:last-child {
  border-right: 1px solid var(--color-main); /* サイトのメインカラーを使う場合 */
}
