@charset "utf-8";
main {
  padding-top: 1;
  padding-left: 0;
  padding-right: 0;
}

.no-data {
  padding-left: 2rem;
  padding-top: 1rem;

}

/*アプリ版にpadding*/
.billing-select,
#detail {
  padding-left: 1rem;
  padding-right: 1rem;
}

/*請求情報h2*/
.billing {
  background-color: #1d5d9b;
  color: #fff;
  padding: 1rem 0rem 1rem 1rem;
  font-weight: bold;
}

/*対象月・請求先*/
.billing-select h3 {
  padding: 0.4rem 0.5rem 0rem 0rem;
  font-weight: bold;
  font-size: 1rem;
  width: 6em;
}

form {
  width: 100%;
}

/* 対象月と請求先*/
.billing-select {
  display: flex;
  align-items: flex-start;
  padding-top: 0.25rem;
  padding-bottom: 0.5rem;
}

/*請求先のselectのwith編集の為*/
#invoice {
  width: 100%;
}

/* 料金・使用料*/
.billing-payment {
  background-color: #1d5d9b;
  color: #fff;
  border-radius: 0.3125rem;
  padding: 0.5rem 0rem 0.5rem 1.5rem;
  align-items: center;
  margin: 0 0.5rem 0.5rem;
}

.billing-payment dt {
  font-size: 1rem;
  word-break: keep-all;
}

/* 料金・使用料*/
.billing-payment dd {
  margin-left: auto;
  color: #f4d160;
  font-weight: bold;
  font-size: 1.5rem;
  text-align: right;
  line-height: 1em;
  padding: 0.5rem ;
}

.billing-payment span {
  font-size: 0.7em;
  margin-left: 0.5rem;
}

/* 支払方法  */
.settlement {
  display: flex;
  flex-direction: column;
  padding-left: 0.5rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  font-size: 0.8rem;
  flex-grow: 1;
}

.settlement-detail {
  display: flex;
  background-color: #f6f4eb;
  border-radius: 0.3125rem; /*丸みを出す*/
  font-size: 0.8rem;
  padding-left: 1rem;
  margin: 0 0.5rem 0.5rem;
}

.settlement-fixed {
  margin: 0 auto;
}

.settlement-detail dt {
  font-weight: normal; /* フォントウェイトをデフォルトに設定 */
  white-space: nowrap; /*改行させない*/
}

dl {
  display: flex;
  margin-bottom: 0;
  margin-right: 0.5rem;
}

.settlement dd {
  padding-left: 0.5rem; /* これを外すとmargin-bottom: 0.5rem;が適応され文字が真ん中に来ない  */
}

dd {
  margin-bottom: 0;
}

/*請求書ダウンロードボタン＋未確定*/
.invoice {
  background-color: #4682a9;
  color: #fff;
  border-radius: 0.3125rem; /*丸みを出す*/
  border: none;
  text-align: center;
  padding: 0 1rem;
}

/*未確定*/
.pending {
  white-space: nowrap; /*改行させない*/
  display: flex;
  align-items: center;
  background-color: #757575;
}

#inovoice-download-button span {
  display: inline-block;
}

/* ご利用プラン */
.billing-plan {
  margin-top: 2rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
}

.billing-plan h3 {
  padding: 1rem 0.5rem 0.5rem 0rem;
  font-weight: bold;
  font-size: 1rem;
}

/*  table */
.table-contract {
  border: 0.0625rem solid #b8b8b8; /* 枠線のスタイルと太さを設定 */
  margin-bottom: 1rem;
  margin-left: 1rem;
  width: calc(100% - 2rem);
}

.table-contract th,
.table-contract td {
  border-bottom: 0.0625rem solid #b8b8b8; /* 下の横線を設定 */
  padding: 0.5rem 1rem 0.5rem 1rem;
  border-collapse: separate;
}

.table-contract th {
  position: relative; /*要素を相対的な位置に配置　背景の為の処理 */
  text-align: center;
  border-right: 0.0625rem solid #b8b8b8;
  font-weight: normal;
  word-break: keep-all; /*改行*/
}

/* 一つ目のtableのthの水色の背景の処理*/
.table-contract tbody tr:first-child th::before {
  top: 0.1rem;
}

.table-contract tbody tr:last-child th::before {
  bottom: 0.1rem;
}

.table-contract th::before {
  content: "";
  background-color: #badcee;
  position: absolute;
  left: 0.1rem;
  right: 0.1rem;
  top: 0;
  bottom: 0;
  z-index: -1;
}

#list2 th {
  text-align: center;
}

#list2 td {
  text-align: right;
  padding-left: 1rem;
  padding-right: 1rem;
}

#list2 .category {
  text-align: left;
}

/* 二つ目のtable*/
.div-table {
  padding-left: 0;
  padding-right: 0;
}

.table {
  background-color: #f6f4eb;
}

.item {
  color: #1d5d9b;
}

.table tbody tr:last-child td {
  background-color: #ede9d9;
  font-weight: bold;
}

#contract small {
  display: block;
  margin: 0 1rem;
}

/* ウェブサイト版 */
@media screen and (min-width: 1024px) {
  main {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .no-data {
    padding-left: 0rem;
  }

  /*対象月・請求先*/
  .billing-select h3 {
    font-size: 1.5rem;
  }

  .billing-select select {
    width: 100%;
    font-size: 1rem;
  }

  /* 料金・使用料*/
  .billing-payment {
    margin: 1rem 0 1rem 3rem; /*上　右　下　左*/
    width: 90%;
  }

  .billing-payment dt {
    margin: 0 auto 0;
    font-size: 1.5rem;
  }

  .billing-payment dd {
    font-size: 2.5rem;
  }

  /* お支払方法*/
  .settlement {
    margin: 0 auto 0;
  }

  .settlement-detail {
    margin-left: 3rem;
    margin-bottom: 1rem;
    font-size: 1.2rem;
    width: 90%;
  }

  .settlement-fixed {
    font-size: 1.2rem;
  }

  /*ご利用プラン*/
  .billing-plan h3 {
    font-size: 1.5rem;
  }

  .billing-plan select {
    width: 100%;
    font-size: 1rem;
  }
}

@media screen and (max-width: 408px) {
  /*1つ目のテーブル*/
  .table-contract {
    font-size: 0.875rem;
  }

  /*2つめのテーブル*/
  #list2 {
    font-size: 0.875rem;
  }
}

@media screen and (max-width: 320px) {
  /*〇月の料金・使用量*/
  .billing-payment dt {
    font-size: 0.625rem;
  }

  .billing-payment dd {
    font-size: 1rem;
    margin-left: 1rem;
  }

  .billing-payment span {
    font-size: smaller;
    padding-left: 0.2rem;
  }

  /*お支払方法*/
  .settlement-detail {
    font-size: 0.5rem; /* 画面が狭い場合のフォントサイズ */
  }

  .settlement {
    padding-left: 0rem;
  }

  /*1つ目のテーブル*/
  .table-contract {
    width: calc(80% - 2rem);
    margin-left: 0rem;
    font-size: 0.6875rem;
  }

  /*2つめのテーブル*/
  #list2 {
    font-size: 0.6875rem;
  }
}
